Net-Cisco-ISE
view release on metacpan or search on metacpan
lib/Net/Cisco/ISE.pm view on Meta::CPAN
package Net::Cisco::ISE;
use strict;
use Moose;
# REST IO stuff here
use IO::Socket::SSL qw( SSL_VERIFY_NONE );
use LWP::UserAgent;
use XML::Simple;
# Generics
use MIME::Base64;
use URI::Escape;
use Data::Dumper;
# Net::Cisco::ISE::*
use lib qw(.);
use Net::Cisco::ISE::InternalUser;
use Net::Cisco::ISE::IdentityGroup;
use Net::Cisco::ISE::NetworkDevice;
use Net::Cisco::ISE::NetworkDeviceGroup;
#use Net::Cisco::ISE::Endpoint;
#use Net::Cisco::ISE::EndpointCertificate;
#use Net::Cisco::ISE::EndpointIdentityGroup;
#use Net::Cisco::ISE::Portal;
#use Net::Cisco::ISE::Profile;
BEGIN {
use Exporter ();
use vars qw($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS $ERROR %actions);
$VERSION = '0.06';
@ISA = qw(Exporter);
@EXPORT = qw();
@EXPORT_OK = qw();
%EXPORT_TAGS = ();
$ERROR = ""; # TODO: Document error properly!
}
# Moose!
has 'ssl_options' => (
is => 'rw',
isa => 'HashRef',
default => sub { { 'SSL_verify_mode' => SSL_VERIFY_NONE, 'verify_hostname' => '0' } }
);
has 'ssl' => (
is => 'rw',
isa => 'Str',
default => '1',
);
has 'hostname' => (
is => 'rw',
isa => 'Str',
required => '1',
);
has 'port' => (
is => 'rw',
isa => 'Str',
default => '9060'
);
has 'mock' => (
is => 'rw',
lib/Net/Cisco/ISE.pm view on Meta::CPAN
print "Record ID is $id" if $id;
print $Net::Cisco::ISE::ERROR unless $id;
# $Net::Cisco::ISE::ERROR contains details about failure
Multiple instances can be passed as an argument. Objects will be updated in bulk (one transaction). The returned ID is not guaranteed to be the IDs of the created objects.
my $user = $ise->internalusers("name","admin");
$user->id(0); # Required for new user!
$user->password("TopSecret"); # Password policies will be enforced!
my $user2 = $ise->internalusers("name","admin2");
$user2->password("TopSecret"); # Password policies will be enforced!
my $id = $ise->update($user,$user2);
# Update users based on Net::Cisco::ISE::InternalUser instances in arguments
# Return value is ID generated by ISE but not guaranteed.
# print "Record ID is $id" if $id;
# print $Net::Cisco::ISE::ERROR unless $id;
# $Net::Cisco::ISE::ERROR contains details about failure
my $device = $ise->networkdevices("name","Main_Router");
$device->description("Main Router");
$device->ips([{netMask => "32", ipAddress=>"10.0.0.1"}]); # Change IP address! Overlap check is enforced!
my $device2 = $ise->networkdevices("name","Alt_Router");
$device2->description("Standby Router");
$device2->ips([{netMask => "32", ipAddress=>"10.0.0.2"}]); # Change IP address! Overlap check is enforced!
my $id = $ise->create($device,$device2);
# Update devices based on Net::Cisco::ISE::NetworkDevice instances in arguments
# Return value is ID generated by ISE but not guaranteed.
# print "Record ID is $id" if $id;
# print $Net::Cisco::ISE::ERROR unless $id;
# $Net::Cisco::ISE::ERROR contains details about failure
=item delete
This method deletes an existing entry in Cisco ISE, depending on the argument passed. Record type is detected automatically.
my $user = $ise->internalusers("name","admin");
$ise->delete($user);
=item $ERROR
This variable will contain detailed error information, based on the REST API answer. This value is reset during every call to C<internalusers> and C<identitygroups>.
=back
=head1 REQUIREMENTS
For this library to work, you need an instance with Cisco ISE (obviously) or a simulator like L<Net::Cisco::ISE::Mock>.
Instructions on enabling Cisco ISE for API access will be added later.
You will also need
=over 3
=item L<Moose>
=item L<IO::Socket::SSL>
=item L<LWP::UserAgent>
=item L<XML::Simple>
=item L<MIME::Base64>
=item L<URI::Escape>
=back
=head1 BUGS
None so far
=head1 SUPPORT
None so far :)
=head1 AUTHOR
Hendrik Van Belleghem
CPAN ID: BEATNIK
hendrik.vanbelleghem@gmail.com
=head1 COPYRIGHT
This program is free software licensed under the...
The General Public License (GPL)
Version 2, June 1991
The full text of the license can be found in the
LICENSE file included with this module.
=head1 COMPATIBILITY
Certain API calls are not support from Cisco ISE 5.0 onwards. The current supported versions of Cisco ISE (by Cisco) are 5.6, 5.7 and 5.8 (Active).
=head1 SEE ALSO
=over 3
See L<Net::Cisco::ISE::InternalUser> for more information on User management.
See L<Net::Cisco::ISE::IdentityGroup> for more information on User Group management.
See L<Net::Cisco::ISE::NetworkDevice> for more information on Device management.
See L<Net::Cisco::ISE::NetworkDeviceGroup> for more information on Device Group management.
See the L<Cisco ISE product page|http://www.cisco.com/c/en/us/products/security/identity-services-engine/index.html> for more information.
L<Net::Cisco::ISE> relies on L<Moose>.
=back
=cut
#################### main pod documentation end ###################
( run in 1.693 second using v1.01-cache-2.11-cpan-39bf76dae61 )