AnnouncementTask.java 2.14 KB
Newer Older
Akka's avatar
Akka committed
1
2
3
package emu.grasscutter.task.tasks;

import emu.grasscutter.Grasscutter;
4
import emu.grasscutter.game.managers.AnnouncementSystem;
Akka's avatar
Akka committed
5
6
7
8
9
10
11
12
13
14
15
16
17
import emu.grasscutter.task.Task;
import emu.grasscutter.task.TaskHandler;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;

import java.util.Date;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.stream.Collectors;

@Task(taskName = "Announcement", taskCronExpression = "0 * * * * ?", triggerName = "AnnouncementTrigger")
public final class AnnouncementTask extends TaskHandler {

Akka's avatar
Akka committed
18
    static Map<Integer, Integer> intervalMap = new ConcurrentHashMap<>();
Akka's avatar
Akka committed
19
20
21
22
23
24
25
26
27
28
29
30
31
    @Override
    public void onEnable() {
        Grasscutter.getLogger().debug("[Task] Announcement task enabled.");
    }

    @Override
    public void onDisable() {
        Grasscutter.getLogger().debug("[Task] Announcement task disabled.");
    }

    @Override
    public synchronized void execute(JobExecutionContext context) throws JobExecutionException {
        var current = new Date();
32
33
        var announceConfigItems = Grasscutter.getGameServer().getAnnouncementSystem().getAnnounceConfigItemMap().values().stream()
            .filter(AnnouncementSystem.AnnounceConfigItem::isTick)
Akka's avatar
Akka committed
34
35
            .filter(i -> current.after(i.getBeginTime()))
            .filter(i -> current.before(i.getEndTime()))
36
            .collect(Collectors.toMap(AnnouncementSystem.AnnounceConfigItem::getTemplateId, y -> y));
Akka's avatar
Akka committed
37
38
39
40
41

        announceConfigItems.values().forEach(i -> intervalMap.compute(i.getTemplateId(), (k,v) -> v == null ? 1 : v + 1));

        var toSend = intervalMap.entrySet().stream()
            .filter(i -> announceConfigItems.containsKey(i.getKey()))
Akka's avatar
Akka committed
42
            .filter(i -> i.getValue() >= announceConfigItems.get(i.getKey()).getInterval())
Akka's avatar
Akka committed
43
44
45
            .map(i -> announceConfigItems.get(i.getKey()))
            .toList();

46
        Grasscutter.getGameServer().getAnnouncementSystem().broadcast(toSend);
Akka's avatar
Akka committed
47
48
49
50
51
52
        Grasscutter.getLogger().debug("Broadcast {} announcement(s) to all online players", toSend.size());

        // clear the interval count
        toSend.forEach(i -> intervalMap.put(i.getTemplateId(), 0));
    }
}