module Comply::CLI::Helpers::Token
Constants
- TOKEN_ENV_VAR
Public Instance Methods
current_token_hash()
click to toggle source
# File lib/comply/cli/helpers/token.rb, line 39 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
current_user_email()
click to toggle source
# File lib/comply/cli/helpers/token.rb, line 10 def current_user_email @current_user_email ||= Aptible::Auth::Agent.new(token: fetch_token).me.email end
fetch_token()
click to toggle source
# File lib/comply/cli/helpers/token.rb, line 15 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 comply login ' \ "or set #{TOKEN_ENV_VAR}" end
save_token(token)
click to toggle source
# File lib/comply/cli/helpers/token.rb, line 23 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()
click to toggle source
# File lib/comply/cli/helpers/token.rb, line 48 def token_file File.join ENV['HOME'], '.aptible', 'tokens.json' end