/[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 1497 by torben, Sat Jun 4 07:50:14 2011 UTC miscJava/bukkit-minecraft-plugins/HoerupUtils/src/main/java/dk/thoerup/bukkit/hoeruputils/web/StatusListener.java revision 1938 by torben, Wed Mar 20 15:10:54 2013 UTC
# Line 1  Line 1 
1  package dk.thoerup.bukkit.hoeruputils.web;  package dk.thoerup.bukkit.hoeruputils.web;
2    
3  import java.io.File;  import java.io.IOException;
4    import java.io.OutputStream;
5    import java.net.HttpURLConnection;
6  import java.text.SimpleDateFormat;  import java.text.SimpleDateFormat;
7  import java.util.Date;  import java.util.Date;
8  import java.util.List;  
9  import java.util.Map;  import org.bukkit.Location;
10    import org.bukkit.OfflinePlayer;
11  import org.bukkit.Server;  import org.bukkit.Server;
12  import org.bukkit.util.config.ConfigurationNode;  import org.bukkit.configuration.Configuration;
13  import org.bukkit.entity.Player;  import org.bukkit.entity.Player;
14  import org.bukkit.plugin.Plugin;  import org.bukkit.plugin.Plugin;
 import org.bukkit.util.config.Configuration;  
 import org.kokakiwi.apicraft.events.ApiEvent;  
 import org.kokakiwi.apicraft.events.ApiListener;  
15    
16  public class StatusListener extends ApiListener {  import com.sun.net.httpserver.HttpExchange;
17    import com.sun.net.httpserver.HttpHandler;
18    
19    
20    public class StatusListener implements HttpHandler{
21    
22          SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");          SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
23    
24          Server server;          Server server;
25          public StatusListener(Server server) {          Configuration loginConfig;
26                  this.server = server;                    Configuration homeConfig;
27    
28            long cachedTime = 0;
29            String cachedXml = "";
30    
31            public StatusListener(Plugin plugin, Server server, Configuration loginConfig, Configuration homeConfig) {
32    
33                    this.server = server;
34                    this.loginConfig = loginConfig;        
35                    this.homeConfig = homeConfig;
36          }          }
37    
38          String formatTime(String input) {          String formatTime(String input) {
39                  Date d = new Date( Long.parseLong(input) );                  return formatTime( Long.parseLong(input) );
40            }
41            String formatTime(long input) {
42                    Date d = new Date( input );
43                  return format.format(d );                  return format.format(d );
44          }          }
45                    
46          @Override          @Override
47          public void onApiEvent(ApiEvent event) {          public void handle(HttpExchange http) throws IOException {              
48                  if(event.path[0].equalsIgnoreCase("webstatus")) {  /*              if(!event.path[0].equalsIgnoreCase("webstatus")) {
49                          StringBuilder sb = new StringBuilder();                          return;
50                                            }*/
51                          //out.writeBytes("Server:  " + server.getServerName() + "\n");  
52                          sb.append("Version: " + server.getVersion() + "\n\n");                  String xml;
53    
54                    synchronized(this) { //is this necessary ?
55                            long now = System.currentTimeMillis();
56                            if ( (now-cachedTime) > 5000) {
57                                    xml = buildXML();
58                                    cachedXml = xml;
59                                    cachedTime = now;
60                            } else {
61                                    xml = cachedXml;
62                            }
63                    }
64                                                    
65                          sb.append("--- Online players ---\n");  
66                          for (Player p : server.getOnlinePlayers()) {                              /*              event.setResponse(xml);
67                                  sb.append( p.getName() + "\n");                  event.setActionTaken(true);*/
68                    byte bytes[] = xml.getBytes();
69                    http.sendResponseHeaders(HttpURLConnection.HTTP_OK, bytes.length );
70                    final OutputStream os = http.getResponseBody();
71                    os.write(bytes);
72                    os.close();
73            }
74            
75            private String buildXML() {
76    
77                    StringBuilder sb = new StringBuilder();
78    
79                    sb.append("<?xml version=\"1.0\"?> \n");
80                    sb.append("<serverinfo>");                      
81    
82                    sb.append("<version>" + server.getVersion() + "</version>\n");
83    
84                    long mb = 1024*1024;
85                    Runtime rt = Runtime.getRuntime();
86                    sb.append("<memory>\n");
87                    sb.append("<free>" + rt.freeMemory()/mb + "</free>\n");
88                    sb.append("<total>" + rt.totalMemory()/mb + "</total>\n");
89                    sb.append("<max>" + rt.maxMemory()/mb + "</max>\n");
90                    sb.append("</memory>\n");
91    
92    
93                    long now = System.currentTimeMillis();
94    
95                    sb.append("<players>\n");
96                    OfflinePlayer playerList[] = server.getOfflinePlayers();
97                    for (OfflinePlayer player : playerList) {
98                            long first = player.getFirstPlayed();
99                            long last = player.getLastPlayed();    
100    
101    
102                            sb.append("<player>\n");
103                            sb.append("<name>" + player.getName() + "</name>\n" );
104    
105                            sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");
106                            sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");
107    
108                            sb.append("<online>" + (player.isOnline() ? 1 : 0 )  + "</online>\n" );
109    
110                            if (player.isOnline() ) {              
111                                    long login = loginConfig.getLong( player.getName() + ".logintime", -1);
112                                    long elapsed = (login>-1 ? (now-login) / 1000 : -1);
113    
114                                    Player p2 = server.getPlayer( player.getName() );
115                                    Location loc = p2.getLocation();
116    
117                                    sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );
118                                    sb.append("<ip>" + p2.getAddress().getAddress().toString().replace("/","") + "</ip>\n" );
119                                    sb.append("<location>");
120                                    sb.append("<x>" + loc.getBlockX() + "</x>");
121                                    sb.append("<y>" + loc.getBlockY() + "</y>");
122                                    sb.append("<z>" + loc.getBlockZ() + "</z>");
123                                    sb.append("<world>" + loc.getWorld().getName() + "</world>");
124                                    sb.append("</location>");                      
125                          }                          }
                         sb.append("\n");  
126    
127                          sb.append("--- Last seen players/offline ---\n");                          String homeWorld = homeConfig.getString( player.getName() + ".world");
128                          File configFile = new File("./plugins/LastSeen/times.yml");                          if (homeWorld != null) {
129                          if (configFile.exists() ) {                                  sb.append("<home>");
130                                  Configuration config = new Configuration(configFile);                                  sb.append("<world>" + homeWorld + "</world>\n");
131                                  config.load();                                  sb.append("<x>" + (int)homeConfig.getDouble(player.getName() + ".x") + "</x>\n");
132                                    sb.append("<y>" + (int)homeConfig.getDouble(player.getName() + ".y") + "</y>\n");
133                                  List<String> keys = config.getKeys(null);                                  sb.append("<z>" + (int)homeConfig.getDouble(player.getName() + ".z") + "</z>\n");
134                                  if (keys != null) {                                  sb.append("</home>");
135                                          for (String key : keys) {  
                                                 if (server.getPlayer(key) != null) // player is online  
                                                         continue;  
   
                                                 String last = config.getString( key + ".logout");        
                                                 sb.append("" + key + ": " + formatTime(last) + "\n") ;  
                                         }  
                                 } else {  
                                         sb.append("no players found\n");  
                                 }  
                         } else {  
                                 sb.append("could not find LastSeen/times.yml\n");  
136                          }                          }
                         sb.append("\n");  
137    
138    
139                            sb.append("</player>\n");
140                    }
141                    sb.append("</players>\n");
142                                                    
143                          sb.append("--- Plugins ---\n");                  sb.append("<plugins>\n");
144                          for (Plugin plugin : server.getPluginManager().getPlugins()) {                  for (Plugin plugin : server.getPluginManager().getPlugins()) {
145                                  sb.append( plugin.getDescription().getName() + " " + plugin.getDescription().getVersion() + "\n");  
146                          }                          sb.append("<plugin>\n");        
147                                                                                    sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");
148                          event.setResponse(sb.toString());                          sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");
149                          event.setActionTaken(true);                          sb.append("<website>" + (plugin.getDescription().getWebsite() != null ? plugin.getDescription().getWebsite() : "") + "</website>\n");
150                            sb.append("</plugin>\n");      
151                  }                  }
152                    sb.append("</plugins>\n");
153                                                            
154                    sb.append("</serverinfo>");                    
155    
156                    return sb.toString();
157                    
158          }          }
159    
160  }  }

Legend:
Removed from v.1497  
changed lines
  Added in v.1938

  ViewVC Help
Powered by ViewVC 1.1.20