summaryrefslogtreecommitdiffstats
path: root/EssentialsXMPP/src/com/earth2me/essentials/xmpp/EssentialsXMPPPlayerListener.java
blob: d7e30f7dc9eeb99f55acf693da0f0f6b3bb6d370 (plain)
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
86
87
88
89
90
91
92
93
94
95
96
97
98
package com.earth2me.essentials.xmpp;

import com.earth2me.essentials.IEssentials;
import com.earth2me.essentials.User;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import net.ess3.api.IUser;
import org.bukkit.Bukkit;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.player.AsyncPlayerChatEvent;
import org.bukkit.event.player.PlayerJoinEvent;
import org.bukkit.event.player.PlayerQuitEvent;
import org.bukkit.Server;


class EssentialsXMPPPlayerListener implements Listener
{
        private final transient IEssentials ess;

        EssentialsXMPPPlayerListener(final IEssentials ess)
        {
                super();
                this.ess = ess;
        }

        @EventHandler(priority = EventPriority.MONITOR)
        public void onPlayerJoin(final PlayerJoinEvent event)
        {
                final User user = ess.getUser(event.getPlayer());

                 Bukkit.getScheduler().scheduleSyncDelayedTask(ess, new Runnable()
                                        {
                                                @Override
                                                public void run()
                                                {
                                                        EssentialsXMPP.updatePresence();
                                                }
                                        });

                sendMessageToSpyUsers("Player " + user.getDisplayName() + " joined the game");
        }

        @EventHandler(priority = EventPriority.MONITOR)
        public void onPlayerChat(final AsyncPlayerChatEvent event)
        {
                final User user = ess.getUser(event.getPlayer());
                sendMessageToSpyUsers(String.format(event.getFormat(), user.getDisplayName(), event.getMessage()));
        }

        @EventHandler(priority = EventPriority.MONITOR)
        public void onPlayerQuit(final PlayerQuitEvent event)
        {
                final User user = ess.getUser(event.getPlayer());

                 Bukkit.getScheduler().scheduleSyncDelayedTask(ess, new Runnable()
                                        {
                                                @Override
                                                public void run()
                                                {
                                                        EssentialsXMPP.updatePresence();
                                                }
                                        });


                sendMessageToSpyUsers("Player " + user.getDisplayName() + " left the game");
        }

        private void sendMessageToSpyUsers(final String message)
        {
                try
                {
                        List<String> users = EssentialsXMPP.getInstance().getSpyUsers();
                        synchronized (users)
                        {
                                for (final String address : users)
                                {
                                        Bukkit.getScheduler().scheduleSyncDelayedTask(ess, new Runnable()
                                        {
                                                @Override
                                                public void run()
                                                {
                                                        EssentialsXMPP.getInstance().sendMessage(address, message);
                                                }

                                        });

                                }
                        }
                }
                catch (Exception ex)
                {
                        // Ignore exceptions
                }
        }
}