Skip to main content

Python SDK for CRP-Comply — EU AI Act & GDPR compliance automation

Project description

crp-comply-sdk

PyPI Python License

Python SDK for CRP-Comply — EU AI Act & GDPR compliance automation. A thin, typed HTTP client covering every user-facing endpoint of the CRP-Comply REST API.

Install

pip install crp-comply-sdk

Quick Start

from crp_comply_sdk import CRPComply

with CRPComply(api_key="crp_...") as client:
    # Account
    me = client.me()
    usage = client.usage()

    # EU AI Act Article 6 risk classification
    risk = client.risk_assessment(
        system_name="Hiring Assistant",
        category="employment",
        affects_fundamental_rights=True,
    )

    # GDPR Article 35 DPIA
    dpia = client.dpia(
        system_name="Hiring Assistant",
        data_subjects=["candidates", "employees"],
        makes_automated_decisions=True,
    )

    # Full conformity evidence pack (zip with manifest + HMAC)
    pack = client.evidence_pack(system_name="Hiring Assistant", category="employment")
    zip_bytes = client.download_evidence_pack(pack["pack_id"])
    with open("evidence.zip", "wb") as f:
        f.write(zip_bytes)

API Surface

All methods are keyword-only. Every call is tier-gated server-side — a CRPComplyTierError is raised with an upgrade_url when a feature isn't available on your plan.

Compliance generation

Method Endpoint Purpose
risk_assessment(...) POST /risk-assessment EU AI Act Article 6
compliance_report(..., markdown=False) POST /compliance-report[/markdown] Full compliance status
dpia(...) POST /dpia GDPR Article 35 DPIA
transparency(system_name=...) POST /transparency AI Act Article 13
technical_docs(system_name=...) POST /technical-docs AI Act Article 11
audit_session(session_file=...) POST /audit Audit a CRP session
full_report(...) POST /full-report Markdown mega-report

Evidence packs

Method Endpoint
evidence_pack(...) POST /evidence-pack — build new pack
list_evidence_packs() GET /evidence-packs
get_evidence_pack(pack_id) GET /evidence-packs/{id} — manifest
download_evidence_pack(pack_id) GET /evidence-packs/{id}/download — raw zip bytes
delete_evidence_pack(pack_id) DELETE /evidence-packs/{id}

Persisted reports

Method Endpoint
list_reports(kind=None) GET /reports?kind=...
get_report(report_id) GET /reports/{id}
get_report_markdown(report_id) GET /reports/{id}/markdown — returns str
delete_report(report_id) DELETE /reports/{id}

SDK gateway (realtime checks)

Method Endpoint
features() GET /sdk/features — tier feature matrix
audit(prompt=..., response=...) POST /sdk/audit — PII + injection + risk
classify_risk(...) POST /sdk/classify — quick AI Act bucket

Account

Method Endpoint
health() GET /health (unauthenticated)
me() GET /me — profile + tier + provider status
usage() GET /usage — monthly quota breakdown

Configuration

Option Env var Default
api_key CRP_COMPLY_API_KEY — (required)
base_url CRP_COMPLY_BASE_URL https://api.crp-comply.com/api/v1
timeout 60 seconds
import os
os.environ["CRP_COMPLY_API_KEY"] = "crp_..."
os.environ["CRP_COMPLY_BASE_URL"] = "https://api.crp-comply.com/api/v1"

from crp_comply_sdk import CRPComply
client = CRPComply()  # picks up env vars

LLM Backends

CRP-Comply is LLM-agnostic. Configure your preferred backend server-side at Settings → LLM Provider. Supported:

Backend Default URL Notes
OpenAI https://api.openai.com/v1 Cloud
Anthropic https://api.anthropic.com/v1 Cloud
LM Studio http://localhost:1234/v1 Local, OpenAI-compatible
Ollama http://localhost:11434/v1 Local, OpenAI-compatible
Custom any Any OpenAI-compatible endpoint

Exception Hierarchy

CRPComplyError              # base — all SDK errors
├── CRPComplyAuthError      # 401, 403 — invalid / missing API key
├── CRPComplyQuotaError     # 429 — monthly quota exhausted (has .upgrade_url)
├── CRPComplyTierError      # 402 — feature not in tier (has .upgrade_url,
│                           #       .feature, .current_tier, .required_tier)
└── CRPComplyServerError    # 5xx — server-side failure
from crp_comply_sdk import CRPComply, CRPComplyTierError, CRPComplyQuotaError

try:
    pack = client.evidence_pack(system_name="X", category="y")
except CRPComplyTierError as exc:
    print(f"Upgrade required: {exc.upgrade_url}")
except CRPComplyQuotaError as exc:
    print(f"Quota exhausted. Upgrade at {exc.upgrade_url}")

License

Apache-2.0 — see LICENSE.

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

crp_comply_sdk-0.1.0.tar.gz (12.0 kB view details)

Uploaded Source

Built Distribution

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

crp_comply_sdk-0.1.0-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file crp_comply_sdk-0.1.0.tar.gz.

File metadata

  • Download URL: crp_comply_sdk-0.1.0.tar.gz
  • Upload date:
  • Size: 12.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for crp_comply_sdk-0.1.0.tar.gz
Algorithm Hash digest
SHA256 009ac3dc8c4b7f5d62b6c3cf1e5ccaf530fd4dabaad22c58af9c321b129ada49
MD5 01210e995712981e626d8397ea35fcc1
BLAKE2b-256 7077e1c6a84c541c2f0fc6660972db4df43b6f901b615b48129672387d393cd3

See more details on using hashes here.

File details

Details for the file crp_comply_sdk-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: crp_comply_sdk-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for crp_comply_sdk-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e2061bb04470d77b066e8a9b91bc2ee3521fccad8949029b88a759f90fb918d4
MD5 97377b5accb0b131f2585218779ad4bc
BLAKE2b-256 0bd1eb650ae110f0cb48e11268642723bd05fee83be65e74c25acaa3587a1160

See more details on using hashes here.

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