Providers
AI agents typically need credentials to access external services: an API key for the AI model provider, a token for GitHub or GitLab, and so on. OpenShell manages these credentials as first-class entities called providers.
Create and manage providers that supply credentials to sandboxes.
Providers v2 is available for profile-backed provider policy, provider-owned network rules, and gateway-managed credential refresh. This page remains the credential-focused provider command reference. For the new workflow, see Providers v2.
Provider profiles include metadata for known endpoints and binaries. View the available profiles before creating a provider:
Create a Provider
Providers can be created from local environment variables or with explicit credential values.
For refresh-backed providers such as google-vertex-ai --from-gcloud-adc, openshell provider create now waits for the gateway to configure refresh metadata and mint the initial access token before it reports success.
From Local Credentials
The fastest way to create a provider is to let the CLI discover credentials from your shell environment:
This reads ANTHROPIC_API_KEY or CLAUDE_API_KEY from your current environment
and stores them in the provider.
With Explicit Credentials
Supply a credential value directly:
Bare Key Form
Pass a key name without a value to read the value from the environment variable of that name:
This looks up the current value of $API_KEY in your shell and stores it.
Provider profile metadata is available for known provider types. Provider profile network policy is gateway opt-in:
Without providers_v2_enabled=true, provider behavior remains credential-only.
When providers_v2_enabled=true, --from-existing uses profile-backed
discovery instead of the legacy provider registry. The requested --type must
have a built-in or imported provider profile with a discovery section. If no
matching profile exists, the CLI returns an error instead of falling back to
legacy discovery.
Manage Providers
List, inspect, update, and delete providers from the active gateway.
List all providers:
Use -o json or -o yaml for machine-readable output:
Structured output includes provider metadata (id, name, type), credential key names, config key names, labels, creation timestamp, resource version, and credential expiration times. Only credential and config keys are exposed, never values, preventing accidental credential leakage in logs or output. For details on how credentials are injected into sandboxes, refer to Credential Injection.
Inspect a provider:
Update a provider’s credentials:
Set or clear a credential expiry timestamp:
Use 0 as the timestamp to clear expiry for a credential key.
Credential Refresh
Provider refresh stores non-injectable refresh material separately from the provider’s current credential values. The gateway can mint OAuth2 refresh-token tokens, OAuth2 client credentials tokens, and Google service account JWT tokens, then write the current access token back to the provider record for sandbox injection.
Configure refresh metadata for one injectable credential key:
Check refresh status:
Delete refresh metadata for a credential:
Force a gateway-managed refresh for one credential:
External refresh systems should continue to push new current credentials through
openshell provider update. The --credential-expires-at option works for
static credentials, externally refreshed credentials, and gateway-managed
refresh strategies.
Delete a provider:
Attach Providers to Sandboxes
Pass one or more --provider flags when creating a sandbox:
Each --provider flag attaches one provider. The sandbox receives all
credentials from every attached provider at runtime. Profile-managed providers
also contribute provider-generated network policy entries when
providers_v2_enabled is enabled at the gateway. When the setting is disabled,
providers keep the previous behavior and only provide credentials.
Legacy provider attachment is fixed at sandbox creation time. Providers v2 adds
openshell sandbox provider attach and openshell sandbox provider detach for
running sandboxes. See Providers v2
for runtime attach and detach behavior.
Auto-Discovery Shortcut
When providers_v2_enabled=false and the trailing command in
openshell sandbox create is a recognized tool name (claude, codex, or
opencode), the CLI auto-creates the required provider from your local
credentials if one does not already exist. You do not need to create the
provider separately:
This detects claude as a known tool, finds your ANTHROPIC_API_KEY, creates
a provider, attaches it to the sandbox, and launches Claude Code.
Providers v2 disables command-derived provider inference. When
providers_v2_enabled=true, create or import the provider profile, create the
provider instance, and pass --provider <name> explicitly.
How Credential Injection Works
The agent process inside the sandbox never sees real credential values. At startup, the proxy replaces each credential with an opaque placeholder token in the agent’s environment. When the agent sends an HTTP request containing a placeholder, the proxy resolves it to the real credential before forwarding upstream.
This resolution requires the proxy to see plaintext HTTP. Endpoints must use protocol: rest in the policy (which auto-terminates TLS) or explicit tls: terminate. Endpoints without TLS termination pass traffic through as an opaque stream, and credential placeholders are forwarded unresolved.
Supported injection locations
The proxy resolves credential placeholders in the following parts of an HTTP request:
The proxy does not modify request bodies, cookies, or response content.
Fail-closed behavior
If the proxy detects a credential placeholder in a request but cannot resolve it, it rejects the request with HTTP 500 instead of forwarding the raw placeholder to the upstream server. This prevents accidental credential leakage in server logs or error responses.
Example: Telegram Bot API (path-based credential)
Create a provider with the Telegram bot token:
The agent reads TELEGRAM_BOT_TOKEN from its environment and builds a request like POST /bot<placeholder>/sendMessage. The proxy resolves the placeholder in the URL path and forwards POST /bot123456:ABC-DEF/sendMessage to the upstream.
Example: Google API (query parameter credential)
The agent sends GET /youtube/v3/search?part=snippet&key=<placeholder>. The proxy resolves the placeholder in the query parameter value and percent-encodes the result before forwarding.
Supported Provider Types
The following provider types are supported.
ANTHROPIC_API_KEY is an API key from console.anthropic.com, not a subscription token. Subscription users must generate a separate API key from the Anthropic Console.
Use the generic type for any service not listed above. You define the
environment variable names and values yourself with --credential.
Supported Inference Providers
The following providers have been tested with inference.local. Any provider that exposes an OpenAI-compatible API works with the openai type. Set --config OPENAI_BASE_URL to the provider’s base URL and --credential OPENAI_API_KEY to your API key.
Refer to your provider’s documentation for the correct base URL, available models, and API key setup. For the Vertex-specific auth flows and config keys, refer to Google Vertex AI. To configure inference routing, refer to Inference Routing.
Next Steps
Explore related topics:
- To control what the agent can access, refer to Policies.
- To use the base sandbox container, refer to Sandboxes.
- To view the complete field reference for the policy YAML, refer to the Policy Schema Reference.