Commit 9e9493e4 authored by Axel Brand's avatar Axel Brand Committed by daeva

Gojara

- send messages for Gatewaystatistics on startup for all configured gateways.
- intercept & parse responses for Gatewaystatistics
- prevent away to online flag change from hitting db again, as user has not really logged in again

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@13701 b35dd754-fafc-0310-a699-88a17e54d16e
parent 7ad8dbd8
...@@ -60,6 +60,7 @@ public class RemoteRosterPlugin implements Plugin { ...@@ -60,6 +60,7 @@ public class RemoteRosterPlugin implements Plugin {
manageExternalComponents(); manageExternalComponents();
listenToSettings(); listenToSettings();
transportSessionManager.initializeSessions(); transportSessionManager.initializeSessions();
gojaraAdminManager.gatherGatewayStatistics();
Log.info("Started Gojara successfully. Currently running interceptors: "+iManager.getInterceptors().size()); Log.info("Started Gojara successfully. Currently running interceptors: "+iManager.getInterceptors().size());
} }
......
...@@ -28,12 +28,22 @@ public class GojaraAdminProcessor extends AbstractRemoteRosterProcessor { ...@@ -28,12 +28,22 @@ public class GojaraAdminProcessor extends AbstractRemoteRosterProcessor {
// handle different commands // handle different commands
Log.info("Intercepted something: " + message.toString()); Log.info("Intercepted something: " + message.toString());
String command = packet.getID(); String command = packet.getID();
if (command.equals("online_users")){ if (command.equals("online_users")) {
handleOnlineUsers(message, subdomain); handleOnlineUsers(message, subdomain);
} else if (command.equals("unregister")) { } else if (command.equals("unregister")) {
handleUnregister(message); handleUnregister(message);
} else if (command.equals("config_check")) { } else if (command.equals("config_check")) {
handleConfigCheck(subdomain); handleConfigCheck(subdomain);
} else if (command.equals("uptime")) {
handleStatistic(message, subdomain, "uptime");
} else if (command.equals("messages_from_xmpp")) {
handleStatistic(message, subdomain, "messages_from_xmpp");
} else if (command.equals("messags_to_xmpp")) {
handleStatistic(message, subdomain, "messages_to_xmpp");
} else if (command.equals("used_memory")) {
handleStatistic(message, subdomain, "used_memory");
} else if (command.equals("used_memory_per_user")) {
handleStatistic(message, subdomain, "used_memory_per_user");
} }
} }
...@@ -51,9 +61,21 @@ public class GojaraAdminProcessor extends AbstractRemoteRosterProcessor { ...@@ -51,9 +61,21 @@ public class GojaraAdminProcessor extends AbstractRemoteRosterProcessor {
private void handleUnregister(Message message) { private void handleUnregister(Message message) {
Log.info("Found unregister command! "); Log.info("Found unregister command! ");
} }
private void handleConfigCheck(String subdomain) { private void handleConfigCheck(String subdomain) {
gojaraAdminManager.confirmGatewayConfig(subdomain); gojaraAdminManager.confirmGatewayConfig(subdomain);
Log.info("Confirm config_check for " + subdomain); Log.info("Confirm config_check for " + subdomain);
} }
private void handleStatistic(Message message, String subdomain, String statistic) {
int result;
try {
result = Integer.parseInt(message.getBody());
} catch (Exception e) {
e.printStackTrace();
result = 0;
}
gojaraAdminManager.getGatewayStatisticsMap().get(subdomain).put(statistic, result);
}
} }
\ No newline at end of file
package org.jivesoftware.openfire.plugin.gojara.sessions; package org.jivesoftware.openfire.plugin.gojara.sessions;
import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
import java.util.Map;
import java.util.Set; import java.util.Set;
import org.jivesoftware.openfire.PacketRouter; import org.jivesoftware.openfire.PacketRouter;
...@@ -29,7 +31,9 @@ public class GojaraAdminManager { ...@@ -29,7 +31,9 @@ public class GojaraAdminManager {
private XMPPServer _server; private XMPPServer _server;
private Set<String> unconfiguredGateways; private Set<String> unconfiguredGateways;
private Set<String> configuredGateways; private Set<String> configuredGateways;
private boolean areGatewaysConfigured = true;
private Map<String, Map<String, Integer>> gatewayStatisticsMap;
private long refreshCooldown = 0;
private GojaraAdminManager() { private GojaraAdminManager() {
_server = XMPPServer.getInstance(); _server = XMPPServer.getInstance();
...@@ -44,6 +48,7 @@ public class GojaraAdminManager { ...@@ -44,6 +48,7 @@ public class GojaraAdminManager {
adminUser = _server.createJID("gojaraadmin", null); adminUser = _server.createJID("gojaraadmin", null);
unconfiguredGateways = new HashSet<String>(); unconfiguredGateways = new HashSet<String>();
configuredGateways = new HashSet<String>(); configuredGateways = new HashSet<String>();
setGatewayStatisticsMap(new HashMap<String, Map<String, Integer>>());
} }
public static GojaraAdminManager getInstance() { public static GojaraAdminManager getInstance() {
...@@ -67,8 +72,9 @@ public class GojaraAdminManager { ...@@ -67,8 +72,9 @@ public class GojaraAdminManager {
* *
*/ */
public void testAdminConfiguration(String gateway) { public void testAdminConfiguration(String gateway) {
areGatewaysConfigured = false;
unconfiguredGateways.add(gateway); unconfiguredGateways.add(gateway);
getGatewayStatisticsMap().put(gateway, new HashMap<String, Integer>());
Message message = new Message(); Message message = new Message();
message.setFrom(adminUser); message.setFrom(adminUser);
message.setTo(gateway); message.setTo(gateway);
...@@ -76,7 +82,7 @@ public class GojaraAdminManager { ...@@ -76,7 +82,7 @@ public class GojaraAdminManager {
message.setBody("status"); message.setBody("status");
message.setType(Type.chat); message.setType(Type.chat);
router.route(message); router.route(message);
Log.info("Sent config_check Packet!" + message.toString()); Log.info("Sent config_check Packet!");
} }
/** /**
...@@ -87,8 +93,6 @@ public class GojaraAdminManager { ...@@ -87,8 +93,6 @@ public class GojaraAdminManager {
public void confirmGatewayConfig(String gateway) { public void confirmGatewayConfig(String gateway) {
unconfiguredGateways.remove(gateway); unconfiguredGateways.remove(gateway);
configuredGateways.add(gateway); configuredGateways.add(gateway);
if (unconfiguredGateways.isEmpty())
areGatewaysConfigured = true;
} }
/** /**
...@@ -96,20 +100,37 @@ public class GojaraAdminManager { ...@@ -96,20 +100,37 @@ public class GojaraAdminManager {
* areGatewaysConfigured. * areGatewaysConfigured.
*/ */
public void gatewayUnregistered(String gateway) { public void gatewayUnregistered(String gateway) {
unconfiguredGateways.remove(gateway); unconfiguredGateways.remove(gateway);
configuredGateways.remove(gateway); configuredGateways.remove(gateway);
if (unconfiguredGateways.isEmpty()) getGatewayStatisticsMap().remove(gateway);
areGatewaysConfigured = true;
} }
public boolean areGatewaysConfigured() { public boolean areGatewaysConfigured() {
return areGatewaysConfigured; return unconfiguredGateways.isEmpty();
} }
public boolean isGatewayConfigured(String gateway) { public boolean isGatewayConfigured(String gateway) {
return configuredGateways.contains(gateway); return configuredGateways.contains(gateway);
} }
/**
* Generates a basic ad-hoc command with From,To, Type, ID & Body configured. Body might need to be reconfigured
* when additional info has to be specified, like unregister
*
* @param transport
* @param command
* @return
*/
private Message generateCommand(String transport, String command) {
Message message = new Message();
message.setFrom(adminUser);
message.setTo(transport);
message.setID(command);
message.setBody(command);
message.setType(Type.chat);
return message;
}
/** /**
* Sends the command online_users to specified Spectrum2 transport. We set the ID specific to the command so we can * Sends the command online_users to specified Spectrum2 transport. We set the ID specific to the command so we can
* identify the response. Transport has to be configured for admin_jid = gojaraadmin@domain * identify the response. Transport has to be configured for admin_jid = gojaraadmin@domain
...@@ -121,12 +142,7 @@ public class GojaraAdminManager { ...@@ -121,12 +142,7 @@ public class GojaraAdminManager {
if (unconfiguredGateways.contains(transport)) if (unconfiguredGateways.contains(transport))
return; return;
Message message = new Message(); Message message = generateCommand(transport, "online_users");
message.setFrom(adminUser);
message.setTo(transport);
message.setID("online_users");
message.setBody("online_users");
message.setType(Type.chat);
router.route(message); router.route(message);
Log.info("Sent online_users Packet!" + message.toString()); Log.info("Sent online_users Packet!" + message.toString());
} }
...@@ -141,14 +157,63 @@ public class GojaraAdminManager { ...@@ -141,14 +157,63 @@ public class GojaraAdminManager {
if (unconfiguredGateways.contains(transport)) if (unconfiguredGateways.contains(transport))
return; return;
Message message = new Message(); Message message = generateCommand(transport, "unregister");
message.setFrom(adminUser);
message.setTo(transport);
message.setID("unregister");
message.setBody("unregister " + _server.createJID(user, null).toString()); message.setBody("unregister " + _server.createJID(user, null).toString());
message.setType(Type.chat);
router.route(message); router.route(message);
Log.info("Sent Unregister Packet!" + message.toString()); Log.info("Sent Unregister Packet!" + message.toString());
} }
public Map<String, Map<String, Integer>> getGatewayStatisticsMap() {
return gatewayStatisticsMap;
}
public void setGatewayStatisticsMap(Map<String, Map<String, Integer>> gatewayStatisticsMap) {
this.gatewayStatisticsMap = gatewayStatisticsMap;
}
public void gatherGatewayStatistics() {
if (refreshCooldown == 0) {
refreshCooldown = System.currentTimeMillis();
} else {
// once a minute max
if ((System.currentTimeMillis() - refreshCooldown) < 60000)
return;
}
refreshCooldown = System.currentTimeMillis();
for (String gateway : configuredGateways) {
uptime(gateway);
messagesFrom(gateway);
messagesTo(gateway);
usedMemoryOf(gateway);
averageMemoryOfUser(gateway);
}
}
private void uptime(String transport) {
Message message = generateCommand(transport, "uptime");
router.route(message);
}
private void messagesFrom(String transport) {
Message message = generateCommand(transport, "messages_from_xmpp");
router.route(message);
}
private void messagesTo(String transport) {
Message message = generateCommand(transport, "messages_to_xmpp");
router.route(message);
}
private void usedMemoryOf(String transport) {
Message message = generateCommand(transport, "used_memory");
router.route(message);
}
private void averageMemoryOfUser(String transport) {
Message message = generateCommand(transport, "average_memory_per_user");
router.route(message);
}
} }
...@@ -86,7 +86,8 @@ public class TransportSessionManager { ...@@ -86,7 +86,8 @@ public class TransportSessionManager {
* @return * @return
*/ */
public boolean connectUserTo(String transport, String user) { public boolean connectUserTo(String transport, String user) {
if (transportSessions.get(transport) != null) { //dont update if user is already present, else lots of away to online changes might be spammed
if (transportSessions.get(transport) != null && transportSessions.get(transport).get(user) == null) {
long millis = System.currentTimeMillis(); long millis = System.currentTimeMillis();
transportSessions.get(transport).put(user, millis); transportSessions.get(transport).put(user, millis);
db.insertOrUpdateSession(transport, user, millis); db.insertOrUpdateSession(transport, user, millis);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment