Class: StreamChat::Channel

Inherits:
Object
  • Object
show all
Extended by:
T::Sig
Defined in:
lib/stream-chat/channel.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(client, channel_type, channel_id = nil, custom_data = nil) ⇒ Channel

Returns a new instance of Channel.



30
31
32
33
34
35
36
37
# File 'lib/stream-chat/channel.rb', line 30

def initialize(client, channel_type, channel_id = nil, custom_data = nil)
  @channel_type = channel_type
  @id = channel_id
  @cid = T.let("#{@channel_type}:#{@id}", String)
  @client = client
  @custom_data = T.let(custom_data || {}, StringKeyHash)
  @members = T.let([], T::Array[StringKeyHash])
end

Instance Attribute Details

#channel_typeObject (readonly)

Returns the value of attribute channel_type.



21
22
23
# File 'lib/stream-chat/channel.rb', line 21

def channel_type
  @channel_type
end

#custom_dataObject (readonly)

Returns the value of attribute custom_data.



24
25
26
# File 'lib/stream-chat/channel.rb', line 24

def custom_data
  @custom_data
end

#idObject (readonly)

Returns the value of attribute id.



18
19
20
# File 'lib/stream-chat/channel.rb', line 18

def id
  @id
end

#membersObject (readonly)

Returns the value of attribute members.



27
28
29
# File 'lib/stream-chat/channel.rb', line 27

def members
  @members
end

Instance Method Details

#accept_invite(user_id, **options) ⇒ Object



162
163
164
165
# File 'lib/stream-chat/channel.rb', line 162

def accept_invite(user_id, **options)
  payload = options.merge({ user_id: user_id, accept_invite: true })
  update(nil, nil, **payload)
end

#add_members(user_ids, **options) ⇒ Object



150
151
152
153
# File 'lib/stream-chat/channel.rb', line 150

def add_members(user_ids, **options)
  payload = options.merge({ add_members: user_ids })
  update(nil, nil, **payload)
end

#add_moderators(user_ids) ⇒ Object



174
175
176
# File 'lib/stream-chat/channel.rb', line 174

def add_moderators(user_ids)
  update(nil, nil, add_moderators: user_ids)
end

#assign_roles(members, message = nil) ⇒ Object



184
185
186
# File 'lib/stream-chat/channel.rb', line 184

def assign_roles(members, message = nil)
  update(nil, message, assign_roles: members)
end

#ban_user(user_id, **options) ⇒ Object



210
211
212
# File 'lib/stream-chat/channel.rb', line 210

def ban_user(user_id, **options)
  @client.ban_user(user_id, type: @channel_type, id: @id, **options)
end

#create(user_id) ⇒ Object



78
79
80
81
# File 'lib/stream-chat/channel.rb', line 78

def create(user_id)
  @custom_data['created_by'] = { id: user_id }
  query(watch: false, state: false, presence: false)
end

#deleteObject



128
129
130
# File 'lib/stream-chat/channel.rb', line 128

def delete
  @client.delete(url)
end

#delete_file(url) ⇒ Object



240
241
242
# File 'lib/stream-chat/channel.rb', line 240

def delete_file(url)
  @client.delete("#{self.url}/file", params: { url: url })
end

#delete_image(url) ⇒ Object



245
246
247
# File 'lib/stream-chat/channel.rb', line 245

def delete_image(url)
  @client.delete("#{self.url}/image", params: { url: url })
end

#delete_reaction(message_id, reaction_type, user_id) ⇒ Object



70
71
72
73
74
75
# File 'lib/stream-chat/channel.rb', line 70

def delete_reaction(message_id, reaction_type, user_id)
  @client.delete(
    "messages/#{message_id}/reaction/#{reaction_type}",
    params: { user_id: user_id }
  )
end

#demote_moderators(user_ids) ⇒ Object



189
190
191
# File 'lib/stream-chat/channel.rb', line 189

def demote_moderators(user_ids)
  update(nil, nil, demote_moderators: user_ids)
end

#get_messages(message_ids) ⇒ Object



47
48
49
# File 'lib/stream-chat/channel.rb', line 47

def get_messages(message_ids)
  @client.get("#{url}/messages", params: { 'ids' => message_ids.join(',') })
end

#get_reactions(message_id, **options) ⇒ Object



205
206
207
# File 'lib/stream-chat/channel.rb', line 205

def get_reactions(message_id, **options)
  @client.get("messages/#{message_id}/reactions", params: options)
end

#get_replies(parent_id, **options) ⇒ Object



200
201
202
# File 'lib/stream-chat/channel.rb', line 200

def get_replies(parent_id, **options)
  @client.get("messages/#{parent_id}/replies", params: options)
end

#hide(user_id) ⇒ Object



220
221
222
# File 'lib/stream-chat/channel.rb', line 220

def hide(user_id)
  @client.post("#{url}/hide", data: { user_id: user_id })
end

#invite_members(user_ids, **options) ⇒ Object



156
157
158
159
# File 'lib/stream-chat/channel.rb', line 156

def invite_members(user_ids, **options)
  payload = options.merge({ invites: user_ids })
  update(nil, nil, **payload)
end

#mark_read(user_id, **options) ⇒ Object



