Class: Discorb::Message

Inherits:
DiscordModel show all
Defined in:
lib/discorb/message.rb

Overview

Represents a message.

Direct Known Subclasses

Webhook::Message

Defined Under Namespace

Classes: Activity, Flag, Interaction, Reference, Sticker

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods inherited from DiscordModel

#==, #eql?, #hash

Instance Attribute Details

#activityDiscorb::Message::Activity (readonly)

Returns The activity of the message.

Returns:



117
118
119
# File 'lib/discorb/message.rb', line 117

def activity
  @activity
end

#application_idDiscorb::Application (readonly)

Returns The application of the message.

Returns:



119
120
121
# File 'lib/discorb/message.rb', line 119

def application_id
  @application_id
end

#attachmentsArray<Discorb::Attachment> (readonly)

Returns The attachments of the message.

Returns:



83
84
85
# File 'lib/discorb/message.rb', line 83

def attachments
  @attachments
end

#authorDiscorb::User, Discorb::Member (readonly)

Returns The user that sent the message.

Returns:



69
70
71
# File 'lib/discorb/message.rb', line 69

def author
  @author
end

#channelnil, Discorb::Channel (readonly)

Note:

This method returns an object from client cache. it will return nil if the object is not in cache.

Returns:

  • (nil)

    The object wasn't cached.

  • (Discorb::Channel)

    The channel the message was sent in.



# File 'lib/discorb/message.rb', line 170

#componentsArray<Array<Discorb::Components>> (readonly)

Returns The components of the message.

Returns:

  • (Array<Array<Discorb::Components>>)

    The components of the message.



132
133
134
# File 'lib/discorb/message.rb', line 132

def components
  @components
end

#contentString (readonly) Also known as: to_s

Returns The content of the message.

Returns:

  • (String)

    The content of the message.



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

def content
  @content
end

#created_atTime (readonly) Also known as: timestamp, sent_at

Returns The time the message was created.

Returns:

  • (Time)

    The time the message was created.



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

def created_at
  @created_at
end

#deletedBoolean (readonly) Also known as: deleted?

Returns Whether the message is deleted.

Returns:

  • (Boolean)

    Whether the message is deleted.



134
135
136
# File 'lib/discorb/message.rb', line 134

def deleted
  @deleted
end

#edited?Boolean (readonly)

Returns Whether the message was edited.

Returns:

  • (Boolean)

    Whether the message was edited.



# File 'lib/discorb/message.rb', line 170

#embedDiscorb::Embed? (readonly)

Returns:

  • (Discorb::Embed)

    The embed of the message.

  • (nil)

    If the message has no embed.



# File 'lib/discorb/message.rb', line 170

#embedsArray<Discorb::Embed> (readonly)

Returns The embeds of the message.

Returns:



85
86
87
# File 'lib/discorb/message.rb', line 85

def embeds
  @embeds
end

#flagDiscorb::Message::Flag (readonly)

Returns The flag of the message.

Returns:

See Also:



124
125
126
# File 'lib/discorb/message.rb', line 124

def flag
  @flag
end

#guildnil, Discorb::Guild (readonly)

Note:

This method returns an object from client cache. it will return nil if the object is not in cache.

Returns:

  • (nil)

    The object wasn't cached.

  • (Discorb::Guild)

    The guild the message was sent in.

  • (nil)

    If the message was not sent in a guild.



# File 'lib/discorb/message.rb', line 170

#idDiscorb::Snowflake (readonly)

Returns The ID of the message.

Returns:



67
68
69
# File 'lib/discorb/message.rb', line 67

def id
  @id
end

#interactionDiscorb::Message::Interaction (readonly)

Returns The interaction of the message.

Returns:



128
129
130
# File 'lib/discorb/message.rb', line 128

def interaction
  @interaction
end

#jump_urlString (readonly)

Returns The URL to jump to the message.

Returns:

  • (String)

    The URL to jump to the message.



# File 'lib/discorb/message.rb', line 170

#mention_everyoneBoolean (readonly) Also known as: mention_everyone?

Returns Whether the message mentions everyone.

