bind to all IP addresses and nost just $server::ip (insecure, but convinient
[pxelator] / lib / PXElator / amt.pm
index 0a16b63..0987644 100644 (file)
@@ -6,39 +6,72 @@ use strict;
 use lib '/srv/Intel-AMT/lib/';
 use Intel::AMT::RemoteControl;
 use Intel::AMT::NetworkAdministration;
+use Intel::AMT::EventManager;
 use Data::Dump qw/dump/;
 use Regexp::Common qw/net/;
-use Net::Ping;
 
 use html;
+use ping;
+use CouchDB;
+use Carp qw/confess/;
 
-sub info {
-       my $amt = shift;
+sub ip {
+       my ( $client_ip, $amt ) = @_;
+       return unless $client_ip;
+       $amt ||= client::conf( $client_ip => 'amt' );
        my ( $passwd, $ip ) = split(/\s+/, $amt);
        ( $ip, $passwd ) = ( $passwd, $ip ) if $passwd =~ m/$RE{net}{IPv4}/;
 
-       my $p = Net::Ping->new;
+       $ip ||= $client_ip;
 
-       if ( ! $p->ping( $ip, 0.7 ) ) {
-               return "$ip unreachable";
-       }
+       $ENV{AMT_PASSWORD} = $passwd;
+       $ENV{AMT_HOST} = $ip;
+}
 
-       warn "amt $ip ", '*' x length($passwd), "\n";
+sub power_state {
+       my $state = eval { Intel::AMT::RemoteControl::SystemPowerState };
+       CouchDB::audit('SystemPowerState', { ip => $ENV{AMT_HOST}, SystemPowerState => $state });
+       return $state;
+}
 
-       $ENV{AMT_HOST} = $ip;
-       $ENV{AMT_PASSWORD} = $passwd;
+sub power_on {
+       ip @_;
+       my $state = power_state;
+       defined $state && ( $state & 0x0f ) == 0;
+}
+
+sub network {
+       ip @_;
 
-       my $out;
+       my $amt = eval { Intel::AMT::NetworkAdministration::network_settings };
+       if ( $@ ) {
+               warn "ERROR $@";
+       } else {
+               $amt->{ip} = $ENV{AMT_HOST};
+               CouchDB::audit('log', $amt );
+       }
+       $amt;
+}
 
-       $out = qq|power: S| . Intel::AMT::RemoteControl::SystemPowerState
-               . qq|<br>|
-               . qq| <a href="http://$ip:16992/" target="$ip">amt</a>|
-               . qq| <a href="http://$ip:16992/ip.htm" target="$ip">ip</a>|
-               . qq|<br>|
-               . html::pre_dump( Intel::AMT::NetworkAdministration::network_settings )
-               ;
+sub log {
+       ip @_;
+
+       my $amt = eval { Intel::AMT::EventManager::ReadEventLogRecords };
+       if ( $@ ) {
+               warn "ERROR $@";
+       } else {
+               $amt->{ip} = $ENV{AMT_HOST};
+               CouchDB::audit('log', $amt );
+       }
+       $amt;
+}
 
-       return $out;
+sub RemoteControl {
+       ip shift;
+       my $command = shift;
+       eval { Intel::AMT::RemoteControl::run( $command ) };
+       CouchDB::audit( $command, { ip => $ENV{AMT_HOST}, error => $@ } );
+       warn "ERROR $@" if $@;
 }
 
 1;