Configuration Reference

This page provides a description of all supported configuration options. All values should be placed under the vault key in the Salt configuration.

General configuration

auth

Contains authentication parameters for the local machine.

approle_mount

The name of the AppRole authentication mount point. Defaults to approle.

approle_name

The name of the AppRole. Defaults to salt-master.

Note

Only relevant when a locally configured role_id/secret_id is set to the return payload of a wrapping request, so only in very specialized use cases.

method

Currently only token and approle auth types are supported. Defaults to token.

Hint

In addition to a plain string, the required authentication credentials can also be specified as a dictionary that includes wrap_info, i.e. the return payload of a wrapping request.

role_id

The role ID of the AppRole. Required if auth:method == approle.

secret_id

The SecretID of the AppRole. Only required if the configured AppRole requires it.

token

Token to authenticate to Vault with. Required if auth:method == token.

Hint

You can also pull configuration values, e.g. the token, from environment variables using the env SDB module:

vault:
  auth:
    method: token
    token: sdb://osenv/VAULT_TOKEN
  server:
    url: https://vault.service.domain:8200

osenv:
  driver: env

token_lifecycle

Token renewal settings.

Note

This setting can be specified inside a minion’s configuration as well and then overrides the master’s default for the minion.

Token lifecycle settings have significance for any authentication method, not just token.

minimum_ttl

Specifies the time (in seconds or as a time string like 24h) an in-use token should be valid for. If the current validity period is less than this and the token is renewable, a renewal is attempted. If it is not renewable or a renewal does not extend the ttl beyond the specified minimum, a new token is generated.

Hint

Since leases like database credentials are tied to a token, setting this to a much higher value than the default can be necessary, depending on your specific use case and configuration.

renew_increment

Specifies the amount of time the token’s validity should be requested to be renewed for when renewing a token. When unset, extends the token’s validity by its default ttl. Set this to false to disable token renewals.

Note

The Vault server is allowed to disregard this request.

cache

Configures token/lease and metadata cache (for KV secrets) on all hosts as well as configuration cache on minions that receive issued credentials.

backend

The cache backend in use. Defaults to session, which stores the Vault configuration in memory only for that specific Salt run. disk/file/localfs force using the localfs driver, regardless of configured minion data cache. Setting this to anything else uses the default configured cache for minion data (cache), by default the local filesystem as well.

clear_attempt_revocation

When flushing still valid cached tokens and leases, attempt to have them revoked after a (short) delay. Defaults to 60. Set this to false to disable revocation (not recommended).

clear_on_unauthorized

When encountering an Unauthorized response with an otherwise valid token, flush the cache and request new credentials. Defaults to true.

Tip

If your policies are relatively stable, disabling this prevents a lot of unnecessary overhead, with the tradeoff that once they change, you might have to clear the cache manually or wait for the token to expire.

config

The time in seconds to cache queried configuration from the master. Defaults to 3600 (one hour). Set this to null to disable cache expiration. Changed server configuration on the master is still recognized, but changes in auth and cache need a manual update using vault.update_config or cache clearance using vault.clear_cache.

Note

Expiring the configuration also clears cached authentication credentials and leases.

expire_events

Fire an event when the session cache containing leases is cleared (vault/cache/<scope>/clear) or cached leases have expired (vault/lease/<cache_key>/expire). A reactor can be employed to ensure fresh leases are issued. Defaults to false.

kv_metadata

The time in seconds to cache KV metadata used to determine if a path is using version 1/2 for. Defaults to connection, which clears the metadata cache once a new configuration is requested from the master. Setting this to null keeps the information indefinitely until the cache is cleared manually using vault.clear_cache with connection=false.

secret

The time in seconds to cache tokens/SecretIDs for. Defaults to ttl, which caches the secret for as long as it is valid, unless a new configuration is requested from the master.

client

Added in version 1.1.0.

Configures Vault API client behavior. By default, the client retries requests with a backoff strategy, unless the response includes a Retry-After header, which is respected. Connection errors as well as responses with the status codes 412, 429, 500, 502, 503, 504 are retried.

connect_timeout

Added in version 1.1.0.

The number of seconds to wait for a connection to be established. Defaults to 9.2.

read_timeout

Added in version 1.1.0.

The number of seconds to wait between packets sent by the server. Defaults to 30.

max_retries

Added in version 1.1.0.

The maximum number of retries (not including the initial request) before raising an exception. Set this to 0 to disable retry behavior. Defaults to 5. Maximum: 10.

backoff_factor

