Skip to main content

Zeno secrets adapter: 1Password CLI-backed `SecretsStore` for agent runtime secrets.

Project description

zeno-secrets-1password

1Password-backed SecretsStore for Zeno.

Ships OpCliSecretsStore, a SecretsStore adapter that reads secrets through the 1Password CLI (op read). Intended for agents that run in environments where a 1Password service-account token is available but mounting the raw secret material into the process env is undesirable.

Install

uv add 'zeno-framework[secrets-1password]'

Install the 1Password CLI on the host:

brew install 1password-cli       # macOS
# or follow https://developer.1password.com/docs/cli/get-started/

Export a service-account token:

export OP_SERVICE_ACCOUNT_TOKEN="ops_..."

Usage

from zeno.app import ZenoApp
from zeno.secrets_1password import OpCliSecretsStore

app = ZenoApp(
    ...,
    secrets=OpCliSecretsStore(
        references={
            "OPENAI_API_KEY": "op://Engineering/openai/credential",
            "STRIPE_KEY":     "op://Engineering/stripe/api_key",
        },
        cache_ttl=60.0,
    ),
)

Inside a tool:

@tool
async def call_stripe(ctx: Ctx) -> str:
    api_key = await ctx.secrets.get("STRIPE_KEY")
    ...

What it does

  • get(name) — if name begins with op://, invokes op read name directly; otherwise looks up the reference in the references map and shells op read <ref>.
  • Results are cached in-process for cache_ttl seconds (default 60). Pass cache_ttl=None to disable caching.
  • Invocations time out at timeout seconds (default 5). The subprocess is killed and reaped on timeout; no ResourceWarning leaks.
  • OP_SERVICE_ACCOUNT_TOKEN is passed to the subprocess via an explicit env dict that inherits only PATH — unrelated parent env vars are not leaked into the op process. Pass token="ops_..." to the constructor to override the env var.
  • Missing op binary → ConfigurationError with an install pointer.
  • Missing token → ConfigurationError raised before the subprocess runs.
  • op read exit codes are inspected: "item not found" / "no such" / "isn't an item" map to SecretNotFoundError; everything else (auth failures, network errors) maps to SecretsBackendError with the stderr text preserved in the message.

Why op CLI, not the Connect HTTP API?

The CLI path works both locally (via 1Password desktop auth) and in CI (via a service-account token) with no Connect server to self-host. Connect-based and SDK-based stores can ship later as sibling classes inside the same package without breaking existing callers.

Part of the Zeno framework.

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

zeno_secrets_1password-1.1.0.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

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

zeno_secrets_1password-1.1.0-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

Details for the file zeno_secrets_1password-1.1.0.tar.gz.

File metadata

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

File hashes

Hashes for zeno_secrets_1password-1.1.0.tar.gz
Algorithm Hash digest
SHA256 e675a1ae534828b7c4a707bf7b21356143d164c49928a76491de69d0cbaef4b0
MD5 651f4d6dd445d81052e202c100756f01
BLAKE2b-256 2dc3321ae6134e1443dc4cb25b6799edeac6b7a9b46c1bc80bc7fb20f33914fc

See more details on using hashes here.

Provenance

The following attestation bundles were made for zeno_secrets_1password-1.1.0.tar.gz:

Publisher: publish.yml on nkootstra/zeno

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

File details

Details for the file zeno_secrets_1password-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for zeno_secrets_1password-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 84909c563aac79c47cef8b8fccdf7484474522f3057373f158fbfcc6960bb52f
MD5 b6bdac3d70e61089b0e70a751b98b5a2
BLAKE2b-256 1d4897fb3fe2f020165eac7022d962de33e0f0ef4eb972170d9de6772a7b54c8

See more details on using hashes here.

Provenance

The following attestation bundles were made for zeno_secrets_1password-1.1.0-py3-none-any.whl:

Publisher: publish.yml on nkootstra/zeno

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