Class: Discorb::Gateway::MessageUpdateEvent

Inherits:
GatewayEvent show all
Defined in:
lib/discorb/gateway.rb

Overview

Represents a MESSAGE_UPDATE event.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(client, data, before, after) ⇒ MessageUpdateEvent

Returns a new instance of MessageUpdateEvent.



235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
# File 'lib/discorb/gateway.rb', line 235

def initialize(client, data, before, after)
  @client = client
  @data = data
  @before = before
  @after = after
  @id = Snowflake.new(data[:id])
  @channel_id = Snowflake.new(data[:channel_id])
  @guild_id = Snowflake.new(data[:guild_id]) if data.key?(:guild_id)
  @content = data[:content]
  @timestamp = Time.iso8601(data[:edited_timestamp])
  @mention_everyone = data[:mention_everyone]
  @mention_roles = data[:mention_roles].map { |r| guild.roles[r] } if data.key?(:mention_roles)
  @attachments = data[:attachments].map { |a| Attachment.new(a) } if data.key?(:attachments)
  @embeds = data[:embeds] ? data[:embeds].map { |e| Embed.new(data: e) } : [] if data.key?(:embeds)
end

Instance Attribute Details

#afterDiscorb::Message (readonly)

Returns The message after update.

Returns:



207
208
209
# File 'lib/discorb/gateway.rb', line 207

def after
  @after
end

#attachmentsArray<Discorb::Attachment> (readonly)

Returns The attachments in the message.

Returns:



224
225
226
# File 'lib/discorb/gateway.rb', line 224

def attachments
  @attachments
end

#beforeDiscorb::Message (readonly)

Returns The message before update.

Returns:



205
206
207
# File 'lib/discorb/gateway.rb', line 205

def before
  @before
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.



235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
# File 'lib/discorb/gateway.rb', line 235

def initialize(client, data, before, after)
  @client = client
  @data = data
  @before = before
  @after = after
  @id = Snowflake.new(data[:id])
  @channel_id = Snowflake.new(data[:channel_id])
  @guild_id = Snowflake.new(data[:guild_id]) if data.key?(:guild_id)
  @content = data[:content]
  @timestamp = Time.iso8601(data[:edited_timestamp])
  @mention_everyone = data[:mention_everyone]
  @mention_roles = data[:mention_roles].map { |r| guild.roles[r] } if data.key?(:mention_roles)
  @attachments = data[:attachments].map { |a| Attachment.new(a) } if data.key?(:attachments)
  @embeds = data[:embeds] ? data[:embeds].map { |e| Embed.new(data: e) } : [] if data.key?(:embeds)
end

#channel_idDiscorb::Snowflake (readonly)

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

Returns:



211
212
213
# File 'lib/discorb/gateway.rb', line 211

def channel_id
  @channel_id
end

#contentString (readonly)

Returns The new content of the message.

Returns:

  • (String)

    The new content of the message.



215
216
217
# File 'lib/discorb/gateway.rb', line 215

def content
  @content
end

#embedsArray<Discorb::Embed> (readonly)

Returns The embeds in the message.

Returns:



226
227
228
# File 'lib/discorb/gateway.rb', line 226

def embeds
  @embeds
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.



235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
# File 'lib/discorb/gateway.rb', line 235

def initialize(client, data, before, after)
  @client = client
  @data = data
  @before = before
  @after = after
  @id = Snowflake.new(data[:id])
  @channel_id = Snowflake.new(data[:channel_id])
  @guild_id = Snowflake.new(data[:guild_id]) if data.key?(:guild_id)
  @content = data[:content]
  @timestamp = Time.iso8601(data[:edited_timestamp])
  @mention_everyone = data[:mention_everyone]
  @mention_roles = data[:mention_roles].map { |r| guild.roles[r] } if data.key?(:mention_roles)
  @attachments = data[:attachments].map { |a| Attachment.new(a) } if data.key?(:attachments)
  @embeds = data[:embeds] ? data[:embeds].map { |e| Embed.new(data: e) } : [] if data.key?(:embeds)
end

#guild_idDiscorb::Snowflake (readonly)

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

Returns:



213
214
215
# File 'lib/discorb/gateway.rb', line 213

def guild_id
  @guild_id
end

#idDiscorb::Snowflake (readonly)

Returns The ID of the message.

Returns:



209
210
211
# File 'lib/discorb/gateway.rb', line 209

def id
  @id
end

#mention_everyoneBoolean (readonly)

Returns Whether the message pings @everyone.

Returns:

  • (Boolean)

    Whether the message pings @everyone.



219
220
221
# File 'lib/discorb/gateway.rb', line 219

def mention_everyone
  @mention_everyone
end

#mention_rolesnil, Array<Discorb::Role> (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.

  • (Array<Discorb::Role>)

    The roles mentioned in the message.



222
223
224
# File 'lib/discorb/gateway.rb', line 222

def mention_roles
  @mention_roles
end

#timestampTime (readonly)

Returns The time the message was edited.

Returns:

  • (Time)

    The time the message was edited.



217
218
219
# File 'lib/discorb/gateway.rb', line 217

def timestamp
  @timestamp
end

Instance Method Details

#fetch_messageDiscorb::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.

Fetch the message.

Returns:

Raises:



264
265
266
267
268
# File 'lib/discorb/gateway.rb', line 264

def fetch_message
  Async do
    channel.fetch_message(@id).wait
  end
end