From cc042f70b34f92b81f71957cc7c777a9c5d7e691 Mon Sep 17 00:00:00 2001 From: Daniel Friesel Date: Mon, 1 Nov 2010 19:02:32 +0100 Subject: Add option to recheck services (in groups, too!) --- bin/icli | 76 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 74 insertions(+), 2 deletions(-) (limited to 'bin') diff --git a/bin/icli b/bin/icli index 5f194a3..d961ac7 100755 --- a/bin/icli +++ b/bin/icli @@ -21,7 +21,8 @@ my $colours = 1; my $short = 0; my $list_type = 's'; my $verbosity = 1; -my (@for_hosts, @for_groups); +my $recheck = 0; +my (@for_hosts, @for_groups, @for_services); sub have_host { my ($host) = @_; @@ -33,6 +34,17 @@ sub have_host { } } +sub have_service { + my ($host, $service) = @_; + + foreach my $s (@{$data->{services}->{$host}}) { + if ($s->{service_description} eq $service) { + return 1; + } + } + return 0; +} + sub with_colour { my ($text, $colour) = @_; if ($colours) { @@ -48,6 +60,10 @@ sub pretty_date { return time2str('%Y-%m-%d %H:%M:%S', $unix); } +sub unix_time { + return time2str('%s', localtime(time)); +} + sub read_objects_line { my ($line, $ref) = @_; @@ -77,6 +93,9 @@ sub read_objects_line { when ('hostgroup') { ${$ref}->{hostgroups}->{$cache->{hostgroup_name}} = $cache; } + when('servicegroup') { + ${$ref}->{servicegroups}->{$cache->{servicegroup_name}} = $cache; + } when ('hostcomment') { # TODO } @@ -281,6 +300,36 @@ sub display_host { } } +sub dispatch_command { + my $str = join(';', @_); + + open(my $cmd_fh, '>', '/var/lib/icinga/rw/icinga.cmd') or die("Can't open: $!"); + printf $cmd_fh ( + "[%d] %s", + unix_time(), + $str, + ); + close($cmd_fh) or die("Can't close: $!"); +} + + +sub recheck_host_all { + my ($host) = @_; + + dispatch_command('SCHEDULE_HOST_SVC_CHECKS', $host, unix_time()); + say "Scheduled check of * on '$host'"; +} + +sub recheck_service { + my ($host, $service) = @_; + + if (have_service($host, $service)) { + dispatch_command('SCHEDULE_SVC_CHECK', $host, $service, + unix_time()); + say "Scheduled check of '$service' on '$host'"; + } +} + GetOptions( 'c|config=s' => \$config_file, 'C|no-colours' => sub { $colours = 0 }, @@ -288,9 +337,11 @@ GetOptions( 'g|hostgroup=s' => sub { push(@for_groups, split(/,/, $_[1])) }, 'h|host=s' => sub { push(@for_hosts, split(/,/, $_[1])) }, 'l|list=s' => sub { $list_type = substr($_[1], 0, 1) }, - 's|short' => \$short, + 'r|recheck' => sub { $recheck = 1; $list_type = q{} }, + 's|service=s' => sub { push(@for_services, split(/,/, $_[1])) }, 'v|verbose+' => \$verbosity, 'V|version' => sub { say "icli version $VERSION"; exit 0 }, + 'x|critical-only' => \$short, ); read_objects($status_file, \$data); @@ -339,6 +390,27 @@ elsif ($list_type eq 'd') { display_downtime($downtime); } } +elsif ($recheck) { + if (@for_hosts) { + foreach my $host (@for_hosts) { + if (have_host($host) and not @for_services) { + recheck_host_all($host); + } + elsif (have_host($host)) { + foreach my $service (@for_services) { + recheck_service($host, $service); + } + } + } + } + else { + foreach my $host (sort keys %{$data->{services}}) { + foreach my $service (@for_services) { + recheck_service($host, $service); + } + } + } +} else { die("See perldoc -F $0\n"); } -- cgit v1.2.3