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.0rc2.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.0rc2-py3-none-any.whl (6.4 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for zeno_secrets_1password-1.0.0rc2.tar.gz
Algorithm Hash digest
SHA256 3c26a534c43f3f3cf83a6ab3d9398f01fbbbba652434d574908cead5e12e57d1
MD5 2b828ebe59a346f45fc5d0c793967442
BLAKE2b-256 450693d0a1a52a310b2cfb20c6db42a1d162104e30dc8b9245344bfdd535b840

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for zeno_secrets_1password-1.0.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 12beacdac8b3da01a4ddaa35039b4c17d19acb95d990042803199cd99c350756
MD5 095e505ffe455b3c4f8f25b1cb4755e2
BLAKE2b-256 acbd3d3c1fb05e9455a43cf1f9d50e4741d918569b24f37226c4d4dd00e41811

See more details on using hashes here.

Provenance

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