mirror of
https://github.com/DiscordSRV/Ascension.git
synced 2025-01-18 21:01:46 +01:00
Initial for ban sync
This commit is contained in:
parent
50445503ed
commit
0a61eac1ee
@ -1,5 +1,6 @@
|
|||||||
package com.discordsrv.api.module.type;
|
package com.discordsrv.api.module.type;
|
||||||
|
|
||||||
|
import com.discordsrv.api.module.Module;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
@ -7,18 +8,16 @@ import java.time.Instant;
|
|||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
public interface PunishmentModule {
|
public interface PunishmentModule extends Module {
|
||||||
|
|
||||||
interface Bans extends PunishmentModule {
|
interface Bans extends PunishmentModule {
|
||||||
@Nullable
|
CompletableFuture<@Nullable Punishment> getBan(@NotNull UUID playerUUID);
|
||||||
CompletableFuture<Punishment> getBan(@NotNull UUID playerUUID);
|
|
||||||
CompletableFuture<Void> addBan(@NotNull UUID playerUUID, @Nullable Instant until, @Nullable String reason, @NotNull String punisher);
|
CompletableFuture<Void> addBan(@NotNull UUID playerUUID, @Nullable Instant until, @Nullable String reason, @NotNull String punisher);
|
||||||
CompletableFuture<Void> removeBan(@NotNull UUID playerUUID);
|
CompletableFuture<Void> removeBan(@NotNull UUID playerUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Mutes extends PunishmentModule {
|
interface Mutes extends PunishmentModule {
|
||||||
@Nullable
|
CompletableFuture<@Nullable Punishment> getMute(@NotNull UUID playerUUID);
|
||||||
CompletableFuture<Punishment> getMute(@NotNull UUID playerUUID);
|
|
||||||
CompletableFuture<Void> addMute(@NotNull UUID playerUUID, @Nullable Instant until, @Nullable String reason, @NotNull String punisher);
|
CompletableFuture<Void> addMute(@NotNull UUID playerUUID, @Nullable Instant until, @Nullable String reason, @NotNull String punisher);
|
||||||
CompletableFuture<Void> removeMute(@NotNull UUID playerUUID);
|
CompletableFuture<Void> removeMute(@NotNull UUID playerUUID);
|
||||||
}
|
}
|
||||||
|
@ -2,10 +2,15 @@ package com.discordsrv.bukkit.ban;
|
|||||||
|
|
||||||
import com.discordsrv.api.module.type.PunishmentModule;
|
import com.discordsrv.api.module.type.PunishmentModule;
|
||||||
import com.discordsrv.bukkit.BukkitDiscordSRV;
|
import com.discordsrv.bukkit.BukkitDiscordSRV;
|
||||||
import com.discordsrv.common.logging.NamedLogger;
|
import com.discordsrv.common.bansync.BanSyncModule;
|
||||||
import com.discordsrv.common.module.type.AbstractModule;
|
import com.discordsrv.common.module.type.AbstractModule;
|
||||||
import org.bukkit.BanEntry;
|
import org.bukkit.BanEntry;
|
||||||
import org.bukkit.BanList;
|
import org.bukkit.BanList;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.EventPriority;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.PlayerKickEvent;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
@ -14,10 +19,24 @@ import java.util.Date;
|
|||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
public class BukkitBanModule extends AbstractModule<BukkitDiscordSRV> implements PunishmentModule.Bans {
|
public class BukkitBanModule extends AbstractModule<BukkitDiscordSRV> implements Listener, PunishmentModule.Bans {
|
||||||
|
|
||||||
public BukkitBanModule(BukkitDiscordSRV discordSRV) {
|
public BukkitBanModule(BukkitDiscordSRV discordSRV) {
|
||||||
super(discordSRV, new NamedLogger(discordSRV, "BUKKIT_BAN"));
|
super(discordSRV);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
||||||
|
public void onPlayerKick(PlayerKickEvent event) {
|
||||||
|
Player player = event.getPlayer();
|
||||||
|
if (!player.isBanned()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
BanSyncModule module = discordSRV.getModule(BanSyncModule.class);
|
||||||
|
if (module != null) {
|
||||||
|
getBan(player.getUniqueId()).thenApply(Punishment::reason)
|
||||||
|
.whenComplete((reason, t) -> module.notifyBanned(discordSRV.playerProvider().player(player), reason));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -0,0 +1,162 @@
|
|||||||
|
package com.discordsrv.common.bansync;
|
||||||
|
|
||||||
|
import com.discordsrv.api.event.bus.Subscribe;
|
||||||
|
import com.discordsrv.api.event.events.linking.AccountLinkedEvent;
|
||||||
|
import com.discordsrv.api.event.events.linking.AccountUnlinkedEvent;
|
||||||
|
import com.discordsrv.api.module.type.PunishmentModule;
|
||||||
|
import com.discordsrv.common.DiscordSRV;
|
||||||
|
import com.discordsrv.common.bansync.enums.BanSyncResult;
|
||||||
|
import com.discordsrv.common.event.events.player.PlayerConnectedEvent;
|
||||||
|
import com.discordsrv.common.module.type.AbstractModule;
|
||||||
|
import com.discordsrv.common.player.IPlayer;
|
||||||
|
import com.discordsrv.common.profile.Profile;
|
||||||
|
import net.dv8tion.jda.api.JDA;
|
||||||
|
import net.dv8tion.jda.api.entities.Guild;
|
||||||
|
import net.dv8tion.jda.api.entities.UserSnowflake;
|
||||||
|
import net.dv8tion.jda.api.events.guild.GuildBanEvent;
|
||||||
|
import net.dv8tion.jda.api.events.guild.GuildUnbanEvent;
|
||||||
|
import net.dv8tion.jda.api.exceptions.ErrorResponseException;
|
||||||
|
import net.dv8tion.jda.api.requests.ErrorResponse;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
public class BanSyncModule extends AbstractModule<DiscordSRV> {
|
||||||
|
|
||||||
|
public BanSyncModule(DiscordSRV discordSRV) {
|
||||||
|
super(discordSRV);
|
||||||
|
}
|
||||||
|
|
||||||
|
private CompletableFuture<Long> lookupLinkedAccount(UUID player) {
|
||||||
|
return discordSRV.profileManager().lookupProfile(player)
|
||||||
|
.thenApply(Profile::userId);
|
||||||
|
}
|
||||||
|
|
||||||
|
private CompletableFuture<UUID> lookupLinkedAccount(long userId) {
|
||||||
|
return discordSRV.profileManager().lookupProfile(userId)
|
||||||
|
.thenApply(Profile::playerUUID);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void notifyBanned(IPlayer player, @Nullable String reason) {
|
||||||
|
playerBanChange(player.uniqueId(), true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onPlayerConnected(PlayerConnectedEvent event) {
|
||||||
|
playerBanChange(event.player().uniqueId(), false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onGuildBan(GuildBanEvent event) {
|
||||||
|
userBanChange(event.getUser().getIdLong(), true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onGuildUnban(GuildUnbanEvent event) {
|
||||||
|
userBanChange(event.getUser().getIdLong(), false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onAccountLinked(AccountLinkedEvent event) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onAccountUnlinked(AccountUnlinkedEvent event) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void playerBanChange(UUID player, boolean newState) {
|
||||||
|
lookupLinkedAccount(player).thenApply(userId -> {
|
||||||
|
if (userId == null) {
|
||||||
|
// Unlinked
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: configurable reason format
|
||||||
|
return changeUserBanState(userId, newState, null);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private CompletableFuture<BanSyncResult> changeUserBanState(long userId, boolean newState, @Nullable String reason) {
|
||||||
|
JDA jda = discordSRV.jda();
|
||||||
|
if (jda == null) {
|
||||||
|
return CompletableFuture.completedFuture(BanSyncResult.NO_DISCORD_CONNECTION);
|
||||||
|
}
|
||||||
|
|
||||||
|
Guild guild = jda.getGuildById(0L); // TODO: config
|
||||||
|
if (guild == null) {
|
||||||
|
// Server doesn't exist
|
||||||
|
return CompletableFuture.completedFuture(BanSyncResult.GUILD_DOESNT_EXIST);
|
||||||
|
}
|
||||||
|
|
||||||
|
UserSnowflake snowflake = UserSnowflake.fromId(userId);
|
||||||
|
return guild.retrieveBan(snowflake).submit().exceptionally(t -> {
|
||||||
|
if (t instanceof ErrorResponseException && ((ErrorResponseException) t).getErrorResponse() == ErrorResponse.UNKNOWN_BAN) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
throw (RuntimeException) t;
|
||||||
|
}).thenCompose(ban -> {
|
||||||
|
if (ban == null) {
|
||||||
|
if (newState) {
|
||||||
|
// TODO: configurable deletion timeframe
|
||||||
|
return guild.ban(snowflake, 0, TimeUnit.MILLISECONDS).reason(reason).submit().thenApply(v -> BanSyncResult.BAN_USER);
|
||||||
|
} else {
|
||||||
|
// Already unbanned
|
||||||
|
return CompletableFuture.completedFuture(BanSyncResult.ALREADY_IN_SYNC);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (newState) {
|
||||||
|
// Already banned
|
||||||
|
return CompletableFuture.completedFuture(BanSyncResult.ALREADY_IN_SYNC);
|
||||||
|
} else {
|
||||||
|
return guild.unban(snowflake).reason(reason).submit().thenApply(v -> BanSyncResult.UNBAN_USER);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void userBanChange(long userId, boolean newState) {
|
||||||
|
lookupLinkedAccount(userId).thenApply(playerUUID -> {
|
||||||
|
if (playerUUID == null) {
|
||||||
|
// Unlinked
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: configurable reason format
|
||||||
|
return changePlayerBanState(playerUUID, newState, null);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private CompletableFuture<BanSyncResult> changePlayerBanState(UUID playerUUID, boolean newState, @Nullable String reason) {
|
||||||
|
PunishmentModule.Bans bans = discordSRV.getModule(PunishmentModule.Bans.class);
|
||||||
|
if (bans == null) {
|
||||||
|
return CompletableFuture.completedFuture(BanSyncResult.NO_PUNISHMENT_INTEGRATION);
|
||||||
|
}
|
||||||
|
|
||||||
|
return bans.getBan(playerUUID)
|
||||||
|
.thenCompose(punishment -> {
|
||||||
|
if (punishment == null) {
|
||||||
|
if (newState) {
|
||||||
|
return bans.addBan(playerUUID, null, reason, "DiscordSRV")
|
||||||
|
.thenApply(v -> BanSyncResult.BAN_PLAYER);
|
||||||
|
} else {
|
||||||
|
// Already unbanned
|
||||||
|
return CompletableFuture.completedFuture(BanSyncResult.ALREADY_IN_SYNC);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (newState) {
|
||||||
|
// Already banned
|
||||||
|
return CompletableFuture.completedFuture(BanSyncResult.ALREADY_IN_SYNC);
|
||||||
|
} else {
|
||||||
|
return bans.removeBan(playerUUID).thenApply(v -> BanSyncResult.UNBAN_PLAYER);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,20 @@
|
|||||||
|
package com.discordsrv.common.bansync.enums;
|
||||||
|
|
||||||
|
public enum BanSyncResult {
|
||||||
|
|
||||||
|
// Success, actioned
|
||||||
|
BAN_USER,
|
||||||
|
BAN_PLAYER,
|
||||||
|
UNBAN_USER,
|
||||||
|
UNBAN_PLAYER,
|
||||||
|
|
||||||
|
// Nothing done
|
||||||
|
ALREADY_IN_SYNC,
|
||||||
|
WRONG_DIRECTION,
|
||||||
|
|
||||||
|
// Error
|
||||||
|
NO_PUNISHMENT_INTEGRATION,
|
||||||
|
NO_DISCORD_CONNECTION,
|
||||||
|
GUILD_DOESNT_EXIST
|
||||||
|
|
||||||
|
}
|
@ -20,8 +20,8 @@ package com.discordsrv.common.config.main;
|
|||||||
|
|
||||||
import com.discordsrv.common.DiscordSRV;
|
import com.discordsrv.common.DiscordSRV;
|
||||||
import com.discordsrv.common.config.configurate.annotation.Constants;
|
import com.discordsrv.common.config.configurate.annotation.Constants;
|
||||||
import com.discordsrv.common.groupsync.enums.GroupSyncDirection;
|
import com.discordsrv.common.sync.enums.SyncDirection;
|
||||||
import com.discordsrv.common.groupsync.enums.GroupSyncSide;
|
import com.discordsrv.common.sync.enums.SyncSide;
|
||||||
import org.spongepowered.configurate.objectmapping.ConfigSerializable;
|
import org.spongepowered.configurate.objectmapping.ConfigSerializable;
|
||||||
import org.spongepowered.configurate.objectmapping.meta.Comment;
|
import org.spongepowered.configurate.objectmapping.meta.Comment;
|
||||||
|
|
||||||
@ -45,7 +45,7 @@ public class GroupSyncConfig {
|
|||||||
@Comment("The direction this group-role pair will synchronize in.\n"
|
@Comment("The direction this group-role pair will synchronize in.\n"
|
||||||
+ "Valid options: %1, %2, %3")
|
+ "Valid options: %1, %2, %3")
|
||||||
@Constants.Comment({"bidirectional", "minecraft_to_discord", "discord_to_minecraft"})
|
@Constants.Comment({"bidirectional", "minecraft_to_discord", "discord_to_minecraft"})
|
||||||
public GroupSyncDirection direction = GroupSyncDirection.BIDIRECTIONAL;
|
public SyncDirection direction = SyncDirection.BIDIRECTIONAL;
|
||||||
|
|
||||||
@Comment("Timed resynchronization.\n"
|
@Comment("Timed resynchronization.\n"
|
||||||
+ "This is required if you're not using LuckPerms and want to use Minecraft to Discord synchronization")
|
+ "This is required if you're not using LuckPerms and want to use Minecraft to Discord synchronization")
|
||||||
@ -64,7 +64,7 @@ public class GroupSyncConfig {
|
|||||||
@Comment("Decides which side takes priority when using timed synchronization or the resync command\n"
|
@Comment("Decides which side takes priority when using timed synchronization or the resync command\n"
|
||||||
+ "Valid options: %1, %2")
|
+ "Valid options: %1, %2")
|
||||||
@Constants.Comment({"minecraft", "discord"})
|
@Constants.Comment({"minecraft", "discord"})
|
||||||
public GroupSyncSide tieBreaker = GroupSyncSide.MINECRAFT;
|
public SyncSide tieBreaker = SyncSide.MINECRAFT;
|
||||||
|
|
||||||
@Comment("The LuckPerms \"%1\" context value, used when adding, removing and checking the groups of players.\n"
|
@Comment("The LuckPerms \"%1\" context value, used when adding, removing and checking the groups of players.\n"
|
||||||
+ "Make this blank (\"\") to use the current server's value, or \"%2\" to not use the context")
|
+ "Make this blank (\"\") to use the current server's value, or \"%2\" to not use the context")
|
||||||
@ -81,17 +81,17 @@ public class GroupSyncConfig {
|
|||||||
if ((invalidTieBreaker = (tieBreaker == null)) || (invalidDirection = (direction == null))) {
|
if ((invalidTieBreaker = (tieBreaker == null)) || (invalidDirection = (direction == null))) {
|
||||||
if (invalidTieBreaker) {
|
if (invalidTieBreaker) {
|
||||||
discordSRV.logger().error(label + " has invalid tie-breaker: " + tieBreaker
|
discordSRV.logger().error(label + " has invalid tie-breaker: " + tieBreaker
|
||||||
+ ", should be one of " + Arrays.toString(GroupSyncSide.values()));
|
+ ", should be one of " + Arrays.toString(SyncSide.values()));
|
||||||
}
|
}
|
||||||
if (invalidDirection) {
|
if (invalidDirection) {
|
||||||
discordSRV.logger().error(label + " has invalid direction: " + direction
|
discordSRV.logger().error(label + " has invalid direction: " + direction
|
||||||
+ ", should be one of " + Arrays.toString(GroupSyncDirection.values()));
|
+ ", should be one of " + Arrays.toString(SyncDirection.values()));
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
} else if (direction != GroupSyncDirection.BIDIRECTIONAL) {
|
} else if (direction != SyncDirection.BIDIRECTIONAL) {
|
||||||
boolean minecraft;
|
boolean minecraft;
|
||||||
if ((direction == GroupSyncDirection.MINECRAFT_TO_DISCORD) != (minecraft = (tieBreaker == GroupSyncSide.MINECRAFT))) {
|
if ((direction == SyncDirection.MINECRAFT_TO_DISCORD) != (minecraft = (tieBreaker == SyncSide.MINECRAFT))) {
|
||||||
GroupSyncSide opposite = (minecraft ? GroupSyncSide.DISCORD : GroupSyncSide.MINECRAFT);
|
SyncSide opposite = (minecraft ? SyncSide.DISCORD : SyncSide.MINECRAFT);
|
||||||
discordSRV.logger().warning(label + " with direction "
|
discordSRV.logger().warning(label + " with direction "
|
||||||
+ direction + " with tie-breaker "
|
+ direction + " with tie-breaker "
|
||||||
+ tieBreaker + " (should be " + opposite + ")");
|
+ tieBreaker + " (should be " + opposite + ")");
|
||||||
@ -103,20 +103,7 @@ public class GroupSyncConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
String arrow;
|
return "PairConfig{" + groupName + direction.arrow() + Long.toUnsignedString(roleId) + '}';
|
||||||
switch (direction) {
|
|
||||||
default:
|
|
||||||
case BIDIRECTIONAL:
|
|
||||||
arrow = "<->";
|
|
||||||
break;
|
|
||||||
case DISCORD_TO_MINECRAFT:
|
|
||||||
arrow = "<-";
|
|
||||||
break;
|
|
||||||
case MINECRAFT_TO_DISCORD:
|
|
||||||
arrow = "->";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return "PairConfig{" + groupName + arrow + roleId + '}';
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,9 +31,9 @@ import com.discordsrv.common.debug.file.TextDebugFile;
|
|||||||
import com.discordsrv.common.event.events.player.PlayerConnectedEvent;
|
import com.discordsrv.common.event.events.player.PlayerConnectedEvent;
|
||||||
import com.discordsrv.common.future.util.CompletableFutureUtil;
|
import com.discordsrv.common.future.util.CompletableFutureUtil;
|
||||||
import com.discordsrv.common.groupsync.enums.GroupSyncCause;
|
import com.discordsrv.common.groupsync.enums.GroupSyncCause;
|
||||||
import com.discordsrv.common.groupsync.enums.GroupSyncDirection;
|
import com.discordsrv.common.sync.enums.SyncDirection;
|
||||||
import com.discordsrv.common.groupsync.enums.GroupSyncResult;
|
import com.discordsrv.common.groupsync.enums.GroupSyncResult;
|
||||||
import com.discordsrv.common.groupsync.enums.GroupSyncSide;
|
import com.discordsrv.common.sync.enums.SyncSide;
|
||||||
import com.discordsrv.common.logging.NamedLogger;
|
import com.discordsrv.common.logging.NamedLogger;
|
||||||
import com.discordsrv.common.module.type.AbstractModule;
|
import com.discordsrv.common.module.type.AbstractModule;
|
||||||
import com.discordsrv.common.player.IPlayer;
|
import com.discordsrv.common.player.IPlayer;
|
||||||
@ -176,7 +176,7 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
Map<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> pairs
|
Map<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> pairs
|
||||||
) {
|
) {
|
||||||
CompletableFutureUtil.combine(pairs.values()).whenComplete((v, t) -> {
|
CompletableFutureUtil.combine(pairs.values()).whenComplete((v, t) -> {
|
||||||
SynchronizationSummary summary = new SynchronizationSummary(player, cause);
|
GroupSyncSummary summary = new GroupSyncSummary(player, cause);
|
||||||
for (Map.Entry<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> entry : pairs.entrySet()) {
|
for (Map.Entry<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> entry : pairs.entrySet()) {
|
||||||
summary.add(entry.getKey(), entry.getValue().join());
|
summary.add(entry.getKey(), entry.getValue().join());
|
||||||
}
|
}
|
||||||
@ -312,7 +312,7 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
resyncPair(pair, uuid, userId).whenComplete((result, t2) -> logger().debug(
|
resyncPair(pair, uuid, userId).whenComplete((result, t2) -> logger().debug(
|
||||||
new SynchronizationSummary(uuid, cause, pair, result).toString()
|
new GroupSyncSummary(uuid, cause, pair, result).toString()
|
||||||
));
|
));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -350,14 +350,14 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GroupSyncSide side = pair.tieBreaker;
|
SyncSide side = pair.tieBreaker;
|
||||||
GroupSyncDirection direction = pair.direction;
|
SyncDirection direction = pair.direction;
|
||||||
CompletableFuture<Void> future;
|
CompletableFuture<Void> future;
|
||||||
GroupSyncResult result;
|
GroupSyncResult result;
|
||||||
if (hasRole) {
|
if (hasRole) {
|
||||||
if (side == GroupSyncSide.DISCORD) {
|
if (side == SyncSide.DISCORD) {
|
||||||
// Has role, add group
|
// Has role, add group
|
||||||
if (direction == GroupSyncDirection.MINECRAFT_TO_DISCORD) {
|
if (direction == SyncDirection.MINECRAFT_TO_DISCORD) {
|
||||||
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -366,7 +366,7 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
future = addGroup(player, groupName, pair.serverContext);
|
future = addGroup(player, groupName, pair.serverContext);
|
||||||
} else {
|
} else {
|
||||||
// Doesn't have group, remove role
|
// Doesn't have group, remove role
|
||||||
if (direction == GroupSyncDirection.DISCORD_TO_MINECRAFT) {
|
if (direction == SyncDirection.DISCORD_TO_MINECRAFT) {
|
||||||
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -375,9 +375,9 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
future = member.removeRole(role);
|
future = member.removeRole(role);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (side == GroupSyncSide.DISCORD) {
|
if (side == SyncSide.DISCORD) {
|
||||||
// Doesn't have role, remove group
|
// Doesn't have role, remove group
|
||||||
if (direction == GroupSyncDirection.MINECRAFT_TO_DISCORD) {
|
if (direction == SyncDirection.MINECRAFT_TO_DISCORD) {
|
||||||
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -386,7 +386,7 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
future = removeGroup(player, groupName, pair.serverContext);
|
future = removeGroup(player, groupName, pair.serverContext);
|
||||||
} else {
|
} else {
|
||||||
// Has group, add role
|
// Has group, add role
|
||||||
if (direction == GroupSyncDirection.DISCORD_TO_MINECRAFT) {
|
if (direction == SyncDirection.DISCORD_TO_MINECRAFT) {
|
||||||
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
resultFuture.complete(GroupSyncResult.WRONG_DIRECTION);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -480,8 +480,8 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
|
|
||||||
Map<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> futures = new LinkedHashMap<>();
|
Map<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> futures = new LinkedHashMap<>();
|
||||||
for (GroupSyncConfig.PairConfig pair : pairs) {
|
for (GroupSyncConfig.PairConfig pair : pairs) {
|
||||||
GroupSyncDirection direction = pair.direction;
|
SyncDirection direction = pair.direction;
|
||||||
if (direction == GroupSyncDirection.MINECRAFT_TO_DISCORD) {
|
if (direction == SyncDirection.MINECRAFT_TO_DISCORD) {
|
||||||
// Not going Discord -> Minecraft
|
// Not going Discord -> Minecraft
|
||||||
futures.put(pair, CompletableFuture.completedFuture(GroupSyncResult.WRONG_DIRECTION));
|
futures.put(pair, CompletableFuture.completedFuture(GroupSyncResult.WRONG_DIRECTION));
|
||||||
continue;
|
continue;
|
||||||
@ -490,7 +490,7 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
futures.put(pair, modifyGroupState(player, pair, remove));
|
futures.put(pair, modifyGroupState(player, pair, remove));
|
||||||
|
|
||||||
// If the sync is bidirectional, also add/remove any other roles that are linked to this group
|
// If the sync is bidirectional, also add/remove any other roles that are linked to this group
|
||||||
if (direction == GroupSyncDirection.DISCORD_TO_MINECRAFT) {
|
if (direction == SyncDirection.DISCORD_TO_MINECRAFT) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -550,8 +550,8 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
PermissionModule.Groups permissionProvider = getPermissionProvider();
|
PermissionModule.Groups permissionProvider = getPermissionProvider();
|
||||||
Map<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> futures = new LinkedHashMap<>();
|
Map<GroupSyncConfig.PairConfig, CompletableFuture<GroupSyncResult>> futures = new LinkedHashMap<>();
|
||||||
for (GroupSyncConfig.PairConfig pair : pairs) {
|
for (GroupSyncConfig.PairConfig pair : pairs) {
|
||||||
GroupSyncDirection direction = pair.direction;
|
SyncDirection direction = pair.direction;
|
||||||
if (direction == GroupSyncDirection.DISCORD_TO_MINECRAFT) {
|
if (direction == SyncDirection.DISCORD_TO_MINECRAFT) {
|
||||||
// Not going Minecraft -> Discord
|
// Not going Minecraft -> Discord
|
||||||
futures.put(pair, CompletableFuture.completedFuture(GroupSyncResult.WRONG_DIRECTION));
|
futures.put(pair, CompletableFuture.completedFuture(GroupSyncResult.WRONG_DIRECTION));
|
||||||
continue;
|
continue;
|
||||||
@ -585,7 +585,7 @@ public class GroupSyncModule extends AbstractModule<DiscordSRV> {
|
|||||||
futures.put(pair, modifyRoleState(userId, pair, remove));
|
futures.put(pair, modifyRoleState(userId, pair, remove));
|
||||||
|
|
||||||
// If the sync is bidirectional, also add/remove any other groups that are linked to this role
|
// If the sync is bidirectional, also add/remove any other groups that are linked to this role
|
||||||
if (direction == GroupSyncDirection.MINECRAFT_TO_DISCORD) {
|
if (direction == SyncDirection.MINECRAFT_TO_DISCORD) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,18 +24,18 @@ import com.discordsrv.common.groupsync.enums.GroupSyncResult;
|
|||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
public class SynchronizationSummary {
|
public class GroupSyncSummary {
|
||||||
|
|
||||||
private final EnumMap<GroupSyncResult, Set<GroupSyncConfig.PairConfig>> pairs = new EnumMap<>(GroupSyncResult.class);
|
private final EnumMap<GroupSyncResult, Set<GroupSyncConfig.PairConfig>> pairs = new EnumMap<>(GroupSyncResult.class);
|
||||||
private final UUID player;
|
private final UUID player;
|
||||||
private final GroupSyncCause cause;
|
private final GroupSyncCause cause;
|
||||||
|
|
||||||
public SynchronizationSummary(UUID player, GroupSyncCause cause, GroupSyncConfig.PairConfig config, GroupSyncResult result) {
|
public GroupSyncSummary(UUID player, GroupSyncCause cause, GroupSyncConfig.PairConfig config, GroupSyncResult result) {
|
||||||
this(player, cause);
|
this(player, cause);
|
||||||
add(config, result);
|
add(config, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
public SynchronizationSummary(UUID player, GroupSyncCause cause) {
|
public GroupSyncSummary(UUID player, GroupSyncCause cause) {
|
||||||
this.player = player;
|
this.player = player;
|
||||||
this.cause = cause;
|
this.cause = cause;
|
||||||
}
|
}
|
@ -16,12 +16,26 @@
|
|||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package com.discordsrv.common.groupsync.enums;
|
package com.discordsrv.common.sync.enums;
|
||||||
|
|
||||||
public enum GroupSyncDirection {
|
public enum SyncDirection {
|
||||||
|
|
||||||
MINECRAFT_TO_DISCORD,
|
MINECRAFT_TO_DISCORD("->"),
|
||||||
DISCORD_TO_MINECRAFT,
|
DISCORD_TO_MINECRAFT("<-"),
|
||||||
BIDIRECTIONAL
|
BIDIRECTIONAL("<->");
|
||||||
|
|
||||||
|
private final String arrow;
|
||||||
|
|
||||||
|
SyncDirection(String arrow) {
|
||||||
|
this.arrow = arrow;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Game on the left, Discord on the right.
|
||||||
|
* @return the arrow
|
||||||
|
*/
|
||||||
|
public String arrow() {
|
||||||
|
return arrow;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -16,9 +16,9 @@
|
|||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package com.discordsrv.common.groupsync.enums;
|
package com.discordsrv.common.sync.enums;
|
||||||
|
|
||||||
public enum GroupSyncSide {
|
public enum SyncSide {
|
||||||
|
|
||||||
MINECRAFT,
|
MINECRAFT,
|
||||||
DISCORD
|
DISCORD
|
Loading…
Reference in New Issue
Block a user