Class: Discorb::Gateway::MessageUpdateEvent
- Inherits:
-
GatewayEvent
- Object
- GatewayEvent
- Discorb::Gateway::MessageUpdateEvent
- Defined in:
- lib/discorb/gateway.rb
Overview
Represents a MESSAGE_UPDATE
event.
Instance Attribute Summary collapse
-
#after -> Discorb::Message
readonly
The message after update.
-
#attachments -> Array<Discorb::Attachment>
readonly
The attachments in the message.
-
#before -> Discorb::Message
readonly
The message before update.
- #channel -> nil, Discorb::Channel readonly
-
#channel_id -> Discorb::Snowflake
readonly
The ID of the channel the message was sent in.
-
#content -> String
readonly
The new content of the message.
-
#embeds -> Array<Discorb::Embed>
readonly
The embeds in the message.
- #guild -> nil, Discorb::Guild readonly
-
#guild_id -> Discorb::Snowflake
readonly
The ID of the guild the message was sent in.
-
#id -> Discorb::Snowflake
readonly
The ID of the message.
-
#mention_everyone -> Boolean
readonly
Whether the message pings @everyone.
- #mention_roles -> nil, Array<Discorb::Role> readonly
-
#timestamp -> Time
readonly
The time the message was edited.
Instance Method Summary collapse
-
#fetch_message -> Async::Task<Discorb::Message>
Fetch the message.
-
#initialize(client, data, before, after) -> MessageUpdateEvent
constructor
A new instance of MessageUpdateEvent.
Constructor Details
#initialize(client, data, before, after) -> MessageUpdateEvent
Returns a new instance of MessageUpdateEvent.
297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 |
# File 'lib/discorb/gateway.rb', line 297 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
#after -> Discorb::Message (readonly)
Returns The message after update.
269 270 271 |
# File 'lib/discorb/gateway.rb', line 269 def after @after end |
#attachments -> Array<Discorb::Attachment> (readonly)
Returns The attachments in the message.
286 287 288 |
# File 'lib/discorb/gateway.rb', line 286 def @attachments end |
#before -> Discorb::Message (readonly)
Returns The message before update.
267 268 269 |
# File 'lib/discorb/gateway.rb', line 267 def before @before end |
#channel -> nil, Discorb::Channel (readonly)
This method returns an object from client cache. it will return nil
if the object is not in cache.
297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 |
# File 'lib/discorb/gateway.rb', line 297 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_id -> Discorb::Snowflake (readonly)
Returns The ID of the channel the message was sent in.
273 274 275 |
# File 'lib/discorb/gateway.rb', line 273 def channel_id @channel_id end |
#content -> String (readonly)
Returns The new content of the message.
277 278 279 |
# File 'lib/discorb/gateway.rb', line 277 def content @content end |
#embeds -> Array<Discorb::Embed> (readonly)
Returns The embeds in the message.
288 289 290 |
# File 'lib/discorb/gateway.rb', line 288 def @embeds end |
#guild -> nil, Discorb::Guild (readonly)
This method returns an object from client cache. it will return nil
if the object is not in cache.
297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 |
# File 'lib/discorb/gateway.rb', line 297 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_id -> Discorb::Snowflake (readonly)
Returns The ID of the guild the message was sent in.
275 276 277 |
# File 'lib/discorb/gateway.rb', line 275 def guild_id @guild_id end |
#id -> Discorb::Snowflake (readonly)
Returns The ID of the message.
271 272 273 |
# File 'lib/discorb/gateway.rb', line 271 def id @id end |
#mention_everyone -> Boolean (readonly)
Returns Whether the message pings @everyone.
281 282 283 |
# File 'lib/discorb/gateway.rb', line 281 def mention_everyone @mention_everyone end |
#mention_roles -> nil, Array<Discorb::Role> (readonly)
This method returns an object from client cache. it will return nil
if the object is not in cache.
284 285 286 |
# File 'lib/discorb/gateway.rb', line 284 def mention_roles @mention_roles end |
#timestamp -> Time (readonly)
Returns The time the message was edited.
279 280 281 |
# File 'lib/discorb/gateway.rb', line 279 def @timestamp end |
Instance Method Details
#fetch_message -> Async::Task<Discorb::Message>
Fetch the message.
325 326 327 328 329 |
# File 'lib/discorb/gateway.rb', line 325 def Async do channel.(@id).wait end end |