Class: Discordrb::Message

Inherits:
Object
  • Object
show all
Includes:
IDObject
Defined in:
lib/discordrb/data/message.rb

Overview

A message on Discord that was sent to a text channel

Instance Attribute Summary collapse

Attributes included from IDObject

#id

Instance Method Summary collapse

Methods included from IDObject

#==, #creation_time, synthesise

Instance Attribute Details

#attachmentsArray<Attachment> (readonly)



36
37
38
# File 'lib/discordrb/data/message.rb', line 36

def attachments
  @attachments
end

#authorMember, User (readonly) Also known as: user, writer



15
16
17
# File 'lib/discordrb/data/message.rb', line 15

def author
  @author
end

#channelChannel (readonly)



20
21
22
# File 'lib/discordrb/data/message.rb', line 20

def channel
  @channel
end

#componentsArray<Component> (readonly)



74
75
76
# File 'lib/discordrb/data/message.rb', line 74

def components
  @components
end

#contentString (readonly) Also known as: text, to_s



9
10
11
# File 'lib/discordrb/data/message.rb', line 9

def content
  @content
end

#editedtrue, false (readonly) Also known as: edited?



52
53
54
# File 'lib/discordrb/data/message.rb', line 52

def edited
  @edited
end

#edited_timestampTime (readonly) Also known as: edit_timestamp



26
27
28
# File 'lib/discordrb/data/message.rb', line 26

def edited_timestamp
  @edited_timestamp
end

#embedsArray<Embed> (readonly)



39
40
41
# File 'lib/discordrb/data/message.rb', line 39

def embeds
  @embeds
end

#mention_everyonetrue, false (readonly) Also known as: mention_everyone?, mentions_everyone?



56
57
58
# File 'lib/discordrb/data/message.rb', line 56

def mention_everyone
  @mention_everyone
end

#mentionsArray<User> (readonly)



30
31
32
# File 'lib/discordrb/data/message.rb', line 30

def mentions
  @mentions
end

#nonceString (readonly)



49
50
51
# File 'lib/discordrb/data/message.rb', line 49

def nonce
  @nonce
end

#pinnedtrue, false (readonly) Also known as: pinned?



61
62
63
# File 'lib/discordrb/data/message.rb', line 61

def pinned
  @pinned
end

#reactionsArray<Reaction> (readonly)



42
43
44
# File 'lib/discordrb/data/message.rb', line 42

def reactions
  @reactions
end

#role_mentionsArray<Role> (readonly)



33
34
35
# File 'lib/discordrb/data/message.rb', line 33

def role_mentions
  @role_mentions
end

#serverServer? (readonly)



68
69
70
# File 'lib/discordrb/data/message.rb', line 68

def server
  @server
end

#timestampTime (readonly)



23
24
25
# File 'lib/discordrb/data/message.rb', line 23

def timestamp
  @timestamp
end

#ttstrue, false (readonly) Also known as: tts?



45
46
47
# File 'lib/discordrb/data/message.rb', line 45

def tts
  @tts
end

#typeInteger (readonly)



65
66
67
# File 'lib/discordrb/data/message.rb', line 65

def type
  @type
end

#webhook_idInteger? (readonly)



71
72
73
# File 'lib/discordrb/data/message.rb', line 71

def webhook_id
  @webhook_id
end

Instance Method Details

#all_reaction_users(limit: 100) ⇒ Hash<String => Array<User>>

Returns a hash of all reactions to a message as keys and the users that reacted to it as values.

Examples:

Get all the users that reacted to a message for a giveaway.

giveaway_participants = message.all_reaction_users


334
335
336
337
# File 'lib/discordrb/data/message.rb', line 334

def all_reaction_users(limit: 100)
  all_reactions = @reactions.map { |r| { r.to_s => reacted_with(r, limit: limit) } }
  all_reactions.reduce({}, :merge)
end

#await(key, attributes = {}, &block) ⇒ Object

Deprecated.

Will be changed to blocking behavior in v4.0. Use #await! instead.

Add an Await for a message with the same user and channel.

See Also:



230
231
232
# File 'lib/discordrb/data/message.rb', line 230

def await(key, attributes = {}, &block)
  @bot.add_await(key, Discordrb::Events::MessageEvent, { from: @author.id, in: @channel.id }.merge(attributes), &block)
end

#await!(attributes = {}, &block) ⇒ Object

Add a blocking Await for a message with the same user and channel.

See Also:



236
237
238
# File 'lib/discordrb/data/message.rb', line 236

def await!(attributes = {}, &block)
  @bot.add_await!(Discordrb::Events::MessageEvent, { from: @author.id, in: @channel.id }.merge(attributes), &block)
