Merge remote-tracking branch 'origin/discord' into Misc
This commit is contained in:
8
src/com/redstoner/modules/discord/Discord.cmd
Normal file
8
src/com/redstoner/modules/discord/Discord.cmd
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
command discord {
|
||||||
|
[empty] {
|
||||||
|
perm utils.external.discord
|
||||||
|
help Info, Register Instructions, and Token for the Discord;
|
||||||
|
run discord;
|
||||||
|
type player;
|
||||||
|
}
|
||||||
|
}
|
||||||
118
src/com/redstoner/modules/discord/Discord.java
Normal file
118
src/com/redstoner/modules/discord/Discord.java
Normal file
@@ -0,0 +1,118 @@
|
|||||||
|
package com.redstoner.modules.discord;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.security.SecureRandom;
|
||||||
|
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.json.simple.JSONObject;
|
||||||
|
|
||||||
|
import net.nemez.chatapi.click.Message;
|
||||||
|
|
||||||
|
import com.nemez.cmdmgr.Command;
|
||||||
|
import com.redstoner.annotations.Commands;
|
||||||
|
import com.redstoner.annotations.Version;
|
||||||
|
import com.redstoner.misc.CommandHolderType;
|
||||||
|
import com.redstoner.modules.Module;
|
||||||
|
import com.redstoner.misc.JsonManager;
|
||||||
|
import com.redstoner.misc.Main;
|
||||||
|
|
||||||
|
@Commands(CommandHolderType.File)
|
||||||
|
@Version(major = 4, minor = 0, revision = 0, compatible = 4)
|
||||||
|
public class Discord implements Module {
|
||||||
|
|
||||||
|
private final String FILENAME = "discordTokens.json";
|
||||||
|
private final String DNE_LINK = "dne://";
|
||||||
|
|
||||||
|
private JSONObject discordTables;
|
||||||
|
private JSONObject byToken;
|
||||||
|
private JSONObject byUUID;
|
||||||
|
|
||||||
|
private String joinLink;
|
||||||
|
private File savefile;
|
||||||
|
|
||||||
|
private final String tokenCharacters = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
|
||||||
|
private SecureRandom rnd = new SecureRandom();
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
@Override
|
||||||
|
public boolean onEnable() {
|
||||||
|
savefile = new File(Main.plugin.getDataFolder(), FILENAME);
|
||||||
|
|
||||||
|
discordTables = JsonManager.getObject(savefile);
|
||||||
|
|
||||||
|
if (discordTables == null) {
|
||||||
|
discordTables = new JSONObject();
|
||||||
|
discordTables.put("joinLink", DNE_LINK);
|
||||||
|
save();
|
||||||
|
}
|
||||||
|
|
||||||
|
Object joinLinkObject = discordTables.get("joinLink");
|
||||||
|
|
||||||
|
if (joinLinkObject == null || ((String) joinLinkObject).equals(DNE_LINK)) {
|
||||||
|
getLogger().error("Missing Join Link. Set: \"joinLink\" to \"_joinLink_\" in the discordTokens.json file.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
joinLink = (String) joinLinkObject;
|
||||||
|
|
||||||
|
Object byTokenObject = discordTables.get("byToken");
|
||||||
|
|
||||||
|
if (byTokenObject == null) {
|
||||||
|
discordTables.put("byToken", new JSONObject());
|
||||||
|
discordTables.put("byUUID", new JSONObject());
|
||||||
|
}
|
||||||
|
|
||||||
|
byToken = (JSONObject) discordTables.get("byToken");
|
||||||
|
byUUID = (JSONObject) discordTables.get("byUUID");
|
||||||
|
|
||||||
|
return true;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
@Command(hook = "discord")
|
||||||
|
public void discord(CommandSender sender) {
|
||||||
|
Player p = (Player) sender;
|
||||||
|
String pUUID = p.getUniqueId().toString();
|
||||||
|
|
||||||
|
Object tokenObject = byUUID.get(pUUID);
|
||||||
|
String token = tokenObject == null? null : (String) tokenObject;
|
||||||
|
|
||||||
|
if (token == null) {
|
||||||
|
|
||||||
|
token = randomToken(8);
|
||||||
|
Object UUIDObject = byToken.get(token);
|
||||||
|
|
||||||
|
while (UUIDObject != null) {
|
||||||
|
token = randomToken(8);
|
||||||
|
UUIDObject = byToken.get(token);
|
||||||
|
}
|
||||||
|
byUUID.put(pUUID, token);
|
||||||
|
byToken.put(token, pUUID);
|
||||||
|
save();
|
||||||
|
}
|
||||||
|
|
||||||
|
new Message(sender, null).appendText("\n&cRedstoner&7 has a &2Discord&7 Now! \nClick ")
|
||||||
|
.appendLinkHover("&e" + joinLink, joinLink, "&aClick to Join")
|
||||||
|
.appendText("&7 to join. \n\nTo sync you rank, copy ")
|
||||||
|
.appendSuggestHover("&e" + token, token, "&aClick to Copy")
|
||||||
|
.appendText("&7 into &3#rank-sync&7.\n")
|
||||||
|
.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
private String randomToken(int length){
|
||||||
|
StringBuilder sb = new StringBuilder( length );
|
||||||
|
for( int i = 0; i < length; i++ )
|
||||||
|
sb.append( tokenCharacters.charAt( rnd.nextInt(tokenCharacters.length()) ) );
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
private void save() {
|
||||||
|
|
||||||
|
discordTables.put("byToken", byToken);
|
||||||
|
discordTables.put("byUUID", byUUID);
|
||||||
|
JsonManager.save(discordTables, savefile);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user