| version 1.7, 2006/06/28 23:33:18 | version 1.13, 2006/09/07 03:39:36 | 
|  |  | 
| package Net::Telnet::Trango; | package Net::Telnet::Trango; | 
| # $RedRiver: Trango.pm,v 1.6 2006/06/28 22:00:15 andrew Exp $ | # $RedRiver: Trango.pm,v 1.12 2006/08/31 21:29:53 andrew Exp $ | 
| use strict; | use strict; | 
| use warnings; | use warnings; | 
| use base 'Net::Telnet'; | use base 'Net::Telnet'; | 
|  |  | 
|  |  | 
| Same as new from L<Net::Telnet> but has defaults for the trango 'Prompt' | Same as new from L<Net::Telnet> but has defaults for the trango 'Prompt' | 
|  |  | 
|  | It also takes an optional parameter 'Decode'.  If not defined it | 
|  | defaults to 1, if it is set to 0, it will not decode the output and | 
|  | instead return an array of the lines that were returned from the | 
|  | command. | 
|  |  | 
| =cut | =cut | 
|  |  | 
| sub new | sub new | 
|  |  | 
| foreach my $key (keys %args) { | foreach my $key (keys %args) { | 
| $PRIVATE{$key} = $args{$key}; | $PRIVATE{$key} = $args{$key}; | 
| } | } | 
|  | $PRIVATE{'Decode'} = 1 unless defined $PRIVATE{'Decode'}; | 
|  | delete $args{'Decode'}; | 
|  |  | 
| my $self = $class->SUPER::new(%args); | my $self = $class->SUPER::new(%args); | 
| bless $self if ref $self; | bless $self if ref $self; | 
|  |  | 
|  |  | 
| returns an array ref of hashes containing each log line. | returns an array ref of hashes containing each log line. | 
|  |  | 
|  | =item save_sudb | 
|  |  | 
|  | returns true on success, undef on failure | 
|  |  | 
|  | =item syslog | 
|  |  | 
|  | returns the output from the syslog command | 
|  |  | 
|  | =item pipe | 
|  |  | 
|  | returns the output from the pipe command | 
|  |  | 
|  | =item maclist | 
|  |  | 
|  | returns the output from the maclist command | 
|  |  | 
|  | =item maclist_reset | 
|  |  | 
|  | resets the maclist.  No useful output. | 
|  |  | 
|  | =item eth_list | 
|  |  | 
|  | returns the output from the eth list command | 
|  |  | 
| =cut | =cut | 
|  |  | 
|  |  | 
|  |  | 
| sulog       => { decode => 'sulog', expect => $success }, | sulog       => { decode => 'sulog', expect => $success }, | 
| 'exit'      => { no_prompt => 1, cmd_disconnects => 1 }, | 'exit'      => { no_prompt => 1, cmd_disconnects => 1 }, | 
| reboot      => { no_prompt => 1, cmd_disconnects => 1 }, | reboot      => { no_prompt => 1, cmd_disconnects => 1 }, | 
| sudb_save   => { String => "sudb save", expect => $success }, | save_sudb   => { String => 'save sudb', expect => $success }, | 
|  | syslog      => { expect => $success }, | 
|  | 'pipe'      => { }, # XXX needs a special decode | 
|  | maclist     => { decode => 'maclist' }, | 
|  | maclist_reset => { String => 'maclist reset', expect => 'done' }, | 
|  | eth_link    => { String => 'eth link', expect => $success }, | 
|  | # eth r, w and reset??? | 
| #su password??? | #su password??? | 
| #_bootloader | #_bootloader | 
| #temp | #temp | 
|  |  | 
| ); | ); | 
| } | } | 
|  |  | 
|  | =pod | 
|  |  | 
|  | =item su_ipconfig | 
|  |  | 
|  | C<su_ipconfig( 'suid', 'new_ip', 'new_subnet', 'new_gateway' )> | 
|  |  | 
|  | =cut | 
|  |  | 
|  | sub su_ipconfig | 
|  | { | 
|  | my $self        = shift; | 
|  |  | 
|  | my $suid        = shift; | 
|  | my $new_ip      = shift; | 
|  | my $new_subnet  = shift; | 
|  | my $new_gateway = shift; | 
|  |  | 
|  | return undef unless $suid =~ /^\d+$/; | 
|  | return undef unless $new_ip; | 
|  | return undef unless $new_subnet; | 
|  | return undef unless $new_gateway; | 
|  |  | 
|  | # su ipconfig <suid> <new ip> <new subnet> <new gateway> | 
|  | return $self->cmd(String => 'su ipconfig ' . | 
|  | $suid       . ' ' . | 
|  | $new_ip     . ' ' . | 
|  | $new_subnet . ' ' . | 
|  | $new_gateway, | 
|  | expect => $success, | 
|  | ); | 
|  | } | 
|  |  | 
| =pod | =pod | 
|  |  | 
| =item sudb_view | =item sudb_view | 
|  |  | 
|  |  | 
| return undef unless @lines; | return undef unless @lines; | 
|  |  | 
|  | unless ($PRIVATE{'Decode'}) { | 
|  | return @lines; | 
|  | } | 
|  |  | 
| my @sus; | my @sus; | 
| foreach (@lines) { | foreach (@lines) { | 
|  | next unless $_; | 
| if (/^\[(\d+)\]\s+(\d+)\s+(\d+)\s+(\d+)\s+([0-9A-Fa-f\s]+)$/) { | if (/^\[(\d+)\]\s+(\d+)\s+(\d+)\s+(\d+)\s+([0-9A-Fa-f\s]+)$/) { | 
| my %s = ( | my %s = ( | 
| suid => $1, | suid => $1, | 
|  |  | 
|  |  | 
| and returns true on success or undef otherwise. | and returns true on success or undef otherwise. | 
|  |  | 
| You should sudb_save() after calling this, or your changes  will be lost | You should save_sudb() after calling this, or your changes  will be lost | 
| when the AP is rebooted. | when the AP is rebooted. | 
|  |  | 
| =cut | =cut | 
|  |  | 
| Takes either 'all' or the  suid of the su to delete | Takes either 'all' or the  suid of the su to delete | 
| and returns true on success or undef otherwise. | and returns true on success or undef otherwise. | 
|  |  | 
| You should sudb_save() after calling this, or your changes  will be lost | You should save_sudb() after calling this, or your changes  will be lost | 
| when the AP is rebooted. | when the AP is rebooted. | 
|  |  | 
| =cut | =cut | 
|  |  | 
| return $self->cmd( String => 'sudb delete ' . $suid, expect => $success ); | return $self->cmd( String => 'sudb delete ' . $suid, expect => $success ); | 
| } | } | 
|  |  | 
|  |  | 
| =pod | =pod | 
|  |  | 
| =item sudb_modify | =item sudb_modify | 
|  |  | 
|  |  | 
| su2su takes a group id parameter that is in hex. | su2su takes a group id parameter that is in hex. | 
|  |  | 
| You should sudb_save() after calling this, or your changes  will be lost | You should save_sudb() after calling this, or your changes  will be lost | 
| when the AP is rebooted. | when the AP is rebooted. | 
|  |  | 
| =cut | =cut | 
|  |  | 
| ); | ); | 
|  |  | 
| my %cfg; | my %cfg; | 
| if (@_ == 2) { | if (@_ == 1) { | 
| $cfg{'String'} = shift; | $cfg{'String'} = shift; | 
| } elsif (@_ > 2) { | } elsif (@_ > 1) { | 
| %cfg = @_; | %cfg = @_; | 
| } | } | 
|  |  | 
|  |  | 
| $self->last_lines(\@lines); | $self->last_lines(\@lines); | 
|  |  | 
| my $vals = 1; | my $vals = 1; | 
| if ($cfg{'decode'}) { | if ($PRIVATE{'Decode'} && $cfg{'decode'}) { | 
| if ($cfg{'decode'} eq 'each') { | if ($cfg{'decode'} eq 'each') { | 
| $vals = _decode_each_line(@lines); | $vals = _decode_each_line(@lines); | 
| } elsif ($cfg{'decode'} eq 'sulog') { | } elsif ($cfg{'decode'} eq 'sulog') { | 
| $vals = _decode_sulog(@lines); | $vals = _decode_sulog(@lines); | 
|  | } elsif ($cfg{'decode'} eq 'maclist') { | 
|  | $vals = _decode_maclist(@lines); | 
| } else { | } else { | 
| $vals = _decode_lines(@lines); | $vals = _decode_lines(@lines); | 
| } | } | 
|  |  | 
| $self->is_connected(0); | $self->is_connected(0); | 
| } | } | 
|  |  | 
| if ($cfg{'decode'}) { | if ($PRIVATE{'Decode'} && $cfg{'decode'}) { | 
| return $vals; | return $vals; | 
| } else { | } else { | 
| return @lines; | return @lines; | 
|  |  | 
| } | } | 
| } | } | 
| return \@decoded; | return \@decoded; | 
|  | } | 
|  |  | 
|  | #=item _decode_maclist | 
|  |  | 
|  | sub _decode_maclist | 
|  | { | 
|  | my @lines = @_; | 
|  | my @decoded; | 
|  | my $total_entries = 0; | 
|  | my $current_tm = 0; | 
|  | foreach my $line (@lines) { | 
|  | $line =~ s/\r?\n$//; | 
|  | my ($mac, $loc, $tm) = $line =~ / | 
|  | ([0-9a-fA-F ]{17})\s+ | 
|  | (.*)\s+ | 
|  | tm\s+ | 
|  | (\d+) | 
|  | /x; | 
|  |  | 
|  | if ($mac) { | 
|  | $mac =~ s/\s+//g; | 
|  | $loc =~ s/^\s+//; | 
|  | $loc =~ s/\s+$//; | 
|  |  | 
|  | my $suid = undef; | 
|  | if ($loc =~ /suid\s+=\s+(\d+)/) { | 
|  | $suid = $1; | 
|  | $loc = undef; | 
|  | } | 
|  |  | 
|  | push @decoded, { | 
|  | mac  => $mac, | 
|  | loc  => $loc, | 
|  | tm   => $tm, | 
|  | suid => $suid, | 
|  | cur_tm => \$current_tm, | 
|  | }; | 
|  | } elsif ($line =~ /(\d+)\s+entries/) { | 
|  | $total_entries = $1; | 
|  | } elsif ($line =~ /current tm = (\d+)\s+sec/) { | 
|  | $current_tm = $1 | 
|  | } | 
|  | } | 
|  | if (scalar @decoded == $total_entries) { | 
|  | return \@decoded; | 
|  | } else { | 
|  | # XXX we should have a way to set last error, not sure why we don't | 
|  | return undef; | 
|  | } | 
| } | } | 
|  |  | 
| 1; | 1; |