end

#await_reaction(key, attributes = {}, &block) ⇒ Object

Deprecated.

Will be changed to blocking behavior in v4.0. Use #await_reaction! instead.

Add an Await for a reaction to be added on this message.

See Also:



243
244
245
# File 'lib/discordrb/data/message.rb', line 243

def await_reaction(key, attributes = {}, &block)
  @bot.add_await(key, Discordrb::Events::ReactionAddEvent, { message: @id }.merge(attributes), &block)
end

#await_reaction!(attributes = {}, &block) ⇒ Object

Add a blocking Await for a reaction to be added on this message.

See Also:



249
250
251
# File 'lib/discordrb/data/message.rb', line 249

def await_reaction!(attributes = {}, &block)
  @bot.add_await!(Discordrb::Events::ReactionAddEvent, { message: @id }.merge(attributes), &block)
end

#buttonsArray<Components::Button>



393
394
395
396
397
398
399
400
401
402
403
404
# File 'lib/discordrb/data/message.rb', line 393

def buttons
  results = @components.collect do |component|
    case component
    when Components::Button
      component
    when Components::ActionRow
      component.buttons
    end
  end

  results.flatten.compact
end

#chat_input_command?true, false

Whether or not this message was of type "CHAT_INPUT_COMMAND"



379
380
381
# File 'lib/discordrb/data/message.rb', line 379

def chat_input_command?
  @type == 20
end

#create_reaction(reaction) ⇒ Object Also known as: react

Reacts to a message.



291
292
293
294
295
# File 'lib/discordrb/data/message.rb', line 291

def create_reaction(reaction)
  reaction = reaction.to_reaction if reaction.respond_to?(:to_reaction)
  API::Channel.create_reaction(@bot.token, @channel.id, @id, reaction)
  nil
end

#delete(reason = nil) ⇒ Object

Deletes this message.



208
209
210
211
# File 'lib/discordrb/data/message.rb', line 208

def delete(reason = nil)
  API::Channel.delete_message(@bot.token, @channel.id, @id, reason)
  nil
end

#delete_all_reactionsObject

Removes all reactions from this message.



355
356
357
# File 'lib/discordrb/data/message.rb', line 355

def delete_all_reactions
  API::Channel.delete_all_reactions(@bot.token, @channel.id, @id)
end

#delete_own_reaction(reaction) ⇒ Object

Deletes this client's reaction on this message.



349
350
351
352
# File 'lib/discordrb/data/message.rb', line 349

def delete_own_reaction(reaction)
  reaction = reaction.to_reaction if reaction.respond_to?(:to_reaction)
  API::Channel.delete_own_reaction(@bot.token, @channel.id, @id, reaction)
end

#delete_reaction(user, reaction) ⇒ Object

Deletes a reaction made by a user on this message.



342
343
344
345
# File 'lib/discordrb/data/message.rb', line 342

def delete_reaction(user, reaction)
  reaction = reaction.to_reaction if reaction.respond_to?(:to_reaction)
  API::Channel.delete_user_reaction(@bot.token, @channel.id, @id, reaction, user.resolve_id)
end

#edit(new_content, new_embeds = nil, new_components = nil) ⇒ Message

Edits this message to have the specified content instead. You can only edit your own messages.



199
200
201
202
203
204
205
# File 'lib/discordrb/data/message.rb', line 199

def edit(new_content, new_embeds = nil, new_components = nil)
  new_embeds = (new_embeds.instance_of?(Array) ? new_embeds.map(&:to_hash) : [new_embeds&.to_hash]).compact
  new_components = new_components&.to_a || []

  response = API::Channel.edit_message(@bot.token, @channel.id, @id, new_content, [], new_embeds, new_components)
  Message.new(JSON.parse(response), @bot)
end

#emojiArray<Emoji>



264
265
266
267
268
269
# File 'lib/discordrb/data/message.rb', line 264

def emoji
  return if @content.nil?
  return @emoji unless @emoji.empty?

  @emoji = @bot.parse_mentions(@content).select { |el| el.is_a? Discordrb::Emoji }
end

#emoji?true, false

Check if any emoji were used in this message.



273
274
275
# File 'lib/discordrb/data/message.rb', line 273

def emoji?
  emoji&.empty?
end

#from_bot?true, false



254
255
256
# File 'lib/discordrb/data/message.rb', line 254

def from_bot?
  @author&.current_bot?
end

#inspectObject

The inspect method is overwritten to give more useful output



360
361
362
# File 'lib/discordrb/data/message.rb', line 360

