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

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

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

revision 1495 by torben, Fri Jun 3 11:29:38 2011 UTC revision 1667 by torben, Wed Dec 21 19:19:02 2011 UTC
# Line 3  package dk.thoerup.bukkit.hoeruputils.we Line 3  package dk.thoerup.bukkit.hoeruputils.we
3  import java.io.File;  import java.io.File;
4  import java.text.SimpleDateFormat;  import java.text.SimpleDateFormat;
5  import java.util.Date;  import java.util.Date;
6  import java.util.List;  import java.util.Set;
7  import java.util.Map;  import java.util.Map;
8  import org.bukkit.Server;  import org.bukkit.Server;
9  import org.bukkit.util.config.ConfigurationNode;  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  import org.bukkit.util.config.Configuration;  
13    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;
17    
# Line 18  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) {
31                  Date d = new Date( Long.parseLong(input) );                  return formatTime( Long.parseLong(input) );
32            }
33            String formatTime(long input) {
34                    Date d = new Date( input );
35                  return format.format(d );                  return format.format(d );
36          }          }
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\n");  
45                                            sb.append("<?xml version=\"1.0\"?> \n");
46                          sb.append("--- Online players ---\n");                  sb.append("<serverinfo>");                      
47                          for (Player p : server.getOnlinePlayers()) {                              
48                                  sb.append( p.getName() + "\n");                  sb.append("<version>" + server.getVersion() + "</version>\n");
49                          }  
50                    long mb = 1024*1024;
51                          sb.append("--- Last seen players/offline ---\n");                  Runtime rt = Runtime.getRuntime();
52                          File configFile = new File("./plugins/LastSeen/times.yml");                  sb.append("<memory>\n");
53                          if (configFile.exists() ) {                  sb.append("<free>" + rt.freeMemory()/mb + "</free>\n");
54                                  Configuration config = new Configuration(configFile);                  sb.append("<total>" + rt.totalMemory()/mb + "</total>\n");
55                                  config.load();                  sb.append("<max>" + rt.maxMemory()/mb + "</max>\n");
56                    sb.append("</memory>\n");
57                                  List<String> keys = config.getKeys(null);  
58                                  if (keys != null) {  
59                                          for (String key : keys) {                  long now = System.currentTimeMillis();
60                                                  if (server.getPlayer(key) != null) // player is online                  sb.append("<onlineplayers>\n");                
61                                                          continue;                  for (Player p : server.getOnlinePlayers()) {
62                            long login = loginConfig.getLong( p.getName() + ".logintime", -1);
63                                                  String last = config.getString( key + ".logout");                                long elapsed = (now-login) / 1000;
64                                                  sb.append("" + key + ": " + formatTime(last) + "\n") ;  
65                                          }                          sb.append("<player>\n");
66                                  } else {                          sb.append("<name>" + p.getName() + "</name>\n" );
67                                          sb.append("no players found\n");                          sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );
68                                  }                          sb.append("</player>\n");
69                          } else {                  }
70                                  sb.append("could not find LastSeen/times.yml\n");                  sb.append("</onlineplayers>");
71                          }  
72                            
73                    sb.append("<offlineplayers>\n");
74                    OfflinePlayer playerList[] = server.getOfflinePlayers();
75                    for (OfflinePlayer player : playerList) {
76                            long first = player.getFirstPlayed();
77                            long last = player.getLastPlayed();    
78    
79                            sb.append("<offlineplayer>\n");
80                            sb.append("<name>" + player.getName() + "</name>\n" );
81                            sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");
82                            sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");
83                            sb.append("</offlineplayer>\n");
84                    }
85                    sb.append("</offlineplayers>\n");
86    
87                                                    
88                          sb.append("--- Plugins ---\n");                  sb.append("<plugins>\n");
89                          for (Plugin plugin : server.getPluginManager().getPlugins()) {                  for (Plugin plugin : server.getPluginManager().getPlugins()) {
90                                  sb.append( plugin.getDescription().getName() + " " + plugin.getDescription().getVersion() + "\n");                          sb.append("<plugin>\n");        
91                          }                          sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");
92                                                                                    sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");
93                          event.setResponse(sb.toString());                          sb.append("</plugin>\n");      
                         event.setActionTaken(true);  
94                  }                  }
95                    sb.append("</plugins>\n");
96                                                            
97                    sb.append("</serverinfo>");                    
98                    event.setResponse(sb.toString());
99                    event.setActionTaken(true);
100                    
101          }          }
102    
103  }  }

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

  ViewVC Help
Powered by ViewVC 1.1.20