Manage secrets
Kalix provides secret management for each project. Secrets are for passwords, login credentials, keys, etc. You can provide secrets to your services through environment variables. When you display the service information, the content of the secrets will not displayed.
Manage secrets in a project
Adding secrets
To add secrets to your Kalix project, you can use the Akka CLI.
| To mark your project as the target of subsequent commands, use the following command:  | 
When you create a secret, it contains:
- 
secret name 
- 
contents (as key/value pairs) 
- CLI
- 
Use the akka secret createcommand.akka secret create generic db-secret \ (1) --literal username=admin \ --literal pwd=my_passwd (2)1 Secret name 2 Contents (as key/value pairs) You can also set a secret from a file, using the --from-fileargument:akka secret create generic some-key \ --from-file key=path/to/my-key-file
Updating secrets
- CLI
- 
Secrets can be updated using the akka secret updatecommand, in the same way as theakka secret createcommand:akka secret update generic db-secret \ --literal username=new-username \ --literal pwd=new-password
Listing secrets
To list the secrets in your Kalix project, you can use the Akka CLI or the Kalix Console. For security purposes, they only show content keys. Neither the CLI nor the Console will show content values of a secret.
- CLI
- 
Use the akka secret listcommand:akka secret listThe results should look something like: NAME TYPE KEYS db-secret generic username,pwd 
- Console
- 
- 
Sign in to your Kalix account at: https://console.kalix.io/ 
- 
Click the project for which you want to see the secrets. 
- 
Using the left pane or top navigation bar, click Secrets to open the Secrets page which lists the secrets. 
 
- 
Display secret contents
To display secret contents for your Kalix project, you can use the Akka CLI or the Kalix Console. For security purposes, they only show content keys. Neither the CLI nor the Console will show content values of a secret.
- CLI
- 
Use the akka secret getcommand:akka secret get <secret-name>The results should look something like: NAME: db-secret KEYS: username pwd 
- Console
- 
- 
Sign in to your Kalix account at: https://console.kalix.io/ 
- 
Click the project for which you want to see the secrets. 
- 
Using the left pane or top navigation bar, click Secrets to open the Secrets page which lists the secrets. 
- 
Click the secret you wish to review. 
 
- 
Set secrets as environment variables for a service
To set secrets as environment variables for a service, you can use the Akka CLI.
- CLI
- 
akka service deploycommand with parameter--secret-env:akka service deploy --classic <service-name> <container-image> \ --secret-env MY_VAR1=db-secret/username,MY_VAR2=db-secret/pwd (1)1 The value for an environment variable that refers to a secret is of the form <secret-name>/<secret-key>
Display secrets as environment variables for a service
To set secrets as environment variables for a service, you can use the Akka CLI or the Kalix Console.
- CLI
- 
akka service get:akka service get <service-name>The results should look something like: Service: <service-name> Created: 24s Description: Status: Running Image: <container-image-path> Env variables: MY_VAR1=db-secret/username MY_VAR2=db-secret/pwd Generation: 1 Store: <store-name> 
- Console
- 
- 
Sign in to your Kalix account at: https://console.kalix.io/ 
- 
Click the project to which your service belongs. 
- 
Click the service. 
- 
In the Properties: <service-name>panel, you should see the environment variables.
 
-