def inspect
  "<Message content=\"#{@content}\" id=#{@id} timestamp=#{@timestamp} author=#{@author} channel=#{@channel}>"
end


365
366
367
# File 'lib/discordrb/data/message.rb', line 365

def link
  "https://discord.com/channels/#{@server&.id || '@me'}/#{@channel.id}/#{@id}"
end

#my_reactionsArray<Reaction>

Returns the reactions made by the current bot or user.



285
286
287
# File 'lib/discordrb/data/message.rb', line 285

def my_reactions
  @reactions.select(&:me)
end

#pin(reason = nil) ⇒ Object

Pins this message



214
215
216
217
218
# File 'lib/discordrb/data/message.rb', line 214

def pin(reason = nil)
  API::Channel.pin_message(@bot.token, @channel.id, @id, reason)
  @pinned = true
  nil
end

#reacted_with(reaction, limit: 100) ⇒ Array<User>

Returns the list of users who reacted with a certain reaction.

Examples:

Get all the users that reacted with a thumbs up.

thumbs_up_reactions = message.reacted_with("\u{1F44D}")


305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
# File 'lib/discordrb/data/message.rb', line 305

def reacted_with(reaction, limit: 100)
  reaction = reaction.to_reaction if reaction.respond_to?(:to_reaction)
  reaction = reaction.to_s if reaction.respond_to?(:to_s)

  get_reactions = proc do |fetch_limit, after_id = nil|
    resp = API::Channel.get_reactions(@bot.token, @channel.id, @id, reaction, nil, after_id, fetch_limit)
    return JSON.parse(resp).map { |d| User.new(d, @bot) }
  end

  # Can be done without pagination
  return get_reactions.call(limit) if limit && limit <= 100

  paginator = Paginator.new(limit, :down) do |last_page|
    if last_page && last_page.count < 100
      []
    else
      get_reactions.call(100, last_page&.last&.id)
    end
  end

  paginator.to_a
end

#reactions?true, false

Check if any reactions were used in this message.



279
280
281
# File 'lib/discordrb/data/message.rb', line 279

def reactions?
  !@reactions.empty?
end

#referenced_messageMessage?



384
385
386
387
388
389
390
# File 'lib/discordrb/data/message.rb', line 384

def referenced_message
  return @referenced_message if @referenced_message
  return nil unless @message_reference

  referenced_channel = @bot.channel(@message_reference['channel_id'])
  @referenced_message = referenced_channel.message(@message_reference['message_id'])
end

#reply(content) ⇒ Message

Deprecated.

Please use #respond.

Replies to this message with the specified content.



167
168
169
# File 'lib/discordrb/data/message.rb', line 167

def reply(content)
  @channel.send_message(content)
end

#reply!(content, tts: false, embed: nil, attachments: nil, allowed_mentions: {}, mention_user: false, components: nil) ⇒ Message

Responds to this message as an inline reply.



180
181
182
183
184
185
186
# File 'lib/discordrb/data/message.rb', line 180

def reply!(content, tts: false, embed: nil, attachments: nil, allowed_mentions: {}, mention_user: false, components: nil)
  allowed_mentions = { parse: [] } if allowed_mentions == false
  allowed_mentions = allowed_mentions.to_hash.transform_keys(&:to_sym)
  allowed_mentions[:replied_user] = mention_user

  respond(content, tts, embed, attachments, allowed_mentions, self, components)
end

#reply?true, false

Whether or not this message was sent in reply to another message



373
374
375
# File 'lib/discordrb/data/message.rb', line 373

def reply?
  !@referenced_message.nil?
end

#respond(content, tts = false, embed = nil, attachments = nil, allowed_mentions = nil, message_reference = nil, components = nil) ⇒ Message

Sends a message to this channel.



189
190
191
# File 'lib/discordrb/data/message.rb', line 189

def respond(content, tts = false, embed = nil, attachments = nil, allowed_mentions = nil, message_reference = nil, components = nil)
  @channel.send_message(content, tts, embed, attachments, allowed_mentions, message_reference, components)
end

#to_messageDiscordrb::Message Also known as: message

to_message -> self or message



408
409
410
# File 'lib/discordrb/data/message.rb', line 408

def to_message
  self
end

#unpin(reason = nil) ⇒ Object

Unpins this message



221
222
223
224
225
# File 'lib/discordrb/data/message.rb', line 221

def unpin(reason = nil)
  API::Channel.unpin_message(@bot.token, @channel.id, @id, reason)
  @pinned = false
  nil
end

#webhook?true, false



259
260
261
# File 'lib/discordrb/data/message.rb', line 259

def webhook?
  !@webhook_id.nil?
end