Class: ThePlaidApi::Client

Inherits:
Object
  • Object
show all
Includes:
CoreLibrary
Defined in:
lib/the_plaid_api/client.rb

Overview

the_plaid_api client class.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(connection: nil, adapter: :net_http_persistent, timeout: 30, 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, proxy_settings: nil, logging_configuration: nil, environment: Environment::SANDBOX, client_id_credentials: nil, secret_credentials: nil, plaid_version_credentials: nil, config: nil) ⇒ Client

Returns a new instance of Client.



22
23
24
25
26
27
28
29
30
31
32
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/the_plaid_api/client.rb', line 22

def initialize(
  connection: nil, adapter: :net_http_persistent, timeout: 30,
  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, proxy_settings: nil,
  logging_configuration: nil, environment: Environment::SANDBOX,
  client_id_credentials: nil, secret_credentials: nil,
  plaid_version_credentials: nil, config: nil
)
  @config = if config.nil?
              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,
                proxy_settings: proxy_settings,
                logging_configuration: logging_configuration,
                environment: environment,
                client_id_credentials: client_id_credentials,
                secret_credentials: secret_credentials,
                plaid_version_credentials: plaid_version_credentials
              )
            else
              config
            end
  user_agent_params = BaseApi.user_agent_parameters

  @global_configuration = GlobalConfiguration.new(client_configuration: @config)
                                             .base_uri_executor(@config.method(:get_base_uri))
                                             .global_errors(BaseApi::GLOBAL_ERRORS)
                                             .user_agent(BaseApi.user_agent,
                                                         agent_parameters: user_agent_params)

  initialize_auth_managers(@global_configuration)
  @global_configuration = @global_configuration.auth_managers(@auth_managers)
end

Instance Attribute Details

#auth_managersObject (readonly)

Returns the value of attribute auth_managers.



10
11
12
# File 'lib/the_plaid_api/client.rb', line 10

def auth_managers
  @auth_managers
end

#configObject (readonly)

Returns the value of attribute config.



10
11
12
# File 'lib/the_plaid_api/client.rb', line 10

def config
  @config
end

Class Method Details

.from_env(**overrides) ⇒ Object

Creates a client directly from environment variables.



74
75
76
77
78
# File 'lib/the_plaid_api/client.rb', line 74

def self.from_env(**overrides)
  default_config = Configuration.build_default_config_from_env
  new_config = default_config.clone_with(**overrides)
  new(config: new_config)
end

Instance Method Details

#initialize_auth_managers(global_config) ⇒ Object

Initializes the auth managers hash used for authenticating API calls.

Parameters:

  • global_config (GlobalConfiguration)

    The global configuration of the SDK)



62
63
64
65
66
67
68
69
70
71
# File 'lib/the_plaid_api/client.rb', line 62

def initialize_auth_managers(global_config)
  @auth_managers = {}
  http_client_config = global_config.client_configuration
  %w[clientId secret plaidVersion].each { |auth| @auth_managers[auth] = nil }
  @auth_managers['clientId'] = ClientId.new(http_client_config.client_id_credentials)
  @auth_managers['secret'] = Secret.new(http_client_config.secret_credentials)
  @auth_managers['plaidVersion'] = PlaidVersion.new(
    http_client_config.plaid_version_credentials
  )
end

#plaidPlaidApi

Access to plaid controller.

Returns:

  • (PlaidApi)

    Returns the controller instance.



18
19
20
# File 'lib/the_plaid_api/client.rb', line 18

def plaid
  @plaid ||= PlaidApi.new @global_configuration
end

#user_agent_detailObject



12
13
14
# File 'lib/the_plaid_api/client.rb', line 12

def user_agent_detail
  config.user_agent_detail
end