| // Copyright (c) HashiCorp, Inc. |
| // SPDX-License-Identifier: MPL-2.0 |
| |
| package command |
| |
| import ( |
| "github.com/hashicorp/vault/command/config" |
| ) |
| |
| const ( |
| // DefaultConfigPath is the default path to the configuration file |
| DefaultConfigPath = "~/.vault" |
| |
| // ConfigPathEnv is the environment variable that can be used to |
| // override where the Vault configuration is. |
| ConfigPathEnv = "VAULT_CONFIG_PATH" |
| ) |
| |
| // Config is the CLI configuration for Vault that can be specified via |
| // a `$HOME/.vault` file which is HCL-formatted (therefore HCL or JSON). |
| type DefaultConfig struct { |
| // TokenHelper is the executable/command that is executed for storing |
| // and retrieving the authentication token for the Vault CLI. If this |
| // is not specified, then vault's internal token store will be used, which |
| // stores the token on disk unencrypted. |
| TokenHelper string `hcl:"token_helper"` |
| } |
| |
| // Config loads the configuration and returns it. If the configuration |
| // is already loaded, it is returned. |
| // |
| // Config just calls into config.Config for backwards compatibility purposes. |
| // Use config.Config instead. |
| func Config() (*DefaultConfig, error) { |
| conf, err := config.Config() |
| return (*DefaultConfig)(conf), err |
| } |
| |
| // LoadConfig reads the configuration from the given path. If path is |
| // empty, then the default path will be used, or the environment variable |
| // if set. |
| // |
| // LoadConfig just calls into config.LoadConfig for backwards compatibility |
| // purposes. Use config.LoadConfig instead. |
| func LoadConfig(path string) (*DefaultConfig, error) { |
| conf, err := config.LoadConfig(path) |
| return (*DefaultConfig)(conf), err |
| } |
| |
| // ParseConfig parses the given configuration as a string. |
| // |
| // ParseConfig just calls into config.ParseConfig for backwards compatibility |
| // purposes. Use config.ParseConfig instead. |
| func ParseConfig(contents string) (*DefaultConfig, error) { |
| conf, err := config.ParseConfig(contents) |
| return (*DefaultConfig)(conf), err |
| } |