Returns:

  • (Boolean)

    Whether the message mentions everyone.



140
141
142
# File 'lib/discorb/message.rb', line 140

def mention_everyone
  @mention_everyone
end

#message_referenceDiscorb::Message::Reference (readonly)

Returns The reference of the message.

Returns:



121
122
123
# File 'lib/discorb/message.rb', line 121

def message_reference
  @message_reference
end

#pinnedBoolean (readonly) Also known as: pinned?

Returns Whether the message is pinned.

Returns:

  • (Boolean)

    Whether the message is pinned.



143
144
145
# File 'lib/discorb/message.rb', line 143

def pinned
  @pinned
end

#reactionsArray<Discorb::Reaction> (readonly)

Returns The reactions of the message.

Returns:



87
88
89
# File 'lib/discorb/message.rb', line 87

def reactions
  @reactions
end

#stickersDiscorb::Message::Sticker (readonly)

Returns The sticker of the message.

Returns:



126
127
128
# File 'lib/discorb/message.rb', line 126

def stickers
  @stickers
end

#threadDiscorb::ThreadChannel (readonly)

Returns The thread channel of the message.

Returns:



130
131
132
# File 'lib/discorb/message.rb', line 130

def thread
  @thread
end

#ttsBoolean (readonly) Also known as: tts?

Returns Whether the message is tts.

Returns:

  • (Boolean)

    Whether the message is tts.



137
138
139
# File 'lib/discorb/message.rb', line 137

def tts
  @tts
end

#typeSymbol (readonly)

Currently, this will be one of:

  • :default
  • :recipient_add
  • :recipient_remove
  • :call
  • :channel_name_change
  • :channel_icon_change
  • :channel_pinned_message
  • :guild_member_join
  • :user_premium_guild_subscription
  • :user_premium_guild_subscription_tier_1
  • :user_premium_guild_subscription_tier_2
  • :user_premium_guild_subscription_tier_3
  • :channel_follow_add
  • :guild_discovery_disqualified
  • :guild_discovery_requalified
  • :guild_discovery_grace_period_initial_warning
  • :guild_discovery_grace_period_final_warning
  • :thread_created
  • :reply
  • :application_command
  • :thread_starter_message
  • :guild_invite_reminder

Returns:

  • (Symbol)

    The type of the message.



115
116
117
# File 'lib/discorb/message.rb', line 115

def type
  @type
end

#updated_atTime? (readonly) Also known as: edited_at, edited_timestamp

Returns:

  • (Time)

    The time the message was edited.

  • (nil)

    If the message was not edited.



79
80
81
# File 'lib/discorb/message.rb', line 79

def updated_at
  @updated_at
end

#webhook?Boolean (readonly)

Returns Whether the message was sent by a webhook.

Returns:

  • (Boolean)

    Whether the message was sent by a webhook.



# File 'lib/discorb/message.rb', line 170

#webhook_idDiscorb::Snowflake (readonly)

Returns The ID of the channel the message was sent in.

Returns:



89
90
91
# File 'lib/discorb/message.rb', line 89

def webhook_id
  @webhook_id
end

Instance Method Details

#add_reaction(emoji) ⇒ Object Also known as: react_with

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Add a reaction to the message.

Parameters:

Raises:



265
266
267
268
269
# File 'lib/discorb/message.rb', line 265

def add_reaction(emoji)
  Async do |_task|
    @client.internet.put("/channels/#{@channel_id}/messages/#{@id}/reactions/#{emoji.to_uri}/@me", nil).wait
  end
end

#fetch_reacted_users(emoji, limit: nil, after: 0) ⇒ Array<Discorb::User>

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Fetch reacted users of reaction.

Parameters:

  • emoji (Discorb::Emoji)

    The emoji to fetch.

  • limit (Integer, nil) (defaults to: nil)

    The maximum number of users to fetch. nil for no limit.

  • after (Discorb::Snowflake, nil) (defaults to: 0)

    The ID of the user to start fetching from.

Returns:

Raises:



315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
# File 'lib/discorb/message.rb', line 315

