Commit 5515e869 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

My little small refactoring.

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@8404 b35dd754-fafc-0310-a699-88a17e54d16e
parent ba699985
...@@ -11,9 +11,9 @@ ...@@ -11,9 +11,9 @@
package org.jivesoftware.openfire; package org.jivesoftware.openfire;
import org.jivesoftware.openfire.session.Session;
import org.jivesoftware.util.LocaleUtils; import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log; import org.jivesoftware.util.Log;
import org.jivesoftware.openfire.session.Session;
import org.xmpp.packet.Packet; import org.xmpp.packet.Packet;
import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.LinkedBlockingQueue;
...@@ -86,7 +86,7 @@ public class Channel<T extends Packet> { ...@@ -86,7 +86,7 @@ public class Channel<T extends Packet> {
try { try {
Session session = SessionManager.getInstance().getSession(packet.getFrom()); Session session = SessionManager.getInstance().getSession(packet.getFrom());
session.getConnection().close(); session.close();
} }
catch (Exception e1) { catch (Exception e1) {
Log.error(e1); Log.error(e1);
......
...@@ -12,10 +12,9 @@ ...@@ -12,10 +12,9 @@
package org.jivesoftware.openfire; package org.jivesoftware.openfire;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.session.Session; import org.jivesoftware.openfire.session.LocalSession;
import org.xmpp.packet.Packet; import org.xmpp.packet.Packet;
import java.net.InetAddress;
import java.net.UnknownHostException; import java.net.UnknownHostException;
/** /**
...@@ -40,15 +39,53 @@ public interface Connection { ...@@ -40,15 +39,53 @@ public interface Connection {
* *
* @param session the session that owns this connection * @param session the session that owns this connection
*/ */
public void init(Session session); public void init(LocalSession session);
/** /**
* Returns the InetAddress describing the connection. * Returns the raw IP address of this <code>InetAddress</code>
* object. The result is in network byte order: the highest order
* byte of the address is in <code>getAddress()[0]</code>.
* *
* @return the InetAddress describing the underlying connection properties. * @return the raw IP address of this object.
* @throws java.net.UnknownHostException if IP address of host could not be determined. * @throws java.net.UnknownHostException if IP address of host could not be determined.
*/ */
public InetAddress getInetAddress() throws UnknownHostException; public byte[] getAddress() throws UnknownHostException;
/**
* Returns the IP address string in textual presentation.
*
* @return the raw IP address in a string format.
* @throws java.net.UnknownHostException if IP address of host could not be determined.
*/
public String getHostAddress() throws UnknownHostException;
/**
* Gets the host name for this IP address.
*
* <p>If this InetAddress was created with a host name,
* this host name will be remembered and returned;
* otherwise, a reverse name lookup will be performed
* and the result will be returned based on the system
* configured name lookup service. If a lookup of the name service
* is required, call
* {@link java.net.InetAddress#getCanonicalHostName() getCanonicalHostName}.
*
* <p>If there is a security manager, its
* <code>checkConnect</code> method is first called
* with the hostname and <code>-1</code>
* as its arguments to see if the operation is allowed.
* If the operation is not allowed, it will return
* the textual representation of the IP address.
*
* @return the host name for this IP address, or if the operation
* is not allowed by the security check, the textual
* representation of the IP address.
* @throws java.net.UnknownHostException if IP address of host could not be determined.
*
* @see java.net.InetAddress#getCanonicalHostName
* @see SecurityManager#checkConnect
*/
public String getHostName() throws UnknownHostException;
/** /**
* Close this session including associated socket connection. The order of * Close this session including associated socket connection. The order of
......
...@@ -12,7 +12,6 @@ ...@@ -12,7 +12,6 @@
package org.jivesoftware.openfire; package org.jivesoftware.openfire;
import org.dom4j.Element; import org.dom4j.Element;
import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.container.BasicModule; import org.jivesoftware.openfire.container.BasicModule;
import org.jivesoftware.openfire.handler.IQHandler; import org.jivesoftware.openfire.handler.IQHandler;
import org.jivesoftware.openfire.interceptor.InterceptorManager; import org.jivesoftware.openfire.interceptor.InterceptorManager;
...@@ -75,7 +74,8 @@ public class IQRouter extends BasicModule { ...@@ -75,7 +74,8 @@ public class IQRouter extends BasicModule {
if (packet == null) { if (packet == null) {
throw new NullPointerException(); throw new NullPointerException();
} }
ClientSession session = sessionManager.getSession(packet.getFrom()); JID sender = packet.getFrom();
ClientSession session = sessionManager.getSession(sender);
try { try {
// Invoke the interceptors before we process the read packet // Invoke the interceptors before we process the read packet
InterceptorManager.getInstance().invokeInterceptors(packet, session, true, false); InterceptorManager.getInstance().invokeInterceptors(packet, session, true, false);
...@@ -87,7 +87,7 @@ public class IQRouter extends BasicModule { ...@@ -87,7 +87,7 @@ public class IQRouter extends BasicModule {
IQ reply = IQ.createResultIQ(packet); IQ reply = IQ.createResultIQ(packet);
reply.setChildElement(packet.getChildElement().createCopy()); reply.setChildElement(packet.getChildElement().createCopy());
reply.setError(PacketError.Condition.bad_request); reply.setError(PacketError.Condition.bad_request);
sessionManager.getSession(packet.getFrom()).process(reply); session.process(reply);
Log.warn("User tried to authenticate with this server using an unknown receipient: " + Log.warn("User tried to authenticate with this server using an unknown receipient: " +
packet); packet);
} }
...@@ -104,7 +104,7 @@ public class IQRouter extends BasicModule { ...@@ -104,7 +104,7 @@ public class IQRouter extends BasicModule {
IQ reply = IQ.createResultIQ(packet); IQ reply = IQ.createResultIQ(packet);
reply.setChildElement(packet.getChildElement().createCopy()); reply.setChildElement(packet.getChildElement().createCopy());
reply.setError(PacketError.Condition.not_authorized); reply.setError(PacketError.Condition.not_authorized);
sessionManager.getSession(packet.getFrom()).process(reply); session.process(reply);
} }
// Invoke the interceptors after we have processed the read packet // Invoke the interceptors after we have processed the read packet
InterceptorManager.getInstance().invokeInterceptors(packet, session, true, true); InterceptorManager.getInstance().invokeInterceptors(packet, session, true, true);
...@@ -305,10 +305,7 @@ public class IQRouter extends BasicModule { ...@@ -305,10 +305,7 @@ public class IQRouter extends BasicModule {
Log.error(LocaleUtils.getLocalizedString("admin.error.routing"), e); Log.error(LocaleUtils.getLocalizedString("admin.error.routing"), e);
Session session = sessionManager.getSession(packet.getFrom()); Session session = sessionManager.getSession(packet.getFrom());
if (session != null) { if (session != null) {
Connection conn = session.getConnection(); session.close();
if (conn != null) {
conn.close();
}
} }
} }
} }
...@@ -328,11 +325,7 @@ public class IQRouter extends BasicModule { ...@@ -328,11 +325,7 @@ public class IQRouter extends BasicModule {
return; return;
} }
// Route the error packet to the original sender of the IQ. // Route the error packet to the original sender of the IQ.
try {
routingTable.routePacket(reply.getTo(), reply); routingTable.routePacket(reply.getTo(), reply);
} catch (UnauthorizedException e) {
// Should never happen
}
} }
private IQHandler getHandler(String namespace) { private IQHandler getHandler(String namespace) {
...@@ -353,9 +346,10 @@ public class IQRouter extends BasicModule { ...@@ -353,9 +346,10 @@ public class IQRouter extends BasicModule {
/** /**
* Notification message indicating that a packet has failed to be routed to the receipient. * Notification message indicating that a packet has failed to be routed to the receipient.
* *
* @param receipient address of the entity that failed to receive the packet.
* @param packet IQ packet that failed to be sent to the receipient. * @param packet IQ packet that failed to be sent to the receipient.
*/ */
public void routingFailed(Packet packet) { public void routingFailed(JID receipient, Packet packet) {
IQ iq = (IQ) packet; IQ iq = (IQ) packet;
// If a route to the target address was not found then try to answer a // If a route to the target address was not found then try to answer a
// service_unavailable error code to the sender of the IQ packet // service_unavailable error code to the sender of the IQ packet
......
...@@ -33,7 +33,7 @@ public class GetNumberUserSessions extends AdHocCommand { ...@@ -33,7 +33,7 @@ public class GetNumberUserSessions extends AdHocCommand {
field.setLabel(getLabel()); field.setLabel(getLabel());
field.setVariable("onlineuserssessionsnum"); field.setVariable("onlineuserssessionsnum");
SessionManager sessionManager = SessionManager.getInstance(); SessionManager sessionManager = SessionManager.getInstance();
field.addValue(sessionManager.getUserSessionsCount() + sessionManager.getAnonymousSessionCount()); field.addValue(sessionManager.getUserSessionsCount());
command.add(form.getElement()); command.add(form.getElement());
} }
......
...@@ -11,13 +11,13 @@ ...@@ -11,13 +11,13 @@
package org.jivesoftware.openfire.component; package org.jivesoftware.openfire.component;
import org.jivesoftware.database.DbConnectionManager; import org.jivesoftware.database.DbConnectionManager;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.jivesoftware.openfire.SessionManager; import org.jivesoftware.openfire.SessionManager;
import org.jivesoftware.openfire.XMPPServer; import org.jivesoftware.openfire.XMPPServer;
import org.jivesoftware.openfire.component.ExternalComponentConfiguration.Permission; import org.jivesoftware.openfire.component.ExternalComponentConfiguration.Permission;
import org.jivesoftware.openfire.session.ComponentSession; import org.jivesoftware.openfire.session.ComponentSession;
import org.jivesoftware.openfire.session.Session; import org.jivesoftware.openfire.session.Session;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet; import java.sql.ResultSet;
...@@ -74,7 +74,7 @@ public class ExternalComponentManager { ...@@ -74,7 +74,7 @@ public class ExternalComponentManager {
String domain = subdomain + "." + XMPPServer.getInstance().getServerInfo().getName(); String domain = subdomain + "." + XMPPServer.getInstance().getServerInfo().getName();
Session session = SessionManager.getInstance().getComponentSession(domain); Session session = SessionManager.getInstance().getComponentSession(domain);
if (session != null) { if (session != null) {
session.getConnection().close(); session.close();
} }
} }
...@@ -340,7 +340,7 @@ public class ExternalComponentManager { ...@@ -340,7 +340,7 @@ public class ExternalComponentManager {
for (ComponentSession session : SessionManager.getInstance().getComponentSessions()) { for (ComponentSession session : SessionManager.getInstance().getComponentSessions()) {
for (String domain : session.getExternalComponent().getSubdomains()) { for (String domain : session.getExternalComponent().getSubdomains()) {
if (!canAccess(domain)) { if (!canAccess(domain)) {
session.getConnection().close(); session.close();
break; break;
} }
} }
......
...@@ -14,18 +14,19 @@ package org.jivesoftware.openfire.handler; ...@@ -14,18 +14,19 @@ package org.jivesoftware.openfire.handler;
import org.dom4j.DocumentHelper; import org.dom4j.DocumentHelper;
import org.dom4j.Element; import org.dom4j.Element;
import org.dom4j.QName; import org.dom4j.QName;
import org.jivesoftware.stringprep.StringprepException;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log;
import org.jivesoftware.openfire.*; import org.jivesoftware.openfire.*;
import org.jivesoftware.openfire.auth.AuthFactory; import org.jivesoftware.openfire.auth.AuthFactory;
import org.jivesoftware.openfire.auth.AuthToken; import org.jivesoftware.openfire.auth.AuthToken;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.session.ClientSession; import org.jivesoftware.openfire.session.ClientSession;
import org.jivesoftware.openfire.session.LocalClientSession;
import org.jivesoftware.openfire.session.Session; import org.jivesoftware.openfire.session.Session;
import org.jivesoftware.openfire.user.UserManager; import org.jivesoftware.openfire.user.UserManager;
import org.jivesoftware.openfire.user.UserNotFoundException; import org.jivesoftware.openfire.user.UserNotFoundException;
import org.jivesoftware.stringprep.StringprepException;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log;
import org.xmpp.packet.IQ; import org.xmpp.packet.IQ;
import org.xmpp.packet.JID; import org.xmpp.packet.JID;
import org.xmpp.packet.PacketError; import org.xmpp.packet.PacketError;
...@@ -60,9 +61,10 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo { ...@@ -60,9 +61,10 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo {
private Element probeResponse; private Element probeResponse;
private IQHandlerInfo info; private IQHandlerInfo info;
private String serverName;
private UserManager userManager; private UserManager userManager;
private XMPPServer localServer;
private SessionManager sessionManager; private SessionManager sessionManager;
private RoutingTable routingTable;
/** /**
* Clients are not authenticated when accessing this handler. * Clients are not authenticated when accessing this handler.
...@@ -84,7 +86,7 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo { ...@@ -84,7 +86,7 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo {
} }
public IQ handleIQ(IQ packet) throws UnauthorizedException, PacketException { public IQ handleIQ(IQ packet) throws UnauthorizedException, PacketException {
ClientSession session = sessionManager.getSession(packet.getFrom()); LocalClientSession session = (LocalClientSession) sessionManager.getSession(packet.getFrom());
// If no session was found then answer an error (if possible) // If no session was found then answer an error (if possible)
if (session == null) { if (session == null) {
Log.error("Error during authentication. Session not found in " + Log.error("Error during authentication. Session not found in " +
...@@ -160,7 +162,7 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo { ...@@ -160,7 +162,7 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo {
return null; return null;
} }
private IQ login(String username, Element iq, IQ packet, String password, ClientSession session, String digest) private IQ login(String username, Element iq, IQ packet, String password, LocalClientSession session, String digest)
throws UnauthorizedException, UserNotFoundException { throws UnauthorizedException, UserNotFoundException {
// Verify that specified resource is not violating any string prep rule // Verify that specified resource is not violating any string prep rule
String resource = iq.elementTextTrim("resource"); String resource = iq.elementTextTrim("resource");
...@@ -195,21 +197,16 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo { ...@@ -195,21 +197,16 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo {
// Verify if there is a resource conflict between new resource and existing one. // Verify if there is a resource conflict between new resource and existing one.
// Check if a session already exists with the requested full JID and verify if // Check if a session already exists with the requested full JID and verify if
// we should kick it off or refuse the new connection // we should kick it off or refuse the new connection
if (sessionManager.isActiveRoute(username, resource)) { ClientSession oldSession = routingTable.getClientRoute(new JID(username, serverName, resource));
ClientSession oldSession; if (oldSession != null) {
try { try {
String domain = localServer.getServerInfo().getName();
oldSession = sessionManager.getSession(username, domain, resource);
oldSession.incrementConflictCount(); oldSession.incrementConflictCount();
int conflictLimit = sessionManager.getConflictKickLimit(); int conflictLimit = sessionManager.getConflictKickLimit();
if (conflictLimit != SessionManager.NEVER_KICK && oldSession.getConflictCount() > conflictLimit) { if (conflictLimit != SessionManager.NEVER_KICK && oldSession.getConflictCount() > conflictLimit) {
Connection conn = oldSession.getConnection();
if (conn != null) {
// Send a stream:error before closing the old connection // Send a stream:error before closing the old connection
StreamError error = new StreamError(StreamError.Condition.conflict); StreamError error = new StreamError(StreamError.Condition.conflict);
conn.deliverRawText(error.toXML()); oldSession.deliverRawText(error.toXML());
conn.close(); oldSession.close();
}
} }
else { else {
IQ response = IQ.createResultIQ(packet); IQ response = IQ.createResultIQ(packet);
...@@ -251,7 +248,7 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo { ...@@ -251,7 +248,7 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo {
return response; return response;
} }
private IQ anonymousLogin(ClientSession session, IQ packet) { private IQ anonymousLogin(LocalClientSession session, IQ packet) {
IQ response = IQ.createResultIQ(packet); IQ response = IQ.createResultIQ(packet);
if (anonymousAllowed) { if (anonymousAllowed) {
session.setAnonymousAuth(); session.setAnonymousAuth();
...@@ -277,9 +274,10 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo { ...@@ -277,9 +274,10 @@ public class IQAuthHandler extends IQHandler implements IQAuthInfo {
public void initialize(XMPPServer server) { public void initialize(XMPPServer server) {
super.initialize(server); super.initialize(server);
localServer = server;
userManager = server.getUserManager(); userManager = server.getUserManager();
sessionManager = server.getSessionManager(); sessionManager = server.getSessionManager();
routingTable = server.getRoutingTable();
serverName = server.getServerInfo().getName();
} }
public IQHandlerInfo getInfo() { public IQHandlerInfo getInfo() {
......
...@@ -12,15 +12,16 @@ ...@@ -12,15 +12,16 @@
package org.jivesoftware.openfire.handler; package org.jivesoftware.openfire.handler;
import org.dom4j.Element; import org.dom4j.Element;
import org.jivesoftware.stringprep.StringprepException;
import org.jivesoftware.util.Log;
import org.jivesoftware.openfire.Connection;
import org.jivesoftware.openfire.IQHandlerInfo; import org.jivesoftware.openfire.IQHandlerInfo;
import org.jivesoftware.openfire.RoutingTable;
import org.jivesoftware.openfire.SessionManager; import org.jivesoftware.openfire.SessionManager;
import org.jivesoftware.openfire.XMPPServer; import org.jivesoftware.openfire.XMPPServer;
import org.jivesoftware.openfire.auth.AuthToken; import org.jivesoftware.openfire.auth.AuthToken;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.session.ClientSession; import org.jivesoftware.openfire.session.ClientSession;
import org.jivesoftware.openfire.session.LocalClientSession;
import org.jivesoftware.stringprep.StringprepException;
import org.jivesoftware.util.Log;
import org.xmpp.packet.IQ; import org.xmpp.packet.IQ;
import org.xmpp.packet.JID; import org.xmpp.packet.JID;
import org.xmpp.packet.PacketError; import org.xmpp.packet.PacketError;
...@@ -41,7 +42,8 @@ import org.xmpp.packet.StreamError; ...@@ -41,7 +42,8 @@ import org.xmpp.packet.StreamError;
public class IQBindHandler extends IQHandler { public class IQBindHandler extends IQHandler {
private IQHandlerInfo info; private IQHandlerInfo info;
private XMPPServer localServer; private String serverName;
private RoutingTable routingTable;
public IQBindHandler() { public IQBindHandler() {
super("Resource Binding handler"); super("Resource Binding handler");
...@@ -49,7 +51,7 @@ public class IQBindHandler extends IQHandler { ...@@ -49,7 +51,7 @@ public class IQBindHandler extends IQHandler {
} }
public IQ handleIQ(IQ packet) throws UnauthorizedException { public IQ handleIQ(IQ packet) throws UnauthorizedException {
ClientSession session = sessionManager.getSession(packet.getFrom()); LocalClientSession session = (LocalClientSession) sessionManager.getSession(packet.getFrom());
// If no session was found then answer an error (if possible) // If no session was found then answer an error (if possible)
if (session == null) { if (session == null) {
Log.error("Error during resource binding. Session not found in " + Log.error("Error during resource binding. Session not found in " +
...@@ -94,22 +96,16 @@ public class IQBindHandler extends IQHandler { ...@@ -94,22 +96,16 @@ public class IQBindHandler extends IQHandler {
String username = authToken.getUsername().toLowerCase(); String username = authToken.getUsername().toLowerCase();
// If a session already exists with the requested JID, then check to see // If a session already exists with the requested JID, then check to see
// if we should kick it off or refuse the new connection // if we should kick it off or refuse the new connection
if (sessionManager.isActiveRoute(username, resource)) { ClientSession oldSession = routingTable.getClientRoute(new JID(username, serverName, resource));
ClientSession oldSession; if (oldSession != null) {
try { try {
String domain = localServer.getServerInfo().getName();
oldSession = sessionManager.getSession(username, domain, resource);
oldSession.incrementConflictCount(); oldSession.incrementConflictCount();
int conflictLimit = sessionManager.getConflictKickLimit(); int conflictLimit = sessionManager.getConflictKickLimit();
if (conflictLimit != SessionManager.NEVER_KICK && if (conflictLimit != SessionManager.NEVER_KICK && oldSession.getConflictCount() > conflictLimit) {
oldSession.getConflictCount() > conflictLimit) {
Connection conn = oldSession.getConnection();
if (conn != null) {
// Kick out the old connection that is conflicting with the new one // Kick out the old connection that is conflicting with the new one
StreamError error = new StreamError(StreamError.Condition.conflict); StreamError error = new StreamError(StreamError.Condition.conflict);
conn.deliverRawText(error.toXML()); oldSession.deliverRawText(error.toXML());
conn.close(); oldSession.close();
}
} }
else { else {
reply.setChildElement(packet.getChildElement().createCopy()); reply.setChildElement(packet.getChildElement().createCopy());
...@@ -135,7 +131,8 @@ public class IQBindHandler extends IQHandler { ...@@ -135,7 +131,8 @@ public class IQBindHandler extends IQHandler {
public void initialize(XMPPServer server) { public void initialize(XMPPServer server) {
super.initialize(server); super.initialize(server);
localServer = server; routingTable = server.getRoutingTable();
serverName = server.getServerInfo().getName();
} }
public IQHandlerInfo getInfo() { public IQHandlerInfo getInfo() {
......
...@@ -11,11 +11,11 @@ ...@@ -11,11 +11,11 @@
package org.jivesoftware.openfire.handler; package org.jivesoftware.openfire.handler;
import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log;
import org.jivesoftware.openfire.*; import org.jivesoftware.openfire.*;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.container.BasicModule; import org.jivesoftware.openfire.container.BasicModule;
import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log;
import org.xmpp.packet.IQ; import org.xmpp.packet.IQ;
import org.xmpp.packet.Packet; import org.xmpp.packet.Packet;
import org.xmpp.packet.PacketError; import org.xmpp.packet.PacketError;
...@@ -60,7 +60,7 @@ public abstract class IQHandler extends BasicModule implements ChannelHandler { ...@@ -60,7 +60,7 @@ public abstract class IQHandler extends BasicModule implements ChannelHandler {
} }
catch (Exception de) { catch (Exception de) {
Log.error(LocaleUtils.getLocalizedString("admin.error"), de); Log.error(LocaleUtils.getLocalizedString("admin.error"), de);
sessionManager.getSession(iq.getFrom()).getConnection().close(); sessionManager.getSession(iq.getFrom()).close();
} }
} }
} }
......
...@@ -13,8 +13,6 @@ package org.jivesoftware.openfire.handler; ...@@ -13,8 +13,6 @@ package org.jivesoftware.openfire.handler;
import org.dom4j.DocumentHelper; import org.dom4j.DocumentHelper;
import org.dom4j.Element; import org.dom4j.Element;
import org.jivesoftware.util.JiveConstants;
import org.jivesoftware.util.Log;
import org.jivesoftware.openfire.*; import org.jivesoftware.openfire.*;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.disco.*; import org.jivesoftware.openfire.disco.*;
...@@ -22,8 +20,10 @@ import org.jivesoftware.openfire.forms.DataForm; ...@@ -22,8 +20,10 @@ import org.jivesoftware.openfire.forms.DataForm;
import org.jivesoftware.openfire.forms.FormField; import org.jivesoftware.openfire.forms.FormField;
import org.jivesoftware.openfire.forms.spi.XDataFormImpl; import org.jivesoftware.openfire.forms.spi.XDataFormImpl;
import org.jivesoftware.openfire.forms.spi.XFormFieldImpl; import org.jivesoftware.openfire.forms.spi.XFormFieldImpl;
import org.jivesoftware.openfire.session.ClientSession; import org.jivesoftware.openfire.session.LocalClientSession;
import org.jivesoftware.openfire.user.UserManager; import org.jivesoftware.openfire.user.UserManager;
import org.jivesoftware.util.JiveConstants;
import org.jivesoftware.util.Log;
import org.xmpp.packet.IQ; import org.xmpp.packet.IQ;
import org.xmpp.packet.JID; import org.xmpp.packet.JID;
...@@ -49,6 +49,7 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature ...@@ -49,6 +49,7 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature
private IQDiscoInfoHandler infoHandler; private IQDiscoInfoHandler infoHandler;
private IQDiscoItemsHandler itemsHandler; private IQDiscoItemsHandler itemsHandler;
private RoutingTable routingTable;
private SessionManager sessionManager; private SessionManager sessionManager;
private UserManager userManager; private UserManager userManager;
private OfflineMessageStore messageStore; private OfflineMessageStore messageStore;
...@@ -63,18 +64,17 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature ...@@ -63,18 +64,17 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature
IQ reply = IQ.createResultIQ(packet); IQ reply = IQ.createResultIQ(packet);
Element offlineRequest = packet.getChildElement(); Element offlineRequest = packet.getChildElement();
JID from = packet.getFrom();
if (offlineRequest.element("purge") != null) { if (offlineRequest.element("purge") != null) {
// User requested to delete all offline messages // User requested to delete all offline messages
messageStore.deleteMessages(packet.getFrom().getNode()); messageStore.deleteMessages(from.getNode());
} }
else if (offlineRequest.element("fetch") != null) { else if (offlineRequest.element("fetch") != null) {
// Mark that offline messages shouldn't be sent when the user becomes available // Mark that offline messages shouldn't be sent when the user becomes available
stopOfflineFlooding(packet.getFrom()); stopOfflineFlooding(from);
ClientSession session = sessionManager.getSession(packet.getFrom());
// User requested to receive all offline messages // User requested to receive all offline messages
for (OfflineMessage offlineMessage : messageStore.getMessages( for (OfflineMessage offlineMessage : messageStore.getMessages(from.getNode(), false)) {
packet.getFrom().getNode(), false)) { sendOfflineMessage(from, offlineMessage);
sendOfflineMessage(offlineMessage, session);
} }
} }
else { else {
...@@ -91,29 +91,27 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature ...@@ -91,29 +91,27 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature
} }
if ("view".equals(item.attributeValue("action"))) { if ("view".equals(item.attributeValue("action"))) {
// User requested to receive specific message // User requested to receive specific message
OfflineMessage offlineMsg = messageStore.getMessage(packet.getFrom().getNode(), OfflineMessage offlineMsg = messageStore.getMessage(from.getNode(), creationDate);
creationDate);
if (offlineMsg != null) { if (offlineMsg != null) {
ClientSession session = sessionManager.getSession(packet.getFrom()); sendOfflineMessage(from, offlineMsg);
sendOfflineMessage(offlineMsg, session);
} }
} }
else if ("remove".equals(item.attributeValue("action"))) { else if ("remove".equals(item.attributeValue("action"))) {
// User requested to delete specific message // User requested to delete specific message
messageStore.deleteMessage(packet.getFrom().getNode(), creationDate); messageStore.deleteMessage(from.getNode(), creationDate);
} }
} }
} }
return reply; return reply;
} }
private void sendOfflineMessage(OfflineMessage offlineMessage, ClientSession session) { private void sendOfflineMessage(JID receipient, OfflineMessage offlineMessage) {
Element offlineInfo = offlineMessage.addChildElement("offline", NAMESPACE); Element offlineInfo = offlineMessage.addChildElement("offline", NAMESPACE);
synchronized (dateFormat) { synchronized (dateFormat) {
offlineInfo.addElement("item").addAttribute("node", offlineInfo.addElement("item").addAttribute("node",
dateFormat.format(offlineMessage.getCreationDate())); dateFormat.format(offlineMessage.getCreationDate()));
} }
session.process(offlineMessage); routingTable.routePacket(receipient, offlineMessage);
} }
public IQHandlerInfo getInfo() { public IQHandlerInfo getInfo() {
...@@ -187,6 +185,7 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature ...@@ -187,6 +185,7 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature
messageStore = server.getOfflineMessageStore(); messageStore = server.getOfflineMessageStore();
sessionManager = server.getSessionManager(); sessionManager = server.getSessionManager();
userManager = server.getUserManager(); userManager = server.getUserManager();
routingTable = server.getRoutingTable();
} }
public void start() throws IllegalStateException { public void start() throws IllegalStateException {
...@@ -202,7 +201,7 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature ...@@ -202,7 +201,7 @@ public class IQOfflineMessagesHandler extends IQHandler implements ServerFeature
} }
private void stopOfflineFlooding(JID senderJID) { private void stopOfflineFlooding(JID senderJID) {
ClientSession session = sessionManager.getSession(senderJID); LocalClientSession session = (LocalClientSession) sessionManager.getSession(senderJID);
if (session != null) { if (session != null) {
session.setOfflineFloodStopped(true); session.setOfflineFloodStopped(true);
} }
......
...@@ -358,12 +358,7 @@ public class IQPrivacyHandler extends IQHandler ...@@ -358,12 +358,7 @@ public class IQPrivacyHandler extends IQHandler
IQ pushPacket = new IQ(IQ.Type.set); IQ pushPacket = new IQ(IQ.Type.set);
Element child = pushPacket.setChildElement("query", "jabber:iq:privacy"); Element child = pushPacket.setChildElement("query", "jabber:iq:privacy");
child.addElement("list").addAttribute("name", list.getName()); child.addElement("list").addAttribute("name", list.getName());
try {
sessionManager.userBroadcast(from.getNode(), pushPacket); sessionManager.userBroadcast(from.getNode(), pushPacket);
}
catch (UnauthorizedException e) {
// Ignore
}
return result; return result;
} }
......
...@@ -14,8 +14,6 @@ package org.jivesoftware.openfire.handler; ...@@ -14,8 +14,6 @@ package org.jivesoftware.openfire.handler;
import org.dom4j.DocumentHelper; import org.dom4j.DocumentHelper;
import org.dom4j.Element; import org.dom4j.Element;
import org.dom4j.QName; import org.dom4j.QName;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.jivesoftware.openfire.IQHandlerInfo; import org.jivesoftware.openfire.IQHandlerInfo;
import org.jivesoftware.openfire.PacketException; import org.jivesoftware.openfire.PacketException;
import org.jivesoftware.openfire.SessionManager; import org.jivesoftware.openfire.SessionManager;
...@@ -34,6 +32,8 @@ import org.jivesoftware.openfire.user.User; ...@@ -34,6 +32,8 @@ import org.jivesoftware.openfire.user.User;
import org.jivesoftware.openfire.user.UserAlreadyExistsException; import org.jivesoftware.openfire.user.UserAlreadyExistsException;
import org.jivesoftware.openfire.user.UserManager; import org.jivesoftware.openfire.user.UserManager;
import org.jivesoftware.openfire.user.UserNotFoundException; import org.jivesoftware.openfire.user.UserNotFoundException;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.xmpp.packet.IQ; import org.xmpp.packet.IQ;
import org.xmpp.packet.JID; import org.xmpp.packet.JID;
import org.xmpp.packet.PacketError; import org.xmpp.packet.PacketError;
...@@ -236,7 +236,7 @@ public class IQRegisterHandler extends IQHandler implements ServerFeaturesProvid ...@@ -236,7 +236,7 @@ public class IQRegisterHandler extends IQHandler implements ServerFeaturesProvid
// Take a quick nap so that the client can process the result // Take a quick nap so that the client can process the result
Thread.sleep(10); Thread.sleep(10);
// Close the user's connection // Close the user's connection
session.getConnection().close(); session.close();
// The reply has been sent so clean up the variable // The reply has been sent so clean up the variable
reply = null; reply = null;
} }
......
...@@ -17,7 +17,7 @@ import org.jivesoftware.openfire.container.BasicModule; ...@@ -17,7 +17,7 @@ import org.jivesoftware.openfire.container.BasicModule;
import org.jivesoftware.openfire.roster.Roster; import org.jivesoftware.openfire.roster.Roster;
import org.jivesoftware.openfire.roster.RosterItem; import org.jivesoftware.openfire.roster.RosterItem;
import org.jivesoftware.openfire.roster.RosterManager; import org.jivesoftware.openfire.roster.RosterManager;
import org.jivesoftware.openfire.session.ClientSession; import org.jivesoftware.openfire.session.LocalClientSession;
import org.jivesoftware.openfire.session.Session; import org.jivesoftware.openfire.session.Session;
import org.jivesoftware.openfire.user.UserManager; import org.jivesoftware.openfire.user.UserManager;
import org.jivesoftware.openfire.user.UserNotFoundException; import org.jivesoftware.openfire.user.UserNotFoundException;
...@@ -89,10 +89,10 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler ...@@ -89,10 +89,10 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler
} }
public void process(Packet packet) throws UnauthorizedException, PacketException { public void process(Packet packet) throws UnauthorizedException, PacketException {
process((Presence) packet, sessionManager.getSession(packet.getFrom())); process((Presence) packet, (LocalClientSession) sessionManager.getSession(packet.getFrom()));
} }
public void process(Presence presence, ClientSession session) throws UnauthorizedException, PacketException { private void process(Presence presence, LocalClientSession session) throws UnauthorizedException, PacketException {
try { try {
Presence.Type type = presence.getType(); Presence.Type type = presence.getType();
// Available // Available
...@@ -187,7 +187,7 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler ...@@ -187,7 +187,7 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler
* @param session The session being updated * @param session The session being updated
* @throws UserNotFoundException If the user being updated does not exist * @throws UserNotFoundException If the user being updated does not exist
*/ */
private void initSession(ClientSession session) throws UserNotFoundException { private void initSession(LocalClientSession session) throws UserNotFoundException {
// Only user sessions need to be authenticated // Only user sessions need to be authenticated
if (userManager.isRegisteredUser(session.getAddress().getNode())) { if (userManager.isRegisteredUser(session.getAddress().getNode())) {
...@@ -245,7 +245,7 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler ...@@ -245,7 +245,7 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler
* *
* @param update The update to broadcast * @param update The update to broadcast
*/ */
private void broadcastUpdate(Presence update) throws PacketException { private void broadcastUpdate(Presence update) {
if (update.getFrom() == null) { if (update.getFrom() == null) {
return; return;
} }
...@@ -437,13 +437,8 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler ...@@ -437,13 +437,8 @@ public class PresenceUpdateHandler extends BasicModule implements ChannelHandler
for (String jid : jids) { for (String jid : jids) {
Presence presence = update.createCopy(); Presence presence = update.createCopy();
presence.setTo(jid); presence.setTo(jid);
try {
routingTable.routePacket(handlerJID, presence); routingTable.routePacket(handlerJID, presence);
} }
catch (UnauthorizedException ue) {
Log.error(ue);
}
}
} }
} }
} }
......
...@@ -15,21 +15,22 @@ import org.dom4j.Element; ...@@ -15,21 +15,22 @@ import org.dom4j.Element;
import org.dom4j.Namespace; import org.dom4j.Namespace;
import org.dom4j.QName; import org.dom4j.QName;
import org.jivesoftware.openfire.Connection; import org.jivesoftware.openfire.Connection;
import org.jivesoftware.openfire.StreamID;
import org.jivesoftware.openfire.PacketDeliverer; import org.jivesoftware.openfire.PacketDeliverer;
import org.jivesoftware.openfire.SessionPacketRouter; import org.jivesoftware.openfire.SessionPacketRouter;
import org.jivesoftware.openfire.multiplex.UnknownStanzaException; import org.jivesoftware.openfire.StreamID;
import org.jivesoftware.openfire.auth.UnauthorizedException; import org.jivesoftware.openfire.auth.UnauthorizedException;
import org.jivesoftware.openfire.multiplex.UnknownStanzaException;
import org.jivesoftware.openfire.net.SASLAuthentication; import org.jivesoftware.openfire.net.SASLAuthentication;
import org.jivesoftware.openfire.net.VirtualConnection; import org.jivesoftware.openfire.net.VirtualConnection;
import org.jivesoftware.openfire.session.ClientSession; import org.jivesoftware.openfire.session.LocalClientSession;
import org.jivesoftware.util.Log; import org.jivesoftware.util.Log;
import org.xmpp.packet.Packet; import org.xmpp.packet.Packet;
import java.io.UnsupportedEncodingException;
import java.net.InetAddress; import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.*; import java.util.*;
import java.util.concurrent.CopyOnWriteArraySet; import java.util.concurrent.CopyOnWriteArraySet;
import java.io.UnsupportedEncodingException;
/** /**
* A session represents a serious of interactions with an XMPP client sending packets using the HTTP * A session represents a serious of interactions with an XMPP client sending packets using the HTTP
...@@ -39,7 +40,7 @@ import java.io.UnsupportedEncodingException; ...@@ -39,7 +40,7 @@ import java.io.UnsupportedEncodingException;
* *
* @author Alexander Wenckus * @author Alexander Wenckus
*/ */
public class HttpSession extends ClientSession { public class HttpSession extends LocalClientSession {
private int wait; private int wait;
private int hold = 0; private int hold = 0;
private String language; private String language;
...@@ -707,8 +708,16 @@ public class HttpSession extends ClientSession { ...@@ -707,8 +708,16 @@ public class HttpSession extends ClientSession {
((HttpSession) session).closeConnection(); ((HttpSession) session).closeConnection();
} }
public InetAddress getInetAddress() { public byte[] getAddress() throws UnknownHostException {
return address; return address.getAddress();
}
public String getHostAddress() throws UnknownHostException {
return address.getHostAddress();
}
public String getHostName() throws UnknownHostException {
return address.getHostName();
} }
public void systemShutdown() { public void systemShutdown() {
......
...@@ -204,7 +204,7 @@ public class MediaProxyService extends BasicModule ...@@ -204,7 +204,7 @@ public class MediaProxyService extends BasicModule
childElementCopy.remove(candidateElement); childElementCopy.remove(candidateElement);
Element publicIp = childElementCopy.addElement("publicip"); Element publicIp = childElementCopy.addElement("publicip");
try { try {
String ip = sessionManager.getSession(iq.getFrom()).getConnection().getInetAddress().getHostAddress(); String ip = sessionManager.getSession(iq.getFrom()).getHostAddress();
if (ip != null) { if (ip != null) {
publicIp.addAttribute("ip", ip); publicIp.addAttribute("ip", ip);
} }
......
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