Module: Aptible::CLI::Helpers::Token
- Includes:
- ConfigPath
- Included in:
- Agent, App, Database, Environment, LogDrain, Maintenance, MetricDrain
- Defined in:
- lib/aptible/cli/helpers/token.rb
Constant Summary collapse
- TOKEN_ENV_VAR =
'APTIBLE_ACCESS_TOKEN'.freeze
Instance Method Summary collapse
Methods included from ConfigPath
Instance Method Details
#current_token_hash ⇒ Object
37 38 39 40 41 42 43 44 |
# File 'lib/aptible/cli/helpers/token.rb', line 37 def current_token_hash # NOTE: older versions of the CLI did not properly create the # token_file with mode 600, which is why we update it when reading. File.chmod(0o600, token_file) JSON.parse(File.read(token_file)) rescue {} end |
#fetch_token ⇒ Object
13 14 15 16 17 18 19 |
# File 'lib/aptible/cli/helpers/token.rb', line 13 def fetch_token @token ||= ENV[TOKEN_ENV_VAR] || current_token_hash[Aptible::Auth.configuration.root_url] return @token if @token raise Thor::Error, 'Could not read token: please run aptible login ' \ "or set #{TOKEN_ENV_VAR}" end |
#save_token(token) ⇒ Object
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/aptible/cli/helpers/token.rb', line 21 def save_token(token) hash = current_token_hash.merge( Aptible::Auth.configuration.root_url => token ) FileUtils.mkdir_p(File.dirname(token_file)) File.open(token_file, 'w', 0o600) do |file| file.puts hash.to_json end rescue StandardError => e m = "Could not write token to #{token_file}: #{e}. " \ 'Check filesystem permissions.' raise Thor::Error, m end |
#token_file ⇒ Object
46 47 48 |
# File 'lib/aptible/cli/helpers/token.rb', line 46 def token_file File.join(aptible_config_path, 'tokens.json').freeze end |