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

Legend:
Removed from v.1664  
changed lines
  Added in v.1935

  ViewVC Help
Powered by ViewVC 1.1.20