Commit 95ef5198 authored by Daniel Henninger's avatar Daniel Henninger Committed by dhenninger

Fixed calls to clearspace and cleaned up manager.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/branches@9973 b35dd754-fafc-0310-a699-88a17e54d16e
parent 516e319f
...@@ -272,7 +272,9 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -272,7 +272,9 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
String path = ClearspaceAuthProvider.URL_PREFIX + "authenticate/" + username + "/" + password; String path = ClearspaceAuthProvider.URL_PREFIX + "authenticate/" + username + "/" + password;
executeRequest(GET, path); executeRequest(GET, path);
return true; return true;
} catch (Exception e) {} } catch (Exception e) {
// Nothing to do.
}
return false; return false;
} }
...@@ -287,9 +289,11 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -287,9 +289,11 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
try { try {
String path = ClearspaceUserProvider.USER_URL_PREFIX + "users/count"; String path = ClearspaceUserProvider.USER_URL_PREFIX + "users/count";
Element element = executeRequest(GET, path); Element element = executeRequest(GET, path);
int count = Integer.valueOf(getReturn(element)); getReturn(element);
return true; return true;
} catch (Exception e) {} } catch (Exception e) {
// Nothing to do.
}
return false; return false;
} }
...@@ -410,26 +414,28 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -410,26 +414,28 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
private synchronized void configClearspace() throws UnauthorizedException { private synchronized void configClearspace() throws UnauthorizedException {
try { try {
List<String> bindInterfaces = getServerInterfaces();
if (bindInterfaces.size() == 0) {
// We aren't up and running enough to tell Clearspace what interfaces to bind to.
return;
}
XMPPServerInfo serverInfo = XMPPServer.getInstance().getServerInfo(); XMPPServerInfo serverInfo = XMPPServer.getInstance().getServerInfo();
// TODO use the post method // TODO: Eventually we would like to get POST support working properly.
// Creates the XML with the data // String path = IM_URL_PREFIX + "configureComponent/";
/** //
Document groupDoc = DocumentHelper.createDocument(); // // Creates the XML with the data
Element rootE = groupDoc.addElement("connect"); // Document groupDoc = DocumentHelper.createDocument();
Element domainE = rootE.addElement("domain"); // Element rootE = groupDoc.addElement("configureComponent");
domainE.setText(serverInfo.getXMPPDomain()); // Element domainE = rootE.addElement("domain");
Element hostsE = rootE.addElement("hosts"); // domainE.setText(serverInfo.getXMPPDomain());
List<String> bindInterfaces = getServerInterfaces(); // Element hostsE = rootE.addElement("hosts");
hostsE.setText("127.0.0.1"); // hostsE.setText(WSUtils.marshallList(bindInterfaces));
Element portE = rootE.addElement("port"); // Element portE = rootE.addElement("port");
portE.setText(String.valueOf(ExternalComponentManager.getServicePort())); // portE.setText(String.valueOf(ExternalComponentManager.getServicePort()));
//
executeRequest(POST, path, rootE.asXML()); // executeRequest(POST, path, rootE.asXML());
*/
List<String> bindInterfaces = getServerInterfaces();
String path = IM_URL_PREFIX + "configureComponent/" + serverInfo.getXMPPDomain() + String path = IM_URL_PREFIX + "configureComponent/" + serverInfo.getXMPPDomain() +
"/" + WSUtils.marshallList(bindInterfaces) + "/" + WSUtils.marshallList(bindInterfaces) +
...@@ -465,19 +471,17 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -465,19 +471,17 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
int adminSecurePort = JiveGlobals.getXMLProperty("adminConsole.securePort", 9091); int adminSecurePort = JiveGlobals.getXMLProperty("adminConsole.securePort", 9091);
if (bindInterface == null) { if (bindInterface == null) {
Enumeration<NetworkInterface> nets = null;
try { try {
nets = NetworkInterface.getNetworkInterfaces(); Enumeration<NetworkInterface> nets = NetworkInterface.getNetworkInterfaces();
} catch (SocketException e) {
// We failed to discover a valid IP address where the admin console is running
return null;
}
for (NetworkInterface netInterface : Collections.list(nets)) { for (NetworkInterface netInterface : Collections.list(nets)) {
Enumeration<InetAddress> addresses = netInterface.getInetAddresses(); Enumeration<InetAddress> addresses = netInterface.getInetAddresses();
for (InetAddress address : Collections.list(addresses)) { for (InetAddress address : Collections.list(addresses)) {
if ("127.0.0.1".equals(address.getHostAddress())) { if ("127.0.0.1".equals(address.getHostAddress())) {
continue; continue;
} }
if (address.getHostAddress().startsWith("0.")) {
continue;
}
Socket socket = new Socket(); Socket socket = new Socket();
InetSocketAddress remoteAddress = new InetSocketAddress(address, adminPort > 0 ? adminPort : adminSecurePort); InetSocketAddress remoteAddress = new InetSocketAddress(address, adminPort > 0 ? adminPort : adminSecurePort);
try { try {
...@@ -489,6 +493,10 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -489,6 +493,10 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
} }
} }
} }
} catch (SocketException e) {
// We failed to discover a valid IP address where the admin console is running
return null;
}
} }
return bindInterfaces; return bindInterfaces;
} }
...@@ -496,24 +504,23 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -496,24 +504,23 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
private void updateClearspaceSharedSecret(String newSecret) { private void updateClearspaceSharedSecret(String newSecret) {
try { try {
// Keeping this around for the moment just in case.
String path = IM_URL_PREFIX + "updateSharedSecret/" + newSecret; String path = IM_URL_PREFIX + "updateSharedSecret/" + newSecret;
executeRequest(GET, path); executeRequest(GET, path);
//TODO use the post method // TODO: We should switch to POST once we figure out why it's not behaving.
/* // String path = IM_URL_PREFIX + "updateSharedSecret/";
// Creates the XML with the data //
Document groupDoc = DocumentHelper.createDocument(); // // Creates the XML with the data
Element rootE = groupDoc.addElement("updateSharedSecret"); // Document groupDoc = DocumentHelper.createDocument();
rootE.addElement("newSecret").setText(newSecret // Element rootE = groupDoc.addElement("updateSharedSecret");
); // rootE.addElement("newSecret").setText(newSecret);
//
executeRequest(POST, path, groupDoc.asXML()); // executeRequest(POST, path, groupDoc.asXML());
*/
} catch (UnauthorizedException ue) { } catch (UnauthorizedException ue) {
// TODO what should happen here? should continue? // TODO: what should happen here? should continue?
} catch (Exception e) { } catch (Exception e) {
// TODO what should happen here? should continue? // TODO: what should happen here? should continue?
} }
} }
...@@ -653,8 +660,8 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -653,8 +660,8 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
// Get the exception class and message if any // Get the exception class and message if any
int index = exceptionText.indexOf(":"); int index = exceptionText.indexOf(":");
String className = null; String className;
String message = null; String message;
// If there is no massege, save the class only // If there is no massege, save the class only
if (index == -1) { if (index == -1) {
className = exceptionText; className = exceptionText;
...@@ -671,7 +678,7 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -671,7 +678,7 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
} }
//Tries to create an instance with the message //Tries to create an instance with the message
Exception exception = null; Exception exception;
try { try {
Class exceptionClass = Class.forName(className); Class exceptionClass = Class.forName(className);
if (message == null) { if (message == null) {
...@@ -691,10 +698,10 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -691,10 +698,10 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
} }
/** /**
* Returns the Clearspace user id the user. * Returns the Clearspace user id the user by username.
* @param username * @param username Username to retrieve ID of.
* @return * @return The ID number of the user in Clearspace.
* @throws org.jivesoftware.openfire.user.UserNotFoundException * @throws org.jivesoftware.openfire.user.UserNotFoundException If the user was not found.
*/ */
protected long getUserID(String username) throws UserNotFoundException { protected long getUserID(String username) throws UserNotFoundException {
// todo implement cache // todo implement cache
...@@ -708,14 +715,13 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -708,14 +715,13 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
} }
/** /**
* Returns the Clearspace user id the user. * Returns the Clearspace user id the user by JID.
* @param user * @param user JID of user to retrieve ID of.
* @return * @return The ID number of the user in Clearspace.
* @throws org.jivesoftware.openfire.user.UserNotFoundException * @throws org.jivesoftware.openfire.user.UserNotFoundException If the user was not found.
*/ */
protected long getUserID(JID user) throws UserNotFoundException { protected long getUserID(JID user) throws UserNotFoundException {
// todo implement cache // TODO: implement cache, after we are listening for user events from Clearspace.
//todo tema de si es local o no
XMPPServer server = XMPPServer.getInstance(); XMPPServer server = XMPPServer.getInstance();
String username = server.isLocal(user) ? JID.unescapeNode(user.getNode()) : user.toString(); String username = server.isLocal(user) ? JID.unescapeNode(user.getNode()) : user.toString();
try { try {
...@@ -734,12 +740,12 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -734,12 +740,12 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
/** /**
* Returns the Clearspace group id of the group. * Returns the Clearspace group id of the group.
* @param groupname * @param groupname Name of the group to retrieve ID of.
* @return * @return The ID number of the group in Clearspace.
* @throws org.jivesoftware.openfire.group.GroupNotFoundException * @throws org.jivesoftware.openfire.group.GroupNotFoundException If the group was not found.
*/ */
protected long getGroupID(String groupname) throws GroupNotFoundException { protected long getGroupID(String groupname) throws GroupNotFoundException {
// todo implement cache // TODO: implement cache, after we are listening for group events from Clearspace.
try { try {
String path = ClearspaceGroupProvider.URL_PREFIX + "groups/" + groupname; String path = ClearspaceGroupProvider.URL_PREFIX + "groups/" + groupname;
Element element = executeRequest(org.jivesoftware.openfire.clearspace.ClearspaceManager.HttpType.GET, path); Element element = executeRequest(org.jivesoftware.openfire.clearspace.ClearspaceManager.HttpType.GET, path);
...@@ -760,7 +766,7 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM ...@@ -760,7 +766,7 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
try { try {
configClearspace(); configClearspace();
} catch (UnauthorizedException e) { } catch (UnauthorizedException e) {
//TODO mark that there is an authorization problem // TODO: mark that there is an authorization problem
} }
} }
} }
......
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