/[projects]/miscJava/bukkit-minecraft-plugins/HoerupUtils/src/main/java/dk/thoerup/bukkit/hoeruputils/web/StatusListener.java
ViewVC logotype

Annotation of /miscJava/bukkit-minecraft-plugins/HoerupUtils/src/main/java/dk/thoerup/bukkit/hoeruputils/web/StatusListener.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1671 - (hide annotations) (download)
Thu Dec 22 20:30:28 2011 UTC (12 years, 5 months ago) by torben
Original Path: miscJava/bukkit-minecraft-plugins/HoerupUtils/src/dk/thoerup/bukkit/hoeruputils/web/StatusListener.java
File size: 4016 byte(s)
add diver command and add player homes to status XML
1 torben 1241 package dk.thoerup.bukkit.hoeruputils.web;
2    
3 torben 1494 import java.io.File;
4     import java.text.SimpleDateFormat;
5     import java.util.Date;
6 torben 1614 import java.util.Set;
7 torben 1494 import java.util.Map;
8 torben 1670 import org.bukkit.Location;
9 torben 1241 import org.bukkit.Server;
10 torben 1664 import org.bukkit.OfflinePlayer;
11 torben 1241 import org.bukkit.entity.Player;
12     import org.bukkit.plugin.Plugin;
13 torben 1614
14 torben 1667 import org.bukkit.configuration.Configuration;
15 torben 1614
16 torben 1241 import org.kokakiwi.apicraft.events.ApiEvent;
17     import org.kokakiwi.apicraft.events.ApiListener;
18    
19     public class StatusListener extends ApiListener {
20    
21 torben 1495 SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
22 torben 1494
23 torben 1241 Server server;
24 torben 1667 Configuration loginConfig;
25 torben 1671 Configuration homeConfig;
26 torben 1667
27 torben 1671 public StatusListener(Server server, Configuration loginConfig, Configuration homeConfig) {
28 torben 1667 this.server = server;
29     this.loginConfig = loginConfig;
30 torben 1671 this.homeConfig = homeConfig;
31 torben 1241 }
32 torben 1494
33     String formatTime(String input) {
34 torben 1664 return formatTime( Long.parseLong(input) );
35     }
36     String formatTime(long input) {
37     Date d = new Date( input );
38 torben 1494 return format.format(d );
39     }
40 torben 1241
41     @Override
42     public void onApiEvent(ApiEvent event) {
43 torben 1666 if(!event.path[0].equalsIgnoreCase("webstatus")) {
44     return;
45     }
46     StringBuilder sb = new StringBuilder();
47 torben 1589
48 torben 1666 sb.append("<?xml version=\"1.0\"?> \n");
49     sb.append("<serverinfo>");
50 torben 1664
51 torben 1666 sb.append("<version>" + server.getVersion() + "</version>\n");
52 torben 1494
53 torben 1666 long mb = 1024*1024;
54     Runtime rt = Runtime.getRuntime();
55     sb.append("<memory>\n");
56     sb.append("<free>" + rt.freeMemory()/mb + "</free>\n");
57     sb.append("<total>" + rt.totalMemory()/mb + "</total>\n");
58     sb.append("<max>" + rt.maxMemory()/mb + "</max>\n");
59     sb.append("</memory>\n");
60 torben 1494
61 torben 1614
62 torben 1667 long now = System.currentTimeMillis();
63    
64 torben 1668 sb.append("<players>\n");
65 torben 1666 OfflinePlayer playerList[] = server.getOfflinePlayers();
66     for (OfflinePlayer player : playerList) {
67     long first = player.getFirstPlayed();
68     long last = player.getLastPlayed();
69 torben 1664
70 torben 1668
71     sb.append("<player>\n");
72 torben 1666 sb.append("<name>" + player.getName() + "</name>\n" );
73 torben 1668
74 torben 1666 sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");
75     sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");
76 torben 1670
77     sb.append("<online>" + (player.isOnline() ? 1 : 0 ) + "</online>\n" );
78    
79     if (player.isOnline() ) {
80     long login = loginConfig.getLong( player.getName() + ".logintime", -1);
81     long elapsed = (login>-1 ? (now-login) / 1000 : -1);
82    
83     Player p2 = server.getPlayer( player.getName() );
84     Location loc = p2.getLocation();
85    
86     sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );
87     sb.append("<ip>" + p2.getAddress().getAddress().toString().replace("/","") + "</ip>\n" );
88     sb.append("<location>");
89     sb.append("<x>" + loc.getBlockX() + "</x>");
90     sb.append("<y>" + loc.getBlockY() + "</y>");
91     sb.append("<z>" + loc.getBlockZ() + "</z>");
92     sb.append("<world>" + loc.getWorld().getName() + "</world>");
93 torben 1671 sb.append("</location>");
94 torben 1670 }
95    
96 torben 1671 String homeWorld = homeConfig.getString( player.getName() + ".world");
97     if (homeWorld != null) {
98     sb.append("<home>");
99     sb.append("<world>" + homeWorld + "</world>\n");
100     sb.append("<x>" + (int)homeConfig.getDouble(player.getName() + ".x") + "</x>\n");
101     sb.append("<y>" + (int)homeConfig.getDouble(player.getName() + ".y") + "</y>\n");
102     sb.append("<z>" + (int)homeConfig.getDouble(player.getName() + ".z") + "</z>\n");
103     sb.append("</home>");
104 torben 1670
105 torben 1671 }
106    
107    
108 torben 1668 sb.append("</player>\n");
109 torben 1666 }
110 torben 1668 sb.append("</players>\n");
111 torben 1494
112 torben 1666 sb.append("<plugins>\n");
113     for (Plugin plugin : server.getPluginManager().getPlugins()) {
114 torben 1670
115 torben 1666 sb.append("<plugin>\n");
116     sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");
117     sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");
118 torben 1670 sb.append("<website>" + (plugin.getDescription().getWebsite() != null ? plugin.getDescription().getWebsite() : "") + "</website>\n");
119 torben 1666 sb.append("</plugin>\n");
120     }
121     sb.append("</plugins>\n");
122 torben 1241
123 torben 1666 sb.append("</serverinfo>");
124     event.setResponse(sb.toString());
125     event.setActionTaken(true);
126    
127 torben 1241 }
128    
129     }

  ViewVC Help
Powered by ViewVC 1.1.20