6 |
use lib '/srv/Intel-AMT/lib/'; |
use lib '/srv/Intel-AMT/lib/'; |
7 |
use Intel::AMT::RemoteControl; |
use Intel::AMT::RemoteControl; |
8 |
use Intel::AMT::NetworkAdministration; |
use Intel::AMT::NetworkAdministration; |
9 |
|
use Intel::AMT::EventManager; |
10 |
use Data::Dump qw/dump/; |
use Data::Dump qw/dump/; |
11 |
use Regexp::Common qw/net/; |
use Regexp::Common qw/net/; |
12 |
|
|
13 |
use html; |
use html; |
14 |
use ping; |
use ping; |
15 |
use CouchDB; |
use store; |
16 |
use Carp qw/confess/; |
use Carp qw/confess/; |
17 |
|
|
18 |
sub ip { |
sub ip { |
19 |
my $client_ip = shift || confess "no ip"; |
my ( $client_ip, $amt ) = @_; |
20 |
my ( $passwd, $ip ) = split(/\s+/, client::conf( $client_ip => 'amt' )); |
return unless $client_ip; |
21 |
|
$amt ||= client::conf( $client_ip => 'amt' ); |
22 |
|
my ( $passwd, $ip ) = split(/\s+/, $amt); |
23 |
( $ip, $passwd ) = ( $passwd, $ip ) if $passwd =~ m/$RE{net}{IPv4}/; |
( $ip, $passwd ) = ( $passwd, $ip ) if $passwd =~ m/$RE{net}{IPv4}/; |
24 |
|
|
25 |
$ip ||= $client_ip; |
$ip ||= $client_ip; |
26 |
|
|
|
if ( ! ping::host( $ip ) ) { |
|
|
warn "W: ping $ip unreachable\n"; |
|
|
} |
|
|
|
|
|
warn "amt $ip ", '*' x length($passwd), "\n"; |
|
|
|
|
27 |
$ENV{AMT_PASSWORD} = $passwd; |
$ENV{AMT_PASSWORD} = $passwd; |
28 |
$ENV{AMT_HOST} = $ip; |
$ENV{AMT_HOST} = $ip; |
29 |
|
|
30 |
} |
my $hostname = client::conf( $client_ip => 'hostname' ) || $client_ip; |
31 |
|
|
32 |
sub power_on { |
client::conf( $ip => 'hostname', default => "amt-$hostname" ); |
33 |
ip @_; |
|
34 |
power_state() == 0; |
return $ip; |
35 |
} |
} |
36 |
|
|
37 |
sub power_state { |
sub power_state { |
38 |
my $state = eval { Intel::AMT::RemoteControl::SystemPowerState }; |
my $state = eval { Intel::AMT::RemoteControl::SystemPowerState }; |
39 |
CouchDB::audit('SystemPowerState', { ip => $ENV{AMT_HOST}, SystemPowerState => $state }); |
store::audit('SystemPowerState', { ip => $ENV{AMT_HOST}, SystemPowerState => $state }); |
40 |
return $state; |
return $state; |
41 |
} |
} |
42 |
|
|
43 |
sub info { |
sub power_on { |
44 |
ip @_; |
ip @_; |
45 |
|
my $state = power_state; |
46 |
|
defined $state && ( $state & 0x0f ) == 0; |
47 |
|
} |
48 |
|
|
49 |
my $amt; |
sub network { |
50 |
eval { |
ip @_; |
|
$amt = Intel::AMT::NetworkAdministration::network_settings; |
|
|
$amt->{power_state} = Intel::AMT::RemoteControl::SystemPowerState; |
|
|
CouchDB::audit('network', $amt ); |
|
|
}; |
|
|
warn "ERROR amt $@" if $@; |
|
|
|
|
|
my $out; |
|
|
my $ip = $ENV{AMT_HOST}; |
|
|
|
|
|
$out = |
|
|
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( $amt ) |
|
|
; |
|
51 |
|
|
52 |
return $out; |
my $amt = eval { Intel::AMT::NetworkAdministration::network_settings }; |
53 |
|
if ( $@ ) { |
54 |
|
warn "ERROR $@"; |
55 |
|
} else { |
56 |
|
$amt->{ip} = $ENV{AMT_HOST}; |
57 |
|
store::audit('log', $amt ); |
58 |
|
} |
59 |
|
$amt; |
60 |
} |
} |
61 |
|
|
62 |
|
sub log { |
63 |
|
ip @_; |
64 |
|
|
65 |
|
my $amt = eval { Intel::AMT::EventManager::ReadEventLogRecords }; |
66 |
|
if ( $@ ) { |
67 |
|
warn "ERROR $@"; |
68 |
|
} else { |
69 |
|
$amt->{ip} = $ENV{AMT_HOST}; |
70 |
|
store::audit('log', $amt ); |
71 |
|
} |
72 |
|
$amt; |
73 |
|
} |
74 |
|
|
75 |
sub RemoteControl { |
sub RemoteControl { |
76 |
ip shift; |
ip shift; |
77 |
my $command = shift; |
my $command = shift; |
78 |
eval { Intel::AMT::RemoteControl::run( $command ) }; |
eval { Intel::AMT::RemoteControl::run( $command ) }; |
79 |
CouchDB::audit( $command, { ip => $ENV{AMT_HOST}, error => $@ } ); |
store::audit( $command, { ip => $ENV{AMT_HOST}, error => $@ } ); |
80 |
warn "ERROR $@" if $@; |
warn "ERROR $@" if $@; |
81 |
} |
} |
82 |
|
|