migrate powershell with json

This commit is contained in:
garnier-quentin 2020-06-17 16:46:50 +02:00
parent b55663a1a6
commit d9ca85b4ef
26 changed files with 788 additions and 419 deletions

View File

@ -26,6 +26,8 @@ use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::listnodevms; use centreon::common::powershell::hyperv::2012::listnodevms;
use apps::hyperv::2012::local::mode::resources::types qw($node_vm_state);
use JSON::XS;
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
@ -39,7 +41,7 @@ sub new {
'command-options:s' => { name => 'command_options', default => '-InputFormat none -NoLogo -EncodedCommand' }, 'command-options:s' => { name => 'command_options', default => '-InputFormat none -NoLogo -EncodedCommand' },
'no-ps' => { name => 'no_ps' }, 'no-ps' => { name => 'no_ps' },
'ps-exec-only' => { name => 'ps_exec_only' }, 'ps-exec-only' => { name => 'ps_exec_only' },
'ps-display' => { name => 'ps_display' }, 'ps-display' => { name => 'ps_display' }
}); });
return $self; return $self;
@ -50,6 +52,25 @@ sub check_options {
$self->SUPER::init(%options); $self->SUPER::init(%options);
} }
sub manage_selection {
my ($self, %options) = @_;
#[
# { "name": "XXXX1", "state": 2, "status": "Operating normally", "is_clustered": true, "note": null },
# { "name": "XXXX2", "state": 2, "status": "Operating normally", "is_clustered": false, "note": null },
# { "name": "XXXX3", "state": 2, "status": "Operating normally", "is_clustered": true, "note": null }
#]
my $decoded;
eval {
$decoded = JSON::XS->new->utf8->decode($options{stdout});
};
if ($@) {
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
$self->{output}->option_exit();
}
return $decoded;
}
sub run { sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -82,9 +103,20 @@ sub run {
} else { } else {
$self->{output}->output_add( $self->{output}->output_add(
severity => 'OK', severity => 'OK',
short_msg => 'List Virtual Machines:' short_msg => 'List virtual machines:'
); );
centreon::common::powershell::hyperv::2012::listnodevms::list($self, stdout => $stdout);
my $decoded = $self->manage_selection(stdout => $stdout);
foreach my $node (@$decoded) {
$self->{output}->output_add(
long_msg => sprintf(
"'%s' [state = %s] [status = %s]",
$node->{name},
$node_vm_state->{ $node->{state} },
$node->{status}
)
);
}
} }
$self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1); $self->{output}->display(nolabel => 1, force_ignore_perfdata => 1, force_long_output => 1);
@ -112,7 +144,18 @@ sub disco_show {
command_path => $self->{option_results}->{command_path}, command_path => $self->{option_results}->{command_path},
command_options => $self->{option_results}->{command_options} command_options => $self->{option_results}->{command_options}
); );
centreon::common::powershell::hyperv::2012::listnodevms::disco_show($self, stdout => $stdout);
my $decoded = $self->manage_selection(stdout => $stdout);
foreach my $node (@$decoded) {
$self->{output}->add_disco_entry(
name => $node->{name},
state => $node_vm_state->{ $node->{state} },
status => $node->{status},
is_clustered => $node->{is_clustered} =~ /True|1/i ? 1 : 0,
note => defined($node->{note}) ? $node->{note} : ''
);
}
} }
1; 1;

View File

@ -26,40 +26,20 @@ use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::nodeintegrationservice; use centreon::common::powershell::hyperv::2012::nodeintegrationservice;
use apps::hyperv::2012::local::mode::resources::types qw($node_vm_state $node_vm_integration_service_operational_status);
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
use JSON::XS;
sub custom_service_status_output { sub custom_service_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = 'status : ' . $self->{result_values}->{primary_status} . '/' . $self->{result_values}->{secondary_status};
return $msg; return 'status: ' . $self->{result_values}->{primary_status} . '/' . $self->{result_values}->{secondary_status};
}
sub custom_service_status_calc {
my ($self, %options) = @_;
$self->{result_values}->{primary_status} = $options{new_datas}->{$self->{instance} . '_primary_status'};
$self->{result_values}->{secondary_status} = $options{new_datas}->{$self->{instance} . '_secondary_status'};
$self->{result_values}->{vm} = $options{new_datas}->{$self->{instance} . '_vm'};
$self->{result_values}->{service} = $options{new_datas}->{$self->{instance} . '_service'};
return 0;
} }
sub custom_global_status_output { sub custom_global_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = 'state/version : ' . $self->{result_values}->{integration_service_state} . '/' . $self->{result_values}->{integration_service_version};
return $msg; return 'state/version: ' . $self->{result_values}->{integration_service_state} . '/' . $self->{result_values}->{integration_service_version};
}
sub custom_global_status_calc {
my ($self, %options) = @_;
$self->{result_values}->{integration_service_state} = $options{new_datas}->{$self->{instance} . '_integration_service_state'};
$self->{result_values}->{integration_service_version} = $options{new_datas}->{$self->{instance} . '_integration_service_version'};
$self->{result_values}->{vm} = $options{new_datas}->{$self->{instance} . '_vm'};
$self->{result_values}->{state} = $options{new_datas}->{$self->{instance} . '_state'};
return 0;
} }
sub set_counters { sub set_counters {
@ -74,36 +54,34 @@ sub set_counters {
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
{ label => 'global-status', threshold => 0, set => { { label => 'global-status', threshold => 0, set => {
key_values => [ { name => 'integration_service_state' }, { name => 'integration_service_version' }, { name => 'state' }, { name => 'vm' } ], key_values => [ { name => 'integration_service_state' }, { name => 'integration_service_version' }, { name => 'state' }, { name => 'vm' } ],
closure_custom_calc => $self->can('custom_global_status_calc'),
closure_custom_output => $self->can('custom_global_status_output'), closure_custom_output => $self->can('custom_global_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
}
} }
},
]; ];
$self->{maps_counters}->{service} = [ $self->{maps_counters}->{service} = [
{ label => 'service-status', threshold => 0, set => { { label => 'service-status', threshold => 0, set => {
key_values => [ { name => 'primary_status' }, { name => 'secondary_status' }, { name => 'enabled' }, { name => 'vm' }, { name => 'service' } ], key_values => [ { name => 'primary_status' }, { name => 'secondary_status' }, { name => 'enabled' }, { name => 'vm' }, { name => 'service' } ],
closure_custom_calc => $self->can('custom_service_status_calc'),
closure_custom_output => $self->can('custom_service_status_output'), closure_custom_output => $self->can('custom_service_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
}
} }
},
]; ];
} }
sub vm_long_output { sub vm_long_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "checking virtual machine '" . $options{instance_value}->{display} . "'"; return "checking virtual machine '" . $options{instance_value}->{vm} . "'";
} }
sub prefix_vm_output { sub prefix_vm_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "VM '" . $options{instance_value}->{display} . "' "; return "VM '" . $options{instance_value}->{vm} . "' ";
} }
sub prefix_service_output { sub prefix_service_output {
@ -137,7 +115,7 @@ sub new {
'warning-global-status:s' => { name => 'warning_global_status', default => '%{integration_service_state} =~ /Update required/i' }, 'warning-global-status:s' => { name => 'warning_global_status', default => '%{integration_service_state} =~ /Update required/i' },
'critical-global-status:s' => { name => 'critical_global_status', default => '' }, 'critical-global-status:s' => { name => 'critical_global_status', default => '' },
'warning-service-status:s' => { name => 'warning_service_status', default => '' }, 'warning-service-status:s' => { name => 'warning_service_status', default => '' },
'critical-service-status:s' => { name => 'critical_service_status', default => '%{primary_status} !~ /Ok/i' }, 'critical-service-status:s' => { name => 'critical_service_status', default => '%{primary_status} !~ /Ok/i' }
}); });
return $self; return $self;
@ -183,47 +161,83 @@ sub manage_selection {
$self->{output}->exit(); $self->{output}->exit();
} }
#[name= test1 ][state= Running ][IntegrationServicesState= Update required ][IntegrationServicesVersion= 3.1 ][note= ] my $decoded;
#[service= Time Synchronization ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] eval {
#[service= Heartbeat ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] $decoded = JSON::XS->new->utf8->decode($stdout);
#[service= Key-Value Pair Exchange ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] };
#[service= Shutdown ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] if ($@) {
#[service= VSS ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] $self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
#[service= Guest Service Interface ][enabled= False][primaryOperationalStatus= Ok ][secondaryOperationalStatus= ] $self->{output}->option_exit();
#[name= test2 ][state= Running ][IntegrationServicesState= ][IntegrationServicesVersion= ][note= ] }
#[service= Time Synchronization ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ]
#[service= Heartbeat ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] #[
#[service= Key-Value Pair Exchange ][enabled= True][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] # {
#[service= Shutdown ][enabled= False][primaryOperationalStatus= NoContact ][secondaryOperationalStatus= ] # "name": "test1", "state": 2, "integration_services_state": "Update required", "integration_services_version": "3.1", "note": null,
# "services": [
# { "service": "Time Synchronization", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "Key-Value Pair Exchange", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "Shutdown", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "VSS", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "Guest Service Interface", "enabled": false, "primary_operational_status": 2, "secondary_operational_status": null }
# ]
# },
# {
# "name": "test2", "state": 2, "integration_services_state": null, "integration_services_version": null, "note": null,
# "services": [
# { "service": "Time Synchronization", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "Key-Value Pair Exchange", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "Shutdown", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "VSS", "enabled": true, "primary_operational_status": 12, "secondary_operational_status": null },
# { "service": "Guest Service Interface", "enabled": false, "primary_operational_status": 2, "secondary_operational_status": null }
# ]
# }
#]
$self->{vm} = {}; $self->{vm} = {};
my $id = 1; my $id = 1;
while ($stdout =~ /^\[name=\s*(.*?)\s*\]\[state=\s*(.*?)\s*\]\[IntegrationServicesState=\s*(.*?)\s*\]\[IntegrationServicesVersion=\s*(.*?)\s*\]\[note=\s*(.*?)\s*\](.*?)(?=\[name=|\z)/msig) { foreach my $node (@$decoded) {
my ($name, $status, $integration_service_state, $integration_service_version, $note, $content) = ($1, $2, $3, $4, $5, $6);
if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' && if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' &&
$name !~ /$self->{option_results}->{filter_vm}/i) { $node->{name} !~ /$self->{option_results}->{filter_vm}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $name . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
if (defined($self->{option_results}->{filter_status}) && $self->{option_results}->{filter_status} ne '' && if (defined($self->{option_results}->{filter_status}) && $self->{option_results}->{filter_status} ne '' &&
$status !~ /$self->{option_results}->{filter_status}/i) { $node_vm_state->{ $node->{state} } !~ /$self->{option_results}->{filter_status}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $status . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
if (defined($self->{option_results}->{filter_note}) && $self->{option_results}->{filter_note} ne '' && if (defined($self->{option_results}->{filter_note}) && $self->{option_results}->{filter_note} ne '' &&
$note !~ /$self->{option_results}->{filter_note}/i) { defined($node->{note}) && $node->{note} !~ /$self->{option_results}->{filter_note}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $note . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
$self->{vm}->{$id} = { display => $name, vm => $name, service => {} }; $self->{vm}->{$id} = {
$self->{vm}->{$id}->{global} = { vm => $node->{name},
$name => { vm => $name, integration_service_state => $integration_service_state, integration_service_version => $integration_service_version, state => $status } service => {}
}; };
$self->{vm}->{$id}->{global} = {
$node->{name} => {
vm => $node->{name},
integration_service_state => defined($node->{integration_services_state}) ? $node->{integration_services_state} : '-',
integration_service_version => defined($node->{integration_services_version}) ? $node->{integration_services_version} : '-',
state => $node_vm_state->{ $node->{state} }
}
};
my $id2 = 1; my $id2 = 1;
while ($content =~ /^\[service=\s*(.*?)\s*\]\[enabled=\s*(.*?)\s*\]\[primaryOperationalStatus=\s*(.*?)\s*\]\[secondaryOperationalStatus=\s*(.*?)\s*\]/msig) { foreach my $service (@{$node->{services}}) {
$self->{vm}->{$id}->{service}->{$id2} = { vm => $name, service => $1, enabled => $2, primary_status => $3, secondary_status => $4 }; $self->{vm}->{$id}->{service}->{$id2} = {
vm => $node->{name},
service => $service->{service},
enabled => $service->{enabled} =~ /True|1/i ? 1 : 0,
primary_status =>
defined($service->{primary_operational_status}) && defined($node_vm_integration_service_operational_status->{ $service->{primary_operational_status} }) ?
$node_vm_integration_service_operational_status->{ $service->{primary_operational_status} } : '-',
secondary_status =>
defined($service->{secondary_operational_status}) && defined($node_vm_integration_service_operational_status->{ $service->{secondary_operational_status} }) ?
$node_vm_integration_service_operational_status->{ $service->{secondary_operational_status} } : '-'
};
$id2++; $id2++;
} }

View File

@ -26,39 +26,31 @@ use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::nodereplication; use centreon::common::powershell::hyperv::2012::nodereplication;
use apps::hyperv::2012::local::mode::resources::types qw($node_replication_state);
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
use JSON::XS;
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = 'replication health : ' . $self->{result_values}->{health}; return 'replication health: ' . $self->{result_values}->{health};
return $msg;
}
sub custom_status_calc {
my ($self, %options) = @_;
$self->{result_values}->{vm} = $options{new_datas}->{$self->{instance} . '_vm'};
$self->{result_values}->{state} = $options{new_datas}->{$self->{instance} . '_state'};
$self->{result_values}->{health} = $options{new_datas}->{$self->{instance} . '_health'};
return 0;
} }
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All virtual machines are ok' }, { name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All virtual machines are ok' }
]; ];
$self->{maps_counters}->{vm} = [ $self->{maps_counters}->{vm} = [
{ label => 'status', threshold => 0, set => { { label => 'status', threshold => 0, set => {
key_values => [ { name => 'vm' }, { name => 'state' }, { name => 'health' } ], key_values => [ { name => 'vm' }, { name => 'state' }, { name => 'health' } ],
closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
}
} }
},
]; ];
} }
@ -83,7 +75,7 @@ sub new {
'ps-display' => { name => 'ps_display' }, 'ps-display' => { name => 'ps_display' },
'filter-vm:s' => { name => 'filter_vm' }, 'filter-vm:s' => { name => 'filter_vm' },
'warning-status:s' => { name => 'warning_status', default => '%{health} =~ /Warning/i' }, 'warning-status:s' => { name => 'warning_status', default => '%{health} =~ /Warning/i' },
'critical-status:s' => { name => 'critical_status', default => '%{health} =~ /Critical/i' }, 'critical-status:s' => { name => 'critical_status', default => '%{health} =~ /Critical/i' }
}); });
return $self; return $self;
@ -129,22 +121,34 @@ sub manage_selection {
$self->{output}->exit(); $self->{output}->exit();
} }
#[name= XXXX1 ][state= Running ][health= Critical ] my $decoded;
#[name= XXXX2 ][state= Running ][health= Normal ] eval {
#[name= XXXX3 ][state= Running ][health= Warning ] $decoded = JSON::XS->new->utf8->decode($stdout);
};
if ($@) {
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
$self->{output}->option_exit();
}
#[
# { "name": "XXXX1", "state": "Replicating", "health": "Critical" },
# { "name": "XXXX2", "state": "Replicating", "health": "Normal" },
# { "name": "XXXX3", "state": "Replicating", "health": "Warning" }
#]
$self->{vm} = {}; $self->{vm} = {};
my $id = 1; my $id = 1;
while ($stdout =~ /^\[name=\s*(.*?)\s*\]\[state=\s*(.*?)\s*\]\[health=\s*(.*?)\s*\].*?(?=\[name=|\z)/msig) { foreach my $node (@$decoded) {
my ($name, $status, $health) = ($1, $2, $3);
if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' && if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' &&
$name !~ /$self->{option_results}->{filter_vm}/i) { $name !~ /$self->{option_results}->{filter_vm}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $name . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $name . "': no matching filter.", debug => 1);
next; next;
} }
$self->{vm}->{$id} = { display => $name, vm => $name, state => $status, health => $health }; $self->{vm}->{$id} = {
vm => $node->{name},
state => $node_replication_state->{ $node->{state} },
health => $node->{health}
};
$id++; $id++;
} }
} }

View File

@ -26,6 +26,8 @@ use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::nodesnapshot; use centreon::common::powershell::hyperv::2012::nodesnapshot;
use apps::hyperv::2012::local::mode::resources::types qw($node_vm_state);
use JSON::XS;
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -53,19 +55,19 @@ sub set_counters {
sub custom_snapshot_output { sub custom_snapshot_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "[status = " . $self->{result_values}->{status} . "] checkpoint started '" . centreon::plugins::misc::change_seconds(value => $self->{result_values}->{snapshot}) . "' ago"; return "checkpoint started " . centreon::plugins::misc::change_seconds(value => $self->{result_values}->{snapshot}) . " ago";
} }
sub custom_backing_output { sub custom_backing_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "[status = " . $self->{result_values}->{status} . "] backing started '" . centreon::plugins::misc::change_seconds(value => $self->{result_values}->{backing}) . "' ago"; return "backing started " . centreon::plugins::misc::change_seconds(value => $self->{result_values}->{backing}) . " ago";
} }
sub prefix_vm_output { sub prefix_vm_output {
my ($self, %options) = @_; my ($self, %options) = @_;
return "VM '" . $options{instance_value}->{display} . "' "; return "VM '" . $options{instance_value}->{display} . "' [status = " . $options{instance_value}->{status} . '] ';
} }
sub new { sub new {
@ -122,43 +124,58 @@ sub manage_selection {
$self->{output}->exit(); $self->{output}->exit();
} }
#[name= ISC1-SV04404 ][state= Running ][note= ] my $decoded;
#[checkpointCreationTime= 1475502921.28734 ][type= snapshot] eval {
#[checkpointCreationTime= 1475503073.81975 ][type= backing] $decoded = JSON::XS->new->utf8->decode($stdout);
};
if ($@) {
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
$self->{output}->option_exit();
}
#[
# {
# "name": "ISC1-SV04404", "state": 2, "note": null,
# "checkpoints": [
# { "creation_time": 1475502921.28734, "type": "snapshot" },
# { "creation_time": 1475503073.81975, "type": "backing" }
# ]
# }
#]
$self->{vm} = {}; $self->{vm} = {};
my ($id, $time) = (1, time()); my ($id, $time) = (1, time());
while ($stdout =~ /^\[name=\s*(.*?)\s*\]\[state=\s*(.*?)\s*\]\[note=\s*(.*?)\s*\](.*?)(?=\[name=|\z)/msig) { foreach my $node (@$decoded) {
my ($name, $status, $note, $content) = ($1, $2, $3, $4); my ($name, $status, $note, $content) = ($1, $2, $3, $4);
my %chkpt = (backing => -1, snapshot => -1);
while ($content =~ /\[checkpointCreationTime=\s*(.*?)\s*\]\[type=\s*(.*?)\s*\]/msig) { my $checkpoint = { backing => -1, snapshot => -1 };
my ($timestamp, $type) = ($1, $2); foreach my $chkpt (@{$node->{checkpoints}}) {
$timestamp =~ s/,/\./g; $chkpt->{creation_time} =~ s/,/\./g;
$chkpt{$type} = $timestamp if ($timestamp > 0 && ($chkpt{$type} == -1 || $chkpt{$type} > $timestamp)); $checkpoint->{ $chkpt->{type} } = $chkpt->{creation_time} if ($chkpt->{creation_time} > 0 && ($checkpoint->{ $chkpt->{type} } == -1 || $checkpoint->{ $chkpt->{type} } > $chkpt->{creation_time}));
} }
next if ($chkpt{backing} == -1 && $chkpt{snapshot} == -1); next if ($checkpoint->{backing} == -1 && $checkpoint->{snapshot} == -1);
if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' && if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' &&
$name !~ /$self->{option_results}->{filter_vm}/i) { $node->{name} !~ /$self->{option_results}->{filter_vm}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $name . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
if (defined($self->{option_results}->{filter_note}) && $self->{option_results}->{filter_note} ne '' && if (defined($self->{option_results}->{filter_note}) && $self->{option_results}->{filter_note} ne '' &&
$note !~ /$self->{option_results}->{filter_note}/i) { defined($node->{note}) && $node->{note} !~ /$self->{option_results}->{filter_note}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $note . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
if (defined($self->{option_results}->{filter_status}) && $self->{option_results}->{filter_status} ne '' && if (defined($self->{option_results}->{filter_status}) && $self->{option_results}->{filter_status} ne '' &&
$status !~ /$self->{option_results}->{filter_status}/i) { $node_vm_state->{ $node->{state} } !~ /$self->{option_results}->{filter_status}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $status . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
$self->{vm}->{$id} = { $self->{vm}->{$id} = {
display => $name, display => $node->{name},
snapshot => $chkpt{snapshot} > 0 ? $time - $chkpt{snapshot} : undef, snapshot => $checkpoint->{snapshot} > 0 ? $time - $checkpoint->{snapshot} : undef,
backing => $chkpt{backing} > 0 ? $time - $chkpt{backing} : undef, backing => $checkpoint->{backing} > 0 ? $time - $checkpoint->{backing} : undef,
status => $status status => $node_vm_state->{ $node->{state} }
}; };
$id++; $id++;
} }

View File

@ -27,22 +27,13 @@ use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::nodevmstatus; use centreon::common::powershell::hyperv::2012::nodevmstatus;
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
use apps::hyperv::2012::local::mode::resources::types qw($node_vm_state);
use JSON::XS;
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = 'status : ' . $self->{result_values}->{status} . " (state: " . $self->{result_values}->{state} . ", is clustered: " . $self->{result_values}->{is_clustered} . ")"; return 'status: ' . $self->{result_values}->{status} . " (state: " . $self->{result_values}->{state} . ", is clustered: " . $self->{result_values}->{is_clustered} . ")";
return $msg;
}
sub custom_status_calc {
my ($self, %options) = @_;
$self->{result_values}->{vm} = $options{new_datas}->{$self->{instance} . '_vm'};
$self->{result_values}->{state} = $options{new_datas}->{$self->{instance} . '_state'};
$self->{result_values}->{status} = $options{new_datas}->{$self->{instance} . '_status'};
$self->{result_values}->{is_clustered} = $options{new_datas}->{$self->{instance} . '_is_clustered'};
return 0;
} }
sub set_counters { sub set_counters {
@ -54,12 +45,11 @@ sub set_counters {
$self->{maps_counters}->{vm} = [ $self->{maps_counters}->{vm} = [
{ label => 'status', threshold => 0, set => { { label => 'status', threshold => 0, set => {
key_values => [ { name => 'vm' }, { name => 'state' }, { name => 'status' }, { name => 'is_clustered' } ], key_values => [ { name => 'vm' }, { name => 'state' }, { name => 'status' }, { name => 'is_clustered' } ],
closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
}
} }
},
]; ];
} }
@ -85,7 +75,7 @@ sub new {
'filter-vm:s' => { name => 'filter_vm' }, 'filter-vm:s' => { name => 'filter_vm' },
'filter-note:s' => { name => 'filter_note' }, 'filter-note:s' => { name => 'filter_note' },
'warning-status:s' => { name => 'warning_status', default => '' }, 'warning-status:s' => { name => 'warning_status', default => '' },
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Operating normally/i' }, 'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Operating normally/i' }
}); });
return $self; return $self;
@ -131,27 +121,43 @@ sub manage_selection {
$self->{output}->exit(); $self->{output}->exit();
} }
#[name= XXXX1 ][state= Running ][status= Operating normally ][IsClustered= True ][note= ] my $decoded;
#[name= XXXX2 ][state= Running ][status= Operating normally ][IsClustered= False ][note= ] eval {
#[name= XXXX3 ][state= Running ][status= Operating normally ][IsClustered= False ][note= ] $decoded = JSON::XS->new->utf8->decode($stdout);
};
if ($@) {
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
$self->{output}->option_exit();
}
#[
# { "name": "XXXX1", "state": 2, "status": "Operating normally", "is_clustered": true, "note": null },
# { "name": "XXXX2", "state": 2, "status": "Operating normally", "is_clustered": false, "note": null },
# { "name": "XXXX3", "state": 2, "status": "Operating normally", "is_clustered": true, "note": null }
#]
$self->{vm} = {}; $self->{vm} = {};
my $id = 1; my $id = 1;
while ($stdout =~ /^\[name=\s*(.*?)\s*\]\[state=\s*(.*?)\s*\]\[status=\s*(.*?)\s*\]\[IsClustered=\s*(.*?)\s*\]\[note=\s*(.*?)\s*\].*?(?=\[name=|\z)/msig) { foreach my $node (@$decoded) {
my ($name, $state, $status, $is_clustered, $note) = ($1, $2, $3, $4, $5); my ($name, $state, $status, $is_clustered, $note) = ($1, $2, $3, $4, $5);
if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' && if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' &&
$name !~ /$self->{option_results}->{filter_vm}/i) { $node->{name} !~ /$self->{option_results}->{filter_vm}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $name . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
if (defined($self->{option_results}->{filter_note}) && $self->{option_results}->{filter_note} ne '' && if (defined($self->{option_results}->{filter_note}) && $self->{option_results}->{filter_note} ne '' &&
$note !~ /$self->{option_results}->{filter_note}/i) { defined($node->{note}) && $node->{note} !~ /$self->{option_results}->{filter_note}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $note . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
next; next;
} }
$self->{vm}->{$id} = { display => $name, vm => $name, status => $status, state => $state, is_clustered => $is_clustered }; $self->{vm}->{$id} = {
vm => $node->{name},
status => $node->{status},
state => $node_vm_state->{ $node->{state} },
is_clustered => $node->{is_clustered} =~ /True|1/i ? 1 : 0
};
$id++; $id++;
} }

View File

@ -0,0 +1,152 @@
#
# Copyright 2020 Centreon (http://www.centreon.com/)
#
# Centreon is a full-fledged industry-strength solution that meets
# the needs in IT infrastructure and application monitoring for
# service performance.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
package apps::hyperv::2012::local::mode::resources::types;
use strict;
use warnings;
use Exporter;
our $node_replication_state;
our $node_vm_integration_service_operational_status;
our $node_vm_state;
our $scvmm_vm_status;
our @ISA = qw(Exporter);
our @EXPORT_OK = qw(
$node_replication_state $node_vm_integration_service_operational_status
$node_vm_state $scvmm_vm_status
);
$node_vm_state = {
1 => 'Other',
2 => 'Running',
3 => 'Off',
4 => 'Stopping',
6 => 'Saved',
9 => 'Paused',
10 => 'Starting',
11 => 'Reset',
32773 => 'Saving',
32776 => 'Pausing',
32777 => 'Resuming',
32779 => 'FastSaved',
32780 => 'FastSaving',
32781 => 'ForceShutdown',
32782 => 'ForceReboot',
32783 => 'RunningCritical',
32784 => 'OffCritical',
32785 => 'StoppingCritical',
32786 => 'SavedCritical',
32787 => 'PausedCritical',
32788 => 'StartingCritical',
32789 => 'ResetCritical',
32790 => 'SavingCritical',
32791 => 'PausingCritical',
32792 => 'ResumingCritical',
32793 => 'FastSavedCritical',
32794 => 'FastSavingCritical'
};
$node_replication_state = {
0 => 'Disabled',
1 => 'ReadyForInitialReplication',
2 => 'InitialReplicationInProgress',
3 => 'WaitingForInitialReplication',
4 => 'Replicating',
5 => 'PreparedForFailover',
6 => 'FailedOverWaitingCompletion',
7 => 'FailedOver',
8 => 'Suspended',
9 => 'Error',
10 => 'WaitingForStartResynchronize',
11 => 'Resynchronizing',
12 => 'ResynchronizeSuspended',
13 => 'RecoveryInProgress',
14 => 'FailbackInProgress',
15 => 'FailbackComplete',
16 => 'WaitingForUpdateCompletion',
17 => 'UpdateError',
18 => 'WaitingForRepurposeCompletion',
19 => 'PreparedForSyncReplication',
20 => 'PreparedForGroupReverseReplication',
21 => 'FiredrillInProgress'
};
$node_vm_integration_service_operational_status = {
2 => 'Ok',
3 => 'Degraded',
6 => 'Error',
7 => 'NonRecoverableError',
12 => 'NoContact',
13 => 'LostCommunication',
32775 => 'ProtocolMismatch',
32782 => 'ApplicationCritical',
32783 => 'CommunicationTimedOut',
32784 => 'CommunicationFailed',
32896 => 'Disabled'
};
$scvmm_vm_status = {
0 => 'Running',
1 => 'PowerOff',
2 => 'PoweringOff',
3 => 'Saved',
4 => 'Saving',
5 => 'Restoring',
6 => 'Paused',
10 => 'DiscardSavedState',
11 => 'Starting',
12 => 'MergingDrives',
13 => 'Deleting',
14 => 'Reset',
80 => 'DiscardingDrives',
81 => 'Pausing',
100 => 'UnderCreation',
101 => 'CreationFailed',
102 => 'Stored',
103 => 'UnderTemplateCreation',
104 => 'TemplateCreationFailed',
105 => 'CustomizationFailed',
106 => 'UnderUpdate',
107 => 'UpdateFailed',
108 => 'ReplacementFailed',
109 => 'UnderReplacement',
200 => 'UnderMigration',
201 => 'MigrationFailed',
210 => 'CreatingCheckpoint',
211 => 'DeletingCheckpoint',
212 => 'RecoveringCheckpoint',
213 => 'CheckpointFailed',
214 => 'InitializingCheckpointOperation',
215 => 'FinishingCheckpointOperation',
220 => 'Missing',
221 => 'HostNotResponding',
222 => 'Unsupported',
223 => 'IncompleteVMConfig',
224 => 'UnsupportedSharedFiles',
225 => 'UnsupportedCluster',
226 => 'UnderLiveCloning',
227 => 'DbOnly',
240 => 'P2VCreationFailed',
250 => 'V2VCreationFailed'
};
1;

View File

@ -26,13 +26,14 @@ use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::scvmmintegrationservice; use centreon::common::powershell::hyperv::2012::scvmmintegrationservice;
use apps::hyperv::2012::local::mode::resources::types qw($scvmm_vm_status);
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
use JSON::XS;
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = 'VMAddition : ' . $self->{result_values}->{vmaddition}; return 'VMAddition: ' . $self->{result_values}->{vmaddition};
return $msg;
} }
sub custom_status_calc { sub custom_status_calc {
@ -40,20 +41,19 @@ sub custom_status_calc {
$self->{result_values}->{vm} = $options{new_datas}->{$self->{instance} . '_vm'}; $self->{result_values}->{vm} = $options{new_datas}->{$self->{instance} . '_vm'};
$self->{result_values}->{status} = $options{new_datas}->{$self->{instance} . '_status'}; $self->{result_values}->{status} = $options{new_datas}->{$self->{instance} . '_status'};
$self->{result_values}->{vmaddition} = $options{new_datas}->{$self->{instance} . '_vmaddition'}; $self->{result_values}->{vmaddition} = $options{new_datas}->{$self->{instance} . '_vm_addition'};
$self->{result_values}->{operatingsystemshutdownenabled} = $options{new_datas}->{$self->{instance} . '_operatingsystemshutdownenabled'}; $self->{result_values}->{operatingsystemshutdownenabled} = $options{new_datas}->{$self->{instance} . '_operating_system_shutdown_enabled'};
$self->{result_values}->{timesynchronizationenabled} = $options{new_datas}->{$self->{instance} . '_timesynchronizationenabled'}; $self->{result_values}->{timesynchronizationenabled} = $options{new_datas}->{$self->{instance} . '_time_synchronization_enabled'};
$self->{result_values}->{dataexchangeenabled} = $options{new_datas}->{$self->{instance} . '_dataexchangeenabled'}; $self->{result_values}->{dataexchangeenabled} = $options{new_datas}->{$self->{instance} . '_data_exchange_enabled'};
$self->{result_values}->{heartbeatenabled} = $options{new_datas}->{$self->{instance} . '_heartbeatenabled'}; $self->{result_values}->{heartbeatenabled} = $options{new_datas}->{$self->{instance} . '_heartbeat_enabled'};
$self->{result_values}->{backupenabled} = $options{new_datas}->{$self->{instance} . '_backupenabled'}; $self->{result_values}->{backupenabled} = $options{new_datas}->{$self->{instance} . '_backup_enabled'};
return 0; return 0;
} }
sub custom_integrationservice_output { sub custom_integrationservice_output {
my ($self, %options) = @_; my ($self, %options) = @_;
my $msg = $self->{result_values}->{output_label} . ' : ' . $self->{result_values}->{service_status};
return $msg; return $self->{result_values}->{output_label} . ': ' . $self->{result_values}->{service_status};
} }
sub custom_integrationservice_calc { sub custom_integrationservice_calc {
@ -70,64 +70,65 @@ sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All integration services are ok' }, { name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All integration services are ok' }
]; ];
$self->{maps_counters}->{vm} = [ $self->{maps_counters}->{vm} = [
{ label => 'status', , threshold => 0, set => { { label => 'status', threshold => 0, set => {
key_values => [ { name => 'vm' }, { name => 'status' }, { name => 'vmaddition' }, key_values => [ { name => 'vm' }, { name => 'status' }, { name => 'vm_addition' },
{ name => 'operatingsystemshutdownenabled' }, { name => 'timesynchronizationenabled' }, { name => 'operating_system_shutdown_enabled' }, { name => 'time_synchronization_enabled' },
{ name => 'dataexchangeenabled' }, { name => 'heartbeatenabled' }, { name => 'backupenabled' } ], { name => 'data_exchange_enabled' }, { name => 'heartbeat_enabled' }, { name => 'backup_enabled' } ],
closure_custom_calc => $self->can('custom_status_calc'), closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
} }
}, },
{ label => 'osshutdown-status', threshold => 0, set => { { label => 'osshutdown-status', threshold => 0, set => {
key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'operatingsystemshutdownenabled' } ], key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'operating_system_shutdown_enabled' } ],
closure_custom_calc => $self->can('custom_integrationservice_calc'), closure_custom_calc => $self->can('custom_integrationservice_calc'),
closure_custom_calc_extra_options => { output_label => 'Operating System Shutdown', name_status => 'operatingsystemshutdownenabled' }, closure_custom_calc_extra_options => { output_label => 'operating system shutdown', name_status => 'operating_system_shutdown_enabled' },
closure_custom_output => $self->can('custom_integrationservice_output'), closure_custom_output => $self->can('custom_integrationservice_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
} }
}, },
{ label => 'timesync-status', threshold => 0, set => { { label => 'timesync-status', threshold => 0, set => {
key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'timesynchronizationenabled' } ], key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'time_synchronization_enabled' } ],
closure_custom_calc => $self->can('custom_integrationservice_calc'), closure_custom_calc => $self->can('custom_integrationservice_calc'),
closure_custom_calc_extra_options => { output_label => 'Time Synchronization', name_status => 'timesynchronizationenabled' }, closure_custom_calc_extra_options => { output_label => 'time synchronization', name_status => 'time_synchronization_enabled' },
closure_custom_output => $self->can('custom_integrationservice_output'), closure_custom_output => $self->can('custom_integrationservice_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
} }
}, },
{ label => 'dataexchange-status', threshold => 0, set => { { label => 'dataexchange-status', threshold => 0, set => {
key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'dataexchangeenabled' } ], key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'data_exchange_enabled' } ],
closure_custom_calc => $self->can('custom_integrationservice_calc'), closure_custom_calc => $self->can('custom_integrationservice_calc'),
closure_custom_calc_extra_options => { output_label => 'Data Exchange', name_status => 'dataexchangeenabled' }, closure_custom_calc_extra_options => { output_label => 'data exchange', name_status => 'data_exchange_enabled' },
closure_custom_output => $self->can('custom_integrationservice_output'), closure_custom_output => $self->can('custom_integrationservice_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
} }
}, },
{ label => 'heartbeat-status', threshold => 0, set => { { label => 'heartbeat-status', threshold => 0, set => {
key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'heartbeatenabled' } ], key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'heartbeat_enabled' } ],
closure_custom_calc => $self->can('custom_integrationservice_calc'), closure_custom_calc => $self->can('custom_integrationservice_calc'),
closure_custom_calc_extra_options => { output_label => 'Heartbeat', name_status => 'heartbeatenabled' }, closure_custom_calc_extra_options => { output_label => 'heartbeat', name_status => 'heartbeat_enabled' },
closure_custom_output => $self->can('custom_integrationservice_output'), closure_custom_output => $self->can('custom_integrationservice_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
} }
}, },
{ label => 'backup-status', threshold => 0, set => { { label => 'backup-status', threshold => 0, set => {
key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'backupenabled' } ], key_values => [ { name => 'status' }, { name => 'vm' }, { name => 'backup_enabled' } ],
closure_custom_calc => $self->can('custom_integrationservice_calc'), closure_custom_calc => $self->can('custom_integrationservice_calc'),
closure_custom_calc_extra_options => { output_label => 'Backup', name_status => 'backupenabled' }, closure_custom_calc_extra_options => { output_label => 'backup', name_status => 'backup_enabled' },
closure_custom_output => $self->can('custom_integrationservice_output'), closure_custom_output => $self->can('custom_integrationservice_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
}
} }
},
]; ];
} }
@ -169,7 +170,7 @@ sub new {
'warning-heartbeat-status:s' => { name => 'warning_heartbeat_status', default => '' }, 'warning-heartbeat-status:s' => { name => 'warning_heartbeat_status', default => '' },
'critical-heartbeat-status:s' => { name => 'critical_heartbeat_status', default => '' }, 'critical-heartbeat-status:s' => { name => 'critical_heartbeat_status', default => '' },
'warning-backup-status:s' => { name => 'warning_backup_status', default => '' }, 'warning-backup-status:s' => { name => 'warning_backup_status', default => '' },
'critical-backup-status:s' => { name => 'critical_backup_status', default => '' }, 'critical-backup-status:s' => { name => 'critical_backup_status', default => '' }
}); });
return $self; return $self;
@ -233,32 +234,53 @@ sub manage_selection {
$self->{output}->exit(); $self->{output}->exit();
} }
#[VM= test1 ][Description= Test Descr - - pp - - aa ][Status= Running ][Cloud= ][HostGroup= All Hosts\CORP\test1 ][VMAddition= 6.3.9600.16384 ] my $decoded;
#[VM= test2 ][Description= ][Status= HostNotResponding ][Cloud= ][HostGroup= All Hosts\CORP\test2 ][VMAddition= Not Detected ] eval {
#[VM= test3 ][Description= ][Status= HostNotResponding ][Cloud= ][HostGroup= All Hosts\CORP\test3 ][VMAddition= Not Detected ] $decoded = JSON::XS->new->utf8->decode($stdout);
#[VM= test4 ][Description= ][Status= HostNotResponding ][Cloud= ][HostGroup= All Hosts\CORP\test4 ][VMAddition= Not Detected ] };
if ($@) {
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
$self->{output}->option_exit();
}
#[
# { "name": "test1", "description": "Test Descr - - pp - - aa", "status": 0, "cloud": "", "host_group_path": "All Hosts\\\CORP\\\test1", "vm_addition": "6.3.9600.16384" },
# {
# "name": "test2", "description": "", "status": 0, "cloud": "", "host_group_path": "All Hosts\\\CORP\\\test2", "vm_addition": "Not Detected",
# "operating_system_shutdown_enabled": true,
# "time_synchronization_enabled": false,
# "data_exchange_enabled": true,
# "heartbeat_enabled": false,
# "backup_enabled": true
# }
#]
$self->{vm} = {}; $self->{vm} = {};
my $id = 1; my $id = 1;
my @lines = split /\n/, $stdout; foreach my $node (@$decoded) {
foreach my $line (@lines) { $node->{hostgroup} = $node->{host_group_path};
my %values; $node->{vm} = $node->{name};
while ($line =~ /\[(.*?)=\s*(.*?)\s*\]/g) { $node->{status} = $scvmm_vm_status->{ $node->{status} };
$values{lc($1)} = $2;
foreach (('operating_system_shutdown_enabled', 'time_synchronization_enabled', 'data_exchange_enabled', 'heartbeat_enabled', 'backup_enabled')) {
$node->{$_} = ($node->{$_} =~ /True|1/i ? 1 : 0) if (defined($node->{$_}));
} }
$values{hostgroup} =~ s/\\/\//g;
my $filtered = 0; my $filtered = 0;
foreach (('vm', 'description', 'status', 'hostgroup')) { foreach (('vm', 'description', 'status', 'hostgroup')) {
if (defined($self->{option_results}->{'filter_' . $_}) && $self->{option_results}->{'filter_' . $_} ne '' && if (defined($self->{option_results}->{'filter_' . $_}) && $self->{option_results}->{'filter_' . $_} ne '' &&
$values{$_} !~ /$self->{option_results}->{'filter_' . $_}/i) { $node->{$_} !~ /$self->{option_results}->{'filter_' . $_}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $values{$_} . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
$filtered = 1; $filtered = 1;
last; last;
} }
} }
$self->{vm}->{$id} = { %values } if ($filtered == 0); next if ($filtered == 1);
$self->{vm}->{$id} = {
%$node
};
$id++; $id++;
} }
} }

View File

@ -26,20 +26,22 @@ use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::scvmmsnapshot; use centreon::common::powershell::hyperv::2012::scvmmsnapshot;
use apps::hyperv::2012::local::mode::resources::types qw($scvmm_vm_status);
use JSON::XS;
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All VM snapshots are ok' }, { name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All VM snapshots are ok' }
]; ];
$self->{maps_counters}->{vm} = [ $self->{maps_counters}->{vm} = [
{ label => 'snapshot', set => { { label => 'snapshot', set => {
key_values => [ { name => 'snapshot' }, { name => 'display' } ], key_values => [ { name => 'snapshot' }, { name => 'display' } ],
closure_custom_output => $self->can('custom_vm_output'), closure_custom_output => $self->can('custom_vm_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; }
}
} }
},
]; ];
} }
@ -75,7 +77,7 @@ sub new {
'filter-vm:s' => { name => 'filter_vm' }, 'filter-vm:s' => { name => 'filter_vm' },
'filter-description:s' => { name => 'filter_description' }, 'filter-description:s' => { name => 'filter_description' },
'filter-hostgroup:s' => { name => 'filter_hostgroup' }, 'filter-hostgroup:s' => { name => 'filter_hostgroup' },
'filter-status:s' => { name => 'filter_status', default => 'running' }, 'filter-status:s' => { name => 'filter_status', default => 'running' }
}); });
return $self; return $self;
@ -133,34 +135,54 @@ sub manage_selection {
$self->{output}->exit(); $self->{output}->exit();
} }
#[name= test-server ][description= ][status= Running ][cloud= ][hostgrouppath= All Hosts\CORP\Test\test-server ] my $decoded;
#[checkpointAddedTime= 1475502741.957 ] eval {
#[checkpointAddedTime= 1475502963.21 ] $decoded = JSON::XS->new->utf8->decode($stdout);
};
if ($@) {
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
$self->{output}->option_exit();
}
#[
# {
# "name": "test-server", "description": "", "status": 0, "cloud": "", "host_group_path": "All Hosts\\\CORP\\\Test\\\test-server",
# "checkpoints": [
# { "added_time": 1475502741.957 },
# { "added_time": 1475502963.21 }
# ]
# }
#]
$self->{vm} = {}; $self->{vm} = {};
my $id = 1; my $id = 1;
while ($stdout =~ /^\[name=\s*(.*?)\s*\]\[description=\s*(.*?)\s*\]\[status=\s*(.*?)\s*\]\[cloud=\s*(.*?)\s*\]\[hostgrouppath=\s*(.*?)\s*\](.*?)(?=\[name=|\z)/msig) { foreach my $node (@$decoded) {
my %values = (vm => $1, description => $2, status => $3, cloud => $4, hostgroup => $5); $node->{hostgroup} = $node->{host_group_path};
my $content = $6; $node->{vm} = $node->{name};
$node->{status} = $scvmm_vm_status->{ $node->{status} };
my $chkpt = -1; my $chkpt = -1;
while ($content =~ /\[checkpointAddedTime=\s*(.*?)\s*\]/msig) { foreach (@{$node->{checkpoints}}) {
$chkpt = $1 if ($chkpt == -1 || $chkpt > $1); $chkpt = $_->{added_time} if ($chkpt == -1 || $chkpt > $_->{added_time});
} }
next if ($chkpt == -1); next if ($chkpt == -1);
my $filtered = 0; my $filtered = 0;
$values{hostgroup} =~ s/\\/\//g;
foreach (('vm', 'description', 'status', 'hostgroup')) { foreach (('vm', 'description', 'status', 'hostgroup')) {
if (defined($self->{option_results}->{'filter_' . $_}) && $self->{option_results}->{'filter_' . $_} ne '' && if (defined($self->{option_results}->{'filter_' . $_}) && $self->{option_results}->{'filter_' . $_} ne '' &&
$values{$_} !~ /$self->{option_results}->{'filter_' . $_}/i) { $node->{$_} !~ /$self->{option_results}->{'filter_' . $_}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $values{$_} . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $node->{$_} . "': no matching filter.", debug => 1);
$filtered = 1; $filtered = 1;
last; last;
} }
} }
$self->{vm}->{$id} = { display => $values{vm}, snapshot => time() - $chkpt } if ($filtered == 0); next if ($filtered == 1);
$self->{vm}->{$id} = {
display => $node->{name},
snapshot => time() - $chkpt
};
$id++; $id++;
} }
} }

View File

@ -26,7 +26,9 @@ use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::plugins::misc;
use centreon::common::powershell::hyperv::2012::scvmmvmstatus; use centreon::common::powershell::hyperv::2012::scvmmvmstatus;
use apps::hyperv::2012::local::mode::resources::types qw($scvmm_vm_status);
use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold); use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold);
use JSON::XS;
sub custom_status_output { sub custom_status_output {
my ($self, %options) = @_; my ($self, %options) = @_;
@ -34,30 +36,21 @@ sub custom_status_output {
return 'status: ' . $self->{result_values}->{status}; return 'status: ' . $self->{result_values}->{status};
} }
sub custom_status_calc {
my ($self, %options) = @_;
$self->{result_values}->{vm} = $options{new_datas}->{$self->{instance} . '_vm'};
$self->{result_values}->{status} = $options{new_datas}->{$self->{instance} . '_status'};
$self->{result_values}->{hostgroup} = $options{new_datas}->{$self->{instance} . '_hostgroup'};
return 0;
}
sub set_counters { sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All virtual machines are ok' }, { name => 'vm', type => 1, cb_prefix_output => 'prefix_vm_output', message_multiple => 'All virtual machines are ok' }
]; ];
$self->{maps_counters}->{vm} = [ $self->{maps_counters}->{vm} = [
{ label => 'status', threshold => 0, set => { { label => 'status', threshold => 0, set => {
key_values => [ { name => 'vm' }, { name => 'hostgroup' }, { name => 'status' } ], key_values => [ { name => 'vm' }, { name => 'hostgroup' }, { name => 'status' } ],
closure_custom_calc => $self->can('custom_status_calc'),
closure_custom_output => $self->can('custom_status_output'), closure_custom_output => $self->can('custom_status_output'),
closure_custom_perfdata => sub { return 0; }, closure_custom_perfdata => sub { return 0; },
closure_custom_threshold_check => \&catalog_status_threshold, closure_custom_threshold_check => \&catalog_status_threshold
}
} }
},
]; ];
} }
@ -88,7 +81,7 @@ sub new {
'filter-description:s' => { name => 'filter_description' }, 'filter-description:s' => { name => 'filter_description' },
'filter-hostgroup:s' => { name => 'filter_hostgroup' }, 'filter-hostgroup:s' => { name => 'filter_hostgroup' },
'warning-status:s' => { name => 'warning_status', default => '' }, 'warning-status:s' => { name => 'warning_status', default => '' },
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Running|Stopped/i' }, 'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Running|Stopped/i' }
}); });
return $self; return $self;
@ -147,27 +140,44 @@ sub manage_selection {
$self->{output}->exit(); $self->{output}->exit();
} }
#[name= test-server ][description= ][status= Running ][cloud= ][hostgrouppath= All Hosts\CORP\Test\test-server ] my $decoded;
#[name= test-server2 ][description= ][status= Running ][cloud= ][hostgrouppath= All Hosts\CORP\Test\test-server2 ] eval {
$decoded = JSON::XS->new->utf8->decode($stdout);
};
if ($@) {
$self->{output}->add_option_msg(short_msg => "Cannot decode json response: $@");
$self->{output}->option_exit();
}
#[
# { "name": "test-server", "description": "", "status": 0, "cloud": "", "host_group_path": "All Hosts\\\CORP\\\Test\\\test-server" },
# { "name": "test-server2", "description": "", "status": 0, "cloud": "", "host_group_path": "All Hosts\\\CORP\\\Test\\\test-server2" }
#]
$self->{vm} = {}; $self->{vm} = {};
my $id = 1; my $id = 1;
while ($stdout =~ /^\[name=\s*(.*?)\s*\]\[description=\s*(.*?)\s*\]\[status=\s*(.*?)\s*\]\[cloud=\s*(.*?)\s*\]\[hostgrouppath=\s*(.*?)\s*\].*?(?=\[name=|\z)/msig) { foreach my $node (@$decoded) {
my %values = (vm => $1, description => $2, status => $3, cloud => $4, hostgroup => $5); if (defined($self->{option_results}->{filter_vm}) && $self->{option_results}->{filter_vm} ne '' &&
$node->{name} !~ /$self->{option_results}->{filter_vm}/i) {
my $filtered = 0; $self->{output}->output_add(long_msg => "skipping '" . $node->{name} . "': no matching filter.", debug => 1);
$values{hostgroup} =~ s/\\/\//g; next;
foreach (('vm', 'description', 'hostgroup')) {
if (defined($self->{option_results}->{'filter_' . $_}) && $self->{option_results}->{'filter_' . $_} ne '' &&
$values{$_} !~ /$self->{option_results}->{'filter_' . $_}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $values{$_} . "': no matching filter.", debug => 1);
$filtered = 1;
last;
} }
if (defined($self->{option_results}->{filter_description}) && $self->{option_results}->{filter_description} ne '' &&
$node->{description} !~ /$self->{option_results}->{filter_description}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $node->{node} . "': no matching filter.", debug => 1);
next;
}
if (defined($self->{option_results}->{filter_hostgroup}) && $self->{option_results}->{filter_hostgroup} ne '' &&
$node->{host_group_path} !~ /$self->{option_results}->{filter_hostgroup}/i) {
$self->{output}->output_add(long_msg => "skipping '" . $node->{node} . "': no matching filter.", debug => 1);
next;
} }
$self->{vm}->{$id} = { display => $values{vm}, vm => $values{vm}, status => $values{status}, hostgroup => $values{hostgroup} } $self->{vm}->{$id} = {
if ($filtered == 0); vm => $node->{name},
status => $scvmm_vm_status->{ $node->{status} },
hostgroup => $node->{host_group_path}
};
$id++; $id++;
} }

View File

@ -175,7 +175,6 @@ sub manage_selection {
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
if (ref($decoded) eq "ARRAY") {
foreach my $site (@{$decoded}) { foreach my $site (@{$decoded}) {
$self->{sites}->{$site->{SiteCode}} = { $self->{sites}->{$site->{SiteCode}} = {
display => $site->{SiteCode}, display => $site->{SiteCode},
@ -183,17 +182,7 @@ sub manage_selection {
Type => $map_type{$site->{Type}}, Type => $map_type{$site->{Type}},
Mode => $map_mode{$site->{Mode}}, Mode => $map_mode{$site->{Mode}},
Status => $map_status{$site->{Status}}, Status => $map_status{$site->{Status}},
SecondarySiteCMUpdateStatus => $site->{SecondarySiteCMUpdateStatus}, SecondarySiteCMUpdateStatus => $site->{SecondarySiteCMUpdateStatus}
};
}
} else {
$self->{sites}->{$decoded->{SiteCode}} = {
display => $decoded->{SiteCode},
SiteName => $decoded->{SiteName},
Type => $map_type{$decoded->{Type}},
Mode => $map_mode{$decoded->{Mode}},
Status => $map_status{$decoded->{Status}},
SecondarySiteCMUpdateStatus => $decoded->{SecondarySiteCMUpdateStatus},
}; };
} }

View File

@ -40,47 +40,42 @@ sub set_counters {
key_values => [ { name => 'ComputersUpToDateCount' } ], key_values => [ { name => 'ComputersUpToDateCount' } ],
output_template => 'Up-to-date: %d', output_template => 'Up-to-date: %d',
perfdatas => [ perfdatas => [
{ label => 'computers_up_to_date', value => 'ComputersUpToDateCount', { label => 'computers_up_to_date', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'needing-updates', set => { { label => 'needing-updates', set => {
key_values => [ { name => 'ComputerTargetsNeedingUpdatesCount' } ], key_values => [ { name => 'ComputerTargetsNeedingUpdatesCount' } ],
output_template => 'Needing Updates: %d', output_template => 'Needing Updates: %d',
perfdatas => [ perfdatas => [
{ label => 'computers_needing_updates', value => 'ComputerTargetsNeedingUpdatesCount', { label => 'computers_needing_updates', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'with-update-errors', set => { { label => 'with-update-errors', set => {
key_values => [ { name => 'ComputerTargetsWithUpdateErrorsCount' } ], key_values => [ { name => 'ComputerTargetsWithUpdateErrorsCount' } ],
output_template => 'With Update Errors: %d', output_template => 'With Update Errors: %d',
perfdatas => [ perfdatas => [
{ label => 'computers_with_update_errors', value => 'ComputerTargetsWithUpdateErrorsCount', { label => 'computers_with_update_errors', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'not-contacted', set => { { label => 'not-contacted', set => {
key_values => [ { name => 'ComputersNotContactedSinceCount' } ], key_values => [ { name => 'ComputersNotContactedSinceCount' } ],
output_template => 'Not Contacted: %d', output_template => 'Not Contacted: %d',
perfdatas => [ perfdatas => [
{ label => 'computers_not_contacted', value => 'ComputersNotContactedSinceCount', { label => 'computers_not_contacted', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'unassigned', set => { { label => 'unassigned', set => {
key_values => [ { name => 'UnassignedComputersCount' } ], key_values => [ { name => 'UnassignedComputersCount' } ],
output_template => 'Unassigned: %s', output_template => 'Unassigned: %s',
perfdatas => [ perfdatas => [
{ label => 'computers_unassigned', value => 'UnassignedComputersCount', { label => 'computers_unassigned', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
], }
} }
},
]; ];
} }
@ -106,7 +101,7 @@ sub new {
'wsus-server:s' => { name => 'wsus_server', default => 'localhost' }, 'wsus-server:s' => { name => 'wsus_server', default => 'localhost' },
'wsus-port:s' => { name => 'wsus_port', default => 8530 }, 'wsus-port:s' => { name => 'wsus_port', default => 8530 },
'not-updated-since:s' => { name => 'not_updated_since', default => 10 }, 'not-updated-since:s' => { name => 'not_updated_since', default => 10 },
'use-ssl' => { name => 'use_ssl' }, 'use-ssl' => { name => 'use_ssl' }
}); });
return $self; return $self;

View File

@ -40,74 +40,66 @@ sub set_counters {
key_values => [ { name => 'ComputerTargetCount' } ], key_values => [ { name => 'ComputerTargetCount' } ],
output_template => 'Computers: %d', output_template => 'Computers: %d',
perfdatas => [ perfdatas => [
{ label => 'computers', value => 'ComputerTargetCount', { label => 'computers', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'computer-groups', set => { { label => 'computer-groups', set => {
key_values => [ { name => 'CustomComputerTargetGroupCount' } ], key_values => [ { name => 'CustomComputerTargetGroupCount' } ],
output_template => 'Computer Groups: %d', output_template => 'Computer Groups: %d',
perfdatas => [ perfdatas => [
{ label => 'computer_groups', value => 'CustomComputerTargetGroupCount', { label => 'computer_groups', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'updates', set => { { label => 'updates', set => {
key_values => [ { name => 'UpdateCount' } ], key_values => [ { name => 'UpdateCount' } ],
output_template => 'Updates: %d', output_template => 'Updates: %d',
perfdatas => [ perfdatas => [
{ label => 'updates', value => 'UpdateCount', { label => 'updates', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'approved-updates', set => { { label => 'approved-updates', set => {
key_values => [ { name => 'ApprovedUpdateCount' } ], key_values => [ { name => 'ApprovedUpdateCount' } ],
output_template => 'Approved Updates: %d', output_template => 'Approved Updates: %d',
perfdatas => [ perfdatas => [
{ label => 'approved_updates', value => 'ApprovedUpdateCount', { label => 'approved_updates', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'declined-updates', set => { { label => 'declined-updates', set => {
key_values => [ { name => 'DeclinedUpdateCount' } ], key_values => [ { name => 'DeclinedUpdateCount' } ],
output_template => 'Declined Updates: %d', output_template => 'Declined Updates: %d',
perfdatas => [ perfdatas => [
{ label => 'declined_updates', value => 'DeclinedUpdateCount', { label => 'declined_updates', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'not-approved-updates', set => { { label => 'not-approved-updates', set => {
key_values => [ { name => 'NotApprovedUpdateCount' } ], key_values => [ { name => 'NotApprovedUpdateCount' } ],
output_template => 'Not Approved Updates: %d', output_template => 'Not Approved Updates: %d',
perfdatas => [ perfdatas => [
{ label => 'not_approved_updates', value => 'NotApprovedUpdateCount', { label => 'not_approved_updates', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'stale-updates', set => { { label => 'stale-updates', set => {
key_values => [ { name => 'UpdatesWithStaleUpdateApprovalsCount' } ], key_values => [ { name => 'UpdatesWithStaleUpdateApprovalsCount' } ],
output_template => 'Stale Updates: %d', output_template => 'Stale Updates: %d',
perfdatas => [ perfdatas => [
{ label => 'stale_updates', value => 'UpdatesWithStaleUpdateApprovalsCount', { label => 'stale_updates', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'expired-updates', set => { { label => 'expired-updates', set => {
key_values => [ { name => 'ExpiredUpdateCount' } ], key_values => [ { name => 'ExpiredUpdateCount' } ],
output_template => 'Expired Updates: %d', output_template => 'Expired Updates: %d',
perfdatas => [ perfdatas => [
{ label => 'expired_updates', value => 'ExpiredUpdateCount', { label => 'expired_updates', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
], }
} }
},
]; ];
} }
@ -126,7 +118,7 @@ sub new {
'ps-display' => { name => 'ps_display' }, 'ps-display' => { name => 'ps_display' },
'wsus-server:s' => { name => 'wsus_server', default => 'localhost' }, 'wsus-server:s' => { name => 'wsus_server', default => 'localhost' },
'wsus-port:s' => { name => 'wsus_port', default => 8530 }, 'wsus-port:s' => { name => 'wsus_port', default => 8530 },
'use-ssl' => { name => 'use_ssl' }, 'use-ssl' => { name => 'use_ssl' }
}); });
return $self; return $self;

View File

@ -32,7 +32,7 @@ sub set_counters {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{maps_counters_type} = [ $self->{maps_counters_type} = [
{ name => 'global', type => 0, cb_prefix_output => 'prefix_output' }, { name => 'global', type => 0, cb_prefix_output => 'prefix_output' }
]; ];
$self->{maps_counters}->{global} = [ $self->{maps_counters}->{global} = [
@ -40,47 +40,42 @@ sub set_counters {
key_values => [ { name => 'UpdatesWithClientErrorsCount' } ], key_values => [ { name => 'UpdatesWithClientErrorsCount' } ],
output_template => 'With Client Errors: %d', output_template => 'With Client Errors: %d',
perfdatas => [ perfdatas => [
{ label => 'updates_with_client_errors', value => 'UpdatesWithClientErrorsCount', { label => 'updates_with_client_errors', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'with-server-errors', set => { { label => 'with-server-errors', set => {
key_values => [ { name => 'UpdatesWithServerErrorsCount' } ], key_values => [ { name => 'UpdatesWithServerErrorsCount' } ],
output_template => 'With Server Errors: %d', output_template => 'With Server Errors: %d',
perfdatas => [ perfdatas => [
{ label => 'updates_with_server_errors', value => 'UpdatesWithServerErrorsCount', { label => 'updates_with_server_errors', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'needing-files', set => { { label => 'needing-files', set => {
key_values => [ { name => 'UpdatesNeedingFilesCount' } ], key_values => [ { name => 'UpdatesNeedingFilesCount' } ],
output_template => 'Needing Files: %d', output_template => 'Needing Files: %d',
perfdatas => [ perfdatas => [
{ label => 'updates_needing_files_count', value => 'UpdatesNeedingFilesCount', { label => 'updates_needing_files_count', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'needed-by-computers', set => { { label => 'needed-by-computers', set => {
key_values => [ { name => 'UpdatesNeededByComputersCount' } ], key_values => [ { name => 'UpdatesNeededByComputersCount' } ],
output_template => 'Needed By Computers: %d', output_template => 'Needed By Computers: %d',
perfdatas => [ perfdatas => [
{ label => 'updates_needed_by_computers', value => 'UpdatesNeededByComputersCount', { label => 'updates_needed_by_computers', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
],
} }
}, },
{ label => 'up-to-date', set => { { label => 'up-to-date', set => {
key_values => [ { name => 'UpdatesUpToDateCount' } ], key_values => [ { name => 'UpdatesUpToDateCount' } ],
output_template => 'Up-to-date: %s', output_template => 'Up-to-date: %s',
perfdatas => [ perfdatas => [
{ label => 'updates_up_to_date', value => 'UpdatesUpToDateCount', { label => 'updates_up_to_date', template => '%d', min => 0 }
template => '%d', min => 0 }, ]
], }
} }
},
]; ];
} }

View File

@ -41,7 +41,7 @@ sub convert_to_json {
my (%options) = @_; my (%options) = @_;
my $ps = q{ my $ps = q{
function ConvertTo-JSON-20($maxDepth = 4,$forceArray = $false) { function ConvertTo-JSON-20($maxDepth = 4) {
begin { begin {
$data = @() $data = @()
} }
@ -50,11 +50,7 @@ function ConvertTo-JSON-20($maxDepth = 4,$forceArray = $false) {
} }
end{ end{
if ($data.length -eq 1 -and $forceArray -eq $false) {
$value = $data[0]
} else {
$value = $data $value = $data
}
if ($value -eq $null) { if ($value -eq $null) {
return "null" return "null"

View File

@ -22,7 +22,7 @@ package centreon::common::powershell::hyperv::2012::listnodevms;
use strict; use strict;
use warnings; use warnings;
use centreon::plugins::misc; use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -30,17 +30,35 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
$ErrorActionPreference = "Stop" $ErrorActionPreference = "Stop"
$vms = Get-VM $vms = Get-VM
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
$item = @{}
$note = $vm.Notes -replace "\r","" $note = $vm.Notes -replace "\r",""
$note = $note -replace "\n"," - " $note = $note -replace "\n"," - "
Write-Host "[name=" $vm.VMName "][state=" $vm.State "][status=" $vm.Status "][IsClustered=" $vm.IsClustered "][note=" $note "]" $item.name = $vm.VMName
$item.state = $vm.State.value__
$item.status = $vm.Status
$item.note = $note
$item.is_clustered = $vm.IsClustered
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1
@ -52,49 +70,6 @@ exit 0
return $ps; return $ps;
} }
sub list {
my ($self, %options) = @_;
# Following output:
#[name= XXXX1 ][state= Running ][status= Operating normally ][IsClustered= True ][note= ]
#...
foreach my $line (split /\n/, $options{stdout}) {
next if ($line !~ /^\[name=(.*?)\]\[state=(.*?)\]\[status=(.*?)\]\[IsClustered=(.*?)\]\[note=(.*?)\]/);
my ($name, $state, $status, $IsClustered, $note) = (
centreon::plugins::misc::trim($1), centreon::plugins::misc::trim($2),
centreon::plugins::misc::trim($3), centreon::plugins::misc::trim($4), centreon::plugins::misc::trim($5)
);
$self->{output}->output_add(long_msg => "'" . $name . "' [state = $state, status = " . $status . ']');
}
}
sub disco_show {
my ($self, %options) = @_;
# Following output:
#[name= XXXX1 ][state= Running ][status= Operating normally ][IsClustered= True ][note= ]
#...
foreach my $line (split /\n/, $options{stdout}) {
next if ($line !~ /^\[name=(.*?)\]\[state=(.*?)\]\[status=(.*?)\]\[IsClustered=(.*?)\]\[note=(.*?)\]/);
my ($name, $state, $status, $IsClustered, $note) = (
centreon::plugins::misc::trim($1), centreon::plugins::misc::trim($2),
centreon::plugins::misc::trim($3), centreon::plugins::misc::trim($4), centreon::plugins::misc::trim($5)
);
$self->{output}->add_disco_entry(
name => $name,
state => $state,
status => $status,
is_clustered => $IsClustered,
note => $note
);
}
}
1; 1;
__END__ __END__

View File

@ -22,6 +22,7 @@ package centreon::common::powershell::hyperv::2012::nodeintegrationservice;
use strict; use strict;
use warnings; use warnings;
use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -29,20 +30,49 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
$ErrorActionPreference = "Stop" $ErrorActionPreference = "Stop"
$vms = Get-VM $vms = Get-VM
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
$item = @{}
$note = $vm.Notes -replace "\r","" $note = $vm.Notes -replace "\r",""
$note = $note -replace "\n"," - " $note = $note -replace "\n"," - "
Write-Host "[name=" $vm.VMName "][state=" $vm.State "][IntegrationServicesState=" $vm.IntegrationServicesState "][IntegrationServicesVersion=" $vm.IntegrationServicesVersion "][note=" $note "]"
$item.name = $vm.VMName
$item.state = $vm.State.value__
$item.integration_services_state = $vm.IntegrationServicesState
$item.integration_services_version = $vm.IntegrationServicesVersion
$item.note = $note
$services = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($service in $VM.VMIntegrationService) { Foreach ($service in $VM.VMIntegrationService) {
Write-Host "[service=" $service.Name "][enabled=" $service.Enabled "][primaryOperationalStatus=" $service.PrimaryOperationalStatus "][secondaryOperationalStatus=" $service.SecondaryOperationalStatus "]" $service = @{}
$service.name = $service.Name
$service.enabled = $service.Enabled
$service.primary_operational_status = $service.PrimaryOperationalStatus.value__
$service.secondary_operational_status = $service.SecondaryOperationalStatus.value__
$services.Add($service)
} }
$item.services = $services
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1

View File

@ -22,6 +22,7 @@ package centreon::common::powershell::hyperv::2012::nodereplication;
use strict; use strict;
use warnings; use warnings;
use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -29,15 +30,30 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
$ErrorActionPreference = "Stop" $ErrorActionPreference = "Stop"
$vms = Get-VMReplication $vms = Get-VMReplication
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
Write-Host "[name=" $vm.Name "][state=" $vm.State "][health=" $vm.Health "]" $item = @{}
$item.name = $vm.Name
$item.state = $vm.State.value__
$item.health = $vm.Health.value__
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1

View File

@ -22,6 +22,7 @@ package centreon::common::powershell::hyperv::2012::nodesnapshot;
use strict; use strict;
use warnings; use warnings;
use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -29,6 +30,12 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
@ -38,17 +45,23 @@ Try {
$snapshots = Get-VMSnapshot -VMName * $snapshots = Get-VMSnapshot -VMName *
} }
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
$i=0 $item = @{}
$note = $vm.Notes -replace "\r","" $note = $vm.Notes -replace "\r",""
$note = $note -replace "\n"," - " $note = $note -replace "\n"," - "
$item.note = $note
$item.name = $vm.VMName
$item.state = $vm.State.value__
$checkpoints = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($snap in $snapshots) { Foreach ($snap in $snapshots) {
if ($snap.VMName -eq $vm.VMName) { if ($snap.VMName -eq $vm.VMName) {
if ($i -eq 0) { $checkpoint = @{}
Write-Host "[name=" $vm.VMName "][state=" $vm.State "][note=" $note "]" $checkpoint.type = "snapshot"
} $checkpoint.creation_time = (get-date -date $snap.CreationTime.ToUniversalTime() -UFormat ' . "'%s'" . ')
Write-Host "[checkpointCreationTime=" (get-date -date $snap.CreationTime.ToUniversalTime() -UFormat ' . "'%s'" . ') "][type= snapshot]" $checkpoints.Add($checkpoint)
$i=1
} }
} }
if ($vm.status -imatch "Backing") { if ($vm.status -imatch "Backing") {
@ -56,16 +69,21 @@ Try {
Foreach ($VMDisk in $VMDisks) { Foreach ($VMDisk in $VMDisks) {
$VHD = Get-VHD $VMDisk.Path $VHD = Get-VHD $VMDisk.Path
if ($VHD.Path -imatch ".avhdx" -or $VHD.VhdType -imatch "Differencing") { if ($VHD.Path -imatch ".avhdx" -or $VHD.VhdType -imatch "Differencing") {
$checkpoint = @{}
$parent = Get-Item $VHD.ParentPath $parent = Get-Item $VHD.ParentPath
if ($i -eq 0) { $checkpoint.type = "backing"
Write-Host "[name=" $vm.VMName "][state=" $vm.State "][note=" $note "]" $checkpoint.creation_time = (get-date -date $parent.LastWriteTime.ToUniversalTime() -UFormat ' . "'%s'" . ')
} $checkpoints.Add($checkpoint)
Write-Host "[checkpointCreationTime=" (get-date -date $parent.LastWriteTime.ToUniversalTime() -UFormat ' . "'%s'" . ') "][type= backing]"
$i=1
} }
} }
} }
$item.checkpoints = $checkpoints
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1

View File

@ -22,6 +22,7 @@ package centreon::common::powershell::hyperv::2012::nodevmstatus;
use strict; use strict;
use warnings; use warnings;
use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -29,6 +30,12 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
@ -42,15 +49,28 @@ Try {
} }
} Catch { } Catch {
} }
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
$item = @{}
$note = $vm.Notes -replace "\r","" $note = $vm.Notes -replace "\r",""
$note = $note -replace "\n"," - " $note = $note -replace "\n"," - "
$isClustered = $vm.IsClustered
$item.name = $vm.VMName
$item.state = $vm.State.value__
$item.status = $vm.Status
$item.note = $note
$item.is_clustered = $vm.IsClustered
if ($node_is_clustered -eq 0) { if ($node_is_clustered -eq 0) {
$isClustered = "nodeNotClustered" $item.is_clustered = $false
} }
Write-Host "[name=" $vm.VMName "][state=" $vm.State "][status=" $vm.Status "][IsClustered=" $isClustered "][note=" $note "]"
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1

View File

@ -22,6 +22,7 @@ package centreon::common::powershell::hyperv::2012::scvmmintegrationservice;
use strict; use strict;
use warnings; use warnings;
use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -29,6 +30,12 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
@ -42,21 +49,29 @@ Try {
$connection = Get-VMMServer -ComputerName "' . $options{scvmm_hostname} . '" -TCPPort ' . $options{scvmm_port} . ' -Credential $UserCredential $connection = Get-VMMServer -ComputerName "' . $options{scvmm_hostname} . '" -TCPPort ' . $options{scvmm_port} . ' -Credential $UserCredential
$vms = Get-SCVirtualMachine -VMMServer $connection $vms = Get-SCVirtualMachine -VMMServer $connection
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
$item = @{}
$desc = $vm.description -replace "\r","" $desc = $vm.description -replace "\r",""
$desc = $desc -replace "\n"," - " $desc = $desc -replace "\n"," - "
Write-Host ("[VM={0}]" -f $vm.Name) -NoNewline $item.name = $vm.Name
Write-Host ("[Description={0}]" -f $desc) -NoNewline $item.status = $vm.Status.value__
Write-Host ("[Status={0}]" -f $vm.Status) -NoNewline $item.description = $desc
Write-Host ("[Cloud={0}]" -f $vm.Cloud) -NoNewline $item.cloud = $vm.Cloud
Write-Host ("[HostGroup={0}]" -f $vm.HostGroupPath) -NoNewline $item.host_group_path = $vm.HostGroupPath
Write-Host ("[VMAddition={0}]" -f $vm.VMAddition) -NoNewline $item.vm_addition = $vm.VMAddition
Write-Host ("[OperatingSystemShutdownEnabled={0}]" -f $vm.OperatingSystemShutdownEnabled) -NoNewline $item.operating_system_shutdown_enabled = $vm.OperatingSystemShutdownEnabled
Write-Host ("[TimeSynchronizationEnabled={0}]" -f $vm.TimeSynchronizationEnabled) -NoNewline $item.time_synchronization_enabled = $vm.TimeSynchronizationEnabled
Write-Host ("[DataExchangeEnabled={0}]" -f $vm.DataExchangeEnabled) -NoNewline $item.data_exchange_enabled = $vm.DataExchangeEnabled
Write-Host ("[HeartbeatEnabled={0}]" -f $vm.HeartbeatEnabled) -NoNewline $item.heartbeat_enabled = $vm.HeartbeatEnabled
Write-Host ("[BackupEnabled={0}]" -f $vm.BackupEnabled) $item.backup_enabled = $vm.BackupEnabled
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1

View File

@ -22,6 +22,7 @@ package centreon::common::powershell::hyperv::2012::scvmmsnapshot;
use strict; use strict;
use warnings; use warnings;
use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -29,6 +30,12 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
@ -42,19 +49,32 @@ Try {
$connection = Get-VMMServer -ComputerName "' . $options{scvmm_hostname} . '" -TCPPort ' . $options{scvmm_port} . ' -Credential $UserCredential $connection = Get-VMMServer -ComputerName "' . $options{scvmm_hostname} . '" -TCPPort ' . $options{scvmm_port} . ' -Credential $UserCredential
$vms = Get-SCVirtualMachine -VMMServer $connection $vms = Get-SCVirtualMachine -VMMServer $connection
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
$i = 0 $item = @{}
$checkpoints = Get-SCVMCheckpoint -VMMServer $connection -Vm $vm $checkpoints = Get-SCVMCheckpoint -VMMServer $connection -Vm $vm
$desc = $vm.description -replace "\r","" $desc = $vm.description -replace "\r",""
$desc = $desc -replace "\n"," - " $desc = $desc -replace "\n"," - "
$item.name = $vm.Name
$item.description = $desc
$item.status = $vm.Status.value__
$item.host_group_path = $vm.HostGroupPath
$chkpt_list = New-Object System.Collections.Generic.List[Hashtable];
foreach ($checkpoint in $checkpoints) { foreach ($checkpoint in $checkpoints) {
if ($i -eq 0) { $chkpt = @{}
Write-Host "[name=" $vm.Name "][description=" $desc "][status=" $vm.Status "][cloud=" $vm.Cloud "][hostgrouppath=" $vm.HostGroupPath "]" $chkpt.type = "backing"
} $chkpt.added_time = (get-date -date $checkpoint.AddedTime.ToUniversalTime() -UFormat ' . "'%s'" . ')
Write-Host "[checkpointAddedTime=" (get-date -date $checkpoint.AddedTime.ToUniversalTime() -UFormat ' . "'%s'" . ') "]" $chkpt_list.Add($chkpt)
$i = 1
} }
$item.checkpoints = $chkpt_list
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1

View File

@ -22,6 +22,7 @@ package centreon::common::powershell::hyperv::2012::scvmmvmstatus;
use strict; use strict;
use warnings; use warnings;
use centreon::common::powershell::functions;
sub get_powershell { sub get_powershell {
my (%options) = @_; my (%options) = @_;
@ -29,6 +30,12 @@ sub get_powershell {
my $ps = ' my $ps = '
$culture = new-object "System.Globalization.CultureInfo" "en-us" $culture = new-object "System.Globalization.CultureInfo" "en-us"
[System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture [System.Threading.Thread]::CurrentThread.CurrentUICulture = $culture
';
$ps .= centreon::common::powershell::functions::escape_jsonstring(%options);
$ps .= centreon::common::powershell::functions::convert_to_json(%options);
$ps .= '
$ProgressPreference = "SilentlyContinue" $ProgressPreference = "SilentlyContinue"
Try { Try {
@ -42,11 +49,22 @@ Try {
$connection = Get-VMMServer -ComputerName "' . $options{scvmm_hostname} . '" -TCPPort ' . $options{scvmm_port} . ' -Credential $UserCredential $connection = Get-VMMServer -ComputerName "' . $options{scvmm_hostname} . '" -TCPPort ' . $options{scvmm_port} . ' -Credential $UserCredential
$vms = Get-SCVirtualMachine -VMMServer $connection $vms = Get-SCVirtualMachine -VMMServer $connection
$items = New-Object System.Collections.Generic.List[Hashtable];
Foreach ($vm in $vms) { Foreach ($vm in $vms) {
$item = @{}
$desc = $vm.description -replace "\r","" $desc = $vm.description -replace "\r",""
$desc = $desc -replace "\n"," - " $desc = $desc -replace "\n"," - "
Write-Host "[name=" $vm.Name "][description=" $desc "][status=" $vm.Status "][cloud=" $vm.Cloud "][hostgrouppath=" $vm.HostGroupPath "]" $item.name = $vm.Name
$item.description = $desc
$item.status = $vm.Status.value__
$item.cloud = $vm.Cloud
$item.host_group_path = $vm.HostGroupPath
$items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception
exit 1 exit 1

View File

@ -77,7 +77,7 @@ Try {
$items.Add($item) $items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20 -forceArray 1 $jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception

View File

@ -67,7 +67,7 @@ Try {
$items.Add($item) $items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20 -forceArray 1 $jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception

View File

@ -70,7 +70,7 @@ Try {
$items.Add($item) $items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20 -forceArray 1 $jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception

View File

@ -57,7 +57,7 @@ Try {
$items.Add($item) $items.Add($item)
} }
$jsonString = $items | ConvertTo-JSON-20 -forceArray 1 $jsonString = $items | ConvertTo-JSON-20
Write-Host $jsonString Write-Host $jsonString
} Catch { } Catch {
Write-Host $Error[0].Exception Write-Host $Error[0].Exception