2010-12-01 05:47:24 +01:00
|
|
|
import java.util.logging.Level;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
//=====================================================================
|
|
|
|
//Class: vMinecraftListener
|
|
|
|
//Use: The listener to catch incoming chat and commands
|
|
|
|
//Author: nossr50, TrapAlice, cerevisiae
|
|
|
|
//=====================================================================
|
|
|
|
public class vMinecraftListener extends PluginListener {
|
|
|
|
protected static final Logger log = Logger.getLogger("Minecraft");
|
|
|
|
|
|
|
|
//=====================================================================
|
|
|
|
//Function: disable
|
|
|
|
//Input: None
|
|
|
|
//Output: None
|
|
|
|
//Use: Disables vMinecraft, but why would you want to do that? ;)
|
|
|
|
//=====================================================================
|
|
|
|
public void disable() {
|
|
|
|
log.log(Level.INFO, "vMinecraft disabled");
|
|
|
|
}
|
2010-12-16 01:22:48 +01:00
|
|
|
public void onPlayerMove(Player player, Location from, Location to) {
|
2010-12-16 01:53:25 +01:00
|
|
|
if(vMinecraftSettings.getInstance().isFrozen(player.getName())){
|
2010-12-16 01:22:48 +01:00
|
|
|
player.teleportTo(from);
|
|
|
|
}
|
|
|
|
}
|
2010-12-01 05:47:24 +01:00
|
|
|
|
|
|
|
//=====================================================================
|
|
|
|
//Function: onChat
|
|
|
|
//Input: Player player: The player calling the command
|
|
|
|
// String message: The message to color
|
|
|
|
//Output: boolean: If the user has access to the command
|
|
|
|
// and it is enabled
|
|
|
|
//Use: Checks for quote, rage, and colors
|
|
|
|
//=====================================================================
|
2010-12-16 01:22:48 +01:00
|
|
|
|
2010-12-01 05:47:24 +01:00
|
|
|
public boolean onChat(Player player, String message){
|
|
|
|
|
|
|
|
//Quote (Greentext)
|
2010-12-01 07:56:52 +01:00
|
|
|
if (message.startsWith("@") ||
|
|
|
|
vMinecraftSettings.getInstance().isAdminToggled(player.getName()))
|
2010-12-01 05:47:24 +01:00
|
|
|
return vMinecraftChat.adminChat(player, message);
|
|
|
|
|
|
|
|
else if (message.startsWith(">"))
|
|
|
|
return vMinecraftChat.quote(player, message);
|
|
|
|
|
|
|
|
//Rage (FFF)
|
|
|
|
else if (message.startsWith("FFF"))
|
|
|
|
return vMinecraftChat.rage(player, message);
|
|
|
|
|
|
|
|
//Send through quakeColors otherwise
|
|
|
|
else
|
|
|
|
return vMinecraftChat.quakeColors(player, message);
|
|
|
|
}
|
|
|
|
|
|
|
|
//=====================================================================
|
|
|
|
//Function: onCommand
|
|
|
|
//Input: Player player: The player calling the command
|
|
|
|
// String[] split: The arguments
|
|
|
|
//Output: boolean: If the user has access to the command
|
|
|
|
// and it is enabled
|
|
|
|
//Use: Checks for exploits and runs the commands
|
|
|
|
//=====================================================================
|
|
|
|
public boolean onCommand(Player player, String[] split) {
|
|
|
|
|
|
|
|
//Copy the arguments into their own array.
|
|
|
|
String[] args = new String[split.length - 1];
|
|
|
|
System.arraycopy(split, 1, args, 0, args.length);
|
|
|
|
|
|
|
|
//Return the results of the command
|
|
|
|
int exitCode = vMinecraftCommands.cl.call(split[0], player, args);
|
|
|
|
if(exitCode == 0)
|
|
|
|
return false;
|
|
|
|
else if(exitCode == 1)
|
|
|
|
return true;
|
|
|
|
else
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//=====================================================================
|
|
|
|
//Function: onHealthChange
|
|
|
|
//Input: Player player: The player calling the command
|
|
|
|
// int oldValue: The old health value;
|
|
|
|
// int newValue: The new health value
|
|
|
|
//Output: boolean: If the user has access to the command
|
|
|
|
// and it is enabled
|
|
|
|
//Use: Checks for exploits and runs the commands
|
|
|
|
//=====================================================================
|
|
|
|
public boolean onHealthChange(Player player,int oldValue,int newValue){
|
2010-12-24 02:16:38 +01:00
|
|
|
if (player.getHealth() > 1 && vMinecraftUsers.getProfile(player).isDead()){
|
2010-12-14 01:15:04 +01:00
|
|
|
vMinecraftUsers.getProfile(player).isDead(false);
|
2010-12-24 02:16:38 +01:00
|
|
|
if(vMinecraftSettings.getInstance().playerspawn())
|
|
|
|
{
|
|
|
|
Warp home = null;
|
|
|
|
home = etc.getDataSource().getHome(player.getName());
|
|
|
|
player.teleportTo(home.Location);
|
|
|
|
}
|
2010-12-13 23:15:06 +01:00
|
|
|
}
|
2010-12-14 00:22:23 +01:00
|
|
|
return false;
|
2010-12-03 03:27:04 +01:00
|
|
|
}
|
2010-12-01 19:59:51 +01:00
|
|
|
|
|
|
|
public void onLogin(Player player){
|
2010-12-11 07:28:56 +01:00
|
|
|
vMinecraftChat.sendMessage(player, player, Colors.Rose + "There are currently " + etc.getServer().getPlayerList().size() + " players online.");
|
2010-12-01 19:59:51 +01:00
|
|
|
vMinecraftUsers.addUser(player);
|
|
|
|
}
|
2010-12-12 22:01:17 +01:00
|
|
|
|
|
|
|
public void onDisconnect(Player player){
|
|
|
|
vMinecraftUsers.removeUser(player);
|
|
|
|
}
|
2010-12-08 05:53:51 +01:00
|
|
|
|
2010-12-08 05:08:40 +01:00
|
|
|
public boolean onIgnite(Block block, Player player) {
|
|
|
|
if(vMinecraftSettings.stopFire){
|
2010-12-08 09:21:01 +01:00
|
|
|
if(block.getStatus() == 3 || block.getStatus() == 1){
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if(block.getStatus() == 2 && !player.isAdmin()){
|
2010-12-08 05:08:40 +01:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2010-12-14 01:15:04 +01:00
|
|
|
|
2010-12-14 01:19:10 +01:00
|
|
|
public boolean onDamage(PluginLoader.DamageType type, BaseEntity attacker, BaseEntity defender, int amount) {
|
2010-12-14 01:15:04 +01:00
|
|
|
Player defend = null;
|
|
|
|
if(defender != null && defender.isPlayer())
|
|
|
|
{
|
|
|
|
defend = defender.getPlayer();
|
|
|
|
if (vMinecraftSettings.getInstance().isEzModo(defend.getName())) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (defend.getHealth() > 0)
|
|
|
|
return false;
|
|
|
|
if (vMinecraftUsers.getProfile(defend).isDead())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
vMinecraftUsers.getProfile(defend).isDead(true);
|
2010-12-01 05:47:24 +01:00
|
|
|
|
2010-12-14 01:15:04 +01:00
|
|
|
Player attack = null;
|
|
|
|
if(attacker != null && attacker.isPlayer())
|
|
|
|
attack = attacker.getPlayer();
|
|
|
|
if(attack != null)
|
|
|
|
{
|
2010-12-14 01:19:10 +01:00
|
|
|
vMinecraftChat.gmsg(defend.getName() + " was slain by " + attack.getName());
|
2010-12-14 01:15:04 +01:00
|
|
|
}
|
|
|
|
if (type == type.CREEPER_EXPLOSION) {
|
|
|
|
vMinecraftChat.gmsg(defend.getName() + Colors.Rose + " was blown to bits by a creeper");
|
|
|
|
} else if(type == type.FALL){
|
|
|
|
vMinecraftChat.gmsg(defend.getName() + Colors.Rose + " fell to death!");
|
|
|
|
} else if(type == type.FIRE){
|
|
|
|
vMinecraftChat.gmsg(defend.getName() + Colors.Rose + " was incinerated");
|
|
|
|
} else if (type == type.FIRE_TICK){
|
|
|
|
vMinecraftChat.gmsg(defend.getName() + Colors.Rose + " Stop drop and roll, not scream, run, and burn ");
|
|
|
|
} else if (type == type.LAVA){
|
|
|
|
vMinecraftChat.gmsg(defend.getName() + Colors.Rose + " drowned in lava");
|
|
|
|
} else if (type == type.WATER){
|
|
|
|
log.log(Level.INFO, "Water");
|
|
|
|
vMinecraftChat.gmsg(defend.getName() + Colors.Rose + " should've attended that swimming class");
|
|
|
|
} else {
|
|
|
|
vMinecraftChat.gmsg(Colors.Gray + defend.getName() + " " + vMinecraftSettings.randomDeathMsg());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
return false;
|
2010-12-03 02:25:02 +01:00
|
|
|
}
|
2010-12-01 05:47:24 +01:00
|
|
|
}
|