public abstract class PresenceAbstract extends AnnotatedXMPPProcessor implements XMPPProcessorIfc
| Modifier and Type | Field and Description |
|---|---|
static String |
PRESENCE_ELEMENT_NAME |
static String |
PRESENCE_PROBE_FULL_JID_KEY |
protected static boolean |
probeFullJID |
protected RosterAbstract |
roster_util |
static String |
SKIP_OFFLINE_PROP_KEY |
static String |
SKIP_OFFLINE_SYS_PROP_KEY |
protected static boolean |
skipOffline |
static String |
USERS_STATUS_CHANGES |
protected static String |
XMLNS |
ALL_NAMES, ALL_PATHS, cmpInfoCLIENT_XMLNS| Constructor and Description |
|---|
PresenceAbstract() |
| Modifier and Type | Method and Description |
|---|---|
void |
broadcastProbe(XMPPResourceConnection session,
Queue<Packet> results,
Map<String,Object> settings)
sendPresenceBroadcast method broadcasts given presence to all buddies from roster and to all users
to which direct presence was sent. |
int |
concurrentQueuesNo()
Methods returns a preferable number of threads/packets queues for the plugin.
|
protected static void |
forwardPresence(Queue<Packet> results,
Packet packet,
JID from)
Simply forwards packet to the destination
|
boolean |
getProbeFullJID() |
protected static RosterAbstract |
getRosterUtil()
Returns shared instance of class implementing
RosterAbstract - either default one (RosterFlat) or
the one configured with "roster-implementation" property. |
boolean |
isSkipOffline() |
boolean |
isSkipOfflineSys() |
protected static Element |
prepareProbe(XMPPResourceConnection session) |
protected static boolean |
requiresPresenceSending(RosterAbstract roster,
JID buddy,
XMPPResourceConnection session,
boolean systemCheck)
Method checks whether a given contact requires sending presence.
|
static void |
sendPresence(StanzaType t,
BareJID from,
BareJID to,
Queue<Packet> results,
Element pres)
Sends Presence stanza from provided parameters without returning created result
Packet object. |
static Packet |
sendPresence(StanzaType t,
JID from,
JID to,
Queue<Packet> results,
Element pres)
Sends Presence stanza from provided parameters as well as returns created result
Packet object. |
void |
setProbeFullJID(boolean probeFullJID) |
void |
setSkipOffline(boolean skipOffline) |
void |
setSkipOfflineSys(boolean skipOfflineSys) |
static void |
updatePresenceChange(Packet presence,
XMPPResourceConnection session,
Queue<Packet> results)
updatePresenceChange method is used to broadcast to all active resources presence stanza received
from other users, like incoming availability presence, subscription presence and so on... |
static void |
updateUserResources(Element presence,
XMPPResourceConnection session,
Queue<Packet> results,
boolean initial)
updateUserResources method is used to broadcast to all other resources presence
stanza from one user resource. |
id, supDiscoFeatures, supElementNamePaths, supNamespaces, supStreamFeatures, supTypescanHandle, compareTo, getComponentInfo, getInstance, getQueueSize, getStatistics, getThreadsNo, init, toStringclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitprocesscanHandle, getComponentInfo, getStatistics, id, init, supDiscoFeatures, supElementNamePaths, supNamespaces, supStreamFeatures, supTypescompareTopublic static final String PRESENCE_ELEMENT_NAME
public static final String SKIP_OFFLINE_PROP_KEY
public static final String PRESENCE_PROBE_FULL_JID_KEY
public static final String SKIP_OFFLINE_SYS_PROP_KEY
public static final String USERS_STATUS_CHANGES
protected static final String XMLNS
@ConfigField(desc="Probe full JID", alias="probe-full-jid") protected static boolean probeFullJID
@ConfigField(desc="Skip offline", alias="skip-offline") protected static boolean skipOffline
protected RosterAbstract roster_util
protected static void forwardPresence(Queue<Packet> results, Packet packet, JID from)
results - this a collection with packets which have been generated as input packet processing results.packet - to forwardfrom - is a JID instance with stanza source address.protected static RosterAbstract getRosterUtil()
RosterAbstract - either default one (RosterFlat) or
the one configured with "roster-implementation" property.RosterAbstractprotected static Element prepareProbe(XMPPResourceConnection session) throws NotAuthorizedException
NotAuthorizedExceptionprotected static boolean requiresPresenceSending(RosterAbstract roster, JID buddy, XMPPResourceConnection session, boolean systemCheck) throws NotAuthorizedException, TigaseDBException
skipOffline
and user being offline in the roster the presence is not sent. Alternatively enabling option skipOfflineSys would cause local environment check for user status and omit sending presence if the local use is
offline.roster - instance of class implementing RosterAbstract.buddy - JID of a contact for which a check is to be performed.session - user session which keeps all the user session data and also gives an access to the user's
repository data.systemCheck - indicates whether the check should be only based on local environment state (true) or
rooster state of given user should also be taken into consideration (false).NotAuthorizedExceptionTigaseDBExceptionpublic static Packet sendPresence(StanzaType t, JID from, JID to, Queue<Packet> results, Element pres)
Packet object. In case
of missing pres parameter a Presence stanza will be created with provided StanzaType type t, JID type from and JID type to. Otherwise Presence stanza pres will be
cloned and to attribute will be set from parameter to.t - specifies type of the presence to be send.from - is a JID instance with stanza source address.to - is a JID instance with stanza destination address.results - this a collection with packets which have been generated as input packet processing results.pres - an Object of type Element holding Presence stanza to be sent.Packet holding Presence stanza created from provided parameters.public static void sendPresence(StanzaType t, BareJID from, BareJID to, Queue<Packet> results, Element pres)
Packet object. In case of
missing pres parameter a Presence stanza will be created with provided StanzaType type t, JID type from and JID type to. Otherwise Presence stanza pres will be
cloned and to attribute will be set from parameter to.t - specifies type of the presence to be send.from - is a JID instance with stanza source address.to - is a JID instance with stanza destination address.results - this a collection with packets which have been generated as input packet processing results.pres - an Object of type Element holding Presence stanza to be sent.public static void updatePresenceChange(Packet presence, XMPPResourceConnection session, Queue<Packet> results) throws NotAuthorizedException
updatePresenceChange method is used to broadcast to all active resources presence stanza received
from other users, like incoming availability presence, subscription presence and so on... Initial presences are
however sent only to those resources which already have sent initial presence.presence - an Element presence received from other users, we have to change 'to' attribute to
full resource JID.session - user session which keeps all the user session data and also gives an access to the user's
repository data.results - this a collection with packets which have been generated as input packet processing results.NotAuthorizedException - if an error occurspublic static void updateUserResources(Element presence, XMPPResourceConnection session, Queue<Packet> results, boolean initial) throws NotAuthorizedException
updateUserResources method is used to broadcast to all other resources presence
stanza from one user resource. So if new resource connects this method updates presence information about new
resource to old resources and about old resources to new resource.presence - an Element presence received from other users, we have to change 'to' attribute to
full resource JID.session - user session which keeps all the user session data and also gives an access to the user's
repository data.results - this a collection with packets which have been generated as input packet processing results.initial - specifies whether this is an initial presence or not (i.e. if there is a presence data from the
presence stored within user session object or not)NotAuthorizedException - if an error occurspublic boolean isSkipOfflineSys()
public void setSkipOfflineSys(boolean skipOfflineSys)
public boolean isSkipOffline()
public void setSkipOffline(boolean skipOffline)
public boolean getProbeFullJID()
public void setProbeFullJID(boolean probeFullJID)
public void broadcastProbe(XMPPResourceConnection session, Queue<Packet> results, Map<String,Object> settings) throws NotAuthorizedException, TigaseDBException
sendPresenceBroadcast method broadcasts given presence to all buddies from roster and to all users
to which direct presence was sent. Before sending presence method calls requiresPresenceSending(),
configured to only check local environment status (if enabled) to verify whether presence needs to be sent.session - user session which keeps all the user session data and also gives an access to the user's
repository data.results - this a collection with packets which have been generated as input packet processing results.settings - this map keeps plugin specific settings loaded from the Tigase server configuration.NotAuthorizedException - if an error occursTigaseDBExceptionpublic int concurrentQueuesNo()
XMPPImplIfcconcurrentQueuesNo in interface XMPPImplIfcconcurrentQueuesNo in class XMPPProcessorCopyright © 2004–2021 "Tigase, Inc.". All rights reserved.