/[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 1668 by torben, Thu Dec 22 11:25:17 2011 UTC miscJava/bukkit-minecraft-plugins/HoerupUtils/src/main/java/dk/thoerup/bukkit/hoeruputils/web/StatusListener.java revision 1695 by torben, Mon Feb 27 14:54:56 2012 UTC
# Line 5  import java.text.SimpleDateFormat; Line 5  import java.text.SimpleDateFormat;
5  import java.util.Date;  import java.util.Date;
6  import java.util.Set;  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.OfflinePlayer;  import org.bukkit.OfflinePlayer;
11  import org.bukkit.entity.Player;  import org.bukkit.entity.Player;
# Line 12  import org.bukkit.plugin.Plugin; Line 13  import org.bukkit.plugin.Plugin;
13    
14  import org.bukkit.configuration.Configuration;  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    import de.codeinfection.quickwango.ApiBukkit.ApiBukkit;
19    import de.codeinfection.quickwango.ApiBukkit.ApiServer.*;
20    
21  public class StatusListener extends ApiListener {  
22    @Controller( name = "webstatus", authenticate = false )
23    public class StatusListener extends ApiController {
24    
25          SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");          SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
26    
27          Server server;          Server server;
28          Configuration loginConfig;          Configuration loginConfig;
29            Configuration homeConfig;
30    
31            long cachedTime = 0;
32            String cachedXml = "";
33    
34            public StatusListener(Plugin plugin, Server server, Configuration loginConfig, Configuration homeConfig) {
35                    super(plugin);
36    
         public StatusListener(Server server, Configuration loginConfig) {  
37                  this.server = server;                  this.server = server;
38                  this.loginConfig = loginConfig;                          this.loginConfig = loginConfig;        
39                    this.homeConfig = homeConfig;
40          }          }
41    
42          String formatTime(String input) {          String formatTime(String input) {
# Line 36  public class StatusListener extends ApiL Line 48  public class StatusListener extends ApiL
48          }          }
49                    
50          @Override          @Override
51          public void onApiEvent(ApiEvent event) {          public void defaultAction(String action, ApiRequest request, ApiResponse response) {
52                  if(!event.path[0].equalsIgnoreCase("webstatus")) {  /*              if(!event.path[0].equalsIgnoreCase("webstatus")) {
53                          return;                          return;
54                    }*/
55    
56                    String xml;
57    
58                    synchronized(this) { //is this necessary ?
59                            long now = System.currentTimeMillis();
60                            if ( (now-cachedTime) > 5000) {
61                                    xml = buildXML();
62                                    cachedXml = xml;
63                                    cachedTime = now;
64                            } else {
65                                    xml = cachedXml;
66                            }
67                  }                  }
68                            
69    
70    /*              event.setResponse(xml);
71                    event.setActionTaken(true);*/
72    
73                    response.setContent( xml);
74            }
75            
76            private String buildXML() {
77    
78                  StringBuilder sb = new StringBuilder();                  StringBuilder sb = new StringBuilder();
79    
80                  sb.append("<?xml version=\"1.0\"?> \n");                  sb.append("<?xml version=\"1.0\"?> \n");
# Line 64  public class StatusListener extends ApiL Line 99  public class StatusListener extends ApiL
99                          long first = player.getFirstPlayed();                          long first = player.getFirstPlayed();
100                          long last = player.getLastPlayed();                              long last = player.getLastPlayed();    
101    
                         long login = loginConfig.getLong( player.getName() + ".logintime", -1);  
                         long elapsed = (login>-1 ? (now-login) / 1000 : -1);  
102    
103                          sb.append("<player>\n");                          sb.append("<player>\n");
104                          sb.append("<name>" + player.getName() + "</name>\n" );                          sb.append("<name>" + player.getName() + "</name>\n" );
                         sb.append("<online>" + (player.isOnline() ? 1 : 0 )  + "</online>\n" );  
                         sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );  
105    
106                          sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");                          sb.append("<firstseen>" + formatTime(first) + "</firstseen>\n");
107                          sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");                          sb.append("<lastseen>" + formatTime(last) + "</lastseen>\n");
108    
109                            sb.append("<online>" + (player.isOnline() ? 1 : 0 )  + "</online>\n" );
110    
111                            if (player.isOnline() ) {              
112                                    long login = loginConfig.getLong( player.getName() + ".logintime", -1);
113                                    long elapsed = (login>-1 ? (now-login) / 1000 : -1);
114    
115                                    Player p2 = server.getPlayer( player.getName() );
116                                    Location loc = p2.getLocation();
117    
118                                    sb.append("<sessionlength>" + elapsed + "</sessionlength>\n" );
119                                    sb.append("<ip>" + p2.getAddress().getAddress().toString().replace("/","") + "</ip>\n" );
120                                    sb.append("<location>");
121                                    sb.append("<x>" + loc.getBlockX() + "</x>");
122                                    sb.append("<y>" + loc.getBlockY() + "</y>");
123                                    sb.append("<z>" + loc.getBlockZ() + "</z>");
124                                    sb.append("<world>" + loc.getWorld().getName() + "</world>");
125                                    sb.append("</location>");                      
126                            }
127    
128                            String homeWorld = homeConfig.getString( player.getName() + ".world");
129                            if (homeWorld != null) {
130                                    sb.append("<home>");
131                                    sb.append("<world>" + homeWorld + "</world>\n");
132                                    sb.append("<x>" + (int)homeConfig.getDouble(player.getName() + ".x") + "</x>\n");
133                                    sb.append("<y>" + (int)homeConfig.getDouble(player.getName() + ".y") + "</y>\n");
134                                    sb.append("<z>" + (int)homeConfig.getDouble(player.getName() + ".z") + "</z>\n");
135                                    sb.append("</home>");
136    
137                            }
138    
139    
140                          sb.append("</player>\n");                          sb.append("</player>\n");
141                  }                  }
142                  sb.append("</players>\n");                  sb.append("</players>\n");
143                                                    
144                  sb.append("<plugins>\n");                  sb.append("<plugins>\n");
145                  for (Plugin plugin : server.getPluginManager().getPlugins()) {                  for (Plugin plugin : server.getPluginManager().getPlugins()) {
146    
147                          sb.append("<plugin>\n");                                  sb.append("<plugin>\n");        
148                          sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");                          sb.append("<name>" + plugin.getDescription().getName() + "</name>\n");
149                          sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");                          sb.append("<version>" + plugin.getDescription().getVersion() + "</version>\n");
150                            sb.append("<website>" + (plugin.getDescription().getWebsite() != null ? plugin.getDescription().getWebsite() : "") + "</website>\n");
151                          sb.append("</plugin>\n");                                sb.append("</plugin>\n");      
152                  }                  }
153                  sb.append("</plugins>\n");                  sb.append("</plugins>\n");
154                                                                                                                    
155                  sb.append("</serverinfo>");                                      sb.append("</serverinfo>");                    
156                  event.setResponse(sb.toString());  
157                  event.setActionTaken(true);                  return sb.toString();
158                                    
159          }          }
160    

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

  ViewVC Help
Powered by ViewVC 1.1.20