mirror of
https://github.com/AtlasMediaGroup/TotalFreedomMod.git
synced 2024-11-17 04:46:11 +00:00
97 lines
4.7 KiB
Java
97 lines
4.7 KiB
Java
|
package me.totalfreedom.totalfreedommod.command;
|
||
|
|
||
|
import me.totalfreedom.totalfreedommod.playerverification.VPlayer;
|
||
|
import me.totalfreedom.totalfreedommod.rank.Rank;
|
||
|
import net.pravian.aero.util.Ips;
|
||
|
import org.bukkit.ChatColor;
|
||
|
import org.bukkit.command.Command;
|
||
|
import org.bukkit.command.CommandSender;
|
||
|
import org.bukkit.entity.Player;
|
||
|
|
||
|
@CommandPermissions(level = Rank.OP, source = SourceType.ONLY_IN_GAME)
|
||
|
@CommandParameters(description = "Manage your verification", usage = "/<command> <enable | disable | clearips | status> <discord | forum>", aliases = "playerverification, opverification, opverify, opv")
|
||
|
public class Command_playerverify extends FreedomCommand {
|
||
|
@Override
|
||
|
protected boolean run(CommandSender sender, Player playerSender, Command cmd, String commandLabel, String[] args, boolean senderIsConsole) {
|
||
|
if (args.length < 2) {
|
||
|
return false;
|
||
|
}
|
||
|
if (plugin.al.isAdmin(sender)) {
|
||
|
msg("This command is only for OP's.", ChatColor.RED);
|
||
|
return true;
|
||
|
}
|
||
|
switch (args[0].toLowerCase()) {
|
||
|
case "enable":
|
||
|
switch (args[1].toLowerCase()) {
|
||
|
case "discord":
|
||
|
if (!plugin.dc.enabled) {
|
||
|
msg("The discord verification system is currently disabled.", ChatColor.RED);
|
||
|
return true;
|
||
|
}
|
||
|
VPlayer data = plugin.pv.getVerificationPlayer(playerSender);
|
||
|
if (data.isDiscordVerificationEnabled()) {
|
||
|
msg("Discord verification is already enabled for you.", ChatColor.RED);
|
||
|
return true;
|
||
|
}
|
||
|
data.setDiscordVerificationEnabled(true);
|
||
|
plugin.pv.saveVerificationData(data);
|
||
|
msg("Enabled discord verification. Please type /linkdiscord to link a discord account.", ChatColor.AQUA);
|
||
|
return true;
|
||
|
case "forum":
|
||
|
msg("TODO. This will be enabled in a later update. Please use discord verification instead.");
|
||
|
return true;
|
||
|
default:
|
||
|
return false;
|
||
|
}
|
||
|
case "disable":
|
||
|
switch (args[1].toLowerCase()) {
|
||
|
case "discord":
|
||
|
VPlayer data = plugin.pv.getVerificationPlayer(playerSender);
|
||
|
if (!data.isDiscordVerificationEnabled()) {
|
||
|
msg("Discord verification is already disabled for you.", ChatColor.RED);
|
||
|
return true;
|
||
|
}
|
||
|
data.setDiscordVerificationEnabled(false);
|
||
|
plugin.pv.saveVerificationData(data);
|
||
|
msg("Disabled discord verification.", ChatColor.AQUA);
|
||
|
return true;
|
||
|
case "forum":
|
||
|
msg("TODO. Forum verification will be enabled in a later update.");
|
||
|
return true;
|
||
|
default:
|
||
|
return false;
|
||
|
}
|
||
|
case "status":
|
||
|
switch (args[1].toLowerCase()) {
|
||
|
case "discord":
|
||
|
VPlayer data = plugin.pv.getVerificationPlayer(playerSender);
|
||
|
boolean enabled = data.isDiscordVerificationEnabled();
|
||
|
boolean specified = data.getDiscordID() != null;
|
||
|
msg(ChatColor.GRAY + "Discord Verification Enabled: " + (enabled ? ChatColor.AQUA + "true" : ChatColor.RED + "false"));
|
||
|
msg(ChatColor.GRAY + "Discord ID: " + (specified ? ChatColor.AQUA + data.getDiscordID() : ChatColor.RED + "not set"));
|
||
|
return true;
|
||
|
case "forum":
|
||
|
msg("TODO. Forum verification will be enabled in a later update.");
|
||
|
return true;
|
||
|
default:
|
||
|
return false;
|
||
|
}
|
||
|
case "clearips":
|
||
|
VPlayer data = plugin.pv.getVerificationPlayer(playerSender);
|
||
|
int cleared = 0;
|
||
|
for (String ip : data.getIPs()) {
|
||
|
if (!ip.equals(Ips.getIp(playerSender))) {
|
||
|
data.removeIp(ip);
|
||
|
cleared++;
|
||
|
}
|
||
|
}
|
||
|
msg("Cleared all IP's except your current IP \"" + Ips.getIp(playerSender) + "\"");
|
||
|
msg("Cleared " + cleared + " IP's.");
|
||
|
plugin.pv.saveVerificationData(data);
|
||
|
return true;
|
||
|
default:
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
}
|