mirror of
https://github.com/EssentialsX/Essentials.git
synced 2025-01-08 01:17:41 +01:00
Attempt to optimize Essentials login event.
This commit is contained in:
parent
a1f1319990
commit
c298fb9332
@ -166,9 +166,17 @@ public class EssentialsPlayerListener implements Listener
|
|||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ess.getBackup().onPlayerJoin();
|
ess.getBackup().onPlayerJoin();
|
||||||
final User user = ess.getUser(player);
|
final User user = ess.getUser(player);
|
||||||
user.setLastLogin(System.currentTimeMillis());
|
|
||||||
|
if (user.isNPC())
|
||||||
|
{
|
||||||
|
user.setNPC(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
final long currentTime = System.currentTimeMillis();
|
||||||
|
user.checkMuteTimeout(currentTime);
|
||||||
user.updateActivity(false);
|
user.updateActivity(false);
|
||||||
|
|
||||||
ess.scheduleSyncDelayedTask(new Runnable()
|
ess.scheduleSyncDelayedTask(new Runnable()
|
||||||
@ -176,6 +184,7 @@ public class EssentialsPlayerListener implements Listener
|
|||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
{
|
{
|
||||||
|
user.setLastLogin(currentTime);
|
||||||
user.setDisplayNick();
|
user.setDisplayNick();
|
||||||
updateCompass(user);
|
updateCompass(user);
|
||||||
|
|
||||||
@ -277,7 +286,6 @@ public class EssentialsPlayerListener implements Listener
|
|||||||
{
|
{
|
||||||
switch (event.getResult())
|
switch (event.getResult())
|
||||||
{
|
{
|
||||||
case ALLOWED:
|
|
||||||
case KICK_FULL:
|
case KICK_FULL:
|
||||||
case KICK_BANNED:
|
case KICK_BANNED:
|
||||||
break;
|
break;
|
||||||
@ -286,30 +294,25 @@ public class EssentialsPlayerListener implements Listener
|
|||||||
}
|
}
|
||||||
|
|
||||||
final User user = ess.getUser(event.getPlayer());
|
final User user = ess.getUser(event.getPlayer());
|
||||||
if (user.isNPC())
|
|
||||||
{
|
|
||||||
user.setNPC(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
final long currentTime = System.currentTimeMillis();
|
if (event.getResult() == Result.KICK_BANNED || user.isBanned())
|
||||||
final boolean banExpired = user.checkBanTimeout(currentTime);
|
|
||||||
user.checkMuteTimeout(currentTime);
|
|
||||||
user.checkJailTimeout(currentTime);
|
|
||||||
|
|
||||||
if (!banExpired && (user.isBanned() || event.getResult() == Result.KICK_BANNED))
|
|
||||||
{
|
{
|
||||||
String banReason = user.getBanReason();
|
final boolean banExpired = user.checkBanTimeout(System.currentTimeMillis());
|
||||||
if (banReason == null || banReason.isEmpty() || banReason.equalsIgnoreCase("ban"))
|
if (!banExpired)
|
||||||
{
|
{
|
||||||
banReason = _("defaultBanReason");
|
String banReason = user.getBanReason();
|
||||||
|
if (banReason == null || banReason.isEmpty() || banReason.equalsIgnoreCase("ban"))
|
||||||
|
{
|
||||||
|
banReason = _("defaultBanReason");
|
||||||
|
}
|
||||||
|
if (user.getBanTimeout() > 0)
|
||||||
|
{
|
||||||
|
//TODO: TL This
|
||||||
|
banReason += "\n\n" + "Expires in " + Util.formatDateDiff(user.getBanTimeout());
|
||||||
|
}
|
||||||
|
event.disallow(Result.KICK_BANNED, banReason);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
if (user.getBanTimeout() > 0)
|
|
||||||
{
|
|
||||||
//TODO: TL This
|
|
||||||
banReason += "\n\n" + "Expires in " + Util.formatDateDiff(user.getBanTimeout());
|
|
||||||
}
|
|
||||||
event.disallow(Result.KICK_BANNED, banReason);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event.getResult() == Result.KICK_FULL && !user.isAuthorized("essentials.joinfullserver"))
|
if (event.getResult() == Result.KICK_FULL && !user.isAuthorized("essentials.joinfullserver"))
|
||||||
|
@ -310,6 +310,8 @@ public class Jails extends AsyncStorageObjectHolder<com.earth2me.essentials.sett
|
|||||||
public void onPlayerJoin(final PlayerJoinEvent event)
|
public void onPlayerJoin(final PlayerJoinEvent event)
|
||||||
{
|
{
|
||||||
final User user = ess.getUser(event.getPlayer());
|
final User user = ess.getUser(event.getPlayer());
|
||||||
|
final long currentTime = System.currentTimeMillis();
|
||||||
|
user.checkJailTimeout(currentTime);
|
||||||
if (!user.isJailed() || user.getJail() == null || user.getJail().isEmpty())
|
if (!user.isJailed() || user.getJail() == null || user.getJail().isEmpty())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user