464 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			464 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. currentmodule:: discord
 | |
| 
 | |
| API Reference
 | |
| ===============
 | |
| 
 | |
| The following section outlines the API of discord.py's command extension module.
 | |
| 
 | |
| .. _ext_commands_api_bot:
 | |
| 
 | |
| Bot
 | |
| ----
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.Bot
 | |
|     :members:
 | |
|     :inherited-members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.AutoShardedBot
 | |
|     :members:
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.when_mentioned
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.when_mentioned_or
 | |
| 
 | |
| .. _ext_commands_api_events:
 | |
| 
 | |
| Event Reference
 | |
| -----------------
 | |
| 
 | |
| These events function similar to :ref:`the regular events <discord-api-events>`, except they
 | |
| are custom to the command extension module.
 | |
| 
 | |
| .. function:: on_command_error(ctx, error)
 | |
| 
 | |
|     An error handler that is called when an error is raised
 | |
|     inside a command either through user input error, check
 | |
|     failure, or an error in your own code.
 | |
| 
 | |
|     A default one is provided (:meth:`.Bot.on_command_error`).
 | |
| 
 | |
|     :param ctx: The invocation context.
 | |
|     :type ctx: :class:`.Context`
 | |
|     :param error: The error that was raised.
 | |
|     :type error: :class:`.CommandError` derived
 | |
| 
 | |
| .. function:: on_command(ctx)
 | |
| 
 | |
|     An event that is called when a command is found and is about to be invoked.
 | |
| 
 | |
|     This event is called regardless of whether the command itself succeeds via
 | |
|     error or completes.
 | |
| 
 | |
|     :param ctx: The invocation context.
 | |
|     :type ctx: :class:`.Context`
 | |
| 
 | |
| .. function:: on_command_completion(ctx)
 | |
| 
 | |
|     An event that is called when a command has completed its invocation.
 | |
| 
 | |
|     This event is called only if the command succeeded, i.e. all checks have
 | |
|     passed and the user input it correctly.
 | |
| 
 | |
|     :param ctx: The invocation context.
 | |
|     :type ctx: :class:`.Context`
 | |
| 
 | |
| .. _ext_commands_api_command:
 | |
| 
 | |
| Command
 | |
| --------
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.command
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.group
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.Command
 | |
|     :members:
 | |
|     :special-members: __call__
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.Group
 | |
|     :members:
 | |
|     :inherited-members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.GroupMixin
 | |
|     :members:
 | |
| 
 | |
| .. _ext_commands_api_cogs:
 | |
| 
 | |
| Cogs
 | |
| ------
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.Cog
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.CogMeta
 | |
|     :members:
 | |
| 
 | |
| .. _ext_commands_help_command:
 | |
| 
 | |
| Help Commands
 | |
| -----------------
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.HelpCommand
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.DefaultHelpCommand
 | |
|     :members:
 | |
|     :exclude-members: send_bot_help, send_cog_help, send_group_help, send_command_help, prepare_help_command
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.MinimalHelpCommand
 | |
|     :members:
 | |
|     :exclude-members: send_bot_help, send_cog_help, send_group_help, send_command_help, prepare_help_command
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.Paginator
 | |
|     :members:
 | |
| 
 | |
| Enums
 | |
| ------
 | |
| 
 | |
| .. class:: discord.ext.commands.BucketType
 | |
| 
 | |
|     Specifies a type of bucket for, e.g. a cooldown.
 | |
| 
 | |
|     .. attribute:: default
 | |
| 
 | |
|         The default bucket operates on a global basis.
 | |
|     .. attribute:: user
 | |
| 
 | |
|         The user bucket operates on a per-user basis.
 | |
|     .. attribute:: guild
 | |
| 
 | |
|         The guild bucket operates on a per-guild basis.
 | |
|     .. attribute:: channel
 | |
| 
 | |
|         The channel bucket operates on a per-channel basis.
 | |
|     .. attribute:: member
 | |
| 
 | |
|         The member bucket operates on a per-member basis.
 | |
|     .. attribute:: category
 | |
| 
 | |
|         The category bucket operates on a per-category basis.
 | |
|     .. attribute:: role
 | |
| 
 | |
|         The role bucket operates on a per-role basis.
 | |
| 
 | |
|         .. versionadded:: 1.3
 | |
| 
 | |
| 
 | |
| .. _ext_commands_api_checks:
 | |
| 
 | |
| Checks
 | |
| -------
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.check
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.check_any
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.has_role
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.has_permissions
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.has_guild_permissions
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.has_any_role
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.bot_has_role
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.bot_has_permissions
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.bot_has_guild_permissions
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.bot_has_any_role
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.cooldown
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.max_concurrency
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.before_invoke
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.after_invoke
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.guild_only
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.dm_only
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.is_owner
 | |
| 
 | |
| .. autofunction:: discord.ext.commands.is_nsfw
 | |
| 
 | |
| .. _ext_commands_api_context:
 | |
| 
 | |
| Context
 | |
| --------
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.Context
 | |
|     :members:
 | |
|     :inherited-members:
 | |
|     :exclude-members: history, typing
 | |
| 
 | |
|     .. automethod:: discord.ext.commands.Context.history
 | |
|         :async-for:
 | |
| 
 | |
|     .. automethod:: discord.ext.commands.Context.typing
 | |
|         :async-with:
 | |
| 
 | |
| .. _ext_commands_api_converters:
 | |
| 
 | |
| Converters
 | |
| ------------
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.Converter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.MemberConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.UserConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.MessageConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.TextChannelConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.VoiceChannelConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.CategoryChannelConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.InviteConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.RoleConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.GameConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.ColourConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.EmojiConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.PartialEmojiConverter
 | |
|     :members:
 | |
| 
 | |
| .. autoclass:: discord.ext.commands.clean_content
 | |
|     :members:
 | |
| 
 | |
| .. data:: ext.commands.Greedy
 | |
| 
 | |
|     A special converter that greedily consumes arguments until it can't.
 | |
|     As a consequence of this behaviour, most input errors are silently discarded,
 | |
|     since it is used as an indicator of when to stop parsing.
 | |
| 
 | |
|     When a parser error is met the greedy converter stops converting, undoes the
 | |
|     internal string parsing routine, and continues parsing regularly.
 | |
| 
 | |
|     For example, in the following code:
 | |
| 
 | |
|     .. code-block:: python3
 | |
| 
 | |
|         @commands.command()
 | |
|         async def test(ctx, numbers: Greedy[int], reason: str):
 | |
|             await ctx.send("numbers: {}, reason: {}".format(numbers, reason))
 | |
| 
 | |
|     An invocation of ``[p]test 1 2 3 4 5 6 hello`` would pass ``numbers`` with
 | |
|     ``[1, 2, 3, 4, 5, 6]`` and ``reason`` with ``hello``\.
 | |
| 
 | |
|     For more information, check :ref:`ext_commands_special_converters`.
 | |
| 
 | |
| .. _ext_commands_api_errors:
 | |
| 
 | |
| Exceptions
 | |
| -----------
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.CommandError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ConversionError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.MissingRequiredArgument
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ArgumentParsingError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.UnexpectedQuoteError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.InvalidEndOfQuotedStringError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ExpectedClosingQuoteError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.BadArgument
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.BadUnionArgument
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.PrivateMessageOnly
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.NoPrivateMessage
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.CheckFailure
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.CheckAnyFailure
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.CommandNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.DisabledCommand
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.CommandInvokeError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.TooManyArguments
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.UserInputError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.CommandOnCooldown
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.MaxConcurrencyReached
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.NotOwner
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.MessageNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.MemberNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.UserNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ChannelNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ChannelNotReadable
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.RoleNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.EmojiNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.PartialEmojiConversionFailure
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.BadBoolArgument
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.MissingPermissions
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.BotMissingPermissions
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.MissingRole
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.BotMissingRole
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.MissingAnyRole
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.BotMissingAnyRole
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.NSFWChannelRequired
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ExtensionError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ExtensionAlreadyLoaded
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ExtensionNotLoaded
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.NoEntryPointError
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ExtensionFailed
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.ExtensionNotFound
 | |
|     :members:
 | |
| 
 | |
| .. autoexception:: discord.ext.commands.CommandRegistrationError
 | |
|     :members:
 | |
| 
 | |
| 
 | |
| Exception Hierarchy
 | |
| +++++++++++++++++++++
 | |
| 
 | |
| .. exception_hierarchy::
 | |
| 
 | |
|     - :exc:`~.DiscordException`
 | |
|         - :exc:`~.commands.CommandError`
 | |
|             - :exc:`~.commands.ConversionError`
 | |
|             - :exc:`~.commands.UserInputError`
 | |
|                 - :exc:`~.commands.MissingRequiredArgument`
 | |
|                 - :exc:`~.commands.TooManyArguments`
 | |
|                 - :exc:`~.commands.BadArgument`
 | |
|                     - :exc:`~.commands.MessageNotFound`
 | |
|                     - :exc:`~.commands.MemberNotFound`
 | |
|                     - :exc:`~.commands.UserNotFound`
 | |
|                     - :exc:`~.commands.ChannelNotFound`
 | |
|                     - :exc:`~.commands.ChannelNotReadable`
 | |
|                     - :exc:`~.commands.BadColourArgument`
 | |
|                     - :exc:`~.commands.RoleNotFound`
 | |
|                     - :exc:`~.commands.BadInviteArgument`
 | |
|                     - :exc:`~.commands.EmojiNotFound`
 | |
|                     - :exc:`~.commands.PartialEmojiConversionFailure`
 | |
|                     - :exc:`~.commands.BadBoolArgument`
 | |
|                 - :exc:`~.commands.BadUnionArgument`
 | |
|                 - :exc:`~.commands.ArgumentParsingError`
 | |
|                     - :exc:`~.commands.UnexpectedQuoteError`
 | |
|                     - :exc:`~.commands.InvalidEndOfQuotedStringError`
 | |
|                     - :exc:`~.commands.ExpectedClosingQuoteError`
 | |
|             - :exc:`~.commands.CommandNotFound`
 | |
|             - :exc:`~.commands.CheckFailure`
 | |
|                 - :exc:`~.commands.CheckAnyFailure`
 | |
|                 - :exc:`~.commands.PrivateMessageOnly`
 | |
|                 - :exc:`~.commands.NoPrivateMessage`
 | |
|                 - :exc:`~.commands.NotOwner`
 | |
|                 - :exc:`~.commands.MissingPermissions`
 | |
|                 - :exc:`~.commands.BotMissingPermissions`
 | |
|                 - :exc:`~.commands.MissingRole`
 | |
|                 - :exc:`~.commands.BotMissingRole`
 | |
|                 - :exc:`~.commands.MissingAnyRole`
 | |
|                 - :exc:`~.commands.BotMissingAnyRole`
 | |
|                 - :exc:`~.commands.NSFWChannelRequired`
 | |
|             - :exc:`~.commands.DisabledCommand`
 | |
|             - :exc:`~.commands.CommandInvokeError`
 | |
|             - :exc:`~.commands.CommandOnCooldown`
 | |
|             - :exc:`~.commands.MaxConcurrencyReached`
 | |
|         - :exc:`~.commands.ExtensionError`
 | |
|             - :exc:`~.commands.ExtensionAlreadyLoaded`
 | |
|             - :exc:`~.commands.ExtensionNotLoaded`
 | |
|             - :exc:`~.commands.NoEntryPointError`
 | |
|             - :exc:`~.commands.ExtensionFailed`
 | |
|             - :exc:`~.commands.ExtensionNotFound`
 | |
|     - :exc:`~.ClientException`
 | |
|         - :exc:`~.commands.CommandRegistrationError`
 |