CLI
Command Line Interface (CLI)
There are a handful of ways to interact with the Akeyless Platform for managing, creating, and fetching multiple types of supported secrets. One of them is our Command Line Interface (CLI).
The Akeyless CLI has a pre-compiled binary version for Linux, macOS, and Windows which can be easily installed.
Download
To pull the latest CLI version from the Akeyless official bucket, please make sure that: https://akeyless-cli.s3.*
endpoint is trusted.
Run the following command to download and install the CLI binary:
curl -o akeyless https://akeyless-cli.s3.us-east-2.amazonaws.com/cli/latest/production/cli-linux-amd64
chmod +x akeyless
./akeyless
curl -o akeyless https://akeyless-cli.s3.us-east-2.amazonaws.com/cli/latest/production/cli-linux-arm64
chmod +x akeyless
./akeyless
curl -o akeyless https://akeyless-cli.s3.us-east-2.amazonaws.com/cli/latest/production/cli-darwin-amd64
chmod +x akeyless
./akeyless
curl -o akeyless https://akeyless-cli.s3.us-east-2.amazonaws.com/cli/latest/cli-darwin-arm64
chmod +x akeyless
./akeyless
curl -o akeyless.exe https://akeyless-cli.s3.us-east-2.amazonaws.com/cli/latest/production/cli-windows-amd64.exe
akeyless.exe
Or using Homebrew package manager for MacOS:
brew install akeylesslabs/tap/akeyless
Authentication
The CLI supports various types of Authentication Methods:
- API Key (
access_key
) - AWS IAM (
aws_iam
) - Azure Active Directory (
azure_ad
) - SAML (
saml
) - Password (
email/password
) - Certificate (
certificate
) - OIDC (
oidc
) - K8s (
k8s
) - GCP (
GCP
) - OCI (
oci
)
For security reasons, if the correct credentials are not entered, the Akeyless CLI will not provide an error message immediately. Instead, you will receive an error message when attempting to run commands.
Installation
Running the CLI for the first time, will start an interactive flow by default , where you can modify the basic settings if needed.
For exmaple the default Akeyless URL should be vault.akeyless.io
unless specificly you are running in different SaaS environment, tpress Enter to leave the URL as is:
"AKEYLESS-CLI, first use detected
Enter Akeyless URL (Default: vault.akeyless.io)"
At the prompt Would you like to configure a profile (Y/n)
line, type Y
. Then, type a name to rename the default profile, or press Enter to leave the name as default
:
"Would you like to configure a profile? (Y/n) Y
Profile Name: (Default: default)"
Choose an Authentication Method from the list to configure the profile with, where pressing Enter
will use by default API Key, set the relevant Access ID and Access Key:
access-id '<Access-ID>'
access-key '<Access-Key>'
'Profile default successfully configured'
Continue with installing the Akeyless CLI depending on your operating system
Non Interactive mode
To initiate the CLI non-interactively, run:
./akeyless --init
which will work once only during for the first time you run the CLI on that environment.
Linux \ Mac
Once the authentication is succeeded, follow the prompt to add the CLI executable to your $PATH
:
Would you like to move 'akeyless' binary to: /home/username/.akeyless/bin/akeyless? (Y/n)
The cli was successfully moved to path: /home/username/.akeyless/bin/akeyless
Would you like to add '/home/username/.akeyless/bin' To user PATH environment variable? (Y/n)
Please run the following command to start using Akeyless CLI:
'source ~/.bash_profile'
The CLI will try to locate the user profile file (based on shell, i.e .bash_profile
, .zprofile
, .profile
, etc), and export the USER_HOME_DIR/.akeyless/bin/
to user $PATH
.
Try running the create-secret
command to test your installation:
akeyless create-secret --name MySecret1 --value MySecretPassword
Windows
Note
PowerShell ISE does not support interactive input mode. Please work with the PowerShell cmdlet to set up the Akeyless CLI.
Once the authentication is succeeded, the following prompt will appear:
Would you like to move 'akeyless.exe' binary to: C:\Users\username\.akeyless\bin\akeyless.exe? (Y/n)
#after user inputs 'Y'
The cli was successfully moved to path: C:\Users\username\.akeyless\bin\akeyless.exe
After the Akeyless CLI Binary is moved to USER_HOME_DIR/.akeyless/bin/akeyless
, another prompt will appear:
Would you like to add 'C:\Users\username\.akeyless\bin' To user PATH environment variable? (Y/n)
#after user inputs 'Y'
Run the following command to start using Akeyless CLI:
set "PATH=%PATH%;C:\Users\username\.akeyless\bin" (Update PATH for current session)
setx PATH "%PATH%;C:\Users\username\.akeyless\bin" (Update PATH permenantly)
Note
The CLI updates the path env for the current user only. This change only takes effect after the user logs off and logs back on.
Copy and run the relevant command for your purpose (permanent
or current session
), after that, The CLI should be ready to use.
Try running the create-secret
command to test your installation:
akeyless create-secret --name MySecret1 --value MySecretPassword
Working with profiles
Akeyless CLI supports profiles that can be set with different authentication methods and permissions, if you wish to configure a new profile, use the following command:
akeyless configure --profile <new profile name> --access-id <Access id> --access-key <Access key> --access-type access_key
While the default method is an API key, if you wish to use a different authentication method please consult the CLI reference for this command.
To view the profile settings file, go to the .akeyless
folder under your home
directory, the profiles folder contains a toml
file for each profile.
cd .akeyless/profiles/
After you've created an additional profile, add the --profile
parameter with the profile name to any akeyless
command to use it under that profile.
Advanced Configuration
When creating a profile in the CLI, the profile contains only the Authentication Method settings, such as Access ID
, and Access Type
.
However, you can configure additional parameters as defaults in your profile. Once set, these default parameters will automatically be used for your commands unless you choose to override them explicitly.
The following parameters can be added to a profile, for example on thedeafult
profile:
["default"]
gateway_url = `'https://<Your-Akeyless-GW-URL:8000>'`
default_location_prefix = '</non-production>'
cert_issuer_name = '</cert/IssuerName>'
cert_username = '<ubuntu>'
public_key_file_path = '<ssh/id_rsa.pub >'
legacy_signing_alg_name = '<true|false>'
Where:
-
gateway_url
: Akeyless Gateway Configuration Manager URL (port8000
). -
default_location_prefix
: A global default prefix for thename
flag, relevant for all types of objects in the account. In the example above, all commands will be performed on/non-production
folder. -
cert_issuer_name
: The default name of an SSH Certificate Issuer to use. -
cert_username
: The username the SSH certificate Issuer will issue the certificate for, e.gubuntu
. -
public_key_file_path
: Path to the file containing the SSH public key. -
legacy_signing_alg_name
: Set this option to use the SSH legacy signing algorithm.
Working with the Gateway
In case you are working with your own Fragment, or to work directly with your Gateway create an environment variable AKEYLESS_GATEWAY_URL
to point your CLI to interact with the relevant Gateway:
export AKEYLESS_GATEWAY_URL=<https://Your_GW_URL:8080>
set AKEYLESS_GATEWAY_URL=<https://Your_GW_URL:8080>
Alternatively, you can set the relevant Gateway on the profile
configuration file.
In case your Gateway uses a self-signed certificate not trusted by your machine, set the environment variable AKEYLESS_TRUSTED_TLS_CERTIFICATE_FILE
with the location of your PEM
file.
Precedence Configuration
Settings can be found in various locations, such as environment variables, the profile
configuration file, or directly as command-line parameters. Some locations have higher precedence than others, in this order:
-
Command line options: Overrides settings in any other location, including environment variables and profile configuration file.
-
Environment variables: Overrides settings in the profile configuration file.
-
Profile file: Values in the profile are used only if no explicit parameters or environment variables are set.
Troubleshooting
For access deny issues ensure the following:
-
Permissions: Make sure the authentication method you created the profile with is associated with the proper role with the authority to perform the action you tried.
-
Profile configuration file: Make sure your profile configuration file is valid and that everything is spelled correctly and matches the authentication method you chose.
Tutorial
Check out our tutorial video on Installing and Configuring the CLI.
Updated about 14 hours ago