Class: ShellDataReportingApIs::Configuration

Inherits:
CoreLibrary::HttpClientConfiguration
  • Object
show all
Defined in:
lib/shell_data_reporting_ap_is/configuration.rb

Overview

All configuration including auth info and base URI for the API access are configured in this class.

Constant Summary collapse

ENVIRONMENTS =

All the environments the SDK can run in.

{
  Environment::SIT => {
    Server::OAUTH_SERVER => 'https://api-test.shell.com',
    Server::SHELL => 'https://api-test.shell.com/test'
  },
  Environment::PRODUCTION => {
    Server::OAUTH_SERVER => 'https://api.shell.com',
    Server::SHELL => 'https://api.shell.com'
  }
}.freeze

Class Attribute Summary collapse

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(connection: nil, adapter: :net_http_persistent, timeout: 60, max_retries: 0, retry_interval: 1, backoff_factor: 2, retry_statuses: [408, 413, 429, 500, 502, 503, 504, 521, 522, 524], retry_methods: %i[get put],, http_callback: nil, environment: Environment::SIT, basic_auth_credentials: nil, bearer_token_credentials: nil) ⇒ Configuration

Returns a new instance of Configuration.



33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# File 'lib/shell_data_reporting_ap_is/configuration.rb', line 33

def initialize(
  connection: nil, adapter: :net_http_persistent, timeout: 60,
  max_retries: 0, retry_interval: 1, backoff_factor: 2,
  retry_statuses: [408, 413, 429, 500, 502, 503, 504, 521, 522, 524],
  retry_methods: %i[get put], http_callback: nil,
  environment: Environment::SIT, basic_auth_credentials: nil,
  bearer_token_credentials: nil
)

  super connection: connection, adapter: adapter, timeout: timeout,
        max_retries: max_retries, retry_interval: retry_interval,
        backoff_factor: backoff_factor, retry_statuses: retry_statuses,
        retry_methods: retry_methods, http_callback: http_callback

  # Current API environment
  @environment = String(environment)

  # The object holding Basic Authentication credentials
  @basic_auth_credentials = basic_auth_credentials

  # The object holding OAuth 2 Client Credentials Grant credentials
  @bearer_token_credentials = bearer_token_credentials

  # The Http Client to use for making requests.
  set_http_client CoreLibrary::FaradayClient.new(self)
end

Class Attribute Details

.environmentsObject (readonly)

Returns the value of attribute environments.



30
31
32
# File 'lib/shell_data_reporting_ap_is/configuration.rb', line 30

def environments
  @environments
end

Instance Attribute Details

#basic_auth_credentialsObject (readonly)

The attribute readers for properties.



27
28
29
# File 'lib/shell_data_reporting_ap_is/configuration.rb', line 27

def basic_auth_credentials
  @basic_auth_credentials
end

#bearer_token_credentialsObject (readonly)

The attribute readers for properties.



27
28
29
# File 'lib/shell_data_reporting_ap_is/configuration.rb', line 27

def bearer_token_credentials
  @bearer_token_credentials
end

#environmentObject (readonly)

The attribute readers for properties.



27
28
29
# File 'lib/shell_data_reporting_ap_is/configuration.rb', line 27

def environment
  @environment
end

Instance Method Details

#clone_with(connection: nil, adapter: nil, timeout: nil, max_retries: nil, retry_interval: nil, backoff_factor: nil, retry_statuses: nil, retry_methods: nil, http_callback: nil, environment: nil, basic_auth_credentials: nil, bearer_token_credentials: nil) ⇒ Object



60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# File 'lib/shell_data_reporting_ap_is/configuration.rb', line 60

def clone_with(connection: nil, adapter: nil, timeout: nil,
               max_retries: nil, retry_interval: nil, backoff_factor: nil,
               retry_statuses: nil, retry_methods: nil, http_callback: nil,
               environment: nil, basic_auth_credentials: nil,
               bearer_token_credentials: nil)
  connection ||= self.connection
  adapter ||= self.adapter
  timeout ||= self.timeout
  max_retries ||= self.max_retries
  retry_interval ||= self.retry_interval
  backoff_factor ||= self.backoff_factor
  retry_statuses ||= self.retry_statuses
  retry_methods ||= self.retry_methods
  http_callback ||= self.http_callback
  environment ||= self.environment
  basic_auth_credentials ||= self.basic_auth_credentials
  bearer_token_credentials ||= self.bearer_token_credentials

  Configuration.new(connection: connection, adapter: adapter,
                    timeout: timeout, max_retries: max_retries,
                    retry_interval: retry_interval,
                    backoff_factor: backoff_factor,
                    retry_statuses: retry_statuses,
                    retry_methods: retry_methods,
                    http_callback: http_callback, environment: environment,
                    basic_auth_credentials: basic_auth_credentials,
                    bearer_token_credentials: bearer_token_credentials)
end

#get_base_uri(server = Server::SHELL) ⇒ String

Generates the appropriate base URI for the environment and the server. required.

Parameters:

  • server (Configuration::Server) (defaults to: Server::SHELL)

    The server enum for which the base URI is

Returns:

  • (String)

    The base URI.



106
107
108
# File 'lib/shell_data_reporting_ap_is/configuration.rb', line 106

def get_base_uri(server = Server::SHELL)
  ENVIRONMENTS[environment][server].clone
end