Class ThreadChannelActionImpl
- All Implemented Interfaces:
RestAction<ThreadChannel>
,AbstractThreadCreateAction<ThreadChannel,
,ThreadChannelAction> AuditableRestAction<ThreadChannel>
,FluentAuditableRestAction<ThreadChannel,
,ThreadChannelAction> ThreadChannelAction
-
Field Summary
Fields inherited from class net.dv8tion.jda.internal.requests.RestActionImpl
LOG
Fields inherited from interface net.dv8tion.jda.api.requests.restaction.AuditableRestAction
MAX_REASON_LENGTH
-
Constructor Summary
ConstructorsConstructorDescriptionThreadChannelActionImpl
(GuildChannel channel, String name, String parentMessageId) ThreadChannelActionImpl
(GuildChannel channel, String name, ChannelType type) -
Method Summary
Modifier and TypeMethodDescriptiondeadline
(long timestamp) Similar toRestAction.timeout(long, TimeUnit)
but schedules a deadline at which the request has to be completed.getGuild()
The guild to create thisGuildChannel
for.getType()
TheChannelType
for the resulting channel.Applies the specified reason as audit-log reason field.setAutoArchiveDuration
(ThreadChannel.AutoArchiveDuration autoArchiveDuration) Sets theThreadChannel.AutoArchiveDuration
for the new thread.setCheck
(BooleanSupplier checks) Sets the last-second checks before finally executing the http request in the queue.setInvitable
(boolean invitable) Sets whether this channel allows all members to add new members.Sets the name for the new GuildChannel.setSlowmode
(int slowmode) Sets the slowmode for the new thread.Timeout for this RestAction instance.Methods inherited from class net.dv8tion.jda.internal.requests.RestActionImpl
complete, getCheck, getDefaultFailure, getDefaultSuccess, getDefaultTimeout, getJDA, handleResponse, isPassContext, priority, queue, setDefaultFailure, setDefaultSuccess, setDefaultTimeout, setErrorMapper, setPassContext, submit
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface net.dv8tion.jda.api.requests.restaction.FluentAuditableRestAction
addCheck
Methods inherited from interface net.dv8tion.jda.api.requests.RestAction
and, and, complete, complete, completeAfter, delay, delay, delay, delay, flatMap, flatMap, getCheck, getJDA, map, mapToResult, onErrorFlatMap, onErrorFlatMap, onErrorMap, onErrorMap, onSuccess, queue, queue, queue, queueAfter, queueAfter, queueAfter, queueAfter, queueAfter, queueAfter, submit, submit, submitAfter, submitAfter, zip
-
Constructor Details
-
ThreadChannelActionImpl
-
ThreadChannelActionImpl
-
-
Method Details
-
reason
Description copied from interface:AuditableRestAction
Applies the specified reason as audit-log reason field.
When the provided reason is empty ornull
it will be treated as not set. If the provided reason is longer than 512<T> characters, it will be truncated to fit the limit.Reasons for any AuditableRestAction may be retrieved via
AuditLogEntry.getReason()
in iterableAuditLogPaginationActions
fromGuild.retrieveAuditLogs()
! Forguild bans
, this is also accessible viaGuild.Ban.getReason()
.This will specify the reason via the
X-Audit-Log-Reason
Request Header.- Specified by:
reason
in interfaceAuditableRestAction<ThreadChannel>
- Specified by:
reason
in interfaceFluentAuditableRestAction<ThreadChannel,
ThreadChannelAction> - Overrides:
reason
in classAuditableRestActionImpl<ThreadChannel>
- Parameters:
reason
- The reason for this action which should be logged in the Guild's AuditLogs (up to 512<T> characters)- Returns:
- The current AuditableRestAction instance for chaining convenience
- See Also:
-
setCheck
Description copied from interface:RestAction
Sets the last-second checks before finally executing the http request in the queue.
If the provided supplier evaluates tofalse
or throws an exception this will not be finished. When an exception is thrown from the supplier it will be provided to the failure callback.- Specified by:
setCheck
in interfaceAuditableRestAction<ThreadChannel>
- Specified by:
setCheck
in interfaceFluentAuditableRestAction<ThreadChannel,
ThreadChannelAction> - Specified by:
setCheck
in interfaceRestAction<ThreadChannel>
- Overrides:
setCheck
in classAuditableRestActionImpl<ThreadChannel>
- Parameters:
checks
- The checks to run before executing the request, ornull
to run no checks- Returns:
- The current RestAction for chaining convenience
- See Also:
-
timeout
Description copied from interface:AuditableRestAction
Timeout for this RestAction instance.
If the request doesn't get executed within the timeout it will fail.When a RestAction times out, it will fail with a
TimeoutException
. This is the same asdeadline(System.currentTimeMillis() + unit.toMillis(timeout))
.Example
action.timeout(10, TimeUnit.SECONDS) // 10 seconds from now .queueAfter(20, SECONDS); // request will not be executed within deadline and timeout immediately after 20 seconds
- Specified by:
timeout
in interfaceAuditableRestAction<ThreadChannel>
- Specified by:
timeout
in interfaceFluentAuditableRestAction<ThreadChannel,
ThreadChannelAction> - Specified by:
timeout
in interfaceRestAction<ThreadChannel>
- Overrides:
timeout
in classAuditableRestActionImpl<ThreadChannel>
- Parameters:
timeout
- The timeout to useunit
-Unit
for the timeout value- Returns:
- The same RestAction instance with the applied timeout
- See Also:
-
deadline
Description copied from interface:RestAction
Similar toRestAction.timeout(long, TimeUnit)
but schedules a deadline at which the request has to be completed.
If the deadline is reached, the request will fail with aTimeoutException
.This does not mean that the request will immediately timeout when the deadline is reached. JDA will check the deadline right before executing the request or within intervals in a worker thread. This only means the request will timeout if the deadline has passed.
Example
action.deadline(System.currentTimeMillis() + 10000) // 10 seconds from now .queueAfter(20, SECONDS); // request will not be executed within deadline and timeout immediately after 20 seconds
- Specified by:
deadline
in interfaceAuditableRestAction<ThreadChannel>
- Specified by:
deadline
in interfaceFluentAuditableRestAction<ThreadChannel,
ThreadChannelAction> - Specified by:
deadline
in interfaceRestAction<ThreadChannel>
- Overrides:
deadline
in classAuditableRestActionImpl<ThreadChannel>
- Parameters:
timestamp
- Millisecond timestamp at which the request will timeout- Returns:
- The same RestAction with the applied deadline
- See Also:
-
getGuild
Description copied from interface:AbstractThreadCreateAction
The guild to create thisGuildChannel
for.- Specified by:
getGuild
in interfaceAbstractThreadCreateAction<ThreadChannel,
ThreadChannelAction> - Returns:
- The guild
-
getType
Description copied from interface:AbstractThreadCreateAction
TheChannelType
for the resulting channel.- Specified by:
getType
in interfaceAbstractThreadCreateAction<ThreadChannel,
ThreadChannelAction> - Returns:
- The channel type
-
setName
Description copied from interface:AbstractThreadCreateAction
Sets the name for the new GuildChannel.- Specified by:
setName
in interfaceAbstractThreadCreateAction<ThreadChannel,
ThreadChannelAction> - Parameters:
name
- The not-null name for the new GuildChannel (up to 100 characters)- Returns:
- The current action, for chaining convenience
-
setAutoArchiveDuration
@Nonnull public ThreadChannelAction setAutoArchiveDuration(@Nonnull ThreadChannel.AutoArchiveDuration autoArchiveDuration) Description copied from interface:AbstractThreadCreateAction
Sets theThreadChannel.AutoArchiveDuration
for the new thread.
This is primarily used to hide threads after the provided time of inactivity. Threads are automatically archived after 7 days of inactivity regardless.- Specified by:
setAutoArchiveDuration
in interfaceAbstractThreadCreateAction<ThreadChannel,
ThreadChannelAction> - Parameters:
autoArchiveDuration
- The new archive inactivity duration (which hides the thread)- Returns:
- The current action, for chaining convenience
-
setSlowmode
Description copied from interface:AbstractThreadCreateAction
Sets the slowmode for the new thread.A channel slowmode must not be negative nor greater than
ISlowmodeChannel.MAX_SLOWMODE
!Note: Bots are unaffected by this.
HavingMESSAGE_MANAGE
orMANAGE_CHANNEL
permission also grants immunity to slowmode.- Specified by:
setSlowmode
in interfaceAbstractThreadCreateAction<ThreadChannel,
ThreadChannelAction> - Parameters:
slowmode
- The new slowmode- Returns:
- The current action, for chaining convenience
- See Also:
-
setInvitable
Description copied from interface:ThreadChannelAction
Sets whether this channel allows all members to add new members.
When set to false, only moderators and the thread owner can add new members.- Specified by:
setInvitable
in interfaceThreadChannelAction
- Parameters:
invitable
- True, if all members should be allowed to add new members- Returns:
- The current ThreadChannelAction for chaining convenience
-