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

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.0.tar.gz (78.5 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.0-py3-none-any.whl (25.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: scp_sdk-0.2.0.tar.gz
  • Upload date:
  • Size: 78.5 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.0.tar.gz
Algorithm Hash digest
SHA256 8818f3d7503f3a28b2052bafee478fb0cf1162621dc291e356a4987a2bc1fd1e
MD5 eafb17366a021a8cd9d6a8945ebfb918
BLAKE2b-256 9b792de83c898120cbdb39022d055bccb690a8f5de11219a4da80e1086368dfc

See more details on using hashes here.

Provenance

The following attestation bundles were made for scp_sdk-0.2.0.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.0-py3-none-any.whl.

File metadata

  • Download URL: scp_sdk-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 25.5 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 34c05ff3c8e0dad1c183e87d279032e7870dd7890af1e343e616e11320e8e5ba
MD5 de6ebaba6036beaaf4d32b678d388e3a
BLAKE2b-256 e7b61789d6ed1cd30f2735713b20f98ae2f61e399c33cc67808f227b0c21e24e

See more details on using hashes here.

Provenance

The following attestation bundles were made for scp_sdk-0.2.0-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