Class: GetStreamRuby::Client
- Inherits:
-
Object
- Object
- GetStreamRuby::Client
- Defined in:
- lib/getstream_ruby/client.rb
Constant Summary collapse
- AUTH_IAT_LEEWAY_SECONDS =
Backdate the JWT ‘iat` claim by this many seconds.
JWT timestamps are whole-second (RFC 7519 NumericDate), so ‘Time.now.to_i` truncates to the second. The server applies minimal forward leeway on `iat`, so stamping `iat = now` lets a small fraction of requests be rejected (“token used before issue at (iat)”) whenever the caller’s clock is even marginally ahead of the server and the truncation lands on a second boundary. Backdating absorbs that sub-second skew.
5
Instance Attribute Summary collapse
-
#configuration ⇒ Object
readonly
Returns the value of attribute configuration.
Instance Method Summary collapse
-
#chat ⇒ GetStream::Generated::ChatClient
The chat API client.
-
#common ⇒ GetStream::Generated::CommonClient
The common API client.
-
#feed(feed_group_id, feed_id) ⇒ GetStream::Generated::Feed
Create an individual feed instance.
- #feed_resource ⇒ Object
-
#feeds ⇒ GetStream::Generated::FeedsClient
The feeds API client.
-
#initialize(config = nil, api_key: nil, api_secret: nil, **options) ⇒ Client
constructor
A new instance of Client.
- #make_request(method, path, query_params: nil, body: nil, request_timeout: nil) ⇒ Object
-
#moderation ⇒ GetStream::Generated::ModerationClient
The moderation API client.
-
#parse_sns(notification_body) ⇒ Object
Decode + parse a Stream-delivered SNS notification body.
-
#parse_sqs(message_body) ⇒ Object
Decode + parse a Stream-delivered SQS message body.
-
#post(path, body = {}) ⇒ GetStreamRuby::StreamResponse
The API response.
-
#verify_and_parse_webhook(body, signature) ⇒ Object
Verify and parse a webhook payload in one call, using this client’s API secret (CHA-2961).
-
#verify_signature(body, signature) ⇒ Boolean
Verify a webhook signature using this client’s API secret (CHA-2961).
-
#video ⇒ GetStream::Generated::VideoClient
The video API client.
-
#wait_for_task(task_id, poll_interval: 1, timeout: 60) ⇒ Object
Polls the task-status endpoint until the task reaches a terminal state.
Constructor Details
#initialize(config = nil, api_key: nil, api_secret: nil, **options) ⇒ Client
Returns a new instance of Client.
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/getstream_ruby/client.rb', line 40 def initialize(config = nil, api_key: nil, api_secret: nil, **) @configuration = config || GetStreamRuby.configuration # Create new configuration with overrides if any parameters provided if api_key || api_secret || !.empty? @configuration = Configuration.with_overrides( api_key: api_key, api_secret: api_secret, **, ) end @configuration.validate! @connection = build_connection @configuration.log_pool_config_to(@configuration.logger) end |
Instance Attribute Details
#configuration ⇒ Object (readonly)
Returns the value of attribute configuration.
38 39 40 |
# File 'lib/getstream_ruby/client.rb', line 38 def configuration @configuration end |
Instance Method Details
#chat ⇒ GetStream::Generated::ChatClient
Returns The chat API client.
79 80 81 |
# File 'lib/getstream_ruby/client.rb', line 79 def chat @chat ||= GetStream::Generated::ChatClient.new(self) end |
#common ⇒ GetStream::Generated::CommonClient
Returns The common API client.
64 65 66 |
# File 'lib/getstream_ruby/client.rb', line 64 def common @common ||= GetStream::Generated::CommonClient.new(self) end |
#feed(feed_group_id, feed_id) ⇒ GetStream::Generated::Feed
Create an individual feed instance
92 93 94 |
# File 'lib/getstream_ruby/client.rb', line 92 def feed(feed_group_id, feed_id) GetStream::Generated::Feed.new(self, feed_group_id, feed_id) end |
#feed_resource ⇒ Object
57 58 59 |
# File 'lib/getstream_ruby/client.rb', line 57 def feed_resource @feed_resource ||= Resources::Feed.new(self) end |
#feeds ⇒ GetStream::Generated::FeedsClient
Returns The feeds API client.
69 70 71 |
# File 'lib/getstream_ruby/client.rb', line 69 def feeds @feeds ||= GetStream::Generated::FeedsClient.new(self) end |
#make_request(method, path, query_params: nil, body: nil, request_timeout: nil) ⇒ Object
192 193 194 195 196 197 198 199 200 201 |
# File 'lib/getstream_ruby/client.rb', line 192 def make_request(method, path, query_params: nil, body: nil, request_timeout: nil) # Handle query parameters if query_params && !query_params.empty? query_string = query_params.map { |k, v| "#{k}=#{v}" }.join('&') path = "#{path}?#{query_string}" end # Make the request request(method, path, body, request_timeout: request_timeout) end |
#moderation ⇒ GetStream::Generated::ModerationClient
Returns The moderation API client.
74 75 76 |
# File 'lib/getstream_ruby/client.rb', line 74 def moderation @moderation ||= GetStream::Generated::ModerationClient.new(self) end |
#parse_sns(notification_body) ⇒ Object
Decode + parse a Stream-delivered SNS notification body.
Accepts either the raw SNS HTTP envelope JSON or the pre-extracted Message string. Convenience wrapper around StreamChat::Webhook.parse_sns. No signature is required; SNS deliveries are authenticated via AWS IAM.
138 139 140 |
# File 'lib/getstream_ruby/client.rb', line 138 def parse_sns(notification_body) StreamChat::Webhook.parse_sns(notification_body) end |
#parse_sqs(message_body) ⇒ Object
Decode + parse a Stream-delivered SQS message body.
Convenience wrapper around StreamChat::Webhook.parse_sqs. No signature is required; SQS deliveries are authenticated via AWS IAM.
129 130 131 |
# File 'lib/getstream_ruby/client.rb', line 129 def parse_sqs() StreamChat::Webhook.parse_sqs() end |
#post(path, body = {}) ⇒ GetStreamRuby::StreamResponse
Returns The API response.
145 146 147 |
# File 'lib/getstream_ruby/client.rb', line 145 def post(path, body = {}) request(:post, path, body) end |
#verify_and_parse_webhook(body, signature) ⇒ Object
Verify and parse a webhook payload in one call, using this client’s API secret (CHA-2961).
Handles gzip-compressed bodies transparently. Raises StreamChat::Webhook::InvalidWebhookError on signature mismatch or parse failures; distinguish failure modes via the message substring.
121 122 123 |
# File 'lib/getstream_ruby/client.rb', line 121 def verify_and_parse_webhook(body, signature) StreamChat::Webhook.verify_and_parse_webhook(body, signature, @configuration.api_secret) end |
#verify_signature(body, signature) ⇒ Boolean
Verify a webhook signature using this client’s API secret (CHA-2961).
Convenience wrapper around StreamChat::Webhook.verify_signature that supplies the secret automatically. The module-level method is still available for callers that need to verify with an arbitrary secret.
105 106 107 |
# File 'lib/getstream_ruby/client.rb', line 105 def verify_signature(body, signature) StreamChat::Webhook.verify_signature(body, signature, @configuration.api_secret) end |
#video ⇒ GetStream::Generated::VideoClient
Returns The video API client.
84 85 86 |
# File 'lib/getstream_ruby/client.rb', line 84 def video @video ||= GetStream::Generated::VideoClient.new(self) end |
#wait_for_task(task_id, poll_interval: 1, timeout: 60) ⇒ Object
Polls the task-status endpoint until the task reaches a terminal state.
Behaviour:
- status="completed": returns the task `result` payload.
- status="failed": raises `TaskError` populated from the task's
`ErrorResult` (`type`, `description`, `stacktrace`,
`version`).
- timeout elapsed: raises `TransportError` with `error_type:
"timeout"`.
165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 |
# File 'lib/getstream_ruby/client.rb', line 165 def wait_for_task(task_id, poll_interval: 1, timeout: 60) start_time = monotonic_now loop do response = common.get_task(task_id) status = response.status case status when 'completed' return response.result when 'failed' raise ErrorMapping.build_task_error(task_id, response.error) end if monotonic_now - start_time >= timeout raise TransportError.new( "wait_for_task timed out after #{timeout}s for task_id=#{task_id}", error_type: 'timeout', ) end sleep(poll_interval) end end |