Added in version 1.1.0.

A backoff factor (in seconds) to use between retry attempts when applying the backoff strategy (based on the Fibonacci sequence). Defaults to 0.1. Maximum: 3.0

Hint

The effective sleep time before the nth retry is given by:

{backoff_factor} * {Fibonacci(n+3)}

The default values thus result in the following sleep times (in seconds), without accounting for backoff_jitter and only if the response did not include the Retry-After header:

[initial request] 0.2 [1st] 0.3 [2nd] 0.5 [3rd] 0.8 [4th] 1.3 [5th]

If we did not receive a response (connection/read error), the first retry is executed immediately, thus the following sleep times are in effect by default:

[initial request] 0 [1st] 0.2 [2nd] 0.3 [3rd] 0.5 [4th] 0.8 [5th]

backoff_max

Added in version 1.1.0.

A cap for the effective sleep time between retries. Defaults to 10.0. Maximum: 60.0.

backoff_jitter

Added in version 1.1.0.

A maximum number of seconds to randomize the effective sleep time between retries by. Defaults to 0.2. Maximum: 5.0

retry_post

Added in version 1.1.0.

Whether to retry requests that are potentially non-idempotent (POST, PATCH). Defaults to False.

Note

HTTP 429 responses are always retried, regardless of HTTP verb.

retry_status

Added in version 1.1.0.

A list of HTTP status codes which should be retried. Defaults to [412, 500, 502, 503, 504].

Note

HTTP 429 is always retried, regardless of HTTP verb and whether it is present in this list. It is recommended to ensure the Retry-After header is sent by Vault to optimize the spent resources. See respect_retry_after for details.

respect_retry_after

Added in version 1.1.0.

Whether to respect the Retry-After header sent by Vault, usually when a rate limit has been hit. Defaults to True.

Hint

This header is not sent by default and must be enabled explicitly via enable_rate_limit_response_headers.

retry_after_max

Added in version 1.1.0.

When respect_retry_after is True, limit the maximum amount of seconds the client sleeps before retrying. Set this to null (YAML/JSON)/None (Python) to disable this behavior. Defaults to 60.

server

Configures Vault server details.

url

URL of your Vault installation. Required.

verify

Configures certificate verification behavior when issuing requests to the Vault server. If unset, requests use the CA certificates bundled with certifi.

For details, please see the requests documentation on certificate verification.

Note

In addition, this value can be set to a PEM-encoded CA certificate to use as the sole trust anchor for certificate chain verification.

Hint

This value can be set inside the minion configuration as well, from where it takes precedence.

namespace

Optional Vault namespace. Used with Vault Enterprise.

Master-only configuration

issue

Configures authentication data issued by the master to minions.

type

The type of authentication to issue to minions. Can be token or approle. Defaults to token.

To be able to issue AppRoles to minions, the master needs to be able to create new AppRoles on the configured auth mount. It is strongly encouraged to create a separate mount dedicated to minions.

approle

Configuration regarding issued AppRoles.

mount

Specifies the name of the auth mount the master manages. Defaults to salt-minions. This mount should be exclusively dedicated to the Salt master.

params

Configures the AppRole the master creates for minions. See the Vault AppRole API docs for details. If you update these params, you can update the minion AppRoles manually using the runner vault.sync_approles, but they are updated automatically during a request by a minion as well.

token

Configuration regarding issued tokens.

role_name

Specifies the Token Role name to use for creating minion tokens. If omitted, minion tokens are created without any role, thus being able to inherit any master token policy (including token creation capabilities).

params

Configures the tokens the master issues to minions. See the Vault Token API docs for details. To make full use of multi-use tokens, you should configure a cache that survives a single session (e.g. disk).

Important

If unset, the master issues single-use tokens to minions, which can be quite expensive.

allow_minion_override_params

Whether to allow minions to request to override parameters for issuing credentials. See issue_params.

wrap

The time a minion has to unwrap a wrapped secret issued by the master. Set this to false to disable wrapping, otherwise a time string like 30s can be used. Defaults to 30s.

keys

List of keys to use to unseal the Vault server with the vault.unseal runner.

metadata

Configures metadata for the issued entities/secrets. Values can be strings or string templates.

Important

Vault allows string-valued metadata only, hence templates that resolve to lists are concatenated into a lexicographically sorted comma-separated list (Python list.sort()).

In addition, each list item is rendered into a distinct key of its own, determined by its parent key name and its list index. For example, if you are templating a metadata key named roles using a list, which in this example resolves to [web, db], the single roles definition creates three separate metadata entries:

  • roles: db,web

  • roles__0: db

  • roles__1: web

