The 1Password Connect server provides a REST API that can be used to securely access data from your 1Password account. Learn more about setting up a Secrets Automation Workflow
You can use the 1Password command-line tool to set up a 1Password Connect server and issue tokens for it. Set up a 1Password Connect server:
op create connect server <name> --vaults <vault>[,<vault>]
You'll get a 1password-credentials.json
file that you'll use to deploy the Connect server.
Issue a token:
op create connect token <server_name> <token_name> --vault <vault_uuid>[,(r|w|rw)] [--vault <vault_uuid>[,(r|w|rw)]]
Deploying 1Password Connect requires 2 containers to be running in your infrastructure.
1password/connect-sync
: keeps information available on the server updated with 1Password.com1password/connect-api
: serves the Connect REST API
Deployment Examples:
The following environment variable configuration options are available for both contains:
OP_SESSION
: path to the 1password-credentials.json file. Defaults to~/.op/1password-credentials.json
.OP_HTTP_PORT
: port used by the HTTP server. Defaults to8080
OP_LOG_LEVEL
: set the logging level of the container. Defaults toinfo
.
All other configuration options are only relevant for the password/connect-api
container:
OP_HTTPS_PORT
: port used by the HTTP sever when TLS is configured (see below). Defaults to8443
.OP_SYNC_TIMEOUT
: define how long to wait for initial sync to complete. Defaults to10s
.
More information on configuration options
By default, 1Password Connect is configured for use within a trusted network. It is possible to enable TLS for the connection between your application and Connect. This can be done by either by providing your own certificate or by letting Connect request a certificate using Let's Encrypt.
Connect will listen on the port defined by HTTPS_PORT
(default 8443
) when TLS is enabled.
Provide own certificate
Connect can use a PEM-encoded private key and certificate by setting the following two environment variables for the connect-api
container:
OP_TLS_KEY_FILE
: path to the private key file.OP_TLS_CERT_FILE
: path to the certificate file. This should be the full certificate chain.
Use Let's Encrypt
Connect can also request a certificate from the Let's Encrypt CA.
For this, two environment variables have to be set for the connect-api
container:
OP_TLS_USE_LETSENCRYPT
: should be set to any value.OP_TLS_DOMAIN
: the (sub-)domain for which to request a certificate. The DNS-records for this domain must point to the Connect server.
As long as Connect is running, its HTTPS listener must be reachable on a public IP at port 443 (either by setting OP_HTTPS_PORT=443
or by forwarding traffic at port 443
to Connect's OP_HTTPS_PORT
) for the server to be able to refresh its Let's Encrypt certificate.