-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathQuitHandler.java
More file actions
85 lines (73 loc) · 3.19 KB
/
QuitHandler.java
File metadata and controls
85 lines (73 loc) · 3.19 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package dansplugins.activitytracker.eventhandlers;
import dansplugins.activitytracker.exceptions.NoSessionException;
import dansplugins.activitytracker.services.DiscordWebhookService;
import dansplugins.activitytracker.utils.Logger;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerQuitEvent;
import org.bukkit.plugin.java.JavaPlugin;
import dansplugins.activitytracker.data.PersistentData;
import dansplugins.activitytracker.objects.ActivityRecord;
import dansplugins.activitytracker.objects.Session;
/**
* @author Daniel McCoy Stephenson
*/
public class QuitHandler implements Listener {
private final PersistentData persistentData;
private final Logger logger;
private final DiscordWebhookService discordWebhookService;
private final JavaPlugin plugin;
private static final String STAFF_PERMISSION = "at.staff";
public QuitHandler(PersistentData persistentData, Logger logger, DiscordWebhookService discordWebhookService, JavaPlugin plugin) {
this.persistentData = persistentData;
this.logger = logger;
this.discordWebhookService = discordWebhookService;
this.plugin = plugin;
}
@EventHandler()
public void handle(PlayerQuitEvent event) {
Player player = event.getPlayer();
ActivityRecord record = persistentData.getActivityRecord(player);
if (record == null) {
logger.log("ERROR: No activity record found for " + player.getName() + " on logout.");
return;
}
Session currentSession;
try {
currentSession = record.getMostRecentSession();
}
catch (NoSessionException e) {
logger.log("ERROR: The most recent session was null for " + player.getName() + ": " + e.getMessage());
return;
}
logger.log(player.getName() + " has quit the server. Ending their session.");
try {
if (currentSession.isActive()) {
currentSession.endSession();
double totalHoursSpent = record.getHoursSpentNotIncludingTheCurrentSession() + currentSession.getMinutesSpent() / 60;
logger.log(player.getName() + " total hours spent on the server: " + totalHoursSpent);
record.setHoursSpent(totalHoursSpent);
} else {
logger.log("WARNING: Session for " + player.getName() + " was already ended.");
}
} catch (Exception e) {
logger.log("ERROR: Failed to properly end session for " + player.getName() + ": " + e.getMessage());
}
sendDiscordQuitNotification(player);
}
private void sendDiscordQuitNotification(Player player) {
if (!discordWebhookService.isEnabled()) {
return;
}
if (discordWebhookService.isStaffOnly() && !player.hasPermission(STAFF_PERMISSION)) {
return;
}
plugin.getServer().getScheduler().runTaskAsynchronously(plugin, new Runnable() {
@Override
public void run() {
discordWebhookService.sendQuitNotification(player.getName());
}
});
}
}