Stanza Class Reference
This is an abstraction of a XMPP stanza.
More...
#include <stanza.h>
Inherits gloox::Tag.
List of all members.
Public Member Functions |
| Stanza (const Tag *tag) |
| Stanza (const std::string &name, const std::string &cdata="", const std::string &xmllang="default", bool incoming=false) |
virtual | ~Stanza () |
virtual StanzaSubType | subtype () const |
virtual const JID & | from () const |
virtual const JID & | to () const |
virtual const std::string & | id () const |
virtual const std::string & | xmlns () const |
virtual Presence | presence () const |
virtual int | priority () const |
virtual const std::string | status (const std::string &lang="default") const |
virtual const std::string | body (const std::string &lang="default") const |
virtual const std::string | subject (const std::string &lang="default") const |
virtual const std::string | errorText (const std::string &lang="default") const |
virtual StanzaError | error () const |
Tag * | errorAppCondition () |
virtual const std::string & | thread () const |
void | setThread (const std::string &thread) |
const std::string & | xmlLang () const |
void | finalize () |
void | addExtension (StanzaExtension *se) |
const StanzaExtensionList & | extensions () const |
Static Public Member Functions |
static Stanza * | createIqStanza (const JID &to, const std::string &id, StanzaSubType subtype=StanzaIqGet, const std::string &xmlns="", Tag *tag=0) |
static Stanza * | createPresenceStanza (const JID &to, const std::string &msg="", Presence status=PresenceAvailable, const std::string &xmllang="") |
static Stanza * | createMessageStanza (const JID &to, const std::string &body, StanzaSubType subtype=StanzaMessageChat, const std::string &subject="", const std::string &thread="", const std::string &xmllang="") |
static Stanza * | createSubscriptionStanza (const JID &to, const std::string &msg="", StanzaSubType subtype=StanzaS10nSubscribe, const std::string &xmllang="") |
Detailed Description
This is an abstraction of a XMPP stanza.
You can create a new Stanza from an existing Tag (or another stanza).
- Author:
- Jakob Schroeter <js@camaya.net>
- Since:
- 0.4
Definition at line 39 of file stanza.h.
Constructor & Destructor Documentation
Creates a new Stanza from a deep copy of the given Tag.
- Parameters:
-
- Since:
- 0.7
- Note:
- While the signature of this constructor in 0.7 is the the same as in older versions, semantics have changed. The copy created by this constructor is no longer a shallow one. You have to make sure the copy is deleted properly.
Definition at line 32 of file stanza.cpp.
Stanza |
( |
const std::string & |
name, |
|
|
const std::string & |
cdata = "" , |
|
|
const std::string & |
xmllang = "default" , |
|
|
bool |
incoming = false | |
|
) |
| | |
Creates a new Stanza with given name and optional CData.
- Parameters:
-
| name | The name of the root tag. |
| cdata | Initial XML character data for the tag. |
| xmllang | The value of the xmllang attribute. The stanza's primary language. |
| incoming | Indicates whether tag names, attributes, attribute values, and cdata shall be escaped (false, default) or not (true). |
Definition at line 24 of file stanza.cpp.
Virtual destructor.
Definition at line 48 of file stanza.cpp.
Member Function Documentation
virtual const std::string body |
( |
const std::string & |
lang = "default" |
) |
const [inline, virtual] |
Returns the body of a message stanza for the given language if available. If the requested language is not available, the default body (without a xml:lang attribute) will be returned.
- Parameters:
-
| lang | The language identifier for the desired language. It must conform to section 2.12 of the XML specification and RFC 3066. If empty, the default body will be returned, if any. |
- Returns:
- The body of a message stanza. Empty for non-message stanzas.
Definition at line 134 of file stanza.h.
Stanza * createIqStanza |
( |
const JID & |
to, |
|
|
const std::string & |
id, |
|
|
StanzaSubType |
subtype = StanzaIqGet , |
|
|
const std::string & |
xmlns = "" , |
|
|
Tag * |
tag = 0 | |
|
) |
| | [static] |
Creates a new IQ stanza.
- Parameters:
-
| to | The receiver of the stanza. |
| id | An ID for the stanza. Best is to use ClientBase::getID() as input. |
| subtype | The IQ type. Only StanzaIq* types are valid. |
| xmlns | If this is non-empty, a child element named 'query' will be included, with this value as value of the 'xmlns' attribute. |
| tag | If this if not NULL, and xmlns is not empty, this Tag will be included as child tag of the 'query' element. |
- Since:
- 0.7
Definition at line 307 of file stanza.cpp.
Stanza * createMessageStanza |
( |
const JID & |
to, |
|
|
const std::string & |
body, |
|
|
StanzaSubType |
subtype = StanzaMessageChat , |
|
|
const std::string & |
subject = "" , |
|
|
const std::string & |
thread = "" , |
|
|
const std::string & |
xmllang = "" | |
|
) |
| | [static] |
Creates a new message stanza.
- Parameters:
-
| to | The receiver of the message. |
| body | The message's body. |
| subtype | The message type. Only StanzaMessage* types are valid. |
| subject | The message's subject. |
| thread | The message's conversation thread id. |
| xmllang | The message's language. |
- Since:
- 0.7
Definition at line 382 of file stanza.cpp.
Stanza * createPresenceStanza |
( |
const JID & |
to, |
|
|
const std::string & |
msg = "" , |
|
|
Presence |
status = PresenceAvailable , |
|
|
const std::string & |
xmllang = "" | |
|
) |
| | [static] |
Creates a new presence stanza. to
can be an empty JID. This makes the created stanza a broadcast stanza sent to all contacts in the roster.
- Parameters:
-
| to | The receiver of the stanza. |
| msg | An optional message. |
| status | The status. |
| xmllang | The status message's language. |
- Since:
- 0.7
Definition at line 343 of file stanza.cpp.
Stanza * createSubscriptionStanza |
( |
const JID & |
to, |
|
|
const std::string & |
msg = "" , |
|
|
StanzaSubType |
subtype = StanzaS10nSubscribe , |
|
|
const std::string & |
xmllang = "" | |
|
) |
| | [static] |
Creates a new subscription stanza.
- Parameters:
-
| to | The recipient of the subscription stanza. |
| msg | An optional message. |
| subtype | The subscription type. Only StanzaS10n* types are vaild. |
| xmllang | The message's language. |
- Since:
- 0.7
Definition at line 427 of file stanza.cpp.
Returns the stanza error condition, if any.
- Returns:
- The stanza error condition.
Definition at line 165 of file stanza.h.
Tag* errorAppCondition |
( |
|
) |
[inline] |
This function can be used to retrieve the application-specific error condition of a stanza error.
- Returns:
- The application-specific error element of a stanza error. 0 if no respective element was found or no error occured.
Definition at line 172 of file stanza.h.
virtual const std::string errorText |
( |
const std::string & |
lang = "default" |
) |
const [inline, virtual] |
Returns the text of a error stanza for the given language if available. If the requested language is not available, the default text (without a xml:lang attribute) will be returned.
- Parameters:
-
| lang | The language identifier for the desired language. It must conform to section 2.12 of the XML specification and RFC 3066. If empty, the default subject will be returned, if any. |
- Returns:
- The text of an error stanza. Empty for non-error stanzas.
Definition at line 158 of file stanza.h.
Returns the list of the Stanza's extensions.
- Returns:
- The list of the Stanza's extensions.
Definition at line 215 of file stanza.h.
void finalize |
( |
|
) |
[inline] |
Use this function to parse the content of the Tag and determine type, etc. of the Stanza. This feels kind of hackish... You only need to call this if you are constructing a bare Stanza from scratch. Stanzas provided by gloox are fully parsed.
- Deprecated:
Definition at line 200 of file stanza.h.
virtual const JID& from |
( |
|
) |
const [inline, virtual] |
Returns the JID the stanza comes from.
- Returns:
- The origin of the stanza.
Definition at line 78 of file stanza.h.
virtual const std::string& id |
( |
|
) |
const [inline, virtual] |
Returns the id of the stanza, if set.
- Returns:
- The ID of the stanza.
Definition at line 90 of file stanza.h.
virtual Presence presence |
( |
|
) |
const [inline, virtual] |
Returns the presence 'show' type of a presence stanza.
- Returns:
- The presence type of the sender.
Definition at line 102 of file stanza.h.
virtual int priority |
( |
|
) |
const [inline, virtual] |
Returns the remote entity resource's presence priority if the stanza is a presence stanza. If the stanza is not a presence stanza or if no priority information was included, a value below -128 is returned, which is an illegal value for the priority. Legal range is between -128 and +127.
- Returns:
- The priority information contained in the stanza, if any, or a value below -128.
Definition at line 111 of file stanza.h.
void setThread |
( |
const std::string & |
thread |
) |
[inline] |
Sets the Stanza's thread ID. Only useful for message stanzas.
- Parameters:
-
- Since:
- 0.9
Definition at line 185 of file stanza.h.
virtual const std::string status |
( |
const std::string & |
lang = "default" |
) |
const [inline, virtual] |
Returns the status text of a presence stanza for the given language if available. If the requested language is not available, the default status text (without a xml:lang attribute) will be returned.
- Parameters:
-
| lang | The language identifier for the desired language. It must conform to section 2.12 of the XML specification and RFC 3066. If empty, the default body will be returned, if any. |
- Returns:
- The status text set by the sender.
Definition at line 122 of file stanza.h.
virtual const std::string subject |
( |
const std::string & |
lang = "default" |
) |
const [inline, virtual] |
Returns the subject of a message stanza for the given language if available. If the requested language is not available, the default subject (without a xml:lang attribute) will be returned.
- Parameters:
-
| lang | The language identifier for the desired language. It must conform to section 2.12 of the XML specification and RFC 3066. If empty, the default subject will be returned, if any. |
- Returns:
- The subject of a message stanza. Empty for non-message stanzas.
Definition at line 146 of file stanza.h.
Returns the sub-type of the stanza.
- Returns:
- The sub-type of the stanza.
Definition at line 72 of file stanza.h.
virtual const std::string& thread |
( |
|
) |
const [inline, virtual] |
Returns the thread ID of a message stanza.
- Returns:
- The thread ID of a message stanza. Empty for non-message stanzas.
Definition at line 178 of file stanza.h.
virtual const JID& to |
( |
|
) |
const [inline, virtual] |
Returns the receiver of the stanza.
- Returns:
- The stanza's destination.
Definition at line 84 of file stanza.h.
const std::string& xmlLang |
( |
|
) |
const [inline] |
Retrieves the value of the xml:lang attribute of this stanza. Default is 'en'.
Definition at line 191 of file stanza.h.
virtual const std::string& xmlns |
( |
|
) |
const [inline, virtual] |
Returns the value of the xmlns attribute of the first child node.
- Returns:
- The namespace of the IQ stanza.
Definition at line 96 of file stanza.h.
The documentation for this class was generated from the following files: