Interface CommandClient
- All Known Implementing Classes:
- CommandClientImpl
This is implemented in CommandClientImpl
 alongside implementation of EventListener to create a
 compounded "Client Listener" which catches specific kinds of events thrown by JDA and processes them
 automatically to handle and execute Commands.
 
Implementations also serve as a useful platforms, carrying reference info such as the bot's Owner ID, prefix, and a support server invite.
For the CommandClientImpl, once initialized, only the following can be modified:
- Commands may be added or removed.
- The CommandListenermay be set.
- Author:
- John Grosh (jagrosh)
- Implementation Note:
- While typically safe, there are a few ways to misuse the standard implementation of this interface:
         the CommandClientImpl.
         
 Because of this the following should ALWAYS be followed to avoid such errors:1) Do not build and add more than one CommandClient to an instance JDA, EVER. 2) Always create and add the CommandClientImpl to JDA BEFORE you build it, or there is a chance some minor errors will occur, especially if JDA has already fired a ReadyEvent.3) Do not provide anything other than a String representing a long (and furthermore a User ID) as an Owner ID or a CoOwner ID. This will generate errors, but not stop the creation of the CommandClientImpl which will cause several errors to occur very quickly after startup (except if you provide nullfor the Owner ID, that'll just flat out throw anIllegalArgumentException).4) Do not provide strings when using CommandClientBuilder#setEmojis(String, String, String)that are not unicode emojis or that do not match the custom emote format specified inEmoji.getFormatted()() Emote#getAsMention()} (IE:<:EmoteName:EmoteID>).5) Avoid using CommandClientImpl.linkIds(long, net.dv8tion.jda.api.entities.Message). This will create errors and has no real purpose outside of it's current usage.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddAnnotatedModule(Object module) Compiles the providedObjectannotated withJDACommand.Moduleinto aListofCommands and adds them to this CommandClient in the order they are listed.voidaddAnnotatedModule(Object module, Function<Command, Integer> mapFunction) Compiles the providedObjectannotated withJDACommand.Moduleinto aListofCommands and adds them to this CommandClient via theFunctionprovided.voidaddCommand(Command command) Adds a singleCommandto this CommandClient's registered Commands.voidaddCommand(Command command, int index) Adds a singleCommandto this CommandClient's registered Commands at the specified index.voidaddContextMenu(ContextMenu menu) Adds a singleContextMenuto this CommandClient's registered Context Menus.voidaddContextMenu(ContextMenu menu, int index) Adds a singleContextMenuto this CommandClient's registered Context Menus.voidaddSlashCommand(SlashCommand command) Adds a singleSlashCommandto this CommandClient's registered SlashCommand.voidaddSlashCommand(SlashCommand command, int index) Adds a singleSlashCommandto this CommandClient's registered Commands at the specified index.voidapplyCooldown(String name, int seconds) Applies the specified cooldown with the provided name.voidCleans up expired cooldowns to reduce memory.Returns the forced Guild ID for automatic slash command upsertsGets the Client's alternate prefix.Returns the list of registeredCommands during this session.intgetCommandUses(Command command) Gets the number of uses for the provideCommandduring this session, or0if the command is not registered to this CommandClient.intgetCommandUses(String name) Gets the number of uses for aCommandduring this session matching the provided String name, or0if there is no Command with the name.Returns the list of registeredContextMenus during this session.getCooldown(String name) Gets theOffsetDateTimethat the specified cooldown expires.String[]Gets the ID(s) of any CoOwners of this bot as a String Array.long[]Gets the ID(s) of any CoOwners of this bot as alongArray.getError()Gets the error emoji.Gets the word used to invoke a help DM.Returns the currentCommandListener.Gets the ID of the owner of this bot as a String.longGets the ID of the owner of this bot as along.Gets the Client's prefix.String[]Gets the array of prefixesGets the prefix BiConsumerintgetRemainingCooldown(String name) Gets the remaining number of seconds on the specified cooldown.Gets theScheduledExecutorServiceheld by this client.Gets the invite to the bot's support server.<S> SgetSettingsFor(net.dv8tion.jda.api.entities.Guild guild) Returns an Object of the type parameter that should contain settings relating to the specifiedGuild.<M extends GuildSettingsManager>
 MReturns the type ofGuildSettingsManager, the same type of one provided when building this CommandClient, ornullif one was not provided there.Returns the list of registeredSlashCommands during this session.Gets the time thisCommandClientimplementation was created.Gets the success emoji.Returns the visual representation of the bot's prefix.intGets an a recently updated count of all theGuilds the bot is connected to on all shards.Gets the warning emoji.booleanReturns whether manual upsertion is enabledvoidremoveCommand(String name) Removes a singleCommandfrom this CommandClient's registered Commands at the index linked to the provided name/alias.voidsetListener(CommandListener listener) Sets theCommandListenerto catch command-related events thrown by thisCommandClient.voidshutdown()Shuts down internals of the Command Client, such as the threadpool and guild settings managervoidupsertInteractions(net.dv8tion.jda.api.JDA jda) Upserts all interactions to the providedforced server.voidupsertInteractions(net.dv8tion.jda.api.JDA jda, String serverId) Upserts all interactions to the provided server.booleanGets whether this CommandClient uses linked deletion.
- 
Method Details- 
getPrefixString getPrefix()Gets the Client's prefix.- Returns:
- A possibly-null prefix
 
- 
getAltPrefixString getAltPrefix()Gets the Client's alternate prefix.- Returns:
- A possibly-null alternate prefix
 
- 
getPrefixesString[] getPrefixes()Gets the array of prefixes- Returns:
- A possibly-null list of prefixes
 
- 
getPrefixFunctionGets the prefix BiConsumer- Returns:
- A possibly-null prefix BiConsumer
 
- 
getTextualPrefixString getTextualPrefix()Returns the visual representation of the bot's prefix.This is the same as getPrefix()unless the prefix is the default, in which case it appears as @Botname.- Returns:
- A never-null prefix
 
- 
addCommandAdds a singleCommandto this CommandClient's registered Commands.For CommandClient's containing 20 commands or less, command calls by users will have the bot iterate through the entire ArrayListto find the command called. As expected, this can get fairly hefty if a bot has a lot of Commands registered to it.To prevent delay a CommandClient that has more that 20 Commands registered to it will begin to use indexed calls. 
 Indexed calls use aHashMapwhich links theirnameand theiraliasesto the index that which they are located at in the ArrayList they are stored.This means that all insertion and removal of Commands must reorganize the index maintained by the HashMap. 
 For this particular insertion, the Command provided is inserted at the end of the index, meaning it will become the "rightmost" Command in the ArrayList.- Parameters:
- command- The Command to add
- Throws:
- IllegalArgumentException- If the Command provided has a name or alias that has already been registered
 
- 
addCommandAdds a singleCommandto this CommandClient's registered Commands at the specified index.For CommandClient's containing 20 commands or less, command calls by users will have the bot iterate through the entire ArrayListto find the command called. As expected, this can get fairly hefty if a bot has a lot of Commands registered to it.To prevent delay a CommandClient that has more that 20 Commands registered to it will begin to use indexed calls. 
 Indexed calls use aHashMapwhich links theirnameand theiraliasesto the index that which they are located at in the ArrayList they are stored.This means that all insertion and removal of Commands must reorganize the index maintained by the HashMap. 
 For this particular insertion, the Command provided is inserted at the index specified, meaning it will become the Command located at that index in the ArrayList. This will shift the Command previously located at that index as well as any located at greater indices, right one index (size()+1).- Parameters:
- command- The Command to add
- index- The index to add the Command at (must follow the specifications- 0<=index<=size())
- Throws:
- ArrayIndexOutOfBoundsException- If- index < 0or- index > size()
- IllegalArgumentException- If the Command provided has a name or alias that has already been registered to an index
 
- 
addSlashCommandAdds a singleSlashCommandto this CommandClient's registered SlashCommand.For CommandClient's containing 20 commands or less, command calls by users will have the bot iterate through the entire ArrayListto find the command called. As expected, this can get fairly hefty if a bot has a lot of Commands registered to it.To prevent delay a CommandClient that has more that 20 Commands registered to it will begin to use indexed calls. 
 Indexed calls use aHashMapwhich links theirnameto the index that which they are located at in the ArrayList they are stored.This means that all insertion and removal of SlashCommands must reorganize the index maintained by the HashMap. 
 For this particular insertion, the SlashCommand provided is inserted at the end of the index, meaning it will become the "rightmost" Command in the ArrayList.- Parameters:
- command- The Command to add
- Throws:
- IllegalArgumentException- If the SlashCommand provided has a name or alias that has already been registered
 
- 
addSlashCommandAdds a singleSlashCommandto this CommandClient's registered Commands at the specified index.For CommandClient's containing 20 commands or less, command calls by users will have the bot iterate through the entire ArrayListto find the command called. As expected, this can get fairly hefty if a bot has a lot of Commands registered to it.To prevent delay a CommandClient that has more that 20 Commands registered to it will begin to use indexed calls. 
 Indexed calls use aHashMapwhich links theirnameto the index that which they are located at in the ArrayList they are stored.This means that all insertion and removal of Commands must reorganize the index maintained by the HashMap. 
 For this particular insertion, the Command provided is inserted at the index specified, meaning it will become the Command located at that index in the ArrayList. This will shift the Command previously located at that index as well as any located at greater indices, right one index (size()+1).- Parameters:
- command- The Command to add
- index- The index to add the Command at (must follow the specifications- 0<=index<=size())
- Throws:
- ArrayIndexOutOfBoundsException- If- index < 0or- index > size()
- IllegalArgumentException- If the Command provided has a name or alias that has already been registered to an index
 
- 
addContextMenuAdds a singleContextMenuto this CommandClient's registered Context Menus.- Parameters:
- menu- The menu to add
- Throws:
- IllegalArgumentException- If the Context Menu provided has a name that has already been registered
 
- 
addContextMenuAdds a singleContextMenuto this CommandClient's registered Context Menus.- Parameters:
- menu- The menu to add
- index- The index to add the Context Menu at (must follow the specifications- 0<=index<=size())
- Throws:
- IllegalArgumentException- If the Context Menu provided has a name that has already been registered
 
- 
removeCommandRemoves a singleCommandfrom this CommandClient's registered Commands at the index linked to the provided name/alias.For CommandClient's containing 20 commands or less, command calls by users will have the bot iterate through the entire ArrayListto find the command called. As expected, this can get fairly hefty if a bot has a lot of Commands registered to it.To prevent delay a CommandClient that has more that 20 Commands registered to it will begin to use indexed calls. 
 Indexed calls use aHashMapwhich links theirnameand theiraliasesto the index that which they are located at in the ArrayList they are stored.This means that all insertion and removal of Commands must reorganize the index maintained by the HashMap. 
 For this particular removal, the Command removed is that of the corresponding index retrieved by the name provided. This will shift any Commands located at greater indices, left one index (size()-1).- Parameters:
- name- The name or an alias of the Command to remove
- Throws:
- IllegalArgumentException- If the name provided was not registered to an index
 
- 
addAnnotatedModuleCompiles the providedObjectannotated withJDACommand.Moduleinto aListofCommands and adds them to this CommandClient in the order they are listed.This is done through the AnnotatedModuleCompilerprovided when building this CommandClient.- Parameters:
- module- An object annotated with JDACommand.Module to compile into commands to be added.
- Throws:
- IllegalArgumentException- If the Command provided has a name or alias that has already been registered
 
- 
addAnnotatedModuleCompiles the providedObjectannotated withJDACommand.Moduleinto aListofCommands and adds them to this CommandClient via theFunctionprovided.This is done through the AnnotatedModuleCompilerprovided when building this CommandClient.The Function will applyeachCommandin the compiled list and request anintin return.
 Using thisint, the command provided will be applied to the CommandClient viaCommandClient#addCommand(Command, int).- Parameters:
- module- An object annotated with JDACommand.Module to compile into commands to be added.
- mapFunction- The Function to get indexes for each compiled Command with when adding them to the CommandClient.
- Throws:
- ArrayIndexOutOfBoundsException- If- index < 0or- index > size()
- IllegalArgumentException- If the Command provided has a name or alias that has already been registered to an index
 
- 
setListenerSets theCommandListenerto catch command-related events thrown by thisCommandClient.- Parameters:
- listener- The CommandListener
 
- 
getListenerCommandListener getListener()Returns the currentCommandListener.- Returns:
- A possibly-null CommandListener
 
- 
getCommandsReturns the list of registeredCommands during this session.- Returns:
- A never-null List of Commands registered during this session
 
- 
getSlashCommandsList<SlashCommand> getSlashCommands()Returns the list of registeredSlashCommands during this session.- Returns:
- A never-null List of Slash Commands registered during this session
 
- 
getContextMenusList<ContextMenu> getContextMenus()Returns the list of registeredContextMenus during this session.- Returns:
- A never-null List of Context Menus registered during this session
 
- 
isManualUpsertboolean isManualUpsert()Returns whether manual upsertion is enabled- Returns:
- The manual upsertion status
 
- 
forcedGuildIdString forcedGuildId()Returns the forced Guild ID for automatic slash command upserts- Returns:
- A possibly-null forcedGuildId set in the builder
 
- 
getStartTimeOffsetDateTime getStartTime()Gets the time thisCommandClientimplementation was created.- Returns:
- The start time of this CommandClient implementation
 
- 
getCooldownGets theOffsetDateTimethat the specified cooldown expires.- Parameters:
- name- The cooldown name
- Returns:
- The expiration time, or null if the cooldown does not exist
 
- 
getRemainingCooldownGets the remaining number of seconds on the specified cooldown.- Parameters:
- name- The cooldown name
- Returns:
- The number of seconds remaining
 
- 
applyCooldownApplies the specified cooldown with the provided name.- Parameters:
- name- The cooldown name
- seconds- The time to make the cooldown last
 
- 
cleanCooldownsvoid cleanCooldowns()Cleans up expired cooldowns to reduce memory.
- 
getCommandUsesGets the number of uses for the provideCommandduring this session, or0if the command is not registered to this CommandClient.- Parameters:
- command- The Command
- Returns:
- The number of uses for the Command
 
- 
getCommandUsesGets the number of uses for aCommandduring this session matching the provided String name, or0if there is no Command with the name.NOTE: this method WILL NOT get uses for a command if an aliasis provided! Also note thatchild commandsARE NOT tracked and providing names or effective names of child commands will return0.- Parameters:
- name- The name of the Command
- Returns:
- The number of uses for the Command, or 0if the name does not match with a Command
 
- 
getOwnerIdString getOwnerId()Gets the ID of the owner of this bot as a String.- Returns:
- The String ID of the owner of the bot
 
- 
getOwnerIdLonglong getOwnerIdLong()Gets the ID of the owner of this bot as along.- Returns:
- The longID of the owner of the bot
 
- 
getCoOwnerIdsString[] getCoOwnerIds()Gets the ID(s) of any CoOwners of this bot as a String Array.- Returns:
- The String ID(s) of any CoOwners of this bot
 
- 
getCoOwnerIdsLonglong[] getCoOwnerIdsLong()Gets the ID(s) of any CoOwners of this bot as alongArray.- Returns:
- The longID(s) of any CoOwners of this bot
 
- 
getSuccessString getSuccess()Gets the success emoji.- Returns:
- The success emoji
 
- 
getWarningString getWarning()Gets the warning emoji.- Returns:
- The warning emoji
 
- 
getErrorString getError()Gets the error emoji.- Returns:
- The error emoji
 
- 
getScheduleExecutorScheduledExecutorService getScheduleExecutor()Gets theScheduledExecutorServiceheld by this client.This is used for methods such as CommandEvent#async(Runnable)run code asynchronously.- Returns:
- The ScheduledExecutorService held by this client.
 
- 
getServerInviteString getServerInvite()Gets the invite to the bot's support server.- Returns:
- A possibly-null server invite
 
- 
getTotalGuildsint getTotalGuilds()Gets an a recently updated count of all theGuilds the bot is connected to on all shards.NOTE: This may not always or should not be assumed accurate! Any time a shard joins or leaves a guild it will update the number retrieved by this method but will not update when other shards join or leave guilds. This means that shards will not always retrieve the same value. For instance: - 1) Shard A joins 10 Guilds
- 2) Shard B invokes this method
- 3) Shard A invokes this method
 This feature requires a Discord Bots API Key to be set! 
 To set your Discord Bots API Key, you'll have to retrieve it from the Discord Bots website.- Returns:
