mirror of
https://github.com/EssentialsX/Essentials.git
synced 2025-01-01 14:07:46 +01:00
Merge branch 'refs/heads/master' into release
This commit is contained in:
commit
e271e60144
@ -30,7 +30,12 @@ public class Commandbanip extends EssentialsCommand
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ess.getServer().banIP(u.getAddress().getAddress().getHostAddress());
|
final String ipAddress = u.getLastLoginAddress();
|
||||||
|
if (ipAddress.length() == 0)
|
||||||
|
{
|
||||||
|
throw new Exception(Util.i18n("playerNotFound"));
|
||||||
|
}
|
||||||
|
ess.getServer().banIP(u.getLastLoginAddress());
|
||||||
sender.sendMessage(Util.i18n("banIpAddress"));
|
sender.sendMessage(Util.i18n("banIpAddress"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,7 +38,6 @@ public class Commandgamemode extends EssentialsCommand
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
player.setGameMode(player.getGameMode() == GameMode.SURVIVAL ? GameMode.CREATIVE : GameMode.SURVIVAL);
|
player.setGameMode(player.getGameMode() == GameMode.SURVIVAL ? GameMode.CREATIVE : GameMode.SURVIVAL);
|
||||||
//TODO: add this to messages?
|
|
||||||
sender.sendMessage(Util.format("gameMode", Util.i18n(player.getGameMode().toString().toLowerCase()), player.getDisplayName()));
|
sender.sendMessage(Util.format("gameMode", Util.i18n(player.getGameMode().toString().toLowerCase()), player.getDisplayName()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,9 @@ public class Commandrepair extends EssentialsCommand
|
|||||||
final List<String> repaired = new ArrayList<String>();
|
final List<String> repaired = new ArrayList<String>();
|
||||||
repairItems(user.getInventory().getContents(), user, repaired);
|
repairItems(user.getInventory().getContents(), user, repaired);
|
||||||
|
|
||||||
repairItems(user.getInventory().getArmorContents(), user, repaired);
|
if (user.isAuthorized("essentials.repair.armor")) {
|
||||||
|
repairItems(user.getInventory().getArmorContents(), user, repaired);
|
||||||
|
}
|
||||||
|
|
||||||
if (repaired.isEmpty())
|
if (repaired.isEmpty())
|
||||||
{
|
{
|
||||||
|
@ -0,0 +1,41 @@
|
|||||||
|
package com.earth2me.essentials.commands;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.User;
|
||||||
|
import org.bukkit.Server;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.PluginCommand;
|
||||||
|
|
||||||
|
|
||||||
|
public class Commandsudo extends EssentialsCommand
|
||||||
|
{
|
||||||
|
public Commandsudo()
|
||||||
|
{
|
||||||
|
super("sudo");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run(final Server server, final CommandSender sender, final String commandLabel, final String[] args) throws Exception
|
||||||
|
{
|
||||||
|
if (args.length < 2)
|
||||||
|
{
|
||||||
|
throw new NotEnoughArgumentsException();
|
||||||
|
}
|
||||||
|
|
||||||
|
final User user = getPlayer(server, args, 0, false);
|
||||||
|
final String command = args[1];
|
||||||
|
final String[] arguments = new String[args.length - 2];
|
||||||
|
if (arguments.length > 0) {
|
||||||
|
System.arraycopy(args, 2, arguments, 0, args.length - 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
//TODO: Translate this.
|
||||||
|
sender.sendMessage("Running the command as " + user.getDisplayName());
|
||||||
|
|
||||||
|
final PluginCommand pc = ess.getServer().getPluginCommand(command);
|
||||||
|
if (pc != null)
|
||||||
|
{
|
||||||
|
pc.execute(user.getBase(), command, arguments);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package com.earth2me.essentials.signs;
|
||||||
|
|
||||||
|
import com.earth2me.essentials.Trade;
|
||||||
|
import com.earth2me.essentials.ChargeException;
|
||||||
|
import com.earth2me.essentials.IEssentials;
|
||||||
|
import com.earth2me.essentials.User;
|
||||||
|
import com.earth2me.essentials.Util;
|
||||||
|
import org.bukkit.GameMode;
|
||||||
|
|
||||||
|
|
||||||
|
public class SignGameMode extends EssentialsSign
|
||||||
|
{
|
||||||
|
public SignGameMode()
|
||||||
|
{
|
||||||
|
super("GameMode");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean onSignCreate(final ISign sign, final User player, final String username, final IEssentials ess) throws SignException
|
||||||
|
{
|
||||||
|
validateTrade(sign, 1, ess);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean onSignInteract(final ISign sign, final User player, final String username, final IEssentials ess) throws SignException, ChargeException
|
||||||
|
{
|
||||||
|
final Trade charge = getTrade(sign, 1, ess);
|
||||||
|
charge.isAffordableFor(player);
|
||||||
|
|
||||||
|
player.setGameMode(player.getGameMode() == GameMode.SURVIVAL ? GameMode.CREATIVE : GameMode.SURVIVAL);
|
||||||
|
player.sendMessage(Util.format("gameMode", Util.i18n(player.getGameMode().toString().toLowerCase()), player.getDisplayName()));
|
||||||
|
charge.charge(player);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
@ -7,6 +7,7 @@ public enum Signs
|
|||||||
BUY(new SignBuy()),
|
BUY(new SignBuy()),
|
||||||
DISPOSAL(new SignDisposal()),
|
DISPOSAL(new SignDisposal()),
|
||||||
FREE(new SignFree()),
|
FREE(new SignFree()),
|
||||||
|
GAMEMODE(new SignGameMode()),
|
||||||
HEAL(new SignHeal()),
|
HEAL(new SignHeal()),
|
||||||
MAIL(new SignMail()),
|
MAIL(new SignMail()),
|
||||||
PROTECTION(new SignProtection()),
|
PROTECTION(new SignProtection()),
|
||||||
|
@ -274,6 +274,10 @@ commands:
|
|||||||
description: Spawns a mob.
|
description: Spawns a mob.
|
||||||
usage: /<command> <mob>[:data][,<mount>[:data]] [amount]
|
usage: /<command> <mob>[:data][,<mount>[:data]] [amount]
|
||||||
aliases: [espawnmob]
|
aliases: [espawnmob]
|
||||||
|
sudo:
|
||||||
|
description: Make another user do something.
|
||||||
|
usage: /<command> <player> <command [args]>
|
||||||
|
aliases: [esudo]
|
||||||
suicide:
|
suicide:
|
||||||
description: Causes you to perish.
|
description: Causes you to perish.
|
||||||
usage: /<command>
|
usage: /<command>
|
||||||
|
@ -70,4 +70,6 @@ v 1.5:
|
|||||||
If the files on Disc have changed AND there have been changes to it's in-memory data it will show a warning.
|
If the files on Disc have changed AND there have been changes to it's in-memory data it will show a warning.
|
||||||
You then MUST issue a '/mansave force' to overwrite the disc files, or a '/manload' to overwrite the memory data.
|
You then MUST issue a '/mansave force' to overwrite the disc files, or a '/manload' to overwrite the memory data.
|
||||||
- Fix for an error in checkFullUserPermission caused by players disconnecting mid perms update.
|
- Fix for an error in checkFullUserPermission caused by players disconnecting mid perms update.
|
||||||
- Notification of being moved to the default group only happens if it's a demotion/promotion (not on join).
|
- Notification of being moved to the default group only happens if it's a demotion/promotion (not on join).
|
||||||
|
- Fixed GM holding files open and causing the time stamp to be incorrect. This caused GM to require a '/mansave force' when it shouldn't be needed.
|
||||||
|
- Fixed a crash on reload due to bukkit not unloading plugins before reloading.
|
@ -130,6 +130,9 @@ public class GroupManager extends JavaPlugin {
|
|||||||
throw new IllegalStateException("An error ocurred while loading GroupManager");
|
throw new IllegalStateException("An error ocurred while loading GroupManager");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set a few defaults (reloads)
|
||||||
|
setLoaded(false);
|
||||||
|
|
||||||
// Initialize the world listener and bukkit permissions to handle
|
// Initialize the world listener and bukkit permissions to handle
|
||||||
// events.
|
// events.
|
||||||
WorldEvents = new GMWorldListener(this);
|
WorldEvents = new GMWorldListener(this);
|
||||||
|
@ -338,7 +338,7 @@ public class WorldDataHolder {
|
|||||||
}
|
}
|
||||||
this.setDefaultGroup(this.getGroup(ph.getDefaultGroup().getName()));
|
this.setDefaultGroup(this.getGroup(ph.getDefaultGroup().getName()));
|
||||||
this.removeGroupsChangedFlag();
|
this.removeGroupsChangedFlag();
|
||||||
this.timeStampGroups = ph.getTimeStampGroups();
|
this.timeStampGroups = getGroupsFile().lastModified();
|
||||||
|
|
||||||
ph = null;
|
ph = null;
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
@ -368,7 +368,7 @@ public class WorldDataHolder {
|
|||||||
tempUser.clone(this);
|
tempUser.clone(this);
|
||||||
}
|
}
|
||||||
this.removeUsersChangedFlag();
|
this.removeUsersChangedFlag();
|
||||||
this.timeStampUsers = ph.getTimeStampUsers();
|
this.timeStampUsers = getUsersFile().lastModified();
|
||||||
|
|
||||||
ph = null;
|
ph = null;
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
@ -925,6 +925,7 @@ public class WorldDataHolder {
|
|||||||
out.write(newLine);
|
out.write(newLine);
|
||||||
|
|
||||||
yaml.dump(root, out);
|
yaml.dump(root, out);
|
||||||
|
out.close();
|
||||||
} catch (UnsupportedEncodingException ex) {
|
} catch (UnsupportedEncodingException ex) {
|
||||||
} catch (FileNotFoundException ex) {
|
} catch (FileNotFoundException ex) {
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
@ -995,10 +996,13 @@ public class WorldDataHolder {
|
|||||||
opt.setDefaultFlowStyle(DumperOptions.FlowStyle.BLOCK);
|
opt.setDefaultFlowStyle(DumperOptions.FlowStyle.BLOCK);
|
||||||
final Yaml yaml = new Yaml(opt);
|
final Yaml yaml = new Yaml(opt);
|
||||||
try {
|
try {
|
||||||
yaml.dump(root, new OutputStreamWriter(new FileOutputStream(usersFile), "UTF-8"));
|
OutputStreamWriter out = new OutputStreamWriter(new FileOutputStream(usersFile), "UTF-8");
|
||||||
|
yaml.dump(root, out);
|
||||||
|
out.close();
|
||||||
} catch (UnsupportedEncodingException ex) {
|
} catch (UnsupportedEncodingException ex) {
|
||||||
} catch (FileNotFoundException ex) {
|
} catch (FileNotFoundException ex) {
|
||||||
}
|
} catch (IOException e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update the LastModified time.
|
// Update the LastModified time.
|
||||||
|
@ -25,10 +25,11 @@ public class EssentialsProtectPlayerListener extends PlayerListener
|
|||||||
@Override
|
@Override
|
||||||
public void onPlayerInteract(final PlayerInteractEvent event)
|
public void onPlayerInteract(final PlayerInteractEvent event)
|
||||||
{
|
{
|
||||||
if (event.isCancelled())
|
// Do not return if cancelled, because the interact event has 2 cancelled states.
|
||||||
|
/*if (event.isCancelled())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}*/
|
||||||
final User user = ess.getUser(event.getPlayer());
|
final User user = ess.getUser(event.getPlayer());
|
||||||
|
|
||||||
if (event.hasItem()
|
if (event.hasItem()
|
||||||
|
Loading…
Reference in New Issue
Block a user