Skip to main content

OCC cryptographic proof signing for Google Gemini

Project description

occ-gemini

OCC cryptographic proof signing for Google Gemini.

Every tool/function call produces an Ed25519-signed proof entry in proof.jsonl, creating a tamper-evident audit log of agent actions.

Install

pip install occ-gemini

Quick Start

Wrap a Model (recommended)

import google.generativeai as genai
from occ_gemini import wrap_model

model = genai.GenerativeModel("gemini-pro")
safe_model = wrap_model(model)
response = safe_model.generate_content("What's the weather?")
# proof.jsonl now contains signed proof entries for any function calls

Decorate Individual Tools

from occ_gemini import occ_tool

@occ_tool
def get_weather(location: str) -> str:
    return f"Sunny in {location}"

Custom Signer

from occ_gemini import OCCSigner, wrap_model

signer = OCCSigner(state_dir="/tmp/.occ", proof_file="audit.jsonl")
safe_model = wrap_model(model, signer=signer)

Proof Format

Each line in proof.jsonl is a JSON object:

{
  "version": "occ/proof/1",
  "timestamp": "2026-03-20T12:00:00.000Z",
  "signer": "<base64url-ed25519-public-key>",
  "payload": {
    "type": "tool-call",
    "tool": "get_weather",
    "inputHash": "<sha256-hex>",
    "outputHash": "<sha256-hex>"
  },
  "signature": "<base64url-ed25519-signature>",
  "prev": "<sha256-hex-of-previous-proof>"
}

Proofs are chained: each proof's prev field contains the SHA-256 hash of the previous proof's canonical JSON.

Configuration

  • State directory: Keypair stored in .occ/signer-state.json (defaults to CWD)
  • Proof file: Defaults to proof.jsonl in CWD
  • Both configurable via OCCSigner(state_dir=..., proof_file=...)

License

Apache-2.0

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

occ_gemini-0.1.0.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

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

occ_gemini-0.1.0-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for occ_gemini-0.1.0.tar.gz
Algorithm Hash digest
SHA256 bea68617c9fd24c375313a2f0a0eaa8937eb55c602ce824b801091add90240b7
MD5 cf02f790d38a59947f262cefef02fd36
BLAKE2b-256 afae7972d041ed2dd44bdedd2b96cf572f35eb0298de6e9333423d52ddf226d2

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for occ_gemini-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f234e0be7eb53f83f648b1a13f08e3dde06e66f4636484fcf6723ae68ddc1db0
MD5 aed5e8266e19a4e803356770834a273e
BLAKE2b-256 d8a905dfd4ac67718a14b68810c5b18b241dee925d35a3d05fb976d340e3a31b

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