Configurations
ARLAS configurations
An ARLAS Configuration tells arlas_cli
how to contact ARLAS Server and Elasticsearch.
See more information about configuration.
It is possible, with the arlas_cli confs
command lines, to manage the ARLAS configurations.
List configurations (confs) management commands
Options:
--help Show this message and exit.
Commands:
check Check the services of a configuration
create Add a configuration
default Display the default configuration
delete Delete a configuration
describe Describe a configuration
list List configurations
login Add a configuration for ARLAS Cloud
set Set default configuration among existing configurations
create
arlas_cli
is meant to communicate with a deployed ARLAS. This link is configured by creating a new configuration.
Add a configuration
Arguments:
NAME Name of the configuration [required]
Options:
--server TEXT ARLAS Server url [required]
--headers TEXT header (name:value)
--persistence TEXT ARLAS Persistence url
--persistence-headers TEXT header (name:value)
--elastic TEXT elasticsearch url
--elastic-login TEXT elasticsearch login
--elastic-password TEXT elasticsearch password
--elastic-headers TEXT header (name:value)
--allow-delete / --no-allow-delete
Is delete command allowed for this
configuration? [default: no-allow-delete]
--auth-token-url TEXT Token URL of the authentication service
--auth-headers TEXT header (name:value)
--auth-org TEXT ARLAS IAM Organization
--auth-login TEXT login
--auth-password TEXT password
--auth-client-id TEXT Client ID
--auth-client-secret TEXT Client secret
--auth-grant-type TEXT Grant type (e.g. password)
--auth-arlas-iam / --no-auth-arlas-iam
Is it an ARLAS IAM service? [default: auth-
arlas-iam]
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
Create a new configuration
The arlas_cli confs create
command has to be filled with options specific to your ARLAS deployment.
Those options can be filled as described in the following sections.
ARLAS Authentication
Keycloak and ARLAS IAM authentications are supported. See scripts/init_arlas_cli_confs.sh script for different connection configuration examples.
ARLAS IAM
To create a configuration for ARLAS IAM, the following parameters have to be set with your values:
- The IAM session url
IAM_URL
- Your IAM user
ARLAS_USER
- Your IAM password
ARLAS_PWD
- Your ARLAS organization
ARLAS_ORGANIZATION
The following options are used by confs create
sub-command to generate the configuration:
--auth-arlas-iam
--auth-token-url {IAM_URL}
--auth-login {ARLAS_USER}
--auth-password {ARLAS_PWD}
--auth-headers "Content-Type:application/json;charset=utf-8"
--auth-org {ARLAS_ORGANIZATION}
A full example once you have set IAM_URL
, ARLAS_ORGANIZATION
, ARLAS_USER
and ARLAS_PWD
:
arlas_cli --config-file /tmp/arlas-cli.yaml confs create local.iam.user \
--server https://${ARLAS_HOST}/arlas \
--headers "Content-Type:application/json" \
--persistence https://${ARLAS_HOST}/persist \
--persistence-headers "Content-Type:application/json" \
--elastic http://localhost:9200 \
--elastic-headers "Content-Type:application/json" \
--allow-delete \
--auth-token-url https://${ARLAS_HOST}/arlas_iam_server/session \
--auth-headers "Content-Type:application/json" \
--auth-login ${ARLAS_USER} \
--auth-password ${ARLAS_PWD} \
--auth-org ${ARLAS_ORGANIZATION} \
--auth-arlas-iam
Keycloak
To create a configuration for Keycloak, the following parameters have to be set with your values:
- The Keycloak token url
TOKEN_URL
- Your user's login
ARLAS_USER
- Your user's password
ARLAS_PWD
The following options are used by confs create
sub-command to generate the configuration:
--auth-grant-type password \
--auth-client-id arlas-front \
--auth-token-url ${TOKEN_URL} \
--auth-headers "Content-Type:application/x-www-form-urlencoded" \
--auth-login ${ARLAS_USER} \
--auth-password ${ARLAS_PWD} \
A full example once you have set TOKEN_URL
, ARLAS_USER
and ARLAS_PWD
:
arlas_cli --config-file /tmp/arlas-cli.yaml \
confs create local.kc.user \
--server https://${ARLAS_HOST}/arlas \
--persistence https://${ARLAS_HOST}/persist \
--persistence-headers "Content-Type:application/json" \
--elastic http://localhost:9200 \
--elastic-headers "Content-Type:application/json" \
--allow-delete \
--auth-grant-type password \
--auth-client-id arlas-front \
--auth-token-url https://${ARLAS_HOST}:9443/auth/realms/arlas/protocol/openid-connect/token \
--auth-headers "Content-Type:application/x-www-form-urlencoded" \
--auth-login ${ARLAS_USER} \
--auth-password ${ARLAS_PWD} \
--no-auth-arlas-iam
ARLAS Server and Persistence
The ARLAS server URL (ARLAS_SERVER_URL
) and the ARLAS persistence server URL (ARLAS_PERSISTENCE_URL
) have to be set in the configuration using the following options in the confs create
sub-command:
--server {ARLAS_SERVER_URL}
--headers "Content-Type:application/json"
--persistence {ARLAS_PERSISTENCE_URL}
--persistence-headers "Content-Type:application/json"
Elasticsearch
The used Elasticsearch instance and your credentials has to be set in the configuration:
ELASTIC_ENDPOINT
: The used Elasticsearch endpoint (eg: http://localhost:9200)ELASTIC_USER
: Your ES user nameELASTIC_PWD
: Your ES user password
The link to the ES instance is configured by using the following options in the confs create
sub-command:
--elastic {ELASTIC_ENDPOINT}
--elastic-headers "Content-Type:application/json"
--elastic-login {ELASTIC_USER}
--elastic-password {ELASTIC_PWD}
Allow data deletion
By default, it is not possible to run the indices delete
command on an elasticsearch with arlas_cli
.
This is to prevent accidental data loss.
--allow-delete
In order to allow to delete on a configuration, use the --allow-delete
option.
login
Create configuration for ARLAS Cloud
The confs longin
allows to create a configuration linked to an ARLAS Cloud account:
Add a configuration for ARLAS Cloud
Arguments:
AUTH_LOGIN ARLAS login [required]
ELASTIC_LOGIN Elasticsearch login [required]
ELASTIC Elasticsearch url [required]
Options:
--auth-org TEXT ARLAS IAM Organization, default is your
email domain name
--allow-delete / --no-allow-delete
Is delete command allowed for this
configuration? [default: allow-delete]
--auth-password TEXT ARLAS password
--elastic-password TEXT elasticsearch password
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
Only your own ES and ARLAS credentials have to be set, the configuration is directly linked to the ARLAS Cloud instance.
It creates a configuration based on your username (extracted from your ARLAS login) : cloud.arlas.io.{USER_NAME}
Note
This created configuration is used as default.
You no longer need to declare the --config
in the arlas_cli commands
See the ARLAS Cloud configuration guide.
delete
Delete an existing configuration
An existing configuration can be deleted with the confs delete
sub command:
Delete a configuration
Arguments:
CONFIG Name of the configuration [required]
Options:
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
To remove an existing configuration from the default configuration file, simply run the following command:
arlas_cli confs delete {conf_name}
The configuration will no longer appear in the configuration file.
Warning
Once deleted, the configuration cannot be retrieved.
describe
Describe the content of a configuration
The content of a configuration can be detailed with confs describe
sub command:
Describe a configuration
Arguments:
CONFIG Name of the configuration [required]
Options:
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
For example, the default local configuration looks like:
authorization: null
elastic:
headers:
Content-Type: application/json
location: http://localhost:9200
login: null
password: null
persistence:
headers:
Content-Type: application/json
location: http://localhost/persist
login: null
password: null
server:
headers:
Content-Type: application/json
location: http://localhost/arlas
login: null
password: null
We get the different elements of the configurations:
- authorization: The authentication system configuration
- elastic: The link to Elasticsearch cluster
- persistence: The link to ARLAS persistence
- server: The link to ARLAS server
See more about the configuration.
list
List the available configurations
The list of available configurations can be obtained with confs list
sub command:
List configurations
Options:
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
The confs list
sub-command returns the list of available configuration names and their ARLAS server url.
For example:
| name | url |
+-------+------------------------+
| local | http://localhost/arlas |
+-------+------------------------+
default
Get the current default configuration
The default arlas_cli configuration can be obtained with the confs default
subcommand:
Display the default configuration
Options:
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
Note
When a configuration is set as default, you do not need to specify --config
option in arlas_cli
commands.
To identify which configuration is currently set as the default, run:
arlas_cli confs default
set
Set the default configuration
The default arlas_cli configuration can be set with the confs set
subcommand:
Set default configuration among existing configurations
Arguments:
NAME Name of the configuration to become default [required]
Options:
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
Note
When a configuration is set as default, you do not need to specify --config
option in arlas_cli
commands.
To set a configuration conf_name
as the default, run:
arlas_cli confs set {conf_name}
check
Check the services of a configuration
You can verify the services accessible through a specific configuration using the confs check
subcommand:
Check the services of a configuration
Arguments:
NAME Configuration to be checked [required]
Options:
--help Show this message and exit.
See full arlas_cli documentation at
https://docs.arlas.io/external_docs/arlas_cli/
This command validates that the addresses and credentials defined in the configuration are correct and ensures successful access to the services.
The following services are validated:
- ARLAS Server
- ARLAS Persistence
- ARLAS IAM
- Elasticsearch
Success
Example:
ARLAS Persistence: ... ok
ARLAS IAM: ... ok
Elasticsearch: ... ok
All services are up and running, and the configuration is correctly set up.