6eb99a2168
Signed-off-by: Digimer <digimer@alteeve.ca>
1972 lines
91 KiB
Perl
Executable File
1972 lines
91 KiB
Perl
Executable File
#!/usr/bin/perl
|
|
|
|
use strict;
|
|
use warnings;
|
|
use Anvil::Tools;
|
|
use Data::Dumper;
|
|
use Text::Diff;
|
|
|
|
$| = 1;
|
|
|
|
my $THIS_FILE = ($0 =~ /^.*\/(.*)$/)[0];
|
|
my $running_directory = ($0 =~ /^(.*?)\/$THIS_FILE$/)[0];
|
|
if (($running_directory =~ /^\./) && ($ENV{PWD}))
|
|
{
|
|
$running_directory =~ s/^\./$ENV{PWD}/;
|
|
}
|
|
|
|
my $anvil = Anvil::Tools->new();
|
|
|
|
# Get a list of all interfaces with IP addresses.
|
|
$anvil->Get->switches({list => [
|
|
"add",
|
|
"edit",
|
|
"delete",
|
|
"alert-overrides",
|
|
"alert-override-uuid",
|
|
"alert-override-recipient-uuid",
|
|
"alert-override-host-uuid",
|
|
"alert-override-alert-level",
|
|
"level",
|
|
"mail-servers",
|
|
"mail-server-uuid",
|
|
"mail-server-address",
|
|
"mail-server-port",
|
|
"mail-server-username",
|
|
"mail-server-password",
|
|
"mail-server-security",
|
|
"mail-server-authentication",
|
|
"mail-server-helo-domain",
|
|
"recipients",
|
|
"recipient-uuid",
|
|
"recipient-name",
|
|
"recipient-email",
|
|
"recipient-language",
|
|
"recipient-level",
|
|
"test",
|
|
"y",
|
|
"yes",
|
|
]});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => $anvil->data->{switches}});
|
|
|
|
$anvil->Database->connect();
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, secure => 0, key => "log_0132" });
|
|
if (not $anvil->data->{sys}{database}{connections})
|
|
{
|
|
# No databases, exit.
|
|
$anvil->Log->entry({ source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, priority => "err", key => "error_0003" });
|
|
$anvil->nice_exit({ exit_code => 1 });
|
|
}
|
|
|
|
check_switches($anvil);
|
|
|
|
if ($anvil->data->{switches}{"mail-servers"})
|
|
{
|
|
handle_mail_servers($anvil);
|
|
}
|
|
elsif ($anvil->data->{switches}{"recipients"})
|
|
{
|
|
$anvil->data->{sys}{show}{recipients} = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::show::recipients' => $anvil->data->{sys}{show}{recipients},
|
|
}});
|
|
handle_recipients($anvil);
|
|
}
|
|
elsif ($anvil->data->{switches}{"alert-overrides"})
|
|
{
|
|
$anvil->data->{sys}{show}{alert_overrides} = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::show::alert_overrides' => $anvil->data->{sys}{show}{alert_overrides},
|
|
}});
|
|
handle_alert_overrides($anvil);
|
|
}
|
|
elsif ($anvil->data->{switches}{"test"})
|
|
{
|
|
handle_test_alert($anvil);
|
|
}
|
|
else
|
|
{
|
|
$anvil->data->{sys}{show}{mail_servers} = 1;
|
|
$anvil->data->{sys}{show}{recipients} = 1;
|
|
$anvil->data->{sys}{show}{alert_overrides} = 1;
|
|
$anvil->data->{sys}{show}{systems} = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::show::mail_servers' => $anvil->data->{sys}{show}{mail_servers},
|
|
'sys::show::recipients' => $anvil->data->{sys}{show}{recipients},
|
|
'sys::show::alert_overrides' => $anvil->data->{sys}{show}{alert_overrides},
|
|
'sys::show::systems' => $anvil->data->{sys}{show}{systems},
|
|
}});
|
|
show_existing($anvil);
|
|
}
|
|
|
|
$anvil->nice_exit({exit_code => 0});
|
|
|
|
|
|
#############################################################################################################
|
|
# Functions #
|
|
#############################################################################################################
|
|
|
|
sub handle_test_alert
|
|
{
|
|
my ($anvil) = @_;
|
|
|
|
# * 1 or "critical"
|
|
# * 2 or "warning"
|
|
# * 3 or "notice"
|
|
# * 4 or "info"
|
|
my $level = "";
|
|
my $say_level = "";
|
|
if (($anvil->data->{switches}{level} eq "critical") or ($anvil->data->{switches}{level} eq "1"))
|
|
{
|
|
$level = "critical";
|
|
$say_level = $anvil->Words->string({key => "unit_0024"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
level => $level,
|
|
say_level => $say_level,
|
|
}});
|
|
}
|
|
elsif (($anvil->data->{switches}{level} eq "warning") or ($anvil->data->{switches}{level} eq "2"))
|
|
{
|
|
$level = "warning";
|
|
$say_level = $anvil->Words->string({key => "unit_0025"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
level => $level,
|
|
say_level => $say_level,
|
|
}});
|
|
}
|
|
elsif (($anvil->data->{switches}{level} eq "notice") or ($anvil->data->{switches}{level} eq "3"))
|
|
{
|
|
$level = "notice";
|
|
$say_level = $anvil->Words->string({key => "unit_0026"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
level => $level,
|
|
say_level => $say_level,
|
|
}});
|
|
}
|
|
elsif (($anvil->data->{switches}{level} eq "info") or ($anvil->data->{switches}{level} eq "4"))
|
|
{
|
|
$level = "info";
|
|
$say_level = $anvil->Words->string({key => "unit_0027"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
level => $level,
|
|
say_level => $say_level,
|
|
}});
|
|
}
|
|
|
|
my $alert_uuid = $anvil->Alert->register({debug => 2, alert_level => $level, message => "message_0306", variables => { level => $say_level }, set_by => $THIS_FILE, sort_position => 0});
|
|
if ($alert_uuid)
|
|
{
|
|
print $anvil->Words->string({key => "message_0306", variables => { level => $say_level }})."\n";
|
|
$anvil->Email->send_alerts();
|
|
}
|
|
else
|
|
{
|
|
# No one is listening, or no mail servers are configured.
|
|
print $anvil->Words->string({key => "message_0307", variables => { level => $say_level }})."\n";
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
sub handle_alert_overrides
|
|
{
|
|
my ($anvil) = @_;
|
|
|
|
### Are we adding, editing or deleting?
|
|
# If we're adding or editing, all fields are required.
|
|
my $confirm_needed = 0;
|
|
if (($anvil->data->{switches}{add}) or ($anvil->data->{switches}{edit}) or ($anvil->data->{switches}{'delete'}))
|
|
{
|
|
# Did the user confirm yet?
|
|
if ((not $anvil->data->{switches}{'y'}) and (not $anvil->data->{switches}{'yes'}))
|
|
{
|
|
$confirm_needed = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { confirm_needed => $confirm_needed }});
|
|
}
|
|
}
|
|
|
|
if (($anvil->data->{switches}{add}) or ($anvil->data->{switches}{edit}))
|
|
{
|
|
# Do we have what we need?
|
|
my $problem = 0;
|
|
foreach my $switch ("alert-override-recipient-uuid", "alert-override-host-uuid", "alert-override-alert-level")
|
|
{
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
switch => $switch,
|
|
"switches::$switch" => $anvil->data->{switches}{$switch},
|
|
}});
|
|
if (($anvil->data->{switches}{$switch} eq "") or ($anvil->data->{switches}{$switch} eq "#!SET!#"))
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0387", variables => { switch => $switch }});
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
|
|
if ($problem)
|
|
{
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
}
|
|
|
|
# These will be filled out if we need the user to confirm.
|
|
$anvil->data->{sys}{say_old_alert_override_level} = "";
|
|
$anvil->data->{sys}{say_old_alert_override_recipient} = "";
|
|
$anvil->data->{sys}{say_old_alert_override_host} = "";
|
|
$anvil->data->{sys}{say_new_alert_override_level} = "";
|
|
$anvil->data->{sys}{say_new_alert_override_recipient} = "";
|
|
$anvil->data->{sys}{say_new_alert_override_host} = "";
|
|
|
|
# Populate the new 'say' strings, if needed.
|
|
my $alert_override_uuid = $anvil->data->{switches}{"alert-override-uuid"};
|
|
my $new_alert_override_alert_level = $anvil->data->{switches}{"alert-override-alert-level"};
|
|
my $new_alert_override_recipient_uuid = $anvil->data->{switches}{"alert-override-recipient-uuid"};
|
|
my $new_alert_override_host_uuid = $anvil->data->{switches}{"alert-override-host-uuid"};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
alert_override_uuid => $alert_override_uuid,
|
|
new_alert_override_alert_level => $new_alert_override_alert_level,
|
|
new_alert_override_recipient_uuid => $new_alert_override_recipient_uuid,
|
|
new_alert_override_host_uuid => $new_alert_override_host_uuid,
|
|
}});
|
|
if ($new_alert_override_recipient_uuid)
|
|
{
|
|
$anvil->data->{sys}{say_new_alert_override_recipient} = $anvil->data->{recipients}{recipient_uuid}{$new_alert_override_recipient_uuid}{recipient_name}." (".$anvil->data->{recipients}{recipient_uuid}{$new_alert_override_recipient_uuid}{recipient_email}.")";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_alert_override_recipient' => $anvil->data->{sys}{say_new_alert_override_recipient},
|
|
}});
|
|
}
|
|
if ($new_alert_override_host_uuid)
|
|
{
|
|
$anvil->data->{sys}{say_new_alert_override_host} = $anvil->data->{hosts}{host_uuid}{$new_alert_override_host_uuid}{host_name};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_alert_override_host' => $anvil->data->{sys}{say_new_alert_override_host},
|
|
}});
|
|
}
|
|
|
|
if ($new_alert_override_alert_level =~ /\d/)
|
|
{
|
|
if ($new_alert_override_alert_level == 0)
|
|
{
|
|
# Ignore
|
|
$anvil->data->{sys}{say_new_alert_override_level} = $anvil->Words->string({key => "unit_0023"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_alert_override_level' => $anvil->data->{sys}{say_new_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($new_alert_override_alert_level == 1)
|
|
{
|
|
# Critical
|
|
$anvil->data->{sys}{say_new_alert_override_level} = $anvil->Words->string({key => "unit_0024"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_alert_override_level' => $anvil->data->{sys}{say_new_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($new_alert_override_alert_level == 2)
|
|
{
|
|
# Warning
|
|
$anvil->data->{sys}{say_new_alert_override_level} = $anvil->Words->string({key => "unit_0025"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_alert_override_level' => $anvil->data->{sys}{say_new_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($new_alert_override_alert_level == 3)
|
|
{
|
|
# Notice
|
|
$anvil->data->{sys}{say_new_alert_override_level} = $anvil->Words->string({key => "unit_0026"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_alert_override_level' => $anvil->data->{sys}{say_new_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($new_alert_override_alert_level == 4)
|
|
{
|
|
# Info
|
|
$anvil->data->{sys}{say_new_alert_override_level} = $anvil->Words->string({key => "unit_0027"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_alert_override_level' => $anvil->data->{sys}{say_new_alert_override_level},
|
|
}});
|
|
}
|
|
}
|
|
|
|
# If we're editing or deleting, make sure we have a valid UUID.
|
|
my $old_alert_override_level = "";
|
|
my $old_alert_override_recipient_uuid = "";
|
|
my $old_alert_override_host_uuid = "";
|
|
if (($anvil->data->{switches}{edit}) or ($anvil->data->{switches}{'delete'}))
|
|
{
|
|
if (not $alert_override_uuid)
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0387", variables => { switch => "alert-override-uuid" }});
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
if (not exists $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid})
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0388", variables => { uuid => $alert_override_uuid }});
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
|
|
$old_alert_override_recipient_uuid = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_recipient_uuid};
|
|
$old_alert_override_host_uuid = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_host_uuid};
|
|
$old_alert_override_level = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_alert_level};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
old_alert_override_recipient_uuid => $old_alert_override_recipient_uuid,
|
|
old_alert_override_host_uuid => $old_alert_override_host_uuid,
|
|
old_alert_override_level => $old_alert_override_level,
|
|
}});
|
|
|
|
# Get the translated log level name.
|
|
if ($old_alert_override_level == 0)
|
|
{
|
|
# Ignore
|
|
$anvil->data->{sys}{say_old_alert_override_level} = $anvil->Words->string({key => "unit_0023"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_alert_override_level' => $anvil->data->{sys}{say_old_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($old_alert_override_level == 1)
|
|
{
|
|
# Critical
|
|
$anvil->data->{sys}{say_old_alert_override_level} = $anvil->Words->string({key => "unit_0024"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_alert_override_level' => $anvil->data->{sys}{say_old_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($old_alert_override_level == 2)
|
|
{
|
|
# Warning
|
|
$anvil->data->{sys}{say_old_alert_override_level} = $anvil->Words->string({key => "unit_0025"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_alert_override_level' => $anvil->data->{sys}{say_old_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($old_alert_override_level == 3)
|
|
{
|
|
# Notice
|
|
$anvil->data->{sys}{say_old_alert_override_level} = $anvil->Words->string({key => "unit_0026"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_alert_override_level' => $anvil->data->{sys}{say_old_alert_override_level},
|
|
}});
|
|
}
|
|
elsif ($old_alert_override_level == 4)
|
|
{
|
|
# Info
|
|
$anvil->data->{sys}{say_old_alert_override_level} = $anvil->Words->string({key => "unit_0027"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_alert_override_level' => $anvil->data->{sys}{say_old_alert_override_level},
|
|
}});
|
|
}
|
|
|
|
# Get the name / email of the recipient and the host
|
|
$anvil->data->{sys}{say_old_alert_override_recipient} = $anvil->data->{recipients}{recipient_uuid}{$old_alert_override_recipient_uuid}{recipient_name}." (".$anvil->data->{recipients}{recipient_uuid}{$old_alert_override_recipient_uuid}{recipient_email}.")";
|
|
$anvil->data->{sys}{say_old_alert_override_host} = $anvil->data->{hosts}{host_uuid}{$old_alert_override_host_uuid}{host_name};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_alert_override_recipient' => $anvil->data->{sys}{say_old_alert_override_recipient},
|
|
'sys::say_old_alert_override_host' => $anvil->data->{sys}{say_old_alert_override_host},
|
|
}});
|
|
}
|
|
|
|
if ($confirm_needed)
|
|
{
|
|
my $key = "";
|
|
if ($anvil->data->{switches}{add})
|
|
{
|
|
$key = "message_0303";
|
|
}
|
|
elsif ($anvil->data->{switches}{edit})
|
|
{
|
|
$key = "message_0304";
|
|
}
|
|
elsif ($anvil->data->{switches}{'delete'})
|
|
{
|
|
$key = "message_0305";
|
|
}
|
|
print $anvil->Words->string({key => $key, variables => {
|
|
new_level => $anvil->data->{sys}{say_new_alert_override_level},
|
|
new_recipient => $anvil->data->{sys}{say_new_alert_override_recipient},
|
|
new_host => $anvil->data->{sys}{say_new_alert_override_host},
|
|
old_level => $anvil->data->{sys}{say_old_alert_override_level},
|
|
old_recipient => $anvil->data->{sys}{say_old_alert_override_recipient},
|
|
old_host => $anvil->data->{sys}{say_old_alert_override_host},
|
|
}})."\n";
|
|
my $answer = <STDIN>;
|
|
chomp $answer;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { answer => $answer }});
|
|
|
|
if (lc($answer) !~ /^y/)
|
|
{
|
|
print $anvil->Words->string({key => "message_0022"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
}
|
|
|
|
# Still alive?
|
|
if ($anvil->data->{switches}{add})
|
|
{
|
|
# Create the new entry.
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_alert_overrides({
|
|
debug => 2,
|
|
alert_override_recipient_uuid => $anvil->data->{switches}{"alert-override-recipient-uuid"},
|
|
alert_override_host_uuid => $anvil->data->{switches}{"alert-override-host-uuid"},
|
|
alert_override_alert_level => $anvil->data->{switches}{"alert-override-alert-level"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0297", variables => { uuid => $mail_server_uuid }})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
elsif ($anvil->data->{switches}{edit})
|
|
{
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_alert_overrides({
|
|
debug => 2,
|
|
alert_override_uuid => $anvil->data->{switches}{"alert-override-uuid"},
|
|
alert_override_recipient_uuid => $anvil->data->{switches}{"alert-override-recipient-uuid"},
|
|
alert_override_host_uuid => $anvil->data->{switches}{"alert-override-host-uuid"},
|
|
alert_override_alert_level => $anvil->data->{switches}{"alert-override-alert-level"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0298"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
elsif ($anvil->data->{switches}{'delete'})
|
|
{
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_alert_overrides({
|
|
debug => 2,
|
|
'delete' => 1,
|
|
alert_override_uuid => $anvil->data->{switches}{"alert-override-uuid"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0299"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
else
|
|
{
|
|
$anvil->data->{sys}{show}{alert_overrides} = 1;
|
|
$anvil->data->{sys}{show}{recipients} = 1;
|
|
$anvil->data->{sys}{show}{systems} = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::show::alert_overrides' => $anvil->data->{sys}{show}{alert_overrides},
|
|
'sys::show::recipients' => $anvil->data->{sys}{show}{recipients},
|
|
'sys::show::systems' => $anvil->data->{sys}{show}{systems},
|
|
}});
|
|
show_existing($anvil);
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
sub handle_recipients
|
|
{
|
|
my ($anvil) = @_;
|
|
|
|
### Are we adding, editing or deleting?
|
|
# If we're adding or editing, all fields are required.
|
|
my $confirm_needed = 0;
|
|
if (($anvil->data->{switches}{add}) or ($anvil->data->{switches}{edit}) or ($anvil->data->{switches}{'delete'}))
|
|
{
|
|
# Did the user confirm yet?
|
|
if ((not $anvil->data->{switches}{'y'}) and (not $anvil->data->{switches}{'yes'}))
|
|
{
|
|
$confirm_needed = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { confirm_needed => $confirm_needed }});
|
|
}
|
|
}
|
|
|
|
if (($anvil->data->{switches}{add}) or ($anvil->data->{switches}{edit}))
|
|
{
|
|
# Do we have what we need?
|
|
my $problem = 0;
|
|
foreach my $switch ("recipient-name", "recipient-email", "recipient-language", "recipient-level")
|
|
{
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
switch => $switch,
|
|
"switches::$switch" => $anvil->data->{switches}{$switch},
|
|
}});
|
|
if (($anvil->data->{switches}{$switch} eq "") or ($anvil->data->{switches}{$switch} eq "#!SET!#"))
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0387", variables => { switch => $switch }});
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
if ($problem)
|
|
{
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
}
|
|
|
|
# If we're editing or deleting, make sure we have a valid UUID.
|
|
my $recipient_uuid = $anvil->data->{switches}{"recipient-uuid"};
|
|
my $old_recipient_language = "";
|
|
my $old_recipient_level = "";
|
|
if (($anvil->data->{switches}{edit}) or ($anvil->data->{switches}{'delete'}))
|
|
{
|
|
if (not $recipient_uuid)
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0387", variables => { switch => "recipient-uuid" }});
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
if (not exists $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid})
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0388", variables => { uuid => $recipient_uuid }});
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
|
|
$old_recipient_language = $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_language};
|
|
$old_recipient_level = $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_level};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
old_recipient_language => $old_recipient_language,
|
|
old_recipient_level => $old_recipient_level,
|
|
}});
|
|
|
|
$anvil->data->{sys}{say_old_language} = $anvil->data->{sys}{languages}{$old_recipient_language};
|
|
|
|
# Get the translated log level name.
|
|
if ($old_recipient_level == 0)
|
|
{
|
|
# Ignore
|
|
$anvil->data->{sys}{say_old_level} = $anvil->Words->string({key => "unit_0023"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_level' => $anvil->data->{sys}{say_old_level},
|
|
}});
|
|
}
|
|
elsif ($old_recipient_level == 1)
|
|
{
|
|
# Critical
|
|
$anvil->data->{sys}{say_old_level} = $anvil->Words->string({key => "unit_0024"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_level' => $anvil->data->{sys}{say_old_level},
|
|
}});
|
|
}
|
|
elsif ($old_recipient_level == 2)
|
|
{
|
|
# Warning
|
|
$anvil->data->{sys}{say_old_level} = $anvil->Words->string({key => "unit_0025"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_level' => $anvil->data->{sys}{say_old_level},
|
|
}});
|
|
}
|
|
elsif ($old_recipient_level == 3)
|
|
{
|
|
# Notice
|
|
$anvil->data->{sys}{say_old_level} = $anvil->Words->string({key => "unit_0026"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_level' => $anvil->data->{sys}{say_old_level},
|
|
}});
|
|
}
|
|
elsif ($old_recipient_level == 4)
|
|
{
|
|
# Info
|
|
$anvil->data->{sys}{say_old_level} = $anvil->Words->string({key => "unit_0027"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_old_level' => $anvil->data->{sys}{say_old_level},
|
|
}});
|
|
}
|
|
}
|
|
|
|
if ($confirm_needed)
|
|
{
|
|
my $key = "";
|
|
if ($anvil->data->{switches}{add})
|
|
{
|
|
$key = "message_0300";
|
|
}
|
|
elsif ($anvil->data->{switches}{edit})
|
|
{
|
|
$key = "message_0301";
|
|
}
|
|
elsif ($anvil->data->{switches}{'delete'})
|
|
{
|
|
$key = "message_0302";
|
|
}
|
|
print $anvil->Words->string({key => $key, variables => {
|
|
new_name => $anvil->data->{switches}{"recipient-name"},
|
|
new_email => $anvil->data->{switches}{"recipient-email"},
|
|
new_language => $anvil->data->{sys}{say_new_language},
|
|
new_level => $anvil->data->{sys}{say_new_level},
|
|
old_name => $recipient_uuid ? $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_name} : "",
|
|
old_email => $recipient_uuid ? $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_email} : "",
|
|
old_language => $anvil->data->{sys}{say_old_language},
|
|
old_level => $anvil->data->{sys}{say_old_level},
|
|
}})."\n";
|
|
my $answer = <STDIN>;
|
|
chomp $answer;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { answer => $answer }});
|
|
|
|
if (lc($answer) !~ /^y/)
|
|
{
|
|
print $anvil->Words->string({key => "message_0022"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
}
|
|
|
|
# Still alive?
|
|
if ($anvil->data->{switches}{add})
|
|
{
|
|
# Create the new entry.
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_recipients({
|
|
debug => 2,
|
|
recipient_name => $anvil->data->{switches}{"recipient-name"},
|
|
recipient_email => $anvil->data->{switches}{"recipient-email"},
|
|
recipient_language => $anvil->data->{switches}{"recipient-language"},
|
|
recipient_level => $anvil->data->{switches}{"recipient-level"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0297", variables => { uuid => $mail_server_uuid }})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
elsif ($anvil->data->{switches}{edit})
|
|
{
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_recipients({
|
|
debug => 2,
|
|
recipient_uuid => $anvil->data->{switches}{"recipient-uuid"},
|
|
recipient_name => $anvil->data->{switches}{"recipient-name"},
|
|
recipient_email => $anvil->data->{switches}{"recipient-email"},
|
|
recipient_language => $anvil->data->{switches}{"recipient-language"},
|
|
recipient_level => $anvil->data->{switches}{"recipient-level"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0298"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
elsif ($anvil->data->{switches}{'delete'})
|
|
{
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_recipients({
|
|
debug => 2,
|
|
'delete' => 1,
|
|
recipient_uuid => $anvil->data->{switches}{"recipient-uuid"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0299"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
else
|
|
{
|
|
$anvil->data->{sys}{show}{mail_recipients} = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::show::recipients' => $anvil->data->{sys}{show}{recipients},
|
|
}});
|
|
show_existing($anvil);
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
sub handle_mail_servers
|
|
{
|
|
my ($anvil) = @_;
|
|
|
|
### Are we adding, editing or deleting?
|
|
# If we're adding or editing, all fields are required.
|
|
my $confirm_needed = 0;
|
|
if (($anvil->data->{switches}{add}) or ($anvil->data->{switches}{edit}) or ($anvil->data->{switches}{'delete'}))
|
|
{
|
|
# Did the user confirm yet?
|
|
if ((not $anvil->data->{switches}{'y'}) and (not $anvil->data->{switches}{'yes'}))
|
|
{
|
|
$confirm_needed = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { confirm_needed => $confirm_needed }});
|
|
}
|
|
}
|
|
|
|
if (($anvil->data->{switches}{add}) or ($anvil->data->{switches}{edit}))
|
|
{
|
|
# Do we have what we need?
|
|
my $problem = 0;
|
|
foreach my $switch ("mail-server-address", "mail-server-port", "mail-server-username", "mail-server-password", "mail-server-security", "mail-server-authentication", "mail-server-helo-domain")
|
|
{
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
switch => $switch,
|
|
"switches::$switch" => $anvil->data->{switches}{$switch},
|
|
}});
|
|
if (not $anvil->data->{switches}{$switch})
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0387", variables => { switch => $switch }});
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
if ($problem)
|
|
{
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
}
|
|
|
|
# If we're editing or deleting, make sure we have a valid UUID.
|
|
my $mail_server_uuid = $anvil->data->{switches}{"mail-server-uuid"};
|
|
if (($anvil->data->{switches}{edit}) or ($anvil->data->{switches}{'delete'}))
|
|
{
|
|
if (not $mail_server_uuid)
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0387", variables => { switch => "mail-server-uuid" }});
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
if (not exists $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid})
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0388", variables => { uuid => $mail_server_uuid }});
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
}
|
|
|
|
# Confirmed?
|
|
if ($confirm_needed)
|
|
{
|
|
my $key = "";
|
|
if ($anvil->data->{switches}{add})
|
|
{
|
|
$key = "message_0294";
|
|
}
|
|
elsif ($anvil->data->{switches}{edit})
|
|
{
|
|
$key = "message_0295";
|
|
}
|
|
elsif ($anvil->data->{switches}{'delete'})
|
|
{
|
|
$key = "message_0296";
|
|
}
|
|
print $anvil->Words->string({key => $key, variables => {
|
|
new_address => $anvil->data->{switches}{"mail-server-address"},
|
|
new_port => $anvil->data->{switches}{"mail-server-port"},
|
|
new_username => $anvil->data->{switches}{"mail-server-username"},
|
|
new_password => $anvil->data->{switches}{"mail-server-password"},
|
|
new_authentication => $anvil->Words->string({key => $anvil->data->{sys}{say_new_auth}}),
|
|
new_security => $anvil->Words->string({key => $anvil->data->{sys}{say_new_security}}),
|
|
new_helo_domain => $anvil->data->{switches}{"mail-server-helo-domain"},
|
|
old_address => $mail_server_uuid ? $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_address} : "",
|
|
old_port => $mail_server_uuid ? $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_port} : "",
|
|
old_username => $mail_server_uuid ? $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_username} : "",
|
|
old_password => $mail_server_uuid ? $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_password} : "",
|
|
old_authentication => $mail_server_uuid ? $anvil->Words->string({key => $anvil->data->{sys}{say_old_auth}}) : "",
|
|
old_security => $mail_server_uuid ? $anvil->Words->string({key => $anvil->data->{sys}{say_old_security}}) : "",
|
|
old_helo_domain => $mail_server_uuid ? $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_helo_domain} : "",
|
|
}})."\n";
|
|
my $answer = <STDIN>;
|
|
chomp $answer;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { answer => $answer }});
|
|
|
|
if (lc($answer) !~ /^y/)
|
|
{
|
|
print $anvil->Words->string({key => "message_0022"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
}
|
|
|
|
# Still alive?
|
|
if ($anvil->data->{switches}{add})
|
|
{
|
|
# Create the new entry.
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_mail_servers({
|
|
debug => 2,
|
|
mail_server_address => $anvil->data->{switches}{"mail-server-address"},
|
|
mail_server_port => $anvil->data->{switches}{"mail-server-port"},
|
|
mail_server_username => $anvil->data->{switches}{"mail-server-username"},
|
|
mail_server_password => $anvil->data->{switches}{"mail-server-password"},
|
|
mail_server_authentication => $anvil->data->{switches}{"mail-server-authentication"},
|
|
mail_server_security => $anvil->data->{switches}{"mail-server-security"},
|
|
mail_server_helo_domain => $anvil->data->{switches}{"mail-server-helo-domain"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0297", variables => { uuid => $mail_server_uuid }})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
elsif ($anvil->data->{switches}{edit})
|
|
{
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_mail_servers({
|
|
debug => 2,
|
|
mail_server_uuid => $anvil->data->{switches}{"mail-server-uuid"},
|
|
mail_server_address => $anvil->data->{switches}{"mail-server-address"},
|
|
mail_server_port => $anvil->data->{switches}{"mail-server-port"},
|
|
mail_server_username => $anvil->data->{switches}{"mail-server-username"},
|
|
mail_server_password => $anvil->data->{switches}{"mail-server-password"},
|
|
mail_server_authentication => $anvil->data->{switches}{"mail-server-authentication"},
|
|
mail_server_security => $anvil->data->{switches}{"mail-server-security"},
|
|
mail_server_helo_domain => $anvil->data->{switches}{"mail-server-helo-domain"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0298"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
elsif ($anvil->data->{switches}{'delete'})
|
|
{
|
|
my ($mail_server_uuid) = $anvil->Database->insert_or_update_mail_servers({
|
|
debug => 2,
|
|
'delete' => 1,
|
|
mail_server_uuid => $anvil->data->{switches}{"mail-server-uuid"},
|
|
});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_server_uuid => $mail_server_uuid }});
|
|
print $anvil->Words->string({key => "message_0299"})."\n";
|
|
$anvil->nice_exit({exit_code => 0});
|
|
}
|
|
else
|
|
{
|
|
$anvil->data->{sys}{show}{mail_servers} = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::show::mail_servers' => $anvil->data->{sys}{show}{mail_servers},
|
|
}});
|
|
show_existing($anvil);
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
# Show existing mail servers.
|
|
sub show_existing
|
|
{
|
|
my ($anvil) = @_;
|
|
|
|
# Show mail servers
|
|
$anvil->data->{longest}{mail_server_address} = length($anvil->Words->string({key => "header_0086"}));
|
|
$anvil->data->{longest}{mail_server_port} = length($anvil->Words->string({key => "header_0087"}));
|
|
$anvil->data->{longest}{mail_server_username} = length($anvil->Words->string({key => "header_0088"}));
|
|
$anvil->data->{longest}{mail_server_password} = length($anvil->Words->string({key => "header_0089"}));
|
|
$anvil->data->{longest}{mail_server_security} = length($anvil->Words->string({key => "header_0090"}));
|
|
$anvil->data->{longest}{mail_server_authentication} = length($anvil->Words->string({key => "header_0091"}));
|
|
$anvil->data->{longest}{mail_server_helo_domain} = length($anvil->Words->string({key => "header_0092"}));
|
|
$anvil->data->{longest}{mail_server_uuid} = length($anvil->Words->string({key => "header_0093"}));
|
|
$anvil->data->{longest}{recipient_name} = length($anvil->Words->string({key => "header_0003"}));
|
|
$anvil->data->{longest}{recipient_email} = length($anvil->Words->string({key => "header_0095"}));
|
|
$anvil->data->{longest}{recipient_alert_level} = length($anvil->Words->string({key => "header_0096"}));
|
|
$anvil->data->{longest}{recipient_language} = length($anvil->Words->string({key => "header_0097"}));
|
|
$anvil->data->{longest}{recipient_uuid} = length($anvil->Words->string({key => "header_0098"}));
|
|
$anvil->data->{longest}{alert_override_recipient_name} = length($anvil->Words->string({key => "header_0100"}));
|
|
$anvil->data->{longest}{alert_override_host_name} = length($anvil->Words->string({key => "header_0026"}));
|
|
$anvil->data->{longest}{alert_override_anvil_name} = length($anvil->Words->string({key => "header_0101"}));
|
|
$anvil->data->{longest}{alert_override_alert_level} = length($anvil->Words->string({key => "header_0096"}));
|
|
$anvil->data->{longest}{alert_override_uuid} = length($anvil->Words->string({key => "header_0102"}));
|
|
$anvil->data->{longest}{host_name} = length($anvil->Words->string({key => "header_0026"}));
|
|
$anvil->data->{longest}{host_type} = length($anvil->Words->string({key => "header_0103"}));
|
|
$anvil->data->{longest}{host_anvil_name} = length($anvil->Words->string({key => "header_0081"}));
|
|
$anvil->data->{longest}{host_uuid} = length($anvil->Words->string({key => "header_0104"}));
|
|
|
|
$anvil->data->{say_alert}{1} = "1 (".$anvil->Words->string({key => "unit_0024"}).")";
|
|
$anvil->data->{say_alert}{2} = "2 (".$anvil->Words->string({key => "unit_0025"}).")";
|
|
$anvil->data->{say_alert}{3} = "3 (".$anvil->Words->string({key => "unit_0026"}).")";
|
|
$anvil->data->{say_alert}{4} = "4 (".$anvil->Words->string({key => "unit_0027"}).")";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'say_alert::1' => $anvil->data->{say_alert}{1},
|
|
'say_alert::2' => $anvil->data->{say_alert}{2},
|
|
'say_alert::3' => $anvil->data->{say_alert}{3},
|
|
'say_alert::4' => $anvil->data->{say_alert}{4},
|
|
}});
|
|
|
|
# Get longest counts.
|
|
foreach my $mail_server_address (sort {$a cmp $b} keys %{$anvil->data->{mail_servers}{address_to_uuid}})
|
|
{
|
|
my $mail_server_uuid = $anvil->data->{mail_servers}{address_to_uuid}{$mail_server_address};
|
|
my $mail_server_port = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_port};
|
|
my $mail_server_username = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_username};
|
|
my $mail_server_password = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_password};
|
|
my $mail_server_security = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_security};
|
|
my $mail_server_authentication = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_authentication};
|
|
my $mail_server_helo_domain = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_helo_domain};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:mail_server_address' => $mail_server_address,
|
|
's2:mail_server_uuid' => $mail_server_uuid,
|
|
's3:mail_server_port' => $mail_server_port,
|
|
's4:mail_server_username' => $mail_server_username,
|
|
's5:mail_server_password' => $anvil->Log->is_secure($mail_server_password),
|
|
's6:mail_server_security' => $mail_server_security,
|
|
's7:mail_server_authentication' => $mail_server_authentication,
|
|
's8:mail_server_helo_domain' => $mail_server_helo_domain,
|
|
}});
|
|
|
|
# mail_server_helo_domain is 'DELETED' if, well, deleted.
|
|
next if $mail_server_helo_domain eq "DELETED";
|
|
|
|
if (length($mail_server_address) > $anvil->data->{longest}{mail_server_address})
|
|
{
|
|
$anvil->data->{longest}{mail_server_address} = length($mail_server_address);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_address' => $anvil->data->{longest}{mail_server_address},
|
|
}});
|
|
}
|
|
|
|
if (length($mail_server_port) > $anvil->data->{longest}{mail_server_port})
|
|
{
|
|
$anvil->data->{longest}{mail_server_port} = length($mail_server_port);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_port' => $anvil->data->{longest}{mail_server_port},
|
|
}});
|
|
}
|
|
|
|
if (length($mail_server_username) > $anvil->data->{longest}{mail_server_username})
|
|
{
|
|
$anvil->data->{longest}{mail_server_username} = length($mail_server_username);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_username' => $anvil->data->{longest}{mail_server_username},
|
|
}});
|
|
}
|
|
|
|
if (length($mail_server_password) > $anvil->data->{longest}{mail_server_password})
|
|
{
|
|
$anvil->data->{longest}{mail_server_password} = length($mail_server_password);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_password' => $anvil->data->{longest}{mail_server_password},
|
|
}});
|
|
}
|
|
|
|
if (length($mail_server_security) > $anvil->data->{longest}{mail_server_security})
|
|
{
|
|
$anvil->data->{longest}{mail_server_security} = length($mail_server_security);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_security' => $anvil->data->{longest}{mail_server_security},
|
|
}});
|
|
}
|
|
|
|
if (length($mail_server_authentication) > $anvil->data->{longest}{mail_server_authentication})
|
|
{
|
|
$anvil->data->{longest}{mail_server_authentication} = length($mail_server_authentication);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_authentication' => $anvil->data->{longest}{mail_server_authentication},
|
|
}});
|
|
}
|
|
|
|
if (length($mail_server_helo_domain) > $anvil->data->{longest}{mail_server_helo_domain})
|
|
{
|
|
$anvil->data->{longest}{mail_server_helo_domain} = length($mail_server_helo_domain);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_helo_domain' => $anvil->data->{longest}{mail_server_helo_domain},
|
|
}});
|
|
}
|
|
|
|
if (length($mail_server_uuid) > $anvil->data->{longest}{mail_server_uuid})
|
|
{
|
|
$anvil->data->{longest}{mail_server_uuid} = length($mail_server_uuid);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::mail_server_uuid' => $anvil->data->{longest}{mail_server_uuid},
|
|
}});
|
|
}
|
|
}
|
|
|
|
foreach my $alert_override_uuid (sort {$a cmp $b} keys %{$anvil->data->{alert_overrides}{alert_override_uuid}})
|
|
{
|
|
my $alert_override_recipient_uuid = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_recipient_uuid};
|
|
my $alert_override_recipient_name = $anvil->data->{recipients}{recipient_uuid}{$alert_override_recipient_uuid}{recipient_name};
|
|
my $alert_override_recipient_email = $anvil->data->{recipients}{recipient_uuid}{$alert_override_recipient_uuid}{recipient_email};
|
|
my $say_recipient = $alert_override_recipient_name." <".$alert_override_recipient_email.">";
|
|
my $alert_override_host_uuid = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_host_uuid};
|
|
my $alert_override_short_host_name = $anvil->data->{hosts}{host_uuid}{$alert_override_host_uuid}{short_host_name};
|
|
my $say_anvil_name = $anvil->data->{hosts}{host_uuid}{$alert_override_host_uuid}{anvil_name} ? $anvil->data->{hosts}{host_uuid}{$alert_override_host_uuid}{anvil_name} : "--";
|
|
my $alert_override_alert_level = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_alert_level};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:alert_override_uuid' => $alert_override_uuid,
|
|
's2:alert_override_recipient_uuid' => $alert_override_recipient_uuid,
|
|
's3:alert_override_recipient_name' => $alert_override_recipient_name,
|
|
's4:alert_override_recipient_email' => $alert_override_recipient_email,
|
|
's5:say_recipient' => $say_recipient,
|
|
's6:alert_override_host_uuid' => $alert_override_host_uuid,
|
|
's7:alert_override_short_host_name' => $alert_override_short_host_name,
|
|
's8:say_anvil_name' => $say_anvil_name,
|
|
's9:alert_override_alert_level' => $alert_override_alert_level,
|
|
}});
|
|
|
|
if (length($say_recipient) > $anvil->data->{longest}{alert_override_recipient_name})
|
|
{
|
|
$anvil->data->{longest}{alert_override_recipient_name} = length($say_recipient);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::alert_override_recipient_name' => $anvil->data->{longest}{alert_override_recipient_name},
|
|
}});
|
|
}
|
|
|
|
if (length($alert_override_short_host_name) > $anvil->data->{longest}{alert_override_host_name})
|
|
{
|
|
$anvil->data->{longest}{alert_override_host_name} = length($alert_override_short_host_name);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::alert_override_host_name' => $anvil->data->{longest}{alert_override_host_name},
|
|
}});
|
|
}
|
|
|
|
if (length($say_anvil_name) > $anvil->data->{longest}{alert_override_anvil_name})
|
|
{
|
|
$anvil->data->{longest}{alert_override_anvil_name} = length($say_anvil_name);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::alert_override_anvil_name' => $anvil->data->{longest}{alert_override_anvil_name},
|
|
}});
|
|
}
|
|
|
|
if (length($anvil->data->{say_alert}{$alert_override_alert_level}) > $anvil->data->{longest}{alert_override_alert_level})
|
|
{
|
|
$anvil->data->{longest}{alert_override_alert_level} = length($anvil->data->{say_alert}{$alert_override_alert_level});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::alert_override_alert_level' => $anvil->data->{longest}{alert_override_alert_level},
|
|
}});
|
|
}
|
|
|
|
if (length($alert_override_uuid) > $anvil->data->{longest}{alert_override_uuid})
|
|
{
|
|
$anvil->data->{longest}{alert_override_uuid} = length($alert_override_uuid);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::alert_override_uuid' => $anvil->data->{longest}{alert_override_uuid},
|
|
}});
|
|
}
|
|
|
|
# This will let us display over-rides by user in order.
|
|
$anvil->data->{alert_overrides}{name_to_uuid}{$alert_override_recipient_name} = $alert_override_uuid;
|
|
$anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{recipient_name} = $say_recipient;
|
|
$anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{anvil_name} = $say_anvil_name;
|
|
$anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{host_uuid} = $alert_override_host_uuid;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"s1:alert_overrides::name_to_uuid::${alert_override_recipient_name}" => $anvil->data->{alert_overrides}{name_to_uuid}{$alert_override_recipient_name},
|
|
"s2:alert_overrides::alert_override_uuid::${alert_override_uuid}::recipient_name" => $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{recipient_name},
|
|
"s3:alert_overrides::alert_override_uuid::${alert_override_uuid}::anvil_name" => $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{anvil_name},
|
|
"s4:alert_overrides::alert_override_uuid::${alert_override_uuid}::host_uuid" => $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{host_uuid},
|
|
}});
|
|
}
|
|
|
|
foreach my $recipient_name (sort {$a cmp $b} keys %{$anvil->data->{recipients}{name_to_uuid}})
|
|
{
|
|
my $recipient_uuid = $anvil->data->{recipients}{name_to_uuid}{$recipient_name};
|
|
my $recipient_email = $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_email};
|
|
my $recipient_language = $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_language};
|
|
my $say_language = $anvil->data->{sys}{languages}{$recipient_language};
|
|
my $recipient_level = say_recipient_level($anvil, $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_level});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"s1:recipient_name" => $recipient_name,
|
|
"s2:recipient_uuid" => $recipient_uuid,
|
|
"s3:recipient_email" => $recipient_email,
|
|
"s4:recipient_language" => $recipient_language,
|
|
"s5:say_language" => $say_language,
|
|
"s6:recipient_level" => $recipient_level,
|
|
}});
|
|
|
|
if (length($recipient_name) > $anvil->data->{longest}{recipient_name})
|
|
{
|
|
$anvil->data->{longest}{recipient_name} = length($recipient_name);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::recipient_name' => $anvil->data->{longest}{recipient_name},
|
|
}});
|
|
}
|
|
|
|
if (length($recipient_email) > $anvil->data->{longest}{recipient_email})
|
|
{
|
|
$anvil->data->{longest}{recipient_email} = length($recipient_email);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::recipient_email' => $anvil->data->{longest}{recipient_email},
|
|
}});
|
|
}
|
|
|
|
if (length($say_language) > $anvil->data->{longest}{recipient_language})
|
|
{
|
|
$anvil->data->{longest}{recipient_language} = length($say_language);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::recipient_language' => $anvil->data->{longest}{recipient_language},
|
|
}});
|
|
}
|
|
|
|
if (length($recipient_level) > $anvil->data->{longest}{recipient_alert_level})
|
|
{
|
|
$anvil->data->{longest}{recipient_alert_level} = length($recipient_level);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::recipient_alert_level' => $anvil->data->{longest}{recipient_alert_level},
|
|
}});
|
|
}
|
|
|
|
if (length($recipient_uuid) > $anvil->data->{longest}{recipient_uuid})
|
|
{
|
|
$anvil->data->{longest}{recipient_uuid} = length($recipient_uuid);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::recipient_uuid' => $anvil->data->{longest}{recipient_uuid},
|
|
}});
|
|
}
|
|
}
|
|
|
|
# Pull out the Strikers, node pair members and DR hosts.
|
|
foreach my $host_name (sort {$a cmp $b} keys %{$anvil->data->{sys}{hosts}{by_name}})
|
|
{
|
|
my $host_uuid = $anvil->data->{sys}{hosts}{by_name}{$host_name};
|
|
my $short_host_name = $anvil->data->{hosts}{host_uuid}{$host_uuid}{short_host_name};
|
|
my $host_type = $anvil->data->{hosts}{host_uuid}{$host_uuid}{host_type};
|
|
my $anvil_name = $anvil->data->{hosts}{host_uuid}{$host_uuid}{anvil_name} ? $anvil->data->{hosts}{host_uuid}{$host_uuid}{anvil_name} : "--";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:host_name' => $host_name,
|
|
's2:short_host_name' => $short_host_name,
|
|
's3:host_type' => $host_type,
|
|
's4:anvil_name' => $anvil_name,
|
|
}});
|
|
|
|
if (length($short_host_name) > $anvil->data->{longest}{host_name})
|
|
{
|
|
$anvil->data->{longest}{host_name} = length($short_host_name);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::host_name' => $anvil->data->{longest}{host_name},
|
|
}});
|
|
}
|
|
|
|
$anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type} = "";
|
|
if ($host_type eq "striker")
|
|
{
|
|
$anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type} = $anvil->Words->string({key => "brand_0003"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"hosts::host_uuid::${host_uuid}::say_host_type" => $anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type},
|
|
}});
|
|
}
|
|
elsif ($host_type eq "node")
|
|
{
|
|
$anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type} = $anvil->Words->string({key => "brand_0007"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"hosts::host_uuid::${host_uuid}::say_host_type" => $anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type},
|
|
}});
|
|
}
|
|
elsif ($host_type eq "dr")
|
|
{
|
|
$anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type} = $anvil->Words->string({key => "brand_0008"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"hosts::host_uuid::${host_uuid}::say_host_type" => $anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type},
|
|
}});
|
|
}
|
|
if (length($anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type}) > $anvil->data->{longest}{host_type})
|
|
{
|
|
$anvil->data->{longest}{host_type} = length($anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::host_type' => $anvil->data->{longest}{host_type},
|
|
}});
|
|
}
|
|
|
|
if (length($anvil_name) > $anvil->data->{longest}{host_anvil_name})
|
|
{
|
|
$anvil->data->{longest}{host_anvil_name} = length($anvil_name);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::host_anvil_name' => $anvil->data->{longest}{host_anvil_name},
|
|
}});
|
|
}
|
|
|
|
if (length($host_uuid) > $anvil->data->{longest}{host_uuid})
|
|
{
|
|
$anvil->data->{longest}{host_uuid} = length($host_uuid);
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'longest::host_uuid' => $anvil->data->{longest}{host_uuid},
|
|
}});
|
|
}
|
|
}
|
|
|
|
# Now show the data.
|
|
if ($anvil->data->{sys}{show}{mail_servers})
|
|
{
|
|
my $longest_mail_server_address = $anvil->data->{longest}{mail_server_address};
|
|
my $longest_mail_server_port = $anvil->data->{longest}{mail_server_port};
|
|
my $longest_mail_server_username = $anvil->data->{longest}{mail_server_username};
|
|
my $longest_mail_server_password = $anvil->data->{longest}{mail_server_password};
|
|
my $longest_mail_server_security = $anvil->data->{longest}{mail_server_security};
|
|
my $longest_mail_server_authentication = $anvil->data->{longest}{mail_server_authentication};
|
|
my $longest_mail_server_helo_domain = $anvil->data->{longest}{mail_server_helo_domain};
|
|
my $longest_mail_server_uuid = $anvil->data->{longest}{mail_server_uuid};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:longest_mail_server_address' => $longest_mail_server_address,
|
|
's2:longest_mail_server_port' => $longest_mail_server_port,
|
|
's3:longest_mail_server_username' => $longest_mail_server_username,
|
|
's4:longest_mail_server_password' => $longest_mail_server_password,
|
|
's5:longest_mail_server_security' => $longest_mail_server_security,
|
|
's6:longest_mail_server_authentication' => $longest_mail_server_authentication,
|
|
's7:longest_mail_server_helo_domain' => $longest_mail_server_helo_domain,
|
|
's8:longest_mail_server_uuid' => $longest_mail_server_uuid,
|
|
}});
|
|
|
|
my $break_line = "+-".sprintf("%0${longest_mail_server_address}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_mail_server_port}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_mail_server_username}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_mail_server_password}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_mail_server_security}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_mail_server_authentication}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_mail_server_helo_domain}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_mail_server_uuid}d", 0)."-+";
|
|
$break_line =~ s/0/-/g;
|
|
|
|
my $header_line = "| ".sprintf("%-${longest_mail_server_address}s", $anvil->Words->string({key => "header_0086"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_mail_server_port}s", $anvil->Words->string({key => "header_0087"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_mail_server_username}s", $anvil->Words->string({key => "header_0088"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_mail_server_password}s", $anvil->Words->string({key => "header_0089"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_mail_server_security}s", $anvil->Words->string({key => "header_0090"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_mail_server_authentication}s", $anvil->Words->string({key => "header_0091"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_mail_server_helo_domain}s", $anvil->Words->string({key => "header_0092"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_mail_server_uuid}s", $anvil->Words->string({key => "header_0093"}))." |";
|
|
|
|
# Display
|
|
print "-=] ".$anvil->Words->string({key => "striker_0187"})."\n";
|
|
print $break_line."\n";
|
|
print $header_line."\n";
|
|
print $break_line."\n";
|
|
my $mail_servers = 0;
|
|
foreach my $mail_server_address (sort {$a cmp $b} keys %{$anvil->data->{mail_servers}{address_to_uuid}})
|
|
{
|
|
my $mail_server_uuid = $anvil->data->{mail_servers}{address_to_uuid}{$mail_server_address};
|
|
my $mail_server_port = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_port};
|
|
my $mail_server_username = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_username};
|
|
my $mail_server_password = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_password};
|
|
my $mail_server_security = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_security};
|
|
my $mail_server_authentication = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_authentication};
|
|
my $mail_server_helo_domain = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_helo_domain};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:mail_server_address' => $mail_server_address,
|
|
's2:mail_server_uuid' => $mail_server_uuid,
|
|
's3:mail_server_port' => $mail_server_port,
|
|
's4:mail_server_username' => $mail_server_username,
|
|
's5:mail_server_password' => $anvil->Log->is_secure($mail_server_password),
|
|
's6:mail_server_security' => $mail_server_security,
|
|
's7:mail_server_authentication' => $mail_server_authentication,
|
|
's8:mail_server_helo_domain' => $mail_server_helo_domain,
|
|
}});
|
|
next if $mail_server_helo_domain eq "DELETED";
|
|
|
|
my $entry_line = "| ".sprintf("%-${longest_mail_server_address}s", $mail_server_address)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_port}s", $mail_server_port)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_username}s", $mail_server_username)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_password}s", $mail_server_password)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_security}s", $mail_server_security)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_authentication}s", $mail_server_authentication)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_helo_domain}s", $mail_server_helo_domain)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_uuid}s", $mail_server_uuid)." |";
|
|
print $entry_line."\n";
|
|
|
|
$mail_servers++;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { mail_servers => $mail_servers }});
|
|
}
|
|
if (not $mail_servers)
|
|
{
|
|
my $entry_line = "| ".sprintf("%-${longest_mail_server_address}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_port}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_username}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_password}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_security}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_authentication}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_helo_domain}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_mail_server_uuid}s", '--')." |";
|
|
print $entry_line."\n";
|
|
}
|
|
print $break_line."\n";
|
|
print "\n";
|
|
}
|
|
|
|
if ($anvil->data->{sys}{show}{recipients})
|
|
{
|
|
my $longest_recipient_name = $anvil->data->{longest}{recipient_name};
|
|
my $longest_recipient_email = $anvil->data->{longest}{recipient_email};
|
|
my $longest_recipient_alert_level = $anvil->data->{longest}{recipient_alert_level};
|
|
my $longest_recipient_language = $anvil->data->{longest}{recipient_language};
|
|
my $longest_recipient_uuid = $anvil->data->{longest}{recipient_uuid};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:longest_recipient_name' => $longest_recipient_name,
|
|
's2:longest_recipient_email' => $longest_recipient_email,
|
|
's3:longest_recipient_alert_level' => $longest_recipient_alert_level,
|
|
's4:longest_recipient_language' => $longest_recipient_language,
|
|
's5:longest_recipient_uuid' => $longest_recipient_uuid,
|
|
}});
|
|
|
|
my $break_line = "+-".sprintf("%0${longest_recipient_name}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_recipient_email}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_recipient_alert_level}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_recipient_language}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_recipient_uuid}d", 0)."-+";
|
|
$break_line =~ s/0/-/g;
|
|
|
|
my $header_line = "| ".sprintf("%-${longest_recipient_name}s", $anvil->Words->string({key => "header_0003"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_recipient_email}s", $anvil->Words->string({key => "header_0095"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_recipient_alert_level}s", $anvil->Words->string({key => "header_0096"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_recipient_language}s", $anvil->Words->string({key => "header_0097"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_recipient_uuid}s", $anvil->Words->string({key => "header_0098"}))." |";
|
|
|
|
# Display
|
|
print "-=] ".$anvil->Words->string({key => "header_0094"})."\n";
|
|
print $break_line."\n";
|
|
print $header_line."\n";
|
|
print $break_line."\n";
|
|
my $recipients = 0;
|
|
foreach my $recipient_name (sort {$a cmp $b} keys %{$anvil->data->{recipients}{name_to_uuid}})
|
|
{
|
|
my $recipient_uuid = $anvil->data->{recipients}{name_to_uuid}{$recipient_name};
|
|
my $recipient_email = $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_email};
|
|
my $recipient_language = $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_language};
|
|
my $say_language = $anvil->data->{sys}{languages}{$recipient_language};
|
|
my $recipient_level = $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid}{recipient_level};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"s1:recipient_name" => $recipient_name,
|
|
"s2:recipient_uuid" => $recipient_uuid,
|
|
"s3:recipient_email" => $recipient_email,
|
|
"s4:recipient_language" => $recipient_language,
|
|
"s5:say_language" => $say_language,
|
|
"s6:recipient_level" => $recipient_level,
|
|
}});
|
|
|
|
# Get the translated log level name.
|
|
my $say_recipient_level = say_recipient_level($anvil, $recipient_level);
|
|
|
|
my $entry_line = "| ".sprintf("%-${longest_recipient_name}s", $recipient_name)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_email}s", $recipient_email)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_alert_level}s", $say_recipient_level)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_language}s", $say_language)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_uuid}s", $recipient_uuid)." |";
|
|
print $entry_line."\n";
|
|
|
|
$recipients++;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { recipients => $recipients }});
|
|
}
|
|
if (not $recipients)
|
|
{
|
|
my $entry_line = "| ".sprintf("%-${longest_recipient_name}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_email}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_alert_level}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_language}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_recipient_uuid}s", '--')." |";
|
|
print $entry_line."\n";
|
|
}
|
|
print $break_line."\n";
|
|
print "\n";
|
|
}
|
|
|
|
if ($anvil->data->{sys}{show}{alert_overrides})
|
|
{
|
|
my $longest_alert_override_recipient_name = $anvil->data->{longest}{alert_override_recipient_name};
|
|
my $longest_alert_override_host_name = $anvil->data->{longest}{alert_override_host_name};
|
|
my $longest_alert_override_anvil_name = $anvil->data->{longest}{alert_override_anvil_name};
|
|
my $longest_alert_override_alert_level = $anvil->data->{longest}{alert_override_alert_level};;
|
|
my $longest_alert_override_uuid = $anvil->data->{longest}{alert_override_uuid};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:longest_alert_override_recipient_name' => $longest_alert_override_recipient_name,
|
|
's2:longest_alert_override_host_name' => $longest_alert_override_host_name,
|
|
's3:longest_alert_override_anvil_name' => $longest_alert_override_anvil_name,
|
|
's4:longest_alert_override_alert_level' => $longest_alert_override_alert_level,
|
|
's5:longest_alert_override_uuid' => $longest_alert_override_uuid,
|
|
}});
|
|
|
|
my $break_line = "+-".sprintf("%0${longest_alert_override_recipient_name}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_alert_override_host_name}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_alert_override_anvil_name}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_alert_override_alert_level}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_alert_override_uuid}d", 0)."-+";
|
|
$break_line =~ s/0/-/g;
|
|
|
|
my $header_line = "| ".sprintf("%-${longest_alert_override_recipient_name}s", $anvil->Words->string({key => "header_0100"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_alert_override_host_name}s", $anvil->Words->string({key => "header_0026"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_alert_override_anvil_name}s", $anvil->Words->string({key => "header_0101"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_alert_override_alert_level}s", $anvil->Words->string({key => "header_0096"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_alert_override_uuid}s", $anvil->Words->string({key => "header_0102"}))." |";
|
|
|
|
# Display
|
|
print "-=] ".$anvil->Words->string({key => "header_0099"})."\n";
|
|
print $break_line."\n";
|
|
print $header_line."\n";
|
|
print $break_line."\n";
|
|
|
|
my $alert_overrides = 0;
|
|
foreach my $recipient_name (sort {$a cmp $b} keys %{$anvil->data->{alert_overrides}{name_to_uuid}})
|
|
{
|
|
my $alert_override_uuid = $anvil->data->{alert_overrides}{name_to_uuid}{$recipient_name};
|
|
my $say_recipient = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{recipient_name};
|
|
my $say_anvil_name = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{anvil_name};
|
|
my $host_uuid = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_host_uuid};
|
|
my $short_host_name = $anvil->data->{hosts}{host_uuid}{$host_uuid}{short_host_name};
|
|
my $alert_level = $anvil->data->{alert_overrides}{alert_override_uuid}{$alert_override_uuid}{alert_override_alert_level};
|
|
my $say_alert_level = $anvil->data->{say_alert}{$alert_level};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:alert_override_uuid' => $alert_override_uuid,
|
|
's2:say_recipient' => $say_recipient,
|
|
's3:say_anvil_name' => $say_anvil_name,
|
|
's4:alert_level' => $alert_level,
|
|
's5:say_alert_level' => $say_alert_level,
|
|
}});
|
|
|
|
my $entry_line = "| ".sprintf("%-${longest_alert_override_recipient_name}s", $say_recipient)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_host_name}s", $short_host_name)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_anvil_name}s", $say_anvil_name)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_alert_level}s", $say_alert_level)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_uuid}s", $alert_override_uuid)." |";
|
|
print $entry_line."\n";
|
|
|
|
$alert_overrides++;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { alert_overrides => $alert_overrides }});
|
|
}
|
|
if (not $alert_overrides)
|
|
{
|
|
my $entry_line = "| ".sprintf("%-${longest_alert_override_recipient_name}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_host_name}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_anvil_name}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_alert_level}s", '--')." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_alert_override_uuid}s", '--')." |";
|
|
print $entry_line."\n";
|
|
}
|
|
print $break_line."\n";
|
|
print "\n";
|
|
}
|
|
|
|
# Lastly, show machines.
|
|
if ($anvil->data->{sys}{show}{systems})
|
|
{
|
|
my $longest_host_name = $anvil->data->{longest}{host_name};
|
|
my $longest_host_type = $anvil->data->{longest}{host_type};
|
|
my $longest_host_anvil_name = $anvil->data->{longest}{host_anvil_name};
|
|
my $longest_host_uuid = $anvil->data->{longest}{host_uuid};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:longest_host_name' => $longest_host_name,
|
|
's2:longest_host_type' => $longest_host_type,
|
|
's3:longest_host_anvil_name' => $longest_host_anvil_name,
|
|
's4:longest_host_uuid' => $longest_host_uuid,
|
|
}});
|
|
|
|
my $break_line = "+-".sprintf("%0${longest_host_name}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_host_type}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_host_anvil_name}d", 0);
|
|
$break_line .= "-+-".sprintf("%0${longest_host_uuid}d", 0)."-+";
|
|
$break_line =~ s/0/-/g;
|
|
|
|
my $header_line = "| ".sprintf("%-${longest_host_name}s", $anvil->Words->string({key => "header_0026"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_host_type}s", $anvil->Words->string({key => "header_0103"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_host_anvil_name}s", $anvil->Words->string({key => "header_0081"}))." ";
|
|
$header_line .= "| ".sprintf("%-${longest_host_uuid}s", $anvil->Words->string({key => "header_0104"}))." |";
|
|
|
|
# Display
|
|
print "-=] ".$anvil->Words->string({key => "header_0105"})."\n";
|
|
print $break_line."\n";
|
|
print $header_line."\n";
|
|
print $break_line."\n";
|
|
foreach my $show_host_type ("striker", "node", "dr")
|
|
{
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { show_host_type => $show_host_type }});
|
|
foreach my $host_name (sort {$a cmp $b} keys %{$anvil->data->{sys}{hosts}{by_name}})
|
|
{
|
|
my $host_uuid = $anvil->data->{sys}{hosts}{by_name}{$host_name};
|
|
my $short_host_name = $anvil->data->{hosts}{host_uuid}{$host_uuid}{short_host_name};
|
|
my $host_type = $anvil->data->{hosts}{host_uuid}{$host_uuid}{host_type};
|
|
my $say_host_type = $anvil->data->{hosts}{host_uuid}{$host_uuid}{say_host_type};
|
|
my $anvil_name = $anvil->data->{hosts}{host_uuid}{$host_uuid}{anvil_name} ? $anvil->data->{hosts}{host_uuid}{$host_uuid}{anvil_name} : "--";
|
|
next if $host_type ne $show_host_type;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
's1:host_name' => $host_name,
|
|
's2:host_uuid' => $host_uuid,
|
|
's3:short_host_name' => $short_host_name,
|
|
's4:host_type' => $host_type,
|
|
's5:say_host_type' => $say_host_type,
|
|
's6:anvil_name' => $anvil_name,
|
|
}});
|
|
|
|
my $entry_line = "| ".sprintf("%-${longest_host_name}s", $short_host_name)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_host_type}s", $say_host_type)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_host_anvil_name}s", $anvil_name)." ";
|
|
$entry_line .= "| ".sprintf("%-${longest_host_uuid}s", $host_uuid)." |";
|
|
print $entry_line."\n";
|
|
}
|
|
}
|
|
print $break_line."\n";
|
|
}
|
|
|
|
return(0);
|
|
}
|
|
|
|
sub say_recipient_level
|
|
{
|
|
my ($anvil, $recipient_level) = @_;
|
|
|
|
my $say_recipient_level = $recipient_level;
|
|
if ($recipient_level == 0)
|
|
{
|
|
# Ignore
|
|
$say_recipient_level .= " (".$anvil->Words->string({key => "unit_0023"}).")";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { say_recipient_level => $say_recipient_level }});
|
|
}
|
|
elsif ($recipient_level == 1)
|
|
{
|
|
# Critical
|
|
$say_recipient_level .= " (".$anvil->Words->string({key => "unit_0024"}).")";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { say_recipient_level => $say_recipient_level }});
|
|
}
|
|
elsif ($recipient_level == 2)
|
|
{
|
|
# Warning
|
|
$say_recipient_level .= " (".$anvil->Words->string({key => "unit_0025"}).")";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { say_recipient_level => $say_recipient_level }});
|
|
}
|
|
elsif ($recipient_level == 3)
|
|
{
|
|
# Notice
|
|
$say_recipient_level .= " (".$anvil->Words->string({key => "unit_0026"}).")";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { say_recipient_level => $say_recipient_level }});
|
|
}
|
|
elsif ($recipient_level == 4)
|
|
{
|
|
# Info
|
|
$say_recipient_level .= " (".$anvil->Words->string({key => "unit_0027"}).")";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { say_recipient_level => $say_recipient_level }});
|
|
}
|
|
|
|
return($say_recipient_level);
|
|
}
|
|
|
|
# This sanity checks input switches. By necessity, this also loads data from the database.
|
|
sub check_switches
|
|
{
|
|
my ($anvil) = @_;
|
|
|
|
# Load data
|
|
$anvil->Database->get_hosts();
|
|
$anvil->Database->get_anvils();
|
|
$anvil->Database->get_mail_servers();
|
|
$anvil->Database->get_recipients();
|
|
$anvil->Database->get_alert_overrides();
|
|
$anvil->Words->language_list();
|
|
|
|
### Now sanity check
|
|
my $problem = 0;
|
|
|
|
# These will be used to limit the display of things, if/when appropriate
|
|
$anvil->data->{sys}{show}{mail_servers} = 0;
|
|
$anvil->data->{sys}{show}{recipients} = 0;
|
|
$anvil->data->{sys}{show}{alert_overrides} = 0;
|
|
$anvil->data->{sys}{show}{systems} = 0;
|
|
$anvil->data->{sys}{say_old_security} = "";
|
|
$anvil->data->{sys}{say_old_auth} = "";
|
|
|
|
# If we're given 'test', make sure the level is provides.
|
|
if ($anvil->data->{switches}{test})
|
|
{
|
|
if (not $anvil->data->{switches}{level})
|
|
{
|
|
# Test requires a level
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0392"});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
|
|
# Is the level valid?
|
|
# * 1 or "critical"
|
|
# * 2 or "warning"
|
|
# * 3 or "notice"
|
|
# * 4 or "info"
|
|
if (($anvil->data->{switches}{level} ne "critical") &&
|
|
($anvil->data->{switches}{level} ne "1") &&
|
|
($anvil->data->{switches}{level} ne "warning") &&
|
|
($anvil->data->{switches}{level} ne "2") &&
|
|
($anvil->data->{switches}{level} ne "notice") &&
|
|
($anvil->data->{switches}{level} ne "3") &&
|
|
($anvil->data->{switches}{level} ne "info") &&
|
|
($anvil->data->{switches}{level} ne "4"))
|
|
{
|
|
# Invalid test alert level.
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0393", variables => {
|
|
level => $anvil->data->{switches}{level},
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
|
|
# Validate UUIDs.
|
|
foreach my $switch ("mail-server-uuid", "alert-override-uuid", "recipient-uuid", "alert-override-recipient-uuid", "alert-override-host-uuid")
|
|
{
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { switch => $switch }});
|
|
if (($anvil->data->{switches}{$switch}) && (not $anvil->Validate->uuid({uuid => $anvil->data->{switches}{$switch}})))
|
|
{
|
|
# Invalid UUID.
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0380", variables => {
|
|
uuid => $anvil->data->{switches}{$switch},
|
|
switch => $switch,
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
|
|
# If it's a Security or Authentication UUID, translate the strings.
|
|
if ((not $problem) && ($switch eq "mail-server-uuid") && ($anvil->data->{switches}{$switch}))
|
|
{
|
|
my $mail_server_uuid = $anvil->data->{switches}{$switch};
|
|
my $mail_server_security = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_security};
|
|
my $mail_server_authentication = $anvil->data->{mail_servers}{mail_server}{$mail_server_uuid}{mail_server_authentication};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
mail_server_uuid => $mail_server_uuid,
|
|
mail_server_security => $mail_server_security,
|
|
mail_server_authentication => $mail_server_authentication,
|
|
}});
|
|
|
|
if ($mail_server_security eq "none")
|
|
{
|
|
$anvil->data->{sys}{say_old_security} = "name_0007";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_security" => $anvil->data->{sys}{say_old_security},
|
|
}});
|
|
}
|
|
elsif ($mail_server_security eq "starttls")
|
|
{
|
|
$anvil->data->{sys}{say_old_security} = "name_0008";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_security" => $anvil->data->{sys}{say_old_security},
|
|
}});
|
|
}
|
|
elsif ($mail_server_security eq "ssl_tls")
|
|
{
|
|
$anvil->data->{sys}{say_old_security} = "name_0009";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_security" => $anvil->data->{sys}{say_old_security},
|
|
}});
|
|
}
|
|
|
|
if ($mail_server_authentication eq "normal_password")
|
|
{
|
|
# normal_password
|
|
$anvil->data->{sys}{say_old_auth} = "name_0001";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_auth" => $anvil->data->{sys}{say_old_auth},
|
|
}});
|
|
}
|
|
elsif ($mail_server_authentication eq "encrypted_password")
|
|
{
|
|
# encrypted_password
|
|
$anvil->data->{sys}{say_old_auth} = "name_0002";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_auth" => $anvil->data->{sys}{say_old_auth},
|
|
}});
|
|
}
|
|
elsif ($mail_server_authentication eq "kerberos_gssapi")
|
|
{
|
|
# kerberos_gssapi
|
|
$anvil->data->{sys}{say_old_auth} = "name_0003";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_auth" => $anvil->data->{sys}{say_old_auth},
|
|
}});
|
|
}
|
|
elsif ($mail_server_authentication eq "ntlm")
|
|
{
|
|
# ntlm, no need to translate
|
|
$anvil->data->{sys}{say_old_auth} = "name_0004";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_auth" => $anvil->data->{sys}{say_old_auth},
|
|
}});
|
|
}
|
|
elsif ($mail_server_authentication eq "tls_certificate")
|
|
{
|
|
# tls_certificate
|
|
$anvil->data->{sys}{say_old_auth} = "name_0005";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_auth" => $anvil->data->{sys}{say_old_auth},
|
|
}});
|
|
}
|
|
elsif ($mail_server_authentication eq "oauth2")
|
|
{
|
|
# oauth2, no need to translate
|
|
$anvil->data->{sys}{say_old_auth} = "name_0006";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_old_auth" => $anvil->data->{sys}{say_old_auth},
|
|
}});
|
|
}
|
|
}
|
|
}
|
|
|
|
# Validate domain or IP data.
|
|
foreach my $switch ("mail-server-address", "mail-server-helo-domain")
|
|
{
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { switch => $switch }});
|
|
if ($anvil->data->{switches}{$switch})
|
|
{
|
|
# Make sure it's a domain or IP address.
|
|
if ((not $anvil->Validate->domain_name({name => $anvil->data->{switches}{$switch}})) && (not $anvil->Validate->ip({ip => $anvil->data->{switches}{$switch}})))
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0381", variables => {
|
|
name => $anvil->data->{switches}{$switch},
|
|
switch => $switch,
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
}
|
|
|
|
# Check log levels.
|
|
foreach my $switch ("alert-override-alert-level", "recipient-level")
|
|
{
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { switch => $switch }});
|
|
if ($anvil->data->{switches}{$switch} ne "")
|
|
{
|
|
# If they used a level name, convert it to a number.
|
|
# 0 = "ignore"
|
|
# 1 = "critical" alerts only
|
|
# 2 = "warning" and critical alerts
|
|
# 3 = "notice", warning and critical alerts
|
|
# 4 = "info"; All alerts. This generates almost constant alerts!
|
|
if ($anvil->data->{switches}{$switch} eq "ignore")
|
|
{
|
|
$anvil->data->{switches}{$switch} = 0;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "switches::".$switch => $anvil->data->{switches}{$switch} }});
|
|
}
|
|
if ($anvil->data->{switches}{$switch} eq "critical")
|
|
{
|
|
$anvil->data->{switches}{$switch} = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "switches::".$switch => $anvil->data->{switches}{$switch} }});
|
|
}
|
|
elsif ($anvil->data->{switches}{$switch} eq "warning")
|
|
{
|
|
$anvil->data->{switches}{$switch} = 2;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "switches::".$switch => $anvil->data->{switches}{$switch} }});
|
|
}
|
|
elsif ($anvil->data->{switches}{$switch} eq "notice")
|
|
{
|
|
$anvil->data->{switches}{$switch} = 3;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "switches::".$switch => $anvil->data->{switches}{$switch} }});
|
|
}
|
|
elsif ($anvil->data->{switches}{$switch} eq "info")
|
|
{
|
|
$anvil->data->{switches}{$switch} = 4;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "switches::".$switch => $anvil->data->{switches}{$switch} }});
|
|
}
|
|
|
|
if (($anvil->data->{switches}{$switch} =~ /\D/) or
|
|
($anvil->data->{switches}{$switch} < 0) or
|
|
($anvil->data->{switches}{$switch} > 4))
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0382", variables => {
|
|
level => $anvil->data->{switches}{$switch},
|
|
switch => $switch,
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
}
|
|
|
|
# Ports (there's only one)
|
|
if ($anvil->data->{switches}{"mail-server-port"})
|
|
{
|
|
# Make sure it's a valid port.
|
|
if (($anvil->data->{switches}{"mail-server-port"} =~ /\D/) or
|
|
($anvil->data->{switches}{"mail-server-port"} < 1) or
|
|
($anvil->data->{switches}{"mail-server-port"} > 65535))
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0383", variables => {
|
|
port => $anvil->data->{switches}{"mail-server-port"},
|
|
switch => "--mail-server-port",
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
|
|
# Make sure mail server security is correct.
|
|
$anvil->data->{sys}{say_new_security} = "";
|
|
if ($anvil->data->{switches}{"mail-server-security"})
|
|
{
|
|
$anvil->data->{switches}{"mail-server-security"} = lc($anvil->data->{switches}{"mail-server-security"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"switches::mail-server-security" => $anvil->data->{switches}{"mail-server-security"},
|
|
}});
|
|
if ($anvil->data->{switches}{"mail-server-security"} eq "none")
|
|
{
|
|
$anvil->data->{sys}{say_new_security} = "name_0007";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_security" => $anvil->data->{sys}{say_new_security},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"mail-server-security"} eq "starttls")
|
|
{
|
|
$anvil->data->{sys}{say_new_security} = "name_0008";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_security" => $anvil->data->{sys}{say_new_security},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"mail-server-security"} eq "tls-ssl")
|
|
{
|
|
$anvil->data->{sys}{say_new_security} = "name_0009";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_security" => $anvil->data->{sys}{say_new_security},
|
|
}});
|
|
}
|
|
else
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0384", variables => {
|
|
security => $anvil->data->{switches}{"mail-server-security"},
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
|
|
# If set, make sure the "alert-override-recipient-uuid" and "alert-override-host-uuid" are valid.
|
|
if ($anvil->data->{switches}{"alert-override-recipient-uuid"})
|
|
{
|
|
my $recipient_uuid = $anvil->data->{switches}{"alert-override-recipient-uuid"};
|
|
if (not exists $anvil->data->{recipients}{recipient_uuid}{$recipient_uuid})
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0390", variables => {
|
|
uuid => $anvil->data->{switches}{"alert-override-recipient-uuid"},
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
if ($anvil->data->{switches}{"alert-override-host-uuid"})
|
|
{
|
|
my $host_uuid = $anvil->data->{switches}{"alert-override-host-uuid"};
|
|
if (not exists $anvil->data->{hosts}{host_uuid}{$host_uuid})
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0391", variables => {
|
|
uuid => $anvil->data->{switches}{"alert-override-host-uuid"},
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
|
|
$anvil->data->{sys}{say_new_auth} = "";
|
|
if ($anvil->data->{switches}{"mail-server-authentication"})
|
|
{
|
|
$anvil->data->{switches}{"mail-server-authentication"} = lc($anvil->data->{switches}{"mail-server-authentication"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"switches::mail-server-authentication" => $anvil->data->{switches}{"mail-server-authentication"},
|
|
}});
|
|
if ($anvil->data->{switches}{"mail-server-authentication"} eq "none")
|
|
{
|
|
# normal_password
|
|
$anvil->data->{sys}{say_new_auth} = "name_0001";
|
|
$anvil->data->{switches}{"mail-server-authentication"} = "normal_password";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_auth" => $anvil->data->{sys}{say_new_auth},
|
|
"switches::mail-server-authentication" => $anvil->data->{switches}{"mail-server-authentication"},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"mail-server-authentication"} eq "encrypted")
|
|
{
|
|
# encrypted_password
|
|
$anvil->data->{sys}{say_new_auth} = "name_0002";
|
|
$anvil->data->{switches}{"mail-server-authentication"} = "encrypted_password";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_auth" => $anvil->data->{sys}{say_new_auth},
|
|
"switches::mail-server-authentication" => $anvil->data->{switches}{"mail-server-authentication"},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"mail-server-authentication"} eq "kerberos")
|
|
{
|
|
# kerberos_gssapi
|
|
$anvil->data->{sys}{say_new_auth} = "name_0003";
|
|
$anvil->data->{switches}{"mail-server-authentication"} = "kerberos_gssapi";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_auth" => $anvil->data->{sys}{say_new_auth},
|
|
"switches::mail-server-authentication" => $anvil->data->{switches}{"mail-server-authentication"},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"mail-server-authentication"} eq "ntlm")
|
|
{
|
|
# ntlm, no need to translate
|
|
$anvil->data->{sys}{say_new_auth} = "name_0004";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_auth" => $anvil->data->{sys}{say_new_auth},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"mail-server-authentication"} eq "tls")
|
|
{
|
|
# tls_certificate
|
|
$anvil->data->{sys}{say_new_auth} = "name_0005";
|
|
$anvil->data->{switches}{"mail-server-authentication"} = "tls_certificate";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_auth" => $anvil->data->{sys}{say_new_auth},
|
|
"switches::mail-server-authentication" => $anvil->data->{switches}{"mail-server-authentication"},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"mail-server-authentication"} eq "oauth2")
|
|
{
|
|
# oauth2, no need to translate
|
|
$anvil->data->{sys}{say_new_auth} = "name_0006";
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
"sys::say_new_auth" => $anvil->data->{sys}{say_new_auth},
|
|
}});
|
|
}
|
|
else
|
|
{
|
|
# Not valid
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0385", variables => {
|
|
auth => $anvil->data->{switches}{"mail-server-authentication"},
|
|
}});
|
|
}
|
|
}
|
|
|
|
$anvil->data->{sys}{say_new_language} = "";
|
|
$anvil->data->{sys}{say_new_level} = "";
|
|
if ($anvil->data->{switches}{"recipient-email"})
|
|
{
|
|
if (not $anvil->Validate->email({email => $anvil->data->{switches}{"recipient-email"}}))
|
|
{
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0386", variables => {
|
|
email => $anvil->data->{switches}{"recipient-email"},
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
}
|
|
if (($anvil->data->{switches}{"recipient-level"} ne "") and ($anvil->data->{switches}{"recipient-level"} ne "#!SET!#"))
|
|
{
|
|
if (($anvil->data->{switches}{"recipient-level"} =~ /\D/) or ($anvil->data->{switches}{"recipient-level"} < 0) or ($anvil->data->{switches}{"recipient-level"} > 4))
|
|
{
|
|
# Invalid.
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, key => "error_0386", variables => {
|
|
email => $anvil->data->{switches}{"recipient-email"},
|
|
}});
|
|
|
|
$problem = 1;
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
|
}
|
|
|
|
# Get the translated log level name.
|
|
if ($anvil->data->{switches}{"recipient-level"} == 0)
|
|
{
|
|
# Ignore
|
|
$anvil->data->{sys}{say_new_level} = $anvil->Words->string({key => "unit_0023"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_level' => $anvil->data->{sys}{say_new_level},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"recipient-level"} == 1)
|
|
{
|
|
# Critical
|
|
$anvil->data->{sys}{say_new_level} = $anvil->Words->string({key => "unit_0024"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_level' => $anvil->data->{sys}{say_new_level},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"recipient-level"} == 2)
|
|
{
|
|
# Warning
|
|
$anvil->data->{sys}{say_new_level} = $anvil->Words->string({key => "unit_0025"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_level' => $anvil->data->{sys}{say_new_level},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"recipient-level"} == 3)
|
|
{
|
|
# Notice
|
|
$anvil->data->{sys}{say_new_level} = $anvil->Words->string({key => "unit_0026"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_level' => $anvil->data->{sys}{say_new_level},
|
|
}});
|
|
}
|
|
elsif ($anvil->data->{switches}{"recipient-level"} == 4)
|
|
{
|
|
# Info
|
|
$anvil->data->{sys}{say_new_level} = $anvil->Words->string({key => "unit_0027"});
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
'sys::say_new_level' => $anvil->data->{sys}{say_new_level},
|
|
}});
|
|
}
|
|
}
|
|
|
|
# Later, we'll need to parse the language file, for now, we always force 'en_CA'.
|
|
$anvil->data->{switches}{"recipient-language"} = "en_CA";
|
|
|
|
# Get the name of the language.
|
|
my $recipient_language = $anvil->data->{switches}{"recipient-language"};
|
|
$anvil->data->{sys}{say_new_language} = $anvil->data->{sys}{languages}{$recipient_language};
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
recipient_language => $recipient_language,
|
|
'sys::say_new_language' => $anvil->data->{sys}{say_new_language},
|
|
}});
|
|
|
|
# If there's a problem, exit now.
|
|
if ($problem)
|
|
{
|
|
$anvil->nice_exit({exit_code => 1});
|
|
}
|
|
|
|
return(0);
|
|
}
|