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.0.2.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.2-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: zeno_secrets_1password-1.0.2.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.0.2.tar.gz
Algorithm Hash digest
SHA256 361e64616611ec65d406cd6fb547adad03a207b963d4aca16b002938e11a43d6
MD5 2d730463735c73063f9e869464840022
BLAKE2b-256 4814f89a623b4b6ddb336d35000751143e12da906598cedb5380f41363bb8d5e

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for zeno_secrets_1password-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4fb800431d86058f259587649ba26c56a8cf7f4c9677b4342e5fe6f06e61efe7
MD5 d6dcb4ca6a56924fe379f22312382b74
BLAKE2b-256 71915571b3562b656be2883a528e1bab92df29a6e144c0abe1f1e18db0b039d8

See more details on using hashes here.

Provenance

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