For details on this, see the templating guide.

entity

Configures custom metadata Vault associates with the minion entity, which can be referenced in templated ACL policies.

Important

Entities are only created when issuing AppRoles to minions.

secret

Configures custom metadata associated with issued tokens/SecretIDs. It is logged in plaintext to the Vault audit log.

policies

assign

List of policies that are assigned to issued minion authentication data, either token or AppRole. They can be static strings or string templates.

Defaults to [saltstack/minions, saltstack/{minion}].

cache_time

Number of seconds compiled templated policies are cached on the master. This is important when using pillar values in templates, since compiling the pillar is an expensive operation.

Note

Only effective when issuing tokens to minions. Token policies need to be compiled every time a token is requested, while AppRole-associated policies are written to Vault configuration the first time authentication data is requested (they can be refreshed on demand by running the vault.sync_approles runner).

They are also refreshed in case other issuance parameters are changed, either on the master or the minion (if allow_minion_override_params is True).

refresh_pillar

Whether to refresh the minion pillar when compiling templated policies that contain pillar variables. Only effective when issuing tokens to minions (see note on policies:cache_time).

Possible values:

null

(default) Only compile the pillar when no cached pillar is found.

false

Never compile the pillar. This means templated policies that contain pillar values are skipped if no cached pillar is found.

true

Always compile the pillar. This can cause additional strain on the master since the compilation is costly.

Note

Hardcoded to True when issuing AppRoles.

Using cached pillar data only (refresh_pillar=False) might cause the policies to be out of sync. If there is no cached pillar data available for the minion, pillar templates fail to render at all.

If you use pillar values for templating policies and do not disable refreshing pillar data, make sure the relevant values are not sourced from Vault (ext_pillar, sdb) or from a pillar sls file that uses the vault execution/sdb module. Although this often works when cached pillar data is available, if the master needs to compile the pillar data during policy rendering, all Vault modules are broken to prevent an infinite loop.

Minion-only configuration

Note

In addition to the following minion-only values, auth:token_lifecycle, server:verify and client can be set on the minion as well, even if it pulls its configuration from a master.

config_location

Override the source of the Vault configuration for the minion. By default, this extension tries to determine if it needs to request the connection details from the master or from the local config, depending on the minion running in local or master-connected mode. This option forces the extension to use the connection details from the master or the local config, regardless of circumstances. Allowed values: master, local.

issue_params

Request overrides for token/AppRole issuance. This needs to be allowed on the master by setting issue:allow_minion_override_params to true. See the master configuration issue:token:params or issue:approle:params for reference.

All configuration parameters with defaults

vault:
  auth:
    approle_mount: approle
    approle_name: salt-master
    method: token
    role_id: <required if auth:method == approle>
    secret_id: null
    token: <required if auth:method == token>
    token_lifecycle:
      minimum_ttl: 10
      renew_increment: null
  cache:
    backend: session
    config: 3600
    kv_metadata: connection
    secret: ttl
  client:
    max_retries: 5
    connect_timeout: 9.2
    read_timeout: 30
    backoff_factor: 0.1
    backoff_max: 10
    backoff_jitter: 0.2
    retry_post: false
    retry_status:
      - 412
      - 500
      - 502
      - 503
      - 504
    respect_retry_after: true
    retry_after_max: 60
  config_location: <variable, depends on running scope>
  issue:
    allow_minion_override_params: false
    type: token
    approle:
      mount: salt-minions
      params:
        bind_secret_id: true
        secret_id_num_uses: 1
        secret_id_ttl: 60
        token_explicit_max_ttl: 60
        token_num_uses: 10
        secret_id_bound_cidrs: null
        token_ttl: null
        token_max_ttl: null
        token_no_default_policy: false
        token_period: null
        token_bound_cidrs: null
    token:
      role_name: null
      params:
        explicit_max_ttl: null
        num_uses: 1
        ttl: null
        period: null
        no_default_policy: false
        renewable: true
    wrap: 30s
  issue_params: {}
  keys: []
  metadata:
    entity:
      minion-id: '{minion}'
    secret:
      saltstack-jid: '{jid}'
      saltstack-minion: '{minion}'
      saltstack-user: '{user}'
  policies:
    assign:
      - saltstack/minions
      - saltstack/{minion}
    cache_time: 60
    refresh_pillar: null
  server:
    url: <required, e. g. https://vault.example.com:8200>
    namespace: null
    verify: null