NAME

Net::Jabber::Presence - Jabber Presence Module

SYNOPSIS

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.

DESCRIPTION

To initialize the Presence with a Jabber <presence/> you must pass it 
the XML::Parser Tree array.  For example:

  my $presence = new Net::Jabber::Presence(@tree);

There has been a change from the old way of handling the callbacks.
You no longer have to do the above, a Net::Jabber::Presence object is 
passed to the callback function for the presence:

  use Net::Jabber;

  sub presence {
    my ($Pres) = @_;
    .
    .
    .
  }

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.

Retrieval functions

$to         = $Pres->GetTo();
$toJID      = $Pres->GetTo("jid");
$from       = $Pres->GetFrom();
$fromJID    = $Pres->GetFrom("jid");
$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();

Creation functions

    $Pres->SetPresence(TYPE=>"online",
		       StatuS=>"Open for Business",
		       iCoN=>"normal");
    $Pres->SetTo("bob\@jabber.org");
    $Pres->SetFrom("jojo\@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(type=>"subscribed");

Test functions

$test = $Pres->DefinedTo();
$test = $Pres->DefinedFrom();
$test = $Pres->DefinedType();
$test = $Pres->DefinedStatus();
$test = $Pres->DefinedPriority();
$test = $Pres->DefinedShow();

METHODS

Retrieval functions

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.

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.

Creation functions

SetPresence(to=>string|JID     - set multiple fields in the <presence/>
            from=>string|JID,    at one time.  This is a cumulative
            type=>string,        and over writing action.  If you set
            status=>string,      the "to" attribute twice, the second
            priority=>integer,   setting is what is used.  If you set
            meta=>string,        the status, and then set the priority
            icon=>string,        then both will be in the <presence/>
            show=>string,        tag.  For valid settings read the
            loc=>string)         specific Set functions below.

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...)

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(type=>string) - creates a new Presence object and populates
                      the to/from fields.  The type will be set in 
                      the <presence/>.

Test functions

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.

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.

AUTHOR

By Ryan Eatmon in May of 2000 for http://jabber.org..

COPYRIGHT

This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.