|
Openfire 3.5.2 Javadoc | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.jivesoftware.openfire.session.LocalSession org.jivesoftware.openfire.session.LocalOutgoingServerSession
public class LocalOutgoingServerSession
Server-to-server communication is done using two TCP connections between the servers. One connection is used for sending packets while the other connection is used for receiving packets. The OutgoingServerSession represents the connection to a remote server that will only be used for sending packets.
Currently only the Server Dialback method is being used for authenticating with the remote
server. Use authenticateDomain(String, String)
to create a new connection to a remote
server that will be used for sending packets to the remote server from the specified domain.
Only the authenticated domains with the remote server will be able to effectively send packets
to the remote server. The remote server will reject and close the connection if a
non-authenticated domain tries to send a packet through this connection.
Once the connection has been established with the remote server and at least a domain has been authenticated then a new route will be added to the routing table for this connection. For optimization reasons the same outgoing connection will be used even if the remote server has several hostnames. However, different routes will be created in the routing table for each hostname of the remote server.
Field Summary |
---|
Fields inherited from class org.jivesoftware.openfire.session.LocalSession |
---|
CHARSET, conn, sessionManager, status |
Fields inherited from interface org.jivesoftware.openfire.session.Session |
---|
MAJOR_VERSION, MINOR_VERSION, STATUS_AUTHENTICATED, STATUS_CLOSED, STATUS_CONNECTED |
Constructor Summary | |
---|---|
LocalOutgoingServerSession(String serverName,
Connection connection,
OutgoingServerSocketReader socketReader,
StreamID streamID)
|
Method Summary | |
---|---|
void |
addAuthenticatedDomain(String domain)
Adds a new authenticated domain, subdomain or virtual host to the list of authenticated domains for the remote server. |
void |
addHostname(String hostname)
Adds a new hostname to the list of known hostnames of the remote server. |
static boolean |
authenticateDomain(String domain,
String hostname)
Creates a new outgoing connection to the specified hostname if no one exists. |
boolean |
authenticateSubdomain(String domain,
String hostname)
Authenticates a subdomain of this server with the specified remote server over an exsiting outgoing connection. |
Collection<String> |
getAuthenticatedDomains()
Returns a collection with all the domains, subdomains and virtual hosts that where authenticated. |
String |
getAvailableStreamFeatures()
Returns a text with the available stream features. |
Collection<String> |
getHostnames()
Returns the list of hostnames related to the remote server. |
boolean |
isUsingServerDialback()
Returns true if this outgoing session was established using server dialback. |
Methods inherited from class org.jivesoftware.openfire.session.LocalSession |
---|
close, decodeVersion, deliverRawText, getAddress, getConnection, getCreationDate, getHostAddress, getHostName, getLastActiveDate, getNumClientPackets, getNumServerPackets, getServerName, getSessionData, getStatus, getStreamID, incrementClientPacketCount, incrementServerPacketCount, isClosed, isSecure, process, removeSessionData, setAddress, setSessionData, setStatus, toString, validate |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Methods inherited from interface org.jivesoftware.openfire.session.Session |
---|
close, deliverRawText, getAddress, getCreationDate, getHostAddress, getHostName, getLastActiveDate, getNumClientPackets, getNumServerPackets, getServerName, getStatus, getStreamID, isClosed, isSecure, process, validate |
Constructor Detail |
---|
public LocalOutgoingServerSession(String serverName, Connection connection, OutgoingServerSocketReader socketReader, StreamID streamID)
Method Detail |
---|
public static boolean authenticateDomain(String domain, String hostname)
The Server Dialback method is currently the only implemented method for server-to-server
authentication. This implies that the remote server will ask the Authoritative Server
to verify the domain to authenticate. Most probably this server will act as the
Authoritative Server. See IncomingServerSession
for more information.
domain
- the local domain to authenticate with the remote server.hostname
- the hostname of the remote server.
public boolean authenticateSubdomain(String domain, String hostname)
OutgoingServerSession
authenticateSubdomain
in interface OutgoingServerSession
domain
- the local subdomain to authenticate with the remote server.hostname
- the hostname of the remote server.
public Collection<String> getAuthenticatedDomains()
OutgoingServerSession
getAuthenticatedDomains
in interface OutgoingServerSession
public void addAuthenticatedDomain(String domain)
OutgoingServerSession
addAuthenticatedDomain
in interface OutgoingServerSession
domain
- the new authenticated domain, subdomain or virtual host to add.public Collection<String> getHostnames()
OutgoingServerSession
getHostnames
in interface OutgoingServerSession
public void addHostname(String hostname)
OutgoingServerSession
addHostname
in interface OutgoingServerSession
hostname
- the new known name of the remote serverpublic String getAvailableStreamFeatures()
LocalSession
getAvailableStreamFeatures
in class LocalSession
public boolean isUsingServerDialback()
OutgoingServerSession
isUsingServerDialback
in interface OutgoingServerSession
|
Openfire 3.5.2 Javadoc | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |