Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add GuildManager#setFeatures #2222

Merged
merged 8 commits into from
Oct 18, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 15 additions & 2 deletions src/main/java/net/dv8tion/jda/api/entities/Guild.java
Original file line number Diff line number Diff line change
Expand Up @@ -544,14 +544,27 @@ default ImageProxy getIcon()

/**
* The Features of the {@link net.dv8tion.jda.api.entities.Guild Guild}.
* <p>
* <a target="_blank" href="https://discord.com/developers/docs/resources/guild#guild-object-guild-features"><b>List of Features</b></a>
*
* <p>Features can be updated using {@link GuildManager#setFeatures(Collection)}.
*
* @return Never-null, unmodifiable Set containing all of the Guild's features.
*
* @see <a target="_blank" href="https://discord.com/developers/docs/resources/guild#guild-object-guild-features">List of Features</a>
*/
@Nonnull
Set<String> getFeatures();

/**
* Whether the invites for this guild are paused/disabled.
* <br>This is equivalent to {@code getFeatures().contains("INVITES_DISABLED")}.
*
* @return True, if invites are paused/disabled
*/
default boolean isInvitesDisabled()
{
return getFeatures().contains("INVITES_DISABLED");
}

/**
* The Discord hash-id of the splash image for this Guild. A Splash image is an image displayed when viewing a
* Discord Guild Invite on the web or in client just before accepting or declining the invite.
Expand Down
125 changes: 125 additions & 0 deletions src/main/java/net/dv8tion/jda/api/managers/GuildManager.java
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,13 @@
import net.dv8tion.jda.api.entities.Icon;
import net.dv8tion.jda.api.entities.channel.concrete.TextChannel;
import net.dv8tion.jda.api.entities.channel.concrete.VoiceChannel;
import net.dv8tion.jda.internal.utils.Checks;

import javax.annotation.CheckReturnValue;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.Arrays;
import java.util.Collection;

/**
* Manager providing functionality to update one or more fields for a {@link net.dv8tion.jda.api.entities.Guild Guild}.
Expand Down Expand Up @@ -73,6 +76,8 @@ public interface GuildManager extends Manager<GuildManager>
long COMMUNITY_UPDATES_CHANNEL = 1 << 13;
/** Used to reset the premium progress bar enabled field */
long BOOST_PROGRESS_BAR_ENABLED = 1 << 14;
/** Used to add or remove modifiable features (such as {@code "INVITES_DISABLED"}) */
long FEATURES = 1 << 15;

/**
* Resets the fields specified by the provided bit-flag pattern.
Expand All @@ -94,6 +99,7 @@ public interface GuildManager extends Manager<GuildManager>
* <li>{@link #EXPLICIT_CONTENT_LEVEL}</li>
* <li>{@link #VERIFICATION_LEVEL}</li>
* <li>{@link #BOOST_PROGRESS_BAR_ENABLED}</li>
* <li>{@link #FEATURES}</li>
* </ul>
*
* @param fields
Expand Down Expand Up @@ -125,6 +131,7 @@ public interface GuildManager extends Manager<GuildManager>
* <li>{@link #EXPLICIT_CONTENT_LEVEL}</li>
* <li>{@link #VERIFICATION_LEVEL}</li>
* <li>{@link #BOOST_PROGRESS_BAR_ENABLED}</li>
* <li>{@link #FEATURES}</li>
* </ul>
*
* @param fields
Expand Down Expand Up @@ -372,4 +379,122 @@ public interface GuildManager extends Manager<GuildManager>
@Nonnull
@CheckReturnValue
GuildManager setBoostProgressBarEnabled(boolean boostProgressBarEnabled);

/**
* Configures the new {@link Guild#getFeatures() features} of the {@link Guild}.
* <br>The list of available features, including which ones can be configured, is available in the
* <a href="https://discord.com/developers/docs/resources/guild#guild-object-guild-features" target="_blank">Official Discord API Documentation</a>.
*
* <p><b>Example</b>
* <pre>{@code
* List<String> features = new ArrayList<>(guild.getFeatures());
* features.add("INVITES_DISABLED");
* guild.getManager().setFeatures(features).queue();
* }</pre>
*
* @param features
* The new features to use
*
* @throws IllegalArgumentException
* If the provided list is null
*
* @return GuildManager for chaining convenience
*/
@Nonnull
@CheckReturnValue
GuildManager setFeatures(@Nonnull Collection<String> features);

/**
* Adds a {@link Guild#getFeatures() Guild Feature} to the list of features.
* <br>The list of available features, including which ones can be configured, is available in the
* <a href="https://discord.com/developers/docs/resources/guild#guild-object-guild-features" target="_blank">Official Discord API Documentation</a>.
*
* @param features
* The features to add
*
* @throws IllegalArgumentException
* If any of the provided features is null
*
* @return GuildManager for chaining convenience
*/
@Nonnull
@CheckReturnValue
GuildManager addFeatures(@Nonnull Collection<String> features);

/**
* Adds a {@link Guild#getFeatures() Guild Feature} to the list of features.
* <br>The list of available features, including which ones can be configured, is available in the
* <a href="https://discord.com/developers/docs/resources/guild#guild-object-guild-features" target="_blank">Official Discord API Documentation</a>.
*
* @param features
* The features to add
*
* @throws IllegalArgumentException
* If any of the provided features is null
*
* @return GuildManager for chaining convenience
*/
@Nonnull
@CheckReturnValue
default GuildManager addFeatures(@Nonnull String... features)
{
Checks.noneNull(features, "Features");
return addFeatures(Arrays.asList(features));
}

/**
* Removes a {@link Guild#getFeatures() Guild Feature} from the list of features.
* <br>The list of available features, including which ones can be configured, is available in the
* <a href="https://discord.com/developers/docs/resources/guild#guild-object-guild-features" target="_blank">Official Discord API Documentation</a>.
*
* @param features
* The features to remove
*
* @throws IllegalArgumentException
* If any of the provided features is null
*
* @return GuildManager for chaining convenience
*/
@Nonnull
@CheckReturnValue
GuildManager removeFeatures(@Nonnull Collection<String> features);

/**
* Removes a {@link Guild#getFeatures() Guild Feature} from the list of features.
* <br>The list of available features, including which ones can be configured, is available in the
* <a href="https://discord.com/developers/docs/resources/guild#guild-object-guild-features" target="_blank">Official Discord API Documentation</a>.
*
* @param features
* The features to remove
*
* @throws IllegalArgumentException
* If any of the provided features is null
*
* @return GuildManager for chaining convenience
*/
@Nonnull
@CheckReturnValue
default GuildManager removeFeatures(@Nonnull String... features)
{
Checks.noneNull(features, "Features");
return removeFeatures(Arrays.asList(features));
}

/**
* Configures the {@code INVITES_DISABLED} feature flag of this guild.
* <br>This is equivalent to adding or removing the feature {@code INVITES_DISABLED} via {@link #setFeatures(Collection)}.
*
* @param disabled
* True, to pause/disable all invites to the guild
*
* @return GuildManager for chaining convenience
*/
@Nonnull
@CheckReturnValue
default GuildManager setInvitesDisabled(boolean disabled)
{
if (disabled)
return addFeatures("INVITES_DISABLED");
return removeFeatures("INVITES_DISABLED");
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@

package net.dv8tion.jda.internal.managers;

import net.dv8tion.jda.api.JDA;
import net.dv8tion.jda.api.Permission;
import net.dv8tion.jda.api.entities.Guild;
import net.dv8tion.jda.api.entities.Icon;
Expand All @@ -32,6 +31,11 @@
import javax.annotation.CheckReturnValue;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.Collection;
import java.util.HashSet;
import java.util.Set;
import java.util.function.Consumer;
import java.util.stream.Collectors;

public class GuildManagerImpl extends ManagerBase<GuildManager> implements GuildManager
{
Expand All @@ -47,11 +51,11 @@ public class GuildManagerImpl extends ManagerBase<GuildManager> implements Guild
protected int explicitContentLevel;
protected int verificationLevel;
protected boolean boostProgressBarEnabled;
protected Set<String> features;

public GuildManagerImpl(Guild guild)
{
super(guild.getJDA(), Route.Guilds.MODIFY_GUILD.compile(guild.getId()));
JDA api = guild.getJDA();
this.guild = guild;
if (isPermissionChecksEnabled())
checkPermissions();
Expand Down Expand Up @@ -91,6 +95,8 @@ public GuildManagerImpl reset(long fields)
this.description = null;
if ((fields & BANNER) == BANNER)
this.banner = null;
if ((fields & FEATURES) == FEATURES)
this.features = null;
return this;
}

Expand All @@ -116,6 +122,7 @@ public GuildManagerImpl reset()
this.banner = null;
this.afkChannel = null;
this.systemChannel = null;
this.features = null;
return this;
}

Expand Down Expand Up @@ -284,6 +291,44 @@ public GuildManager setBoostProgressBarEnabled(boolean enabled)
return this;
}

@Nonnull
@Override
public GuildManager setFeatures(@Nonnull Collection<String> features)
{
Checks.noneNull(features, "Features");
this.features = features.stream()
.map(String::toUpperCase)
.collect(Collectors.toSet());
set |= FEATURES;
return this;
}

@Nonnull
@Override
public GuildManager addFeatures(@Nonnull Collection<String> features)
{
return updateFeatures(features, this.features::add);
}

@Nonnull
@Override
public GuildManager removeFeatures(@Nonnull Collection<String> features)
{
return updateFeatures(features, this.features::remove);
}

private GuildManager updateFeatures(Collection<String> changed, Consumer<String> op)
{
Checks.noneNull(changed, "Features");
if (this.features == null)
this.features = new HashSet<>(getGuild().getFeatures());
changed.stream()
.map(String::toUpperCase)
.forEach(op);
set |= FEATURES;
return this;
}

@Override
protected RequestBody finalizeData()
{
Expand Down Expand Up @@ -318,6 +363,8 @@ protected RequestBody finalizeData()
body.put("description", description);
if (shouldUpdate(BOOST_PROGRESS_BAR_ENABLED))
body.put("premium_progress_bar_enabled", boostProgressBarEnabled);
if (shouldUpdate(FEATURES))
body.put("features", features);

reset(); //now that we've built our JSON object, reset the manager back to the non-modified state
return getRequestBody(body);
Expand Down