def fetch_reacted_users(emoji, limit: nil, after: 0)
  Async do |_task|
    if limit.nil? || !limit.positive?
      after = 0
      users = []
      loop do
        _resp, data = @client.internet.get("/channels/#{@channel_id}/messages/#{@id}/reactions/#{emoji.to_uri}?limit=100&after=#{after}").wait
        break if data.empty?

        users += data.map { |r| guild&.members&.[](r[:id]) || @client.users[r[:id]] || User.new(@client, r) }

        break if data.length < 100

        after = data[-1][:id]
      end
      next users
    else
      _resp, data = @client.internet.get("/channels/#{@channel_id}/messages/#{@id}/reactions/#{emoji.to_uri}?limit=#{limit}&after=#{after}").wait
      next data.map { |r| guild&.members&.[](r[:id]) || @client.users[r[:id]] || User.new(@client, r) }
    end
  end
end

#inspectObject

Meta



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

def inspect
  "#<#{self.class} #{@content.inspect} id=#{@id}>"
end

#pin(reason: nil) ⇒ Object

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Pin the message.

Parameters:

  • reason (String) (defaults to: nil)

    The reason for pinning the message.

Raises:



345
346
347
348
349
# File 'lib/discorb/message.rb', line 345

def pin(reason: nil)
  Async do
    channel.pin_message(self, reason: reason).wait
  end
end

#publishObject

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Publish the message.

Raises:



252
253
254
255
256
# File 'lib/discorb/message.rb', line 252

def publish
  Async do |_task|
    channel.post("/channels/#{@channel_id}/messages/#{@id}/crosspost", nil).wait
  end
end

#remove_reaction(emoji) ⇒ Object Also known as: delete_reaction

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Remove a reaction from the message.

Parameters:

Raises:



280
281
282
283
284
# File 'lib/discorb/message.rb', line 280

def remove_reaction(emoji)
  Async do |_task|
    @client.internet.delete("/channels/#{@channel_id}/messages/#{@id}/reactions/#{emoji.to_uri}/@me").wait
  end
end

#remove_reaction_of(emoji, member) ⇒ Object Also known as: delete_reaction_of

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Remove other member's reaction from the message.

Parameters:

Raises:



296
297
298
299
300
# File 'lib/discorb/message.rb', line 296

def remove_reaction_of(emoji, member)
  Async do |_task|
    @client.internet.delete("/channels/#{@channel_id}/messages/#{@id}/reactions/#{emoji.to_uri}/#{member.is_a?(Member) ? member.id : member}").wait
  end
end

#reply(*args, **kwargs) ⇒ Discorb::Message

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Reply to the message.

Returns:

Raises:



241
242
243
244
245
# File 'lib/discorb/message.rb', line 241

def reply(*args, **kwargs)
  Async do |_task|
    channel.post(*args, reference: self, **kwargs).wait
  end
end

#start_thread(*args, **kwargs) ⇒ <Type> Also known as: create_thread

Start thread from the message.

Returns:

  • (<Type>)



369
370
371
372
373
# File 'lib/discorb/message.rb', line 369

def start_thread(*args, **kwargs)
  Async do
    channel.start_thread(*args, message: self, **kwargs).wait
  end
end

#to_reference(fail_if_not_exists: true) ⇒ Hash

Convert the message to reference object.

Parameters:

  • fail_if_not_exists (Boolean) (defaults to: true)

    Whether to raise an error if the message does not exist.

Returns:

  • (Hash)

    The reference object.



223
224
225
226
227
228
229
230
# File 'lib/discorb/message.rb', line 223

def to_reference(fail_if_not_exists: true)
  {
    message_id: @id,
    channel_id: @channel_id,
    guild_id: @guild_id,
    fail_if_not_exists: fail_if_not_exists,
  }
end

#unpinObject

Note:

This is an asynchronous method, it will return a Async::Task object. Use Async::Task#wait to get the result.

Note:

This method calls HTTP request.

Unpin the message.

Raises:



356
357
358
359
360
# File 'lib/discorb/message.rb', line 356

def unpin
  Async do
    channel.unpin_message(self, reason: reason).wait
  end
end