Skip to main content

Python SDK for System Capability Protocol - programmatic manifest/graph access and integration framework

Project description

SCP SDK

Python SDK for the System Capability Protocol (SCP) - programmatic access to manifests and graphs, plus a framework for building integrations.

Features

  • Core Models: Type-safe Pydantic models for SCP v0.1 manifests
  • Graph Abstraction: Efficient querying and traversal of system dependencies
  • Integration Framework: Reusable base classes and utilities for building integrations (60-80% code reduction)
  • Fully Tested: Comprehensive test suite with pytest

Documentation

Architecture

The SDK is composed of three main layers:

  1. Core (scp_sdk.core): Defines the data models (SCPManifest, System, Dependency) and the Graph abstraction for analyzing architecture.
  2. Integrations (scp_sdk.integrations): Provides a framework (IntegrationBase, IntegrationConfig) for syncing SCP data to external tools (PagerDuty, ServiceNow, etc.).
  3. Utilities (scp_sdk.utils): Helper functions for tier handling and common tasks.

Installation

# Using uv (recommended)
cd /path/to/scp-sdk
uv sync

# Or with pip
pip install -e .

Quick Start

Load and Query Manifests

from scp_sdk import Manifest

# Load from file
manifest = Manifest.from_file("scp.yaml")

# Or from YAML string
yaml_str = """
scp: "0.1.0"
system:
  urn: "urn:scp:payment-service"
  name: "Payment Service"
  classification:
    tier: 1
"""
manifest = Manifest.from_yaml(yaml_str)

# Query
print(manifest.urn)  # urn:scp:payment-service
print(manifest.tier)  # 1
print(manifest.team)  # team name

# Get specific dependency
dep = manifest.get_dependency("urn:scp:user-service")
print(dep.criticality)  # required

Build and Query Graphs

from scp_sdk import Graph

# Load from unified JSON (from scp-cli scan --export json)
graph = Graph.from_file("graph.json")

# Or build from manifests
graph = Graph.from_manifests([manifest1, manifest2])

# Query
for system in graph.systems():
    print(system.name)

# Find system
payment_svc = graph.find_system("urn:scp:payment-service")

# Get dependencies
deps = graph.dependencies_of(payment_svc)

# Get blast radius (what depends on this system)
dependents = graph.dependents_of(payment_svc)

Build Custom Integrations

The SDK makes building integrations incredibly simple:

from scp_sdk.core.graph import SystemNode, DependencyEdge
from scp_sdk.integrations.base import IntegrationBase
from scp_sdk.integrations.registry import register_integration

@register_integration("pagerduty")
class PagerDutyIntegration(IntegrationBase):
    """Sync SCP systems to PagerDuty services."""

    def sync_system(self, system: SystemNode) -> None:
        """Create/update PagerDuty service."""
        service_data = {
            "name": system.name,
            "description": f"SCP System: {system.urn}",
            "escalation_policy": self.get_policy(system.team),
        }
        # Call PagerDuty API...

    def sync_dependency(self, edge: DependencyEdge) -> None:
        """Sync dependency (optional for PagerDuty)."""
        pass

# Usage
from scp_sdk.integrations.config import IntegrationConfig

config = IntegrationConfig(name="pagerduty", auth={...})
integration = PagerDutyIntegration(config)
result = integration.sync(graph)

The SDK handles:

  • Graph iteration
  • Error handling & retries
  • Logging
  • Dry-run mode
  • ID caching
  • Field mapping utilities

Development

# Install dependencies
make setup

# Run tests
make test

# Run linter
make lint

# Format code
make format

# Type check
make typecheck

# Run all checks
make check

# Run examples
make examples

Examples

See the examples/ directory:

Run them with:

uv run python examples/basic_usage.py
uv run python examples/custom_integration.py

Related Projects

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

scp_sdk-0.2.1.tar.gz (92.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

scp_sdk-0.2.1-py3-none-any.whl (32.8 kB view details)

Uploaded Python 3

File details

Details for the file scp_sdk-0.2.1.tar.gz.

File metadata

  • Download URL: scp_sdk-0.2.1.tar.gz
  • Upload date:
  • Size: 92.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for scp_sdk-0.2.1.tar.gz
Algorithm Hash digest
SHA256 f1943e214bf5ce7d6f8bb138c65fde164ee34d2e75cf1f1efac0969a35221988
MD5 aba068c879fec614019e18da9afbc598
BLAKE2b-256 e9a262da151ed589e63e3b69f82d047f99260f4ff53d2bcce93d0a2807bc2677

See more details on using hashes here.

Provenance

The following attestation bundles were made for scp_sdk-0.2.1.tar.gz:

Publisher: ci.yml on krackenservices/scp-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file scp_sdk-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: scp_sdk-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 32.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for scp_sdk-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c6beef047939234b4b024d13ac1231193d97c8f6bd033a5a9c7f2d2c98233320
MD5 985a6123e2fc3f4f9406de3fc2a250bc
BLAKE2b-256 593924169628569dcace5312a7e183b280e01ceedd8e861d15d9e83eececf809

See more details on using hashes here.

Provenance

The following attestation bundles were made for scp_sdk-0.2.1-py3-none-any.whl:

Publisher: ci.yml on krackenservices/scp-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page