NAME
Skytel - SkyTel utilities
CONCRETE CLASS
SYNOPSIS
use SkyTel;
$skytel = SkyTel->new($username, $password);
$success = $skytel->forward_text( $pin, $date, $autocopy );
$success = $skytel->forward_voice( $pin, $date, $autocopy );
$success = $skytel->forward_all( $pin, $date, $autocopy );
if ( !$success ) { print STDERR $skytel->getError }
DESCRIPTION
Provides utilities to control your skytel account like forwarding text/voice messages.
Requires HTTP::Cookies, LWP::UserAgent, URI and Date::Manip.
AUTHOR
Marc Prewitt <mprewitt@chelsea.net>
SEE ALSO
HTTP::Cookies LWP::UserAgent Date::Manip URI
TODO
Create disable forwarding method.
Create get forwarding info method.
Disable forwarding before trying to forward it? (doesn't seem like it's needed)
x Pin forwarding is not quite working. Keeps saying it's already forwarded (try a different pin). Works fine. Doesn't work if the other pin is already forwarded.
x Create forward_voice methods and forward_all
x Need to handle error codes from HTTP::Response better
x Add autocopy option to forward (autocopy = Enable | Disable)
KNOWN BUGS
Windows Users:
You need to set a TZ variable to your timezone for the date calculations to work correctly. To do this, open the properties of "My Computer" and set a SYSTEM variable TZ to your timezone. I suggest using the form "EST5EDT" so you don't have to change it every 6 months when going to or from daylight savings time.
SSL/HTTPS Notes:
If you receive the message: "501 Protocol scheme 'https' is not supported" you do not have SSL installed and Pager::SkyTel will not be able to communicate with the SkyTel web server. Pager::SkyTel uses LWP::UserAgent for it's https support which in turn uses either IO::Socket::SSL or Crypt::SSLeay. Therefore, if you install one of them, things should work much better. See the README.SSL file which comes with LWP::UserAgent (in the libwww-perl package.)
PUBLIC CONSTANTS
SkyTel::TEXT
Used to indicate the type of forwarding is text.
SkyTel::VOICE
Used to indicate the type of forwarding is voice.
SkyTel::COPY_ENABLE
Used to enable autocopy
SkyTel::COPY_DISABLE
Used to disable autocopy
PUBLIC METHODS
new
my $skytel = SkyTel->new( $username, $password );
Creates a new SkyTel object.
METHOD TYPE: Constructor
PARAMETERS:
$username - The PIN number of your skytel account. $password - The password for your account
RETURN VALUES: a new SkyTel object or undef if could not login with username/password.
getError
$errorString = $skytel->getError;
Returns the error message associated with the last error condition for the object.
forward_all
my $success = $skytel->forward_all( $pin );
Forwards this account's text and messages to the specified account.
METHOD TYPE: Instance
PARAMETERS:
$pin - Forwarding account pin number
$date - Date that forwarding expires (max=1 month after today)
$autocopy - COPY_ENABLE | COPY_DISABLE
RETURN VALUES: 1 if successfully forwarded in, undef if failure.
forward_text
my $success = $skytel->forward_text( $pin );
Forwards this account's text messages to the specified account.
METHOD TYPE: Instance
PARAMETERS:
$pin - Forwarding account pin number
$date - Date that forwarding expires (max=1 month after today)
$autocopy - COPY_ENABLE | COPY_DISABLE
RETURN VALUES: 1 if successfully forwarded in, undef if failure.
forward_voice
my $success = $skytel->forward_voice( $pin );
Forwards this account's voice messages to the specified account.
METHOD TYPE: Instance
PARAMETERS:
$pin - Forwarding account pin number
$date - Date that forwarding expires (max=1 month after today)
$autocopy - COPY_ENABLE | COPY_DISABLE
RETURN VALUES: 1 if successfully forwarded in, undef if failure.
setDebug
SkyTel::setDebug(1) #on
SkyTel::setDebug(0) #off
Turn on of off debugging.
PROTECTED METHODS
_forward
$success = $skytel->_forward( $forward_url )
Submits the $forward_url and returns the result. Uses the currently set cookies for login state and updates the cookies with the new server response.
_setError
$skytel->_setError( $error_message )
Sets an error for this object.
RETURNS: undef
_login
my $success = $skytel->_login;
Logs into the skytel web server. If error, sets $self->{error} with error message.
METHOD TYPE: Instance
PARAMETERS: None
RETURN VALUES: 1 if successfully logged in, undef if failure.