/[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 1497 by torben, Sat Jun 4 07:50:14 2011 UTC revision 1670 by torben, Thu Dec 22 14:45:38 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.Location;
9  import org.bukkit.Server;  import org.bukkit.Server;
10  import org.bukkit.util.config.ConfigurationNode;  import org.bukkit.OfflinePlayer;
11  import org.bukkit.entity.Player;  import org.bukkit.entity.Player;
12  import org.bukkit.plugin.Plugin;  import org.bukkit.plugin.Plugin;
13  import org.bukkit.util.config.Configuration;  
14    import org.bukkit.configuration.Configuration;
15    
16  import org.kokakiwi.apicraft.events.ApiEvent;  import org.kokakiwi.apicraft.events.ApiEvent;
17  import org.kokakiwi.apicraft.events.ApiListener;  import org.kokakiwi.apicraft.events.ApiListener;
18    
# Line 18  public class StatusListener extends ApiL Line 21  public class StatusListener extends ApiL
21          SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");          SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
22    
23          Server server;          Server server;
24          public StatusListener(Server server) {          Configuration loginConfig;
25                  this.server = server;            
26            public StatusListener(Server server, Configuration loginConfig) {
27                    this.server = server;
28                    this.loginConfig = loginConfig;        
29          }          }
30    
31          String formatTime(String input) {          String formatTime(String input) {
32                  Date d = new Date( Long.parseLong(input) );                  return formatTime( Long.parseLong(input) );
33            }
34            String formatTime(long input) {
35                    Date d = new Date( input );
36                  return format.format(d );                  return format.format(d );
37          }          }
38                    
39          @Override          @Override
40          public void onApiEvent(ApiEvent event) {          public void onApiEvent(ApiEvent event) {
41                  if(event.path[0].equalsIgnoreCase("webstatus")) {                  if(!event.path[0].equalsIgnoreCase("webstatus")) {
42                          StringBuilder sb = new StringBuilder();                          return;
43                                            }
44                          //out.writeBytes("Server:  " + server.getServerName() + "\n");                  StringBuilder sb = new StringBuilder();
45                          sb.append("Version: " + server.getVersion() + "\n\n");  
46                    sb.append("<?xml version=\"1.0\"?> \n");
47                    sb.append("<serverinfo>");                      
48    
49                    sb.append("<version>" + server.getVersion() + "</version>\n");
50    
51                    long mb = 1024*1024;
52                    Runtime rt = Runtime.getRuntime();
53                    sb.append("<memory>\n");
54                    sb.append("<free>" + rt.freeMemory()/mb + "</free>\n");
55                    sb.append("<total>" + rt.totalMemory()/mb + "</total>\n");
56                    sb.append("<max>" + rt.maxMemory()/mb + "</max>\n");
57                    sb.append("</memory>\n");
58    
59    
60                    long now = System.currentTimeMillis();
61    
62                    sb.append("<players>\n");
63                    OfflinePlayer playerList[] = server.getOfflinePlayers();
64                    for (OfflinePlayer player : playerList) {
65                            long first = player.getFirstPlayed();
66                            long last = player.getLastPlayed();    
67    
68    
69                            sb.append("<player>\n");
70                            sb.append("<name>" + player.getName() + "</name>\n" );
71    
72                            sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");
73                            sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");
74    
75                            sb.append("<online>" + (player.isOnline() ? 1 : 0 )  + "</online>\n" );
76    
77                            if (player.isOnline() ) {              
78                                    long login = loginConfig.getLong( player.getName() + ".logintime", -1);
79                                    long elapsed = (login>-1 ? (now-login) / 1000 : -1);
80    
81                                    Player p2 = server.getPlayer( player.getName() );
82                                    Location loc = p2.getLocation();
83    
84                                    sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );
85                                    sb.append("<ip>" + p2.getAddress().getAddress().toString().replace("/","") + "</ip>\n" );
86                                    sb.append("<location>");
87                                    sb.append("<x>" + loc.getBlockX() + "</x>");
88                                    sb.append("<y>" + loc.getBlockY() + "</y>");
89                                    sb.append("<z>" + loc.getBlockZ() + "</z>");
90                                    sb.append("<world>" + loc.getWorld().getName() + "</world>");
91                                    sb.append("</location>");
92                                                    
                         sb.append("--- Online players ---\n");  
                         for (Player p : server.getOnlinePlayers()) {                              
                                 sb.append( p.getName() + "\n");  
93                          }                          }
                         sb.append("\n");  
94    
                         sb.append("--- Last seen players/offline ---\n");  
                         File configFile = new File("./plugins/LastSeen/times.yml");  
                         if (configFile.exists() ) {  
                                 Configuration config = new Configuration(configFile);  
                                 config.load();  
   
                                 List<String> keys = config.getKeys(null);  
                                 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");  
95    
96                            sb.append("</player>\n");
97                    }
98                    sb.append("</players>\n");
99                                                    
100                          sb.append("--- Plugins ---\n");                  sb.append("<plugins>\n");
101                          for (Plugin plugin : server.getPluginManager().getPlugins()) {                  for (Plugin plugin : server.getPluginManager().getPlugins()) {
102                                  sb.append( plugin.getDescription().getName() + " " + plugin.getDescription().getVersion() + "\n");  
103                          }                          sb.append("<plugin>\n");        
104                                                                                    sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");
105                          event.setResponse(sb.toString());                          sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");
106                          event.setActionTaken(true);                          sb.append("<website>" + (plugin.getDescription().getWebsite() != null ? plugin.getDescription().getWebsite() : "") + "</website>\n");
107                            sb.append("</plugin>\n");      
108                  }                  }
109                    sb.append("</plugins>\n");
110                                                            
111                    sb.append("</serverinfo>");                    
112                    event.setResponse(sb.toString());
113                    event.setActionTaken(true);
114                    
115          }          }
116    
117  }  }

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

  ViewVC Help
Powered by ViewVC 1.1.20