- A recently updated count of all the Guilds the bot is connected to on all shards.
 
- 
getHelpWordString getHelpWord()Gets the word used to invoke a help DM.- Returns:
- The help word
 
- 
usesLinkedDeletionboolean usesLinkedDeletion()Gets whether this CommandClient uses linked deletion.Linking calls is the basic principle of pairing bot responses with their calling Messages.
 Using this with a basic function such as deletion, this causes bots to delete their Messages as a response to the calling Message being deleted.- Returns:
- trueif the bot uses linked deletion,- falseotherwise.
- See Also:
 
- 
getSettingsFor<S> S getSettingsFor(net.dv8tion.jda.api.entities.Guild guild) Returns an Object of the type parameter that should contain settings relating to the specifiedGuild.The returning object for this is specified via provision of a GuildSettingsManagertoCommandClientBuilder#setGuildSettingsManager(GuildSettingsManager), more specificallyGuildSettingsManager#getSettings(Guild).- Type Parameters:
- S- The type of settings the GuildSettingsManager provides
- Parameters:
- guild- The Guild to get Settings for
- Returns:
- The settings object for the Guild, specified in
         GuildSettingsManager#getSettings(Guild), can benullif the implementation allows it.
 
- 
getSettingsManagerReturns the type ofGuildSettingsManager, the same type of one provided when building this CommandClient, ornullif one was not provided there.This is good if you want to use non-abstract methods specific to your implementation. - Type Parameters:
- M- The type of the GuildSettingsManager
- Returns:
- The GuildSettingsManager, or nullif one was not provided when building this CommandClient.
 
- 
shutdownvoid shutdown()Shuts down internals of the Command Client, such as the threadpool and guild settings manager
- 
upsertInteractionsvoid upsertInteractions(net.dv8tion.jda.api.JDA jda) Upserts all interactions to the providedforced server.
 This runs after theReadyEventhas been fired ifisManualUpsert()isfalse.
 IfforcedGuildId()isnull, commands will upsert globally. This may take up to an hour.- Parameters:
- jda- The JDA instance to use
 
- 
upsertInteractionsUpserts all interactions to the provided server.
 This runs after theReadyEventhas been fired ifisManualUpsert()isfalse.
 Ifnullis passed for the server, commands will upsert globally. This may take up to an hour.- Parameters:
- jda- The JDA instance to use
- serverId- The server to upsert interactions for
 
 
-