Net::Jabber::Presence - Jabber Presence Module
Net::Jabber::Presence is a companion to the Net::Jabber module. It provides the user a simple interface to set and retrieve all parts of a Jabber Presence.
To initialize the Presence with a Jabber <presence/> you must pass it the XML::Parser Tree array from the Net::Jabber::Client module. In the callback function for the presence: use Net::Jabber; sub presence { my $presence = new Net::Jabber::Presence(@_); . . . } You now have access to all of the retrieval functions available. To create a new presence to send to the server: use Net::Jabber; $Pres = new Net::Jabber::Presence(); Now you can call the creation functions below to populate the tag before sending it. For more information about the array format being passed to the CallBack please read the Net::Jabber::Client documentation.
$to = $Pres->GetTo(); $toJID = $Pres->GetTo("jid"); $from = $Pres->GetFrom(); $fromJID = $Pres->GetFrom("jid"); $sto = $Pres->GetSTo(); $stoJID = $Pres->GetSTo("jid"); $sfrom = $Pres->GetSFrom(); $sfromJID = $Pres->GetSFrom("jid"); $etherxTo = $Pres->GetEtherxTo(); $etherxFrom = $Pres->GetEtherxFrom(); $type = $Pres->GetType(); $status = $Pres->GetStatus(); $priority = $Pres->GetPriority(); $show = $Pres->GetShow(); @xTags = $Pres->GetX(); @xTags = $Pres->GetX("my:namespace"); @xTrees = $Pres->GetXTrees(); @xTrees = $Pres->GetXTrees("my:namespace"); $str = $Pres->GetXML(); @presence = $Pres->GetTree();
$Pres->SetPresence(TYPE=>"online", StatuS=>"Open for Business", iCoN=>"normal"); $Pres->SetTo("bob\@jabber.org"); $Pres->SetFrom("jojo\@jabber.org"); $Pres->SetSTo("jabber.org"); $Pres->SetSFrom("jabber.org"); $Pres->SetEtherxTo("jabber.org"); $Pres->SetEtherxFrom("transport.jabber.org"); $Pres->SetType("unavailable"); $Pres->SetStatus("Taking a nap"); $Pres->SetPriority(10); $Pres->SetShow("away"); $X = $Pres->NewX("jabber:x:delay"); $X = $Pres->NewX("my:namespace"); $Reply = $Pres->Reply(); $Reply = $Pres->Reply(template=>"client"); $Reply = $Pres->Reply(template=>"transport", type=>"subscribed");
$test = $Pres->DefinedTo(); $test = $Pres->DefinedFrom(); $test = $Pres->DefinedSTo(); $test = $Pres->DefinedSFrom(); $test = $Pres->DefinedEtherxTo(); $test = $Pres->DefinedEtherxFrom(); $test = $Pres->DefinedType(); $test = $Pres->DefinedStatus(); $test = $Pres->DefinedPriority(); $test = $Pres->DefinedShow();
GetTo() - returns either a string with the Jabber Identifier, GetTo("jid") or a Net::Jabber::JID object for the person who is going to receive the <presence/>. To get the JID object set the string to "jid", otherwise leave blank for the text string. GetFrom() - returns either a string with the Jabber Identifier, GetFrom("jid") or a Net::Jabber::JID object for the person who sent the <presence/>. To get the JID object set the string to "jid", otherwise leave blank for the text string. GetSTo() - returns either a string with the Jabber Identifier, GetSTo("jid") or a Net::Jabber::JID object for the <host/> component who is going to receive the <presence/>. To get the JID object set the string to "jid", otherwise leave blank for the text string. GetSFrom() - returns either a string with the Jabber Identifier, GetSFrom("jid") or a Net::Jabber::JID object for the <host/> component who sent the <presence/>. To get the JID object set the string to "jid", otherwise leave blank for the text string. GetEtherxTo(string) - returns the etherx:to attribute. This is for Transport writers who need to communicate with Etherx. GetEtherxFrom(string) - returns the etherx:from attribute. This is for Transport writers who need to communicate with Etherx. GetType() - returns a string with the type <presence/> this is. GetStatus() - returns a string with the current status of the resource. GetPriority() - returns an integer with the priority of the resource The default is 0 if there is no priority in this presence. GetShow() - returns a string with the state the client should show. GetX(string) - returns an array of Net::Jabber::X objects. The string can either be empty or the XML Namespace you are looking for. If empty then GetX returns every <x/> tag in the <presence/>. If an XML Namespace is sent then GetX returns every <x/> tag with that Namespace. GetXTrees(string) - returns an array of XML::Parser::Tree objects. The string can either be empty or the XML Namespace you are looking for. If empty then GetXTrees returns every <x/> tag in the <presence/>. If an XML Namespace is sent then GetXTrees returns every <x/> tag with that Namespace. GetXML() - returns the XML string that represents the <presence/>. This is used by the Send() function in Client.pm to send this object as a Jabber Presence. GetTree() - returns an array that contains the <presence/> tag in XML::Parser Tree format.
SetPresence(to=>string|JID - set multiple fields in the <presence/> from=>string|JID, at one time. This is a cumulative sto=>string, and over writing action. If you set sfrom=>string, the "to" attribute twice, the second etherxto=>string, setting is what is used. If you set etherxfrom=>string, the status, and then set the priority type=>string, then both will be in the <presence/> status=>string, tag. For valid settings read the priority=>integer, specific Set functions below. meta=>string, icon=>string, show=>string, loc=>string) SetTo(string) - sets the to attribute. You can either pass a string SetTo(JID) or a JID object. They must be valid Jabber Identifiers or the server will return an error message. (ie. jabber:bob@jabber.org/Silent Bob, etc...) SetFrom(string) - sets the from attribute. You can either pass a string SetFrom(JID) or a JID object. They must be valid Jabber Identifiers or the server will return an error message. (ie. jabber:bob@jabber.org/Silent Bob, etc...) SetSTo(string) - sets the sto attribute. You can either pass a string SetSTo(JID) or a JID object. They must be valid Jabber Identifiers or the server will return an error message. (ie. jabber:bob@jabber.org/Silent Bob, etc...) SetSFrom(string) - sets the sfrom attribute. You can either pass a string SetSFrom(JID) or a JID object. They must be valid Jabber Identifiers or the server will return an error message. (ie. jabber:bob@jabber.org/Silent Bob, etc...) SetEtherxTo(string) - sets the etherx:to attribute. This is for Transport writers who need to communicate with Etherx. SetEtherxFrom(string) - sets the etherx:from attribute. This is for Transport writers who need to communicate with Etherx. SetType(string) - sets the type attribute. Valid settings are: available available to receive messages; default unavailable unavailable to receive anything subscribe ask the recipient to subscribe you subscribed tell the sender they are subscribed unsubscribe ask the recipient to unsubscribe you unsubscribed tell the sender they are unsubscribed probe probe SetStatus(string) - sets the status tag to be whatever string the user wants associated with that resource. SetPriority(integer) - sets the priority of this resource. The highest resource attached to the jabber account is the one that receives the messages. SetShow(string) - sets the name of the default symbol to display for this resource. NewX(string) - creates a new Net::Jabber::X object with the namespace in the string. In order for this function to work with a custom namespace, you must define and register that namespace with the X module. For more information please read the documentation for Net::Jabber::X. Reply(template=>string, - creates a new Presence object and type=>string) populates the to/from and etherxto/etherxfrom fields based the value of template. The following templates are available: client: (default) just sets the to/from transport: transport-reply: the transport will send the reply to the sender The type will be set in the <presence/>.
DefinedTo() - returns 1 if the to attribute is defined in the <presence/>, 0 otherwise. DefinedFrom() - returns 1 if the from attribute is defined in the <presence/>, 0 otherwise. DefinedEtherxTo() - returns 1 if the etherx:to attribute is defined in the <presence/>, 0 otherwise. DefinedEtherxFrom() - returns 1 if the etherx:from attribute is defined in the <presence/>, 0 otherwise. DefinedType() - returns 1 if the type attribute is defined in the <presence/>, 0 otherwise. DefinedStatus() - returns 1 if <status/> is defined in the <presence/>, 0 otherwise. DefinedPriority() - returns 1 if <priority/> is defined in the <presence/>, 0 otherwise. DefinedShow() - returns 1 if <show/> is defined in the <presence/>, 0 otherwise.
By Ryan Eatmon in May of 2000 for http://jabber.org..
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
To install Net::Jabber, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Net::Jabber
CPAN shell
perl -MCPAN -e shell install Net::Jabber
For more information on module installation, please visit the detailed CPAN module installation guide.