Class: SurgeAPI::Client
- Inherits:
-
Internal::Transport::BaseClient
- Object
- Internal::Transport::BaseClient
- SurgeAPI::Client
- Defined in:
- lib/surge_api/client.rb
Constant Summary collapse
- DEFAULT_MAX_RETRIES =
Default max number of retries to attempt after a failed retryable request.
2- DEFAULT_TIMEOUT_IN_SECONDS =
Default per-request timeout.
60.0- DEFAULT_INITIAL_RETRY_DELAY =
Default initial retry delay in seconds. Overall delay is calculated using exponential backoff + jitter.
0.5- DEFAULT_MAX_RETRY_DELAY =
Default max retry delay in seconds.
8.0
Constants inherited from Internal::Transport::BaseClient
Internal::Transport::BaseClient::MAX_REDIRECTS, Internal::Transport::BaseClient::PLATFORM_HEADERS
Instance Attribute Summary collapse
- #accounts ⇒ SurgeAPI::Resources::Accounts readonly
- #api_key ⇒ String readonly
- #blasts ⇒ SurgeAPI::Resources::Blasts readonly
- #campaigns ⇒ SurgeAPI::Resources::Campaigns readonly
- #contacts ⇒ SurgeAPI::Resources::Contacts readonly
- #messages ⇒ SurgeAPI::Resources::Messages readonly
- #phone_numbers ⇒ SurgeAPI::Resources::PhoneNumbers readonly
- #users ⇒ SurgeAPI::Resources::Users readonly
- #verifications ⇒ SurgeAPI::Resources::Verifications readonly
- #webhooks ⇒ SurgeAPI::Resources::Webhooks readonly
Attributes inherited from Internal::Transport::BaseClient
#base_url, #headers, #idempotency_header, #initial_retry_delay, #max_retries, #max_retry_delay, #requester, #timeout
Instance Method Summary collapse
-
#initialize(api_key: ENV["SURGE_API_KEY"], base_url: ENV["SURGE_BASE_URL"], max_retries: self.class::DEFAULT_MAX_RETRIES, timeout: self.class::DEFAULT_TIMEOUT_IN_SECONDS, initial_retry_delay: self.class::DEFAULT_INITIAL_RETRY_DELAY, max_retry_delay: self.class::DEFAULT_MAX_RETRY_DELAY) ⇒ Client
constructor
Creates and returns a new client for interacting with the API.
Methods inherited from Internal::Transport::BaseClient
follow_redirect, #inspect, reap_connection!, #request, #send_request, should_retry?, validate!
Methods included from Internal::Util::SorbetRuntimeSupport
#const_missing, #define_sorbet_constant!, #sorbet_constant_defined?, #to_sorbet_type, to_sorbet_type
Constructor Details
#initialize(api_key: ENV["SURGE_API_KEY"], base_url: ENV["SURGE_BASE_URL"], max_retries: self.class::DEFAULT_MAX_RETRIES, timeout: self.class::DEFAULT_TIMEOUT_IN_SECONDS, initial_retry_delay: self.class::DEFAULT_INITIAL_RETRY_DELAY, max_retry_delay: self.class::DEFAULT_MAX_RETRY_DELAY) ⇒ Client
Creates and returns a new client for interacting with the API.
‘“api.example.com/v2/”`. Defaults to `ENV`
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 |
# File 'lib/surge_api/client.rb', line 71 def initialize( api_key: ENV["SURGE_API_KEY"], base_url: ENV["SURGE_BASE_URL"], max_retries: self.class::DEFAULT_MAX_RETRIES, timeout: self.class::DEFAULT_TIMEOUT_IN_SECONDS, initial_retry_delay: self.class::DEFAULT_INITIAL_RETRY_DELAY, max_retry_delay: self.class::DEFAULT_MAX_RETRY_DELAY ) base_url ||= "https://api.surge.app" if api_key.nil? raise ArgumentError.new("api_key is required, and can be set via environ: \"SURGE_API_KEY\"") end @api_key = api_key.to_s super( base_url: base_url, timeout: timeout, max_retries: max_retries, initial_retry_delay: initial_retry_delay, max_retry_delay: max_retry_delay ) @accounts = SurgeAPI::Resources::Accounts.new(client: self) @blasts = SurgeAPI::Resources::Blasts.new(client: self) @campaigns = SurgeAPI::Resources::Campaigns.new(client: self) @contacts = SurgeAPI::Resources::Contacts.new(client: self) @messages = SurgeAPI::Resources::Messages.new(client: self) @phone_numbers = SurgeAPI::Resources::PhoneNumbers.new(client: self) @users = SurgeAPI::Resources::Users.new(client: self) @verifications = SurgeAPI::Resources::Verifications.new(client: self) @webhooks = SurgeAPI::Resources::Webhooks.new(client: self) end |
Instance Attribute Details
#accounts ⇒ SurgeAPI::Resources::Accounts (readonly)
22 23 24 |
# File 'lib/surge_api/client.rb', line 22 def accounts @accounts end |
#api_key ⇒ String (readonly)
19 20 21 |
# File 'lib/surge_api/client.rb', line 19 def api_key @api_key end |
#blasts ⇒ SurgeAPI::Resources::Blasts (readonly)
25 26 27 |
# File 'lib/surge_api/client.rb', line 25 def blasts @blasts end |
#campaigns ⇒ SurgeAPI::Resources::Campaigns (readonly)
28 29 30 |
# File 'lib/surge_api/client.rb', line 28 def campaigns @campaigns end |
#contacts ⇒ SurgeAPI::Resources::Contacts (readonly)
31 32 33 |
# File 'lib/surge_api/client.rb', line 31 def contacts @contacts end |
#messages ⇒ SurgeAPI::Resources::Messages (readonly)
34 35 36 |
# File 'lib/surge_api/client.rb', line 34 def @messages end |
#phone_numbers ⇒ SurgeAPI::Resources::PhoneNumbers (readonly)
37 38 39 |
# File 'lib/surge_api/client.rb', line 37 def phone_numbers @phone_numbers end |
#users ⇒ SurgeAPI::Resources::Users (readonly)
40 41 42 |
# File 'lib/surge_api/client.rb', line 40 def users @users end |
#verifications ⇒ SurgeAPI::Resources::Verifications (readonly)
43 44 45 |
# File 'lib/surge_api/client.rb', line 43 def verifications @verifications end |
#webhooks ⇒ SurgeAPI::Resources::Webhooks (readonly)
46 47 48 |
# File 'lib/surge_api/client.rb', line 46 def webhooks @webhooks end |