Skip to main content

Python SDK for Wytness — audit logging for AI agents with cryptographic signing and chain integrity

Project description

Wytness Python SDK

Audit logging for AI agents. Every action your AI agent takes is cryptographically signed, hash-chained, and streamed to the Wytness platform for compliance and observability.

Installation

pip install wytness-sdk

One-time setup — register your signing public key

On first run, the SDK generates an Ed25519 keypair at ./keys/signing.key. The Wytness API rejects events with 412 Precondition Failed until the matching public key is registered against your org. Print the public PEM:

wytness-show-public            # default ./keys/signing.key
# or:
python -m wytness.show_public

Paste the output into the Signing Key section of https://app.wytness.dev/keys. Wytness never sees your private key. Alternatively, click Generate Signing Key on the Keys page and drop the downloaded private key into ./keys/signing.key.

Quick Start

from wytness import AuditClient, audit_tool

# Initialize the client
client = AuditClient(
    agent_id="my-agent",
    human_operator_id="user-123",
    http_api_key="aa_live_...",   # from app.wytness.dev settings
)

# Decorate any tool your agent calls
@audit_tool(client=client)
def send_email(to: str, subject: str, body: str):
    # Your tool implementation
    pass

# Every call is automatically logged, signed, and chained
send_email(to="team@company.com", subject="Report", body="Weekly summary")

Features

  • Response capture — AI agent responses are automatically captured, truncated to 5K chars, and PII-redacted
  • PII redaction — emails, SSN, TFN, credit cards, and phone numbers are automatically redacted from responses and parameter values
  • Cryptographic signing — every event is signed with Ed25519
  • Hash chaining — tamper-evident chain of events per agent session
  • Automatic secret redaction — secrets in parameter names are automatically redacted
  • HTTP transport — stream events to api.wytness.dev over HTTPS
  • File fallback — events are saved locally if the API is unreachable

HTTP Emitter (Recommended)

Send events directly to the Wytness API using your API key:

client = AuditClient(
    agent_id="my-agent",
    human_operator_id="user-123",
    http_endpoint="https://api.wytness.dev",
    http_api_key="aa_live_...",
)

API

AuditClient(agent_id, **kwargs)

Parameter Type Default Description
agent_id str required Unique identifier for the agent
agent_version str "0.1.0" Version of the agent
human_operator_id str "unknown" ID of the human overseeing the agent
signing_key str|None None Base64-encoded Ed25519 private key (for serverless)
signing_key_path str "./keys/signing.key" Path to Ed25519 private key (auto-generated if missing). Ignored when signing_key is set.
http_api_key str|None None API key for HTTP endpoint
http_endpoint str "https://api.wytness.dev" HTTP API endpoint URL
fallback_log_path str "./audit_fallback.jsonl" Local fallback file path

@audit_tool(client, task_id="default")

Decorator that wraps a function to automatically log audit events. Works with both sync and async functions. Captures:

  • Function name, parameters (with secret redaction), and return value hash
  • Response text (truncated to 5K chars, PII-redacted) — the function's return value as a string
  • Execution duration, success/failure status, and error codes
  • Cryptographic signature and hash chain link

client.session_id

Read-only property returning the UUID for this client instance.

client.flush(timeout=5.0)

Wait for pending HTTP requests to complete. Call before process exit in serverless/short-lived environments.

hash_value(value)

SHA-256 hash of any JSON-serialisable value. Use this when recording events manually to compute inputs_hash / outputs_hash.

from wytness import hash_value

result = my_tool(data)
outputs_hash = hash_value(result)

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

wytness_sdk-0.8.0.tar.gz (282.0 kB view details)

Uploaded Source

Built Distribution

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

wytness_sdk-0.8.0-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

Details for the file wytness_sdk-0.8.0.tar.gz.

File metadata

  • Download URL: wytness_sdk-0.8.0.tar.gz
  • Upload date:
  • Size: 282.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for wytness_sdk-0.8.0.tar.gz
Algorithm Hash digest
SHA256 151711212e70a361777a2143d900209969102db696e026cc41301ac1bab6b76e
MD5 d41d1cd4c4e091f854a11dc0a7b416c1
BLAKE2b-256 a30e804a47a0dfaabe9430f24687e2bf8e479158c730779d179659a2d3af1eb2

See more details on using hashes here.

Provenance

The following attestation bundles were made for wytness_sdk-0.8.0.tar.gz:

Publisher: publish-python-sdk.yml on imwickkd/wytness

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

File details

Details for the file wytness_sdk-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: wytness_sdk-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 18.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for wytness_sdk-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a31fff54224cba331111593d64adaaa0b190f613dd5faf7eefd02ddc3c08f4b6
MD5 8f5d293b148e59fc4b701eba804d77d9
BLAKE2b-256 99b5d64528a17f4ffbc0922ef56b3827a339c6604ce58c08fc5f8731e9e78fc4

See more details on using hashes here.

Provenance

The following attestation bundles were made for wytness_sdk-0.8.0-py3-none-any.whl:

Publisher: publish-python-sdk.yml on imwickkd/wytness

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