194
195
196
197
# File 'lib/stream-chat/channel.rb', line 194

def mark_read(user_id, **options)
  payload = add_user_id(options, user_id)
  @client.post("#{url}/read", data: payload)
end

#mute(user_id, expiration = nil) ⇒ Object



138
139
140
141
142
# File 'lib/stream-chat/channel.rb', line 138

def mute(user_id, expiration = nil)
  data = { user_id: user_id, channel_cid: @cid }
  data['expiration'] = expiration if expiration
  @client.post('moderation/mute/channel', data: data)
end

#query(**options) ⇒ Object



84
85
86
87
88
89
90
91
92
# File 'lib/stream-chat/channel.rb', line 84

def query(**options)
  payload = { state: true, data: @custom_data }.merge(options)
  url = "channels/#{@channel_type}"
  url = "#{url}/#{@id}" unless @id.nil?

  state = @client.post("#{url}/query", data: payload)
  @id = state['channel']['id'] if @id.nil?
  state
end

#query_members(filter_conditions = {}, sort: nil, **options) ⇒ Object



95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# File 'lib/stream-chat/channel.rb', line 95

def query_members(filter_conditions = {}, sort: nil, **options)
  params = {}.merge(options).merge({
                                     id: @id,
                                     type: @channel_type,
                                     filter_conditions: filter_conditions,
                                     sort: StreamChat.get_sort_fields(sort)
                                   })

  if @id == '' && @members.length.positive?
    params['members'] = []
    @members.each do |m|
      params['members'] << m['user'].nil? ? m['user_id'] : m['user']['id']
    end
  end

  @client.get('members', params: { payload: params.to_json })
end

#reject_invite(user_id, **options) ⇒ Object



168
169
170
171
# File 'lib/stream-chat/channel.rb', line 168

def reject_invite(user_id, **options)
  payload = options.merge({ user_id: user_id, reject_invite: true })
  update(nil, nil, **payload)
end

#remove_members(user_ids) ⇒ Object



179
180
181
# File 'lib/stream-chat/channel.rb', line 179

def remove_members(user_ids)
  update(nil, nil, remove_members: user_ids)
end

#send_event(event, user_id) ⇒ Object



58
59
60
61
# File 'lib/stream-chat/channel.rb', line 58

def send_event(event, user_id)
  payload = { 'event' => add_user_id(event, user_id) }
  @client.post("#{url}/event", data: payload)
end

#send_file(url, user, content_type = nil) ⇒ Object



230
231
232
# File 'lib/stream-chat/channel.rb', line 230

def send_file(url, user, content_type = nil)
  @client.send_file("#{self.url}/file", url, user, content_type)
end

#send_image(url, user, content_type = nil) ⇒ Object



235
236
237
# File 'lib/stream-chat/channel.rb', line 235

def send_image(url, user, content_type = nil)
  @client.send_file("#{self.url}/image", url, user, content_type)
end

#send_message(message, user_id) ⇒ Object



52
53
54
55
# File 'lib/stream-chat/channel.rb', line 52

def send_message(message, user_id)
  payload = { message: add_user_id(message, user_id) }
  @client.post("#{url}/message", data: payload)
end

#send_reaction(message_id, reaction, user_id) ⇒ Object



64
65
66
67
# File 'lib/stream-chat/channel.rb', line 64

def send_reaction(message_id, reaction, user_id)
  payload = { reaction: add_user_id(reaction, user_id) }
  @client.post("messages/#{message_id}/reaction", data: payload)
end

#show(user_id) ⇒ Object



225
226
227
# File 'lib/stream-chat/channel.rb', line 225

def show(user_id)
  @client.post("#{url}/show", data: { user_id: user_id })
end

#truncate(**options) ⇒ Object



133
134
135
# File 'lib/stream-chat/channel.rb', line 133

def truncate(**options)
  @client.post("#{url}/truncate", data: options)
end

#unban_user(user_id) ⇒ Object



215
216
217
# File 'lib/stream-chat/channel.rb', line 215

def unban_user(user_id)
  @client.unban_user(user_id, type: @channel_type, id: @id)
end

#unmute(user_id) ⇒ Object



145
146
147
# File 'lib/stream-chat/channel.rb', line 145

def unmute(user_id)
  @client.post('moderation/unmute/channel', data: { 'user_id' => user_id, 'channel_cid' => @cid })
end

#update(channel_data, update_message = nil, **options) ⇒ Object



114
115
116
117
# File 'lib/stream-chat/channel.rb', line 114

def update(channel_data, update_message = nil, **options)
  payload = { data: channel_data, message: update_message }.merge(options)
  @client.post(url, data: payload)
end

#update_partial(set = nil, unset = nil) ⇒ Object



120
121
122
123
124
125
# File 'lib/stream-chat/channel.rb', line 120

def update_partial(set = nil, unset = nil)
  raise StreamChannelException, 'set or unset is needed' if set.nil? && unset.nil?

  payload = { set: set, unset: unset }
  @client.patch(url, data: payload)
end

#urlObject



40
41
42
43
44
# File 'lib/stream-chat/channel.rb', line 40

def url
  raise StreamChannelException, 'channel does not have an id' if @id.nil?

  "channels/#{@channel_type}/#{@id}"
end