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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

miscJava/bukkit-minecraft-plugins/HoerupUtils/src/dk/thoerup/bukkit/hoeruputils/web/StatusListener.java revision 1667 by torben, Wed Dec 21 19:19:02 2011 UTC miscJava/bukkit-minecraft-plugins/HoerupUtils/src/main/java/dk/thoerup/bukkit/hoeruputils/web/StatusListener.java revision 1684 by torben, Fri Jan 27 12:21:27 2012 UTC
# Line 5  import java.text.SimpleDateFormat; Line 5  import java.text.SimpleDateFormat;
5  import java.util.Date;  import java.util.Date;
6  import java.util.Set;  import java.util.Set;
7  import java.util.Map;  import java.util.Map;
8    import org.bukkit.Location;
9  import org.bukkit.Server;  import org.bukkit.Server;
10  import org.bukkit.OfflinePlayer;  import org.bukkit.OfflinePlayer;
11  import org.bukkit.entity.Player;  import org.bukkit.entity.Player;
# Line 21  public class StatusListener extends ApiL Line 22  public class StatusListener extends ApiL
22    
23          Server server;          Server server;
24          Configuration loginConfig;          Configuration loginConfig;
25            Configuration homeConfig;
26    
27          public StatusListener(Server server, Configuration loginConfig) {          long cachedTime = 0;
28            String cachedXml = "";
29    
30            public StatusListener(Server server, Configuration loginConfig, Configuration homeConfig) {
31                  this.server = server;                  this.server = server;
32                  this.loginConfig = loginConfig;                          this.loginConfig = loginConfig;        
33                    this.homeConfig = homeConfig;
34          }          }
35    
36          String formatTime(String input) {          String formatTime(String input) {
# Line 40  public class StatusListener extends ApiL Line 46  public class StatusListener extends ApiL
46                  if(!event.path[0].equalsIgnoreCase("webstatus")) {                  if(!event.path[0].equalsIgnoreCase("webstatus")) {
47                          return;                          return;
48                  }                  }
49    
50                    String xml;
51    
52                    synchronized(this) { //is this necessary ?
53                            long now = System.currentTimeMillis();
54                            if ( (now-cachedTime) > 5000) {
55                                    xml = buildXML();
56                                    cachedXml = xml;
57                                    cachedTime = now;
58                            } else {
59                                    xml = cachedXml;
60                            }
61                    }
62                            
63    
64                    event.setResponse(xml);
65                    event.setActionTaken(true);
66            }
67            
68            private String buildXML() {
69    
70                  StringBuilder sb = new StringBuilder();                  StringBuilder sb = new StringBuilder();
71    
72                  sb.append("<?xml version=\"1.0\"?> \n");                  sb.append("<?xml version=\"1.0\"?> \n");
# Line 57  public class StatusListener extends ApiL Line 84  public class StatusListener extends ApiL
84    
85    
86                  long now = System.currentTimeMillis();                  long now = System.currentTimeMillis();
                 sb.append("<onlineplayers>\n");                  
                 for (Player p : server.getOnlinePlayers()) {  
                         long login = loginConfig.getLong( p.getName() + ".logintime", -1);  
                         long elapsed = (now-login) / 1000;  
   
                         sb.append("<player>\n");  
                         sb.append("<name>" + p.getName() + "</name>\n" );  
                         sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );  
                         sb.append("</player>\n");  
                 }  
                 sb.append("</onlineplayers>");  
87    
88                    sb.append("<players>\n");
                 sb.append("<offlineplayers>\n");  
89                  OfflinePlayer playerList[] = server.getOfflinePlayers();                  OfflinePlayer playerList[] = server.getOfflinePlayers();
90                  for (OfflinePlayer player : playerList) {                  for (OfflinePlayer player : playerList) {
91                          long first = player.getFirstPlayed();                          long first = player.getFirstPlayed();
92                          long last = player.getLastPlayed();                              long last = player.getLastPlayed();    
93    
94                          sb.append("<offlineplayer>\n");  
95                            sb.append("<player>\n");
96                          sb.append("<name>" + player.getName() + "</name>\n" );                          sb.append("<name>" + player.getName() + "</name>\n" );
97    
98                          sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");                          sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");
99                          sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");                          sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");
                         sb.append("</offlineplayer>\n");  
                 }  
                 sb.append("</offlineplayers>\n");  
100    
101                            sb.append("<online>" + (player.isOnline() ? 1 : 0 )  + "</online>\n" );
102    
103                            if (player.isOnline() ) {              
104                                    long login = loginConfig.getLong( player.getName() + ".logintime", -1);
105                                    long elapsed = (login>-1 ? (now-login) / 1000 : -1);
106    
107                                    Player p2 = server.getPlayer( player.getName() );
108                                    Location loc = p2.getLocation();
109    
110                                    sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );
111                                    sb.append("<ip>" + p2.getAddress().getAddress().toString().replace("/","") + "</ip>\n" );
112                                    sb.append("<location>");
113                                    sb.append("<x>" + loc.getBlockX() + "</x>");
114                                    sb.append("<y>" + loc.getBlockY() + "</y>");
115                                    sb.append("<z>" + loc.getBlockZ() + "</z>");
116                                    sb.append("<world>" + loc.getWorld().getName() + "</world>");
117                                    sb.append("</location>");                      
118                            }
119    
120                            String homeWorld = homeConfig.getString( player.getName() + ".world");
121                            if (homeWorld != null) {
122                                    sb.append("<home>");
123                                    sb.append("<world>" + homeWorld + "</world>\n");
124                                    sb.append("<x>" + (int)homeConfig.getDouble(player.getName() + ".x") + "</x>\n");
125                                    sb.append("<y>" + (int)homeConfig.getDouble(player.getName() + ".y") + "</y>\n");
126                                    sb.append("<z>" + (int)homeConfig.getDouble(player.getName() + ".z") + "</z>\n");
127                                    sb.append("</home>");
128    
129                            }
130    
131    
132                            sb.append("</player>\n");
133                    }
134                    sb.append("</players>\n");
135                                                    
136                  sb.append("<plugins>\n");                  sb.append("<plugins>\n");
137                  for (Plugin plugin : server.getPluginManager().getPlugins()) {                  for (Plugin plugin : server.getPluginManager().getPlugins()) {
138    
139                          sb.append("<plugin>\n");                                  sb.append("<plugin>\n");        
140                          sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");                          sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");
141                          sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");                          sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");
142                            sb.append("<website>" + (plugin.getDescription().getWebsite() != null ? plugin.getDescription().getWebsite() : "") + "</website>\n");
143                          sb.append("</plugin>\n");                                sb.append("</plugin>\n");      
144                  }                  }
145                  sb.append("</plugins>\n");                  sb.append("</plugins>\n");
146                                                                                                                    
147                  sb.append("</serverinfo>");                                      sb.append("</serverinfo>");                    
148                  event.setResponse(sb.toString());  
149                  event.setActionTaken(true);                  return sb.toString();
150                                    
151          }          }
152    

Legend:
Removed from v.1667  
changed lines
  Added in v.1684

  ViewVC Help
Powered by ViewVC 1.1.20