#!/usr/local/cpanel/3rdparty/bin/perl
# cpanel - scripts/check_unreliable_resolvers Copyright 2022 cPanel, L.L.C.
# All rights reserved.
# copyright@cpanel.net http://cpanel.net
# This code is subject to the cPanel license. Unauthorized copying is prohibited
#
package scripts::check_unreliable_resolvers;
use strict;
use Getopt::Long ();
use Pod::Usage ();
use Cpanel::Resolvers::Check ();
my $ONE_DAY_IN_SECONDS = 86400;
our $NOTIFICATION_INTERVAL = $ONE_DAY_IN_SECONDS;
sub script {
my ( $class, $argv ) = @_;
my %opts = (
notify => 0,
quiet => 0,
);
my $self = bless {}, $class;
my $help;
Getopt::Long::GetOptionsFromArray(
$argv,
help => \$help,
notify => \$opts{'notify'},
quiet => \$opts{'quiet'},
);
if ($help) {
Pod::Usage::pod2usage(
-exitval => 'NOEXIT',
-verbose => 2,
-noperldoc => 1,
);
return 0;
}
$self->{'notify'} = $opts{'notify'};
$self->{'quiet'} = $opts{'quiet'};
my $resolver_state = Cpanel::Resolvers::Check::check_resolvers_performance();
if ( !$resolver_state->{'state'}->is_ok() ) {
$self->send_notification($resolver_state);
return 1;
}
print $self->_locale()->maketext(q{OK}), "\n" unless $self->{'quiet'};
return 0;
}
sub send_notification {
my ( $self, $resolvers_ref ) = @_;
require Cpanel::Locale;
my $old = $self->_locale()->set_context_plain();
require Cpanel::Notify;
my $ic_obj = Cpanel::Notify::notification_class(
'class' => 'Check::Resolvers',
'application' => 'Check::Resolvers',
'status' => $resolvers_ref->{'state'},
'interval' => $NOTIFICATION_INTERVAL,
'constructor_args' => [
'origin' => 'check_unreliable_resolvers',
resolver_state => $resolvers_ref->{'resolver_state'},
overall_state => $resolvers_ref->{'state'},
'skip_send' => 1,
]
);
unless ( $self->{'quiet'} ) {
print $ic_obj->render_template_include_as_text( 'template' => 'subject', 'type' => 'text' ) . "\n\n" . $ic_obj->render_template_include_as_text( 'template' => 'body', 'type' => 'html' ) . "\n";
}
if ( $self->{'notify'} ) {
my %notify_check_args = (
app => 'Check::Resolvers',
status => $resolvers_ref->{'state'},
interval => $NOTIFICATION_INTERVAL,
);
return 0 if Cpanel::Notify::notify_blocked(%notify_check_args);
Cpanel::Notify::update_notification_time_if_interval_reached(%notify_check_args);
$ic_obj->send();
}
$self->_locale()->set_context($old);
return 1;
}
sub _locale {
my ($self) = @_;
require Cpanel::Locale;
return ( $self->{'_locale'} ||= Cpanel::Locale->get_handle() );
}
exit( __PACKAGE__->script( \@ARGV ) ) unless caller;
__END__
=pod
=encoding utf-8
=head1 NAME
check_unreliable_resolvers - Checks for resolvers in /etc/resolv.conf that are not reliable or missing
=head1 SYNOPSIS
check_unreliable_resolvers OPTIONS
Options:
--quiet
Do not display output.
--notify
Send notification to the system administrator.
--help
Print this message.
=head1 DESCRIPTION
This script checks the state of /etc/resolv.conf and can notify when one or more
of the nameservers is responding slowly, not responding, unreliable, or otherwise
problematic.
=cut