AXL-Client-Simple
view release on metacpan or search on metacpan
lib/AXL/Client/Simple/Phone.pm view on Meta::CPAN
package AXL::Client::Simple::Phone;
use Moose;
use AXL::Client::Simple::LineResultSet;
use Carp;
our $VERSION = '0.01';
$VERSION = eval $VERSION; # numify for warning-free dev releases
has client => (
is => 'ro',
isa => 'AXL::Client::Simple',
required => 1,
weak_ref => 1,
);
has stash => (
is => 'ro',
isa => 'HashRef',
required => 1,
);
has currentProfileName => (
is => 'ro',
isa => 'Str',
required => 0,
lazy_build => 1,
);
sub _build_currentProfileName { return (shift)->stash->{currentProfileName} }
has loginUserId => (
is => 'ro',
isa => 'Str',
required => 0,
lazy_build => 1,
);
sub _build_loginUserId { return (shift)->stash->{loginUserId} }
sub has_active_em {
my $self = shift;
return ($self->currentProfileName && $self->loginUserId);
}
has currentProfile => (
is => 'ro',
isa => 'AXL::Client::Simple::Phone',
lazy_build => 1,
);
sub _build_currentProfile {
my $self = shift;
return $self if not $self->has_active_em;
my $profile = $self->client->getDeviceProfile->(
profileName => $self->currentProfileName);
if (exists $profile->{'Fault'}) {
my $f = $profile->{'Fault'}->{'faultstring'};
croak "Fault status returned from server in _build_currentProfile: $f\n";
}
return AXL::Client::Simple::Phone->new({
client => $self->client,
stash => $profile->{'parameters'}->{'return'}->{'profile'},
});
}
has lines => (
is => 'ro',
isa => 'AXL::Client::Simple::LineResultSet',
lazy_build => 1,
);
sub _build_lines {
my $self = shift;
my @lines = map { { stash => $_ } }
map { defined $_ ? $_ : () }
map { $_->{'parameters'}->{'return'}->{'directoryNumber'} }
map { $self->client->getLine->(uuid => $_) }
map { $_->{'dirn'}->{'uuid'} }
@{ $self->stash->{'lines'}->{'line'} || [] };
return AXL::Client::Simple::LineResultSet->new({items => \@lines});
}
__PACKAGE__->meta->make_immutable;
no Moose;
1;
__END__
=head1 NAME
lib/AXL/Client/Simple/Phone.pm view on Meta::CPAN
This document refers to version 0.01 of AXL::Client::Simple::Phone
=head1 SYNOPSIS
First set up your CUCM AXL client as per L<AXL::Client::Simple>:
use AXL::Client::Simple;
my $cucm = AXL::Client::Simple->new({
server => 'call-manager-server.example.com',
username => 'oliver',
password => 's3krit', # or set in $ENV{AXL_PASS}
});
Then perform simple queries on the Unified Communications server:
my $device = $cucm->get_phone('SEP001122334455');
my $lines = $device->lines;
printf "this device has %s lines.\n", $lines->count;
while ($lines->has_next) {
my $l = $lines->next;
print $l->alertingName, "\n";
print $l->extn, "\n";
}
if ($device->has_active_em) {
# extension mobility is active, so the lines are different
my $profile = $device->currentProfile;
my $profile_lines = $profile->lines;
printf "this profile has %s lines.\n", $profile_lines->count;
while ($profile_lines->has_next) {
my $l = $profile_lines->next;
print $l->alertingName, "\n";
print $l->extn, "\n";
}
}
=head1 DESCRIPTION
This module allows you to retrieve some properties of a device registered with
a Cisco Unified Communications server, including its line numbers and
extension mobility profile lines.
=head1 METHODS
=head2 CONSTRUCTOR
=head2 AXL::Client::Simple::Phone->new( \%arguments )
You would not normally call this constructor. Use the L<AXL::Client::Simple>
constructor instead.
=over 4
=item C<< client => >> C<AXL::Client::Simple> object (required)
An instance of C<AXL::Client::Simple> which has been configured with your
server location, user credentials and SOAP APIs. This will be stored as a weak
reference.
=item C<< stash => >> Hash Ref (required)
This hash reference contains the raw data returned from the Unified
Communications server when asked for properties of this device. From this
stash are retrieved data to construct each property as listed below.
=back
=head2 LINES QUERY AND RESULT SET
=head2 $device->lines
Query the Unified Communications server and retrieve phone line details for
this device.
The returned object contains the ordered collection of phone lines and is of
type C<AXL::Client::Simple::LineResultSet>. It's an iterator, so you can walk
through the list of lines (see the synposis, above). For example:
my $lines = $device->lines;
=head2 $lines->next
Provides the next item in the collection of lines, or C<undef> if there are no
more items to return. Usually used in a loop along with C<has_next> like so:
while ($lines->has_next) {
print $lines->next->alertingName, "\n"; # the alerting name field from CUCM
print $lines->next->extn, "\n"; # the phone line extension number
}
=head2 $lines->peek
Returns the next item without moving the state of the iterator forward. It
returns C<undef> if it is at the end of the collection and there are no more
items to return.
=head2 $lines->has_next
Returns a true value if there is another entry in the collection after the
current item, otherwise returns a false value.
=head2 $lines->reset
Resets the iterator's cursor, so you can walk through the entries again from
the start.
=head2 $lines->count
Returns the number of entries returned by the C<lines> server query.
=head2 $lines->items
Returns an array ref containing all the entries returned by the C<lines>
server query. They are each objects of type C<AXL::Client::Simple::Line>.
=head2 PHONE PROPERTIES
=head2 $device->currentProfileName
If the device has Extension Mobility enabled and an extension mobility profile
( run in 0.611 second using v1.01-cache-2.11-cpan-140bd7fdf52 )