Releases: discord-jda/JDA
v5.2.1
Small bug fix release.
Bug Fixes
- Fix GuildManager#setSafetyAlertsChannel by @MinnDevelopment in #2765
- Correctly handle disabled intent in setEnabledIntents by @MinnDevelopment in #2767
- Ensure label cannot be null in Button by @MinnDevelopment in #2771
- Handle user in EntityBuilder#createApplicationEmoji as optional by @Xirado in #2769
Full Changelog: v5.2.0...v5.2.1
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.2.1")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.2.1</version>
</dependency>
v5.2.0 | Application emoji and premium buttons
Overview
This release adds some new features for applications. We've also started working on more compliance tests to make contributing and reviewing changes easier.
Premium Buttons (#2752)
The interaction response replyWithPremiumRequired
is being phased out in favor of custom messages with a new button style Button.premium(sku)
to upsell specific premium features instead.
You can change your code to a simple reply(content)
with this button as a component.
event.reply("This feature is only available for premium users.")
.addActionRow(Button.primary(SkuSnowflake.fromId(PREMIUM_FEATURE_SKU)))
.setEphemeral(true)
.queue();
For more info, see the official Discord Changelog.
Application Emoji (#2726)
Your bot can now manage emoji with JDA by using JDA#createApplicationEmoji
. These emojis can then be used like any other emoji with Emoji.fromCustom(name, id, animated)
.
New Features
- Added Safety Alerts Channel by @RealYusufIsmail in #2725
- Add
ScheduledEvent::getJumpUrl
by @raul1ro in #2736 - Add premium buttons by @freya022 in #2752
- Add support for Application Emoji by @yoyosource in #2726
Bug Fixes
- Fix handling of passing null to setMessageReference by @MinnDevelopment in #2749
Changes
- Deprecated
GatewayIntent#GUILD_EMOJIS_AND_STICKERS
in favor ofGUILD_EXPRESSIONS
by @freya022 in #2755 - Remove deprecated permission constants
- Remove deprecated and stage instance privacy level
Full Changelog: v5.1.2...v5.2.0
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.2.0")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.2.0</version>
</dependency>
v5.1.2 | Message Forwarding and Voice Messages
Overview
This release adds support for new message features.
Forwarding messages (#2744)
You can now handle forwarded messages using the new message snapshots.
@Override
public void onMessageReceived(MessageReceivedEvent event) {
MessageReference messageReference = event.getMessage().getMessageReference();
// Forwarded messages have a reference of type FORWARD
if (messageReference != null && messageReference.getType() == MessageReference.MessageReferenceType.FORWARD) {
// The content of the forwarded message is provided as a snapshot
MessageSnapshot snapshot = event.getMessage().getMessageSnapshots().getFirst();
System.out.println("Received forwarded message with content: " + snapshot.getContentRaw());
}
}
A bot can also forward a message using Message#fowardTo
. Note that a forwarded message cannot contain any additional content.
Voice messages (#2738)
You can now send voice messages with JDA, by utilizing the new FileUpload#asVoiceMessage
method on your audio attachments.
channel.sendFiles(
FileUpload.fromData(audioFile)
.asVoiceMessage(MediaType.parse("audio/ogg"), waveform, 10.5) // 10.5 seconds audio/ogg message
).queue();
To create a voice message, you must first determine the audio media type of your voice message and sample a waveform up to 256 bytes. Voice messages require a valid audio/*
media type like audio/ogg
.
The waveform is used to render the voice message shape in the preview. It must not be an accurate sampling of the actual audio.
New Features
- Add support for message forwarding by @MinnDevelopment in #2744
- Support sending voice messages by @MinnDevelopment in #2738
Bug Fixes
Full Changelog: v5.1.1...v5.1.2
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.1.2")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.1.2</version>
</dependency>
v5.1.1 | Small bugfix release
Overview
Small release to fix a few bugs. This fixes an issue that caused voice receive to no longer work as intended in 5.1.0.
Bug Fixes
- Remove extension from received audio packets by @davidffa in #2721
- Remove
@CheckReturnValue
from Once.Builder.subscribe by @freya022 in #2730 - Fix parsing error for AutoModResponse by @StasiumDev in #2728
Full Changelog: v5.1.0...v5.1.1
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.1.1")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.1.1</version>
</dependency>
v5.1.0 | Voice Gateway v8
Overview
This release updates the implementation of the voice gateway to API version 8 (previously 4). Previous versions will be incompatible coming November 18, 2024. This includes adding a new dependency on tink, to support the new encryption modes.
Additionally, the MessageEmbedEvent
has been removed. Discord sends standard update events for embed loading now, this event can no longer be supported.
New Features
- Add new message and embed types by @MinnDevelopment in #2716
Changes
- Upgrade to voice gateway v8 by @MinnDevelopment in #2717
- Remove MessageEmbedEvent by @MinnDevelopment in #2720
Bug Fixes
Full Changelog: v5.0.2...v5.1.0
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.1.0")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.1.0</version>
</dependency>
v5.0.2 | Single time event listener
Overview
This release includes some bug fixes as well as a new event listener feature to add a one-time-use event listener.
Once Event Listener (#2683)
A common problem that developers run into, is "waiting" for a specific event in the context of some command. For instance, waiting for a user to add a reaction or reply with a message in response to some prompt.
This can now be achieved using the new listenOnce event listener:
// listen for a message event
jda.listenOnce(MessageReceivedEvent.class)
// filter for specific event
.filter(event -> event.getChannel().equals(channel))
.filter(event -> event.getAuthor().equals(user))
// handle timeout
.timeout(timeout, () -> hook.editOriginal("Timeout!").queue())
// subscribe to first event that matches filters
.subscribe(event -> {
hook.editOriginal("You sent: " + event.getMessage().getContentRaw()).queue();
});
New Features
- Add
TeamMember.RoleType
by @freya022 in #2703 - Add abstract
createCopy
method inSelectMenu
by @Kaktushose in #2684 - Add
JDA#listenOnce
by @freya022 in #2683 - Add support for profile automod by @MinnDevelopment in #2580
Changes
- Expand list of retried http error codes by @MinnDevelopment in #2710
- Update to Jackson 2.17.2 by @freya022 in #2695
Bug Fixes
Full Changelog: v5.0.1...v5.0.2
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.0.2")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.0.2</version>
</dependency>
v5.0.1 | Hotfix shard manager thread handling
Overview
Small hotfix release, fixes problem with default thread config for DefaultShardManager
. This caused requests to fail if a shard is stopped or restarted.
Bug Fixes
- Fix automatic shutdown for elastic pool by @MinnDevelopment in #2704
Full Changelog: v5.0.0...v5.0.1
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.0.1")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.0.1</version>
</dependency>
v5.0.0 | End of beta phase
The Long Awaited Stabilization
After almost 3 years of refactoring and polishing, the stabilization of JDA 5.0.0 is here. If you have been following along, not much has changed since the latest beta release.
If you have somehow avoided updating to a beta release since 2021, here is a list of the most noteworthy additions, changes, and bug fixes since 4.4.0.
You can also use our Migration Guide to help you update to the latest version of JDA 5. This guide also includes the most important changes you need to consider.
Interactions / Application Features
Discord has further improved the capabilities of applications with new types of interactions. This major release of JDA adds support for these features, coming with some restructuring to properly accomodate the new types.
We've renamed interaction events to a more consistent naming scheme:
SlashCommandEvent
becomesSlashCommandInteractionEvent
ButtonClickEvent
becomesButtonInteractionEvent
Similarly, we've renamed component types slightly:
SelectionMenu
is nowStringSelectMenu
, while adding a newEntitySelectMenu
- What was previously called
Component
has now been renamed toActionComponent
andItemComponent
, allowing us to introduceComponent
as an abstraction over bothButton
andActionRow
(which is now aLayoutComponent
). The newComponent
interface is now an abstraction over bothItemComponent
andLayoutComponent
.
To learn more about interactions in JDA 5, take a look at our Interactions Wiki Guide.
Channel Type Rework
We've refactored the channel types and usages in JDA to be more maintainable. Each type of channel now directly maps to a specific channel interface, unlike before where VoiceChannel
was used for both stage and voice type channels.
Instead there are now concrete interfaces for each type, such as NewsChannel
, StageChannel
, ForumChannel
, etc.
The channel type hierarchy has been further refined, by introducing higher level abstractions to represent the features of multiple channel types:
As well as more specific features or attributes of channels:
To properly maintain these many different channel types and make them easy to use, we've also introduced new union types to encompass multiple channels into a simple common union type. This replaces the old getTextChannel()
/getVoiceChannel()
getters on events with getChannel().asTextChannel()
. However, you can also use the standard features of the unions directly. For instance, a MessageChannelUnion
allows to send messages and these specialization methods:
MessageChannelUnion channel = event.getChannel();
channel.sendMessage("hello").queue();
if (channel.getType() == TEXT) {
channel.asTextChannel().getManager().setTopic("test topic").queue();
}
Cache access has also seen some improvement, by introducing a new getChannelById(Class, long)
method, allowing to just get a MessageChannel
without worrying about the concrete type.
GuildMessageChannel channel = guild.getChannelById(GuildMessageChannel.class, 125227483518861312L);
channel.sendMessage("Hello general chat!").queue();
Learn more about the channel rework in Channel Rework.
Message Features
We've refactored our message sending interfaces to be more consistent, by abstracting MessageAction
, MessageBuilder
, and ReplyAction
into shared interfaces MessageCreateRequest
and MessageEditRequest
. This makes all message sending code consistent. We recommend to simply chain your builder-like code directly on send messages:
channel.sendMessage("Hello World")
.setComponents(ActionRow.of(button1, button2))
.setEmbeds(embed1, embed2)
.setFiles(files)
.queue();
However, if you need to use builders, we've introduced MessageEditBuilder and MessageCreateBuilder to replace the old MessageBuilder
utility. You can also now use SplitUtil
to easily divide message content into multiple messages.
To support file descriptions and reduce the number of sendFile overloads, we've also introduced a new FileUpload
type that unifies all attachments into a single type.
FileUpload file = FileUpload.fromData(new File("myFile.png"), "image.png")
.setDescription("this is my alt text for screenreaders, allowing to make accessible images in your messages!");
channel.sendFiles(file).queue();
Learn more about the changes to message sending in Message Send/Edit Rework.
Emojis and Stickers
In JDA 5, we have decided to unify all emoji types into a consistent type structure:
Emoji
, a top-level interface representing all emoji as well as a type discriminator withEmoji#getType
UnicodeEmoji
, standard unicode emoji such as 🤔CustomEmoji
, custom emoji found in messages, like<:minn:245267426227388416>
RichCustomEmoji
, emoji with more information such as owner, accessible through the guild settings.EmojiUnion
, adding type casting for things likeMessageReaction#getEmoji
These new emoji types replace the duplication of ReactionEmote
and Activity.Emoji
.
Stickers have also been refactored in a similar way, making a clear distinction between stickers found in messages and guild settings:
Sticker
, a top-level abstraction of all sticker typesStickerItem
, stickers found in messagesRichSticker
, stickers with more information that is usually omitted for messages (sticker items)StandardSticker
, rich stickers provided by nitro instead of guildsGuildSticker
, rich stickers provided in guildsStickerUnion
, adding type casting
Learn more about the changes to emojis and stickers in Sticker and Emoji Rework.
Installation
All future JDA releases will be distributed through maven central. You no longer need to use jcenter()
in your dependency manager.
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.0.0")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.0.0</version>
</dependency>
Changelog (5.0.0-beta.24 -> 5.0.0)
The changes since the latest beta release to this release.
- Allow UserSnowflake subtypes in bulk ban methods by @freya022 (#2689)
- Update MessageType enum by @MinnDevelopment (#2691)
- Improve Unknown Interactio...
v5.0.0-beta.24 | Bug fixes and entitlement types
Overview
This is a small bugfix release, including some missing features for premium app entitlements.
Additional Entitlement Features (#2667)
This release adds support for test entitlements and consumed entitlements.
An entitlement can be consumed, marking it as already used. This can be useful for one-time entitlements, which are consumed on use.
public boolean hasEntitlement(long skuId, List<Entitlement> entitlements) {
return entitlements.stream().anyMatch(e -> e.getSkuIdLong() == skuId && !e.isConsumed());
}
public void consumeEntitlement(long skuId, List<Entitlement> entitlements) {
entitlements.stream()
.filter(e -> e.getSkuIdLong() == skuId && !e.isConsumed())
.findFirst()
.ifPresent(entitlement -> entitlement.consume().queue());
}
New Features
- Add
IPostContainerManager#setTopic
by @freya022 in #2666 - Add missing features relating to premium app subscriptions by @Tobias123567 in #2667
Changes
- Improve logging for gateway connection by @MinnDevelopment in #2665
- Add more static analyzer annotations by @MinnDevelopment in #2675
- Update SLF4J api and jackson by @MinnDevelopment in #2674
Bug Fixes
- Fix ClassCastException in EntityBuilder#updateMemberCache by @Xirado in #2660
- Properly copy poll data in MessageCreateRequest#applyData by @MinnDevelopment in #2662
- Make channel access checks consistent by @MinnDevelopment in #2679
Full Changelog: v5.0.0-beta.23...v5.0.0-beta.24
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.0.0-beta.24")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.0.0-beta.24</version>
</dependency>
v5.0.0-beta.23 | Message Polls
Overview
This release includes an updated README, please let us know if you spot any issues with it!
Polls (#2649)
Discord has recently released a new feature on their platform to start and vote in polls. These polls can now be sent in messages:
channel.sendMessage("Hello guys! Check my poll:")
.setPoll(
MessagePollData.builder("Which programming language is better?")
.addAnswer("Java", Emoji.fromFormatted("<:java:1006323566314274856>"))
.addAnswer("Kotlin", Emoji.fromFormatted("<:kotlin:295940257797636096>"))
.build())
.queue()
The poll automatically expires after a set duration, configurable in the MessagePollBuilder
using setDuration. A poll can also be ended manually using endPoll or endPollById.
You can check the poll votes on a message using the new Message#getPoll
:
MessagePoll poll = message.getPoll();
for (MessagePoll.Answer answer : poll.getAnswers()) {
System.out.printf("Poll Answer %s has %d votes\n", answer.getText(), answer.getVotes());
}
Note
The votes for polls are eventually consistent and need to be recounted after the poll ends. You can check whether the votes are validated using MessagePoll#isFinalizedVotes.
New Features
- Add USER_MUST_BE_VERIFIED ErrorResponse by @GitMilchi in #2651
- Update permission enum by @MinnDevelopment in #2654
- Poll support by @MinnDevelopment in #2649
Changes
- Update dependencies and use version catalog by @MinnDevelopment in #2652
Bugs Fixes
Full Changelog: v5.0.0-beta.22...v5.0.0-beta.23
Installation
Gradle
repositories {
mavenCentral()
}
dependencies {
implementation("net.dv8tion:JDA:5.0.0-beta.23")
}
Maven
<dependency>
<groupId>net.dv8tion</groupId>
<artifactId>JDA</artifactId>
<version>5.0.0-beta.23</version>
</dependency>