/[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

revision 1664 by torben, Wed Dec 21 09:43:48 2011 UTC revision 1668 by torben, Thu Dec 22 11:25:17 2011 UTC
# Line 10  import org.bukkit.OfflinePlayer; Line 10  import org.bukkit.OfflinePlayer;
10  import org.bukkit.entity.Player;  import org.bukkit.entity.Player;
11  import org.bukkit.plugin.Plugin;  import org.bukkit.plugin.Plugin;
12    
13  import org.bukkit.configuration.file.YamlConfiguration;  import org.bukkit.configuration.Configuration;
14    
15  import org.kokakiwi.apicraft.events.ApiEvent;  import org.kokakiwi.apicraft.events.ApiEvent;
16  import org.kokakiwi.apicraft.events.ApiListener;  import org.kokakiwi.apicraft.events.ApiListener;
# Line 20  public class StatusListener extends ApiL Line 20  public class StatusListener extends ApiL
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;            
25            public StatusListener(Server server, Configuration loginConfig) {
26                    this.server = server;
27                    this.loginConfig = loginConfig;        
28          }          }
29    
30          String formatTime(String input) {          String formatTime(String input) {
# Line 34  public class StatusListener extends ApiL Line 37  public class StatusListener extends ApiL
37                    
38          @Override          @Override
39          public void onApiEvent(ApiEvent event) {          public void onApiEvent(ApiEvent event) {
40                  if(event.path[0].equalsIgnoreCase("webstatus")) {                  if(!event.path[0].equalsIgnoreCase("webstatus")) {
41                          StringBuilder sb = new StringBuilder();                          return;
42                                            }
43                          //out.writeBytes("Server:  " + server.getServerName() + "\n");                  StringBuilder sb = new StringBuilder();
44                          sb.append("Version: " + server.getVersion() + "\n");  
45                    sb.append("<?xml version=\"1.0\"?> \n");
46                    sb.append("<serverinfo>");                      
47    
48                    sb.append("<version>" + server.getVersion() + "</version>\n");
49    
50                    long mb = 1024*1024;
51                    Runtime rt = Runtime.getRuntime();
52                    sb.append("<memory>\n");
53                    sb.append("<free>" + rt.freeMemory()/mb + "</free>\n");
54                    sb.append("<total>" + rt.totalMemory()/mb + "</total>\n");
55                    sb.append("<max>" + rt.maxMemory()/mb + "</max>\n");
56                    sb.append("</memory>\n");
57    
                         long mb = 1024*1024;  
                         Runtime rt = Runtime.getRuntime();  
                         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()) {  
58    
59                                  sb.append( p.getName() );                  long now = System.currentTimeMillis();
                         }  
                         sb.append("\n");  
   
                         sb.append("--- Last seen players/offline ---\n");  
 /*  
                         File configFile = new File("./plugins/LastSeen/times.yml");  
                         if (configFile.exists() ) {  
   
                                 YamlConfiguration config = new YamlConfiguration();  
                                 try {  
                                         config.load(configFile);  
                                 } catch (Exception e) {  
                                         event.setResponse(e.toString() );  
                                         event.setActionTaken(true);  
                                         return;                          
                                 }  
   
                                 Set<String> keys = config.getKeys(false);  
                                 if (keys != null) {  
                                         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");  
                         }  
                         sb.append("\n");*/  
                         OfflinePlayer playerList[] = server.getOfflinePlayers();  
                         for (OfflinePlayer player : playerList) {  
                                 //long first = p.getFirstPlayed();  
   
                                 long last = player.getLastPlayed();      
                                 sb.append(player.getName() + ": " + formatTime(last) + "\n");  
                         }  
60    
61                    sb.append("<players>\n");
62                    OfflinePlayer playerList[] = server.getOfflinePlayers();
63                    for (OfflinePlayer player : playerList) {
64                            long first = player.getFirstPlayed();
65                            long last = player.getLastPlayed();    
66    
67                            long login = loginConfig.getLong( player.getName() + ".logintime", -1);
68                            long elapsed = (login>-1 ? (now-login) / 1000 : -1);
69    
70                            sb.append("<player>\n");
71                            sb.append("<name>" + player.getName() + "</name>\n" );
72                            sb.append("<online>" + (player.isOnline() ? 1 : 0 )  + "</online>\n" );
73                            sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );
74    
75                            sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");
76                            sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");
77                            sb.append("</player>\n");
78                    }
79                    sb.append("</players>\n");
80                                                    
81                          sb.append("--- Plugins ---\n");                  sb.append("<plugins>\n");
82                          for (Plugin plugin : server.getPluginManager().getPlugins()) {                  for (Plugin plugin : server.getPluginManager().getPlugins()) {
83                                  sb.append( plugin.getDescription().getName() + " " + plugin.getDescription().getVersion() + "\n");                          sb.append("<plugin>\n");        
84                          }                          sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");
85                                                                                    sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");
86                          event.setResponse(sb.toString());                          sb.append("</plugin>\n");      
                         event.setActionTaken(true);  
87                  }                  }
88                    sb.append("</plugins>\n");
89                                                            
90                    sb.append("</serverinfo>");                    
91                    event.setResponse(sb.toString());
92                    event.setActionTaken(true);
93                    
94          }          }
95    
96  }  }

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

  ViewVC Help
Powered by ViewVC 1.1.20