Module: Discordrb::EventContainer
Overview
This module provides the functionality required for events and awaits. It is separated from the Bot class so users can make their own container modules and include them.
Class Method Summary collapse
-
.class_from_string(str) ⇒ Class
Utility method to return a class object from a string of its name.
-
.event_class(handler_class) ⇒ Class?
Returns the event class for a handler class type.
-
.handler_class(event_class) ⇒ Class
Returns the handler class for an event class type.
Instance Method Summary collapse
-
#add_handler(handler) ⇒ Object
(also: #<<)
Adds an event handler to this container.
-
#application_command(name, attributes = {}) {|event| ... } ⇒ ApplicationCommandEventHandler
This event is raised whenever an application command (slash command) is executed.
-
#application_command_permissions_update(attributes = {}) {|event| ... } ⇒ ApplicationCommandPermissionsUpdateEventHandler
This event is raised whenever an application command's permissions are updated.
-
#autocomplete(name = nil, attributes = {}) {|event| ... } ⇒ AutocompleteEventHandler
This event is raised whenever an autocomplete interaction is created.
-
#await(attributes = {}) {|event| ... } ⇒ AwaitEventHandler
This event is raised when an Await is triggered.
-
#button(attributes = {}) {|event| ... } ⇒ ButtonEventHandler
This event is raised whenever an button interaction is created.
-
#channel_create(attributes = {}) {|event| ... } ⇒ ChannelCreateEventHandler
This event is raised when a channel is created.
-
#channel_delete(attributes = {}) {|event| ... } ⇒ ChannelDeleteEventHandler
This event is raised when a channel is deleted.
-
#channel_pins_update(attributes = {}) {|event| ... } ⇒ ChannelPinsUpdateEventHandler
This event is raised whenever a message is pinned or unpinned.
-
#channel_recipient_add(attributes = {}) {|event| ... } ⇒ ChannelRecipientAddHandler
This event is raised when a recipient is added to a group channel.
-
#channel_recipient_remove(attributes = {}) {|event| ... } ⇒ ChannelRecipientRemoveHandler
This event is raised when a recipient is removed from a group channel.
-
#channel_select(attributes = {}) {|event| ... } ⇒ ChannelSelectEventHandler
This event is raised whenever an select channel interaction is created.
-
#channel_update(attributes = {}) {|event| ... } ⇒ ChannelUpdateEventHandler
This event is raised when a channel is updated.
-
#clear! ⇒ Object
Removes all events from this event handler.
-
#disconnected(attributes = {}) {|event| ... } ⇒ DisconnectEventHandler
This event is raised when the bot has disconnected from the WebSocket, due to the Bot#stop method or external causes.
-
#heartbeat(attributes = {}) {|event| ... } ⇒ HeartbeatEventHandler
This event is raised every time the bot sends a heartbeat over the galaxy.
-
#include_events(container) ⇒ Object
(also: #include!)
Adds all event handlers from another container into this one.
-
#integration_create(attributes = {}) {|event| ... } ⇒ IntegrationCreateEventHandler
This event is raised whenever an integration is added to a server.
-
#integration_delete(attributes = {}) {|event| ... } ⇒ IntegrationDeleteEventHandler
This event is raised whenever an integration is removed from a server.
-
#integration_update(attributes = {}) {|event| ... } ⇒ IntegrationUpdateEventHandler
This event is raised whenever an integration is updated in a server.
-
#interaction_create(attributes = {}) {|event| ... } ⇒ InteractionCreateEventHandler
This event is raised whenever an interaction event is received.
-
#invite_create(attributes = {}) {|event| ... } ⇒ InviteCreateEventHandler
This event is raised when an invite is created.
-
#invite_delete(attributes = {}) {|event| ... } ⇒ InviteDeleteEventHandler
This event is raised when an invite is deleted.
-
#member_join(attributes = {}) {|event| ... } ⇒ ServerMemberAddEventHandler
This event is raised when a new user joins a server.
-
#member_leave(attributes = {}) {|event| ... } ⇒ ServerMemberDeleteEventHandler
This event is raised when a member leaves a server.
-
#member_update(attributes = {}) {|event| ... } ⇒ ServerMemberUpdateEventHandler
This event is raised when a member update happens.
-
#mention(attributes = {}) {|event| ... } ⇒ MentionEventHandler
This event is raised when the bot is mentioned in a message.
-
#mentionable_select(attributes = {}) {|event| ... } ⇒ MentionableSelectEventHandler
This event is raised whenever an select mentionable interaction is created.
-
#message(attributes = {}) {|event| ... } ⇒ MessageEventHandler
This event is raised when a message is sent to a text channel the bot is currently in.
-
#message_delete(attributes = {}) {|event| ... } ⇒ MessageDeleteEventHandler
This event is raised when a message is deleted in a channel.
-
#message_edit(attributes = {}) {|event| ... } ⇒ MessageEditEventHandler
This event is raised when a message is edited in a channel.
-
#message_update(attributes = {}) {|event| ... } ⇒ MessageUpdateEventHandler
This event is raised whenever a message is updated.
-
#modal_submit(attributes = {}) {|event| ... } ⇒ ModalSubmitEventHandler
This event is raised whenever a modal is submitted.
-
#playing(attributes = {}) {|event| ... } ⇒ PlayingEventHandler
This event is raised when the game a user is playing changes.
-
#pm(attributes = {}) {|event| ... } ⇒ PrivateMessageEventHandler
(also: #private_message, #direct_message, #dm)
This event is raised when a private message is sent to the bot.
-
#presence(attributes = {}) {|event| ... } ⇒ PresenceEventHandler
This event is raised when a user's status (online/offline/idle) changes.
-
#raw(attributes = {}) {|event| ... } ⇒ RawEventHandler
This event is raised for every dispatch received over the gateway, whether supported by discordrb or not.
-
#reaction_add(attributes = {}) {|event| ... } ⇒ ReactionAddEventHandler
This event is raised when somebody reacts to a message.
-
#reaction_remove(attributes = {}) {|event| ... } ⇒ ReactionRemoveEventHandler
This event is raised when somebody removes a reaction from a message.
-
#reaction_remove_all(attributes = {}) {|event| ... } ⇒ ReactionRemoveAllEventHandler
This event is raised when somebody removes all reactions from a message.
-
#reaction_remove_emoji(attributes = {}) {|event| ... } ⇒ ReactionRemoveEmojiEventHandler
This event is raised when somebody removes all instances of a single reaction from a message.
-
#ready(attributes = {}) {|event| ... } ⇒ ReadyEventHandler
This event is raised when the READY packet is received, i.e.
-
#remove_application_command_handler(name) ⇒ Object
Remove an application command handler.
-
#remove_handler(handler) ⇒ Object
Removes an event handler from this container.
-
#role_select(attributes = {}) {|event| ... } ⇒ RoleSelectEventHandler
This event is raised whenever an select role interaction is created.
-
#server_create(attributes = {}) {|event| ... } ⇒ ServerCreateEventHandler
This event is raised when a server is created respective to the bot, i.e.
-
#server_delete(attributes = {}) {|event| ... } ⇒ ServerDeleteEventHandler
This event is raised when a server is deleted, or when the bot leaves a server.
-
#server_emoji(attributes = {}) {|event| ... } ⇒ ServerEmojiChangeEventHandler
This event is raised when an emoji or collection of emojis is created/deleted/updated.
-
#server_emoji_create(attributes = {}) {|event| ... } ⇒ ServerEmojiCreateEventHandler
This event is raised when an emoji is created.
-
#server_emoji_delete(attributes = {}) {|event| ... } ⇒ ServerEmojiDeleteEventHandler
This event is raised when an emoji is deleted.
-
#server_emoji_update(attributes = {}) {|event| ... } ⇒ ServerEmojiUpdateEventHandler
This event is raised when an emoji is updated.
-
#server_role_create(attributes = {}) {|event| ... } ⇒ ServerRoleCreateEventHandler
This event is raised when a role is created.
-
#server_role_delete(attributes = {}) {|event| ... } ⇒ ServerRoleDeleteEventHandler
This event is raised when a role is deleted.
-
#server_role_update(attributes = {}) {|event| ... } ⇒ ServerRoleUpdateEventHandler
This event is raised when a role is updated.
-
#server_update(attributes = {}) {|event| ... } ⇒ ServerUpdateEventHandler
This event is raised when a server is updated, for example if the name or region has changed.
-
#string_select(attributes = {}) {|event| ... } ⇒ StringSelectEventHandler
(also: #select_menu)
This event is raised whenever an select string interaction is created.
-
#typing(attributes = {}) {|event| ... } ⇒ TypingEventHandler
This event is raised when somebody starts typing in a channel the bot is also in.
-
#unknown(attributes = {}) {|event| ... } ⇒ UnknownEventHandler
This event is raised for a dispatch received over the gateway that is not currently handled otherwise by discordrb.
-
#user_ban(attributes = {}) {|event| ... } ⇒ UserBanEventHandler
This event is raised when a user is banned from a server.
-
#user_select(attributes = {}) {|event| ... } ⇒ UserSelectEventHandler
This event is raised whenever an select user interaction is created.
-
#user_unban(attributes = {}) {|event| ... } ⇒ UserUnbanEventHandler
This event is raised when a user is unbanned from a server.
-
#voice_server_update(attributes = {}) {|event| ... } ⇒ VoiceServerUpdateEventHandler
This event is raised when first connecting to a server's voice channel.
-
#voice_state_update(attributes = {}) {|event| ... } ⇒ VoiceStateUpdateEventHandler
This event is raised when a user's voice state changes.
-
#webhook_update(attributes = {}) {|event| ... } ⇒ WebhookUpdateEventHandler
This event is raised when a webhook is updated.
Methods included from Events
Class Method Details
.class_from_string(str) ⇒ Class
Utility method to return a class object from a string of its name. Mostly useful for internal stuff
831 832 833 834 835 |
# File 'lib/discordrb/container.rb', line 831 def self.class_from_string(str) str.split('::').inject(Object) do |mod, class_name| mod.const_get(class_name) end end |
.event_class(handler_class) ⇒ Class?
Returns the event class for a handler class type
821 822 823 824 825 826 |
# File 'lib/discordrb/container.rb', line 821 def self.event_class(handler_class) class_name = handler_class.to_s return nil unless class_name.end_with? 'Handler' EventContainer.class_from_string(class_name[0..-8]) end |
.handler_class(event_class) ⇒ Class
Returns the handler class for an event class type
813 814 815 |
# File 'lib/discordrb/container.rb', line 813 def self.handler_class(event_class) class_from_string("#{event_class}Handler") end |
Instance Method Details
#add_handler(handler) ⇒ Object Also known as: <<
Adds an event handler to this container. Usually, it's more expressive to just use one of the shorthand adder methods like #message, but if you want to create one manually you can use this.
781 782 783 784 785 786 |
# File 'lib/discordrb/container.rb', line 781 def add_handler(handler) clazz = EventContainer.event_class(handler.class) @event_handlers ||= {} @event_handlers[clazz] ||= [] @event_handlers[clazz] << handler end |
#application_command(name, attributes = {}) {|event| ... } ⇒ ApplicationCommandEventHandler
This event is raised whenever an application command (slash command) is executed.
570 571 572 573 574 575 576 577 578 579 |
# File 'lib/discordrb/container.rb', line 570 def application_command(name, attributes = {}, &block) @application_commands ||= {} unless block @application_commands[name] ||= ApplicationCommandEventHandler.new(attributes, nil) return @application_commands[name] end @application_commands[name] = ApplicationCommandEventHandler.new(attributes, block) end |
#application_command_permissions_update(attributes = {}) {|event| ... } ⇒ ApplicationCommandPermissionsUpdateEventHandler
This event is raised whenever an application command's permissions are updated.
696 697 698 |
# File 'lib/discordrb/container.rb', line 696 def (attributes = {}, &block) register_event(ApplicationCommandPermissionsUpdateEvent, attributes, block) end |
#autocomplete(name = nil, attributes = {}) {|event| ... } ⇒ AutocompleteEventHandler
This event is raised whenever an autocomplete interaction is created.
684 685 686 |
# File 'lib/discordrb/container.rb', line 684 def autocomplete(name = nil, attributes = {}, &block) register_event(AutocompleteEvent, attributes.merge!({ name: name }), block) end |
#await(attributes = {}) {|event| ... } ⇒ AwaitEventHandler
This event is raised when an Await is triggered. It provides an easy way to execute code on an await without having to rely on the await's block.
500 501 502 |
# File 'lib/discordrb/container.rb', line 500 def await(attributes = {}, &block) register_event(AwaitEvent, attributes, block) end |
#button(attributes = {}) {|event| ... } ⇒ ButtonEventHandler
This event is raised whenever an button interaction is created.
588 589 590 |
# File 'lib/discordrb/container.rb', line 588 def (attributes = {}, &block) register_event(ButtonEvent, attributes, block) end |
#channel_create(attributes = {}) {|event| ... } ⇒ ChannelCreateEventHandler
This event is raised when a channel is created.
241 242 243 |
# File 'lib/discordrb/container.rb', line 241 def channel_create(attributes = {}, &block) register_event(ChannelCreateEvent, attributes, block) end |
#channel_delete(attributes = {}) {|event| ... } ⇒ ChannelDeleteEventHandler
This event is raised when a channel is deleted.
263 264 265 |
# File 'lib/discordrb/container.rb', line 263 def channel_delete(attributes = {}, &block) register_event(ChannelDeleteEvent, attributes, block) end |
#channel_pins_update(attributes = {}) {|event| ... } ⇒ ChannelPinsUpdateEventHandler
This event is raised whenever a message is pinned or unpinned.
669 670 671 |
# File 'lib/discordrb/container.rb', line 669 def channel_pins_update(attributes = {}, &block) register_event(ChannelPinsUpdateEvent, attributes, block) end |
#channel_recipient_add(attributes = {}) {|event| ... } ⇒ ChannelRecipientAddHandler
This event is raised when a recipient is added to a group channel.
275 276 277 |
# File 'lib/discordrb/container.rb', line 275 def channel_recipient_add(attributes = {}, &block) register_event(ChannelRecipientAddEvent, attributes, block) end |
#channel_recipient_remove(attributes = {}) {|event| ... } ⇒ ChannelRecipientRemoveHandler
This event is raised when a recipient is removed from a group channel.
287 288 289 |
# File 'lib/discordrb/container.rb', line 287 def channel_recipient_remove(attributes = {}, &block) register_event(ChannelRecipientRemoveEvent, attributes, block) end |
#channel_select(attributes = {}) {|event| ... } ⇒ ChannelSelectEventHandler
This event is raised whenever an select channel interaction is created.
658 659 660 |
# File 'lib/discordrb/container.rb', line 658 def channel_select(attributes = {}, &block) register_event(ChannelSelectEvent, attributes, block) end |
#channel_update(attributes = {}) {|event| ... } ⇒ ChannelUpdateEventHandler
This event is raised when a channel is updated.
252 253 254 |
# File 'lib/discordrb/container.rb', line 252 def channel_update(attributes = {}, &block) register_event(ChannelUpdateEvent, attributes, block) end |
#clear! ⇒ Object
Removes all events from this event handler.
773 774 775 776 |
# File 'lib/discordrb/container.rb', line 773 def clear! @event_handlers&.clear @application_commands&.clear end |
#disconnected(attributes = {}) {|event| ... } ⇒ DisconnectEventHandler
This event is raised when the bot has disconnected from the WebSocket, due to the Bot#stop method or external causes. It's the recommended way to do clean-up tasks.
61 62 63 |
# File 'lib/discordrb/container.rb', line 61 def disconnected(attributes = {}, &block) register_event(DisconnectEvent, attributes, block) end |
#heartbeat(attributes = {}) {|event| ... } ⇒ HeartbeatEventHandler
This event is raised every time the bot sends a heartbeat over the galaxy. This happens roughly every 40 seconds, but may happen at a lower rate should Discord change their interval. It may also happen more quickly for periods of time, especially for unstable connections, since discordrb rather sends a heartbeat than not if there's a choice. (You shouldn't rely on all this to be accurately timed.)
All this makes this event useful to periodically trigger something, like doing some API request every hour, setting some kind of uptime variable or whatever else. The only limit is yourself.
76 77 78 |
# File 'lib/discordrb/container.rb', line 76 def heartbeat(attributes = {}, &block) register_event(HeartbeatEvent, attributes, block) end |
#include_events(container) ⇒ Object Also known as: include!
Adds all event handlers from another container into this one. Existing event handlers will be overwritten.
790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 |
# File 'lib/discordrb/container.rb', line 790 def include_events(container) application_command_handlers = container.instance_variable_get(:@application_commands) handlers = container.instance_variable_get :@event_handlers return unless handlers || application_command_handlers @event_handlers ||= {} @event_handlers.merge!(handlers || {}) { |_, old, new| old + new } @application_commands ||= {} @application_commands.merge!(application_command_handlers || {}) do |_, old, new| old.subcommands.merge!(new.subcommands) old end end |
#integration_create(attributes = {}) {|event| ... } ⇒ IntegrationCreateEventHandler
This event is raised whenever an integration is added to a server.
708 709 710 |
# File 'lib/discordrb/container.rb', line 708 def integration_create(attributes = {}, &block) register_event(IntegrationCreateEvent, attributes, block) end |
#integration_delete(attributes = {}) {|event| ... } ⇒ IntegrationDeleteEventHandler
This event is raised whenever an integration is removed from a server.
732 733 734 |
# File 'lib/discordrb/container.rb', line 732 def integration_delete(attributes = {}, &block) register_event(IntegrationDeleteEvent, attributes, block) end |
#integration_update(attributes = {}) {|event| ... } ⇒ IntegrationUpdateEventHandler
This event is raised whenever an integration is updated in a server.
720 721 722 |
# File 'lib/discordrb/container.rb', line 720 def integration_update(attributes = {}, &block) register_event(IntegrationUpdateEvent, attributes, block) end |
#interaction_create(attributes = {}) {|event| ... } ⇒ InteractionCreateEventHandler
This event is raised whenever an interaction event is received.
560 561 562 |
# File 'lib/discordrb/container.rb', line 560 def interaction_create(attributes = {}, &block) register_event(InteractionCreateEvent, attributes, block) end |
#invite_create(attributes = {}) {|event| ... } ⇒ InviteCreateEventHandler
This event is raised when an invite is created.
535 536 537 |
# File 'lib/discordrb/container.rb', line 535 def invite_create(attributes = {}, &block) register_event(InviteCreateEvent, attributes, block) end |
#invite_delete(attributes = {}) {|event| ... } ⇒ InviteDeleteEventHandler
This event is raised when an invite is deleted.
546 547 548 |
# File 'lib/discordrb/container.rb', line 546 def invite_delete(attributes = {}, &block) register_event(InviteDeleteEvent, attributes, block) end |
#member_join(attributes = {}) {|event| ... } ⇒ ServerMemberAddEventHandler
This event is raised when a new user joins a server.
324 325 326 |
# File 'lib/discordrb/container.rb', line 324 def member_join(attributes = {}, &block) register_event(ServerMemberAddEvent, attributes, block) end |
#member_leave(attributes = {}) {|event| ... } ⇒ ServerMemberDeleteEventHandler
This event is raised when a member leaves a server.
345 346 347 |
# File 'lib/discordrb/container.rb', line 345 def member_leave(attributes = {}, &block) register_event(ServerMemberDeleteEvent, attributes, block) end |
#member_update(attributes = {}) {|event| ... } ⇒ ServerMemberUpdateEventHandler
This event is raised when a member update happens. This includes when a members nickname or roles are updated.
335 336 337 |
# File 'lib/discordrb/container.rb', line 335 def member_update(attributes = {}, &block) register_event(ServerMemberUpdateEvent, attributes, block) end |
#mention(attributes = {}) {|event| ... } ⇒ MentionEventHandler
This event is raised when the bot is mentioned in a message.
230 231 232 |
# File 'lib/discordrb/container.rb', line 230 def mention(attributes = {}, &block) register_event(MentionEvent, attributes, block) end |
#mentionable_select(attributes = {}) {|event| ... } ⇒ MentionableSelectEventHandler
This event is raised whenever an select mentionable interaction is created.
647 648 649 |
# File 'lib/discordrb/container.rb', line 647 def mentionable_select(attributes = {}, &block) register_event(MentionableSelectEvent, attributes, block) end |
#message(attributes = {}) {|event| ... } ⇒ MessageEventHandler
This event is raised when a message is sent to a text channel the bot is currently in.
41 42 43 |
# File 'lib/discordrb/container.rb', line 41 def (attributes = {}, &block) register_event(MessageEvent, attributes, block) end |
#message_delete(attributes = {}) {|event| ... } ⇒ MessageDeleteEventHandler
This event is raised when a message is deleted in a channel.
116 117 118 |
# File 'lib/discordrb/container.rb', line 116 def (attributes = {}, &block) register_event(MessageDeleteEvent, attributes, block) end |
#message_edit(attributes = {}) {|event| ... } ⇒ MessageEditEventHandler
This event is raised when a message is edited in a channel.
104 105 106 |
# File 'lib/discordrb/container.rb', line 104 def (attributes = {}, &block) register_event(MessageEditEvent, attributes, block) end |
#message_update(attributes = {}) {|event| ... } ⇒ MessageUpdateEventHandler
This event is raised whenever a message is updated. Message updates can be triggered from a user editing their own message, or from Discord automatically attaching embeds to the user's message for URLs contained in the message's content. If you only want to listen for users editing their own messages, use the #message_edit handler instead.
132 133 134 |
# File 'lib/discordrb/container.rb', line 132 def (attributes = {}, &block) register_event(MessageUpdateEvent, attributes, block) end |
#modal_submit(attributes = {}) {|event| ... } ⇒ ModalSubmitEventHandler
This event is raised whenever a modal is submitted.
614 615 616 |
# File 'lib/discordrb/container.rb', line 614 def modal_submit(attributes = {}, &block) register_event(ModalSubmitEvent, attributes, block) end |
#playing(attributes = {}) {|event| ... } ⇒ PlayingEventHandler
This event is raised when the game a user is playing changes.
210 211 212 |
# File 'lib/discordrb/container.rb', line 210 def (attributes = {}, &block) register_event(PlayingEvent, attributes, block) end |
#pm(attributes = {}) {|event| ... } ⇒ PrivateMessageEventHandler Also known as: private_message, direct_message, dm
This event is raised when a private message is sent to the bot.
518 519 520 |
# File 'lib/discordrb/container.rb', line 518 def pm(attributes = {}, &block) register_event(PrivateMessageEvent, attributes, block) end |
#presence(attributes = {}) {|event| ... } ⇒ PresenceEventHandler
This event is raised when a user's status (online/offline/idle) changes.
198 199 200 |
# File 'lib/discordrb/container.rb', line 198 def presence(attributes = {}, &block) register_event(PresenceEvent, attributes, block) end |
#raw(attributes = {}) {|event| ... } ⇒ RawEventHandler
This event is raised for every dispatch received over the gateway, whether supported by discordrb or not.
742 743 744 |
# File 'lib/discordrb/container.rb', line 742 def raw(attributes = {}, &block) register_event(RawEvent, attributes, block) end |
#reaction_add(attributes = {}) {|event| ... } ⇒ ReactionAddEventHandler
This event is raised when somebody reacts to a message.
146 147 148 |
# File 'lib/discordrb/container.rb', line 146 def reaction_add(attributes = {}, &block) register_event(ReactionAddEvent, attributes, block) end |
#reaction_remove(attributes = {}) {|event| ... } ⇒ ReactionRemoveEventHandler
This event is raised when somebody removes a reaction from a message.
161 162 163 |
# File 'lib/discordrb/container.rb', line 161 def reaction_remove(attributes = {}, &block) register_event(ReactionRemoveEvent, attributes, block) end |
#reaction_remove_all(attributes = {}) {|event| ... } ⇒ ReactionRemoveAllEventHandler
This event is raised when somebody removes all reactions from a message.
173 174 175 |
# File 'lib/discordrb/container.rb', line 173 def reaction_remove_all(attributes = {}, &block) register_event(ReactionRemoveAllEvent, attributes, block) end |
#reaction_remove_emoji(attributes = {}) {|event| ... } ⇒ ReactionRemoveEmojiEventHandler
This event is raised when somebody removes all instances of a single reaction from a message.
185 186 187 |
# File 'lib/discordrb/container.rb', line 185 def reaction_remove_emoji(attributes = {}, &block) register_event(ReactionRemoveEmojiEvent, attributes, block) end |
#ready(attributes = {}) {|event| ... } ⇒ ReadyEventHandler
This event is raised when the READY packet is received, i.e. servers and channels have finished initialization. It's the recommended way to do things when the bot has finished starting up.
51 52 53 |
# File 'lib/discordrb/container.rb', line 51 def ready(attributes = {}, &block) register_event(ReadyEvent, attributes, block) end |
#remove_application_command_handler(name) ⇒ Object
Remove an application command handler
768 769 770 |
# File 'lib/discordrb/container.rb', line 768 def remove_application_command_handler(name) @application_commands.delete(name) end |
#remove_handler(handler) ⇒ Object
Removes an event handler from this container. If you're looking for a way to do temporary events, I recommend Awaits instead of this.
760 761 762 763 764 |
# File 'lib/discordrb/container.rb', line 760 def remove_handler(handler) clazz = EventContainer.event_class(handler.class) @event_handlers ||= {} @event_handlers[clazz].delete(handler) end |
#role_select(attributes = {}) {|event| ... } ⇒ RoleSelectEventHandler
This event is raised whenever an select role interaction is created.
636 637 638 |
# File 'lib/discordrb/container.rb', line 636 def role_select(attributes = {}, &block) register_event(RoleSelectEvent, attributes, block) end |
#server_create(attributes = {}) {|event| ... } ⇒ ServerCreateEventHandler
This event is raised when a server is created respective to the bot, i.e. the bot joins a server or creates a new one itself.
378 379 380 |
# File 'lib/discordrb/container.rb', line 378 def server_create(attributes = {}, &block) register_event(ServerCreateEvent, attributes, block) end |
#server_delete(attributes = {}) {|event| ... } ⇒ ServerDeleteEventHandler
This event is raised when a server is deleted, or when the bot leaves a server. (These two cases are identical to Discord.)
399 400 401 |
# File 'lib/discordrb/container.rb', line 399 def server_delete(attributes = {}, &block) register_event(ServerDeleteEvent, attributes, block) end |
#server_emoji(attributes = {}) {|event| ... } ⇒ ServerEmojiChangeEventHandler
This event is raised when an emoji or collection of emojis is created/deleted/updated.
409 410 411 |
# File 'lib/discordrb/container.rb', line 409 def server_emoji(attributes = {}, &block) register_event(ServerEmojiChangeEvent, attributes, block) end |
#server_emoji_create(attributes = {}) {|event| ... } ⇒ ServerEmojiCreateEventHandler
This event is raised when an emoji is created.
421 422 423 |
# File 'lib/discordrb/container.rb', line 421 def server_emoji_create(attributes = {}, &block) register_event(ServerEmojiCreateEvent, attributes, block) end |
#server_emoji_delete(attributes = {}) {|event| ... } ⇒ ServerEmojiDeleteEventHandler
This event is raised when an emoji is deleted.
433 434 435 |
# File 'lib/discordrb/container.rb', line 433 def server_emoji_delete(attributes = {}, &block) register_event(ServerEmojiDeleteEvent, attributes, block) end |
#server_emoji_update(attributes = {}) {|event| ... } ⇒ ServerEmojiUpdateEventHandler
This event is raised when an emoji is updated.
446 447 448 |
# File 'lib/discordrb/container.rb', line 446 def server_emoji_update(attributes = {}, &block) register_event(ServerEmojiUpdateEvent, attributes, block) end |
#server_role_create(attributes = {}) {|event| ... } ⇒ ServerRoleCreateEventHandler
This event is raised when a role is created.
456 457 458 |
# File 'lib/discordrb/container.rb', line 456 def server_role_create(attributes = {}, &block) register_event(ServerRoleCreateEvent, attributes, block) end |
#server_role_delete(attributes = {}) {|event| ... } ⇒ ServerRoleDeleteEventHandler
This event is raised when a role is deleted.
466 467 468 |
# File 'lib/discordrb/container.rb', line 466 def server_role_delete(attributes = {}, &block) register_event(ServerRoleDeleteEvent, attributes, block) end |
#server_role_update(attributes = {}) {|event| ... } ⇒ ServerRoleUpdateEventHandler
This event is raised when a role is updated.
476 477 478 |
# File 'lib/discordrb/container.rb', line 476 def server_role_update(attributes = {}, &block) register_event(ServerRoleUpdateEvent, attributes, block) end |
#server_update(attributes = {}) {|event| ... } ⇒ ServerUpdateEventHandler
This event is raised when a server is updated, for example if the name or region has changed.
388 389 390 |
# File 'lib/discordrb/container.rb', line 388 def server_update(attributes = {}, &block) register_event(ServerUpdateEvent, attributes, block) end |
#string_select(attributes = {}) {|event| ... } ⇒ StringSelectEventHandler Also known as:
This event is raised whenever an select string interaction is created.
599 600 601 |
# File 'lib/discordrb/container.rb', line 599 def string_select(attributes = {}, &block) register_event(StringSelectEvent, attributes, block) end |
#typing(attributes = {}) {|event| ... } ⇒ TypingEventHandler
This event is raised when somebody starts typing in a channel the bot is also in. The official Discord client would display the typing indicator for five seconds after receiving this event. If the user continues typing after five seconds, the event will be re-raised.
91 92 93 |
# File 'lib/discordrb/container.rb', line 91 def typing(attributes = {}, &block) register_event(TypingEvent, attributes, block) end |
#unknown(attributes = {}) {|event| ... } ⇒ UnknownEventHandler
This event is raised for a dispatch received over the gateway that is not currently handled otherwise by discordrb.
753 754 755 |
# File 'lib/discordrb/container.rb', line 753 def unknown(attributes = {}, &block) register_event(UnknownEvent, attributes, block) end |
#user_ban(attributes = {}) {|event| ... } ⇒ UserBanEventHandler
This event is raised when a user is banned from a server.
356 357 358 |
# File 'lib/discordrb/container.rb', line 356 def user_ban(attributes = {}, &block) register_event(UserBanEvent, attributes, block) end |
#user_select(attributes = {}) {|event| ... } ⇒ UserSelectEventHandler
This event is raised whenever an select user interaction is created.
625 626 627 |
# File 'lib/discordrb/container.rb', line 625 def user_select(attributes = {}, &block) register_event(UserSelectEvent, attributes, block) end |
#user_unban(attributes = {}) {|event| ... } ⇒ UserUnbanEventHandler
This event is raised when a user is unbanned from a server.
367 368 369 |
# File 'lib/discordrb/container.rb', line 367 def user_unban(attributes = {}, &block) register_event(UserUnbanEvent, attributes, block) end |
#voice_server_update(attributes = {}) {|event| ... } ⇒ VoiceServerUpdateEventHandler
This event is raised when first connecting to a server's voice channel.
314 315 316 |
# File 'lib/discordrb/container.rb', line 314 def voice_server_update(attributes = {}, &block) register_event(VoiceServerUpdateEvent, attributes, block) end |
#voice_state_update(attributes = {}) {|event| ... } ⇒ VoiceStateUpdateEventHandler
This event is raised when a user's voice state changes. This includes when a user joins, leaves, or moves between voice channels, as well as their mute and deaf status for themselves and on the server.
304 305 306 |
# File 'lib/discordrb/container.rb', line 304 def voice_state_update(attributes = {}, &block) register_event(VoiceStateUpdateEvent, attributes, block) end |
#webhook_update(attributes = {}) {|event| ... } ⇒ WebhookUpdateEventHandler
This event is raised when a webhook is updated.
488 489 490 |
# File 'lib/discordrb/container.rb', line 488 def webhook_update(attributes = {}, &block) register_event(WebhookUpdateEvent, attributes, block) end |