Class: StreamChat::Channel
- Inherits:
-
Object
- Object
- StreamChat::Channel
- Extended by:
- T::Sig
- Defined in:
- lib/stream-chat/channel.rb
Instance Attribute Summary collapse
-
#channel_type ⇒ Object
readonly
Returns the value of attribute channel_type.
-
#cid ⇒ Object
readonly
Returns the value of attribute cid.
-
#custom_data ⇒ Object
readonly
Returns the value of attribute custom_data.
-
#id ⇒ Object
readonly
Returns the value of attribute id.
-
#members ⇒ Object
readonly
Returns the value of attribute members.
Instance Method Summary collapse
- #accept_invite(user_id, **options) ⇒ Object
- #add_members(user_ids, **options) ⇒ Object
- #add_moderators(user_ids) ⇒ Object
- #archive(user_id) ⇒ Object
- #assign_roles(members, message = nil) ⇒ Object
- #ban_user(user_id, **options) ⇒ Object
- #create(user_id) ⇒ Object
- #create_draft(message, user_id) ⇒ Object
- #delete ⇒ Object
- #delete_draft(user_id, parent_id: nil) ⇒ Object
- #delete_file(url) ⇒ Object
- #delete_image(url) ⇒ Object
- #delete_reaction(message_id, reaction_type, user_id) ⇒ Object
- #demote_moderators(user_ids) ⇒ Object
- #get_draft(user_id, parent_id: nil) ⇒ Object
- #get_messages(message_ids) ⇒ Object
- #get_reactions(message_id, **options) ⇒ Object
- #get_replies(parent_id, **options) ⇒ Object
- #hide(user_id) ⇒ Object
-
#initialize(client, channel_type, channel_id = nil, custom_data = nil) ⇒ Channel
constructor
A new instance of Channel.
- #invite_members(user_ids, **options) ⇒ Object
- #mark_read(user_id, **options) ⇒ Object
- #mute(user_id, expiration = nil) ⇒ Object
- #pin(user_id) ⇒ Object
- #query(**options) ⇒ Object
- #query_members(filter_conditions = {}, sort: nil, **options) ⇒ Object
- #reject_invite(user_id, **options) ⇒ Object
- #remove_members(user_ids) ⇒ Object
- #send_event(event, user_id) ⇒ Object
- #send_file(url, user, content_type = nil) ⇒ Object
- #send_image(url, user, content_type = nil) ⇒ Object
- #send_message(message, user_id, **options) ⇒ Object
- #send_reaction(message_id, reaction, user_id) ⇒ Object
- #show(user_id) ⇒ Object
- #truncate(**options) ⇒ Object
- #unarchive(user_id) ⇒ Object
- #unban_user(user_id) ⇒ Object
- #unmute(user_id) ⇒ Object
- #unpin(user_id) ⇒ Object
- #update(channel_data, update_message = nil, **options) ⇒ Object
- #update_member_partial(user_id, set: nil, unset: nil) ⇒ Object
- #update_partial(set = nil, unset = nil) ⇒ Object
- #url ⇒ Object
Constructor Details
#initialize(client, channel_type, channel_id = nil, custom_data = nil) ⇒ Channel
Returns a new instance of Channel.
29 30 31 32 33 34 35 36 |
# File 'lib/stream-chat/channel.rb', line 29 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_type ⇒ Object (readonly)
Returns the value of attribute channel_type.
17 18 19 |
# File 'lib/stream-chat/channel.rb', line 17 def channel_type @channel_type end |
#cid ⇒ Object (readonly)
Returns the value of attribute cid.
20 21 22 |
# File 'lib/stream-chat/channel.rb', line 20 def cid @cid end |
#custom_data ⇒ Object (readonly)
Returns the value of attribute custom_data.
23 24 25 |
# File 'lib/stream-chat/channel.rb', line 23 def custom_data @custom_data end |
#id ⇒ Object (readonly)
Returns the value of attribute id.
14 15 16 |
# File 'lib/stream-chat/channel.rb', line 14 def id @id end |
#members ⇒ Object (readonly)
Returns the value of attribute members.
26 27 28 |
# File 'lib/stream-chat/channel.rb', line 26 def members @members end |
Instance Method Details
#accept_invite(user_id, **options) ⇒ Object
250 251 252 253 |
# File 'lib/stream-chat/channel.rb', line 250 def accept_invite(user_id, **) payload = .merge({ user_id: user_id, accept_invite: true }) update(nil, nil, **payload) end |
#add_members(user_ids, **options) ⇒ Object
236 237 238 239 |
# File 'lib/stream-chat/channel.rb', line 236 def add_members(user_ids, **) payload = .merge({ add_members: user_ids }) update(nil, nil, **payload) end |
#add_moderators(user_ids) ⇒ Object
264 265 266 |
# File 'lib/stream-chat/channel.rb', line 264 def add_moderators(user_ids) update(nil, nil, add_moderators: user_ids) end |
#archive(user_id) ⇒ Object
200 201 202 203 204 205 206 207 208 209 |
# File 'lib/stream-chat/channel.rb', line 200 def archive(user_id) raise StreamChannelException, 'user ID must not be empty' if user_id.empty? payload = { set: { archived: true } } @client.patch("#{url}/member/#{CGI.escape(user_id)}", data: payload) end |
#assign_roles(members, message = nil) ⇒ Object
276 277 278 |
# File 'lib/stream-chat/channel.rb', line 276 def assign_roles(members, = nil) update(nil, , assign_roles: members) end |
#ban_user(user_id, **options) ⇒ Object
307 308 309 |
# File 'lib/stream-chat/channel.rb', line 307 def ban_user(user_id, **) @client.ban_user(user_id, type: @channel_type, id: @id, **) end |
#create(user_id) ⇒ Object
83 84 85 86 |
# File 'lib/stream-chat/channel.rb', line 83 def create(user_id) @custom_data['created_by'] = { id: user_id } query(watch: false, state: false, presence: false) end |
#create_draft(message, user_id) ⇒ Object
369 370 371 372 |
# File 'lib/stream-chat/channel.rb', line 369 def create_draft(, user_id) payload = { message: add_user_id(, user_id) } @client.post("#{url}/draft", data: payload) end |
#delete ⇒ Object
143 144 145 |
# File 'lib/stream-chat/channel.rb', line 143 def delete @client.delete(url) end |
#delete_draft(user_id, parent_id: nil) ⇒ Object
380 381 382 383 384 |
# File 'lib/stream-chat/channel.rb', line 380 def delete_draft(user_id, parent_id: nil) params = { user_id: user_id } params[:parent_id] = parent_id if parent_id @client.delete("#{url}/draft", params: params) end |
#delete_file(url) ⇒ Object
353 354 355 |
# File 'lib/stream-chat/channel.rb', line 353 def delete_file(url) @client.delete("#{self.url}/file", params: { url: url }) end |
#delete_image(url) ⇒ Object
359 360 361 |
# File 'lib/stream-chat/channel.rb', line 359 def delete_image(url) @client.delete("#{self.url}/image", params: { url: url }) end |
#delete_reaction(message_id, reaction_type, user_id) ⇒ Object
74 75 76 77 78 79 |
# File 'lib/stream-chat/channel.rb', line 74 def delete_reaction(, reaction_type, user_id) @client.delete( "messages/#{}/reaction/#{reaction_type}", params: { user_id: user_id } ) end |
#demote_moderators(user_ids) ⇒ Object
282 283 284 |
# File 'lib/stream-chat/channel.rb', line 282 def demote_moderators(user_ids) update(nil, nil, demote_moderators: user_ids) end |
#get_draft(user_id, parent_id: nil) ⇒ Object
392 393 394 395 396 |
# File 'lib/stream-chat/channel.rb', line 392 def get_draft(user_id, parent_id: nil) params = { user_id: user_id } params[:parent_id] = parent_id if parent_id @client.get("#{url}/draft", params: params) end |
#get_messages(message_ids) ⇒ Object
47 48 49 |
# File 'lib/stream-chat/channel.rb', line 47 def () @client.get("#{url}/messages", params: { 'ids' => .join(',') }) end |
#get_reactions(message_id, **options) ⇒ Object
301 302 303 |
# File 'lib/stream-chat/channel.rb', line 301 def get_reactions(, **) @client.get("messages/#{}/reactions", params: ) end |
#get_replies(parent_id, **options) ⇒ Object
295 296 297 |
# File 'lib/stream-chat/channel.rb', line 295 def get_replies(parent_id, **) @client.get("messages/#{parent_id}/replies", params: ) end |
#hide(user_id) ⇒ Object
320 321 322 |
# File 'lib/stream-chat/channel.rb', line 320 def hide(user_id) @client.post("#{url}/hide", data: { user_id: user_id }) end |
#invite_members(user_ids, **options) ⇒ Object
243 244 245 246 |
# File 'lib/stream-chat/channel.rb', line 243 def invite_members(user_ids, **) payload = .merge({ invites: user_ids }) update(nil, nil, **payload) end |
#mark_read(user_id, **options) ⇒ Object
288 289 290 291 |
# File 'lib/stream-chat/channel.rb', line 288 def mark_read(user_id, **) payload = add_user_id(, user_id) @client.post("#{url}/read", data: payload) end |
#mute(user_id, expiration = nil) ⇒ Object
160 161 162 163 164 |
# File 'lib/stream-chat/channel.rb', line 160 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 |
#pin(user_id) ⇒ Object
174 175 176 177 178 179 180 181 182 183 |
# File 'lib/stream-chat/channel.rb', line 174 def pin(user_id) raise StreamChannelException, 'user ID must not be empty' if user_id.empty? payload = { set: { pinned: true } } @client.patch("#{url}/member/#{CGI.escape(user_id)}", data: payload) end |
#query(**options) ⇒ Object
90 91 92 93 94 95 96 97 98 |
# File 'lib/stream-chat/channel.rb', line 90 def query(**) payload = { state: true, data: @custom_data }.merge() 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
107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 |
# File 'lib/stream-chat/channel.rb', line 107 def query_members(filter_conditions = {}, sort: nil, **) params = {}.merge().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
257 258 259 260 |
# File 'lib/stream-chat/channel.rb', line 257 def reject_invite(user_id, **) payload = .merge({ user_id: user_id, reject_invite: true }) update(nil, nil, **payload) end |
#remove_members(user_ids) ⇒ Object
270 271 272 |
# File 'lib/stream-chat/channel.rb', line 270 def remove_members(user_ids) update(nil, nil, remove_members: user_ids) end |
#send_event(event, user_id) ⇒ Object
60 61 62 63 |
# File 'lib/stream-chat/channel.rb', line 60 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
336 337 338 |
# File 'lib/stream-chat/channel.rb', line 336 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
347 348 349 |
# File 'lib/stream-chat/channel.rb', line 347 def send_image(url, user, content_type = nil) @client.send_file("#{self.url}/image", url, user, content_type) end |
#send_message(message, user_id, **options) ⇒ Object
53 54 55 56 |
# File 'lib/stream-chat/channel.rb', line 53 def (, user_id, **) payload = .merge({ message: add_user_id(, user_id) }) @client.post("#{url}/message", data: payload) end |
#send_reaction(message_id, reaction, user_id) ⇒ Object
67 68 69 70 |
# File 'lib/stream-chat/channel.rb', line 67 def send_reaction(, reaction, user_id) payload = { reaction: add_user_id(reaction, user_id) } @client.post("messages/#{}/reaction", data: payload) end |
#show(user_id) ⇒ Object
327 328 329 |
# File 'lib/stream-chat/channel.rb', line 327 def show(user_id) @client.post("#{url}/show", data: { user_id: user_id }) end |
#truncate(**options) ⇒ Object
149 150 151 |
# File 'lib/stream-chat/channel.rb', line 149 def truncate(**) @client.post("#{url}/truncate", data: ) end |
#unarchive(user_id) ⇒ Object
213 214 215 216 217 218 219 220 221 222 |
# File 'lib/stream-chat/channel.rb', line 213 def unarchive(user_id) raise StreamChannelException, 'user ID must not be empty' if user_id.empty? payload = { set: { archived: false } } @client.patch("#{url}/member/#{CGI.escape(user_id)}", data: payload) end |
#unban_user(user_id) ⇒ Object
313 314 315 |
# File 'lib/stream-chat/channel.rb', line 313 def unban_user(user_id) @client.unban_user(user_id, type: @channel_type, id: @id) end |
#unmute(user_id) ⇒ Object
168 169 170 |
# File 'lib/stream-chat/channel.rb', line 168 def unmute(user_id) @client.post('moderation/unmute/channel', data: { 'user_id' => user_id, 'channel_cid' => @cid }) end |
#unpin(user_id) ⇒ Object
187 188 189 190 191 192 193 194 195 196 |
# File 'lib/stream-chat/channel.rb', line 187 def unpin(user_id) raise StreamChannelException, 'user ID must not be empty' if user_id.empty? payload = { set: { pinned: false } } @client.patch("#{url}/member/#{CGI.escape(user_id)}", data: payload) end |
#update(channel_data, update_message = nil, **options) ⇒ Object
127 128 129 130 |
# File 'lib/stream-chat/channel.rb', line 127 def update(channel_data, = nil, **) payload = { data: channel_data, message: }.merge() @client.post(url, data: payload) end |
#update_member_partial(user_id, set: nil, unset: nil) ⇒ Object
226 227 228 229 230 231 232 |
# File 'lib/stream-chat/channel.rb', line 226 def update_member_partial(user_id, set: nil, unset: nil) raise StreamChannelException, 'user ID must not be empty' if user_id.empty? raise StreamChannelException, 'set or unset is required' if set.nil? && unset.nil? payload = { set: set, unset: unset } @client.patch("#{url}/member/#{CGI.escape(user_id)}", data: payload) end |
#update_partial(set = nil, unset = nil) ⇒ Object
134 135 136 137 138 139 |
# File 'lib/stream-chat/channel.rb', line 134 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 |
#url ⇒ Object
39 40 41 42 43 |
# File 'lib/stream-chat/channel.rb', line 39 def url raise StreamChannelException, 'channel does not have an id' if @id.nil? "channels/#{@channel_type}/#{@id}" end |