Skip to main content

Python SDK for Certivu — quantum-resistant trust infrastructure for AI-generated content

Project description

certivu-python

Python SDK for Certivu — quantum-resistant trust infrastructure for AI-generated content.

Install

pip install certivu

Quick start

from certivu import CertivuClient

client = CertivuClient(
    api_key="ctv_key_abc123",
    generator_id="your-generator-uuid",
)

# Sign AI-generated content — images, audio, or text; format auto-detected
result = client.sign(content=image_bytes, model="stable-diffusion-xl")
# result.signed_content — bytes of the signed file (serve this, not the original)
# result.token         — ctv_ provenance token
# result.format        — 'image' | 'audio' | 'text'

# Sign audio or text explicitly
result = client.sign(content=pdf_bytes, model="gpt-4o", format="text")

# Verify — no API key needed, always free
result = client.verify(content=image_bytes)
if result.authentic and result.confidence == "high":
    print(result.provenance.org, result.provenance.signed_at)

# Verify without re-uploading the image
status = client.get_token_status("ctv_7f3kx9mq2...")

# Batch verify
results = client.verify_batch([
    {"content": image1_bytes},
    {"content": image2_bytes, "token": "ctv_..."},
])

# Audit log
page = client.get_audit_log(page=1, limit=50)

Async

from certivu import AsyncCertivuClient

async with AsyncCertivuClient(api_key="ctv_key_abc123") as client:
    result = await client.verify(content=image_bytes)
    results = await client.verify_batch([{"content": img} for img in images])

Generator setup

  1. Create a generator in the dashboard and select its supported formats (image, audio, text).

  2. Copy the generator ID and your org API key.

  3. Sign content — all cryptography (ML-DSA, watermarking, hashing) is handled server-side:

    result = client.sign(
        content=file_bytes,
        model="stable-diffusion-xl",
        generator_id="gen_xyz",
    )
    output_file.write(result.signed_content)
    

Confidence levels

Confidence Meaning
high Watermark ✓ + Record ✓ + Signature ✓ — full chain intact
medium Record ✓ + Signature ✓ — re-uploaded without watermark
low Partial signals — something is off
none Not signed by Certivu — no claim either way

Links

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

certivu-2.1.0.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

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

certivu-2.1.0-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file certivu-2.1.0.tar.gz.

File metadata

  • Download URL: certivu-2.1.0.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for certivu-2.1.0.tar.gz
Algorithm Hash digest
SHA256 935b75fd597e747582664f94d97146b13d49e239f7037682996b1dcd7557ea45
MD5 badc2d08c4016d2c135471cbdb7542f4
BLAKE2b-256 63d5bdb0c99ec29c6268df2e30a4b7a882076b96c46ba2d100704cc4425da536

See more details on using hashes here.

File details

Details for the file certivu-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: certivu-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 9.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for certivu-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f6115e78b8dc796b14801aff551723c090dd37a72b0d29be0376c00cbaa60986
MD5 8fd4eed7b2a69b0c01f31888bd28da22
BLAKE2b-256 f00562b14923c68a7d0aa281cfde40cc19d91e5674288649b2685a8bc8455cb5

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