require 'dotenv' require 'aws_config' Dotenv.load class EC2 class Host class Config class << self attr_writer :config_file, :aws_region, :aws_profile, :aws_access_key_id, :aws_secret_access_key, :aws_credential_file, :log_level, :hostname_tag, :roles_tag, :optional_array_tags, :optional_string_tags end def self.configure(params) params.each do |key, val| send("#{key}=", val) end end def self.config_file @config_file ||= ENV.fetch('EC2_HOST_CONFIG_FILE', File.exist?('/etc/sysconfig/ec2-host') ? '/etc/sysconfig/ec2-host' : '/etc/default/ec2-host') end def self.aws_region @aws_region ||= ENV['AWS_REGION'] || config.fetch('AWS_REGION', nil) || # ref. old aws cli ENV['AWS_DEFAULT_REGION'] || config.fetch('AWS_DEFAULT_REGION', nil) || # ref. aws cli and terraform aws_config['region'] || raise('AWS_REGION nor AWS_DEFAULT_REGION is not set') end def self.aws_profile @aws_profile ||= ENV['AWS_PROFILE'] || config.fetch('AWS_PROFILE', nil) || # ref. old aws cli ENV['AWS_DEFAULT_PROFILE'] || config.fetch('AWS_DEFAULT_PROFILE', 'default') # ref. aws cli and terraform end def self.aws_access_key_id # ref. aws cli and terraform @aws_access_key_id ||= ENV['AWS_ACCESS_KEY_ID'] || config.fetch('AWS_ACCESS_KEY_ID', nil) end def self.aws_secret_access_key # ref. aws cli and terraform @aws_secret_access_key ||= ENV['AWS_SECRET_ACCESS_KEY'] || config.fetch('AWS_SECRET_ACCESS_KEY', nil) end def self.aws_credential_file @aws_credential_file ||= ENV['AWS_CREDENTIALS_FILE'] || config.fetch('AWS_CREDENTIALS_FILE', nil) || ENV['AWS_CREDENTIAL_FILE'] || config.fetch('AWS_CREDENTIAL_FILE', nil) || # ref. aws cli (supported lately) File.expand_path('~/.aws/credentials') end def self.aws_config_file @aws_config_file ||= ENV['AWS_CONFIG_FILE'] || config.fetch('AWS_CONFIG_FILE', nil) || File.expand_path('~/.aws/config') end def self.aws_config return @aws_config if @aws_config if File.readable?(aws_config_file) && File.readable?(aws_credential_file) AWSConfig.config_file = aws_config_file AWSConfig.credentials_file = aws_credential_file @aws_config = AWSConfig[aws_profile] end @aws_config ||= {} end def self.log_level @log_level ||= ENV['LOG_LEVEL'] || config.fetch('LOG_LEVEL', 'info') end def self.hostname_tag @hostname_tag ||= ENV['HOSTNAME_TAG'] || config.fetch('HOSTNAME_TAG', 'Name') end def self.roles_tag @roles_tag ||= ENV['ROLES_TAG'] || config.fetch('ROLES_TAG', 'Roles') end def self.optional_array_tags @optional_array_tags ||= (ENV['OPTIONAL_ARRAY_TAGS'] || config.fetch('OPTIONAL_ARRAY_TAGS', '')).split(',') end def self.optional_string_tags @optional_string_tags ||= (ENV['OPTIONAL_STRING_TAGS'] || config.fetch('OPTIONAL_STRING_TAGS', '')).split(',') end def self.role_tag_delimiter @role_tag_delimiter ||= ENV['ROLE_TAG_DELIMITER'] || config.fetch('ROLE_TAG_DELIMITER', ':') end def self.array_tag_delimiter @array_tag_delimiter ||= ENV['ARRAY_TAG_DELIMITER'] || config.fetch('ARRAY_TAG_DELIMITER', ',') end def self.role_max_depth @role_max_depth ||= Integer(ENV['ROLE_MAX_DEPTH'] || config.fetch('ROLE_MAX_DEPTH', 3)) end # private def self.optional_array_options @optional_array_options ||= Hash[optional_array_tags.map {|tag| [StringUtil.singularize(StringUtil.underscore(tag)), tag] }] end def self.optional_string_options @optional_string_options ||= Hash[optional_string_tags.map {|tag| [StringUtil.underscore(tag), tag] }] end def self.optional_options @optional_options ||= optional_array_options.merge(optional_string_options) end def self.config return @config if @config @config = {} if File.exist?(config_file) File.readlines(config_file).each do |line| next if line.start_with?('#') key, val = line.chomp.split('=', 2) @config[key] = val end end @config end end end end