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

Quick Start

from wytness import AuditClient, audit_tool

# Initialize the client
client = AuditClient(
    agent_id="my-agent",
    human_operator_id="user-123",
)

# 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.7.0.tar.gz (278.9 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.7.0-py3-none-any.whl (16.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: wytness_sdk-0.7.0.tar.gz
  • Upload date:
  • Size: 278.9 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.7.0.tar.gz
Algorithm Hash digest
SHA256 ceb3cde93dd5f54be671c5b3589b14afe7d0db043b43810af327f95a95fa3b66
MD5 63ce37edbaaacd2feb10146f553903cf
BLAKE2b-256 f94455c67c2b48cf46266b5e1aeb5291e1d69fd67d33a3b395c6c638ed52eb80

See more details on using hashes here.

Provenance

The following attestation bundles were made for wytness_sdk-0.7.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.7.0-py3-none-any.whl.

File metadata

  • Download URL: wytness_sdk-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 16.8 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.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5b30aaaf3a88a95adf1e6cd15f48cbc9461608eb7b0f58eee3936af3269be7fa
MD5 b5617389ed8f9199970f6ed6ec6fec4f
BLAKE2b-256 bdb59de279a832bc185cae1ce41ff1f3b9db37af10182be873db7f778643ef34

See more details on using hashes here.

Provenance

The following attestation bundles were made for wytness_sdk-0.7.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