From 6e361c364c6525815f2b7383a1e7cfc5e7ab6fdb Mon Sep 17 00:00:00 2001 From: zml Date: Tue, 2 Sep 2014 12:16:20 -0700 Subject: [PATCH] Only store last login time for non-virtual players. Fixes #1639 --- .../permissions/bukkit/PermissionsEx.java | 29 +++++++++---------- 1 file changed, 14 insertions(+), 15 deletions(-) diff --git a/src/main/java/ru/tehkode/permissions/bukkit/PermissionsEx.java b/src/main/java/ru/tehkode/permissions/bukkit/PermissionsEx.java index d21c0fcce..57aa9306f 100644 --- a/src/main/java/ru/tehkode/permissions/bukkit/PermissionsEx.java +++ b/src/main/java/ru/tehkode/permissions/bukkit/PermissionsEx.java @@ -428,15 +428,16 @@ public void onAsyncPlayerPreLogin(AsyncPlayerPreLoginEvent event) { public void onPlayerLogin(PlayerJoinEvent event) { try { PermissionUser user = getPermissionsManager().getUser(event.getPlayer()); - if (!user.isVirtual() && !event.getPlayer().getName().equals(user.getOption("name"))) { // Update name only if user exists in config - user.setOption("name", event.getPlayer().getName()); - } - if (!config.shouldLogPlayers()) { - return; + if (!user.isVirtual()) { + if (!event.getPlayer().getName().equals(user.getOption("name"))) { // Update name only if user exists in config + user.setOption("name", event.getPlayer().getName()); + } + if (!config.shouldLogPlayers()) { + return; + } + user.setOption("last-login-time", Long.toString(System.currentTimeMillis() / 1000L)); + // user.setOption("last-login-ip", event.getPlayer().getAddress().getAddress().getHostAddress()); // somehow this won't work } - - user.setOption("last-login-time", Long.toString(System.currentTimeMillis() / 1000L)); - // user.setOption("last-login-ip", event.getPlayer().getAddress().getAddress().getHostAddress()); // somehow this won't work } catch (Throwable t) { ErrorReport.handleError("While login cleanup event", t); } @@ -445,17 +446,15 @@ public void onPlayerLogin(PlayerJoinEvent event) { @EventHandler public void onPlayerQuit(PlayerQuitEvent event) { try { - PermissionUser user = getPermissionsManager().getUser(event.getPlayer()); - if (config.shouldLogPlayers()) { - user.setOption("last-logout-time", Long.toString(System.currentTimeMillis() / 1000L)); - } - if (!user.isVirtual()) { + if (config.shouldLogPlayers()) { + user.setOption("last-logout-time", Long.toString(System.currentTimeMillis() / 1000L)); + } + user.getName(); // Set name if user was created during server run } - - getPermissionsManager().resetUser(event.getPlayer()); + getPermissionsManager().resetUser(event.getPlayer()); } catch (Throwable t) { ErrorReport.handleError("While logout cleanup event", t); }