Added flair in tablist and done /unlol
- Added flair in tablist (idea taken from my command block version) - Done /unlol
This commit is contained in:
parent
41618831dc
commit
afb35c06eb
513 changed files with 114068 additions and 37 deletions
14220
.metadata/.bak_0.log
Normal file
14220
.metadata/.bak_0.log
Normal file
File diff suppressed because it is too large
Load diff
0
.metadata/.lock
Normal file
0
.metadata/.lock
Normal file
1134
.metadata/.log
Normal file
1134
.metadata/.log
Normal file
File diff suppressed because it is too large
Load diff
BIN
.metadata/.mylyn/.taskListIndex/segments.gen
Normal file
BIN
.metadata/.mylyn/.taskListIndex/segments.gen
Normal file
Binary file not shown.
BIN
.metadata/.mylyn/.taskListIndex/segments_1
Normal file
BIN
.metadata/.mylyn/.taskListIndex/segments_1
Normal file
Binary file not shown.
BIN
.metadata/.mylyn/.tasks.xml.zip
Normal file
BIN
.metadata/.mylyn/.tasks.xml.zip
Normal file
Binary file not shown.
BIN
.metadata/.mylyn/repositories.xml.zip
Normal file
BIN
.metadata/.mylyn/repositories.xml.zip
Normal file
Binary file not shown.
BIN
.metadata/.mylyn/tasks.xml.zip
Normal file
BIN
.metadata/.mylyn/tasks.xml.zip
Normal file
Binary file not shown.
|
@ -0,0 +1,374 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading..."); //2015.08.09.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear(); //2015.08.09.
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,116 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color) {
|
||||||
|
FlairColor = color;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time) {
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time) {
|
||||||
|
FlairColor = color;
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2() {
|
||||||
|
|
||||||
|
// Flairs from Command Block The Button - Teams
|
||||||
|
// PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
Player p=Bukkit.getPlayer(UUID);
|
||||||
|
p.setPlayerListName(String.Format("%s%s", ));
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,355 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.htmlcleaner.HtmlCleaner;
|
||||||
|
import org.htmlcleaner.TagNode;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
try {
|
||||||
|
System.out.println("Extracting necessary libraries...");
|
||||||
|
final File[] libs = new File[] { new File(getDataFolder(),
|
||||||
|
"htmlcleaner-2.16.jar") };
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
JarUtils.extractFromJar(lib.getName(),
|
||||||
|
lib.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
getLogger().warning(
|
||||||
|
"Failed to load plugin! Could not find lib: "
|
||||||
|
+ lib.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().disablePlugin(this);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
addClassPath(JarUtils.getJarUrl(lib));
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ThreadMethod() {
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.GetFromName(ign);
|
||||||
|
if (mp == null)
|
||||||
|
continue;
|
||||||
|
if (!mp.UserNames.contains(author))
|
||||||
|
mp.UserNames.add(author);
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
mp.FlairState = FlairStates.Commented;
|
||||||
|
ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DownloadFlair(MaybeOfflinePlayer mp)
|
||||||
|
throws MalformedURLException, IOException {
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users=" + mp.UserName)
|
||||||
|
.replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1)
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(mp, flair, flairclass, mp.UserName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair(MaybeOfflinePlayer p, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
p.UserName = username;
|
||||||
|
p.FlairState = FlairStates.Recognised;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
p.SetFlairColor(0xc);
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
p.SetFlairColor(0x6);
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
p.SetFlairColor(0xe);
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
p.SetFlairColor(0xa);
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
p.SetFlairColor(0x9);
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
p.SetFlairColor(0x7);
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "cant-press":
|
||||||
|
p.SetFlairColor(0xf);
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if (CheckForJoinDate(p)) {
|
||||||
|
p.SetFlairColor(0x7);
|
||||||
|
p.SetFlairTime("--");
|
||||||
|
} else {
|
||||||
|
p.FlairColor = 0xf;
|
||||||
|
p.FlairTime = "--";
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (text.equals("-1"))
|
||||||
|
text = "--";
|
||||||
|
p.FlairTime = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean CheckForJoinDate(MaybeOfflinePlayer mp)
|
||||||
|
throws Exception {
|
||||||
|
URL url = new URL("https://www.reddit.com/u/" + mp.UserName);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
HtmlCleaner cleaner = new HtmlCleaner();
|
||||||
|
TagNode node = cleaner.clean(in);
|
||||||
|
|
||||||
|
node = node.getElementsByAttValue("class", "age", true, true)[0];
|
||||||
|
node = node.getElementsByName("time", false)[0];
|
||||||
|
String joindate = node.getAttributeByName("datetime");
|
||||||
|
SimpleDateFormat parserSDF = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
|
joindate = joindate.split("T")[0];
|
||||||
|
Date date = parserSDF.parse(joindate);
|
||||||
|
return date.before(new Calendar.Builder()
|
||||||
|
.setTimeZone(TimeZone.getTimeZone("UTC")).setDate(2015, 4, 1)
|
||||||
|
.build().getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ConfirmUserMessage(MaybeOfflinePlayer mp) {
|
||||||
|
Player p = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented) && p != null)
|
||||||
|
if (mp.UserNames.size() > 1)
|
||||||
|
p.sendMessage("§9Multiple Reddit users commented your name. You can select with /u accept.§r §6Type /u accept or /u ignore§r");
|
||||||
|
else
|
||||||
|
p.sendMessage("§9A Reddit user commented your name. Is that you?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) {
|
||||||
|
if (reload) {
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("announcemessages.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("thebuttonmc.yml");
|
||||||
|
if (file.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
yc.load(file);
|
||||||
|
MaybeOfflinePlayer.Load(yc);
|
||||||
|
PlayerListener.NotificationSound = yc
|
||||||
|
.getString("notificationsound");
|
||||||
|
PlayerListener.NotificationPitch = yc
|
||||||
|
.getDouble("notificationpitch");
|
||||||
|
AnnounceTime = yc.getInt("announcetime");
|
||||||
|
AnnounceMessages.addAll(yc.getStringList("announcements"));
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() {
|
||||||
|
System.out.println("Saving files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("thebuttonmc.yml");
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
MaybeOfflinePlayer.Save(yc);
|
||||||
|
yc.set("notificationsound", PlayerListener.NotificationSound);
|
||||||
|
yc.set("notificationpitch", PlayerListener.NotificationPitch);
|
||||||
|
yc.set("announcetime", AnnounceTime);
|
||||||
|
yc.set("announcements", AnnounceMessages);
|
||||||
|
yc.save(file);
|
||||||
|
System.out.println("The Button Minecraft plugin saved files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addClassPath(final URL url) throws IOException {
|
||||||
|
final URLClassLoader sysloader = (URLClassLoader) ClassLoader
|
||||||
|
.getSystemClassLoader();
|
||||||
|
final Class<URLClassLoader> sysclass = URLClassLoader.class;
|
||||||
|
try {
|
||||||
|
final Method method = sysclass.getDeclaredMethod("addURL",
|
||||||
|
new Class[] { URL.class });
|
||||||
|
method.setAccessible(true);
|
||||||
|
method.invoke(sysloader, new Object[] { url });
|
||||||
|
} catch (final Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
throw new IOException("Error adding " + url
|
||||||
|
+ " to system classloader");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,603 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.command.BlockCommandSender;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Ocelot;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.potion.PotionEffectType;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.Mob;
|
||||||
|
import com.earth2me.essentials.Mob.MobException;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer Lastlol = null;
|
||||||
|
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label,
|
||||||
|
String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
switch (cmd.getName()) {
|
||||||
|
case "u": {
|
||||||
|
if (args.length < 1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(player
|
||||||
|
.getUniqueId());
|
||||||
|
switch (args[0].toLowerCase()) {
|
||||||
|
case "accept": {
|
||||||
|
if (args.length < 2 && p.UserNames.size() > 1) {
|
||||||
|
player.sendMessage("§9Multiple users commented your name. §bPlease pick one using /u accept <username>");
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
player.sendMessage(sb.toString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)
|
||||||
|
|| p.UserNames.size() == 0) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1 && !p.UserNames.contains(args[1])) {
|
||||||
|
player.sendMessage("§cError: Unknown name: " + args[1]
|
||||||
|
+ "§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.Working) {
|
||||||
|
player.sendMessage("§cError: Something is already in progress.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((args.length > 1 ? args[1] : p.UserNames.get(0))
|
||||||
|
.equals(p.UserName)) {
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1)
|
||||||
|
p.UserName = args[1];
|
||||||
|
else
|
||||||
|
p.UserName = p.UserNames.get(0);
|
||||||
|
|
||||||
|
player.sendMessage("§bObtaining flair...");
|
||||||
|
p.Working = true;
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
PluginMain.Instance.DownloadFlair(mp);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
Player player = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask an admin to set it for you. Also, prepare a comment on /r/thebutton, if possible.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String flair = mp.GetFormattedFlair();
|
||||||
|
mp.FlairState = FlairStates.Accepted;
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
player.sendMessage("§bYour flair has been set:§r "
|
||||||
|
+ flair);
|
||||||
|
mp.Working = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = p;
|
||||||
|
timer.schedule(tt, 20);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore": {
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!p.FlairState.equals(FlairStates.Ignored)) {
|
||||||
|
p.FlairState = FlairStates.Ignored;
|
||||||
|
p.FlairTime = "";
|
||||||
|
p.UserName = "";
|
||||||
|
player.sendMessage("§bYou have removed your flair. You can still use /u accept to get one.§r");
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou already removed your flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "admin": // 2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "opme": // 2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, wouldn't it?"); // Sometimes
|
||||||
|
// I'm
|
||||||
|
// bored
|
||||||
|
// too
|
||||||
|
break;
|
||||||
|
case "announce":
|
||||||
|
DoAnnounce(player, args, null);
|
||||||
|
break;
|
||||||
|
case "name":
|
||||||
|
if (args.length == 1) {
|
||||||
|
player.sendMessage("§cUsage: /u name <playername>§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer
|
||||||
|
.GetFromName(args[1]);
|
||||||
|
if (mp == null) {
|
||||||
|
player.sendMessage("§cUnknown user: " + args[1]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
player.sendMessage("§bUsername of " + args[1] + ": "
|
||||||
|
+ mp.UserName);
|
||||||
|
break;
|
||||||
|
case "enable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = true;
|
||||||
|
player.sendMessage("Enabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "disable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = false;
|
||||||
|
player.sendMessage("Disabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "kittycannon":
|
||||||
|
DoKittyCannon(player, args);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "nrp":
|
||||||
|
case "ooc":
|
||||||
|
if (args.length == 0) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = false;
|
||||||
|
String message = "";
|
||||||
|
for (String arg : args)
|
||||||
|
message += arg + " ";
|
||||||
|
player.chat(message.substring(0, message.length() - 1));
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = true;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
case "unlol": // TODO: Unlol
|
||||||
|
Player p = null;
|
||||||
|
if (Lastlol != null
|
||||||
|
|| (p = Bukkit.getPlayer(Lastlol.UUID)) != null) {
|
||||||
|
p.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.BLINDNESS, 10, 5, false, false));
|
||||||
|
for (Player pl : PluginMain.GetPlayers())
|
||||||
|
pl.sendMessage(player.getDisplayName() + " unlolled "
|
||||||
|
+ p.getDisplayName());
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("admin")) // 2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); // 2015.08.09.
|
||||||
|
return true; // 2015.08.09.
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("announce")) {
|
||||||
|
if (sender instanceof BlockCommandSender)
|
||||||
|
DoAnnounce(null, args, (BlockCommandSender) sender);
|
||||||
|
else
|
||||||
|
DoAnnounce(null, args, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoReload(Player player) { // 2015.07.20.
|
||||||
|
try {
|
||||||
|
PluginMain.Console
|
||||||
|
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); // 2015.08.09.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (mp.FlairState.equals(FlairStates.Recognised)
|
||||||
|
|| mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
String msg = "§bNote: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; // 2015.08.09.
|
||||||
|
p.sendMessage(msg); // 2015.08.09.
|
||||||
|
}
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading done!§r");
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
if (player != null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Player ReloadPlayer; // 2015.08.09.
|
||||||
|
|
||||||
|
private static String DoAdminUsage = "§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin|togglerpshow|toggledebug|savepos|loadpos§r";
|
||||||
|
|
||||||
|
private static void DoAdmin(Player player, String[] args) { // 2015.08.09.
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// args[0] is "admin"
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer = player; // 2015.08.09.
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§bMake sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; // <-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if (ReloadPlayer == player)
|
||||||
|
DoReload(player); // 2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); // 2015.08.09.
|
||||||
|
SendMessage(player,
|
||||||
|
"§bSaved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": // 2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
case "togglerpshow":
|
||||||
|
PlayerListener.ShowRPTag = !PlayerListener.ShowRPTag;
|
||||||
|
SendMessage(player, "RP tag showing "
|
||||||
|
+ (PlayerListener.ShowRPTag ? "enabled" : "disabled"));
|
||||||
|
break;
|
||||||
|
case "toggledebug":
|
||||||
|
PlayerListener.DebugMode = !PlayerListener.DebugMode;
|
||||||
|
SendMessage(player, "DebugMode: " + PlayerListener.DebugMode);
|
||||||
|
break;
|
||||||
|
case "savepos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "loadpos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "updatedynmap":
|
||||||
|
DoUpdateDynmap(player, args);
|
||||||
|
default:
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.GetFromName(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SendMessage(player, "Player name: " + p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: " + p.GetFormattedFlair());
|
||||||
|
SendMessage(player, "Username: " + p.UserName);
|
||||||
|
SendMessage(player, "Flair state: " + p.FlairState);
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
SendMessage(player, sb.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SendMessage(Player player, String message) { // 2015.08.09.
|
||||||
|
if (player == null)
|
||||||
|
PluginMain.Console.sendMessage(message); // 2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoGetLastError(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if (PluginMain.LastException != null) {
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException = null;
|
||||||
|
} else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SetPlayerFlair(Player player,
|
||||||
|
MaybeOfflinePlayer targetplayer, short flaircolor, String flairtime) {
|
||||||
|
targetplayer.FlairColor = flaircolor;
|
||||||
|
targetplayer.FlairTime = flairtime;
|
||||||
|
targetplayer.FlairState = FlairStates.Accepted;
|
||||||
|
targetplayer.UserName = "";
|
||||||
|
SendMessage(player,
|
||||||
|
"§bThe flair has been set. Player: " + targetplayer.PlayerName
|
||||||
|
+ " Flair: " + targetplayer.GetFormattedFlair() + "§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoSetFlair(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if (args.length < 4) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = Bukkit.getPlayer(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
SendMessage(player, "§cPLayer not found.&r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
short flaircolor = 0x00;
|
||||||
|
try {
|
||||||
|
flaircolor = Short.parseShort(args[3], 16);
|
||||||
|
} catch (Exception e) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cFlaircolor must be a hexadecimal number (don't include &).");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player,
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()),
|
||||||
|
flaircolor, (args.length < 5 ? "" : args[4]));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdatePlugin(Player player) { // 2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL(
|
||||||
|
"https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File(
|
||||||
|
"plugins/TheButtonAutoFlair.jar"));
|
||||||
|
PluginUpdated = true; // 2015.08.31.
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoAnnounce(Player player, String[] args,
|
||||||
|
BlockCommandSender commandblock) {
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "add":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce add <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
for (int i = 2; i < args.length; i++) {
|
||||||
|
sb.append(args[i]);
|
||||||
|
if (i != args.length - 1)
|
||||||
|
sb.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage = sb.toString().replace('&', '§');
|
||||||
|
PluginMain.AnnounceMessages.add(finalmessage);
|
||||||
|
SendMessage(player, "§bAnnouncement added.§r");
|
||||||
|
break;
|
||||||
|
case "remove":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce remove <index>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceMessages.remove(Integer.parseInt(args[2]));
|
||||||
|
break;
|
||||||
|
case "settime":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u announce settime <minutes>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceTime = Integer.parseInt(args[2]) * 60 * 1000;
|
||||||
|
SendMessage(player, "Time set between announce messages");
|
||||||
|
break;
|
||||||
|
case "list":
|
||||||
|
SendMessage(player, "§bList of announce messages:§r");
|
||||||
|
SendMessage(player, "§bFormat: [index] message§r");
|
||||||
|
int i = 0;
|
||||||
|
for (String message : PluginMain.AnnounceMessages)
|
||||||
|
SendMessage(player, "[" + i++ + "] " + message);
|
||||||
|
SendMessage(player,
|
||||||
|
"§bCurrent wait time between announcements: "
|
||||||
|
+ PluginMain.AnnounceTime / 60 / 1000
|
||||||
|
+ " minute(s)§r");
|
||||||
|
break;
|
||||||
|
case "edit":
|
||||||
|
if (commandblock == null) {
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§cError: This command can only be used from a command block. Use /u announce remove.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (args.length < 4) {
|
||||||
|
commandblock
|
||||||
|
.sendMessage("§cUsage: /u announce edit <index> <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb1 = new StringBuilder();
|
||||||
|
for (int i1 = 3; i1 < args.length; i1++) {
|
||||||
|
sb1.append(args[i1]);
|
||||||
|
if (i1 != args.length - 1)
|
||||||
|
sb1.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage1 = sb1.toString().replace('&', '§');
|
||||||
|
int index = Integer.parseInt(args[2]);
|
||||||
|
if (index > 100)
|
||||||
|
break;
|
||||||
|
while (PluginMain.AnnounceMessages.size() <= index)
|
||||||
|
PluginMain.AnnounceMessages.add("");
|
||||||
|
PluginMain.AnnounceMessages.set(Integer.parseInt(args[2]),
|
||||||
|
finalmessage1);
|
||||||
|
commandblock.sendMessage("Announcement edited.");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
private static void DoSaveLoadPos(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "savepos|loadpos"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = null;
|
||||||
|
try {
|
||||||
|
p = Bukkit.getPlayer(args[2]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
if (!MaybeOfflinePlayer.AllPlayers.containsKey(p.getUniqueId())) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer is not online: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (args[1].equalsIgnoreCase("savepos")) {
|
||||||
|
mp.SavedLocation = p.getLocation();
|
||||||
|
} else if (args[1].equalsIgnoreCase("loadpos")) {
|
||||||
|
if (mp.SavedLocation != null)
|
||||||
|
p.teleport(mp.SavedLocation);
|
||||||
|
} else {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// SendMessage(player, "Player " + p.getName() +
|
||||||
|
// " position saved/loaded.");s
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdateDynmap(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "updatedynmap"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin updatedynmap <password>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Random random = new Random();
|
||||||
|
|
||||||
|
public static String KittyCannonMinigame = "KittyCannon";
|
||||||
|
|
||||||
|
private static void DoKittyCannon(Player player, String[] args) {
|
||||||
|
if (player == null) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cThis command can only be used by a player.§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(player);
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame))) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou can only use KittyCannon in it's minigame!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
final Mob cat = Mob.OCELOT;
|
||||||
|
final Ocelot ocelot = (Ocelot) cat.spawn(player.getWorld(),
|
||||||
|
player.getServer(), player.getEyeLocation());
|
||||||
|
if (ocelot == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final ArrayList<String> lore = new ArrayList<>();
|
||||||
|
lore.add(player.getName());
|
||||||
|
final int i = random.nextInt(Ocelot.Type.values().length);
|
||||||
|
ocelot.setCatType(Ocelot.Type.values()[i]);
|
||||||
|
ocelot.setTamed(true);
|
||||||
|
ocelot.setBaby();
|
||||||
|
ocelot.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.DAMAGE_RESISTANCE, 5, 5));
|
||||||
|
ocelot.setVelocity(player.getEyeLocation().getDirection()
|
||||||
|
.multiply(2));
|
||||||
|
Bukkit.getScheduler().scheduleSyncDelayedTask(PluginMain.Instance,
|
||||||
|
new Runnable() {
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
final Location loc = ocelot.getLocation();
|
||||||
|
ocelot.remove();
|
||||||
|
loc.getWorld().createExplosion(loc, 0F);
|
||||||
|
final ItemStack head = new ItemStack(
|
||||||
|
Material.SKULL_ITEM, 1, (short) 3, (byte) 3);
|
||||||
|
SkullMeta im = (SkullMeta) head.getItemMeta();
|
||||||
|
im.setDisplayName("§rOcelot Head");
|
||||||
|
im.setOwner("MHF_Ocelot");
|
||||||
|
im.setLore(lore);
|
||||||
|
head.setItemMeta(im);
|
||||||
|
loc.getWorld().dropItem(loc, head);
|
||||||
|
}
|
||||||
|
}, 20);
|
||||||
|
} catch (MobException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,125 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(int color) {
|
||||||
|
FlairColor = (short) color;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time) {
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(int color, String time) {
|
||||||
|
FlairColor = (short)color;
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2() {
|
||||||
|
|
||||||
|
// Flairs from Command Block The Button - Teams
|
||||||
|
// PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
Player p = Bukkit.getPlayer(UUID);
|
||||||
|
p.setPlayerListName(String.format("%s%s", p.getPlayerListName(),
|
||||||
|
GetFormattedFlair()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public short GetFlairColor() {
|
||||||
|
return FlairColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFlairTime() {
|
||||||
|
return FlairTime;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,362 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,355 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.htmlcleaner.HtmlCleaner;
|
||||||
|
import org.htmlcleaner.TagNode;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
try {
|
||||||
|
System.out.println("Extracting necessary libraries...");
|
||||||
|
final File[] libs = new File[] { new File(getDataFolder(),
|
||||||
|
"htmlcleaner-2.16.jar") };
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
JarUtils.extractFromJar(lib.getName(),
|
||||||
|
lib.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
getLogger().warning(
|
||||||
|
"Failed to load plugin! Could not find lib: "
|
||||||
|
+ lib.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().disablePlugin(this);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
addClassPath(JarUtils.getJarUrl(lib));
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ThreadMethod() {
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.GetFromName(ign);
|
||||||
|
if (mp == null)
|
||||||
|
continue;
|
||||||
|
if (!mp.UserNames.contains(author))
|
||||||
|
mp.UserNames.add(author);
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
mp.FlairState = FlairStates.Commented;
|
||||||
|
ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DownloadFlair(MaybeOfflinePlayer mp)
|
||||||
|
throws MalformedURLException, IOException {
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users=" + mp.UserName)
|
||||||
|
.replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1)
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(mp, flair, flairclass, mp.UserName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair(MaybeOfflinePlayer p, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
p.UserName = username;
|
||||||
|
p.FlairState = FlairStates.Recognised;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
p.SetFlairColor(0xc);
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
p.SetFlairColor(0x6);
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
p.SetFlairColor(0xe);
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
p.SetFlairColor(0xa);
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
p.SetFlairColor(0x9);
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
p.SetFlairColor(0x7);
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "cant-press":
|
||||||
|
p.SetFlairColor(0xf);
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if (CheckForJoinDate(p)) {
|
||||||
|
p.FlairColor = 0x7;
|
||||||
|
p.FlairTime = "--";
|
||||||
|
} else {
|
||||||
|
p.FlairColor = 0xf;
|
||||||
|
p.FlairTime = "--";
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (text.equals("-1"))
|
||||||
|
text = "--";
|
||||||
|
p.FlairTime = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean CheckForJoinDate(MaybeOfflinePlayer mp)
|
||||||
|
throws Exception {
|
||||||
|
URL url = new URL("https://www.reddit.com/u/" + mp.UserName);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
HtmlCleaner cleaner = new HtmlCleaner();
|
||||||
|
TagNode node = cleaner.clean(in);
|
||||||
|
|
||||||
|
node = node.getElementsByAttValue("class", "age", true, true)[0];
|
||||||
|
node = node.getElementsByName("time", false)[0];
|
||||||
|
String joindate = node.getAttributeByName("datetime");
|
||||||
|
SimpleDateFormat parserSDF = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
|
joindate = joindate.split("T")[0];
|
||||||
|
Date date = parserSDF.parse(joindate);
|
||||||
|
return date.before(new Calendar.Builder()
|
||||||
|
.setTimeZone(TimeZone.getTimeZone("UTC")).setDate(2015, 4, 1)
|
||||||
|
.build().getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ConfirmUserMessage(MaybeOfflinePlayer mp) {
|
||||||
|
Player p = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented) && p != null)
|
||||||
|
if (mp.UserNames.size() > 1)
|
||||||
|
p.sendMessage("§9Multiple Reddit users commented your name. You can select with /u accept.§r §6Type /u accept or /u ignore§r");
|
||||||
|
else
|
||||||
|
p.sendMessage("§9A Reddit user commented your name. Is that you?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) {
|
||||||
|
if (reload) {
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("announcemessages.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("thebuttonmc.yml");
|
||||||
|
if (file.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
yc.load(file);
|
||||||
|
MaybeOfflinePlayer.Load(yc);
|
||||||
|
PlayerListener.NotificationSound = yc
|
||||||
|
.getString("notificationsound");
|
||||||
|
PlayerListener.NotificationPitch = yc
|
||||||
|
.getDouble("notificationpitch");
|
||||||
|
AnnounceTime = yc.getInt("announcetime");
|
||||||
|
AnnounceMessages.addAll(yc.getStringList("announcements"));
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() {
|
||||||
|
System.out.println("Saving files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("thebuttonmc.yml");
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
MaybeOfflinePlayer.Save(yc);
|
||||||
|
yc.set("notificationsound", PlayerListener.NotificationSound);
|
||||||
|
yc.set("notificationpitch", PlayerListener.NotificationPitch);
|
||||||
|
yc.set("announcetime", AnnounceTime);
|
||||||
|
yc.set("announcements", AnnounceMessages);
|
||||||
|
yc.save(file);
|
||||||
|
System.out.println("The Button Minecraft plugin saved files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addClassPath(final URL url) throws IOException {
|
||||||
|
final URLClassLoader sysloader = (URLClassLoader) ClassLoader
|
||||||
|
.getSystemClassLoader();
|
||||||
|
final Class<URLClassLoader> sysclass = URLClassLoader.class;
|
||||||
|
try {
|
||||||
|
final Method method = sysclass.getDeclaredMethod("addURL",
|
||||||
|
new Class[] { URL.class });
|
||||||
|
method.setAccessible(true);
|
||||||
|
method.invoke(sysloader, new Object[] { url });
|
||||||
|
} catch (final Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
throw new IOException("Error adding " + url
|
||||||
|
+ " to system classloader");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true;
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,221 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer=player; //2015.08.09.
|
||||||
|
SendMessage(player, "§6Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
case "confirm":
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,110 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color) {
|
||||||
|
FlairColor = color;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time) {
|
||||||
|
FlairTime = time;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time) {
|
||||||
|
FlairColor = color;
|
||||||
|
FlairTime = time;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2() {
|
||||||
|
|
||||||
|
// Flairs from Command Block The Button - Teams
|
||||||
|
// PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
event.getPlayer().setPlayerListName("");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,597 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.command.BlockCommandSender;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Ocelot;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.potion.PotionEffectType;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.Mob;
|
||||||
|
import com.earth2me.essentials.Mob.MobException;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer Lastlol = null;
|
||||||
|
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label,
|
||||||
|
String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
switch (cmd.getName()) {
|
||||||
|
case "u": {
|
||||||
|
if (args.length < 1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(player
|
||||||
|
.getUniqueId());
|
||||||
|
switch (args[0].toLowerCase()) {
|
||||||
|
case "accept": {
|
||||||
|
if (args.length < 2 && p.UserNames.size() > 1) {
|
||||||
|
player.sendMessage("§9Multiple users commented your name. §bPlease pick one using /u accept <username>");
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
player.sendMessage(sb.toString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)
|
||||||
|
|| p.UserNames.size() == 0) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1 && !p.UserNames.contains(args[1])) {
|
||||||
|
player.sendMessage("§cError: Unknown name: " + args[1]
|
||||||
|
+ "§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.Working) {
|
||||||
|
player.sendMessage("§cError: Something is already in progress.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((args.length > 1 ? args[1] : p.UserNames.get(0))
|
||||||
|
.equals(p.UserName)) {
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1)
|
||||||
|
p.UserName = args[1];
|
||||||
|
else
|
||||||
|
p.UserName = p.UserNames.get(0);
|
||||||
|
|
||||||
|
player.sendMessage("§bObtaining flair...");
|
||||||
|
p.Working = true;
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
PluginMain.Instance.DownloadFlair(mp);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
Player player = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask an admin to set it for you. Also, prepare a comment on /r/thebutton, if possible.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String flair = mp.GetFormattedFlair();
|
||||||
|
mp.FlairState = FlairStates.Accepted;
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
player.sendMessage("§bYour flair has been set:§r "
|
||||||
|
+ flair);
|
||||||
|
mp.Working = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = p;
|
||||||
|
timer.schedule(tt, 20);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore": {
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!p.FlairState.equals(FlairStates.Ignored)) {
|
||||||
|
p.FlairState = FlairStates.Ignored;
|
||||||
|
p.FlairTime = "";
|
||||||
|
p.UserName = "";
|
||||||
|
player.sendMessage("§bYou have removed your flair. You can still use /u accept to get one.§r");
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou already removed your flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "admin": // 2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "opme": // 2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, wouldn't it?"); // Sometimes
|
||||||
|
// I'm
|
||||||
|
// bored
|
||||||
|
// too
|
||||||
|
break;
|
||||||
|
case "announce":
|
||||||
|
DoAnnounce(player, args, null);
|
||||||
|
break;
|
||||||
|
case "name":
|
||||||
|
if (args.length == 1) {
|
||||||
|
player.sendMessage("§cUsage: /u name <playername>§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer
|
||||||
|
.GetFromName(args[1]);
|
||||||
|
if (mp == null) {
|
||||||
|
player.sendMessage("§cUnknown user: " + args[1]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
player.sendMessage("§bUsername of " + args[1] + ": "
|
||||||
|
+ mp.UserName);
|
||||||
|
break;
|
||||||
|
case "enable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = true;
|
||||||
|
player.sendMessage("Enabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "disable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = false;
|
||||||
|
player.sendMessage("Disabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "kittycannon":
|
||||||
|
DoKittyCannon(player, args);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "nrp":
|
||||||
|
case "ooc":
|
||||||
|
if (args.length == 0) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = false;
|
||||||
|
String message = "";
|
||||||
|
for (String arg : args)
|
||||||
|
message += arg + " ";
|
||||||
|
player.chat(message.substring(0, message.length() - 1));
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = true;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
case "unlol": // TODO: Unlol
|
||||||
|
Player p=null;
|
||||||
|
if(Lastlol!=null || Bukkit.getPlayer(Lastlol.UUID))
|
||||||
|
Lastlol.UUID
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("admin")) // 2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); // 2015.08.09.
|
||||||
|
return true; // 2015.08.09.
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("announce")) {
|
||||||
|
if (sender instanceof BlockCommandSender)
|
||||||
|
DoAnnounce(null, args, (BlockCommandSender) sender);
|
||||||
|
else
|
||||||
|
DoAnnounce(null, args, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoReload(Player player) { // 2015.07.20.
|
||||||
|
try {
|
||||||
|
PluginMain.Console
|
||||||
|
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); // 2015.08.09.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (mp.FlairState.equals(FlairStates.Recognised)
|
||||||
|
|| mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
String msg = "§bNote: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; // 2015.08.09.
|
||||||
|
p.sendMessage(msg); // 2015.08.09.
|
||||||
|
}
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading done!§r");
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
if (player != null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Player ReloadPlayer; // 2015.08.09.
|
||||||
|
|
||||||
|
private static String DoAdminUsage = "§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin|togglerpshow|toggledebug|savepos|loadpos§r";
|
||||||
|
|
||||||
|
private static void DoAdmin(Player player, String[] args) { // 2015.08.09.
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// args[0] is "admin"
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer = player; // 2015.08.09.
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§bMake sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; // <-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if (ReloadPlayer == player)
|
||||||
|
DoReload(player); // 2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); // 2015.08.09.
|
||||||
|
SendMessage(player,
|
||||||
|
"§bSaved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": // 2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
case "togglerpshow":
|
||||||
|
PlayerListener.ShowRPTag = !PlayerListener.ShowRPTag;
|
||||||
|
SendMessage(player, "RP tag showing "
|
||||||
|
+ (PlayerListener.ShowRPTag ? "enabled" : "disabled"));
|
||||||
|
break;
|
||||||
|
case "toggledebug":
|
||||||
|
PlayerListener.DebugMode = !PlayerListener.DebugMode;
|
||||||
|
SendMessage(player, "DebugMode: " + PlayerListener.DebugMode);
|
||||||
|
break;
|
||||||
|
case "savepos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "loadpos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "updatedynmap":
|
||||||
|
DoUpdateDynmap(player, args);
|
||||||
|
default:
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.GetFromName(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SendMessage(player, "Player name: " + p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: " + p.GetFormattedFlair());
|
||||||
|
SendMessage(player, "Username: " + p.UserName);
|
||||||
|
SendMessage(player, "Flair state: " + p.FlairState);
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
SendMessage(player, sb.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SendMessage(Player player, String message) { // 2015.08.09.
|
||||||
|
if (player == null)
|
||||||
|
PluginMain.Console.sendMessage(message); // 2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoGetLastError(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if (PluginMain.LastException != null) {
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException = null;
|
||||||
|
} else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SetPlayerFlair(Player player,
|
||||||
|
MaybeOfflinePlayer targetplayer, short flaircolor, String flairtime) {
|
||||||
|
targetplayer.FlairColor = flaircolor;
|
||||||
|
targetplayer.FlairTime = flairtime;
|
||||||
|
targetplayer.FlairState = FlairStates.Accepted;
|
||||||
|
targetplayer.UserName = "";
|
||||||
|
SendMessage(player,
|
||||||
|
"§bThe flair has been set. Player: " + targetplayer.PlayerName
|
||||||
|
+ " Flair: " + targetplayer.GetFormattedFlair() + "§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoSetFlair(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if (args.length < 4) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = Bukkit.getPlayer(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
SendMessage(player, "§cPLayer not found.&r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
short flaircolor = 0x00;
|
||||||
|
try {
|
||||||
|
flaircolor = Short.parseShort(args[3], 16);
|
||||||
|
} catch (Exception e) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cFlaircolor must be a hexadecimal number (don't include &).");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player,
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()),
|
||||||
|
flaircolor, (args.length < 5 ? "" : args[4]));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdatePlugin(Player player) { // 2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL(
|
||||||
|
"https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File(
|
||||||
|
"plugins/TheButtonAutoFlair.jar"));
|
||||||
|
PluginUpdated = true; // 2015.08.31.
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoAnnounce(Player player, String[] args,
|
||||||
|
BlockCommandSender commandblock) {
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "add":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce add <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
for (int i = 2; i < args.length; i++) {
|
||||||
|
sb.append(args[i]);
|
||||||
|
if (i != args.length - 1)
|
||||||
|
sb.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage = sb.toString().replace('&', '§');
|
||||||
|
PluginMain.AnnounceMessages.add(finalmessage);
|
||||||
|
SendMessage(player, "§bAnnouncement added.§r");
|
||||||
|
break;
|
||||||
|
case "remove":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce remove <index>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceMessages.remove(Integer.parseInt(args[2]));
|
||||||
|
break;
|
||||||
|
case "settime":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u announce settime <minutes>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceTime = Integer.parseInt(args[2]) * 60 * 1000;
|
||||||
|
SendMessage(player, "Time set between announce messages");
|
||||||
|
break;
|
||||||
|
case "list":
|
||||||
|
SendMessage(player, "§bList of announce messages:§r");
|
||||||
|
SendMessage(player, "§bFormat: [index] message§r");
|
||||||
|
int i = 0;
|
||||||
|
for (String message : PluginMain.AnnounceMessages)
|
||||||
|
SendMessage(player, "[" + i++ + "] " + message);
|
||||||
|
SendMessage(player,
|
||||||
|
"§bCurrent wait time between announcements: "
|
||||||
|
+ PluginMain.AnnounceTime / 60 / 1000
|
||||||
|
+ " minute(s)§r");
|
||||||
|
break;
|
||||||
|
case "edit":
|
||||||
|
if (commandblock == null) {
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§cError: This command can only be used from a command block. Use /u announce remove.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (args.length < 4) {
|
||||||
|
commandblock
|
||||||
|
.sendMessage("§cUsage: /u announce edit <index> <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb1 = new StringBuilder();
|
||||||
|
for (int i1 = 3; i1 < args.length; i1++) {
|
||||||
|
sb1.append(args[i1]);
|
||||||
|
if (i1 != args.length - 1)
|
||||||
|
sb1.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage1 = sb1.toString().replace('&', '§');
|
||||||
|
int index = Integer.parseInt(args[2]);
|
||||||
|
if (index > 100)
|
||||||
|
break;
|
||||||
|
while (PluginMain.AnnounceMessages.size() <= index)
|
||||||
|
PluginMain.AnnounceMessages.add("");
|
||||||
|
PluginMain.AnnounceMessages.set(Integer.parseInt(args[2]),
|
||||||
|
finalmessage1);
|
||||||
|
commandblock.sendMessage("Announcement edited.");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
private static void DoSaveLoadPos(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "savepos|loadpos"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = null;
|
||||||
|
try {
|
||||||
|
p = Bukkit.getPlayer(args[2]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
if (!MaybeOfflinePlayer.AllPlayers.containsKey(p.getUniqueId())) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer is not online: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (args[1].equalsIgnoreCase("savepos")) {
|
||||||
|
mp.SavedLocation = p.getLocation();
|
||||||
|
} else if (args[1].equalsIgnoreCase("loadpos")) {
|
||||||
|
if (mp.SavedLocation != null)
|
||||||
|
p.teleport(mp.SavedLocation);
|
||||||
|
} else {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// SendMessage(player, "Player " + p.getName() +
|
||||||
|
// " position saved/loaded.");s
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdateDynmap(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "updatedynmap"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin updatedynmap <password>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Random random = new Random();
|
||||||
|
|
||||||
|
public static String KittyCannonMinigame = "KittyCannon";
|
||||||
|
|
||||||
|
private static void DoKittyCannon(Player player, String[] args) {
|
||||||
|
if (player == null) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cThis command can only be used by a player.§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(player);
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame))) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou can only use KittyCannon in it's minigame!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
final Mob cat = Mob.OCELOT;
|
||||||
|
final Ocelot ocelot = (Ocelot) cat.spawn(player.getWorld(),
|
||||||
|
player.getServer(), player.getEyeLocation());
|
||||||
|
if (ocelot == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final ArrayList<String> lore = new ArrayList<>();
|
||||||
|
lore.add(player.getName());
|
||||||
|
final int i = random.nextInt(Ocelot.Type.values().length);
|
||||||
|
ocelot.setCatType(Ocelot.Type.values()[i]);
|
||||||
|
ocelot.setTamed(true);
|
||||||
|
ocelot.setBaby();
|
||||||
|
ocelot.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.DAMAGE_RESISTANCE, 5, 5));
|
||||||
|
ocelot.setVelocity(player.getEyeLocation().getDirection()
|
||||||
|
.multiply(2));
|
||||||
|
Bukkit.getScheduler().scheduleSyncDelayedTask(PluginMain.Instance,
|
||||||
|
new Runnable() {
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
final Location loc = ocelot.getLocation();
|
||||||
|
ocelot.remove();
|
||||||
|
loc.getWorld().createExplosion(loc, 0F);
|
||||||
|
final ItemStack head = new ItemStack(
|
||||||
|
Material.SKULL_ITEM, 1, (short) 3, (byte) 3);
|
||||||
|
SkullMeta im = (SkullMeta) head.getItemMeta();
|
||||||
|
im.setDisplayName("§rOcelot Head");
|
||||||
|
im.setOwner("MHF_Ocelot");
|
||||||
|
im.setLore(lore);
|
||||||
|
head.setItemMeta(im);
|
||||||
|
loc.getWorld().dropItem(loc, head);
|
||||||
|
}
|
||||||
|
}, 20);
|
||||||
|
} catch (MobException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,354 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
String finalflair;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided":
|
||||||
|
finalflair=""; //2015.08.09.
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
{
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).AcceptedFlair)
|
||||||
|
AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+username+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,73 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
message = message.replaceAll(p.getName(), "§6"+p.getName()+"§r");
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, arg2, arg3)
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
System.out.println("1");
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
System.out.println("2");
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
System.out.println("3");
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
System.out.println("4");
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
System.out.println("5");
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
System.out.println("6");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,376 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{ //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,376 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{ //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
name: TheButtonMCPlugin
|
||||||
|
main: tk.sznp.thebuttonautoflair.PluginMain
|
||||||
|
version: 2.0
|
||||||
|
commands:
|
||||||
|
u:
|
||||||
|
description: Auto-flair system. Accept or ignore flair.
|
||||||
|
usage: "&cUsage: /u accept|ignore|opme&r"
|
||||||
|
nrp:
|
||||||
|
description: Send message in Out-of-Character
|
||||||
|
usage: "&cUsage: /nrp <message>&r"
|
||||||
|
ooc:
|
||||||
|
description: Send message in Out-of-Character
|
||||||
|
usage: "&cUsage: /ooc <message>&r"
|
||||||
|
author: NorbiPeti
|
||||||
|
depend: [Essentials, Towny]
|
|
@ -0,0 +1,224 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer=player; //2015.08.09.
|
||||||
|
SendMessage(player, "§6Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
case "confirm":
|
||||||
|
if(ReloadPlayer.equals(player))
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player, "§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,297 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(!p.CommentedOnReddit && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if(!p.FlairRecognised && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{ //2015.08.10.
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
//String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§7(--s)§r");
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type or your flair type is known.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§r(??s)§r");
|
||||||
|
break;
|
||||||
|
case "opme": //2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, isn't it?"); //Sometimes I'm bored too
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
//if(mp.Flair!=null)
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
{
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName().equals("NorbiPeti"))
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer=player; //2015.08.09.
|
||||||
|
SendMessage(player, "§6Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; //<-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if(ReloadPlayer==player)
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player, "§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); //2015.08.09.
|
||||||
|
SendMessage(player, "§6Saved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": //2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
SendMessage(player, "Flair decided: "+p.FlairDecided);
|
||||||
|
SendMessage(player, "Flair recognised: "+p.FlairRecognised);
|
||||||
|
SendMessage(player, "Commented on Reddit: "+p.CommentedOnReddit);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
private static void SetPlayerFlair(Player player, MaybeOfflinePlayer targetplayer, String flair)
|
||||||
|
{ //2015.08.09.
|
||||||
|
flair=flair.replace('&', '§');
|
||||||
|
targetplayer.Flair=flair;
|
||||||
|
targetplayer.CommentedOnReddit=true; //Or at least has a flair in some way
|
||||||
|
if(!PluginMain.RemoveLineFromFile("customflairs.txt", targetplayer.PlayerName))
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cError removing previous custom flair!§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
File file=new File("customflairs.txt");
|
||||||
|
try {
|
||||||
|
BufferedWriter bw;
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
bw.write(targetplayer.PlayerName+targetplayer.Flair+"\n");
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
SendMessage(player, "§6The flair has been set. Player: "+targetplayer.PlayerName+" Flair: "+flair+"§r");
|
||||||
|
}
|
||||||
|
private static void DoSetFlair(Player player, String[] args)
|
||||||
|
{
|
||||||
|
//args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if(args.length<4)
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cUsage: /u admin setflair <playername> <flair>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, MaybeOfflinePlayer.AddPlayerIfNeeded(args[2]), args[3]);
|
||||||
|
}
|
||||||
|
private static void DoUpdatePlugin(Player player)
|
||||||
|
{ //2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL("https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File("plugins/TheButtonAutoFlair.jar"));
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
}
|
||||||
|
catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,220 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
SendMessage(player, "§6Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
case "confirm":
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,31 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer
|
||||||
|
{ //2015.08.08.
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public String Flair; //If the user comments their name, it gets set, it doesn't matter if they accepted it or not
|
||||||
|
public boolean AcceptedFlair;
|
||||||
|
public boolean IgnoredFlair;
|
||||||
|
public FlairClassType FlairType; //2015.08.09.
|
||||||
|
public static HashMap<String, MaybeOfflinePlayer> AllPlayers=new HashMap<>(); //2015.08.08.
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(String playername)
|
||||||
|
{
|
||||||
|
if(!AllPlayers.containsKey(playername))
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player=new MaybeOfflinePlayer();
|
||||||
|
player.PlayerName=playername;
|
||||||
|
AllPlayers.put(playername, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(playername);
|
||||||
|
}
|
||||||
|
/*public enum FlairClassType
|
||||||
|
{ //2015.08.09.
|
||||||
|
NonPresser,
|
||||||
|
CantPress,
|
||||||
|
Undecided
|
||||||
|
}*/
|
||||||
|
}
|
|
@ -0,0 +1,71 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
message = message.replaceAll(p.getName(), "§6"+p.getName()+"§r");
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
System.out.println("1");
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
System.out.println("2");
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
System.out.println("3");
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
System.out.println("4");
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
System.out.println("5");
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
System.out.println("6");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,380 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{ //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void SaveFiles() //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,78 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String NotificationSound; //2015.08.14.
|
||||||
|
public static float NotificationPitch; //2015.08.14.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
String color=""; //2015.08.17.
|
||||||
|
if(message.contains(p.getName()))
|
||||||
|
{
|
||||||
|
if(NotificationSound==null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); //2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f, NotificationPitch); //2015.08.14.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.17.
|
||||||
|
color=mp.Flair.substring(0, 2);
|
||||||
|
}
|
||||||
|
message = message.replaceAll(p.getName(), color+p.getName()+"§r");
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,106 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time)
|
||||||
|
|
||||||
|
//Flairs from Command Block The Button - Teams
|
||||||
|
//PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
event.getPlayer().setPlayerListName("");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,219 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
case "confirm":
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,371 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerChatTabCompleteEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerPickupItemEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener { // 2015.07.16.
|
||||||
|
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
||||||
|
|
||||||
|
public static boolean Enable = false; // 2015.08.29.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
|
Player p = event.getPlayer();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PlayerName = p.getName(); // 2015.10.17. 0:58
|
||||||
|
if (!mp.FlairState.equals(FlairStates.NoComment))
|
||||||
|
// if (false)
|
||||||
|
PluginMain.ConfirmUserMessage(mp); // 2015.08.09.
|
||||||
|
else { // 2015.07.20.
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
String json = "[\"\",{\"text\":\"If you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
json = "[\"\",{\"text\":\"If you don't want the flair, type /u ignore to prevent this message after next login.\",\"color\":\"aqua\"}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = mp;
|
||||||
|
timer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NICKNAME LOGIC */
|
||||||
|
|
||||||
|
UUID id = p.getUniqueId();
|
||||||
|
|
||||||
|
File f = new File("plugins/Essentials/userdata/" + id + ".yml");
|
||||||
|
if (f.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
try {
|
||||||
|
yc.load(f);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
String nickname = yc.getString("nickname");
|
||||||
|
if (nickname != null) {
|
||||||
|
nicknames.put(nickname, id);
|
||||||
|
|
||||||
|
if (Enable) {
|
||||||
|
if (!p.getName().equals("NorbiPeti")) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.chat("Hey, " + nickname + "!");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mp.RPMode = true; // 2015.08.25.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event) {
|
||||||
|
String deletenick = null;
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
UUID uuid = nicknames.get(nickname);
|
||||||
|
if (event.getPlayer().getUniqueId().equals(uuid)) {
|
||||||
|
deletenick = nickname;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (deletenick != null)
|
||||||
|
nicknames.remove(deletenick);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String NotificationSound; // 2015.08.14.
|
||||||
|
public static double NotificationPitch; // 2015.08.14.
|
||||||
|
|
||||||
|
public static boolean ShowRPTag = false; // 2015.08.31.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event) {
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
String flair = player.GetFormattedFlair();
|
||||||
|
String message = event.getMessage(); // 2015.08.08.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
|
||||||
|
String color = ""; // 2015.08.17.
|
||||||
|
if (message.contains(p.getName())) {
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId()); // 2015.08.17.
|
||||||
|
color = String.format("§%x", (mp.FlairColor == 0x00 ? 0xb
|
||||||
|
: mp.FlairColor)); //TODO: Quiz queue
|
||||||
|
//TODO: Flairs from Command Block The Button - Teams
|
||||||
|
}
|
||||||
|
|
||||||
|
message = message.replace(p.getName(), color + p.getName()
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
for (String n : nicknames.keySet()) {
|
||||||
|
Player p = null;
|
||||||
|
String nwithoutformatting = new String(n);
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (message.contains(nwithoutformatting)) {
|
||||||
|
p = Bukkit.getPlayer(nicknames.get(n));
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()); // 2015.08.17.
|
||||||
|
}
|
||||||
|
if (p != null) {
|
||||||
|
message = message.replace(nwithoutformatting, n
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
event.setMessage(message); // 2015.09.05.
|
||||||
|
|
||||||
|
event.setFormat(event
|
||||||
|
.getFormat()
|
||||||
|
.replace(
|
||||||
|
"{rptag}",
|
||||||
|
(player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "")
|
||||||
|
: "§8[OOC]§r"))
|
||||||
|
.replace("{buttonflair}", flair)
|
||||||
|
.replace(
|
||||||
|
"{isitwilds}",
|
||||||
|
(event.getPlayer().getWorld().getName()
|
||||||
|
.equalsIgnoreCase("wilds") ? "[PVP]" : ""))); // 2015.09.04.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onTabComplete(PlayerChatTabCompleteEvent e) {
|
||||||
|
String name = e.getLastToken();
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
String nwithoutformatting = nickname;
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (nwithoutformatting.startsWith(name)
|
||||||
|
&& !nwithoutformatting.equals(Bukkit.getPlayer(
|
||||||
|
nicknames.get(nickname)).getName()))
|
||||||
|
e.getTabCompletions().add(nwithoutformatting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean DebugMode = false;
|
||||||
|
|
||||||
|
public void SendForDebug(String message) {
|
||||||
|
if (DebugMode) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.sendMessage("[DEBUG] " + message);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean ActiveF = false;
|
||||||
|
private int FCount = 0;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerMessage(AsyncPlayerChatEvent e) {
|
||||||
|
if (e.getMessage().equalsIgnoreCase("F")) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(e
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
if (!mp.PressedF && ActiveF) {
|
||||||
|
FCount++;
|
||||||
|
mp.PressedF = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.getMessage().startsWith(">"))
|
||||||
|
e.setMessage("§2" + e.getMessage());
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Channel c = ((Chat) Bukkit.getPluginManager().getPlugin("TownyChat"))
|
||||||
|
* .getChannelsHandler().getActiveChannel(e.getPlayer(),
|
||||||
|
* channelTypes.GLOBAL);
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* List<String> modes = ((Chat) Bukkit.getPluginManager().getPlugin(
|
||||||
|
* "TownyChat")).getTowny().getPlayerMode(e.getPlayer()); if
|
||||||
|
* (modes.size() == 0 || modes.contains("g")) {
|
||||||
|
*/
|
||||||
|
if (e.getFormat().contains("[g]")) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("tellraw @a [\"\"");
|
||||||
|
sb.append(",{\"text\":\"Hashtags:\"}");
|
||||||
|
int index = -1;
|
||||||
|
ArrayList<String> list = new ArrayList<String>();
|
||||||
|
while ((index = e.getMessage().indexOf("#", index + 1)) != -1) {
|
||||||
|
int index2 = e.getMessage().indexOf(" ", index + 1);
|
||||||
|
if (index2 == -1)
|
||||||
|
index2 = e.getMessage().length();
|
||||||
|
int index3 = e.getMessage().indexOf("#", index + 1);
|
||||||
|
if (index3 != -1 && index3 < index2) // A # occurs before a
|
||||||
|
// space
|
||||||
|
index2 = index3;
|
||||||
|
String original = e.getMessage().substring(index, index2);
|
||||||
|
list.add(original);
|
||||||
|
sb.append(",{\"text\":\" \"}");
|
||||||
|
sb.append(",{\"text\":\"");
|
||||||
|
sb.append(original);
|
||||||
|
sb.append("\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/");
|
||||||
|
sb.append(original.substring(1));
|
||||||
|
sb.append("\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}}");
|
||||||
|
}
|
||||||
|
for (String original : list)
|
||||||
|
e.setMessage(e.getMessage().replace(
|
||||||
|
original,
|
||||||
|
"§9"
|
||||||
|
+ original
|
||||||
|
+ (e.getMessage().startsWith("§2>") ? "§2"
|
||||||
|
: "§r")));
|
||||||
|
/*
|
||||||
|
* for (String original : list)
|
||||||
|
* System.out.println(e.getMessage().replace( original, "§9" +
|
||||||
|
* original + (e.getMessage().startsWith("§2>") ? "§2" : "§r")));
|
||||||
|
*/
|
||||||
|
|
||||||
|
sb.append("]");
|
||||||
|
|
||||||
|
if (list.size() > 0)
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Instance.getServer().getConsoleSender(),
|
||||||
|
sb.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Timer Ftimer;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerDeath(PlayerDeathEvent e) {
|
||||||
|
if (!Minigames.plugin.pdata.getMinigamePlayer(e.getEntity())
|
||||||
|
.isInMinigame() && new Random().nextBoolean()) {
|
||||||
|
if (Ftimer != null)
|
||||||
|
Ftimer.cancel();
|
||||||
|
ActiveF = true;
|
||||||
|
FCount = 0;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PressedF = false;
|
||||||
|
p.sendMessage("§bPress F to pay respects.§r");
|
||||||
|
}
|
||||||
|
Ftimer = new Timer();
|
||||||
|
TimerTask tt = new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (ActiveF) {
|
||||||
|
ActiveF = false;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
p.sendMessage("§b" + FCount + " "
|
||||||
|
+ (FCount == 1 ? "person" : "people")
|
||||||
|
+ " paid their respects.§r");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Ftimer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerItemPickup(PlayerPickupItemEvent e) {
|
||||||
|
// System.out.println("A");
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(e
|
||||||
|
.getPlayer());
|
||||||
|
// System.out.println("B");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* if (!e.getPlayer().isOp() && (!mp.isInMinigame() ||
|
||||||
|
* mp.getMinigame().getName(false)
|
||||||
|
* .equalsIgnoreCase(Commands.KittyCannonMinigame))) return;
|
||||||
|
*/
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame)))
|
||||||
|
return;
|
||||||
|
// System.out.println("C");
|
||||||
|
ItemStack item = e.getItem().getItemStack();
|
||||||
|
if (!item.getType().equals(Material.SKULL_ITEM)
|
||||||
|
&& !item.getType().equals(Material.SKULL))
|
||||||
|
return;
|
||||||
|
// System.out.println("D");
|
||||||
|
SkullMeta meta = (SkullMeta) item.getItemMeta();
|
||||||
|
if (!meta.getDisplayName().equals("§rOcelot Head")
|
||||||
|
|| !meta.getOwner().equals("MHF_Ocelot"))
|
||||||
|
return;
|
||||||
|
// System.out.println("E");
|
||||||
|
if (meta.getLore() == null || meta.getLore().size() == 0)
|
||||||
|
return;
|
||||||
|
// System.out.println("F");
|
||||||
|
ItemStack hat = e.getPlayer().getInventory().getHelmet();
|
||||||
|
if (!(hat != null
|
||||||
|
&& (hat.getType().equals(Material.SKULL) || hat.getType()
|
||||||
|
.equals(Material.SKULL_ITEM)) && ((SkullMeta) hat
|
||||||
|
.getItemMeta()).getDisplayName().equals("§rWolf Head")))
|
||||||
|
e.getPlayer().damage(1f * item.getAmount(),
|
||||||
|
Bukkit.getPlayer(meta.getLore().get(0)));
|
||||||
|
e.getItem().remove();
|
||||||
|
// System.out.println("G");
|
||||||
|
e.setCancelled(true);
|
||||||
|
// System.out.println("H");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,71 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
message.replaceAll(p.getName(), )
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
System.out.println("1");
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
System.out.println("2");
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
System.out.println("3");
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
System.out.println("4");
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
System.out.println("5");
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
System.out.println("6");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,364 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import tk.sznp.thebuttonautoflair.MaybeOfflinePlayer.FlairClassType;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,355 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.htmlcleaner.HtmlCleaner;
|
||||||
|
import org.htmlcleaner.TagNode;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
try {
|
||||||
|
System.out.println("Extracting necessary libraries...");
|
||||||
|
final File[] libs = new File[] { new File(getDataFolder(),
|
||||||
|
"htmlcleaner-2.16.jar") };
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
JarUtils.extractFromJar(lib.getName(),
|
||||||
|
lib.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
getLogger().warning(
|
||||||
|
"Failed to load plugin! Could not find lib: "
|
||||||
|
+ lib.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().disablePlugin(this);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
addClassPath(JarUtils.getJarUrl(lib));
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ThreadMethod() {
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.GetFromName(ign);
|
||||||
|
if (mp == null)
|
||||||
|
continue;
|
||||||
|
if (!mp.UserNames.contains(author))
|
||||||
|
mp.UserNames.add(author);
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
mp.FlairState = FlairStates.Commented;
|
||||||
|
ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DownloadFlair(MaybeOfflinePlayer mp)
|
||||||
|
throws MalformedURLException, IOException {
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users=" + mp.UserName)
|
||||||
|
.replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1)
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(mp, flair, flairclass, mp.UserName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair(MaybeOfflinePlayer p, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
p.UserName = username;
|
||||||
|
p.FlairState = FlairStates.Recognised;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
p.SetFlairColor(0xc);
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
p.SetFlairColor(0x6);
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
p.SetFlairColor(0xe);
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
p.SetFlairColor(0xa);
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
p.SetFlairColor(0x9);
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
p.SetFlairColor(0x7);
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "cant-press":
|
||||||
|
p.FlairColor = 0xf;
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if (CheckForJoinDate(p)) {
|
||||||
|
p.FlairColor = 0x7;
|
||||||
|
p.FlairTime = "--";
|
||||||
|
} else {
|
||||||
|
p.FlairColor = 0xf;
|
||||||
|
p.FlairTime = "--";
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (text.equals("-1"))
|
||||||
|
text = "--";
|
||||||
|
p.FlairTime = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean CheckForJoinDate(MaybeOfflinePlayer mp)
|
||||||
|
throws Exception {
|
||||||
|
URL url = new URL("https://www.reddit.com/u/" + mp.UserName);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
HtmlCleaner cleaner = new HtmlCleaner();
|
||||||
|
TagNode node = cleaner.clean(in);
|
||||||
|
|
||||||
|
node = node.getElementsByAttValue("class", "age", true, true)[0];
|
||||||
|
node = node.getElementsByName("time", false)[0];
|
||||||
|
String joindate = node.getAttributeByName("datetime");
|
||||||
|
SimpleDateFormat parserSDF = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
|
joindate = joindate.split("T")[0];
|
||||||
|
Date date = parserSDF.parse(joindate);
|
||||||
|
return date.before(new Calendar.Builder()
|
||||||
|
.setTimeZone(TimeZone.getTimeZone("UTC")).setDate(2015, 4, 1)
|
||||||
|
.build().getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ConfirmUserMessage(MaybeOfflinePlayer mp) {
|
||||||
|
Player p = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented) && p != null)
|
||||||
|
if (mp.UserNames.size() > 1)
|
||||||
|
p.sendMessage("§9Multiple Reddit users commented your name. You can select with /u accept.§r §6Type /u accept or /u ignore§r");
|
||||||
|
else
|
||||||
|
p.sendMessage("§9A Reddit user commented your name. Is that you?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) {
|
||||||
|
if (reload) {
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("announcemessages.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("thebuttonmc.yml");
|
||||||
|
if (file.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
yc.load(file);
|
||||||
|
MaybeOfflinePlayer.Load(yc);
|
||||||
|
PlayerListener.NotificationSound = yc
|
||||||
|
.getString("notificationsound");
|
||||||
|
PlayerListener.NotificationPitch = yc
|
||||||
|
.getDouble("notificationpitch");
|
||||||
|
AnnounceTime = yc.getInt("announcetime");
|
||||||
|
AnnounceMessages.addAll(yc.getStringList("announcements"));
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() {
|
||||||
|
System.out.println("Saving files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("thebuttonmc.yml");
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
MaybeOfflinePlayer.Save(yc);
|
||||||
|
yc.set("notificationsound", PlayerListener.NotificationSound);
|
||||||
|
yc.set("notificationpitch", PlayerListener.NotificationPitch);
|
||||||
|
yc.set("announcetime", AnnounceTime);
|
||||||
|
yc.set("announcements", AnnounceMessages);
|
||||||
|
yc.save(file);
|
||||||
|
System.out.println("The Button Minecraft plugin saved files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addClassPath(final URL url) throws IOException {
|
||||||
|
final URLClassLoader sysloader = (URLClassLoader) ClassLoader
|
||||||
|
.getSystemClassLoader();
|
||||||
|
final Class<URLClassLoader> sysclass = URLClassLoader.class;
|
||||||
|
try {
|
||||||
|
final Method method = sysclass.getDeclaredMethod("addURL",
|
||||||
|
new Class[] { URL.class });
|
||||||
|
method.setAccessible(true);
|
||||||
|
method.invoke(sysloader, new Object[] { url });
|
||||||
|
} catch (final Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
throw new IOException("Error adding " + url
|
||||||
|
+ " to system classloader");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,74 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
if(message.contains(p.getName()))
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 1.0f); //2015.08.12.
|
||||||
|
message = message.replaceAll(p.getName(), "§6"+p.getName()+"§r");
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
System.out.println("1");
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
System.out.println("2");
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
System.out.println("3");
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
System.out.println("4");
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
System.out.println("5");
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
System.out.println("6");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,368 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerChatTabCompleteEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerPickupItemEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener { // 2015.07.16.
|
||||||
|
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
||||||
|
|
||||||
|
public static boolean Enable = false; // 2015.08.29.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
|
Player p = event.getPlayer();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PlayerName = p.getName(); // 2015.10.17. 0:58
|
||||||
|
if (!mp.FlairState.equals(FlairStates.NoComment))
|
||||||
|
// if (false)
|
||||||
|
PluginMain.ConfirmUserMessage(mp); // 2015.08.09.
|
||||||
|
else { // 2015.07.20.
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
String json = "[\"\",{\"text\":\"If you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
json = "[\"\",{\"text\":\"If you don't want the flair, type /u ignore to prevent this message after next login.\",\"color\":\"aqua\"}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = mp;
|
||||||
|
timer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NICKNAME LOGIC */
|
||||||
|
|
||||||
|
UUID id = p.getUniqueId();
|
||||||
|
|
||||||
|
File f = new File("plugins/Essentials/userdata/" + id + ".yml");
|
||||||
|
if (f.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
try {
|
||||||
|
yc.load(f);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
String nickname = yc.getString("nickname");
|
||||||
|
if (nickname != null) {
|
||||||
|
nicknames.put(nickname, id);
|
||||||
|
|
||||||
|
if (Enable) {
|
||||||
|
if (!p.getName().equals("NorbiPeti")) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.chat("Hey, " + nickname + "!");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mp.RPMode = true; // 2015.08.25.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event) {
|
||||||
|
String deletenick = null;
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
UUID uuid = nicknames.get(nickname);
|
||||||
|
if (event.getPlayer().getUniqueId().equals(uuid)) {
|
||||||
|
deletenick = nickname;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (deletenick != null)
|
||||||
|
nicknames.remove(deletenick);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String NotificationSound; // 2015.08.14.
|
||||||
|
public static double NotificationPitch; // 2015.08.14.
|
||||||
|
|
||||||
|
public static boolean ShowRPTag = false; // 2015.08.31.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event) {
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
String flair = player.GetFormattedFlair();
|
||||||
|
String message = event.getMessage(); // 2015.08.08.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
|
||||||
|
String color = ""; // 2015.08.17.
|
||||||
|
if (message.contains(p.getName())) {
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId()); // 2015.08.17.
|
||||||
|
color = String.format("§%x", (mp.FlairColor == 0x00 ? 0xb
|
||||||
|
: mp.FlairColor)); // TODO: Quiz queue
|
||||||
|
}
|
||||||
|
|
||||||
|
message = message.replace(p.getName(), color + p.getName()
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
for (String n : nicknames.keySet()) {
|
||||||
|
Player p = null;
|
||||||
|
String nwithoutformatting = new String(n);
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (message.contains(nwithoutformatting)) {
|
||||||
|
p = Bukkit.getPlayer(nicknames.get(n));
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()); // 2015.08.17.
|
||||||
|
}
|
||||||
|
if (p != null) {
|
||||||
|
message = message.replace(nwithoutformatting, n
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
event.setMessage(message); // 2015.09.05.
|
||||||
|
|
||||||
|
// TODO: Flairs from Command Block The Button - Teams
|
||||||
|
//PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
event.getPlayer().setPlayerListName("");
|
||||||
|
|
||||||
|
event.setFormat(event
|
||||||
|
.getFormat()
|
||||||
|
.replace(
|
||||||
|
"{rptag}",
|
||||||
|
(player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "")
|
||||||
|
: "§8[OOC]§r"))
|
||||||
|
.replace("{buttonflair}", flair)
|
||||||
|
.replace(
|
||||||
|
"{isitwilds}",
|
||||||
|
(event.getPlayer().getWorld().getName()
|
||||||
|
.equalsIgnoreCase("wilds") ? "[PVP]" : ""))); // 2015.09.04.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onTabComplete(PlayerChatTabCompleteEvent e) {
|
||||||
|
String name = e.getLastToken();
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
String nwithoutformatting = nickname;
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (nwithoutformatting.startsWith(name)
|
||||||
|
&& !nwithoutformatting.equals(Bukkit.getPlayer(
|
||||||
|
nicknames.get(nickname)).getName()))
|
||||||
|
e.getTabCompletions().add(nwithoutformatting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean DebugMode = false;
|
||||||
|
|
||||||
|
public void SendForDebug(String message) {
|
||||||
|
if (DebugMode) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.sendMessage("[DEBUG] " + message);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean ActiveF = false;
|
||||||
|
private int FCount = 0;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerMessage(AsyncPlayerChatEvent e) {
|
||||||
|
if (e.getMessage().equalsIgnoreCase("F")) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(e
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
if (!mp.PressedF && ActiveF) {
|
||||||
|
FCount++;
|
||||||
|
mp.PressedF = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.getMessage().startsWith(">"))
|
||||||
|
e.setMessage("§2" + e.getMessage());
|
||||||
|
|
||||||
|
if (e.getMessage().equalsIgnoreCase("lol"))
|
||||||
|
Commands.Lastlol = MaybeOfflinePlayer.AllPlayers.get(e.getPlayer()
|
||||||
|
.getUniqueId());
|
||||||
|
|
||||||
|
if (e.getFormat().contains("[g]")) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("tellraw @a [\"\"");
|
||||||
|
sb.append(",{\"text\":\"Hashtags:\"}");
|
||||||
|
int index = -1;
|
||||||
|
ArrayList<String> list = new ArrayList<String>();
|
||||||
|
while ((index = e.getMessage().indexOf("#", index + 1)) != -1) {
|
||||||
|
int index2 = e.getMessage().indexOf(" ", index + 1);
|
||||||
|
if (index2 == -1)
|
||||||
|
index2 = e.getMessage().length();
|
||||||
|
int index3 = e.getMessage().indexOf("#", index + 1);
|
||||||
|
if (index3 != -1 && index3 < index2) // A # occurs before a
|
||||||
|
// space
|
||||||
|
index2 = index3;
|
||||||
|
String original = e.getMessage().substring(index, index2);
|
||||||
|
list.add(original);
|
||||||
|
sb.append(",{\"text\":\" \"}");
|
||||||
|
sb.append(",{\"text\":\"");
|
||||||
|
sb.append(original);
|
||||||
|
sb.append("\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/");
|
||||||
|
sb.append(original.substring(1));
|
||||||
|
sb.append("\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}}");
|
||||||
|
}
|
||||||
|
for (String original : list)
|
||||||
|
e.setMessage(e.getMessage().replace(
|
||||||
|
original,
|
||||||
|
"§9"
|
||||||
|
+ original
|
||||||
|
+ (e.getMessage().startsWith("§2>") ? "§2"
|
||||||
|
: "§r")));
|
||||||
|
/*
|
||||||
|
* for (String original : list)
|
||||||
|
* System.out.println(e.getMessage().replace( original, "§9" +
|
||||||
|
* original + (e.getMessage().startsWith("§2>") ? "§2" : "§r")));
|
||||||
|
*/
|
||||||
|
|
||||||
|
sb.append("]");
|
||||||
|
|
||||||
|
if (list.size() > 0)
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Instance.getServer().getConsoleSender(),
|
||||||
|
sb.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Timer Ftimer;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerDeath(PlayerDeathEvent e) {
|
||||||
|
if (!Minigames.plugin.pdata.getMinigamePlayer(e.getEntity())
|
||||||
|
.isInMinigame() && new Random().nextBoolean()) {
|
||||||
|
if (Ftimer != null)
|
||||||
|
Ftimer.cancel();
|
||||||
|
ActiveF = true;
|
||||||
|
FCount = 0;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PressedF = false;
|
||||||
|
p.sendMessage("§bPress F to pay respects.§r");
|
||||||
|
}
|
||||||
|
Ftimer = new Timer();
|
||||||
|
TimerTask tt = new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (ActiveF) {
|
||||||
|
ActiveF = false;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
p.sendMessage("§b" + FCount + " "
|
||||||
|
+ (FCount == 1 ? "person" : "people")
|
||||||
|
+ " paid their respects.§r");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Ftimer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerItemPickup(PlayerPickupItemEvent e) {
|
||||||
|
// System.out.println("A");
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(e
|
||||||
|
.getPlayer());
|
||||||
|
// System.out.println("B");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* if (!e.getPlayer().isOp() && (!mp.isInMinigame() ||
|
||||||
|
* mp.getMinigame().getName(false)
|
||||||
|
* .equalsIgnoreCase(Commands.KittyCannonMinigame))) return;
|
||||||
|
*/
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame)))
|
||||||
|
return;
|
||||||
|
// System.out.println("C");
|
||||||
|
ItemStack item = e.getItem().getItemStack();
|
||||||
|
if (!item.getType().equals(Material.SKULL_ITEM)
|
||||||
|
&& !item.getType().equals(Material.SKULL))
|
||||||
|
return;
|
||||||
|
// System.out.println("D");
|
||||||
|
SkullMeta meta = (SkullMeta) item.getItemMeta();
|
||||||
|
if (!meta.getDisplayName().equals("§rOcelot Head")
|
||||||
|
|| !meta.getOwner().equals("MHF_Ocelot"))
|
||||||
|
return;
|
||||||
|
// System.out.println("E");
|
||||||
|
if (meta.getLore() == null || meta.getLore().size() == 0)
|
||||||
|
return;
|
||||||
|
// System.out.println("F");
|
||||||
|
ItemStack hat = e.getPlayer().getInventory().getHelmet();
|
||||||
|
if (!(hat != null
|
||||||
|
&& (hat.getType().equals(Material.SKULL) || hat.getType()
|
||||||
|
.equals(Material.SKULL_ITEM)) && ((SkullMeta) hat
|
||||||
|
.getItemMeta()).getDisplayName().equals("§rWolf Head")))
|
||||||
|
e.getPlayer().damage(1f * item.getAmount(),
|
||||||
|
Bukkit.getPlayer(meta.getLore().get(0)));
|
||||||
|
e.getItem().remove();
|
||||||
|
// System.out.println("G");
|
||||||
|
e.setCancelled(true);
|
||||||
|
// System.out.println("H");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,73 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
message = message.replaceAll(p.getName(), "§6"+p.getName()+"§r");
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0, 1.0); //2015.08.12.
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
System.out.println("1");
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
System.out.println("2");
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
System.out.println("3");
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
System.out.println("4");
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
System.out.println("5");
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
System.out.println("6");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,216 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,371 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerChatTabCompleteEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerPickupItemEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener { // 2015.07.16.
|
||||||
|
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
||||||
|
|
||||||
|
public static boolean Enable = false; // 2015.08.29.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
|
Player p = event.getPlayer();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PlayerName = p.getName(); // 2015.10.17. 0:58
|
||||||
|
if (!mp.FlairState.equals(FlairStates.NoComment))
|
||||||
|
// if (false)
|
||||||
|
PluginMain.ConfirmUserMessage(mp); // 2015.08.09.
|
||||||
|
else { // 2015.07.20.
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
String json = "[\"\",{\"text\":\"If you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
json = "[\"\",{\"text\":\"If you don't want the flair, type /u ignore to prevent this message after next login.\",\"color\":\"aqua\"}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = mp;
|
||||||
|
timer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NICKNAME LOGIC */
|
||||||
|
|
||||||
|
UUID id = p.getUniqueId();
|
||||||
|
|
||||||
|
File f = new File("plugins/Essentials/userdata/" + id + ".yml");
|
||||||
|
if (f.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
try {
|
||||||
|
yc.load(f);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
String nickname = yc.getString("nickname");
|
||||||
|
if (nickname != null) {
|
||||||
|
nicknames.put(nickname, id);
|
||||||
|
|
||||||
|
if (Enable) {
|
||||||
|
if (!p.getName().equals("NorbiPeti")) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.chat("Hey, " + nickname + "!");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mp.RPMode = true; // 2015.08.25.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event) {
|
||||||
|
String deletenick = null;
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
UUID uuid = nicknames.get(nickname);
|
||||||
|
if (event.getPlayer().getUniqueId().equals(uuid)) {
|
||||||
|
deletenick = nickname;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (deletenick != null)
|
||||||
|
nicknames.remove(deletenick);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String NotificationSound; // 2015.08.14.
|
||||||
|
public static double NotificationPitch; // 2015.08.14.
|
||||||
|
|
||||||
|
public static boolean ShowRPTag = false; // 2015.08.31.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event) {
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
String flair = player.GetFormattedFlair();
|
||||||
|
String message = event.getMessage(); // 2015.08.08.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
|
||||||
|
String color = ""; // 2015.08.17.
|
||||||
|
if (message.contains(p.getName())) {
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId()); // 2015.08.17.
|
||||||
|
color = String.format("§%x", (mp.FlairColor == 0x00 ? 0xb
|
||||||
|
: mp.FlairColor)); //TODO: Quiz queue
|
||||||
|
//TODO: Flairs from Command Block The Button - Teams
|
||||||
|
}
|
||||||
|
|
||||||
|
message = message.replace(p.getName(), color + p.getName()
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
for (String n : nicknames.keySet()) {
|
||||||
|
Player p = null;
|
||||||
|
String nwithoutformatting = new String(n);
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (message.contains(nwithoutformatting)) {
|
||||||
|
p = Bukkit.getPlayer(nicknames.get(n));
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()); // 2015.08.17.
|
||||||
|
}
|
||||||
|
if (p != null) {
|
||||||
|
message = message.replace(nwithoutformatting, n
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
event.setMessage(message); // 2015.09.05.
|
||||||
|
|
||||||
|
event.setFormat(event
|
||||||
|
.getFormat()
|
||||||
|
.replace(
|
||||||
|
"{rptag}",
|
||||||
|
(player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "")
|
||||||
|
: "§8[OOC]§r"))
|
||||||
|
.replace("{buttonflair}", flair)
|
||||||
|
.replace(
|
||||||
|
"{isitwilds}",
|
||||||
|
(event.getPlayer().getWorld().getName()
|
||||||
|
.equalsIgnoreCase("wilds") ? "[PVP]" : ""))); // 2015.09.04.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onTabComplete(PlayerChatTabCompleteEvent e) {
|
||||||
|
String name = e.getLastToken();
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
String nwithoutformatting = nickname;
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (nwithoutformatting.startsWith(name)
|
||||||
|
&& !nwithoutformatting.equals(Bukkit.getPlayer(
|
||||||
|
nicknames.get(nickname)).getName()))
|
||||||
|
e.getTabCompletions().add(nwithoutformatting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean DebugMode = false;
|
||||||
|
|
||||||
|
public void SendForDebug(String message) {
|
||||||
|
if (DebugMode) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.sendMessage("[DEBUG] " + message);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean ActiveF = false;
|
||||||
|
private int FCount = 0;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerMessage(AsyncPlayerChatEvent e) {
|
||||||
|
if (e.getMessage().equalsIgnoreCase("F")) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(e
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
if (!mp.PressedF && ActiveF) {
|
||||||
|
FCount++;
|
||||||
|
mp.PressedF = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.getMessage().startsWith(">"))
|
||||||
|
e.setMessage("§2" + e.getMessage());
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Channel c = ((Chat) Bukkit.getPluginManager().getPlugin("TownyChat"))
|
||||||
|
* .getChannelsHandler().getActiveChannel(e.getPlayer(),
|
||||||
|
* channelTypes.GLOBAL);
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* List<String> modes = ((Chat) Bukkit.getPluginManager().getPlugin(
|
||||||
|
* "TownyChat")).getTowny().getPlayerMode(e.getPlayer()); if
|
||||||
|
* (modes.size() == 0 || modes.contains("g")) {
|
||||||
|
*/
|
||||||
|
if (e.getFormat().contains("[g]")) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("tellraw @a [\"\"");
|
||||||
|
sb.append(",{\"text\":\"Hashtags:\"}");
|
||||||
|
int index = -1;
|
||||||
|
ArrayList<String> list = new ArrayList<String>();
|
||||||
|
while ((index = e.getMessage().indexOf("#", index + 1)) != -1) {
|
||||||
|
int index2 = e.getMessage().indexOf(" ", index + 1);
|
||||||
|
if (index2 == -1)
|
||||||
|
index2 = e.getMessage().length();
|
||||||
|
int index3 = e.getMessage().indexOf("#", index + 1);
|
||||||
|
if (index3 != -1 && index3 < index2) // A # occurs before a
|
||||||
|
// space
|
||||||
|
index2 = index3;
|
||||||
|
String original = e.getMessage().substring(index, index2);
|
||||||
|
list.add(original);
|
||||||
|
sb.append(",{\"text\":\" \"}");
|
||||||
|
sb.append(",{\"text\":\"");
|
||||||
|
sb.append(original);
|
||||||
|
sb.append("\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/");
|
||||||
|
sb.append(original.substring(1));
|
||||||
|
sb.append("\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}}");
|
||||||
|
}
|
||||||
|
for (String original : list)
|
||||||
|
e.setMessage(e.getMessage().replace(
|
||||||
|
original,
|
||||||
|
"§9"
|
||||||
|
+ original
|
||||||
|
+ (e.getMessage().startsWith("§2>") ? "§2"
|
||||||
|
: "§r")));
|
||||||
|
/*
|
||||||
|
* for (String original : list)
|
||||||
|
* System.out.println(e.getMessage().replace( original, "§9" +
|
||||||
|
* original + (e.getMessage().startsWith("§2>") ? "§2" : "§r")));
|
||||||
|
*/
|
||||||
|
|
||||||
|
sb.append("]");
|
||||||
|
|
||||||
|
if (list.size() > 0)
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Instance.getServer().getConsoleSender(),
|
||||||
|
sb.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Timer Ftimer;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerDeath(PlayerDeathEvent e) {
|
||||||
|
if (!Minigames.plugin.pdata.getMinigamePlayer(e.getEntity())
|
||||||
|
.isInMinigame() && new Random().nextBoolean()) {
|
||||||
|
if (Ftimer != null)
|
||||||
|
Ftimer.cancel();
|
||||||
|
ActiveF = true;
|
||||||
|
FCount = 0;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PressedF = false;
|
||||||
|
p.sendMessage("§bPress F to pay respects.§r");
|
||||||
|
}
|
||||||
|
Ftimer = new Timer();
|
||||||
|
TimerTask tt = new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (ActiveF) {
|
||||||
|
ActiveF = false;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
p.sendMessage("§b" + FCount + " "
|
||||||
|
+ (FCount == 1 ? "person" : "people")
|
||||||
|
+ " paid their respects.§r");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Ftimer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerItemPickup(PlayerPickupItemEvent e) {
|
||||||
|
// System.out.println("A");
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(e
|
||||||
|
.getPlayer());
|
||||||
|
// System.out.println("B");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* if (!e.getPlayer().isOp() && (!mp.isInMinigame() ||
|
||||||
|
* mp.getMinigame().getName(false)
|
||||||
|
* .equalsIgnoreCase(Commands.KittyCannonMinigame))) return;
|
||||||
|
*/
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame)))
|
||||||
|
return;
|
||||||
|
// System.out.println("C");
|
||||||
|
ItemStack item = e.getItem().getItemStack();
|
||||||
|
if (!item.getType().equals(Material.SKULL_ITEM)
|
||||||
|
&& !item.getType().equals(Material.SKULL))
|
||||||
|
return;
|
||||||
|
// System.out.println("D");
|
||||||
|
SkullMeta meta = (SkullMeta) item.getItemMeta();
|
||||||
|
if (!meta.getDisplayName().equals("§rOcelot Head")
|
||||||
|
|| !meta.getOwner().equals("MHF_Ocelot"))
|
||||||
|
return;
|
||||||
|
// System.out.println("E");
|
||||||
|
if (meta.getLore() == null || meta.getLore().size() == 0)
|
||||||
|
return;
|
||||||
|
// System.out.println("F");
|
||||||
|
ItemStack hat = e.getPlayer().getInventory().getHelmet();
|
||||||
|
if (!(hat != null
|
||||||
|
&& (hat.getType().equals(Material.SKULL) || hat.getType()
|
||||||
|
.equals(Material.SKULL_ITEM)) && ((SkullMeta) hat
|
||||||
|
.getItemMeta()).getDisplayName().equals("§rWolf Head")))
|
||||||
|
e.getPlayer().damage(1f * item.getAmount(),
|
||||||
|
Bukkit.getPlayer(meta.getLore().get(0)));
|
||||||
|
e.getItem().remove();
|
||||||
|
// System.out.println("G");
|
||||||
|
e.setCancelled(true);
|
||||||
|
// System.out.println("H");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,326 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
Load(false);
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,73 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 1.0f); //2015.08.12.
|
||||||
|
message = message.replaceAll(p.getName(), "§6"+p.getName()+"§r");
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
System.out.println("1");
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
System.out.println("2");
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
System.out.println("3");
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
System.out.println("4");
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
System.out.println("5");
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
System.out.println("6");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,360 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import tk.sznp.thebuttonautoflair.MaybeOfflinePlayer.FlairClassType;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
{
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+username+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true);
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,362 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import tk.sznp.thebuttonautoflair.MaybeOfflinePlayer.FlairClassType;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p)
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+username+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,216 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg);
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,295 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(!p.CommentedOnReddit && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if(!p.FlairRecognised && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{ //2015.08.10.
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
player.sendMessage("§9Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
//String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§9You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§7(--s)§r");
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type or your flair type is known.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§r(??s)§r");
|
||||||
|
break;
|
||||||
|
case "opme": //2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, isn't it?"); //Sometimes I'm bored too
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading Auto-flair plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
//if(mp.Flair!=null)
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
{
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§9Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName().equals("NorbiPeti"))
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer=player; //2015.08.09.
|
||||||
|
SendMessage(player, "§9Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; //<-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if(ReloadPlayer==player)
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player, "§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); //2015.08.09.
|
||||||
|
SendMessage(player, "§9Saved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": //2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
SendMessage(player, "Flair decided: "+p.FlairDecided);
|
||||||
|
SendMessage(player, "Flair recognised: "+p.FlairRecognised);
|
||||||
|
SendMessage(player, "Commented on Reddit: "+p.CommentedOnReddit);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
//System.out.println(message);
|
||||||
|
PluginMain.Console.sendMessage(message); //2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
private static void SetPlayerFlair(Player player, MaybeOfflinePlayer targetplayer, String flair)
|
||||||
|
{ //2015.08.09.
|
||||||
|
flair=flair.replace('&', '§');
|
||||||
|
targetplayer.Flair=flair;
|
||||||
|
targetplayer.CommentedOnReddit=true; //Or at least has a flair in some way
|
||||||
|
if(!PluginMain.RemoveLineFromFile("customflairs.txt", targetplayer.PlayerName))
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cError removing previous custom flair!§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
File file=new File("customflairs.txt");
|
||||||
|
try {
|
||||||
|
BufferedWriter bw;
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
bw.write(targetplayer.PlayerName+targetplayer.Flair+"\n");
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
SendMessage(player, "§9The flair has been set. Player: "+targetplayer.PlayerName+" Flair: "+flair+"§r");
|
||||||
|
}
|
||||||
|
private static void DoSetFlair(Player player, String[] args)
|
||||||
|
{
|
||||||
|
//args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if(args.length<4)
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cUsage: /u admin setflair <playername> <flair>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, MaybeOfflinePlayer.AddPlayerIfNeeded(args[2]), args[3]);
|
||||||
|
}
|
||||||
|
private static void DoUpdatePlugin(Player player)
|
||||||
|
{ //2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL("https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File("plugins/TheButtonAutoFlair.jar"));
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
}
|
||||||
|
catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,298 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(!p.CommentedOnReddit && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if(!p.FlairRecognised && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{ //2015.08.10.
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
player.sendMessage("§9Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
//String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§9You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§7(--s)§r");
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type or your flair type is known.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§r(??s)§r");
|
||||||
|
break;
|
||||||
|
case "opme": //2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, isn't it?"); //Sometimes I'm bored too
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
//if(mp.Flair!=null)
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
{
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§9Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName().equals("NorbiPeti"))
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer=player; //2015.08.09.
|
||||||
|
SendMessage(player, "§9Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; //<-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if(ReloadPlayer==player)
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player, "§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); //2015.08.09.
|
||||||
|
SendMessage(player, "§9Saved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": //2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
SendMessage(player, "Flair decided: "+p.FlairDecided);
|
||||||
|
SendMessage(player, "Flair recognised: "+p.FlairRecognised);
|
||||||
|
SendMessage(player, "Commented on Reddit: "+p.CommentedOnReddit);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
//System.out.println(message);
|
||||||
|
PluginMain.Console.sendMessage(message); //2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
private static void SetPlayerFlair(Player player, MaybeOfflinePlayer targetplayer, String flair)
|
||||||
|
{ //2015.08.09.
|
||||||
|
flair=flair.replace('&', '§');
|
||||||
|
targetplayer.Flair=flair;
|
||||||
|
targetplayer.CommentedOnReddit=true; //Or at least has a flair in some way
|
||||||
|
if(!PluginMain.RemoveLineFromFile("customflairs.txt", targetplayer.PlayerName))
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cError removing previous custom flair!§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
File file=new File("customflairs.txt");
|
||||||
|
try {
|
||||||
|
BufferedWriter bw;
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
bw.write(targetplayer.PlayerName+targetplayer.Flair+"\n");
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
SendMessage(player, "§9The flair has been set. Player: "+targetplayer.PlayerName+" Flair: "+flair+"§r");
|
||||||
|
}
|
||||||
|
private static void DoSetFlair(Player player, String[] args)
|
||||||
|
{
|
||||||
|
//args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if(args.length<4)
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cUsage: /u admin setflair <playername> <flair>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, MaybeOfflinePlayer.AddPlayerIfNeeded(args[2]), args[3]);
|
||||||
|
}
|
||||||
|
private static void DoUpdatePlugin(Player player)
|
||||||
|
{ //2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL("https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File("plugins/TheButtonAutoFlair.jar"));
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
}
|
||||||
|
catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,363 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,297 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(!p.CommentedOnReddit && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if(!p.FlairRecognised && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{ //2015.08.10.
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
player.sendMessage("§9Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
//String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§9You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§7(--s)§r");
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type or your flair type is known.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§r(??s)§r");
|
||||||
|
break;
|
||||||
|
case "opme": //2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, isn't it?"); //Sometimes I'm bored too
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
//if(mp.Flair!=null)
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
{
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§9Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName().equals("NorbiPeti"))
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer=player; //2015.08.09.
|
||||||
|
SendMessage(player, "§9Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; //<-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if(ReloadPlayer==player)
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player, "§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); //2015.08.09.
|
||||||
|
SendMessage(player, "§6Saved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": //2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
SendMessage(player, "Flair decided: "+p.FlairDecided);
|
||||||
|
SendMessage(player, "Flair recognised: "+p.FlairRecognised);
|
||||||
|
SendMessage(player, "Commented on Reddit: "+p.CommentedOnReddit);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
private static void SetPlayerFlair(Player player, MaybeOfflinePlayer targetplayer, String flair)
|
||||||
|
{ //2015.08.09.
|
||||||
|
flair=flair.replace('&', '§');
|
||||||
|
targetplayer.Flair=flair;
|
||||||
|
targetplayer.CommentedOnReddit=true; //Or at least has a flair in some way
|
||||||
|
if(!PluginMain.RemoveLineFromFile("customflairs.txt", targetplayer.PlayerName))
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cError removing previous custom flair!§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
File file=new File("customflairs.txt");
|
||||||
|
try {
|
||||||
|
BufferedWriter bw;
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
bw.write(targetplayer.PlayerName+targetplayer.Flair+"\n");
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
SendMessage(player, "§9The flair has been set. Player: "+targetplayer.PlayerName+" Flair: "+flair+"§r");
|
||||||
|
}
|
||||||
|
private static void DoSetFlair(Player player, String[] args)
|
||||||
|
{
|
||||||
|
//args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if(args.length<4)
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cUsage: /u admin setflair <playername> <flair>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, MaybeOfflinePlayer.AddPlayerIfNeeded(args[2]), args[3]);
|
||||||
|
}
|
||||||
|
private static void DoUpdatePlugin(Player player)
|
||||||
|
{ //2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL("https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File("plugins/TheButtonAutoFlair.jar"));
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
}
|
||||||
|
catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,599 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.command.BlockCommandSender;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Ocelot;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.potion.PotionEffectType;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.Mob;
|
||||||
|
import com.earth2me.essentials.Mob.MobException;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer Lastlol = null;
|
||||||
|
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label,
|
||||||
|
String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
switch (cmd.getName()) {
|
||||||
|
case "u": {
|
||||||
|
if (args.length < 1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(player
|
||||||
|
.getUniqueId());
|
||||||
|
switch (args[0].toLowerCase()) {
|
||||||
|
case "accept": {
|
||||||
|
if (args.length < 2 && p.UserNames.size() > 1) {
|
||||||
|
player.sendMessage("§9Multiple users commented your name. §bPlease pick one using /u accept <username>");
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
player.sendMessage(sb.toString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)
|
||||||
|
|| p.UserNames.size() == 0) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1 && !p.UserNames.contains(args[1])) {
|
||||||
|
player.sendMessage("§cError: Unknown name: " + args[1]
|
||||||
|
+ "§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.Working) {
|
||||||
|
player.sendMessage("§cError: Something is already in progress.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((args.length > 1 ? args[1] : p.UserNames.get(0))
|
||||||
|
.equals(p.UserName)) {
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1)
|
||||||
|
p.UserName = args[1];
|
||||||
|
else
|
||||||
|
p.UserName = p.UserNames.get(0);
|
||||||
|
|
||||||
|
player.sendMessage("§bObtaining flair...");
|
||||||
|
p.Working = true;
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
PluginMain.Instance.DownloadFlair(mp);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
Player player = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask an admin to set it for you. Also, prepare a comment on /r/thebutton, if possible.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String flair = mp.GetFormattedFlair();
|
||||||
|
mp.FlairState = FlairStates.Accepted;
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
player.sendMessage("§bYour flair has been set:§r "
|
||||||
|
+ flair);
|
||||||
|
mp.Working = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = p;
|
||||||
|
timer.schedule(tt, 20);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore": {
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!p.FlairState.equals(FlairStates.Ignored)) {
|
||||||
|
p.FlairState = FlairStates.Ignored;
|
||||||
|
p.FlairTime = "";
|
||||||
|
p.UserName = "";
|
||||||
|
player.sendMessage("§bYou have removed your flair. You can still use /u accept to get one.§r");
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou already removed your flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "admin": // 2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "opme": // 2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, wouldn't it?"); // Sometimes
|
||||||
|
// I'm
|
||||||
|
// bored
|
||||||
|
// too
|
||||||
|
break;
|
||||||
|
case "announce":
|
||||||
|
DoAnnounce(player, args, null);
|
||||||
|
break;
|
||||||
|
case "name":
|
||||||
|
if (args.length == 1) {
|
||||||
|
player.sendMessage("§cUsage: /u name <playername>§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer
|
||||||
|
.GetFromName(args[1]);
|
||||||
|
if (mp == null) {
|
||||||
|
player.sendMessage("§cUnknown user: " + args[1]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
player.sendMessage("§bUsername of " + args[1] + ": "
|
||||||
|
+ mp.UserName);
|
||||||
|
break;
|
||||||
|
case "enable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = true;
|
||||||
|
player.sendMessage("Enabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "disable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = false;
|
||||||
|
player.sendMessage("Disabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "kittycannon":
|
||||||
|
DoKittyCannon(player, args);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "nrp":
|
||||||
|
case "ooc":
|
||||||
|
if (args.length == 0) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = false;
|
||||||
|
String message = "";
|
||||||
|
for (String arg : args)
|
||||||
|
message += arg + " ";
|
||||||
|
player.chat(message.substring(0, message.length() - 1));
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = true;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
case "unlol": // TODO: Unlol
|
||||||
|
Player p=null;
|
||||||
|
if(Lastlol!=null || (p=Bukkit.getPlayer(Lastlol.UUID))!=null)
|
||||||
|
{
|
||||||
|
p.addPotionEffect(new PotionEffect(PotionEffectType.BLINDNESS, 10, 5, false, false));
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("admin")) // 2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); // 2015.08.09.
|
||||||
|
return true; // 2015.08.09.
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("announce")) {
|
||||||
|
if (sender instanceof BlockCommandSender)
|
||||||
|
DoAnnounce(null, args, (BlockCommandSender) sender);
|
||||||
|
else
|
||||||
|
DoAnnounce(null, args, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoReload(Player player) { // 2015.07.20.
|
||||||
|
try {
|
||||||
|
PluginMain.Console
|
||||||
|
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); // 2015.08.09.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (mp.FlairState.equals(FlairStates.Recognised)
|
||||||
|
|| mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
String msg = "§bNote: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; // 2015.08.09.
|
||||||
|
p.sendMessage(msg); // 2015.08.09.
|
||||||
|
}
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading done!§r");
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
if (player != null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Player ReloadPlayer; // 2015.08.09.
|
||||||
|
|
||||||
|
private static String DoAdminUsage = "§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin|togglerpshow|toggledebug|savepos|loadpos§r";
|
||||||
|
|
||||||
|
private static void DoAdmin(Player player, String[] args) { // 2015.08.09.
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// args[0] is "admin"
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer = player; // 2015.08.09.
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§bMake sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; // <-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if (ReloadPlayer == player)
|
||||||
|
DoReload(player); // 2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); // 2015.08.09.
|
||||||
|
SendMessage(player,
|
||||||
|
"§bSaved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": // 2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
case "togglerpshow":
|
||||||
|
PlayerListener.ShowRPTag = !PlayerListener.ShowRPTag;
|
||||||
|
SendMessage(player, "RP tag showing "
|
||||||
|
+ (PlayerListener.ShowRPTag ? "enabled" : "disabled"));
|
||||||
|
break;
|
||||||
|
case "toggledebug":
|
||||||
|
PlayerListener.DebugMode = !PlayerListener.DebugMode;
|
||||||
|
SendMessage(player, "DebugMode: " + PlayerListener.DebugMode);
|
||||||
|
break;
|
||||||
|
case "savepos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "loadpos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "updatedynmap":
|
||||||
|
DoUpdateDynmap(player, args);
|
||||||
|
default:
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.GetFromName(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SendMessage(player, "Player name: " + p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: " + p.GetFormattedFlair());
|
||||||
|
SendMessage(player, "Username: " + p.UserName);
|
||||||
|
SendMessage(player, "Flair state: " + p.FlairState);
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
SendMessage(player, sb.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SendMessage(Player player, String message) { // 2015.08.09.
|
||||||
|
if (player == null)
|
||||||
|
PluginMain.Console.sendMessage(message); // 2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoGetLastError(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if (PluginMain.LastException != null) {
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException = null;
|
||||||
|
} else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SetPlayerFlair(Player player,
|
||||||
|
MaybeOfflinePlayer targetplayer, short flaircolor, String flairtime) {
|
||||||
|
targetplayer.FlairColor = flaircolor;
|
||||||
|
targetplayer.FlairTime = flairtime;
|
||||||
|
targetplayer.FlairState = FlairStates.Accepted;
|
||||||
|
targetplayer.UserName = "";
|
||||||
|
SendMessage(player,
|
||||||
|
"§bThe flair has been set. Player: " + targetplayer.PlayerName
|
||||||
|
+ " Flair: " + targetplayer.GetFormattedFlair() + "§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoSetFlair(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if (args.length < 4) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = Bukkit.getPlayer(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
SendMessage(player, "§cPLayer not found.&r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
short flaircolor = 0x00;
|
||||||
|
try {
|
||||||
|
flaircolor = Short.parseShort(args[3], 16);
|
||||||
|
} catch (Exception e) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cFlaircolor must be a hexadecimal number (don't include &).");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player,
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()),
|
||||||
|
flaircolor, (args.length < 5 ? "" : args[4]));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdatePlugin(Player player) { // 2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL(
|
||||||
|
"https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File(
|
||||||
|
"plugins/TheButtonAutoFlair.jar"));
|
||||||
|
PluginUpdated = true; // 2015.08.31.
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoAnnounce(Player player, String[] args,
|
||||||
|
BlockCommandSender commandblock) {
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "add":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce add <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
for (int i = 2; i < args.length; i++) {
|
||||||
|
sb.append(args[i]);
|
||||||
|
if (i != args.length - 1)
|
||||||
|
sb.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage = sb.toString().replace('&', '§');
|
||||||
|
PluginMain.AnnounceMessages.add(finalmessage);
|
||||||
|
SendMessage(player, "§bAnnouncement added.§r");
|
||||||
|
break;
|
||||||
|
case "remove":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce remove <index>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceMessages.remove(Integer.parseInt(args[2]));
|
||||||
|
break;
|
||||||
|
case "settime":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u announce settime <minutes>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceTime = Integer.parseInt(args[2]) * 60 * 1000;
|
||||||
|
SendMessage(player, "Time set between announce messages");
|
||||||
|
break;
|
||||||
|
case "list":
|
||||||
|
SendMessage(player, "§bList of announce messages:§r");
|
||||||
|
SendMessage(player, "§bFormat: [index] message§r");
|
||||||
|
int i = 0;
|
||||||
|
for (String message : PluginMain.AnnounceMessages)
|
||||||
|
SendMessage(player, "[" + i++ + "] " + message);
|
||||||
|
SendMessage(player,
|
||||||
|
"§bCurrent wait time between announcements: "
|
||||||
|
+ PluginMain.AnnounceTime / 60 / 1000
|
||||||
|
+ " minute(s)§r");
|
||||||
|
break;
|
||||||
|
case "edit":
|
||||||
|
if (commandblock == null) {
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§cError: This command can only be used from a command block. Use /u announce remove.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (args.length < 4) {
|
||||||
|
commandblock
|
||||||
|
.sendMessage("§cUsage: /u announce edit <index> <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb1 = new StringBuilder();
|
||||||
|
for (int i1 = 3; i1 < args.length; i1++) {
|
||||||
|
sb1.append(args[i1]);
|
||||||
|
if (i1 != args.length - 1)
|
||||||
|
sb1.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage1 = sb1.toString().replace('&', '§');
|
||||||
|
int index = Integer.parseInt(args[2]);
|
||||||
|
if (index > 100)
|
||||||
|
break;
|
||||||
|
while (PluginMain.AnnounceMessages.size() <= index)
|
||||||
|
PluginMain.AnnounceMessages.add("");
|
||||||
|
PluginMain.AnnounceMessages.set(Integer.parseInt(args[2]),
|
||||||
|
finalmessage1);
|
||||||
|
commandblock.sendMessage("Announcement edited.");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
private static void DoSaveLoadPos(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "savepos|loadpos"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = null;
|
||||||
|
try {
|
||||||
|
p = Bukkit.getPlayer(args[2]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
if (!MaybeOfflinePlayer.AllPlayers.containsKey(p.getUniqueId())) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer is not online: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (args[1].equalsIgnoreCase("savepos")) {
|
||||||
|
mp.SavedLocation = p.getLocation();
|
||||||
|
} else if (args[1].equalsIgnoreCase("loadpos")) {
|
||||||
|
if (mp.SavedLocation != null)
|
||||||
|
p.teleport(mp.SavedLocation);
|
||||||
|
} else {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// SendMessage(player, "Player " + p.getName() +
|
||||||
|
// " position saved/loaded.");s
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdateDynmap(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "updatedynmap"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin updatedynmap <password>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Random random = new Random();
|
||||||
|
|
||||||
|
public static String KittyCannonMinigame = "KittyCannon";
|
||||||
|
|
||||||
|
private static void DoKittyCannon(Player player, String[] args) {
|
||||||
|
if (player == null) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cThis command can only be used by a player.§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(player);
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame))) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou can only use KittyCannon in it's minigame!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
final Mob cat = Mob.OCELOT;
|
||||||
|
final Ocelot ocelot = (Ocelot) cat.spawn(player.getWorld(),
|
||||||
|
player.getServer(), player.getEyeLocation());
|
||||||
|
if (ocelot == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final ArrayList<String> lore = new ArrayList<>();
|
||||||
|
lore.add(player.getName());
|
||||||
|
final int i = random.nextInt(Ocelot.Type.values().length);
|
||||||
|
ocelot.setCatType(Ocelot.Type.values()[i]);
|
||||||
|
ocelot.setTamed(true);
|
||||||
|
ocelot.setBaby();
|
||||||
|
ocelot.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.DAMAGE_RESISTANCE, 5, 5));
|
||||||
|
ocelot.setVelocity(player.getEyeLocation().getDirection()
|
||||||
|
.multiply(2));
|
||||||
|
Bukkit.getScheduler().scheduleSyncDelayedTask(PluginMain.Instance,
|
||||||
|
new Runnable() {
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
final Location loc = ocelot.getLocation();
|
||||||
|
ocelot.remove();
|
||||||
|
loc.getWorld().createExplosion(loc, 0F);
|
||||||
|
final ItemStack head = new ItemStack(
|
||||||
|
Material.SKULL_ITEM, 1, (short) 3, (byte) 3);
|
||||||
|
SkullMeta im = (SkullMeta) head.getItemMeta();
|
||||||
|
im.setDisplayName("§rOcelot Head");
|
||||||
|
im.setOwner("MHF_Ocelot");
|
||||||
|
im.setLore(lore);
|
||||||
|
head.setItemMeta(im);
|
||||||
|
loc.getWorld().dropItem(loc, head);
|
||||||
|
}
|
||||||
|
}, 20);
|
||||||
|
} catch (MobException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true);
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,355 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.htmlcleaner.HtmlCleaner;
|
||||||
|
import org.htmlcleaner.TagNode;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
try {
|
||||||
|
System.out.println("Extracting necessary libraries...");
|
||||||
|
final File[] libs = new File[] { new File(getDataFolder(),
|
||||||
|
"htmlcleaner-2.16.jar") };
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
JarUtils.extractFromJar(lib.getName(),
|
||||||
|
lib.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
getLogger().warning(
|
||||||
|
"Failed to load plugin! Could not find lib: "
|
||||||
|
+ lib.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().disablePlugin(this);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
addClassPath(JarUtils.getJarUrl(lib));
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ThreadMethod() {
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.GetFromName(ign);
|
||||||
|
if (mp == null)
|
||||||
|
continue;
|
||||||
|
if (!mp.UserNames.contains(author))
|
||||||
|
mp.UserNames.add(author);
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
mp.FlairState = FlairStates.Commented;
|
||||||
|
ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DownloadFlair(MaybeOfflinePlayer mp)
|
||||||
|
throws MalformedURLException, IOException {
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users=" + mp.UserName)
|
||||||
|
.replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1)
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(mp, flair, flairclass, mp.UserName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair(MaybeOfflinePlayer p, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
p.UserName = username;
|
||||||
|
p.FlairState = FlairStates.Recognised;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
p.FlairColor = 0xc;
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
p.FlairColor = 0x6;
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
p.FlairColor = 0xe;
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
p.FlairColor = 0xa;
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
p.FlairColor = 0x9;
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
p.FlairColor = 0x5;
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
p.FlairColor = 0x7;
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
p.FlairColor = 0x5;
|
||||||
|
break;
|
||||||
|
case "cant-press":
|
||||||
|
p.FlairColor = 0xf;
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if (CheckForJoinDate(p)) {
|
||||||
|
p.FlairColor = 0x7;
|
||||||
|
p.FlairTime = "--";
|
||||||
|
} else {
|
||||||
|
p.FlairColor = 0xf;
|
||||||
|
p.FlairTime = "--";
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (text.equals("-1"))
|
||||||
|
text = "--";
|
||||||
|
p.FlairTime = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean CheckForJoinDate(MaybeOfflinePlayer mp)
|
||||||
|
throws Exception {
|
||||||
|
URL url = new URL("https://www.reddit.com/u/" + mp.UserName);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
HtmlCleaner cleaner = new HtmlCleaner();
|
||||||
|
TagNode node = cleaner.clean(in);
|
||||||
|
|
||||||
|
node = node.getElementsByAttValue("class", "age", true, true)[0];
|
||||||
|
node = node.getElementsByName("time", false)[0];
|
||||||
|
String joindate = node.getAttributeByName("datetime");
|
||||||
|
SimpleDateFormat parserSDF = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
|
joindate = joindate.split("T")[0];
|
||||||
|
Date date = parserSDF.parse(joindate);
|
||||||
|
return date.before(new Calendar.Builder()
|
||||||
|
.setTimeZone(TimeZone.getTimeZone("UTC")).setDate(2015, 4, 1)
|
||||||
|
.build().getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ConfirmUserMessage(MaybeOfflinePlayer mp) {
|
||||||
|
Player p = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented) && p != null)
|
||||||
|
if (mp.UserNames.size() > 1)
|
||||||
|
p.sendMessage("§9Multiple Reddit users commented your name. You can select with /u accept.§r §6Type /u accept or /u ignore§r");
|
||||||
|
else
|
||||||
|
p.sendMessage("§9A Reddit user commented your name. Is that you?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) {
|
||||||
|
if (reload) {
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("announcemessages.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("thebuttonmc.yml");
|
||||||
|
if (file.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
yc.load(file);
|
||||||
|
MaybeOfflinePlayer.Load(yc);
|
||||||
|
PlayerListener.NotificationSound = yc
|
||||||
|
.getString("notificationsound");
|
||||||
|
PlayerListener.NotificationPitch = yc
|
||||||
|
.getDouble("notificationpitch");
|
||||||
|
AnnounceTime = yc.getInt("announcetime");
|
||||||
|
AnnounceMessages.addAll(yc.getStringList("announcements"));
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() {
|
||||||
|
System.out.println("Saving files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("thebuttonmc.yml");
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
MaybeOfflinePlayer.Save(yc);
|
||||||
|
yc.set("notificationsound", PlayerListener.NotificationSound);
|
||||||
|
yc.set("notificationpitch", PlayerListener.NotificationPitch);
|
||||||
|
yc.set("announcetime", AnnounceTime);
|
||||||
|
yc.set("announcements", AnnounceMessages);
|
||||||
|
yc.save(file);
|
||||||
|
System.out.println("The Button Minecraft plugin saved files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addClassPath(final URL url) throws IOException {
|
||||||
|
final URLClassLoader sysloader = (URLClassLoader) ClassLoader
|
||||||
|
.getSystemClassLoader();
|
||||||
|
final Class<URLClassLoader> sysclass = URLClassLoader.class;
|
||||||
|
try {
|
||||||
|
final Method method = sysclass.getDeclaredMethod("addURL",
|
||||||
|
new Class[] { URL.class });
|
||||||
|
method.setAccessible(true);
|
||||||
|
method.invoke(sysloader, new Object[] { url });
|
||||||
|
} catch (final Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
throw new IOException("Error adding " + url
|
||||||
|
+ " to system classloader");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,596 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.command.BlockCommandSender;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Ocelot;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.potion.PotionEffectType;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.Mob;
|
||||||
|
import com.earth2me.essentials.Mob.MobException;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
|
||||||
|
public static boolean PluginUpdated = false; // 2015.08.31.
|
||||||
|
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label,
|
||||||
|
String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
switch (cmd.getName()) {
|
||||||
|
case "u": {
|
||||||
|
if (args.length < 1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(player
|
||||||
|
.getUniqueId());
|
||||||
|
switch (args[0].toLowerCase())
|
||||||
|
{
|
||||||
|
case "accept": {
|
||||||
|
if (args.length < 2 && p.UserNames.size() > 1) {
|
||||||
|
player.sendMessage("§9Multiple users commented your name. §bPlease pick one using /u accept <username>");
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
player.sendMessage(sb.toString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)
|
||||||
|
|| p.UserNames.size() == 0) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1 && !p.UserNames.contains(args[1])) {
|
||||||
|
player.sendMessage("§cError: Unknown name: " + args[1]
|
||||||
|
+ "§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.Working) {
|
||||||
|
player.sendMessage("§cError: Something is already in progress.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((args.length > 1 ? args[1] : p.UserNames.get(0))
|
||||||
|
.equals(p.UserName)) {
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1)
|
||||||
|
p.UserName = args[1];
|
||||||
|
else
|
||||||
|
p.UserName = p.UserNames.get(0);
|
||||||
|
|
||||||
|
player.sendMessage("§bObtaining flair...");
|
||||||
|
p.Working = true;
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
PluginMain.Instance.DownloadFlair(mp);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
Player player = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask an admin to set it for you. Also, prepare a comment on /r/thebutton, if possible.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String flair = mp.GetFormattedFlair();
|
||||||
|
mp.FlairState = FlairStates.Accepted;
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
player.sendMessage("§bYour flair has been set:§r "
|
||||||
|
+ flair);
|
||||||
|
mp.Working = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = p;
|
||||||
|
timer.schedule(tt, 20);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore": {
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!p.FlairState.equals(FlairStates.Ignored)) {
|
||||||
|
p.FlairState = FlairStates.Ignored;
|
||||||
|
p.FlairTime = "";
|
||||||
|
p.UserName = "";
|
||||||
|
player.sendMessage("§bYou have removed your flair. You can still use /u accept to get one.§r");
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou already removed your flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "admin": // 2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "opme": // 2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, wouldn't it?"); // Sometimes
|
||||||
|
// I'm
|
||||||
|
// bored
|
||||||
|
// too
|
||||||
|
break;
|
||||||
|
case "announce":
|
||||||
|
DoAnnounce(player, args, null);
|
||||||
|
break;
|
||||||
|
case "name":
|
||||||
|
if (args.length == 1) {
|
||||||
|
player.sendMessage("§cUsage: /u name <playername>§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer
|
||||||
|
.GetFromName(args[1]);
|
||||||
|
if (mp == null) {
|
||||||
|
player.sendMessage("§cUnknown user: " + args[1]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
player.sendMessage("§bUsername of " + args[1] + ": "
|
||||||
|
+ mp.UserName);
|
||||||
|
break;
|
||||||
|
case "enable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = true;
|
||||||
|
player.sendMessage("Enabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "disable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = false;
|
||||||
|
player.sendMessage("Disabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "kittycannon":
|
||||||
|
DoKittyCannon(player, args);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "nrp":
|
||||||
|
case "ooc":
|
||||||
|
if (args.length == 0) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = false;
|
||||||
|
String message = "";
|
||||||
|
for (String arg : args)
|
||||||
|
message += arg + " ";
|
||||||
|
player.chat(message.substring(0, message.length() - 1));
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = true;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
case "unlol": // TODO: Unlol
|
||||||
|
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("admin")) // 2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); // 2015.08.09.
|
||||||
|
return true; // 2015.08.09.
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("announce")) {
|
||||||
|
if (sender instanceof BlockCommandSender)
|
||||||
|
DoAnnounce(null, args, (BlockCommandSender) sender);
|
||||||
|
else
|
||||||
|
DoAnnounce(null, args, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoReload(Player player) { // 2015.07.20.
|
||||||
|
try {
|
||||||
|
PluginMain.Console
|
||||||
|
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); // 2015.08.09.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (mp.FlairState.equals(FlairStates.Recognised)
|
||||||
|
|| mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
String msg = "§bNote: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; // 2015.08.09.
|
||||||
|
p.sendMessage(msg); // 2015.08.09.
|
||||||
|
}
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading done!§r");
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
if (player != null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Player ReloadPlayer; // 2015.08.09.
|
||||||
|
|
||||||
|
private static String DoAdminUsage = "§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin|togglerpshow|toggledebug|savepos|loadpos§r";
|
||||||
|
|
||||||
|
private static void DoAdmin(Player player, String[] args) { // 2015.08.09.
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// args[0] is "admin"
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer = player; // 2015.08.09.
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§bMake sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; // <-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if (ReloadPlayer == player)
|
||||||
|
DoReload(player); // 2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); // 2015.08.09.
|
||||||
|
SendMessage(player,
|
||||||
|
"§bSaved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": // 2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
case "togglerpshow":
|
||||||
|
PlayerListener.ShowRPTag = !PlayerListener.ShowRPTag;
|
||||||
|
SendMessage(player, "RP tag showing "
|
||||||
|
+ (PlayerListener.ShowRPTag ? "enabled" : "disabled"));
|
||||||
|
break;
|
||||||
|
case "toggledebug":
|
||||||
|
PlayerListener.DebugMode = !PlayerListener.DebugMode;
|
||||||
|
SendMessage(player, "DebugMode: " + PlayerListener.DebugMode);
|
||||||
|
break;
|
||||||
|
case "savepos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "loadpos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "updatedynmap":
|
||||||
|
DoUpdateDynmap(player, args);
|
||||||
|
default:
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.GetFromName(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SendMessage(player, "Player name: " + p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: " + p.GetFormattedFlair());
|
||||||
|
SendMessage(player, "Username: " + p.UserName);
|
||||||
|
SendMessage(player, "Flair state: " + p.FlairState);
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
SendMessage(player, sb.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SendMessage(Player player, String message) { // 2015.08.09.
|
||||||
|
if (player == null)
|
||||||
|
PluginMain.Console.sendMessage(message); // 2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoGetLastError(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if (PluginMain.LastException != null) {
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException = null;
|
||||||
|
} else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SetPlayerFlair(Player player,
|
||||||
|
MaybeOfflinePlayer targetplayer, short flaircolor, String flairtime) {
|
||||||
|
targetplayer.FlairColor = flaircolor;
|
||||||
|
targetplayer.FlairTime = flairtime;
|
||||||
|
targetplayer.FlairState = FlairStates.Accepted;
|
||||||
|
targetplayer.UserName = "";
|
||||||
|
SendMessage(player,
|
||||||
|
"§bThe flair has been set. Player: " + targetplayer.PlayerName
|
||||||
|
+ " Flair: " + targetplayer.GetFormattedFlair() + "§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoSetFlair(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if (args.length < 4) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = Bukkit.getPlayer(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
SendMessage(player, "§cPLayer not found.&r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
short flaircolor = 0x00;
|
||||||
|
try {
|
||||||
|
flaircolor = Short.parseShort(args[3], 16);
|
||||||
|
} catch (Exception e) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cFlaircolor must be a hexadecimal number (don't include &).");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player,
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()),
|
||||||
|
flaircolor, (args.length < 5 ? "" : args[4]));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdatePlugin(Player player) { // 2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL(
|
||||||
|
"https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File(
|
||||||
|
"plugins/TheButtonAutoFlair.jar"));
|
||||||
|
PluginUpdated = true; // 2015.08.31.
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoAnnounce(Player player, String[] args,
|
||||||
|
BlockCommandSender commandblock) {
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "add":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce add <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
for (int i = 2; i < args.length; i++) {
|
||||||
|
sb.append(args[i]);
|
||||||
|
if (i != args.length - 1)
|
||||||
|
sb.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage = sb.toString().replace('&', '§');
|
||||||
|
PluginMain.AnnounceMessages.add(finalmessage);
|
||||||
|
SendMessage(player, "§bAnnouncement added.§r");
|
||||||
|
break;
|
||||||
|
case "remove":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce remove <index>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceMessages.remove(Integer.parseInt(args[2]));
|
||||||
|
break;
|
||||||
|
case "settime":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u announce settime <minutes>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceTime = Integer.parseInt(args[2]) * 60 * 1000;
|
||||||
|
SendMessage(player, "Time set between announce messages");
|
||||||
|
break;
|
||||||
|
case "list":
|
||||||
|
SendMessage(player, "§bList of announce messages:§r");
|
||||||
|
SendMessage(player, "§bFormat: [index] message§r");
|
||||||
|
int i = 0;
|
||||||
|
for (String message : PluginMain.AnnounceMessages)
|
||||||
|
SendMessage(player, "[" + i++ + "] " + message);
|
||||||
|
SendMessage(player,
|
||||||
|
"§bCurrent wait time between announcements: "
|
||||||
|
+ PluginMain.AnnounceTime / 60 / 1000
|
||||||
|
+ " minute(s)§r");
|
||||||
|
break;
|
||||||
|
case "edit":
|
||||||
|
if (commandblock == null) {
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§cError: This command can only be used from a command block. Use /u announce remove.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (args.length < 4) {
|
||||||
|
commandblock
|
||||||
|
.sendMessage("§cUsage: /u announce edit <index> <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb1 = new StringBuilder();
|
||||||
|
for (int i1 = 3; i1 < args.length; i1++) {
|
||||||
|
sb1.append(args[i1]);
|
||||||
|
if (i1 != args.length - 1)
|
||||||
|
sb1.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage1 = sb1.toString().replace('&', '§');
|
||||||
|
int index = Integer.parseInt(args[2]);
|
||||||
|
if (index > 100)
|
||||||
|
break;
|
||||||
|
while (PluginMain.AnnounceMessages.size() <= index)
|
||||||
|
PluginMain.AnnounceMessages.add("");
|
||||||
|
PluginMain.AnnounceMessages.set(Integer.parseInt(args[2]),
|
||||||
|
finalmessage1);
|
||||||
|
commandblock.sendMessage("Announcement edited.");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
private static void DoSaveLoadPos(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "savepos|loadpos"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = null;
|
||||||
|
try {
|
||||||
|
p = Bukkit.getPlayer(args[2]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
if (!MaybeOfflinePlayer.AllPlayers.containsKey(p.getUniqueId())) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer is not online: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (args[1].equalsIgnoreCase("savepos")) {
|
||||||
|
mp.SavedLocation = p.getLocation();
|
||||||
|
} else if (args[1].equalsIgnoreCase("loadpos")) {
|
||||||
|
if (mp.SavedLocation != null)
|
||||||
|
p.teleport(mp.SavedLocation);
|
||||||
|
} else {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// SendMessage(player, "Player " + p.getName() +
|
||||||
|
// " position saved/loaded.");s
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdateDynmap(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "updatedynmap"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin updatedynmap <password>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Random random = new Random();
|
||||||
|
|
||||||
|
public static String KittyCannonMinigame = "KittyCannon";
|
||||||
|
|
||||||
|
private static void DoKittyCannon(Player player, String[] args) {
|
||||||
|
if (player == null) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cThis command can only be used by a player.§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(player);
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame))) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou can only use KittyCannon in it's minigame!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
final Mob cat = Mob.OCELOT;
|
||||||
|
final Ocelot ocelot = (Ocelot) cat.spawn(player.getWorld(),
|
||||||
|
player.getServer(), player.getEyeLocation());
|
||||||
|
if (ocelot == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final ArrayList<String> lore = new ArrayList<>();
|
||||||
|
lore.add(player.getName());
|
||||||
|
final int i = random.nextInt(Ocelot.Type.values().length);
|
||||||
|
ocelot.setCatType(Ocelot.Type.values()[i]);
|
||||||
|
ocelot.setTamed(true);
|
||||||
|
ocelot.setBaby();
|
||||||
|
ocelot.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.DAMAGE_RESISTANCE, 5, 5));
|
||||||
|
ocelot.setVelocity(player.getEyeLocation().getDirection()
|
||||||
|
.multiply(2));
|
||||||
|
Bukkit.getScheduler().scheduleSyncDelayedTask(PluginMain.Instance,
|
||||||
|
new Runnable() {
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
final Location loc = ocelot.getLocation();
|
||||||
|
ocelot.remove();
|
||||||
|
loc.getWorld().createExplosion(loc, 0F);
|
||||||
|
final ItemStack head = new ItemStack(
|
||||||
|
Material.SKULL_ITEM, 1, (short) 3, (byte) 3);
|
||||||
|
SkullMeta im = (SkullMeta) head.getItemMeta();
|
||||||
|
im.setDisplayName("§rOcelot Head");
|
||||||
|
im.setOwner("MHF_Ocelot");
|
||||||
|
im.setLore(lore);
|
||||||
|
head.setItemMeta(im);
|
||||||
|
loc.getWorld().dropItem(loc, head);
|
||||||
|
}
|
||||||
|
}, 20);
|
||||||
|
} catch (MobException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,345 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
SaveFiles(); //2015.08.09.
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{ //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void SaveFiles() //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
name: TheButtonMCPlugin
|
||||||
|
main: tk.sznp.thebuttonautoflair.PluginMain
|
||||||
|
version: 2.0
|
||||||
|
commands:
|
||||||
|
u:
|
||||||
|
description: Auto-flair system. Accept or ignore flair.
|
||||||
|
usage: "&cUsage: /u accept|ignore|opme&r"
|
||||||
|
nrp:
|
||||||
|
description: Send message in Out-of-Character
|
||||||
|
usage: "&cUsage: /nrp <message>&r"
|
||||||
|
ooc:
|
||||||
|
description: Send message in Out-of-Character
|
||||||
|
usage: "&cUsage: /ooc <message>&r"
|
||||||
|
author: NorbiPeti
|
||||||
|
depend: [Essentials, Towny]
|
|
@ -0,0 +1,122 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color) {
|
||||||
|
FlairColor = color;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time) {
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time) {
|
||||||
|
FlairColor = color;
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2() {
|
||||||
|
|
||||||
|
// Flairs from Command Block The Button - Teams
|
||||||
|
// PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
Player p = Bukkit.getPlayer(UUID);
|
||||||
|
p.setPlayerListName(String.format("%s%s", p.getPlayerListName(),
|
||||||
|
GetFormattedFlair()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public short GetFlairColor()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,363 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(player, p);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,367 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerChatTabCompleteEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerPickupItemEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener { // 2015.07.16.
|
||||||
|
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
||||||
|
|
||||||
|
public static boolean Enable = false; // 2015.08.29.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
|
Player p = event.getPlayer();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PlayerName = p.getName(); // 2015.10.17. 0:58
|
||||||
|
if (!mp.FlairState.equals(FlairStates.NoComment))
|
||||||
|
// if (false)
|
||||||
|
PluginMain.ConfirmUserMessage(mp); // 2015.08.09.
|
||||||
|
else { // 2015.07.20.
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
String json = "[\"\",{\"text\":\"If you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
json = "[\"\",{\"text\":\"If you don't want the flair, type /u ignore to prevent this message after next login.\",\"color\":\"aqua\"}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = mp;
|
||||||
|
timer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NICKNAME LOGIC */
|
||||||
|
|
||||||
|
UUID id = p.getUniqueId();
|
||||||
|
|
||||||
|
File f = new File("plugins/Essentials/userdata/" + id + ".yml");
|
||||||
|
if (f.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
try {
|
||||||
|
yc.load(f);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
String nickname = yc.getString("nickname");
|
||||||
|
if (nickname != null) {
|
||||||
|
nicknames.put(nickname, id);
|
||||||
|
|
||||||
|
if (Enable) {
|
||||||
|
if (!p.getName().equals("NorbiPeti")) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.chat("Hey, " + nickname + "!");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mp.RPMode = true; // 2015.08.25.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event) {
|
||||||
|
String deletenick = null;
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
UUID uuid = nicknames.get(nickname);
|
||||||
|
if (event.getPlayer().getUniqueId().equals(uuid)) {
|
||||||
|
deletenick = nickname;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (deletenick != null)
|
||||||
|
nicknames.remove(deletenick);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String NotificationSound; // 2015.08.14.
|
||||||
|
public static double NotificationPitch; // 2015.08.14.
|
||||||
|
|
||||||
|
public static boolean ShowRPTag = false; // 2015.08.31.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event) {
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
String flair = player.GetFormattedFlair();
|
||||||
|
String message = event.getMessage(); // 2015.08.08.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
|
||||||
|
String color = ""; // 2015.08.17.
|
||||||
|
if (message.contains(p.getName())) {
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId()); // 2015.08.17.
|
||||||
|
color = String.format("§%x", (mp.FlairColor == 0x00 ? 0xb
|
||||||
|
: mp.FlairColor)); // TODO: Quiz queue
|
||||||
|
// TODO: Flairs from Command Block The Button - Teams
|
||||||
|
//PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
event.getPlayer().setPlayerListName("");
|
||||||
|
}
|
||||||
|
|
||||||
|
message = message.replace(p.getName(), color + p.getName()
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
for (String n : nicknames.keySet()) {
|
||||||
|
Player p = null;
|
||||||
|
String nwithoutformatting = new String(n);
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (message.contains(nwithoutformatting)) {
|
||||||
|
p = Bukkit.getPlayer(nicknames.get(n));
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()); // 2015.08.17.
|
||||||
|
}
|
||||||
|
if (p != null) {
|
||||||
|
message = message.replace(nwithoutformatting, n
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
event.setMessage(message); // 2015.09.05.
|
||||||
|
|
||||||
|
event.setFormat(event
|
||||||
|
.getFormat()
|
||||||
|
.replace(
|
||||||
|
"{rptag}",
|
||||||
|
(player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "")
|
||||||
|
: "§8[OOC]§r"))
|
||||||
|
.replace("{buttonflair}", flair)
|
||||||
|
.replace(
|
||||||
|
"{isitwilds}",
|
||||||
|
(event.getPlayer().getWorld().getName()
|
||||||
|
.equalsIgnoreCase("wilds") ? "[PVP]" : ""))); // 2015.09.04.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onTabComplete(PlayerChatTabCompleteEvent e) {
|
||||||
|
String name = e.getLastToken();
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
String nwithoutformatting = nickname;
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (nwithoutformatting.startsWith(name)
|
||||||
|
&& !nwithoutformatting.equals(Bukkit.getPlayer(
|
||||||
|
nicknames.get(nickname)).getName()))
|
||||||
|
e.getTabCompletions().add(nwithoutformatting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean DebugMode = false;
|
||||||
|
|
||||||
|
public void SendForDebug(String message) {
|
||||||
|
if (DebugMode) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.sendMessage("[DEBUG] " + message);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean ActiveF = false;
|
||||||
|
private int FCount = 0;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerMessage(AsyncPlayerChatEvent e) {
|
||||||
|
if (e.getMessage().equalsIgnoreCase("F")) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(e
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
if (!mp.PressedF && ActiveF) {
|
||||||
|
FCount++;
|
||||||
|
mp.PressedF = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.getMessage().startsWith(">"))
|
||||||
|
e.setMessage("§2" + e.getMessage());
|
||||||
|
|
||||||
|
if (e.getMessage().equalsIgnoreCase("lol"))
|
||||||
|
Commands.Lastlol = MaybeOfflinePlayer.AllPlayers.get(e.getPlayer()
|
||||||
|
.getUniqueId());
|
||||||
|
|
||||||
|
if (e.getFormat().contains("[g]")) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("tellraw @a [\"\"");
|
||||||
|
sb.append(",{\"text\":\"Hashtags:\"}");
|
||||||
|
int index = -1;
|
||||||
|
ArrayList<String> list = new ArrayList<String>();
|
||||||
|
while ((index = e.getMessage().indexOf("#", index + 1)) != -1) {
|
||||||
|
int index2 = e.getMessage().indexOf(" ", index + 1);
|
||||||
|
if (index2 == -1)
|
||||||
|
index2 = e.getMessage().length();
|
||||||
|
int index3 = e.getMessage().indexOf("#", index + 1);
|
||||||
|
if (index3 != -1 && index3 < index2) // A # occurs before a
|
||||||
|
// space
|
||||||
|
index2 = index3;
|
||||||
|
String original = e.getMessage().substring(index, index2);
|
||||||
|
list.add(original);
|
||||||
|
sb.append(",{\"text\":\" \"}");
|
||||||
|
sb.append(",{\"text\":\"");
|
||||||
|
sb.append(original);
|
||||||
|
sb.append("\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/");
|
||||||
|
sb.append(original.substring(1));
|
||||||
|
sb.append("\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}}");
|
||||||
|
}
|
||||||
|
for (String original : list)
|
||||||
|
e.setMessage(e.getMessage().replace(
|
||||||
|
original,
|
||||||
|
"§9"
|
||||||
|
+ original
|
||||||
|
+ (e.getMessage().startsWith("§2>") ? "§2"
|
||||||
|
: "§r")));
|
||||||
|
/*
|
||||||
|
* for (String original : list)
|
||||||
|
* System.out.println(e.getMessage().replace( original, "§9" +
|
||||||
|
* original + (e.getMessage().startsWith("§2>") ? "§2" : "§r")));
|
||||||
|
*/
|
||||||
|
|
||||||
|
sb.append("]");
|
||||||
|
|
||||||
|
if (list.size() > 0)
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Instance.getServer().getConsoleSender(),
|
||||||
|
sb.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Timer Ftimer;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerDeath(PlayerDeathEvent e) {
|
||||||
|
if (!Minigames.plugin.pdata.getMinigamePlayer(e.getEntity())
|
||||||
|
.isInMinigame() && new Random().nextBoolean()) {
|
||||||
|
if (Ftimer != null)
|
||||||
|
Ftimer.cancel();
|
||||||
|
ActiveF = true;
|
||||||
|
FCount = 0;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PressedF = false;
|
||||||
|
p.sendMessage("§bPress F to pay respects.§r");
|
||||||
|
}
|
||||||
|
Ftimer = new Timer();
|
||||||
|
TimerTask tt = new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (ActiveF) {
|
||||||
|
ActiveF = false;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
p.sendMessage("§b" + FCount + " "
|
||||||
|
+ (FCount == 1 ? "person" : "people")
|
||||||
|
+ " paid their respects.§r");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Ftimer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerItemPickup(PlayerPickupItemEvent e) {
|
||||||
|
// System.out.println("A");
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(e
|
||||||
|
.getPlayer());
|
||||||
|
// System.out.println("B");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* if (!e.getPlayer().isOp() && (!mp.isInMinigame() ||
|
||||||
|
* mp.getMinigame().getName(false)
|
||||||
|
* .equalsIgnoreCase(Commands.KittyCannonMinigame))) return;
|
||||||
|
*/
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame)))
|
||||||
|
return;
|
||||||
|
// System.out.println("C");
|
||||||
|
ItemStack item = e.getItem().getItemStack();
|
||||||
|
if (!item.getType().equals(Material.SKULL_ITEM)
|
||||||
|
&& !item.getType().equals(Material.SKULL))
|
||||||
|
return;
|
||||||
|
// System.out.println("D");
|
||||||
|
SkullMeta meta = (SkullMeta) item.getItemMeta();
|
||||||
|
if (!meta.getDisplayName().equals("§rOcelot Head")
|
||||||
|
|| !meta.getOwner().equals("MHF_Ocelot"))
|
||||||
|
return;
|
||||||
|
// System.out.println("E");
|
||||||
|
if (meta.getLore() == null || meta.getLore().size() == 0)
|
||||||
|
return;
|
||||||
|
// System.out.println("F");
|
||||||
|
ItemStack hat = e.getPlayer().getInventory().getHelmet();
|
||||||
|
if (!(hat != null
|
||||||
|
&& (hat.getType().equals(Material.SKULL) || hat.getType()
|
||||||
|
.equals(Material.SKULL_ITEM)) && ((SkullMeta) hat
|
||||||
|
.getItemMeta()).getDisplayName().equals("§rWolf Head")))
|
||||||
|
e.getPlayer().damage(1f * item.getAmount(),
|
||||||
|
Bukkit.getPlayer(meta.getLore().get(0)));
|
||||||
|
e.getItem().remove();
|
||||||
|
// System.out.println("G");
|
||||||
|
e.setCancelled(true);
|
||||||
|
// System.out.println("H");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,370 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerChatTabCompleteEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerPickupItemEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener { // 2015.07.16.
|
||||||
|
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
||||||
|
|
||||||
|
public static boolean Enable = false; // 2015.08.29.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
|
Player p = event.getPlayer();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PlayerName = p.getName(); // 2015.10.17. 0:58
|
||||||
|
if (!mp.FlairState.equals(FlairStates.NoComment))
|
||||||
|
// if (false)
|
||||||
|
PluginMain.ConfirmUserMessage(mp); // 2015.08.09.
|
||||||
|
else { // 2015.07.20.
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
String json = "[\"\",{\"text\":\"If you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
json = "[\"\",{\"text\":\"If you don't want the flair, type /u ignore to prevent this message after next login.\",\"color\":\"aqua\"}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = mp;
|
||||||
|
timer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NICKNAME LOGIC */
|
||||||
|
|
||||||
|
UUID id = p.getUniqueId();
|
||||||
|
|
||||||
|
File f = new File("plugins/Essentials/userdata/" + id + ".yml");
|
||||||
|
if (f.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
try {
|
||||||
|
yc.load(f);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
String nickname = yc.getString("nickname");
|
||||||
|
if (nickname != null) {
|
||||||
|
nicknames.put(nickname, id);
|
||||||
|
|
||||||
|
if (Enable) {
|
||||||
|
if (!p.getName().equals("NorbiPeti")) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.chat("Hey, " + nickname + "!");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mp.RPMode = true; // 2015.08.25.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event) {
|
||||||
|
String deletenick = null;
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
UUID uuid = nicknames.get(nickname);
|
||||||
|
if (event.getPlayer().getUniqueId().equals(uuid)) {
|
||||||
|
deletenick = nickname;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (deletenick != null)
|
||||||
|
nicknames.remove(deletenick);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String NotificationSound; // 2015.08.14.
|
||||||
|
public static double NotificationPitch; // 2015.08.14.
|
||||||
|
|
||||||
|
public static boolean ShowRPTag = false; // 2015.08.31.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event) {
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
String flair = player.GetFormattedFlair();
|
||||||
|
String message = event.getMessage(); // 2015.08.08.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
|
||||||
|
String color = ""; // 2015.08.17.
|
||||||
|
if (message.contains(p.getName())) {
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId()); // 2015.08.17.
|
||||||
|
color = String.format("§%x", (mp.FlairColor == 0x00 ? 0xb
|
||||||
|
: mp.FlairColor)); //TODO: Quiz queue
|
||||||
|
}
|
||||||
|
|
||||||
|
message = message.replace(p.getName(), color + p.getName()
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
for (String n : nicknames.keySet()) {
|
||||||
|
Player p = null;
|
||||||
|
String nwithoutformatting = new String(n);
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (message.contains(nwithoutformatting)) {
|
||||||
|
p = Bukkit.getPlayer(nicknames.get(n));
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()); // 2015.08.17.
|
||||||
|
}
|
||||||
|
if (p != null) {
|
||||||
|
message = message.replace(nwithoutformatting, n
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
event.setMessage(message); // 2015.09.05.
|
||||||
|
|
||||||
|
event.setFormat(event
|
||||||
|
.getFormat()
|
||||||
|
.replace(
|
||||||
|
"{rptag}",
|
||||||
|
(player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "")
|
||||||
|
: "§8[OOC]§r"))
|
||||||
|
.replace("{buttonflair}", flair)
|
||||||
|
.replace(
|
||||||
|
"{isitwilds}",
|
||||||
|
(event.getPlayer().getWorld().getName()
|
||||||
|
.equalsIgnoreCase("wilds") ? "[PVP]" : ""))); // 2015.09.04.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onTabComplete(PlayerChatTabCompleteEvent e) {
|
||||||
|
String name = e.getLastToken();
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
String nwithoutformatting = nickname;
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (nwithoutformatting.startsWith(name)
|
||||||
|
&& !nwithoutformatting.equals(Bukkit.getPlayer(
|
||||||
|
nicknames.get(nickname)).getName()))
|
||||||
|
e.getTabCompletions().add(nwithoutformatting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean DebugMode = false;
|
||||||
|
|
||||||
|
public void SendForDebug(String message) {
|
||||||
|
if (DebugMode) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.sendMessage("[DEBUG] " + message);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean ActiveF = false;
|
||||||
|
private int FCount = 0;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerMessage(AsyncPlayerChatEvent e) {
|
||||||
|
if (e.getMessage().equalsIgnoreCase("F")) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(e
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
if (!mp.PressedF && ActiveF) {
|
||||||
|
FCount++;
|
||||||
|
mp.PressedF = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.getMessage().startsWith(">"))
|
||||||
|
e.setMessage("§2" + e.getMessage());
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Channel c = ((Chat) Bukkit.getPluginManager().getPlugin("TownyChat"))
|
||||||
|
* .getChannelsHandler().getActiveChannel(e.getPlayer(),
|
||||||
|
* channelTypes.GLOBAL);
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* List<String> modes = ((Chat) Bukkit.getPluginManager().getPlugin(
|
||||||
|
* "TownyChat")).getTowny().getPlayerMode(e.getPlayer()); if
|
||||||
|
* (modes.size() == 0 || modes.contains("g")) {
|
||||||
|
*/
|
||||||
|
if (e.getFormat().contains("[g]")) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("tellraw @a [\"\"");
|
||||||
|
sb.append(",{\"text\":\"Hashtags:\"}");
|
||||||
|
int index = -1;
|
||||||
|
ArrayList<String> list = new ArrayList<String>();
|
||||||
|
while ((index = e.getMessage().indexOf("#", index + 1)) != -1) {
|
||||||
|
int index2 = e.getMessage().indexOf(" ", index + 1);
|
||||||
|
if (index2 == -1)
|
||||||
|
index2 = e.getMessage().length();
|
||||||
|
int index3 = e.getMessage().indexOf("#", index + 1);
|
||||||
|
if (index3 != -1 && index3 < index2) // A # occurs before a
|
||||||
|
// space
|
||||||
|
index2 = index3;
|
||||||
|
String original = e.getMessage().substring(index, index2);
|
||||||
|
list.add(original);
|
||||||
|
sb.append(",{\"text\":\" \"}");
|
||||||
|
sb.append(",{\"text\":\"");
|
||||||
|
sb.append(original);
|
||||||
|
sb.append("\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/");
|
||||||
|
sb.append(original.substring(1));
|
||||||
|
sb.append("\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}}");
|
||||||
|
}
|
||||||
|
for (String original : list)
|
||||||
|
e.setMessage(e.getMessage().replace(
|
||||||
|
original,
|
||||||
|
"§9"
|
||||||
|
+ original
|
||||||
|
+ (e.getMessage().startsWith("§2>") ? "§2"
|
||||||
|
: "§r")));
|
||||||
|
/*
|
||||||
|
* for (String original : list)
|
||||||
|
* System.out.println(e.getMessage().replace( original, "§9" +
|
||||||
|
* original + (e.getMessage().startsWith("§2>") ? "§2" : "§r")));
|
||||||
|
*/
|
||||||
|
|
||||||
|
sb.append("]");
|
||||||
|
|
||||||
|
if (list.size() > 0)
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Instance.getServer().getConsoleSender(),
|
||||||
|
sb.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Timer Ftimer;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerDeath(PlayerDeathEvent e) {
|
||||||
|
if (!Minigames.plugin.pdata.getMinigamePlayer(e.getEntity())
|
||||||
|
.isInMinigame() && new Random().nextBoolean()) {
|
||||||
|
if (Ftimer != null)
|
||||||
|
Ftimer.cancel();
|
||||||
|
ActiveF = true;
|
||||||
|
FCount = 0;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PressedF = false;
|
||||||
|
p.sendMessage("§bPress F to pay respects.§r");
|
||||||
|
}
|
||||||
|
Ftimer = new Timer();
|
||||||
|
TimerTask tt = new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (ActiveF) {
|
||||||
|
ActiveF = false;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
p.sendMessage("§b" + FCount + " "
|
||||||
|
+ (FCount == 1 ? "person" : "people")
|
||||||
|
+ " paid their respects.§r");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Ftimer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerItemPickup(PlayerPickupItemEvent e) {
|
||||||
|
// System.out.println("A");
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(e
|
||||||
|
.getPlayer());
|
||||||
|
// System.out.println("B");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* if (!e.getPlayer().isOp() && (!mp.isInMinigame() ||
|
||||||
|
* mp.getMinigame().getName(false)
|
||||||
|
* .equalsIgnoreCase(Commands.KittyCannonMinigame))) return;
|
||||||
|
*/
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame)))
|
||||||
|
return;
|
||||||
|
// System.out.println("C");
|
||||||
|
ItemStack item = e.getItem().getItemStack();
|
||||||
|
if (!item.getType().equals(Material.SKULL_ITEM)
|
||||||
|
&& !item.getType().equals(Material.SKULL))
|
||||||
|
return;
|
||||||
|
// System.out.println("D");
|
||||||
|
SkullMeta meta = (SkullMeta) item.getItemMeta();
|
||||||
|
if (!meta.getDisplayName().equals("§rOcelot Head")
|
||||||
|
|| !meta.getOwner().equals("MHF_Ocelot"))
|
||||||
|
return;
|
||||||
|
// System.out.println("E");
|
||||||
|
if (meta.getLore() == null || meta.getLore().size() == 0)
|
||||||
|
return;
|
||||||
|
// System.out.println("F");
|
||||||
|
ItemStack hat = e.getPlayer().getInventory().getHelmet();
|
||||||
|
if (!(hat != null
|
||||||
|
&& (hat.getType().equals(Material.SKULL) || hat.getType()
|
||||||
|
.equals(Material.SKULL_ITEM)) && ((SkullMeta) hat
|
||||||
|
.getItemMeta()).getDisplayName().equals("§rWolf Head")))
|
||||||
|
e.getPlayer().damage(1f * item.getAmount(),
|
||||||
|
Bukkit.getPlayer(meta.getLore().get(0)));
|
||||||
|
e.getItem().remove();
|
||||||
|
// System.out.println("G");
|
||||||
|
e.setCancelled(true);
|
||||||
|
// System.out.println("H");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,354 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
String finalflair;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
{
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).AcceptedFlair)
|
||||||
|
AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+username+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,370 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear(); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,451 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
public static ConsoleSender Console; //2015.08.12.
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
SaveFiles(); //2015.08.09.
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
//System.out.println("Start: "+start);
|
||||||
|
if(start==-1+"IGN:".length()) //+length: 2015.08.10.
|
||||||
|
continue; //2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
//System.out.println("End: "+end);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
//System.out.println("IGN: "+ign);
|
||||||
|
ign = ign.trim();
|
||||||
|
//System.out.println("Trimmed IGN: "+ign);
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
/*else
|
||||||
|
flair = "non-presser";*/
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
//return p.Flair!=null; //2015.08.08.
|
||||||
|
return p.CommentedOnReddit; //2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
p.FlairRecognised=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(--s)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(??s)§r";
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if(text.equals("-1")) //If true, only non-presser/can't press; if false, any flair
|
||||||
|
p.FlairDecided=false;
|
||||||
|
else
|
||||||
|
p.FlairRecognised=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
//finalflair="";
|
||||||
|
//break;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
/*if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;*/
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.CommentedOnReddit=true; //2015.08.10.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
if(finalflair.length()==0) //Just for the message
|
||||||
|
finalflair="undecided";
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
//return flair==null ? "" : flair;
|
||||||
|
return flair; //2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
/*private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
*String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}*
|
||||||
|
}*/
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}*/
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{ //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
if(s.length>=2) //<-- 2015.08.10.
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("customflairs.txt"); //2015.08.09.
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
if(s.length>=2) //2015.08.10.
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(s[0]);
|
||||||
|
p.Flair=s[1]; //2015.08.09.
|
||||||
|
p.CommentedOnReddit=true; //Kind of
|
||||||
|
}
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void SaveFiles() //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static boolean RemoveLineFromFile(String file, String line)
|
||||||
|
{ //2015.08.09.
|
||||||
|
File inputFile = new File(file);
|
||||||
|
File tempFile = new File("_temp.txt");
|
||||||
|
|
||||||
|
if(!inputFile.exists())
|
||||||
|
return true; //2015.08.10.
|
||||||
|
|
||||||
|
try {
|
||||||
|
BufferedReader reader = new BufferedReader(new FileReader(inputFile));
|
||||||
|
BufferedWriter writer = new BufferedWriter(new FileWriter(tempFile));
|
||||||
|
|
||||||
|
String lineToRemove = line;
|
||||||
|
String currentLine;
|
||||||
|
|
||||||
|
while((currentLine = reader.readLine()) != null) {
|
||||||
|
// trim newline when comparing with lineToRemove
|
||||||
|
String trimmedLine = currentLine.trim();
|
||||||
|
//if(trimmedLine.equals(lineToRemove)) continue;
|
||||||
|
if(trimmedLine.contains(lineToRemove)) continue; //2015.08.09.
|
||||||
|
writer.write(currentLine + System.getProperty("line.separator"));
|
||||||
|
}
|
||||||
|
writer.close();
|
||||||
|
reader.close();
|
||||||
|
if(!tempFile.renameTo(inputFile))
|
||||||
|
{
|
||||||
|
inputFile.delete();
|
||||||
|
return tempFile.renameTo(inputFile);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return true;
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,353 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.htmlcleaner.HtmlCleaner;
|
||||||
|
import org.htmlcleaner.TagNode;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
try {
|
||||||
|
System.out.println("Extracting necessary libraries...");
|
||||||
|
final File[] libs = new File[] { new File(getDataFolder(),
|
||||||
|
"htmlcleaner-2.16.jar") };
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
JarUtils.extractFromJar(lib.getName(),
|
||||||
|
lib.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
getLogger().warning(
|
||||||
|
"Failed to load plugin! Could not find lib: "
|
||||||
|
+ lib.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().disablePlugin(this);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
addClassPath(JarUtils.getJarUrl(lib));
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ThreadMethod() {
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.GetFromName(ign);
|
||||||
|
if (mp == null)
|
||||||
|
continue;
|
||||||
|
if (!mp.UserNames.contains(author))
|
||||||
|
mp.UserNames.add(author);
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
mp.FlairState = FlairStates.Commented;
|
||||||
|
ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DownloadFlair(MaybeOfflinePlayer mp)
|
||||||
|
throws MalformedURLException, IOException {
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users=" + mp.UserName)
|
||||||
|
.replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1)
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(mp, flair, flairclass, mp.UserName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair(MaybeOfflinePlayer p, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
p.UserName = username;
|
||||||
|
p.FlairState = FlairStates.Recognised;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
p.SetFlairColor(0xc);
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
p.SetFlairColor(0x6);
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
p.SetFlairColor(0xe);
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
p.SetFlairColor(0xa);
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
p.SetFlairColor(0x9);
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
p.SetFlairColor(0x7);
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "cant-press":
|
||||||
|
p.SetFlairColor(0xf);
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if (CheckForJoinDate(p)) {
|
||||||
|
p.SetFlair(0x7, "--");
|
||||||
|
} else {
|
||||||
|
p.SetFlair(0xf, "--");
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (text.equals("-1"))
|
||||||
|
text = "--";
|
||||||
|
p.FlairTime = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean CheckForJoinDate(MaybeOfflinePlayer mp)
|
||||||
|
throws Exception {
|
||||||
|
URL url = new URL("https://www.reddit.com/u/" + mp.UserName);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
HtmlCleaner cleaner = new HtmlCleaner();
|
||||||
|
TagNode node = cleaner.clean(in);
|
||||||
|
|
||||||
|
node = node.getElementsByAttValue("class", "age", true, true)[0];
|
||||||
|
node = node.getElementsByName("time", false)[0];
|
||||||
|
String joindate = node.getAttributeByName("datetime");
|
||||||
|
SimpleDateFormat parserSDF = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
|
joindate = joindate.split("T")[0];
|
||||||
|
Date date = parserSDF.parse(joindate);
|
||||||
|
return date.before(new Calendar.Builder()
|
||||||
|
.setTimeZone(TimeZone.getTimeZone("UTC")).setDate(2015, 4, 1)
|
||||||
|
.build().getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ConfirmUserMessage(MaybeOfflinePlayer mp) {
|
||||||
|
Player p = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented) && p != null)
|
||||||
|
if (mp.UserNames.size() > 1)
|
||||||
|
p.sendMessage("§9Multiple Reddit users commented your name. You can select with /u accept.§r §6Type /u accept or /u ignore§r");
|
||||||
|
else
|
||||||
|
p.sendMessage("§9A Reddit user commented your name. Is that you?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) {
|
||||||
|
if (reload) {
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("announcemessages.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("thebuttonmc.yml");
|
||||||
|
if (file.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
yc.load(file);
|
||||||
|
MaybeOfflinePlayer.Load(yc);
|
||||||
|
PlayerListener.NotificationSound = yc
|
||||||
|
.getString("notificationsound");
|
||||||
|
PlayerListener.NotificationPitch = yc
|
||||||
|
.getDouble("notificationpitch");
|
||||||
|
AnnounceTime = yc.getInt("announcetime");
|
||||||
|
AnnounceMessages.addAll(yc.getStringList("announcements"));
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() {
|
||||||
|
System.out.println("Saving files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("thebuttonmc.yml");
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
MaybeOfflinePlayer.Save(yc);
|
||||||
|
yc.set("notificationsound", PlayerListener.NotificationSound);
|
||||||
|
yc.set("notificationpitch", PlayerListener.NotificationPitch);
|
||||||
|
yc.set("announcetime", AnnounceTime);
|
||||||
|
yc.set("announcements", AnnounceMessages);
|
||||||
|
yc.save(file);
|
||||||
|
System.out.println("The Button Minecraft plugin saved files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addClassPath(final URL url) throws IOException {
|
||||||
|
final URLClassLoader sysloader = (URLClassLoader) ClassLoader
|
||||||
|
.getSystemClassLoader();
|
||||||
|
final Class<URLClassLoader> sysclass = URLClassLoader.class;
|
||||||
|
try {
|
||||||
|
final Method method = sysclass.getDeclaredMethod("addURL",
|
||||||
|
new Class[] { URL.class });
|
||||||
|
method.setAccessible(true);
|
||||||
|
method.invoke(sysloader, new Object[] { url });
|
||||||
|
} catch (final Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
throw new IOException("Error adding " + url
|
||||||
|
+ " to system classloader");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,125 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color) {
|
||||||
|
FlairColor = color;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time) {
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time) {
|
||||||
|
FlairColor = color;
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2() {
|
||||||
|
|
||||||
|
// Flairs from Command Block The Button - Teams
|
||||||
|
// PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
Player p = Bukkit.getPlayer(UUID);
|
||||||
|
p.setPlayerListName(String.format("%s%s", p.getPlayerListName(),
|
||||||
|
GetFormattedFlair()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public short GetFlairColor() {
|
||||||
|
return FlairColor;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFlairTime() {
|
||||||
|
return FlairTime;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,197 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(player, p);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.TownColors.clear();
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
PluginMain.TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String msg="§6Reloaded config file.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,201 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.TownColors.clear();
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
PluginMain.TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String msg="§6Reloaded config file.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer
|
||||||
|
{ //2015.08.08.
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public String Flair; //If the user comments their name, it gets set, it doesn't matter if they accepted it or not
|
||||||
|
public boolean AcceptedFlair;
|
||||||
|
public boolean IgnoredFlair;
|
||||||
|
public
|
||||||
|
public static HashMap<String, MaybeOfflinePlayer> AllPlayers=new HashMap<>(); //2015.08.08.
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(String playername)
|
||||||
|
{
|
||||||
|
if(!AllPlayers.containsKey(playername))
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player=new MaybeOfflinePlayer();
|
||||||
|
player.PlayerName=playername;
|
||||||
|
AllPlayers.put(playername, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(playername);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,369 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.Sound;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.PlayerDeathEvent;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerChatTabCompleteEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerPickupItemEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
import java.util.TimerTask;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener { // 2015.07.16.
|
||||||
|
public static HashMap<String, UUID> nicknames = new HashMap<>();
|
||||||
|
|
||||||
|
public static boolean Enable = false; // 2015.08.29.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
|
Player p = event.getPlayer();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PlayerName = p.getName(); // 2015.10.17. 0:58
|
||||||
|
if (!mp.FlairState.equals(FlairStates.NoComment))
|
||||||
|
// if (false)
|
||||||
|
PluginMain.ConfirmUserMessage(mp); // 2015.08.09.
|
||||||
|
else { // 2015.07.20.
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
String json = "[\"\",{\"text\":\"If you'd like your /r/TheButton flair displayed ingame, write your Minecraft name to \",\"color\":\"aqua\"},{\"text\":\"[this thread].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
json = "[\"\",{\"text\":\"If you don't want the flair, type /u ignore to prevent this message after next login.\",\"color\":\"aqua\"}]";
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Console,
|
||||||
|
"tellraw " + mp.PlayerName + " " + json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = mp;
|
||||||
|
timer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NICKNAME LOGIC */
|
||||||
|
|
||||||
|
UUID id = p.getUniqueId();
|
||||||
|
|
||||||
|
File f = new File("plugins/Essentials/userdata/" + id + ".yml");
|
||||||
|
if (f.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
try {
|
||||||
|
yc.load(f);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
String nickname = yc.getString("nickname");
|
||||||
|
if (nickname != null) {
|
||||||
|
nicknames.put(nickname, id);
|
||||||
|
|
||||||
|
if (Enable) {
|
||||||
|
if (!p.getName().equals("NorbiPeti")) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.chat("Hey, " + nickname + "!");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mp.RPMode = true; // 2015.08.25.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event) {
|
||||||
|
String deletenick = null;
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
UUID uuid = nicknames.get(nickname);
|
||||||
|
if (event.getPlayer().getUniqueId().equals(uuid)) {
|
||||||
|
deletenick = nickname;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (deletenick != null)
|
||||||
|
nicknames.remove(deletenick);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String NotificationSound; // 2015.08.14.
|
||||||
|
public static double NotificationPitch; // 2015.08.14.
|
||||||
|
|
||||||
|
public static boolean ShowRPTag = false; // 2015.08.31.
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event) {
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
String flair = player.GetFormattedFlair();
|
||||||
|
String message = event.getMessage(); // 2015.08.08.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) { // 2015.08.12.
|
||||||
|
String color = ""; // 2015.08.17.
|
||||||
|
if (message.contains(p.getName())) {
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId()); // 2015.08.17.
|
||||||
|
color = String.format("§%x", mp.FlairColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
message = message.replace(p.getName(), color + p.getName()
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
for (String n : nicknames.keySet()) {
|
||||||
|
Player p = null;
|
||||||
|
String nwithoutformatting = new String(n);
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (message.contains(nwithoutformatting)) {
|
||||||
|
p = Bukkit.getPlayer(nicknames.get(n));
|
||||||
|
if (NotificationSound == null)
|
||||||
|
p.playSound(p.getLocation(), Sound.ORB_PICKUP, 1.0f, 0.5f); // 2015.08.12.
|
||||||
|
else
|
||||||
|
p.playSound(p.getLocation(), NotificationSound, 1.0f,
|
||||||
|
(float) NotificationPitch); // 2015.08.14.
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()); // 2015.08.17.
|
||||||
|
}
|
||||||
|
if (p != null) {
|
||||||
|
message = message.replace(nwithoutformatting, n
|
||||||
|
+ (event.getMessage().startsWith("§2>") ? "§2" : "§r"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
event.setMessage(message); // 2015.09.05.
|
||||||
|
|
||||||
|
event.setFormat(event
|
||||||
|
.getFormat()
|
||||||
|
.replace(
|
||||||
|
"{rptag}",
|
||||||
|
(player.RPMode ? (ShowRPTag ? "§2[RP]§r" : "")
|
||||||
|
: "§8[OOC]§r"))
|
||||||
|
.replace("{buttonflair}", flair)
|
||||||
|
.replace(
|
||||||
|
"{isitwilds}",
|
||||||
|
(event.getPlayer().getWorld().getName()
|
||||||
|
.equalsIgnoreCase("wilds") ? "[PVP]" : ""))); // 2015.09.04.
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onTabComplete(PlayerChatTabCompleteEvent e) {
|
||||||
|
String name = e.getLastToken();
|
||||||
|
for (String nickname : nicknames.keySet()) {
|
||||||
|
String nwithoutformatting = nickname;
|
||||||
|
int index;
|
||||||
|
while ((index = nwithoutformatting.indexOf("§k")) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§k"
|
||||||
|
+ nwithoutformatting.charAt(index + 2), ""); // Support
|
||||||
|
// for
|
||||||
|
// one
|
||||||
|
// random
|
||||||
|
// char
|
||||||
|
while ((index = nwithoutformatting.indexOf('§')) != -1)
|
||||||
|
nwithoutformatting = nwithoutformatting.replace("§"
|
||||||
|
+ nwithoutformatting.charAt(index + 1), "");
|
||||||
|
if (nwithoutformatting.startsWith(name)
|
||||||
|
&& !nwithoutformatting.equals(Bukkit.getPlayer(
|
||||||
|
nicknames.get(nickname)).getName()))
|
||||||
|
e.getTabCompletions().add(nwithoutformatting);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean DebugMode = false;
|
||||||
|
|
||||||
|
public void SendForDebug(String message) {
|
||||||
|
if (DebugMode) {
|
||||||
|
for (Player player : PluginMain.GetPlayers()) {
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
player.sendMessage("[DEBUG] " + message);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean ActiveF = false;
|
||||||
|
private int FCount = 0;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerMessage(AsyncPlayerChatEvent e) {
|
||||||
|
if (e.getMessage().equalsIgnoreCase("F")) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(e
|
||||||
|
.getPlayer().getUniqueId());
|
||||||
|
if (!mp.PressedF && ActiveF) {
|
||||||
|
FCount++;
|
||||||
|
mp.PressedF = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.getMessage().startsWith(">"))
|
||||||
|
e.setMessage("§2" + e.getMessage());
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Channel c = ((Chat) Bukkit.getPluginManager().getPlugin("TownyChat"))
|
||||||
|
* .getChannelsHandler().getActiveChannel(e.getPlayer(),
|
||||||
|
* channelTypes.GLOBAL);
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* List<String> modes = ((Chat) Bukkit.getPluginManager().getPlugin(
|
||||||
|
* "TownyChat")).getTowny().getPlayerMode(e.getPlayer()); if
|
||||||
|
* (modes.size() == 0 || modes.contains("g")) {
|
||||||
|
*/
|
||||||
|
if (e.getFormat().contains("[g]")) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("tellraw @a [\"\"");
|
||||||
|
sb.append(",{\"text\":\"Hashtags:\"}");
|
||||||
|
int index = -1;
|
||||||
|
ArrayList<String> list = new ArrayList<String>();
|
||||||
|
while ((index = e.getMessage().indexOf("#", index + 1)) != -1) {
|
||||||
|
int index2 = e.getMessage().indexOf(" ", index + 1);
|
||||||
|
if (index2 == -1)
|
||||||
|
index2 = e.getMessage().length();
|
||||||
|
int index3 = e.getMessage().indexOf("#", index + 1);
|
||||||
|
if (index3 != -1 && index3 < index2) // A # occurs before a
|
||||||
|
// space
|
||||||
|
index2 = index3;
|
||||||
|
String original = e.getMessage().substring(index, index2);
|
||||||
|
list.add(original);
|
||||||
|
sb.append(",{\"text\":\" \"}");
|
||||||
|
sb.append(",{\"text\":\"");
|
||||||
|
sb.append(original);
|
||||||
|
sb.append("\",\"color\":\"blue\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://twitter.com/hashtag/");
|
||||||
|
sb.append(original.substring(1));
|
||||||
|
sb.append("\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Open on Twitter\",\"color\":\"blue\"}]}}}");
|
||||||
|
}
|
||||||
|
for (String original : list)
|
||||||
|
e.setMessage(e.getMessage().replace(
|
||||||
|
original,
|
||||||
|
"§9"
|
||||||
|
+ original
|
||||||
|
+ (e.getMessage().startsWith("§2>") ? "§2"
|
||||||
|
: "§r")));
|
||||||
|
/*
|
||||||
|
* for (String original : list)
|
||||||
|
* System.out.println(e.getMessage().replace( original, "§9" +
|
||||||
|
* original + (e.getMessage().startsWith("§2>") ? "§2" : "§r")));
|
||||||
|
*/
|
||||||
|
|
||||||
|
sb.append("]");
|
||||||
|
|
||||||
|
if (list.size() > 0)
|
||||||
|
PluginMain.Instance.getServer().dispatchCommand(
|
||||||
|
PluginMain.Instance.getServer().getConsoleSender(),
|
||||||
|
sb.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Timer Ftimer;
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerDeath(PlayerDeathEvent e) {
|
||||||
|
if (!Minigames.plugin.pdata.getMinigamePlayer(e.getEntity())
|
||||||
|
.isInMinigame() && new Random().nextBoolean()) {
|
||||||
|
if (Ftimer != null)
|
||||||
|
Ftimer.cancel();
|
||||||
|
ActiveF = true;
|
||||||
|
FCount = 0;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
mp.PressedF = false;
|
||||||
|
p.sendMessage("§bPress F to pay respects.§r");
|
||||||
|
}
|
||||||
|
Ftimer = new Timer();
|
||||||
|
TimerTask tt = new TimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (ActiveF) {
|
||||||
|
ActiveF = false;
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
p.sendMessage("§b" + FCount + " "
|
||||||
|
+ (FCount == 1 ? "person" : "people")
|
||||||
|
+ " paid their respects.§r");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Ftimer.schedule(tt, 15 * 1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerItemPickup(PlayerPickupItemEvent e) {
|
||||||
|
// System.out.println("A");
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(e
|
||||||
|
.getPlayer());
|
||||||
|
// System.out.println("B");
|
||||||
|
|
||||||
|
/*
|
||||||
|
* if (!e.getPlayer().isOp() && (!mp.isInMinigame() ||
|
||||||
|
* mp.getMinigame().getName(false)
|
||||||
|
* .equalsIgnoreCase(Commands.KittyCannonMinigame))) return;
|
||||||
|
*/
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame)))
|
||||||
|
return;
|
||||||
|
// System.out.println("C");
|
||||||
|
ItemStack item = e.getItem().getItemStack();
|
||||||
|
if (!item.getType().equals(Material.SKULL_ITEM)
|
||||||
|
&& !item.getType().equals(Material.SKULL))
|
||||||
|
return;
|
||||||
|
// System.out.println("D");
|
||||||
|
SkullMeta meta = (SkullMeta) item.getItemMeta();
|
||||||
|
if (!meta.getDisplayName().equals("§rOcelot Head")
|
||||||
|
|| !meta.getOwner().equals("MHF_Ocelot"))
|
||||||
|
return;
|
||||||
|
// System.out.println("E");
|
||||||
|
if (meta.getLore() == null || meta.getLore().size() == 0)
|
||||||
|
return;
|
||||||
|
// System.out.println("F");
|
||||||
|
ItemStack hat = e.getPlayer().getInventory().getHelmet();
|
||||||
|
if (!(hat != null
|
||||||
|
&& (hat.getType().equals(Material.SKULL) || hat.getType()
|
||||||
|
.equals(Material.SKULL_ITEM)) && ((SkullMeta) hat
|
||||||
|
.getItemMeta()).getDisplayName().equals("§rWolf Head")))
|
||||||
|
e.getPlayer().damage(1f * item.getAmount(),
|
||||||
|
Bukkit.getPlayer(meta.getLore().get(0)));
|
||||||
|
e.getItem().remove();
|
||||||
|
// System.out.println("G");
|
||||||
|
e.setCancelled(true);
|
||||||
|
// System.out.println("H");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true)
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,450 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
SaveFiles(); //2015.08.09.
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
//System.out.println("Start: "+start);
|
||||||
|
if(start==-1+"IGN:".length()) //+length: 2015.08.10.
|
||||||
|
continue; //2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
//System.out.println("End: "+end);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
//System.out.println("IGN: "+ign);
|
||||||
|
ign = ign.trim();
|
||||||
|
//System.out.println("Trimmed IGN: "+ign);
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
/*else
|
||||||
|
flair = "non-presser";*/
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
//return p.Flair!=null; //2015.08.08.
|
||||||
|
return p.CommentedOnReddit; //2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
p.FlairRecognised=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(--s)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(??s)§r";
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if(text.equals("-1")) //If true, only non-presser/can't press; if false, any flair
|
||||||
|
p.FlairDecided=false;
|
||||||
|
else
|
||||||
|
p.FlairRecognised=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
//finalflair="";
|
||||||
|
//break;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
/*if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;*/
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.CommentedOnReddit=true; //2015.08.10.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
if(finalflair.length()==0) //Just for the message
|
||||||
|
finalflair="undecided";
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
//return flair==null ? "" : flair;
|
||||||
|
return flair; //2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
/*private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
*String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}*
|
||||||
|
}*/
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}*/
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{ //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
if(s.length>=2) //<-- 2015.08.10.
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("customflairs.txt"); //2015.08.09.
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
if(s.length>=2) //2015.08.10.
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(s[0]);
|
||||||
|
p.Flair=s[1]; //2015.08.09.
|
||||||
|
p.CommentedOnReddit=true; //Kind of
|
||||||
|
}
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void SaveFiles() //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static boolean RemoveLineFromFile(String file, String line)
|
||||||
|
{ //2015.08.09.
|
||||||
|
File inputFile = new File(file);
|
||||||
|
File tempFile = new File("_temp.txt");
|
||||||
|
|
||||||
|
if(!inputFile.exists())
|
||||||
|
return true; //2015.08.10.
|
||||||
|
|
||||||
|
try {
|
||||||
|
BufferedReader reader = new BufferedReader(new FileReader(inputFile));
|
||||||
|
BufferedWriter writer = new BufferedWriter(new FileWriter(tempFile));
|
||||||
|
|
||||||
|
String lineToRemove = line;
|
||||||
|
String currentLine;
|
||||||
|
|
||||||
|
while((currentLine = reader.readLine()) != null) {
|
||||||
|
// trim newline when comparing with lineToRemove
|
||||||
|
String trimmedLine = currentLine.trim();
|
||||||
|
//if(trimmedLine.equals(lineToRemove)) continue;
|
||||||
|
if(trimmedLine.contains(lineToRemove)) continue; //2015.08.09.
|
||||||
|
writer.write(currentLine + System.getProperty("line.separator"));
|
||||||
|
}
|
||||||
|
writer.close();
|
||||||
|
reader.close();
|
||||||
|
if(!tempFile.renameTo(inputFile))
|
||||||
|
{
|
||||||
|
inputFile.delete();
|
||||||
|
return tempFile.renameTo(inputFile);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return true;
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,452 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; //2015.08.12.
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
SaveFiles(); //2015.08.09.
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
//System.out.println("Start: "+start);
|
||||||
|
if(start==-1+"IGN:".length()) //+length: 2015.08.10.
|
||||||
|
continue; //2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
//System.out.println("End: "+end);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
//System.out.println("IGN: "+ign);
|
||||||
|
ign = ign.trim();
|
||||||
|
//System.out.println("Trimmed IGN: "+ign);
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
/*else
|
||||||
|
flair = "non-presser";*/
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
//return p.Flair!=null; //2015.08.08.
|
||||||
|
return p.CommentedOnReddit; //2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
p.FlairRecognised=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(--s)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(??s)§r";
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if(text.equals("-1")) //If true, only non-presser/can't press; if false, any flair
|
||||||
|
p.FlairDecided=false;
|
||||||
|
else
|
||||||
|
p.FlairRecognised=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
//finalflair="";
|
||||||
|
//break;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
/*if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;*/
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.CommentedOnReddit=true; //2015.08.10.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
if(finalflair.length()==0) //Just for the message
|
||||||
|
finalflair="undecided";
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
//return flair==null ? "" : flair;
|
||||||
|
return flair; //2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
/*private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
*String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}*
|
||||||
|
}*/
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}*/
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{ //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
if(s.length>=2) //<-- 2015.08.10.
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("customflairs.txt"); //2015.08.09.
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
if(s.length>=2) //2015.08.10.
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(s[0]);
|
||||||
|
p.Flair=s[1]; //2015.08.09.
|
||||||
|
p.CommentedOnReddit=true; //Kind of
|
||||||
|
}
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
System.out.println("Auto-flair plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void SaveFiles() //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static boolean RemoveLineFromFile(String file, String line)
|
||||||
|
{ //2015.08.09.
|
||||||
|
File inputFile = new File(file);
|
||||||
|
File tempFile = new File("_temp.txt");
|
||||||
|
|
||||||
|
if(!inputFile.exists())
|
||||||
|
return true; //2015.08.10.
|
||||||
|
|
||||||
|
try {
|
||||||
|
BufferedReader reader = new BufferedReader(new FileReader(inputFile));
|
||||||
|
BufferedWriter writer = new BufferedWriter(new FileWriter(tempFile));
|
||||||
|
|
||||||
|
String lineToRemove = line;
|
||||||
|
String currentLine;
|
||||||
|
|
||||||
|
while((currentLine = reader.readLine()) != null) {
|
||||||
|
// trim newline when comparing with lineToRemove
|
||||||
|
String trimmedLine = currentLine.trim();
|
||||||
|
//if(trimmedLine.equals(lineToRemove)) continue;
|
||||||
|
if(trimmedLine.contains(lineToRemove)) continue; //2015.08.09.
|
||||||
|
writer.write(currentLine + System.getProperty("line.separator"));
|
||||||
|
}
|
||||||
|
writer.close();
|
||||||
|
reader.close();
|
||||||
|
if(!tempFile.renameTo(inputFile))
|
||||||
|
{
|
||||||
|
inputFile.delete();
|
||||||
|
return tempFile.renameTo(inputFile);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return true;
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,362 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import tk.sznp.thebuttonautoflair.MaybeOfflinePlayer.FlairClassType;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p)
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, flair); //2015.07.20.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+username+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,29 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer
|
||||||
|
{ //2015.08.08.
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public String Flair; //If the user comments their name, it gets set, it doesn't matter if they accepted it or not
|
||||||
|
public boolean AcceptedFlair;
|
||||||
|
public boolean IgnoredFlair;
|
||||||
|
//public
|
||||||
|
public static HashMap<String, MaybeOfflinePlayer> AllPlayers=new HashMap<>(); //2015.08.08.
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(String playername)
|
||||||
|
{
|
||||||
|
if(!AllPlayers.containsKey(playername))
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player=new MaybeOfflinePlayer();
|
||||||
|
player.PlayerName=playername;
|
||||||
|
AllPlayers.put(playername, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(playername);
|
||||||
|
}
|
||||||
|
public enum FlairClassType
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,353 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.htmlcleaner.HtmlCleaner;
|
||||||
|
import org.htmlcleaner.TagNode;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
try {
|
||||||
|
System.out.println("Extracting necessary libraries...");
|
||||||
|
final File[] libs = new File[] { new File(getDataFolder(),
|
||||||
|
"htmlcleaner-2.16.jar") };
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
JarUtils.extractFromJar(lib.getName(),
|
||||||
|
lib.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
getLogger().warning(
|
||||||
|
"Failed to load plugin! Could not find lib: "
|
||||||
|
+ lib.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().disablePlugin(this);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
addClassPath(JarUtils.getJarUrl(lib));
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ThreadMethod() {
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.GetFromName(ign);
|
||||||
|
if (mp == null)
|
||||||
|
continue;
|
||||||
|
if (!mp.UserNames.contains(author))
|
||||||
|
mp.UserNames.add(author);
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
mp.FlairState = FlairStates.Commented;
|
||||||
|
ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DownloadFlair(MaybeOfflinePlayer mp)
|
||||||
|
throws MalformedURLException, IOException {
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users=" + mp.UserName)
|
||||||
|
.replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1)
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(mp, flair, flairclass, mp.UserName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair(MaybeOfflinePlayer p, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
p.UserName = username;
|
||||||
|
p.FlairState = FlairStates.Recognised;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
p.SetFlairColor(0xc);
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
p.SetFlairColor(0x6);
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
p.SetFlairColor(0xe);
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
p.SetFlairColor(0xa);
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
p.SetFlairColor(0x9);
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
p.SetFlairColor(0x7);
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "cant-press":
|
||||||
|
p.SetFlairColor(0xf);
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if (CheckForJoinDate(p)) {
|
||||||
|
p.SetFlair(0x7, "--");
|
||||||
|
} else {
|
||||||
|
p.SetFlair(0xf, "--");
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.SetFlairColor(0);
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.FlairColor = 0;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (text.equals("-1"))
|
||||||
|
text = "--";
|
||||||
|
p.FlairTime = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean CheckForJoinDate(MaybeOfflinePlayer mp)
|
||||||
|
throws Exception {
|
||||||
|
URL url = new URL("https://www.reddit.com/u/" + mp.UserName);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
HtmlCleaner cleaner = new HtmlCleaner();
|
||||||
|
TagNode node = cleaner.clean(in);
|
||||||
|
|
||||||
|
node = node.getElementsByAttValue("class", "age", true, true)[0];
|
||||||
|
node = node.getElementsByName("time", false)[0];
|
||||||
|
String joindate = node.getAttributeByName("datetime");
|
||||||
|
SimpleDateFormat parserSDF = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
|
joindate = joindate.split("T")[0];
|
||||||
|
Date date = parserSDF.parse(joindate);
|
||||||
|
return date.before(new Calendar.Builder()
|
||||||
|
.setTimeZone(TimeZone.getTimeZone("UTC")).setDate(2015, 4, 1)
|
||||||
|
.build().getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ConfirmUserMessage(MaybeOfflinePlayer mp) {
|
||||||
|
Player p = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented) && p != null)
|
||||||
|
if (mp.UserNames.size() > 1)
|
||||||
|
p.sendMessage("§9Multiple Reddit users commented your name. You can select with /u accept.§r §6Type /u accept or /u ignore§r");
|
||||||
|
else
|
||||||
|
p.sendMessage("§9A Reddit user commented your name. Is that you?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) {
|
||||||
|
if (reload) {
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("announcemessages.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("thebuttonmc.yml");
|
||||||
|
if (file.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
yc.load(file);
|
||||||
|
MaybeOfflinePlayer.Load(yc);
|
||||||
|
PlayerListener.NotificationSound = yc
|
||||||
|
.getString("notificationsound");
|
||||||
|
PlayerListener.NotificationPitch = yc
|
||||||
|
.getDouble("notificationpitch");
|
||||||
|
AnnounceTime = yc.getInt("announcetime");
|
||||||
|
AnnounceMessages.addAll(yc.getStringList("announcements"));
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() {
|
||||||
|
System.out.println("Saving files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("thebuttonmc.yml");
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
MaybeOfflinePlayer.Save(yc);
|
||||||
|
yc.set("notificationsound", PlayerListener.NotificationSound);
|
||||||
|
yc.set("notificationpitch", PlayerListener.NotificationPitch);
|
||||||
|
yc.set("announcetime", AnnounceTime);
|
||||||
|
yc.set("announcements", AnnounceMessages);
|
||||||
|
yc.save(file);
|
||||||
|
System.out.println("The Button Minecraft plugin saved files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addClassPath(final URL url) throws IOException {
|
||||||
|
final URLClassLoader sysloader = (URLClassLoader) ClassLoader
|
||||||
|
.getSystemClassLoader();
|
||||||
|
final Class<URLClassLoader> sysclass = URLClassLoader.class;
|
||||||
|
try {
|
||||||
|
final Method method = sysclass.getDeclaredMethod("addURL",
|
||||||
|
new Class[] { URL.class });
|
||||||
|
method.setAccessible(true);
|
||||||
|
method.invoke(sysloader, new Object[] { url });
|
||||||
|
} catch (final Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
throw new IOException("Error adding " + url
|
||||||
|
+ " to system classloader");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,112 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2()
|
||||||
|
{
|
||||||
|
|
||||||
|
//Flairs from Command Block The Button - Teams
|
||||||
|
//PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
event.getPlayer().setPlayerListName("");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true);
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,113 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color) {
|
||||||
|
FlairColor = color;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time) {
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time) {
|
||||||
|
FlairColor = color;
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2() {
|
||||||
|
|
||||||
|
// Flairs from Command Block The Button - Teams
|
||||||
|
// PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
event.getPlayer().setPlayerListName("");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,221 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
|
||||||
|
SendMessage(player, "§6Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
case "confirm":
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,370 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload)
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear(); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,368 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§6Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r";
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
//SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,355 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
String finalflair;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
{
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).AcceptedFlair)
|
||||||
|
AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+username+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,215 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(p.Flair==null)
|
||||||
|
{
|
||||||
|
player.sendMessage("Error: You need to write your username to the reddit thread at /r/TheButtonMinecraft");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
player.sendMessage("§6Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§6You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p.Flair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
if(mp.Flair!=null)
|
||||||
|
{
|
||||||
|
String flair=mp.Flair;
|
||||||
|
PluginMain.RemovePlayerDisplayFlairFinal(p, flair);
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(p, flair);
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//String msg="§6Reloaded config file.§r";
|
||||||
|
String msg="§6Reloaded all files.§r";
|
||||||
|
SendMessage(player, msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
DoReload(player);
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
System.out.println(message);
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,358 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import tk.sznp.thebuttonautoflair.MaybeOfflinePlayer.FlairClassType;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
{
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(player.getName()).AcceptedFlair)
|
||||||
|
AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
else
|
||||||
|
player.sendMessage("§9Are you Reddit user "+username+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,465 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
System.out.println("The Button Minecraft server plugin");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() // <-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if (HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users="
|
||||||
|
+ author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1) // 2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors = new HashMap<String, String>(); // 2015.07.20.
|
||||||
|
|
||||||
|
public Boolean HasIGFlair(String playername) {
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AddPlayerIfNeeded(playername); // 2015.08.08.
|
||||||
|
return p.CommentedOnReddit; // 2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AddPlayerIfNeeded(playername); // 2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided = true;
|
||||||
|
p.FlairRecognised = true;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
finalflair = "§c(" + text + ")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair = "§6(" + text + ")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair = "§e(" + text + ")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair = "§a(" + text + ")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair = "§9(" + text + ")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair = "§5(" + text + ")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair = "§7(--s)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair = "§5(" + text + ")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": // 2015.08.08.
|
||||||
|
finalflair = "§r(??s)§r";
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
p.FlairDecided = false;
|
||||||
|
else
|
||||||
|
p.FlairRecognised = false;
|
||||||
|
finalflair = "";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
p.Flair = finalflair; // 2015.08.08.
|
||||||
|
p.CommentedOnReddit = true; // 2015.08.10.
|
||||||
|
p.UserName = username; // 2015.08.08.
|
||||||
|
for (Player player : getServer().getOnlinePlayers()) // <-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if (player.getName().equals(playername)) {
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player) { // 2015.07.16.
|
||||||
|
String flair = MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; // 2015.08.08.
|
||||||
|
// return flair==null ? "" : flair;
|
||||||
|
return flair; // 2015.08.10.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player,
|
||||||
|
Player p) // <-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if (MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if (MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair) {
|
||||||
|
if (!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); // 2015.08.09.
|
||||||
|
} else
|
||||||
|
p.sendMessage("§9Are you Reddit user " + player.UserName
|
||||||
|
+ "?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname) { // 2015.07.20.
|
||||||
|
if (TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player) { // 2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock()
|
||||||
|
.getTown(); // TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) // <-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if (reload) { // 2015.08.09.
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
TownColors.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin..."); // 2015.08.09.
|
||||||
|
try {
|
||||||
|
File file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists()) {
|
||||||
|
BufferedReader br = new BufferedReader(new FileReader(
|
||||||
|
"flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null) {
|
||||||
|
String name = line.replace("\n", "");
|
||||||
|
// System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair = true; // 2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists()) {
|
||||||
|
BufferedReader br = new BufferedReader(new FileReader(
|
||||||
|
"flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null) {
|
||||||
|
String name = line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair = true; // 2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file = new File("autoflairconfig.txt");
|
||||||
|
if (file.exists()) {
|
||||||
|
BufferedReader br = new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null) {
|
||||||
|
String[] s = line.split(" ");
|
||||||
|
if (s.length >= 2) // <-- 2015.08.10.
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file = new File("customflairs.txt"); // 2015.08.09.
|
||||||
|
if (file.exists()) {
|
||||||
|
BufferedReader br = new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null) {
|
||||||
|
String[] s = line.split(" ");
|
||||||
|
if (s.length >= 2) // 2015.08.10.
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer
|
||||||
|
.AddPlayerIfNeeded(s[0]);
|
||||||
|
p.Flair = s[1]; // 2015.08.09.
|
||||||
|
p.CommentedOnReddit = true; // Kind of
|
||||||
|
p.FlairDecided = true;
|
||||||
|
p.FlairRecognised = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file = new File("notificationsound.txt"); // 2015.08.09.
|
||||||
|
if (file.exists()) {
|
||||||
|
BufferedReader br = new BufferedReader(new FileReader(file));
|
||||||
|
String line = br.readLine();
|
||||||
|
String[] split = line.split(" ");
|
||||||
|
PlayerListener.NotificationSound = split[0];
|
||||||
|
PlayerListener.NotificationPitch = Float.parseFloat(split[1]);
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file = new File("announcemessages.txt"); // 2015.08.09.
|
||||||
|
if (file.exists()) {
|
||||||
|
BufferedReader br = new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
boolean first = true;
|
||||||
|
while ((line = br.readLine()) != null) {
|
||||||
|
if (first) {
|
||||||
|
AnnounceTime = Integer.parseInt(line.trim());
|
||||||
|
first = false;
|
||||||
|
} else
|
||||||
|
AnnounceMessages.add(line.trim());
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
} else {
|
||||||
|
// Write time
|
||||||
|
try {
|
||||||
|
BufferedWriter bw;
|
||||||
|
bw = new BufferedWriter(new FileWriter(file));
|
||||||
|
bw.write(AnnounceTime + "\n");
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() // <-- 2015.08.09.
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file = new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for (MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers
|
||||||
|
.values()) // <-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if (!player.AcceptedFlair)
|
||||||
|
continue; // 2015.08.08.
|
||||||
|
bw.write(player.PlayerName + "\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for (MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers
|
||||||
|
.values()) // <-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if (!player.IgnoredFlair)
|
||||||
|
continue; // 2015.08.08.
|
||||||
|
bw.write(player.PlayerName + "\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean RemoveLineFromFile(String file, String line) { // 2015.08.09.
|
||||||
|
File inputFile = new File(file);
|
||||||
|
File tempFile = new File("_temp.txt");
|
||||||
|
|
||||||
|
if (!inputFile.exists())
|
||||||
|
return true; // 2015.08.10.
|
||||||
|
|
||||||
|
try {
|
||||||
|
BufferedReader reader = new BufferedReader(
|
||||||
|
new FileReader(inputFile));
|
||||||
|
BufferedWriter writer = new BufferedWriter(new FileWriter(tempFile));
|
||||||
|
|
||||||
|
String lineToRemove = line;
|
||||||
|
String currentLine;
|
||||||
|
|
||||||
|
while ((currentLine = reader.readLine()) != null) {
|
||||||
|
// trim newline when comparing with lineToRemove
|
||||||
|
String trimmedLine = currentLine.trim();
|
||||||
|
if (trimmedLine.split(" ")[0].equals(lineToRemove))
|
||||||
|
continue; // 2015.08.17.
|
||||||
|
writer.write(currentLine + System.getProperty("line.separator"));
|
||||||
|
}
|
||||||
|
writer.close();
|
||||||
|
reader.close();
|
||||||
|
if (!tempFile.renameTo(inputFile)) {
|
||||||
|
inputFile.delete();
|
||||||
|
return tempFile.renameTo(inputFile);
|
||||||
|
} else
|
||||||
|
return true;
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean RemoveLineFromFile(String file, int index) {
|
||||||
|
File inputFile = new File(file);
|
||||||
|
File tempFile = new File("_temp2.txt");
|
||||||
|
|
||||||
|
if (!inputFile.exists())
|
||||||
|
return true; // 2015.08.10.
|
||||||
|
|
||||||
|
try {
|
||||||
|
BufferedReader reader = new BufferedReader(
|
||||||
|
new FileReader(inputFile));
|
||||||
|
BufferedWriter writer = new BufferedWriter(new FileWriter(tempFile));
|
||||||
|
|
||||||
|
String currentLine;
|
||||||
|
int i = 0;
|
||||||
|
|
||||||
|
while ((currentLine = reader.readLine()) != null) {
|
||||||
|
if (i++ == index)
|
||||||
|
continue;
|
||||||
|
writer.write(currentLine + System.getProperty("line.separator"));
|
||||||
|
}
|
||||||
|
writer.close();
|
||||||
|
reader.close();
|
||||||
|
if (!tempFile.renameTo(inputFile)) {
|
||||||
|
inputFile.delete();
|
||||||
|
return tempFile.renameTo(inputFile);
|
||||||
|
} else
|
||||||
|
return true;
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,122 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.configuration.ConfigurationSection;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer {
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public List<String> UserNames;
|
||||||
|
private String FlairTime;
|
||||||
|
private short FlairColor;
|
||||||
|
public FlairStates FlairState;
|
||||||
|
public boolean RPMode = true;
|
||||||
|
public boolean PressedF;
|
||||||
|
public Location SavedLocation;
|
||||||
|
public boolean Working;
|
||||||
|
public int Tables = 10;
|
||||||
|
|
||||||
|
public UUID UUID;
|
||||||
|
|
||||||
|
public static HashMap<UUID, MaybeOfflinePlayer> AllPlayers = new HashMap<>();
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(UUID uuid) {
|
||||||
|
if (!AllPlayers.containsKey(uuid)) {
|
||||||
|
MaybeOfflinePlayer player = new MaybeOfflinePlayer();
|
||||||
|
player.UUID = uuid;
|
||||||
|
player.FlairColor = 0;
|
||||||
|
player.FlairTime = "";
|
||||||
|
player.FlairState = FlairStates.NoComment;
|
||||||
|
player.UserNames = new ArrayList<>();
|
||||||
|
AllPlayers.put(uuid, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(uuid);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Load(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.getConfigurationSection("players");
|
||||||
|
for (String key : cs.getKeys(false)) {
|
||||||
|
ConfigurationSection cs2 = cs.getConfigurationSection(key);
|
||||||
|
MaybeOfflinePlayer mp = AddPlayerIfNeeded(java.util.UUID
|
||||||
|
.fromString(cs2.getString("uuid")));
|
||||||
|
mp.UserName = cs2.getString("username");
|
||||||
|
mp.FlairColor = (short) cs2.getInt("flaircolor");
|
||||||
|
mp.FlairTime = cs2.getString("flairtime");
|
||||||
|
String flairstate = cs2.getString("flairstate");
|
||||||
|
if (flairstate != null)
|
||||||
|
mp.FlairState = FlairStates.valueOf(flairstate);
|
||||||
|
else
|
||||||
|
mp.FlairState = FlairStates.NoComment;
|
||||||
|
mp.PlayerName = cs2.getString("playername");
|
||||||
|
mp.UserNames = cs2.getStringList("usernames");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Save(YamlConfiguration yc) {
|
||||||
|
ConfigurationSection cs = yc.createSection("players");
|
||||||
|
for (MaybeOfflinePlayer mp : MaybeOfflinePlayer.AllPlayers.values()) {
|
||||||
|
ConfigurationSection cs2 = cs.createSection(mp.UUID.toString());
|
||||||
|
cs2.set("playername", mp.PlayerName);
|
||||||
|
cs2.set("username", mp.UserName);
|
||||||
|
cs2.set("flaircolor", mp.FlairColor);
|
||||||
|
cs2.set("flairtime", mp.FlairTime);
|
||||||
|
cs2.set("flairstate", mp.FlairState.toString());
|
||||||
|
cs2.set("uuid", mp.UUID.toString());
|
||||||
|
cs2.set("usernames", mp.UserNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer GetFromName(String name) {
|
||||||
|
for (MaybeOfflinePlayer mp : AllPlayers.values())
|
||||||
|
if (mp.PlayerName.equalsIgnoreCase(name))
|
||||||
|
return mp;
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String GetFormattedFlair() {
|
||||||
|
if (FlairColor == 0x00)
|
||||||
|
return "";
|
||||||
|
if (FlairTime == null || FlairTime.length() == 0)
|
||||||
|
return String.format("§%x(??s)§r", FlairColor);
|
||||||
|
return String.format("§%x(%ss)§r", FlairColor, FlairTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairColor(short color) {
|
||||||
|
FlairColor = color;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlairTime(String time) {
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(short color, String time) {
|
||||||
|
FlairColor = color;
|
||||||
|
FlairTime = time;
|
||||||
|
SetFlair2();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair2() {
|
||||||
|
|
||||||
|
// Flairs from Command Block The Button - Teams
|
||||||
|
// PluginMain.Instance.getServer().getScoreboardManager().getMainScoreboard().getTeams().add()
|
||||||
|
Player p = Bukkit.getPlayer(UUID);
|
||||||
|
p.setPlayerListName(String.format("%s%s", p.getPlayerListName(),
|
||||||
|
GetFormattedFlair()));
|
||||||
|
}
|
||||||
|
|
||||||
|
public short GetFlairColor()
|
||||||
|
{
|
||||||
|
return FlairColor;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,373 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
if(reload)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear(); //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,353 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.ConsoleCommandSender;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.htmlcleaner.HtmlCleaner;
|
||||||
|
import org.htmlcleaner.TagNode;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.lang.String;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.TimeZone;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
|
||||||
|
// A user, which flair isn't obtainable:
|
||||||
|
// https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
public static PluginMain Instance;
|
||||||
|
public static ConsoleCommandSender Console; // 2015.08.12.
|
||||||
|
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable() {
|
||||||
|
try {
|
||||||
|
System.out.println("Extracting necessary libraries...");
|
||||||
|
final File[] libs = new File[] { new File(getDataFolder(),
|
||||||
|
"htmlcleaner-2.16.jar") };
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
JarUtils.extractFromJar(lib.getName(),
|
||||||
|
lib.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (final File lib : libs) {
|
||||||
|
if (!lib.exists()) {
|
||||||
|
getLogger().warning(
|
||||||
|
"Failed to load plugin! Could not find lib: "
|
||||||
|
+ lib.getName());
|
||||||
|
Bukkit.getServer().getPluginManager().disablePlugin(this);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
addClassPath(JarUtils.getJarUrl(lib));
|
||||||
|
}
|
||||||
|
} catch (final Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(),
|
||||||
|
this);
|
||||||
|
Commands comm = new Commands();
|
||||||
|
this.getCommand("u").setExecutor(comm);
|
||||||
|
this.getCommand("u").setUsage(
|
||||||
|
this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("nrp").setExecutor(comm);
|
||||||
|
this.getCommand("nrp").setUsage(
|
||||||
|
this.getCommand("nrp").getUsage().replace('&', '§'));
|
||||||
|
this.getCommand("ooc").setExecutor(comm);
|
||||||
|
this.getCommand("ooc").setUsage(
|
||||||
|
this.getCommand("ooc").getUsage().replace('&', '§'));
|
||||||
|
Instance = this; // 2015.08.08.
|
||||||
|
Console = this.getServer().getConsoleSender(); // 2015.08.12.
|
||||||
|
LoadFiles(false); // 2015.08.09.
|
||||||
|
Runnable r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
ThreadMethod();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Thread t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
r = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
AnnouncerThread.Run();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
t = new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean stop = false;
|
||||||
|
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable() {
|
||||||
|
SaveFiles(); // 2015.08.09.
|
||||||
|
stop = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ThreadMethod() {
|
||||||
|
while (!stop) {
|
||||||
|
try {
|
||||||
|
String body = DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json = new JSONArray(body).getJSONObject(1)
|
||||||
|
.getJSONObject("data").getJSONArray("children");
|
||||||
|
for (Object obj : json) {
|
||||||
|
JSONObject item = (JSONObject) obj;
|
||||||
|
String author = item.getJSONObject("data").getString(
|
||||||
|
"author");
|
||||||
|
String ign = item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
if (start == -1 + "IGN:".length()) // +length: 2015.08.10.
|
||||||
|
continue; // 2015.08.09.
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end = ign.indexOf('\n', start); // 2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.GetFromName(ign);
|
||||||
|
if (mp == null)
|
||||||
|
continue;
|
||||||
|
if (!mp.UserNames.contains(author))
|
||||||
|
mp.UserNames.add(author);
|
||||||
|
if (mp.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
mp.FlairState = FlairStates.Commented;
|
||||||
|
ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Thread.sleep(10000);
|
||||||
|
} catch (InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
// System.out.println("Error!\n" + e);
|
||||||
|
LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DownloadFlair(MaybeOfflinePlayer mp)
|
||||||
|
throws MalformedURLException, IOException {
|
||||||
|
String[] flairdata = DownloadString(
|
||||||
|
"http://karmadecay.com/thebutton-data.php?users=" + mp.UserName)
|
||||||
|
.replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if (flairdata.length > 1)
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair = "";
|
||||||
|
String flairclass;
|
||||||
|
if (flairdata.length > 2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass = "unknown";
|
||||||
|
SetFlair(mp, flair, flairclass, mp.UserName);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; // 2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException,
|
||||||
|
IOException {
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetFlair(MaybeOfflinePlayer p, String text, String flairclass,
|
||||||
|
String username) {
|
||||||
|
p.UserName = username;
|
||||||
|
p.FlairState = FlairStates.Recognised;
|
||||||
|
switch (flairclass) {
|
||||||
|
case "press-1":
|
||||||
|
p.SetFlairColor(0xc);
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
p.SetFlairColor(0x6);
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
p.SetFlairColor(0xe);
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
p.SetFlairColor(0xa);
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
p.SetFlairColor(0x9);
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
p.SetFlairColor(0x7);
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
p.SetFlairColor(0x5);
|
||||||
|
break;
|
||||||
|
case "cant-press":
|
||||||
|
p.SetFlairColor(0xf);
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
if (text.equals("-1")) // If true, only non-presser/can't press; if
|
||||||
|
// false, any flair
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if (CheckForJoinDate(p)) {
|
||||||
|
p.SetFlair(0x7, "--");
|
||||||
|
} else {
|
||||||
|
p.SetFlair(0xf, "--");
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.SetFlairColor(0);
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
p.FlairState = FlairStates.Commented; // Flair unknown
|
||||||
|
p.SetFlairColor(0);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (text.equals("-1"))
|
||||||
|
text = "--";
|
||||||
|
p.SetFlairTime(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean CheckForJoinDate(MaybeOfflinePlayer mp)
|
||||||
|
throws Exception {
|
||||||
|
URL url = new URL("https://www.reddit.com/u/" + mp.UserName);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
HtmlCleaner cleaner = new HtmlCleaner();
|
||||||
|
TagNode node = cleaner.clean(in);
|
||||||
|
|
||||||
|
node = node.getElementsByAttValue("class", "age", true, true)[0];
|
||||||
|
node = node.getElementsByName("time", false)[0];
|
||||||
|
String joindate = node.getAttributeByName("datetime");
|
||||||
|
SimpleDateFormat parserSDF = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
|
joindate = joindate.split("T")[0];
|
||||||
|
Date date = parserSDF.parse(joindate);
|
||||||
|
return date.before(new Calendar.Builder()
|
||||||
|
.setTimeZone(TimeZone.getTimeZone("UTC")).setDate(2015, 4, 1)
|
||||||
|
.build().getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ConfirmUserMessage(MaybeOfflinePlayer mp) {
|
||||||
|
Player p = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented) && p != null)
|
||||||
|
if (mp.UserNames.size() > 1)
|
||||||
|
p.sendMessage("§9Multiple Reddit users commented your name. You can select with /u accept.§r §6Type /u accept or /u ignore§r");
|
||||||
|
else
|
||||||
|
p.sendMessage("§9A Reddit user commented your name. Is that you?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers() {
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> AnnounceMessages = new ArrayList<>();
|
||||||
|
public static int AnnounceTime = 15 * 60 * 1000;
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) {
|
||||||
|
if (reload) {
|
||||||
|
System.out
|
||||||
|
.println("The Button Minecraft plugin cleanup for reloading...");
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear();
|
||||||
|
AnnounceMessages.clear();
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("announcemessages.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsaccepted.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("flairsignored.txt");
|
||||||
|
if (file.exists())
|
||||||
|
file.delete();
|
||||||
|
file = new File("thebuttonmc.yml");
|
||||||
|
if (file.exists()) {
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
yc.load(file);
|
||||||
|
MaybeOfflinePlayer.Load(yc);
|
||||||
|
PlayerListener.NotificationSound = yc
|
||||||
|
.getString("notificationsound");
|
||||||
|
PlayerListener.NotificationPitch = yc
|
||||||
|
.getDouble("notificationpitch");
|
||||||
|
AnnounceTime = yc.getInt("announcetime");
|
||||||
|
AnnounceMessages.addAll(yc.getStringList("announcements"));
|
||||||
|
}
|
||||||
|
System.out.println("The Button Minecraft plugin loaded files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
} catch (InvalidConfigurationException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void SaveFiles() {
|
||||||
|
System.out.println("Saving files for The Button Minecraft plugin...");
|
||||||
|
try {
|
||||||
|
File file = new File("thebuttonmc.yml");
|
||||||
|
YamlConfiguration yc = new YamlConfiguration();
|
||||||
|
MaybeOfflinePlayer.Save(yc);
|
||||||
|
yc.set("notificationsound", PlayerListener.NotificationSound);
|
||||||
|
yc.set("notificationpitch", PlayerListener.NotificationPitch);
|
||||||
|
yc.set("announcetime", AnnounceTime);
|
||||||
|
yc.set("announcements", AnnounceMessages);
|
||||||
|
yc.save(file);
|
||||||
|
System.out.println("The Button Minecraft plugin saved files!");
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
LastException = e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addClassPath(final URL url) throws IOException {
|
||||||
|
final URLClassLoader sysloader = (URLClassLoader) ClassLoader
|
||||||
|
.getSystemClassLoader();
|
||||||
|
final Class<URLClassLoader> sysclass = URLClassLoader.class;
|
||||||
|
try {
|
||||||
|
final Method method = sysclass.getDeclaredMethod("addURL",
|
||||||
|
new Class[] { URL.class });
|
||||||
|
method.setAccessible(true);
|
||||||
|
method.invoke(sysloader, new Object[] { url });
|
||||||
|
} catch (final Throwable t) {
|
||||||
|
t.printStackTrace();
|
||||||
|
throw new IOException("Error adding " + url
|
||||||
|
+ " to system classloader");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,603 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.command.BlockCommandSender;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Ocelot;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.potion.PotionEffectType;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.Mob;
|
||||||
|
import com.earth2me.essentials.Mob.MobException;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer Lastlol = null;
|
||||||
|
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label,
|
||||||
|
String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
switch (cmd.getName()) {
|
||||||
|
case "u": {
|
||||||
|
if (args.length < 1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(player
|
||||||
|
.getUniqueId());
|
||||||
|
switch (args[0].toLowerCase()) {
|
||||||
|
case "accept": {
|
||||||
|
if (args.length < 2 && p.UserNames.size() > 1) {
|
||||||
|
player.sendMessage("§9Multiple users commented your name. §bPlease pick one using /u accept <username>");
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
player.sendMessage(sb.toString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)
|
||||||
|
|| p.UserNames.size() == 0) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1 && !p.UserNames.contains(args[1])) {
|
||||||
|
player.sendMessage("§cError: Unknown name: " + args[1]
|
||||||
|
+ "§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.Working) {
|
||||||
|
player.sendMessage("§cError: Something is already in progress.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((args.length > 1 ? args[1] : p.UserNames.get(0))
|
||||||
|
.equals(p.UserName)) {
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1)
|
||||||
|
p.UserName = args[1];
|
||||||
|
else
|
||||||
|
p.UserName = p.UserNames.get(0);
|
||||||
|
|
||||||
|
player.sendMessage("§bObtaining flair...");
|
||||||
|
p.Working = true;
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
PluginMain.Instance.DownloadFlair(mp);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
Player player = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask an admin to set it for you. Also, prepare a comment on /r/thebutton, if possible.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String flair = mp.GetFormattedFlair();
|
||||||
|
mp.FlairState = FlairStates.Accepted;
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
player.sendMessage("§bYour flair has been set:§r "
|
||||||
|
+ flair);
|
||||||
|
mp.Working = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = p;
|
||||||
|
timer.schedule(tt, 20);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore": {
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!p.FlairState.equals(FlairStates.Ignored)) {
|
||||||
|
p.FlairState = FlairStates.Ignored;
|
||||||
|
p.SetFlairTime("");
|
||||||
|
p.UserName = "";
|
||||||
|
player.sendMessage("§bYou have removed your flair. You can still use /u accept to get one.§r");
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou already removed your flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "admin": // 2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "opme": // 2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, wouldn't it?"); // Sometimes
|
||||||
|
// I'm
|
||||||
|
// bored
|
||||||
|
// too
|
||||||
|
break;
|
||||||
|
case "announce":
|
||||||
|
DoAnnounce(player, args, null);
|
||||||
|
break;
|
||||||
|
case "name":
|
||||||
|
if (args.length == 1) {
|
||||||
|
player.sendMessage("§cUsage: /u name <playername>§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer
|
||||||
|
.GetFromName(args[1]);
|
||||||
|
if (mp == null) {
|
||||||
|
player.sendMessage("§cUnknown user: " + args[1]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
player.sendMessage("§bUsername of " + args[1] + ": "
|
||||||
|
+ mp.UserName);
|
||||||
|
break;
|
||||||
|
case "enable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = true;
|
||||||
|
player.sendMessage("Enabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "disable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = false;
|
||||||
|
player.sendMessage("Disabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "kittycannon":
|
||||||
|
DoKittyCannon(player, args);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "nrp":
|
||||||
|
case "ooc":
|
||||||
|
if (args.length == 0) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = false;
|
||||||
|
String message = "";
|
||||||
|
for (String arg : args)
|
||||||
|
message += arg + " ";
|
||||||
|
player.chat(message.substring(0, message.length() - 1));
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = true;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
case "unlol":
|
||||||
|
Player p = null;
|
||||||
|
System.out.println("Lastlol: " + Lastlol);
|
||||||
|
if (Lastlol != null
|
||||||
|
|| (p = Bukkit.getPlayer(Lastlol.UUID)) != null) {
|
||||||
|
p.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.BLINDNESS, 10, 5, false, false));
|
||||||
|
for (Player pl : PluginMain.GetPlayers())
|
||||||
|
pl.sendMessage(player.getDisplayName() + " unlolled "
|
||||||
|
+ p.getDisplayName());
|
||||||
|
Lastlol = null;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("admin")) // 2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); // 2015.08.09.
|
||||||
|
return true; // 2015.08.09.
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("announce")) {
|
||||||
|
if (sender instanceof BlockCommandSender)
|
||||||
|
DoAnnounce(null, args, (BlockCommandSender) sender);
|
||||||
|
else
|
||||||
|
DoAnnounce(null, args, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoReload(Player player) { // 2015.07.20.
|
||||||
|
try {
|
||||||
|
PluginMain.Console
|
||||||
|
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); // 2015.08.09.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (mp.FlairState.equals(FlairStates.Recognised)
|
||||||
|
|| mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
String msg = "§bNote: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; // 2015.08.09.
|
||||||
|
p.sendMessage(msg); // 2015.08.09.
|
||||||
|
}
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading done!§r");
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
if (player != null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Player ReloadPlayer; // 2015.08.09.
|
||||||
|
|
||||||
|
private static String DoAdminUsage = "§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin|togglerpshow|toggledebug|savepos|loadpos§r";
|
||||||
|
|
||||||
|
private static void DoAdmin(Player player, String[] args) { // 2015.08.09.
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// args[0] is "admin"
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer = player; // 2015.08.09.
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§bMake sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; // <-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if (ReloadPlayer == player)
|
||||||
|
DoReload(player); // 2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); // 2015.08.09.
|
||||||
|
SendMessage(player,
|
||||||
|
"§bSaved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": // 2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
case "togglerpshow":
|
||||||
|
PlayerListener.ShowRPTag = !PlayerListener.ShowRPTag;
|
||||||
|
SendMessage(player, "RP tag showing "
|
||||||
|
+ (PlayerListener.ShowRPTag ? "enabled" : "disabled"));
|
||||||
|
break;
|
||||||
|
case "toggledebug":
|
||||||
|
PlayerListener.DebugMode = !PlayerListener.DebugMode;
|
||||||
|
SendMessage(player, "DebugMode: " + PlayerListener.DebugMode);
|
||||||
|
break;
|
||||||
|
case "savepos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "loadpos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "updatedynmap":
|
||||||
|
DoUpdateDynmap(player, args);
|
||||||
|
default:
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.GetFromName(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SendMessage(player, "Player name: " + p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: " + p.GetFormattedFlair());
|
||||||
|
SendMessage(player, "Username: " + p.UserName);
|
||||||
|
SendMessage(player, "Flair state: " + p.FlairState);
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
SendMessage(player, sb.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SendMessage(Player player, String message) { // 2015.08.09.
|
||||||
|
if (player == null)
|
||||||
|
PluginMain.Console.sendMessage(message); // 2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoGetLastError(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if (PluginMain.LastException != null) {
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException = null;
|
||||||
|
} else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SetPlayerFlair(Player player,
|
||||||
|
MaybeOfflinePlayer targetplayer, short flaircolor, String flairtime) {
|
||||||
|
targetplayer.SetFlair(flaircolor, flairtime);
|
||||||
|
targetplayer.FlairState = FlairStates.Accepted;
|
||||||
|
targetplayer.UserName = "";
|
||||||
|
SendMessage(player,
|
||||||
|
"§bThe flair has been set. Player: " + targetplayer.PlayerName
|
||||||
|
+ " Flair: " + targetplayer.GetFormattedFlair() + "§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoSetFlair(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if (args.length < 4) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = Bukkit.getPlayer(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
SendMessage(player, "§cPLayer not found.&r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
short flaircolor = 0x00;
|
||||||
|
try {
|
||||||
|
flaircolor = Short.parseShort(args[3], 16);
|
||||||
|
} catch (Exception e) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cFlaircolor must be a hexadecimal number (don't include &).");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player,
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()),
|
||||||
|
flaircolor, (args.length < 5 ? "" : args[4]));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdatePlugin(Player player) { // 2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL(
|
||||||
|
"https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File(
|
||||||
|
"plugins/TheButtonAutoFlair.jar"));
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoAnnounce(Player player, String[] args,
|
||||||
|
BlockCommandSender commandblock) {
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "add":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce add <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
for (int i = 2; i < args.length; i++) {
|
||||||
|
sb.append(args[i]);
|
||||||
|
if (i != args.length - 1)
|
||||||
|
sb.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage = sb.toString().replace('&', '§');
|
||||||
|
PluginMain.AnnounceMessages.add(finalmessage);
|
||||||
|
SendMessage(player, "§bAnnouncement added.§r");
|
||||||
|
break;
|
||||||
|
case "remove":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce remove <index>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceMessages.remove(Integer.parseInt(args[2]));
|
||||||
|
break;
|
||||||
|
case "settime":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u announce settime <minutes>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceTime = Integer.parseInt(args[2]) * 60 * 1000;
|
||||||
|
SendMessage(player, "Time set between announce messages");
|
||||||
|
break;
|
||||||
|
case "list":
|
||||||
|
SendMessage(player, "§bList of announce messages:§r");
|
||||||
|
SendMessage(player, "§bFormat: [index] message§r");
|
||||||
|
int i = 0;
|
||||||
|
for (String message : PluginMain.AnnounceMessages)
|
||||||
|
SendMessage(player, "[" + i++ + "] " + message);
|
||||||
|
SendMessage(player,
|
||||||
|
"§bCurrent wait time between announcements: "
|
||||||
|
+ PluginMain.AnnounceTime / 60 / 1000
|
||||||
|
+ " minute(s)§r");
|
||||||
|
break;
|
||||||
|
case "edit":
|
||||||
|
if (commandblock == null) {
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§cError: This command can only be used from a command block. Use /u announce remove.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (args.length < 4) {
|
||||||
|
commandblock
|
||||||
|
.sendMessage("§cUsage: /u announce edit <index> <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb1 = new StringBuilder();
|
||||||
|
for (int i1 = 3; i1 < args.length; i1++) {
|
||||||
|
sb1.append(args[i1]);
|
||||||
|
if (i1 != args.length - 1)
|
||||||
|
sb1.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage1 = sb1.toString().replace('&', '§');
|
||||||
|
int index = Integer.parseInt(args[2]);
|
||||||
|
if (index > 100)
|
||||||
|
break;
|
||||||
|
while (PluginMain.AnnounceMessages.size() <= index)
|
||||||
|
PluginMain.AnnounceMessages.add("");
|
||||||
|
PluginMain.AnnounceMessages.set(Integer.parseInt(args[2]),
|
||||||
|
finalmessage1);
|
||||||
|
commandblock.sendMessage("Announcement edited.");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
private static void DoSaveLoadPos(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "savepos|loadpos"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = null;
|
||||||
|
try {
|
||||||
|
p = Bukkit.getPlayer(args[2]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
if (!MaybeOfflinePlayer.AllPlayers.containsKey(p.getUniqueId())) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer is not online: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (args[1].equalsIgnoreCase("savepos")) {
|
||||||
|
mp.SavedLocation = p.getLocation();
|
||||||
|
} else if (args[1].equalsIgnoreCase("loadpos")) {
|
||||||
|
if (mp.SavedLocation != null)
|
||||||
|
p.teleport(mp.SavedLocation);
|
||||||
|
} else {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// SendMessage(player, "Player " + p.getName() +
|
||||||
|
// " position saved/loaded.");s
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdateDynmap(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "updatedynmap"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin updatedynmap <password>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Random random = new Random();
|
||||||
|
|
||||||
|
public static String KittyCannonMinigame = "KittyCannon";
|
||||||
|
|
||||||
|
private static void DoKittyCannon(Player player, String[] args) {
|
||||||
|
if (player == null) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cThis command can only be used by a player.§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(player);
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame))) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou can only use KittyCannon in it's minigame!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
final Mob cat = Mob.OCELOT;
|
||||||
|
final Ocelot ocelot = (Ocelot) cat.spawn(player.getWorld(),
|
||||||
|
player.getServer(), player.getEyeLocation());
|
||||||
|
if (ocelot == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final ArrayList<String> lore = new ArrayList<>();
|
||||||
|
lore.add(player.getName());
|
||||||
|
final int i = random.nextInt(Ocelot.Type.values().length);
|
||||||
|
ocelot.setCatType(Ocelot.Type.values()[i]);
|
||||||
|
ocelot.setTamed(true);
|
||||||
|
ocelot.setBaby();
|
||||||
|
ocelot.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.DAMAGE_RESISTANCE, 5, 5));
|
||||||
|
ocelot.setVelocity(player.getEyeLocation().getDirection()
|
||||||
|
.multiply(2));
|
||||||
|
Bukkit.getScheduler().scheduleSyncDelayedTask(PluginMain.Instance,
|
||||||
|
new Runnable() {
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
final Location loc = ocelot.getLocation();
|
||||||
|
ocelot.remove();
|
||||||
|
loc.getWorld().createExplosion(loc, 0F);
|
||||||
|
final ItemStack head = new ItemStack(
|
||||||
|
Material.SKULL_ITEM, 1, (short) 3, (byte) 3);
|
||||||
|
SkullMeta im = (SkullMeta) head.getItemMeta();
|
||||||
|
im.setDisplayName("§rOcelot Head");
|
||||||
|
im.setOwner("MHF_Ocelot");
|
||||||
|
im.setLore(lore);
|
||||||
|
head.setItemMeta(im);
|
||||||
|
loc.getWorld().dropItem(loc, head);
|
||||||
|
}
|
||||||
|
}, 20);
|
||||||
|
} catch (MobException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,72 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
||||||
|
import org.bukkit.event.player.PlayerJoinEvent;
|
||||||
|
import org.bukkit.event.player.PlayerQuitEvent;
|
||||||
|
|
||||||
|
import de.inventivegames.TellRawAutoMessage.Reflection;
|
||||||
|
|
||||||
|
public class PlayerListener implements Listener
|
||||||
|
{ //2015.07.16.
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerJoin(PlayerJoinEvent event)
|
||||||
|
{
|
||||||
|
Player p=event.getPlayer();
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName()); //2015.08.08.
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p.getName()); //2015.08.08.
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
else
|
||||||
|
{ //2015.07.20.
|
||||||
|
String json="[\"\",{\"text\":\"§6Hi! If you'd like your flair displayed ingame, write your §6Minecraft name to \"},{\"text\":\"[this thread.]\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread§r\"}]}}}]";
|
||||||
|
sendRawMessage(p, json);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerLeave(PlayerQuitEvent event)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onPlayerChat(AsyncPlayerChatEvent event)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player = MaybeOfflinePlayer.AllPlayers.get(event.getPlayer().getName());
|
||||||
|
String flair=player.Flair; //2015.08.08.
|
||||||
|
if(player.IgnoredFlair)
|
||||||
|
flair="";
|
||||||
|
String message=event.getMessage(); //2015.08.08.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{ //2015.08.12.
|
||||||
|
message = message.replaceAll(p.getName(), "§6"+p.getName()+"§r");
|
||||||
|
p.playSound(arg0, arg1, arg2, arg3)
|
||||||
|
}
|
||||||
|
event.setFormat(event.getFormat().substring(0, event.getFormat().indexOf(">"))+flair+"> "+message); //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Class<?> nmsChatSerializer = Reflection.getNMSClass("IChatBaseComponent$ChatSerializer");
|
||||||
|
private static Class<?> nmsPacketPlayOutChat = Reflection.getNMSClass("PacketPlayOutChat");
|
||||||
|
public static void sendRawMessage(Player player, String message)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
System.out.println("1");
|
||||||
|
Object handle = Reflection.getHandle(player);
|
||||||
|
System.out.println("2");
|
||||||
|
Object connection = Reflection.getField(handle.getClass(), "playerConnection").get(handle);
|
||||||
|
System.out.println("3");
|
||||||
|
Object serialized = Reflection.getMethod(nmsChatSerializer, "a", String.class).invoke(null, message);
|
||||||
|
System.out.println("4");
|
||||||
|
Object packet = nmsPacketPlayOutChat.getConstructor(Reflection.getNMSClass("IChatBaseComponent")).newInstance(serialized);
|
||||||
|
System.out.println("5");
|
||||||
|
Reflection.getMethod(connection.getClass(), "sendPacket").invoke(connection, packet);
|
||||||
|
System.out.println("6");
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,296 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label, String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if(args.length<1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AllPlayers.get(player.getName()); //2015.08.08.
|
||||||
|
//if(!PluginMain.PlayerFlairs.containsKey(player.getName()))
|
||||||
|
if(!p.CommentedOnReddit && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if(!p.FlairRecognised && !args[0].toLowerCase().equals("admin"))
|
||||||
|
{ //2015.08.10.
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
switch(args[0].toLowerCase()) //toLowerCase: 2015.08.09.
|
||||||
|
{
|
||||||
|
case "accept":
|
||||||
|
{
|
||||||
|
if(p.IgnoredFlair)
|
||||||
|
p.IgnoredFlair=false; //2015.08.08.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.AppendPlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
p.AcceptedFlair=true; //2015.08.08.
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(p, player);
|
||||||
|
player.sendMessage("§9Your flair has been set:§r "+flair);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore":
|
||||||
|
{
|
||||||
|
if(p.AcceptedFlair)
|
||||||
|
p.AcceptedFlair=false; //2015.08.08.
|
||||||
|
if(!p.IgnoredFlair)
|
||||||
|
{
|
||||||
|
p.IgnoredFlair=true;
|
||||||
|
//String flair=p.Flair; //2015.08.08.
|
||||||
|
//PluginMain.RemovePlayerDisplayFlairFinal(player, flair); //2015.07.20.
|
||||||
|
player.sendMessage("§9You have ignored this request. You can still use /u accept though.§r");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou already ignored this request.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/*case "reload": //2015.07.20.
|
||||||
|
DoReload(player);
|
||||||
|
break;*/
|
||||||
|
case "admin": //2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "nonpresser": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§7(--s)§r");
|
||||||
|
break;
|
||||||
|
case "cantpress": //2015.08.09.
|
||||||
|
if(!p.AcceptedFlair)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou need to accept the flair first.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(p.FlairDecided)
|
||||||
|
{
|
||||||
|
player.sendMessage("§cYou have already set the flair type or your flair type is known.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, p, "§r(??s)§r");
|
||||||
|
break;
|
||||||
|
case "opme": //2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, isn't it?"); //Sometimes I'm bored too
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/*if(args[0].toLowerCase()=="reload")
|
||||||
|
DoReload(null); //2015.07.20.*/
|
||||||
|
else if(args.length>0 && args[0].toLowerCase().equals("admin")) //2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); //2015.08.09.
|
||||||
|
return true; //2015.08.09.
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
private static void DoReload(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
//if(player==null || player.isOp() || player.getName()=="NorbiPeti")
|
||||||
|
//{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading Auto-flair plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); //2015.08.09.
|
||||||
|
for(Player p : PluginMain.GetPlayers())
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p.getName());
|
||||||
|
//if(mp.Flair!=null)
|
||||||
|
if(mp.CommentedOnReddit)
|
||||||
|
{
|
||||||
|
PluginMain.AppendPlayerDisplayFlair(mp, p); //2015.08.09.
|
||||||
|
}
|
||||||
|
String msg="§9Note: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; //2015.08.09.
|
||||||
|
p.sendMessage(msg); //2015.08.09.
|
||||||
|
}
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading done!§r");
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
if(player!=null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
//}
|
||||||
|
//else
|
||||||
|
//player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static Player ReloadPlayer; //2015.08.09.
|
||||||
|
private static void DoAdmin(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null || player.isOp() || player.getName().equals("NorbiPeti"))
|
||||||
|
{
|
||||||
|
//System.out.println("Args length: " + args.length);
|
||||||
|
if(args.length==1)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//args[0] is "admin"
|
||||||
|
switch(args[1].toLowerCase())
|
||||||
|
{
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer=player; //2015.08.09.
|
||||||
|
SendMessage(player, "§9Make sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; //<-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if(ReloadPlayer==player)
|
||||||
|
DoReload(player); //2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player, "§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); //2015.08.09.
|
||||||
|
SendMessage(player, "§9Saved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": //2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message="§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if(args.length==2)
|
||||||
|
{
|
||||||
|
String message="§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!MaybeOfflinePlayer.AllPlayers.containsKey(args[2]))
|
||||||
|
{
|
||||||
|
String message="§cPlayer not found: "+args[2]+"§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(args[2]);
|
||||||
|
SendMessage(player, "Player name: "+p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: "+p.Flair);
|
||||||
|
SendMessage(player, "Username: "+p.UserName);
|
||||||
|
SendMessage(player, "Flair accepted: "+p.AcceptedFlair);
|
||||||
|
SendMessage(player, "Flair ignored: "+p.IgnoredFlair);
|
||||||
|
SendMessage(player, "Flair decided: "+p.FlairDecided);
|
||||||
|
SendMessage(player, "Flair recognised: "+p.FlairRecognised);
|
||||||
|
SendMessage(player, "Commented on Reddit: "+p.CommentedOnReddit);
|
||||||
|
}
|
||||||
|
private static void SendMessage(Player player, String message)
|
||||||
|
{ //2015.08.09.
|
||||||
|
if(player==null)
|
||||||
|
//System.out.println(message);
|
||||||
|
PluginMain.Console.sendMessage(message); //2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
private static void DoGetLastError(Player player, String[] args)
|
||||||
|
{ //2015.08.09.
|
||||||
|
//args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if(PluginMain.LastException!=null)
|
||||||
|
{
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException=null;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
private static void SetPlayerFlair(Player player, MaybeOfflinePlayer targetplayer, String flair)
|
||||||
|
{ //2015.08.09.
|
||||||
|
flair=flair.replace('&', '§');
|
||||||
|
targetplayer.Flair=flair;
|
||||||
|
targetplayer.CommentedOnReddit=true; //Or at least has a flair in some way
|
||||||
|
if(!PluginMain.RemoveLineFromFile("customflairs.txt", targetplayer.PlayerName))
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cError removing previous custom flair!§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
File file=new File("customflairs.txt");
|
||||||
|
try {
|
||||||
|
BufferedWriter bw;
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
bw.write(targetplayer.PlayerName+targetplayer.Flair+"\n");
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
SendMessage(player, "§9The flair has been set. Player: "+targetplayer.PlayerName+" Flair: "+flair+"§r");
|
||||||
|
}
|
||||||
|
private static void DoSetFlair(Player player, String[] args)
|
||||||
|
{
|
||||||
|
//args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if(args.length<4)
|
||||||
|
{
|
||||||
|
SendMessage(player, "§cUsage: /u admin setflair <playername> <flair>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player, MaybeOfflinePlayer.AddPlayerIfNeeded(args[2]), args[3]);
|
||||||
|
}
|
||||||
|
private static void DoUpdatePlugin(Player player)
|
||||||
|
{ //2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL("https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File("plugins/TheButtonAutoFlair.jar"));
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
}
|
||||||
|
catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
PluginMain.LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,24 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
public class MaybeOfflinePlayer
|
||||||
|
{ //2015.08.08.
|
||||||
|
public String PlayerName;
|
||||||
|
public String UserName;
|
||||||
|
public String Flair; //If the user comments their name, it gets set, it doesn't matter if they accepted it or not
|
||||||
|
public boolean AcceptedFlair;
|
||||||
|
public boolean IgnoredFlair;
|
||||||
|
public static HashMap<String, MaybeOfflinePlayer> AllPlayers=new HashMap<>(); //2015.08.08.
|
||||||
|
public static MaybeOfflinePlayer AddPlayerIfNeeded(String playername)
|
||||||
|
{
|
||||||
|
if(!AllPlayers.containsKey(playername))
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer player=new MaybeOfflinePlayer();
|
||||||
|
player.PlayerName=playername;
|
||||||
|
AllPlayers.put(playername, player);
|
||||||
|
return player;
|
||||||
|
}
|
||||||
|
return AllPlayers.get(playername);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,374 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import com.palmergames.bukkit.towny.object.Town;
|
||||||
|
import com.palmergames.bukkit.towny.object.WorldCoord;
|
||||||
|
|
||||||
|
public class PluginMain extends JavaPlugin
|
||||||
|
{ //Translated to Java: 2015.07.15.
|
||||||
|
//A user, which flair isn't obtainable:
|
||||||
|
//https://www.reddit.com/r/thebutton/comments/31c32v/i_pressed_the_button_without_really_thinking/
|
||||||
|
private static PluginMain Instance;
|
||||||
|
// Fired when plugin is first enabled
|
||||||
|
@Override
|
||||||
|
public void onEnable()
|
||||||
|
{
|
||||||
|
System.out.println("The Button Auto-flair Plugin by NorbiPeti (:P)");
|
||||||
|
getServer().getPluginManager().registerEvents(new PlayerListener(), this);
|
||||||
|
this.getCommand("u").setExecutor(new Commands());
|
||||||
|
this.getCommand("u").setUsage(this.getCommand("u").getUsage().replace('&', '§'));
|
||||||
|
Instance=this; //2015.08.08.
|
||||||
|
LoadFiles(false); //2015.08.09.
|
||||||
|
Runnable r=new Runnable(){public void run(){ThreadMethod();}};
|
||||||
|
Thread t=new Thread(r);
|
||||||
|
t.start();
|
||||||
|
}
|
||||||
|
Boolean stop=false;
|
||||||
|
// Fired when plugin is disabled
|
||||||
|
@Override
|
||||||
|
public void onDisable()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
FileWriter fw;
|
||||||
|
fw = new FileWriter("flairsaccepted.txt");
|
||||||
|
fw.close();
|
||||||
|
fw = new FileWriter("flairsignored.txt");
|
||||||
|
fw.close();
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
BufferedWriter bw=new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.AcceptedFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
bw = new BufferedWriter(new FileWriter(file, true));
|
||||||
|
for(MaybeOfflinePlayer player : MaybeOfflinePlayer.AllPlayers.values()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(!player.IgnoredFlair)
|
||||||
|
continue; //2015.08.08.
|
||||||
|
bw.write(player.PlayerName+"\n");
|
||||||
|
}
|
||||||
|
bw.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
stop=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ThreadMethod() //<-- 2015.07.16.
|
||||||
|
{
|
||||||
|
while(!stop)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
String body=DownloadString("https://www.reddit.com/r/TheButtonMinecraft/comments/3d25do/autoflair_system_comment_your_minecraft_name_and/.json?limit=1000");
|
||||||
|
JSONArray json=new JSONArray(body).getJSONObject(1).getJSONObject("data").getJSONArray("children");
|
||||||
|
for(Object obj : json)
|
||||||
|
{
|
||||||
|
JSONObject item = (JSONObject)obj;
|
||||||
|
String author=item.getJSONObject("data").getString("author");
|
||||||
|
String ign=item.getJSONObject("data").getString("body");
|
||||||
|
int start = ign.indexOf("IGN:") + "IGN:".length();
|
||||||
|
int end = ign.indexOf(' ', start);
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
end=ign.indexOf('\n', start); //2015.07.15.
|
||||||
|
if (end == -1 || end == start)
|
||||||
|
ign = ign.substring(start);
|
||||||
|
else
|
||||||
|
ign = ign.substring(start, end);
|
||||||
|
ign = ign.trim();
|
||||||
|
if(HasIGFlair(ign))
|
||||||
|
continue;
|
||||||
|
try {
|
||||||
|
Thread.sleep(10);
|
||||||
|
} catch(InterruptedException ex) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
String[] flairdata = DownloadString("http://karmadecay.com/thebutton-data.php?users=" + author).replace("\"", "").split(":");
|
||||||
|
String flair;
|
||||||
|
if(flairdata.length > 1) //2015.07.15.
|
||||||
|
flair = flairdata[1];
|
||||||
|
else
|
||||||
|
flair="";
|
||||||
|
if (flair != "-1")
|
||||||
|
flair = flair + "s";
|
||||||
|
else
|
||||||
|
flair = "non-presser";
|
||||||
|
String flairclass;
|
||||||
|
if(flairdata.length>2)
|
||||||
|
flairclass = flairdata[2];
|
||||||
|
else
|
||||||
|
flairclass="unknown";
|
||||||
|
SetFlair(ign, flair, flairclass, author);
|
||||||
|
}
|
||||||
|
Thread.sleep(10000);
|
||||||
|
}
|
||||||
|
catch(Exception e)
|
||||||
|
{
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Exception LastException; //2015.08.09.
|
||||||
|
|
||||||
|
public String DownloadString(String urlstr) throws MalformedURLException, IOException
|
||||||
|
{
|
||||||
|
URL url = new URL(urlstr);
|
||||||
|
URLConnection con = url.openConnection();
|
||||||
|
con.setRequestProperty("User-Agent", "TheButtonAutoFlair");
|
||||||
|
InputStream in = con.getInputStream();
|
||||||
|
String encoding = con.getContentEncoding();
|
||||||
|
encoding = encoding == null ? "UTF-8" : encoding;
|
||||||
|
String body = IOUtils.toString(in, encoding);
|
||||||
|
in.close();
|
||||||
|
return body;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Map<String, String> TownColors=new HashMap<String, String>(); //2015.07.20.
|
||||||
|
public Boolean HasIGFlair(String playername)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
return p.Flair!=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetFlair(String playername, String text, String flairclass, String username)
|
||||||
|
{
|
||||||
|
MaybeOfflinePlayer p=MaybeOfflinePlayer.AddPlayerIfNeeded(playername); //2015.08.08.
|
||||||
|
String finalflair;
|
||||||
|
p.FlairDecided=true;
|
||||||
|
switch(flairclass)
|
||||||
|
{
|
||||||
|
case "press-1":
|
||||||
|
finalflair="§c("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-2":
|
||||||
|
finalflair="§6("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-3":
|
||||||
|
finalflair="§e("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-4":
|
||||||
|
finalflair="§a("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-5":
|
||||||
|
finalflair="§9("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "press-6":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "no-press":
|
||||||
|
finalflair="§7(non-pr.)§r";
|
||||||
|
break;
|
||||||
|
case "cheater":
|
||||||
|
finalflair="§5("+text+")§r";
|
||||||
|
break;
|
||||||
|
case "cant-press": //2015.08.08.
|
||||||
|
finalflair="§r(can't press)§r";
|
||||||
|
break;
|
||||||
|
case "undecided": //2015.08.09.
|
||||||
|
p.FlairDecided=false;
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
finalflair="";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(finalflair.length()==0) //<-- 2015.07.20.
|
||||||
|
return;
|
||||||
|
p.Flair=finalflair; //2015.08.08.
|
||||||
|
p.UserName=username; //2015.08.08.
|
||||||
|
System.out.println("Added new flair to "+playername+": "+finalflair);
|
||||||
|
for(Player player : getServer().getOnlinePlayers()) //<-- 2015.08.08.
|
||||||
|
{
|
||||||
|
if(player.getName().equals(playername))
|
||||||
|
{
|
||||||
|
//AppendPlayerDisplayFlair(player, username, finalflair);
|
||||||
|
AppendPlayerDisplayFlair(p, player);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetFlair(Player player)
|
||||||
|
{ //2015.07.16.
|
||||||
|
String flair=MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair; //2015.08.08.
|
||||||
|
return flair==null ? "" : flair;
|
||||||
|
}
|
||||||
|
|
||||||
|
//public static void AppendPlayerDisplayFlair(Player player, String username, String flair)
|
||||||
|
public static void AppendPlayerDisplayFlair(MaybeOfflinePlayer player, Player p) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).IgnoredFlair)
|
||||||
|
return;
|
||||||
|
if(MaybeOfflinePlayer.AllPlayers.get(p.getName()).AcceptedFlair)
|
||||||
|
{
|
||||||
|
AppendPlayerDisplayFlairFinal(p, player.Flair); //2015.07.20.
|
||||||
|
if(!player.FlairDecided)
|
||||||
|
p.sendMessage("§9Your flair type is unknown. Are you a non-presser or a can't press? (/u nonpresser or /u cantpress)§r"); //2015.08.09.
|
||||||
|
}
|
||||||
|
else
|
||||||
|
p.sendMessage("§9Are you Reddit user "+player.UserName+"?§r §6Type /u accept or /u ignore§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void AppendPlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
String color = GetColorForTown(GetPlayerTown(player)); //TO!DO: Multiple colors put on first capital letters
|
||||||
|
String[] colors = color.substring(1).split("§");
|
||||||
|
String displayname=player.getName(); //2015.08.08.
|
||||||
|
ArrayList<Integer> Positions=new ArrayList<>();
|
||||||
|
for(int i=0; i<displayname.length(); i++) {
|
||||||
|
if(Character.isUpperCase(displayname.charAt(i))) {
|
||||||
|
Positions.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String finalname=""; //TODO
|
||||||
|
if(Positions.size()>=colors.length)
|
||||||
|
{
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<Positions.size(); i++)
|
||||||
|
{
|
||||||
|
int pos=Positions.get(i);
|
||||||
|
int nextpos;
|
||||||
|
if(i!=Positions.size()-1)
|
||||||
|
nextpos=Positions.get(i+1);
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Positions.clear();
|
||||||
|
int unit=displayname.length()/colors.length;
|
||||||
|
int x=0;
|
||||||
|
for(int i=0; i<displayname.length()-unit; i+=unit)
|
||||||
|
{
|
||||||
|
int pos=i;
|
||||||
|
int nextpos;
|
||||||
|
if(i<displayname.length()-unit-unit)
|
||||||
|
nextpos=i+unit;
|
||||||
|
else
|
||||||
|
nextpos=displayname.length();
|
||||||
|
String substr="§"+colors[x++]+displayname.substring(pos, nextpos)+"§r";
|
||||||
|
finalname+=substr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=flair; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetColorForTown(String townname)
|
||||||
|
{ //2015.07.20.
|
||||||
|
if(TownColors.containsKey(townname))
|
||||||
|
return TownColors.get(townname);
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String GetPlayerTown(Player player)
|
||||||
|
{ //2015.07.20.
|
||||||
|
try {
|
||||||
|
Town town = WorldCoord.parseWorldCoord(player).getTownBlock().getTown(); //TODO
|
||||||
|
return town.getName();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void RemovePlayerDisplayFlairFinal(Player player, String flair)
|
||||||
|
{ //2015.07.20.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.get(player.getName()).Flair=null; //2015.08.08.
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<? extends Player> GetPlayers()
|
||||||
|
{
|
||||||
|
return Instance.getServer().getOnlinePlayers();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void LoadFiles(boolean reload) //<-- 2015.08.09.
|
||||||
|
{
|
||||||
|
if(reload)
|
||||||
|
{
|
||||||
|
System.out.println("Reloading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
MaybeOfflinePlayer.AllPlayers.clear(); //2015.08.09.
|
||||||
|
}
|
||||||
|
System.out.println("Loading files for auto-flair plugin..."); //2015.08.09.
|
||||||
|
try {
|
||||||
|
File file=new File("flairsaccepted.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsaccepted.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
//System.out.println("Name: " + name);
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).AcceptedFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("flairsignored.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader("flairsignored.txt"));
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null)
|
||||||
|
{
|
||||||
|
String name=line.replace("\n", "");
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(name).IgnoredFlair=true; //2015.08.08.
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
file=new File("autoflairconfig.txt");
|
||||||
|
if(file.exists())
|
||||||
|
{
|
||||||
|
BufferedReader br=new BufferedReader(new FileReader(file));
|
||||||
|
String line;
|
||||||
|
while((line=br.readLine())!=null)
|
||||||
|
{
|
||||||
|
String[] s=line.split(" ");
|
||||||
|
TownColors.put(s[0], s[1]);
|
||||||
|
}
|
||||||
|
br.close();
|
||||||
|
}
|
||||||
|
//throw new IOException("Test"); //2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n"+e);
|
||||||
|
LastException=e; //2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,596 @@
|
||||||
|
package tk.sznp.thebuttonautoflair;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.command.BlockCommandSender;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.entity.Ocelot;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.SkullMeta;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.potion.PotionEffectType;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.Mob;
|
||||||
|
import com.earth2me.essentials.Mob.MobException;
|
||||||
|
|
||||||
|
import au.com.mineauz.minigames.MinigamePlayer;
|
||||||
|
import au.com.mineauz.minigames.Minigames;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Timer;
|
||||||
|
|
||||||
|
public class Commands implements CommandExecutor {
|
||||||
|
|
||||||
|
public static MaybeOfflinePlayer Lastlol = null;
|
||||||
|
|
||||||
|
// This method is called, when somebody uses our command
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(CommandSender sender, Command cmd, String label,
|
||||||
|
String[] args) {
|
||||||
|
if (sender instanceof Player) {
|
||||||
|
Player player = (Player) sender;
|
||||||
|
switch (cmd.getName()) {
|
||||||
|
case "u": {
|
||||||
|
if (args.length < 1)
|
||||||
|
return false;
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(player
|
||||||
|
.getUniqueId());
|
||||||
|
switch (args[0].toLowerCase()) {
|
||||||
|
case "accept": {
|
||||||
|
if (args.length < 2 && p.UserNames.size() > 1) {
|
||||||
|
player.sendMessage("§9Multiple users commented your name. §bPlease pick one using /u accept <username>");
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
player.sendMessage(sb.toString());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)
|
||||||
|
|| p.UserNames.size() == 0) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1 && !p.UserNames.contains(args[1])) {
|
||||||
|
player.sendMessage("§cError: Unknown name: " + args[1]
|
||||||
|
+ "§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.Working) {
|
||||||
|
player.sendMessage("§cError: Something is already in progress.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((args.length > 1 ? args[1] : p.UserNames.get(0))
|
||||||
|
.equals(p.UserName)) {
|
||||||
|
player.sendMessage("§cYou already have this user's flair.§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (args.length > 1)
|
||||||
|
p.UserName = args[1];
|
||||||
|
else
|
||||||
|
p.UserName = p.UserNames.get(0);
|
||||||
|
|
||||||
|
player.sendMessage("§bObtaining flair...");
|
||||||
|
p.Working = true;
|
||||||
|
Timer timer = new Timer();
|
||||||
|
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
PluginMain.Instance.DownloadFlair(mp);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
Player player = Bukkit.getPlayer(mp.UUID);
|
||||||
|
if (mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask an admin to set it for you. Also, prepare a comment on /r/thebutton, if possible.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String flair = mp.GetFormattedFlair();
|
||||||
|
mp.FlairState = FlairStates.Accepted;
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
player.sendMessage("§bYour flair has been set:§r "
|
||||||
|
+ flair);
|
||||||
|
mp.Working = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
tt.mp = p;
|
||||||
|
timer.schedule(tt, 20);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "ignore": {
|
||||||
|
if (p.FlairState.equals(FlairStates.NoComment)) {
|
||||||
|
player.sendMessage("§cError: You need to write your username to the reddit thread at /r/TheButtonMinecraft§r");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (p.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
player.sendMessage("Sorry, but your flair isn't recorded. Please ask a mod to set it for you.");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!p.FlairState.equals(FlairStates.Ignored)) {
|
||||||
|
p.FlairState = FlairStates.Ignored;
|
||||||
|
p.FlairTime = "";
|
||||||
|
p.UserName = "";
|
||||||
|
player.sendMessage("§bYou have removed your flair. You can still use /u accept to get one.§r");
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou already removed your flair.§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "admin": // 2015.08.09.
|
||||||
|
DoAdmin(player, args);
|
||||||
|
break;
|
||||||
|
case "opme": // 2015.08.10.
|
||||||
|
player.sendMessage("It would be nice, wouldn't it?"); // Sometimes
|
||||||
|
// I'm
|
||||||
|
// bored
|
||||||
|
// too
|
||||||
|
break;
|
||||||
|
case "announce":
|
||||||
|
DoAnnounce(player, args, null);
|
||||||
|
break;
|
||||||
|
case "name":
|
||||||
|
if (args.length == 1) {
|
||||||
|
player.sendMessage("§cUsage: /u name <playername>§r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer
|
||||||
|
.GetFromName(args[1]);
|
||||||
|
if (mp == null) {
|
||||||
|
player.sendMessage("§cUnknown user: " + args[1]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
player.sendMessage("§bUsername of " + args[1] + ": "
|
||||||
|
+ mp.UserName);
|
||||||
|
break;
|
||||||
|
case "enable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = true;
|
||||||
|
player.sendMessage("Enabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "disable":
|
||||||
|
if (player.getName().equals("NorbiPeti")) {
|
||||||
|
PlayerListener.Enable = false;
|
||||||
|
player.sendMessage("Disabled.");
|
||||||
|
} else
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
case "kittycannon":
|
||||||
|
DoKittyCannon(player, args);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case "nrp":
|
||||||
|
case "ooc":
|
||||||
|
if (args.length == 0) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = false;
|
||||||
|
String message = "";
|
||||||
|
for (String arg : args)
|
||||||
|
message += arg + " ";
|
||||||
|
player.chat(message.substring(0, message.length() - 1));
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(player.getUniqueId()).RPMode = true;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
case "unlol": // TODO: Unlol
|
||||||
|
if(Lastlol!=null)
|
||||||
|
Lastlol.UUID
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
player.sendMessage("Unknown command: " + cmd.getName());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("admin")) // 2015.08.09.
|
||||||
|
{
|
||||||
|
DoAdmin(null, args); // 2015.08.09.
|
||||||
|
return true; // 2015.08.09.
|
||||||
|
} else if (args.length > 0 && args[0].toLowerCase().equals("announce")) {
|
||||||
|
if (sender instanceof BlockCommandSender)
|
||||||
|
DoAnnounce(null, args, (BlockCommandSender) sender);
|
||||||
|
else
|
||||||
|
DoAnnounce(null, args, null);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoReload(Player player) { // 2015.07.20.
|
||||||
|
try {
|
||||||
|
PluginMain.Console
|
||||||
|
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
|
||||||
|
PluginMain.LoadFiles(true); // 2015.08.09.
|
||||||
|
for (Player p : PluginMain.GetPlayers()) {
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (mp.FlairState.equals(FlairStates.Recognised)
|
||||||
|
|| mp.FlairState.equals(FlairStates.Commented)) {
|
||||||
|
PluginMain.ConfirmUserMessage(mp);
|
||||||
|
}
|
||||||
|
String msg = "§bNote: The auto-flair plugin has been reloaded. You might need to wait 10s to have your flair.§r"; // 2015.08.09.
|
||||||
|
p.sendMessage(msg); // 2015.08.09.
|
||||||
|
}
|
||||||
|
PluginMain.Console.sendMessage("§6-- Reloading done!§r");
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
if (player != null)
|
||||||
|
player.sendMessage("§cAn error occured. See console for details.§r");
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Player ReloadPlayer; // 2015.08.09.
|
||||||
|
|
||||||
|
private static String DoAdminUsage = "§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin|togglerpshow|toggledebug|savepos|loadpos§r";
|
||||||
|
|
||||||
|
private static void DoAdmin(Player player, String[] args) { // 2015.08.09.
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// args[0] is "admin"
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "reload":
|
||||||
|
ReloadPlayer = player; // 2015.08.09.
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§bMake sure to save the current settings before you modify and reload them! Type /u admin confirm when done.§r");
|
||||||
|
break;
|
||||||
|
case "playerinfo":
|
||||||
|
DoPlayerInfo(player, args);
|
||||||
|
break;
|
||||||
|
case "getlasterror":
|
||||||
|
DoGetLastError(player, args);
|
||||||
|
break; // <-- 2015.08.10.
|
||||||
|
case "confirm":
|
||||||
|
if (ReloadPlayer == player)
|
||||||
|
DoReload(player); // 2015.08.09.
|
||||||
|
else
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou need to do /u admin reload first.§r");
|
||||||
|
break;
|
||||||
|
case "save":
|
||||||
|
PluginMain.SaveFiles(); // 2015.08.09.
|
||||||
|
SendMessage(player,
|
||||||
|
"§bSaved files. Now you can edit them and reload if you want.§r");
|
||||||
|
break;
|
||||||
|
case "setflair":
|
||||||
|
DoSetFlair(player, args);
|
||||||
|
break;
|
||||||
|
case "updateplugin": // 2015.08.10.
|
||||||
|
DoUpdatePlugin(player);
|
||||||
|
break;
|
||||||
|
case "togglerpshow":
|
||||||
|
PlayerListener.ShowRPTag = !PlayerListener.ShowRPTag;
|
||||||
|
SendMessage(player, "RP tag showing "
|
||||||
|
+ (PlayerListener.ShowRPTag ? "enabled" : "disabled"));
|
||||||
|
break;
|
||||||
|
case "toggledebug":
|
||||||
|
PlayerListener.DebugMode = !PlayerListener.DebugMode;
|
||||||
|
SendMessage(player, "DebugMode: " + PlayerListener.DebugMode);
|
||||||
|
break;
|
||||||
|
case "savepos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "loadpos":
|
||||||
|
DoSaveLoadPos(player, args);
|
||||||
|
break;
|
||||||
|
case "updatedynmap":
|
||||||
|
DoUpdateDynmap(player, args);
|
||||||
|
default:
|
||||||
|
String message = DoAdminUsage;
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
player.sendMessage("§cYou need to be OP to use this command.§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoPlayerInfo(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "playerinfo"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin playerinfo <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer p = MaybeOfflinePlayer.GetFromName(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SendMessage(player, "Player name: " + p.PlayerName);
|
||||||
|
SendMessage(player, "User flair: " + p.GetFormattedFlair());
|
||||||
|
SendMessage(player, "Username: " + p.UserName);
|
||||||
|
SendMessage(player, "Flair state: " + p.FlairState);
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
sb.append("§6Usernames:");
|
||||||
|
for (String username : p.UserNames)
|
||||||
|
sb.append(" ").append(username);
|
||||||
|
SendMessage(player, sb.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SendMessage(Player player, String message) { // 2015.08.09.
|
||||||
|
if (player == null)
|
||||||
|
PluginMain.Console.sendMessage(message); // 2015.08.12.
|
||||||
|
else
|
||||||
|
player.sendMessage(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoGetLastError(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "getlasterror"
|
||||||
|
if (PluginMain.LastException != null) {
|
||||||
|
SendMessage(player, "Last error:");
|
||||||
|
SendMessage(player, PluginMain.LastException.toString());
|
||||||
|
PluginMain.LastException = null;
|
||||||
|
} else
|
||||||
|
SendMessage(player, "There were no exceptions.");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SetPlayerFlair(Player player,
|
||||||
|
MaybeOfflinePlayer targetplayer, short flaircolor, String flairtime) {
|
||||||
|
targetplayer.FlairColor = flaircolor;
|
||||||
|
targetplayer.FlairTime = flairtime;
|
||||||
|
targetplayer.FlairState = FlairStates.Accepted;
|
||||||
|
targetplayer.UserName = "";
|
||||||
|
SendMessage(player,
|
||||||
|
"§bThe flair has been set. Player: " + targetplayer.PlayerName
|
||||||
|
+ " Flair: " + targetplayer.GetFormattedFlair() + "§r");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoSetFlair(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "setflair"
|
||||||
|
if (args.length < 4) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = Bukkit.getPlayer(args[2]);
|
||||||
|
if (p == null) {
|
||||||
|
SendMessage(player, "§cPLayer not found.&r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
short flaircolor = 0x00;
|
||||||
|
try {
|
||||||
|
flaircolor = Short.parseShort(args[3], 16);
|
||||||
|
} catch (Exception e) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cFlaircolor must be a hexadecimal number (don't include &).");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SetPlayerFlair(player,
|
||||||
|
MaybeOfflinePlayer.AddPlayerIfNeeded(p.getUniqueId()),
|
||||||
|
flaircolor, (args.length < 5 ? "" : args[4]));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdatePlugin(Player player) { // 2015.08.10.
|
||||||
|
SendMessage(player, "Updating Auto-Flair plugin...");
|
||||||
|
System.out.println("Forced updating of Auto-Flair plugin.");
|
||||||
|
URL url;
|
||||||
|
try {
|
||||||
|
url = new URL(
|
||||||
|
"https://github.com/NorbiPeti/thebuttonautoflairmc/raw/master/TheButtonAutoFlair.jar");
|
||||||
|
FileUtils.copyURLToFile(url, new File(
|
||||||
|
"plugins/TheButtonAutoFlair.jar"));
|
||||||
|
PluginUpdated = true; // 2015.08.31.
|
||||||
|
SendMessage(player, "Updating done!");
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
} catch (IOException e) {
|
||||||
|
System.out.println("Error!\n" + e);
|
||||||
|
PluginMain.LastException = e; // 2015.08.09.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoAnnounce(Player player, String[] args,
|
||||||
|
BlockCommandSender commandblock) {
|
||||||
|
if (player == null || player.isOp()
|
||||||
|
|| player.getName().equals("NorbiPeti")) {
|
||||||
|
if (args.length == 1) {
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (args[1].toLowerCase()) {
|
||||||
|
case "add":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce add <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
for (int i = 2; i < args.length; i++) {
|
||||||
|
sb.append(args[i]);
|
||||||
|
if (i != args.length - 1)
|
||||||
|
sb.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage = sb.toString().replace('&', '§');
|
||||||
|
PluginMain.AnnounceMessages.add(finalmessage);
|
||||||
|
SendMessage(player, "§bAnnouncement added.§r");
|
||||||
|
break;
|
||||||
|
case "remove":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player, "§cUsage: /u announce remove <index>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceMessages.remove(Integer.parseInt(args[2]));
|
||||||
|
break;
|
||||||
|
case "settime":
|
||||||
|
if (args.length < 3) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cUsage: /u announce settime <minutes>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
PluginMain.AnnounceTime = Integer.parseInt(args[2]) * 60 * 1000;
|
||||||
|
SendMessage(player, "Time set between announce messages");
|
||||||
|
break;
|
||||||
|
case "list":
|
||||||
|
SendMessage(player, "§bList of announce messages:§r");
|
||||||
|
SendMessage(player, "§bFormat: [index] message§r");
|
||||||
|
int i = 0;
|
||||||
|
for (String message : PluginMain.AnnounceMessages)
|
||||||
|
SendMessage(player, "[" + i++ + "] " + message);
|
||||||
|
SendMessage(player,
|
||||||
|
"§bCurrent wait time between announcements: "
|
||||||
|
+ PluginMain.AnnounceTime / 60 / 1000
|
||||||
|
+ " minute(s)§r");
|
||||||
|
break;
|
||||||
|
case "edit":
|
||||||
|
if (commandblock == null) {
|
||||||
|
SendMessage(
|
||||||
|
player,
|
||||||
|
"§cError: This command can only be used from a command block. Use /u announce remove.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (args.length < 4) {
|
||||||
|
commandblock
|
||||||
|
.sendMessage("§cUsage: /u announce edit <index> <message>");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
StringBuilder sb1 = new StringBuilder();
|
||||||
|
for (int i1 = 3; i1 < args.length; i1++) {
|
||||||
|
sb1.append(args[i1]);
|
||||||
|
if (i1 != args.length - 1)
|
||||||
|
sb1.append(" ");
|
||||||
|
}
|
||||||
|
String finalmessage1 = sb1.toString().replace('&', '§');
|
||||||
|
int index = Integer.parseInt(args[2]);
|
||||||
|
if (index > 100)
|
||||||
|
break;
|
||||||
|
while (PluginMain.AnnounceMessages.size() <= index)
|
||||||
|
PluginMain.AnnounceMessages.add("");
|
||||||
|
PluginMain.AnnounceMessages.set(Integer.parseInt(args[2]),
|
||||||
|
finalmessage1);
|
||||||
|
commandblock.sendMessage("Announcement edited.");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
private static void DoSaveLoadPos(Player player, String[] args) { // 2015.08.09.
|
||||||
|
// args[0] is "admin" - args[1] is "savepos|loadpos"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Player p = null;
|
||||||
|
try {
|
||||||
|
p = Bukkit.getPlayer(args[2]);
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
if (!MaybeOfflinePlayer.AllPlayers.containsKey(p.getUniqueId())) {
|
||||||
|
String message = "§cPlayer not found: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AllPlayers.get(p
|
||||||
|
.getUniqueId());
|
||||||
|
if (p == null) {
|
||||||
|
String message = "§cPlayer is not online: " + args[2] + "§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (args[1].equalsIgnoreCase("savepos")) {
|
||||||
|
mp.SavedLocation = p.getLocation();
|
||||||
|
} else if (args[1].equalsIgnoreCase("loadpos")) {
|
||||||
|
if (mp.SavedLocation != null)
|
||||||
|
p.teleport(mp.SavedLocation);
|
||||||
|
} else {
|
||||||
|
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// SendMessage(player, "Player " + p.getName() +
|
||||||
|
// " position saved/loaded.");s
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DoUpdateDynmap(Player player, String[] args) {
|
||||||
|
// args[0] is "admin" - args[1] is "updatedynmap"
|
||||||
|
if (args.length == 2) {
|
||||||
|
String message = "§cUsage: /u admin updatedynmap <password>§r";
|
||||||
|
SendMessage(player, message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Random random = new Random();
|
||||||
|
|
||||||
|
public static String KittyCannonMinigame = "KittyCannon";
|
||||||
|
|
||||||
|
private static void DoKittyCannon(Player player, String[] args) {
|
||||||
|
if (player == null) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cThis command can only be used by a player.§r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MinigamePlayer mp = Minigames.plugin.pdata.getMinigamePlayer(player);
|
||||||
|
if (!(mp.isInMinigame() && mp.getMinigame().getName(false)
|
||||||
|
.equalsIgnoreCase(Commands.KittyCannonMinigame))) {
|
||||||
|
SendMessage(player,
|
||||||
|
"§cYou can only use KittyCannon in it's minigame!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
final Mob cat = Mob.OCELOT;
|
||||||
|
final Ocelot ocelot = (Ocelot) cat.spawn(player.getWorld(),
|
||||||
|
player.getServer(), player.getEyeLocation());
|
||||||
|
if (ocelot == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
final ArrayList<String> lore = new ArrayList<>();
|
||||||
|
lore.add(player.getName());
|
||||||
|
final int i = random.nextInt(Ocelot.Type.values().length);
|
||||||
|
ocelot.setCatType(Ocelot.Type.values()[i]);
|
||||||
|
ocelot.setTamed(true);
|
||||||
|
ocelot.setBaby();
|
||||||
|
ocelot.addPotionEffect(new PotionEffect(
|
||||||
|
PotionEffectType.DAMAGE_RESISTANCE, 5, 5));
|
||||||
|
ocelot.setVelocity(player.getEyeLocation().getDirection()
|
||||||
|
.multiply(2));
|
||||||
|
Bukkit.getScheduler().scheduleSyncDelayedTask(PluginMain.Instance,
|
||||||
|
new Runnable() {
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
final Location loc = ocelot.getLocation();
|
||||||
|
ocelot.remove();
|
||||||
|
loc.getWorld().createExplosion(loc, 0F);
|
||||||
|
final ItemStack head = new ItemStack(
|
||||||
|
Material.SKULL_ITEM, 1, (short) 3, (byte) 3);
|
||||||
|
SkullMeta im = (SkullMeta) head.getItemMeta();
|
||||||
|
im.setDisplayName("§rOcelot Head");
|
||||||
|
im.setOwner("MHF_Ocelot");
|
||||||
|
im.setLore(lore);
|
||||||
|
head.setItemMeta(im);
|
||||||
|
loc.getWorld().dropItem(loc, head);
|
||||||
|
}
|
||||||
|
}, 20);
|
||||||
|
} catch (MobException e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue