dblessing/rundeck-ruby

View on GitHub
lib/rundeck/configuration.rb

Summary

Maintainability
A
0 mins
Test Coverage
module Rundeck
  # Defines constants and methods related to configuration.
  module Configuration
    # An array of valid keys in the options hash when configuring a Rundeck::API.
    VALID_OPTIONS_KEYS = [:endpoint, :api_token, :user_agent].freeze

    # The user agent that will be sent to the API endpoint if none is set.
    DEFAULT_USER_AGENT = "Rundeck Ruby Gem #{Rundeck::VERSION}".freeze

    # @private
    attr_accessor(*VALID_OPTIONS_KEYS)

    # Sets all configuration options to their default values
    # when this module is extended.
    def self.extended(base)
      base.reset
    end

    # Convenience method to allow configuration options to be set in a block.
    def configure
      yield self
    end

    # Creates a hash of options and their values.
    def options
      VALID_OPTIONS_KEYS.reduce({}) do |option, key|
        option.merge!(key => send(key))
      end
    end

    def api_version
      '12'
    end

    # Resets all configuration options to the defaults.
    def reset
      self.endpoint       = ENV['RUNDECK_ENDPOINT']
      self.api_token      = ENV['RUNDECK_API_TOKEN']
      self.user_agent     = DEFAULT_USER_AGENT
    end
  end
end