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.ai 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.0.0rc1.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.0.0rc1-py3-none-any.whl (6.4 kB view details)

Uploaded Python 3

File details

Details for the file zeno_secrets_1password-1.0.0rc1.tar.gz.

File metadata

File hashes

Hashes for zeno_secrets_1password-1.0.0rc1.tar.gz
Algorithm Hash digest
SHA256 0bb729666dd63f59b0f4b0fda7623da78bf92d095568400a0aef6d69ee1d5c4b
MD5 63bc92d3dbd5a1d1152c18ed38afcf77
BLAKE2b-256 15e09645386c50e232c1510c8fc42825b20efc06f020244a538a890841955819

See more details on using hashes here.

Provenance

The following attestation bundles were made for zeno_secrets_1password-1.0.0rc1.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.0.0rc1-py3-none-any.whl.

File metadata

File hashes

Hashes for zeno_secrets_1password-1.0.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 974c8a990b341d12674837d67130dd7d412c0b5871a3f582125b6685ee92dfdb
MD5 0ff6c19e4952b158bbb9439657ae6bda
BLAKE2b-256 e25cc4536f0651ab7685dcd5372f5f467e473df05371ef5e3fb908e089ca7d94

See more details on using hashes here.

Provenance

The following attestation bundles were made for zeno_secrets_1password-1.0.0rc1-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