Class: GetStreamRuby::Client

Inherits:
Object
  • Object
show all
Defined in:
lib/getstream_ruby/client.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(config = nil, api_key: nil, api_secret: nil, **options) ⇒ Client

Returns a new instance of Client.



25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/getstream_ruby/client.rb', line 25

def initialize(config = nil, api_key: nil, api_secret: nil, **options)
  @configuration = config || GetStreamRuby.configuration

  # Create new configuration with overrides if any parameters provided
  if api_key || api_secret || !options.empty?
    @configuration = Configuration.with_overrides(
      api_key: api_key,
      api_secret: api_secret,
      **options,
    )
  end

  @configuration.validate!
  @connection = build_connection
end

Instance Attribute Details

#configurationObject (readonly)

Returns the value of attribute configuration.



23
24
25
# File 'lib/getstream_ruby/client.rb', line 23

def configuration
  @configuration
end

Instance Method Details

#chatGetStream::Generated::ChatClient

Returns The chat API client.

Returns:



63
64
65
# File 'lib/getstream_ruby/client.rb', line 63

def chat
  @chat ||= GetStream::Generated::ChatClient.new(self)
end

#commonGetStream::Generated::CommonClient

Returns The common API client.

Returns:



48
49
50
# File 'lib/getstream_ruby/client.rb', line 48

def common
  @common ||= GetStream::Generated::CommonClient.new(self)
end

#feed(feed_group_id, feed_id) ⇒ GetStream::Generated::Feed

Create an individual feed instance

Parameters:

  • feed_group_id (String)

    The feed group ID

  • feed_id (String)

    The feed ID

Returns:



76
77
78
# File 'lib/getstream_ruby/client.rb', line 76

def feed(feed_group_id, feed_id)
  GetStream::Generated::Feed.new(self, feed_group_id, feed_id)
end

#feed_resourceObject



41
42
43
# File 'lib/getstream_ruby/client.rb', line 41

def feed_resource
  @feed_resource ||= Resources::Feed.new(self)
end

#feedsGetStream::Generated::FeedsClient

Returns The feeds API client.

Returns:



53
54
55
# File 'lib/getstream_ruby/client.rb', line 53

def feeds
  @feeds ||= GetStream::Generated::FeedsClient.new(self)
end

#make_request(method, path, query_params: nil, body: nil) ⇒ Object



133
134
135
136
137
138
139
140
141
142
# File 'lib/getstream_ruby/client.rb', line 133

def make_request(method, path, query_params: nil, body: 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)
end

#moderationGetStream::Generated::ModerationClient

Returns The moderation API client.

Returns:



58
59
60
# File 'lib/getstream_ruby/client.rb', line 58

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.



122
123
124
# File 'lib/getstream_ruby/client.rb', line 122

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.



113
114
115
# File 'lib/getstream_ruby/client.rb', line 113

def parse_sqs(message_body)
  StreamChat::Webhook.parse_sqs(message_body)
end

#post(path, body = {}) ⇒ GetStreamRuby::StreamResponse

Returns The API response.

Parameters:

  • path (String)

    The API path

  • body (Hash) (defaults to: {})

    The request body

Returns:



129
130
131
# File 'lib/getstream_ruby/client.rb', line 129

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.

Parameters:

  • body (String)

    raw request body (possibly gzip-compressed)

  • signature (String)

    X-Signature header value

Returns:

  • (Object)

    the typed event class instance or StreamChat::Webhook::UnknownEvent

Raises:



105
106
107
# File 'lib/getstream_ruby/client.rb', line 105

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.

Parameters:

  • body (String)

    The raw request body (already-decompressed)

  • signature (String)

    The signature from the X-Signature header

Returns:

  • (Boolean)

    true if the signature is valid, false otherwise



89
90
91
# File 'lib/getstream_ruby/client.rb', line 89

def verify_signature(body, signature)
  StreamChat::Webhook.verify_signature(body, signature, @configuration.api_secret)
end

#videoGetStream::Generated::VideoClient

Returns The video API client.

Returns:



68
69
70
# File 'lib/getstream_ruby/client.rb', line 68

def video
  @video ||= GetStream::Generated::VideoClient.new(self)
end