Added /tableflip, /unflip, /chatonly and the ability to unlaugh the console

This commit is contained in:
Norbi Peti 2016-04-24 17:29:08 +02:00
parent e8ebd8c41e
commit 53d8567148
7 changed files with 217 additions and 175 deletions

Binary file not shown.

View file

@ -17,10 +17,17 @@ commands:
description: Unlaugh the last laugh.
mwiki:
description: Search the wiki.
usage: "&vUsage: /mwiki [query]&r"
usage: "&cUsage: /mwiki [query]&r"
dontrunthiscmd:
warmode:
description: Toggles war mode
tableflip:
description: Flip a table.
usage: "&cUsage: /tableflip [message]&r"
unflip:
description: Unflip a flip.
usage: "&cUsage: /unflip [message]&r"
chatonly:
description: Enable chat only mode. Useful for chat clients.
usage: "&cUsage: /chatonly&r"
author: NorbiPeti
depend: [Essentials, Towny, Minigames, Votifier, Factions, WorldGuard, WorldEdit, ProtocolLib, FastLogin, Vault, AuthMe]
permissions:

View file

@ -26,6 +26,11 @@ public class ChatProcessing {
PlayerListener.essentials = (Essentials) (Bukkit.getPluginManager()
.getPlugin("Essentials"));
Player player = (sender instanceof Player ? (Player) sender : null);
if (player != null
&& PlayerListener.essentials.getUser(player).isMuted())
return true;
MaybeOfflinePlayer mp = null;
if (player != null) {
mp = MaybeOfflinePlayer.AllPlayers.get(player.getUniqueId());
@ -41,16 +46,28 @@ public class ChatProcessing {
}
String msg = message.toLowerCase();
if (player != null && msg.contains("lol")) {
Commands.Lastlol = MaybeOfflinePlayer.AllPlayers.get(player
.getUniqueId());
if (msg.contains("lol")) {
if (player != null) {
Commands.Lastlol = player;
Commands.Lastlolornot = true;
Commands.Lastlolconsole = false;
} else {
Commands.Lastlolornot = true;
Commands.Lastlolconsole = true;
Commands.Lastlol = null;
}
} else {
for (int i = 0; i < PlayerListener.LaughStrings.length; i++) {
if (msg.contains(PlayerListener.LaughStrings[i])) {
Commands.Lastlol = MaybeOfflinePlayer.AllPlayers.get(player
.getUniqueId());
if (player != null) {
Commands.Lastlol = player;
Commands.Lastlolornot = false;
Commands.Lastlolconsole = false;
} else {
Commands.Lastlolornot = false;
Commands.Lastlolconsole = true;
Commands.Lastlol = null;
}
break;
}
}
@ -59,7 +76,7 @@ public class ChatProcessing {
: mp.CurrentChannel);
String colormode = currentchannel.Color;
if (mp.OtherColorMode.length() > 0)
if (mp != null && mp.OtherColorMode.length() > 0)
colormode = mp.OtherColorMode;
if (message.startsWith(">"))
colormode = "green"; // If greentext, ignore channel or player
@ -99,11 +116,7 @@ public class ChatProcessing {
hadurls = true;
} catch (MalformedURLException e) {
}
if (mp != null && mp.RainbowPresserColorMode) { // TODO:
// Rainbow
// mode
// for
// console
if (mp != null && mp.RainbowPresserColorMode) {
if (item.startsWith(RainbowPresserColors[rpc])) { // Prevent
// words
// being
@ -196,16 +209,16 @@ public class ChatProcessing {
}
}
if (player != null
&& PlayerListener.essentials.getUser(player).isMuted())
return true;
StringBuilder json = new StringBuilder();
json.append("[\"\",");
json.append(String
.format("{\"text\":\"[%s]%s\",\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"Copy message\",\"color\":\"blue\"}},\"clickEvent\":{\"action\":\"suggest_command\",\"value\":\"%s\"}},",
currentchannel.DisplayName,
(mp != null && !mp.RPMode ? "[OOC]" : ""), suggestmsg));
.format("%s{\"text\":\"[%s]%s\",\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"Copy message\",\"color\":\"blue\"}},\"clickEvent\":{\"action\":\"suggest_command\",\"value\":\"%s\"}},",
(mp != null && mp.ChatOnly ? "{\"text\":\"[C]\",\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Chat only\",\"color\":\"blue\"}]}}},"
// (mp != null && mp.ChatOnly ?
// "{\"text:\":\"\"}," - I have been staring at
// this one line for hours... Hours...
: ""), currentchannel.DisplayName, (mp != null
&& !mp.RPMode ? "[OOC]" : ""), suggestmsg));
json.append("{\"text\":\" <\"},");
json.append(String.format("{\"text\":\"%s%s\",",
(player != null ? player.getDisplayName() : sender.getName()),

View file

@ -1,9 +1,8 @@
package tk.sznp.thebuttonautoflair;
import me.steffansk1997.OreRegenerator.OreRegenerator;
import org.apache.commons.io.FileUtils;
import org.bukkit.Bukkit;
import org.bukkit.GameMode;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.command.BlockCommandSender;
@ -19,10 +18,6 @@ import org.bukkit.potion.PotionEffectType;
import com.earth2me.essentials.Mob;
import com.earth2me.essentials.Mob.MobException;
import com.sk89q.worldguard.bukkit.WorldGuardPlugin;
import com.sk89q.worldguard.protection.ApplicableRegionSet;
import com.sk89q.worldguard.protection.flags.StateFlag;
import com.sk89q.worldguard.protection.regions.ProtectedRegion;
import au.com.mineauz.minigames.MinigamePlayer;
import au.com.mineauz.minigames.Minigames;
@ -37,8 +32,9 @@ import java.util.Timer;
public class Commands implements CommandExecutor {
public static MaybeOfflinePlayer Lastlol = null;
public static Player Lastlol = null;
public static boolean Lastlolornot;
public static boolean Lastlolconsole;
// This method is called, when somebody uses our command
@Override
@ -55,9 +51,9 @@ public class Commands implements CommandExecutor {
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>");
player.sendMessage("§9Multiple users commented your name. §bPlease pick one using /u accept <username>");
StringBuilder sb = new StringBuilder();
sb.append("§6Usernames:");
sb.append("§6Usernames:");
for (String username : p.UserNames)
sb.append(" ").append(username);
player.sendMessage(sb.toString());
@ -65,22 +61,22 @@ public class Commands implements CommandExecutor {
}
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");
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");
player.sendMessage("§cError: Unknown name: " + args[1]
+ "§r");
return true;
}
if (p.Working) {
player.sendMessage("§cError: Something is already in progress.§r");
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");
player.sendMessage("§cYou already have this user's flair.§r");
return true;
}
if (args.length > 1)
@ -88,7 +84,7 @@ public class Commands implements CommandExecutor {
else
p.UserName = p.UserNames.get(0);
player.sendMessage("§bObtaining flair...");
player.sendMessage("§bObtaining flair...");
p.Working = true;
Timer timer = new Timer();
PlayerJoinTimerTask tt = new PlayerJoinTimerTask() {
@ -113,7 +109,7 @@ public class Commands implements CommandExecutor {
String flair = mp.GetFormattedFlair();
mp.FlairState = FlairStates.Accepted;
PluginMain.ConfirmUserMessage(mp);
player.sendMessage("§bYour flair has been set:§r "
player.sendMessage("§bYour flair has been set:§r "
+ flair);
mp.Working = false;
}
@ -124,7 +120,7 @@ public class Commands implements CommandExecutor {
}
case "ignore": {
if (p.FlairState.equals(FlairStates.Accepted)) {
player.sendMessage("§cSorry, but ignoring the flair is no longer possible. As with the original Button, you can't undo what already happened.");
player.sendMessage("§cSorry, but ignoring the flair is no longer possible. As with the original Button, you can't undo what already happened.");
return true;
}
if (p.FlairState.equals(FlairStates.Commented)) {
@ -135,9 +131,9 @@ public class Commands implements CommandExecutor {
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");
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");
player.sendMessage("§cYou already removed your flair.§r");
break;
}
case "admin": // 2015.08.09.
@ -154,16 +150,16 @@ public class Commands implements CommandExecutor {
break;
case "name": {
if (args.length == 1) {
player.sendMessage("§cUsage: /u name <playername>§r");
player.sendMessage("§cUsage: /u name <playername>§r");
break;
}
MaybeOfflinePlayer mp = MaybeOfflinePlayer
.GetFromName(args[1]);
if (mp == null) {
player.sendMessage("§cUnknown user: " + args[1]);
player.sendMessage("§cUnknown user: " + args[1]);
break;
}
player.sendMessage("§bUsername of " + args[1] + ": "
player.sendMessage("§bUsername of " + args[1] + ": "
+ mp.UserName);
break;
}
@ -190,11 +186,11 @@ public class Commands implements CommandExecutor {
p.RainbowPresserColorMode = !p.RainbowPresserColorMode;
p.OtherColorMode = "";
if (p.RainbowPresserColorMode)
player.sendMessage("§eRainbow colors §aenabled.");
player.sendMessage("§eRainbow colors §aenabled.");
else
player.sendMessage("§eRainbow colors §cdisabled.");
player.sendMessage("§eRainbow colors §cdisabled.");
} else {
player.sendMessage("§cYou don't have permission for this command. Donate to get it!");
player.sendMessage("§cYou don't have permission for this command. Donate to get it!");
return true;
}
} else {
@ -203,12 +199,12 @@ public class Commands implements CommandExecutor {
p.OtherColorMode = args[1];
if (p.OtherColorMode.length() > 0)
player.sendMessage(String.format(
"§eMessage color set to %s",
"§eMessage color set to %s",
p.OtherColorMode));
else
player.sendMessage("§eMessage color reset.");
player.sendMessage("§eMessage color reset.");
} else {
player.sendMessage("§cYou don't have permission for this command.");
player.sendMessage("§cYou don't have permission for this command.");
return true;
}
}
@ -234,31 +230,44 @@ public class Commands implements CommandExecutor {
}
case "unlaugh":
case "unlol": {
Player p = null;
if (Lastlol != null
&& (p = Bukkit.getPlayer(Lastlol.UUID)) != null) {
p.addPotionEffect(new PotionEffect(
if (Lastlol != null) {
Lastlol.addPotionEffect(new PotionEffect(
PotionEffectType.BLINDNESS, 10 * 20, 5, false,
false));
for (Player pl : PluginMain.GetPlayers())
pl.sendMessage(player.getDisplayName()
+ (Lastlolornot ? " unlolled " : " unlaughed ")
+ p.getDisplayName());
+ Lastlol.getDisplayName());
Bukkit.getServer()
.getConsoleSender()
.sendMessage(
player.getDisplayName()
+ (Lastlolornot ? " unlolled "
: " unlaughed ")
+ p.getDisplayName());
+ Lastlol.getDisplayName());
Lastlol = null;
} else if (Lastlolconsole) {
for (Player pl : PluginMain.GetPlayers())
pl.sendMessage(player.getDisplayName()
+ (Lastlolornot ? " unlolled " : " unlaughed ")
+ Bukkit.getServer().getConsoleSender()
.getName());
Bukkit.getServer()
.getConsoleSender()
.sendMessage(
player.getDisplayName()
+ (Lastlolornot ? " unlolled "
: " unlaughed ")
+ Bukkit.getServer()
.getConsoleSender()
.getName());
}
return true;
}
case "yeehaw": {
for (Player p : PluginMain.GetPlayers()) {
p.playSound(p.getLocation(), "tbmc.yeehaw", 1f, 1f);
p.sendMessage("§b* " + p.getDisplayName() + " YEEHAWs.");
p.sendMessage("§b* " + p.getDisplayName() + " YEEHAWs.");
}
return true;
}
@ -266,25 +275,28 @@ public class Commands implements CommandExecutor {
DoMWiki(player, args);
return true;
}
case "warmode": {
ApplicableRegionSet ars = ((WorldGuardPlugin) Bukkit
.getPluginManager().getPlugin("WorldGuard"))
.getRegionManager(player.getWorld())
.getApplicableRegions(player.getLocation());
for (ProtectedRegion pr : ars) {
if (pr.getFlag(OreRegenerator.FLAG_REGENORES) == StateFlag.State.ALLOW) {
pr.setFlag(OreRegenerator.FLAG_REGENORES,
StateFlag.State.DENY);
sender.sendMessage("§eWarmode §cdisabled §ein "
+ pr.getId());
} else {
pr.setFlag(OreRegenerator.FLAG_REGENORES,
StateFlag.State.ALLOW);
sender.sendMessage("§eWarmode §aenabled §ein "
+ pr.getId());
case "tableflip": {
String msg = "(╯°□°)╯︵ ┻━┻";
if (args.length > 0) {
msg = args[0] + " " + msg;
}
break;
player.chat(msg);
return true;
}
case "unflip": {
String msg = "┬─┬ ( ゜-゜ノ)";
if (args.length > 0) {
msg = args[0] + "" + msg;
}
player.chat(msg);
return true;
}
case "chatonly": {
MaybeOfflinePlayer p = MaybeOfflinePlayer.AllPlayers.get(player
.getUniqueId());
p.ChatOnly = true;
player.setGameMode(GameMode.SPECTATOR);
player.sendMessage("§bChat-only mode enabled. You are now invincible.");
return true;
}
default:
@ -305,17 +317,15 @@ public class Commands implements CommandExecutor {
switch (cmd.getName()) {
case "unlaugh":
case "unlol": {
Player p = null;
if (Lastlol != null
&& (p = Bukkit.getPlayer(Lastlol.UUID)) != null) {
p.addPotionEffect(new PotionEffect(
if (Lastlol != null) {
Lastlol.addPotionEffect(new PotionEffect(
PotionEffectType.BLINDNESS, 10 * 20, 5, false,
false));
for (Player pl : PluginMain.GetPlayers())
pl.sendMessage(Bukkit.getServer().getConsoleSender()
.getName()
+ (Lastlolornot ? " unlolled " : " unlaughed ")
+ p.getDisplayName());
+ Lastlol.getDisplayName());
Bukkit.getServer()
.getConsoleSender()
.sendMessage(
@ -323,7 +333,7 @@ public class Commands implements CommandExecutor {
.getName()
+ (Lastlolornot ? " unlolled "
: " unlaughed ")
+ p.getDisplayName());
+ Lastlol.getDisplayName());
Lastlol = null;
}
return true;
@ -336,7 +346,7 @@ public class Commands implements CommandExecutor {
private static void DoReload(Player player) {
try {
PluginMain.Console
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
.sendMessage("§6-- Reloading The Button Minecraft plugin...§r");
PluginMain.LoadFiles(true); // 2015.08.09.
for (Player p : PluginMain.GetPlayers()) {
MaybeOfflinePlayer mp = MaybeOfflinePlayer.AddPlayerIfNeeded(p
@ -345,21 +355,21 @@ public class Commands implements CommandExecutor {
|| 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.
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");
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");
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 String DoAdminUsage = "§cUsage: /u admin reload|playerinfo|getlasterror|save|setflair|updateplugin|togglerpshow|toggledebug|savepos|loadpos§r";
private static void DoAdmin(Player player, String[] args) {
if (player == null || PluginMain.permission.has(player, "tbmc.admin")) {
@ -374,7 +384,7 @@ public class Commands implements CommandExecutor {
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");
"§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);
@ -387,12 +397,12 @@ public class Commands implements CommandExecutor {
DoReload(player); // 2015.08.09.
else
SendMessage(player,
"§cYou need to do /u admin reload first.§r");
"§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");
"§bSaved files. Now you can edit them and reload if you want.§r");
break;
case "setflair":
DoSetFlair(player, args);
@ -423,19 +433,19 @@ public class Commands implements CommandExecutor {
return;
}
} else
player.sendMessage("§cYou don't have permission to use this command.§r");
player.sendMessage("§cYou don't have permission 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";
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";
String message = "§cPlayer not found: " + args[2] + "§r";
SendMessage(player, message);
return;
}
@ -444,7 +454,7 @@ public class Commands implements CommandExecutor {
SendMessage(player, "Username: " + p.UserName);
SendMessage(player, "Flair state: " + p.FlairState);
StringBuilder sb = new StringBuilder();
sb.append("§6Usernames:");
sb.append("§6Usernames:");
for (String username : p.UserNames)
sb.append(" ").append(username);
SendMessage(player, sb.toString());
@ -474,15 +484,15 @@ public class Commands implements CommandExecutor {
targetplayer.FlairState = FlairStates.Accepted;
targetplayer.UserName = "";
SendMessage(player,
"§bThe flair has been set. Player: "
"§bThe flair has been set. Player: "
+ targetplayer.PlayerName + " Flair: "
+ targetplayer.GetFormattedFlair() + "§r");
+ targetplayer.GetFormattedFlair() + "§r");
} else {
SendMessage(
player,
"§cSorry, but you can't change an existing flair. (Use -- as time to set non-presser or can't press)");
"§cSorry, but you can't change an existing flair. (Use -- as time to set non-presser or can't press)");
SendMessage(Bukkit.getPlayer(targetplayer.UUID),
"§cYour flair cannot be changed.");
"§cYour flair cannot be changed.");
}
}
@ -490,12 +500,12 @@ public class Commands implements CommandExecutor {
// args[0] is "admin" - args[1] is "setflair"
if (args.length < 4) {
SendMessage(player,
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
"§cUsage: /u admin setflair <playername> <flaircolor> [number]");
return;
}
Player p = Bukkit.getPlayer(args[2]);
if (p == null) {
SendMessage(player, "§cPLayer not found.&r");
SendMessage(player, "§cPLayer not found.&r");
return;
}
short flaircolor = 0x00;
@ -503,7 +513,7 @@ public class Commands implements CommandExecutor {
flaircolor = Short.parseShort(args[3], 16);
} catch (Exception e) {
SendMessage(player,
"§cFlaircolor must be a hexadecimal number (don't include &).");
"§cFlaircolor must be a hexadecimal number (don't include &).");
return;
}
SetPlayerFlair(player,
@ -535,14 +545,14 @@ public class Commands implements CommandExecutor {
if (player == null || player.isOp()
|| player.getName().equals("NorbiPeti")) {
if (args.length == 1) {
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
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>");
SendMessage(player, "§cUsage: /u announce add <message>");
return;
}
StringBuilder sb = new StringBuilder();
@ -551,13 +561,13 @@ public class Commands implements CommandExecutor {
if (i != args.length - 1)
sb.append(" ");
}
String finalmessage = sb.toString().replace('&', '§');
String finalmessage = sb.toString().replace('&', '§');
PluginMain.AnnounceMessages.add(finalmessage);
SendMessage(player, "§bAnnouncement added.§r");
SendMessage(player, "§bAnnouncement added.§r");
break;
case "remove":
if (args.length < 3) {
SendMessage(player, "§cUsage: /u announce remove <index>");
SendMessage(player, "§cUsage: /u announce remove <index>");
return;
}
PluginMain.AnnounceMessages.remove(Integer.parseInt(args[2]));
@ -565,33 +575,33 @@ public class Commands implements CommandExecutor {
case "settime":
if (args.length < 3) {
SendMessage(player,
"§cUsage: /u announce settime <minutes>");
"§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");
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: "
"§bCurrent wait time between announcements: "
+ PluginMain.AnnounceTime / 60 / 1000
+ " minute(s)§r");
+ " 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.");
"§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>");
.sendMessage("§cUsage: /u announce edit <index> <message>");
return;
}
StringBuilder sb1 = new StringBuilder();
@ -600,7 +610,7 @@ public class Commands implements CommandExecutor {
if (i1 != args.length - 1)
sb1.append(" ");
}
String finalmessage1 = sb1.toString().replace('&', '§');
String finalmessage1 = sb1.toString().replace('&', '§');
int index = Integer.parseInt(args[2]);
if (index > 100)
break;
@ -611,7 +621,7 @@ public class Commands implements CommandExecutor {
commandblock.sendMessage("Announcement edited.");
break;
default:
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
String message = "§cUsage: /u announce add|remove|settime|list|edit§r";
SendMessage(player, message);
return;
}
@ -622,7 +632,7 @@ public class Commands implements CommandExecutor {
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";
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
SendMessage(player, message);
return;
}
@ -632,14 +642,14 @@ public class Commands implements CommandExecutor {
} catch (Exception e) {
}
if (!MaybeOfflinePlayer.AllPlayers.containsKey(p.getUniqueId())) {
String message = "§cPlayer not found: " + args[2] + "§r";
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";
String message = "§cPlayer is not online: " + args[2] + "§r";
SendMessage(player, message);
return;
}
@ -649,7 +659,7 @@ public class Commands implements CommandExecutor {
if (mp.SavedLocation != null)
p.teleport(mp.SavedLocation);
} else {
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
String message = "§cUsage: /u admin savepos|loadpos <player>§r";
SendMessage(player, message);
return;
}
@ -660,7 +670,7 @@ public class Commands implements CommandExecutor {
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";
String message = "§cUsage: /u admin updatedynmap <password>§r";
SendMessage(player, message);
return;
}
@ -673,14 +683,14 @@ public class Commands implements CommandExecutor {
private static void DoKittyCannon(Player player, String[] args) {
if (player == null) {
SendMessage(player,
"§cThis command can only be used by a player.§r");
"§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!");
"§cYou can only use KittyCannon in it's minigame!");
return;
}
try {
@ -711,7 +721,7 @@ public class Commands implements CommandExecutor {
final ItemStack head = new ItemStack(
Material.SKULL_ITEM, 1, (short) 3, (byte) 3);
SkullMeta im = (SkullMeta) head.getItemMeta();
im.setDisplayName("§rOcelot Head");
im.setDisplayName("§rOcelot Head");
im.setOwner("MHF_Ocelot");
im.setLore(lore);
head.setItemMeta(im);
@ -729,10 +739,10 @@ public class Commands implements CommandExecutor {
query = query.trim();
if (args.length == 0)
SendMessage(player,
"§bMinecraft Wiki link: http://minecraft.gamepedia.com/");
"§bMinecraft Wiki link: http://minecraft.gamepedia.com/");
else
SendMessage(player,
"§bMinecraft Wiki link: http://minecraft.gamepedia.com/index.php?search="
"§bMinecraft Wiki link: http://minecraft.gamepedia.com/index.php?search="
+ query + "&title=Special%3ASearch&go=Go");
}
}

View file

@ -29,6 +29,7 @@ public class MaybeOfflinePlayer {
public int FDeaths;
public boolean RainbowPresserColorMode = false;
public String OtherColorMode = "";
public boolean ChatOnly = false;
public UUID UUID;
@ -132,4 +133,8 @@ public class MaybeOfflinePlayer {
public String GetFlairTime() {
return FlairTime;
}
public static MaybeOfflinePlayer GetFromPlayer(Player p) {
return MaybeOfflinePlayer.AllPlayers.get(p.getUniqueId());
}
}

View file

@ -9,7 +9,9 @@ import java.util.TimerTask;
import java.util.UUID;
import com.palmergames.bukkit.towny.Towny;
import org.bukkit.Bukkit;
import org.bukkit.GameMode;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.block.Block;
@ -150,31 +152,32 @@ public class PlayerListener implements Listener {
"authme.player.*");
}
if(ispremium)
{
Bukkit.getScheduler().runTaskLater(PluginMain.Instance, new Runnable(){
public void run()
{
if (ispremium) {
Bukkit.getScheduler().runTaskLater(PluginMain.Instance,
new Runnable() {
public void run() {
AuthMe.getInstance().api.forceLogout(p);
}
}, 100);
Bukkit.getScheduler().runTaskLater(PluginMain.Instance, new Runnable(){
public void run()
{
Bukkit.getScheduler().runTaskLater(PluginMain.Instance,
new Runnable() {
public void run() {
AuthMe.getInstance().api.forceLogin(p);
}
}, 120);
}
else if(!mp.FlairState.equals(FlairStates.Accepted) && !mp.FlairState
.equals(FlairStates.Commented))
{
} else if (!mp.FlairState.equals(FlairStates.Accepted)
&& !mp.FlairState.equals(FlairStates.Commented)) {
String json = String
.format("[\"\",{\"text\":\"Welcome! You appear to log in from a non-premium account. Please verify your /r/thebutton flair to play, \",\"color\":\"aqua\"},{\"text\":\"[here].\",\"color\":\"aqua\",\"clickEvent\":{\"action\":\"open_url\",\"value\":\"%s\"},\"hoverEvent\":{\"action\":\"show_text\",\"value\":{\"text\":\"\",\"extra\":[{\"text\":\"Click here to go to the Reddit thread\",\"color\":\"aqua\"}]}}}]",
PluginMain.FlairThreadURL);
PluginMain.Instance.getServer().dispatchCommand(
PluginMain.Console,
PluginMain.Instance.getServer().dispatchCommand(PluginMain.Console,
"tellraw " + mp.PlayerName + " " + json);
}
if (mp.ChatOnly) {
mp.ChatOnly = false;
p.setGameMode(GameMode.SURVIVAL);
}
}
@EventHandler
@ -402,19 +405,19 @@ public class PlayerListener implements Listener {
|| cmd.equalsIgnoreCase("tp")) {
MinigamePlayer mgp = Minigames.plugin.pdata.getMinigamePlayer(event
.getPlayer());
String currentWorld = event.getPlayer().getLocation().getWorld().getName();
String currentWorld = event.getPlayer().getLocation().getWorld()
.getName();
Location currentLocation = event.getPlayer().getLocation();
TownyUniverse universe = Towny.getPlugin(Towny.class).getTownyUniverse();
TownyUniverse universe = Towny.getPlugin(Towny.class)
.getTownyUniverse();
if (mgp.isInMinigame()
&& mgp.getMinigame().getMechanic().getMechanic()
.equals("creativeglobal")) {
mgp.setAllowTeleport(true);
}
else if (TownyUniverse.isWarTime())
{
} else if (TownyUniverse.isWarTime()) {
War war = universe.getWarEvent();
if (war.isWarZone(new WorldCoord(currentWorld, currentLocation.getBlockX(), currentLocation.getBlockZ())))
{
if (war.isWarZone(new WorldCoord(currentWorld, currentLocation
.getBlockX(), currentLocation.getBlockZ()))) {
event.getPlayer().sendMessage(
"§cError: You can't teleport out of a war zone!");
event.setCancelled(true);
@ -590,9 +593,7 @@ public class PlayerListener implements Listener {
e.getPlayer().damage(1f * item.getAmount(),
Bukkit.getPlayer(meta.getLore().get(0)));
e.getItem().remove();
// System.out.println("G");
e.setCancelled(true); // TODO: /tableflip /unflip with spam detection
// System.out.println("H");
e.setCancelled(true);
}
@EventHandler
@ -611,18 +612,6 @@ public class PlayerListener implements Listener {
}
}
/*
* @EventHandler public void onPlayerLogin(PlayerLoginEvent e) {
* System.out.println("Result:" + e.getResult());
* System.out.println("Kick message: " + e.getKickMessage()); }
*/
/*
* @EventHandler public void onPlayerPreLogin(AsyncPlayerPreLoginEvent e) {
* System.out.println("Pre - LoginResult:" + e.getLoginResult());
* System.out.println("Pre - Kick message: " + e.getKickMessage()); }
*/
@EventHandler
public void onPlayerMove(PlayerMoveEvent e) {
// minecraft:tp @a[x=190,y=-80,z=45,dx=5,dy=50,dz=5] 190 1 45
@ -647,6 +636,10 @@ public class PlayerListener implements Listener {
}
});
}
MaybeOfflinePlayer mp=MaybeOfflinePlayer.GetFromPlayer(e.getPlayer());
if(mp.ChatOnly)
e.setCancelled(true);
}
@EventHandler(priority = EventPriority.LOWEST)
@ -665,6 +658,12 @@ public class PlayerListener implements Listener {
e.getPlayer().sendMessage(
"§cYou are not allowed to teleport to/from No Mans Land.");
}
if(MaybeOfflinePlayer.GetFromPlayer(e.getPlayer()).ChatOnly)
{
e.setCancelled(true);
e.getPlayer().sendMessage("§cYou are not allowed to teleport while in chat-only mode.");
}
}
@EventHandler

View file

@ -94,10 +94,18 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
this.getCommand("mwiki").setExecutor(comm);
this.getCommand("mwiki").setUsage(
this.getCommand("mwiki").getUsage().replace('&', '§'));
this.getCommand("warmode").setExecutor(comm);
Instance = this; // 2015.08.08.
Console = this.getServer().getConsoleSender(); // 2015.08.12.
LoadFiles(false); // 2015.08.09.
this.getCommand("tableflip").setExecutor(comm);
this.getCommand("tableflip").setUsage(
this.getCommand("tableflip").getUsage().replace('&', '§'));
this.getCommand("unflip").setExecutor(comm);
this.getCommand("unflip").setUsage(
this.getCommand("unflip").getUsage().replace('&', '§'));
this.getCommand("chatonly").setExecutor(comm);
this.getCommand("chatonly").setUsage(
this.getCommand("chatonly").getUsage().replace('&', '§'));
Instance = this;
Console = this.getServer().getConsoleSender();
LoadFiles(false);
SB = PluginMain.Instance.getServer().getScoreboardManager()
.getMainScoreboard(); // Main can be detected with @a[score_...]