2017-10-20 04:19:32 +00:00
|
|
|
|
#!/usr/bin/perl
|
|
|
|
|
#
|
|
|
|
|
# This checks the state of the postgresql database server and, if necessary, configures it for external
|
|
|
|
|
# access, initializes it and gets it running.
|
|
|
|
|
#
|
|
|
|
|
# Exit codes;
|
|
|
|
|
# 0 = Normal exit.
|
|
|
|
|
# 1 = Failed to initialize postgres
|
|
|
|
|
# 2 = Failed to start postgres
|
2018-03-24 13:57:10 +00:00
|
|
|
|
# 3 = ScanCore user not set in the local ID in anvil.conf
|
2017-10-20 04:19:32 +00:00
|
|
|
|
# 4 = Failed to create the database user.
|
2017-12-27 04:45:59 +00:00
|
|
|
|
# 5 = PostgreSQL not installed.
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
|
use warnings;
|
|
|
|
|
use Data::Dumper;
|
|
|
|
|
use Anvil::Tools;
|
|
|
|
|
|
|
|
|
|
my $THIS_FILE = ($0 =~ /^.*\/(.*)$/)[0];
|
|
|
|
|
my $running_directory = ($0 =~ /^(.*?)\/$THIS_FILE$/)[0];
|
|
|
|
|
if (($running_directory =~ /^\./) && ($ENV{PWD}))
|
|
|
|
|
{
|
|
|
|
|
$running_directory =~ s/^\./$ENV{PWD}/;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Turn off buffering so that the pinwheel will display while waiting for the SSH call(s) to complete.
|
|
|
|
|
$| = 1;
|
|
|
|
|
|
2019-01-18 08:19:36 +00:00
|
|
|
|
my $anvil = Anvil::Tools->new();
|
2021-02-08 18:39:34 +00:00
|
|
|
|
|
|
|
|
|
$anvil->Get->switches;
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, secure => 0, key => "log_0115", variables => { program => $THIS_FILE }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->System->_check_anvil_conf({debug => 2});
|
|
|
|
|
|
2018-05-01 16:26:41 +00:00
|
|
|
|
my $local_uuid = $anvil->Database->get_local_uuid();
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { local_uuid => $local_uuid }});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
|
|
|
|
|
# If we didn't get the $local_uuid, then there is no entry for this system in anvil.conf yet, so we'll add it.
|
|
|
|
|
if (not $local_uuid)
|
|
|
|
|
{
|
|
|
|
|
$local_uuid = add_to_local_config($anvil);
|
2019-09-24 01:00:35 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { local_uuid => $local_uuid }});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Now configure!
|
|
|
|
|
if ($local_uuid)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Start checks
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "sys::service::postgresql" => $anvil->data->{sys}{daemon}{postgresql} }});
|
2018-07-14 06:51:22 +00:00
|
|
|
|
|
2019-09-25 03:35:31 +00:00
|
|
|
|
my $running = $anvil->System->check_daemon({debug => 3, daemon => $anvil->data->{sys}{daemon}{postgresql}});
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { running => $running }});
|
2017-12-27 04:45:59 +00:00
|
|
|
|
if ($running eq "2")
|
|
|
|
|
{
|
|
|
|
|
# Not installed.
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "err", key => "log_0144"});
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 5});
|
2017-12-27 04:45:59 +00:00
|
|
|
|
}
|
|
|
|
|
elsif (not $running)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Do we need to initialize the databae?
|
2019-09-24 01:00:35 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "path::configs::pg_hba.conf" => $anvil->data->{path}{configs}{'pg_hba.conf'} }});
|
2018-07-14 06:51:22 +00:00
|
|
|
|
if (-e $anvil->data->{path}{configs}{'pg_hba.conf'})
|
|
|
|
|
{
|
|
|
|
|
# It already exists.
|
2019-09-24 01:00:35 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "path::configs::pg_hba.conf" => $anvil->data->{path}{configs}{'pg_hba.conf'} }});
|
2018-07-14 06:51:22 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Initialize.
|
2021-05-24 04:09:32 +00:00
|
|
|
|
my ($output, $return_code) = $anvil->System->call({debug => 2, shell_call => $anvil->data->{path}{exe}{'postgresql-setup'}." initdb", source => $THIS_FILE, line => __LINE__});
|
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
output => $output,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
|
|
|
|
# Did it succeed?
|
|
|
|
|
if (not -e $anvil->data->{path}{configs}{'pg_hba.conf'})
|
|
|
|
|
{
|
|
|
|
|
# Failed...
|
2017-12-27 04:45:59 +00:00
|
|
|
|
if ($output =~ /cannot create directory ‘(.*?)’: File exists/s)
|
|
|
|
|
{
|
|
|
|
|
my $file = $1;
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0139", variables => { file => $file }});
|
|
|
|
|
}
|
|
|
|
|
elsif ($output =~ /Initializing database ... failed, see (\/var\/.*?\.log)/s)
|
|
|
|
|
{
|
|
|
|
|
my $file = $1;
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0140", variables => { file => $file }});
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "err", key => "log_0050"});
|
|
|
|
|
}
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 1});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
# Initialized!
|
2017-12-24 05:49:57 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0055"});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Setup postgresql.conf
|
|
|
|
|
my $postgresql_backup = $anvil->data->{path}{directories}{backups}."/pgsql/postgresql.conf";
|
2019-09-24 01:00:35 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { postgresql_backup => $postgresql_backup }});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
$anvil->Storage->copy_file({
|
|
|
|
|
source_file => $anvil->data->{path}{configs}{'postgresql.conf'},
|
|
|
|
|
target_file => $postgresql_backup,
|
|
|
|
|
});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
|
|
|
|
my $postgresql_conf = $anvil->Storage->read_file({file => $anvil->data->{path}{configs}{'postgresql.conf'}});
|
|
|
|
|
my $update_file = 1;
|
|
|
|
|
my $new_postgresql_conf = "";
|
|
|
|
|
foreach my $line (split/\n/, $postgresql_conf)
|
|
|
|
|
{
|
2017-12-27 06:43:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
if ($line =~ /^listen_addresses = '\*'/)
|
|
|
|
|
{
|
|
|
|
|
# No need to update.
|
|
|
|
|
$update_file = 0;
|
|
|
|
|
last;
|
|
|
|
|
}
|
|
|
|
|
elsif ($line =~ /^#listen_addresses = 'localhost'/)
|
|
|
|
|
{
|
|
|
|
|
# Inject the new listen_addresses
|
|
|
|
|
$new_postgresql_conf .= "listen_addresses = '*'\n";
|
|
|
|
|
}
|
|
|
|
|
$new_postgresql_conf .= $line."\n";
|
|
|
|
|
}
|
2017-12-27 06:43:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { update_file => $update_file }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
if ($update_file)
|
|
|
|
|
{
|
|
|
|
|
$anvil->Storage->write_file({
|
2021-05-24 04:09:32 +00:00
|
|
|
|
debug => 3,
|
2017-10-20 04:19:32 +00:00
|
|
|
|
file => $anvil->data->{path}{configs}{'postgresql.conf'},
|
|
|
|
|
body => $new_postgresql_conf,
|
|
|
|
|
user => "postgres",
|
|
|
|
|
group => "postgres",
|
|
|
|
|
mode => "0600",
|
|
|
|
|
overwrite => 1,
|
|
|
|
|
});
|
2017-12-24 05:49:57 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0056", variables => { file => $anvil->data->{path}{configs}{'postgresql.conf'} }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Setup pg_hba.conf now
|
|
|
|
|
my $pg_hba_backup = $anvil->data->{path}{directories}{backups}."/pgsql/pg_hba.conf";
|
2017-12-27 06:43:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { pg_hba_backup => $pg_hba_backup }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
2018-04-30 15:43:30 +00:00
|
|
|
|
$anvil->Storage->copy_file({
|
|
|
|
|
source_file => $anvil->data->{path}{configs}{'pg_hba.conf'},
|
|
|
|
|
target_file => $pg_hba_backup,
|
|
|
|
|
});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
my $pg_hba_conf = $anvil->Storage->read_file({file => $anvil->data->{path}{configs}{'pg_hba.conf'}});
|
|
|
|
|
$update_file = 1;
|
|
|
|
|
my $new_pg_hba_conf = "";
|
|
|
|
|
foreach my $line (split/\n/, $pg_hba_conf)
|
|
|
|
|
{
|
2019-09-24 01:00:35 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
if ($line =~ /^host\s+all\s+all\s+\all\s+md5$/)
|
|
|
|
|
{
|
|
|
|
|
# No need to update.
|
|
|
|
|
$update_file = 0;
|
2019-09-24 01:00:35 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { update_file => $update_file }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
last;
|
|
|
|
|
}
|
|
|
|
|
elsif ($line =~ /^# TYPE\s+DATABASE/)
|
|
|
|
|
{
|
|
|
|
|
# Inject the new listen_addresses
|
|
|
|
|
$new_pg_hba_conf .= $line."\n";
|
2017-12-27 06:43:32 +00:00
|
|
|
|
$new_pg_hba_conf .= "host\tall\t\tall\t\tall\t\t\tmd5\n";
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$new_pg_hba_conf .= $line."\n";
|
|
|
|
|
}
|
|
|
|
|
}
|
2017-12-27 06:43:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { update_file => $update_file }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
if ($update_file)
|
|
|
|
|
{
|
|
|
|
|
$anvil->Storage->write_file({
|
2021-05-24 04:09:32 +00:00
|
|
|
|
debug => 3,
|
2017-10-20 04:19:32 +00:00
|
|
|
|
file => $anvil->data->{path}{configs}{'pg_hba.conf'},
|
|
|
|
|
body => $new_pg_hba_conf,
|
|
|
|
|
user => "postgres",
|
|
|
|
|
group => "postgres",
|
|
|
|
|
mode => "0600",
|
|
|
|
|
overwrite => 1,
|
|
|
|
|
});
|
2017-12-27 06:43:32 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0057", variables => { file => $anvil->data->{path}{configs}{'pg_hba.conf'} }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-12-27 04:45:59 +00:00
|
|
|
|
# Start the daemon. '0' = started, anything else is a problem.
|
2021-05-24 04:09:32 +00:00
|
|
|
|
my $return_code = $anvil->System->start_daemon({debug => 2, daemon => $anvil->data->{sys}{daemon}{postgresql}});
|
2017-12-27 04:45:59 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { return_code => $return_code }});
|
|
|
|
|
if ($return_code eq "0")
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Started the daemon.
|
2017-12-24 05:49:57 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0059"});
|
2017-12-27 17:01:58 +00:00
|
|
|
|
|
|
|
|
|
# Make sure it is enabled on boot.
|
2021-05-24 04:09:32 +00:00
|
|
|
|
my $return_code = $anvil->System->enable_daemon({debug => 2, daemon => $anvil->data->{sys}{daemon}{postgresql}});
|
2017-12-27 17:01:58 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { return_code => $return_code }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
# Failed to start
|
2017-12-27 04:45:59 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "err", key => "log_0094"});
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 2});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Create the .pgpass file, if needed.
|
|
|
|
|
my $created_pgpass = 0;
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, secure => 1, list => {
|
2018-05-21 07:11:47 +00:00
|
|
|
|
'path::secure::postgres_pgpass' => $anvil->data->{path}{secure}{postgres_pgpass},
|
2018-04-30 15:43:30 +00:00
|
|
|
|
"database::${local_uuid}::password" => $anvil->data->{database}{$local_uuid}{password},
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
if ((not -e $anvil->data->{path}{secure}{postgres_pgpass}) && ($anvil->data->{database}{$local_uuid}{password}))
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
2018-04-30 15:43:30 +00:00
|
|
|
|
my $body = "*:*:*:postgres:".$anvil->data->{database}{$local_uuid}{password}."\n";
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, secure => 1, list => { body => $body }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
$anvil->Storage->write_file({
|
2021-05-24 04:09:32 +00:00
|
|
|
|
debug => 3,
|
2017-10-20 04:19:32 +00:00
|
|
|
|
file => $anvil->data->{path}{secure}{postgres_pgpass},
|
|
|
|
|
body => $body,
|
|
|
|
|
user => "postgres",
|
|
|
|
|
group => "postgres",
|
|
|
|
|
mode => "0600",
|
|
|
|
|
overwrite => 1,
|
|
|
|
|
secure => 1,
|
|
|
|
|
});
|
|
|
|
|
if (-e $anvil->data->{path}{secure}{postgres_pgpass})
|
|
|
|
|
{
|
|
|
|
|
$created_pgpass = 1;
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { created_pgpass => $created_pgpass }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Does the database user exist?
|
|
|
|
|
my $create_user = 1;
|
2018-04-30 15:43:30 +00:00
|
|
|
|
my $database_user = $anvil->data->{database}{$local_uuid}{user} ? $anvil->data->{database}{$local_uuid}{user} : $anvil->data->{sys}{database}{user};
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { database_user => $database_user }});
|
2018-04-13 23:55:34 +00:00
|
|
|
|
if (not $database_user)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# No database user defined
|
2018-04-30 15:43:30 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "err", key => "log_0099", variables => { uuid => $local_uuid }});
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 3});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
2021-05-24 04:09:32 +00:00
|
|
|
|
my ($user_list, $return_code) = $anvil->System->call({debug => 2, shell_call => $anvil->data->{path}{exe}{su}." - postgres -c \"".$anvil->data->{path}{exe}{psql}." template1 -c 'SELECT usename, usesysid FROM pg_catalog.pg_user;'\"", source => $THIS_FILE, line => __LINE__});
|
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
user_list => $user_list,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
foreach my $line (split/\n/, $user_list)
|
|
|
|
|
{
|
2018-04-13 23:55:34 +00:00
|
|
|
|
if ($line =~ /^ $database_user\s+\|\s+(\d+)/)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# User exists already
|
|
|
|
|
my $id = $1;
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, key => "log_0060", variables => { user => $database_user, id => $id }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
$create_user = 0;
|
|
|
|
|
last;
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { create_user => $create_user }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
if ($create_user)
|
|
|
|
|
{
|
|
|
|
|
# Create the user
|
2021-05-24 04:09:32 +00:00
|
|
|
|
my ($create_output, $return_code) = $anvil->System->call({debug => 2, shell_call => $anvil->data->{path}{exe}{su}." - postgres -c \"".$anvil->data->{path}{exe}{createuser}." --no-superuser --createdb --no-createrole $database_user\"", source => $THIS_FILE, line => __LINE__});
|
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
create_output => $create_output,
|
|
|
|
|
user_list => $user_list,
|
|
|
|
|
}});
|
|
|
|
|
|
|
|
|
|
(my $user_list, $return_code) = $anvil->System->call({debug => 2, shell_call => $anvil->data->{path}{exe}{su}." - postgres -c \"".$anvil->data->{path}{exe}{psql}." template1 -c 'SELECT usename, usesysid FROM pg_catalog.pg_user;'\"", source => $THIS_FILE, line => __LINE__});
|
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
create_output => $create_output,
|
|
|
|
|
user_list => $user_list,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
my $user_exists = 0;
|
|
|
|
|
foreach my $line (split/\n/, $user_list)
|
|
|
|
|
{
|
2018-04-13 23:55:34 +00:00
|
|
|
|
if ($line =~ /^ $database_user\s+\|\s+(\d+)/)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Success!
|
|
|
|
|
my $id = $1;
|
2018-09-07 05:29:43 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0095", variables => { user => $database_user, id => $id }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
$user_exists = 1;
|
|
|
|
|
last;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (not $user_exists)
|
|
|
|
|
{
|
2018-04-13 23:55:34 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "err", key => "log_0096", variables => { user => $database_user }});
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 4});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Update/set the passwords.
|
2019-09-24 01:00:35 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, secure => 1, list => { "database::${local_uuid}::password" => $anvil->data->{database}{$local_uuid}{password} }});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
if ($anvil->data->{database}{$local_uuid}{password})
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
2018-04-13 23:55:34 +00:00
|
|
|
|
foreach my $user ("postgres", $database_user)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
2019-07-13 08:16:03 +00:00
|
|
|
|
my ($update_output, $return_code) = $anvil->System->call({secure => 1, shell_call => $anvil->data->{path}{exe}{su}." - postgres -c \"".$anvil->data->{path}{exe}{psql}." template1 -c \\\"ALTER ROLE $user WITH PASSWORD '".$anvil->data->{database}{$local_uuid}{password}."';\\\"\"", source => $THIS_FILE, line => __LINE__});
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, secure => 1, list => {
|
|
|
|
|
update_output => $update_output,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
foreach my $line (split/\n/, $user_list)
|
|
|
|
|
{
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
if ($line =~ /ALTER ROLE/)
|
|
|
|
|
{
|
|
|
|
|
# Password set
|
2018-09-07 05:29:43 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0100", variables => { user => $user }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Create the database, if needed.
|
2018-04-13 23:55:34 +00:00
|
|
|
|
my $create_database = 1;
|
2018-04-30 15:43:30 +00:00
|
|
|
|
my $database_name = $anvil->data->{database}{$local_uuid}{name} ? $anvil->data->{database}{$local_uuid}{name} : $anvil->data->{sys}{database}{name};
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { database_name => $database_name }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
2019-09-24 01:00:35 +00:00
|
|
|
|
undef $return_code;
|
|
|
|
|
(my $database_list, $return_code) = $anvil->System->call({shell_call => $anvil->data->{path}{exe}{su}." - postgres -c \"".$anvil->data->{path}{exe}{psql}." template1 -c 'SELECT datname FROM pg_catalog.pg_database;'\"", source => $THIS_FILE, line => __LINE__});
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
database_list => $database_list,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
foreach my $line (split/\n/, $database_list)
|
|
|
|
|
{
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
2018-04-13 23:55:34 +00:00
|
|
|
|
if ($line =~ /^ $database_name$/)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Database already exists.
|
2019-09-25 03:35:31 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 3, key => "log_0105", variables => { database => $database_name }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
$create_database = 0;
|
|
|
|
|
last;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-09-25 03:35:31 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { create_database => $create_database }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
if ($create_database)
|
|
|
|
|
{
|
2019-07-13 08:16:03 +00:00
|
|
|
|
my ($create_output, $return_code) = $anvil->System->call({shell_call => $anvil->data->{path}{exe}{su}." - postgres -c \"".$anvil->data->{path}{exe}{createdb}." --owner ".$database_user." ".$database_name."\"", source => $THIS_FILE, line => __LINE__});
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
create_output => $create_output,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
2019-09-24 01:00:35 +00:00
|
|
|
|
undef $return_code;
|
2019-07-13 08:16:03 +00:00
|
|
|
|
my $database_exists = 0;
|
2019-09-24 01:00:35 +00:00
|
|
|
|
(my $database_list, $return_code) = $anvil->System->call({shell_call => $anvil->data->{path}{exe}{su}." - postgres -c \"".$anvil->data->{path}{exe}{psql}." template1 -c 'SELECT datname FROM pg_catalog.pg_database;'\"", source => $THIS_FILE, line => __LINE__});
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
database_list => $database_list,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
foreach my $line (split/\n/, $database_list)
|
|
|
|
|
{
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
2018-04-13 23:55:34 +00:00
|
|
|
|
if ($line =~ /^ $database_name$/)
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Database created
|
2018-09-07 05:29:43 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "log_0110", variables => { database => $database_name }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
$database_exists = 1;
|
|
|
|
|
last;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (not $database_exists)
|
|
|
|
|
{
|
2018-04-13 23:55:34 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "err", key => "log_0109", variables => { database => $database_name }});
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 5});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Remove the temporary password file.
|
|
|
|
|
if (($created_pgpass) && (-e $anvil->data->{path}{secure}{postgres_pgpass}))
|
|
|
|
|
{
|
|
|
|
|
unlink $anvil->data->{path}{secure}{postgres_pgpass};
|
|
|
|
|
if (-e $anvil->data->{path}{secure}{postgres_pgpass})
|
|
|
|
|
{
|
|
|
|
|
# Failed to unlink the file.
|
2017-12-27 04:45:59 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "alert", key => "log_0107"});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#####################################################################################################
|
|
|
|
|
# NOTE: Below here is stuff that is for general setup. If it grows, we'll have to rename this tool. #
|
|
|
|
|
#####################################################################################################
|
|
|
|
|
|
|
|
|
|
### TODO: This will need to set the proper SELinux context.
|
|
|
|
|
# Apache run scripts can't call the system UUID, so we'll write it to a text file.
|
|
|
|
|
if (not -e $anvil->data->{path}{data}{host_uuid})
|
|
|
|
|
{
|
|
|
|
|
$anvil->Storage->write_file({
|
2021-05-24 04:09:32 +00:00
|
|
|
|
debug => 3,
|
2017-10-20 04:19:32 +00:00
|
|
|
|
file => $anvil->data->{path}{data}{host_uuid},
|
|
|
|
|
body => $anvil->Get->host_uuid,
|
|
|
|
|
user => "apache",
|
|
|
|
|
group => "apache",
|
|
|
|
|
mode => "0666",
|
|
|
|
|
overwrite => 0,
|
|
|
|
|
});
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "message_0011", variables => { file => $anvil->data->{path}{configs}{'postgresql.conf'} }});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Log level 3 creates so much logging that it hits journald's rate limiting (1000 logs per 30
|
|
|
|
|
# seconds). So we need to disable it.
|
2017-12-26 18:12:59 +00:00
|
|
|
|
if (not -e $anvil->data->{path}{configs}{'journald_anvil'})
|
2017-10-20 04:19:32 +00:00
|
|
|
|
{
|
|
|
|
|
# Write the file to disable journald rate limiting.
|
|
|
|
|
my $body = "# This disables the rate limiting so that when log level is set to 3, log
|
|
|
|
|
# entries aren't lost. If you want to override this, don't delete the file,
|
|
|
|
|
# just comment out the lines below.
|
|
|
|
|
|
|
|
|
|
[Journal]
|
|
|
|
|
RateLimitInterval=0
|
|
|
|
|
RateLimitBurst=0
|
|
|
|
|
";
|
|
|
|
|
$anvil->Storage->write_file({
|
2021-05-24 04:09:32 +00:00
|
|
|
|
debug => 3,
|
2017-12-26 18:12:59 +00:00
|
|
|
|
file => $anvil->data->{path}{configs}{'journald_anvil'},
|
2017-10-20 04:19:32 +00:00
|
|
|
|
body => $body,
|
|
|
|
|
user => "root",
|
|
|
|
|
group => "root",
|
|
|
|
|
mode => "0644",
|
|
|
|
|
overwrite => 0,
|
|
|
|
|
});
|
2017-12-26 18:12:59 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 1, key => "message_0012", variables => { file => $anvil->data->{path}{configs}{'journald_anvil'} }});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
2019-09-25 03:35:31 +00:00
|
|
|
|
my ($output, $return_code) = $anvil->System->call({debug => 3, shell_call => $anvil->data->{path}{exe}{systemctl}." restart systemd-journald.service", source => $THIS_FILE, line => __LINE__});
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
output => $output,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2017-12-27 04:45:59 +00:00
|
|
|
|
# Didn't find an entry for this machine. This is normal on nodes.
|
2018-07-13 22:29:28 +00:00
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, key => "log_0143"});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 0});
|
2017-10-20 04:19:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#############################################################################################################
|
|
|
|
|
# Functions #
|
|
|
|
|
#############################################################################################################
|
2018-04-30 15:43:30 +00:00
|
|
|
|
|
|
|
|
|
# This adds this machine to the local anvil.conf file.
|
|
|
|
|
sub add_to_local_config
|
|
|
|
|
{
|
|
|
|
|
my ($anvil) = @_;
|
|
|
|
|
|
2018-08-08 19:10:29 +00:00
|
|
|
|
# Write the password to a file.
|
2019-02-06 07:36:19 +00:00
|
|
|
|
my $password_file = "/tmp/striker-manage-peers.".$anvil->Get->uuid;
|
2018-08-08 19:10:29 +00:00
|
|
|
|
$anvil->Storage->write_file({
|
2021-05-24 04:09:32 +00:00
|
|
|
|
debug => 3,
|
2018-08-08 19:10:29 +00:00
|
|
|
|
secure => 1,
|
|
|
|
|
file => $password_file,
|
|
|
|
|
body => "Initial1",
|
|
|
|
|
mode => "0600",
|
|
|
|
|
overwrite => 1,
|
|
|
|
|
});
|
|
|
|
|
|
2018-08-13 06:22:46 +00:00
|
|
|
|
# Make the shell call, and parse the output looking for our own entry
|
2019-07-13 08:16:03 +00:00
|
|
|
|
my $host_uuid = $anvil->Get->host_uuid();
|
|
|
|
|
my ($output, $return_code) = $anvil->System->call({
|
2021-05-24 04:09:32 +00:00
|
|
|
|
debug => 2,
|
|
|
|
|
shell_call => $anvil->data->{path}{exe}{'striker-manage-peers'}." --add --host-uuid ".$anvil->Get->host_uuid." --host localhost --port 5432 --password-file ".$password_file." --ping 0".$anvil->Log->switches,
|
2018-08-13 06:22:46 +00:00
|
|
|
|
source => $THIS_FILE,
|
|
|
|
|
line => __LINE__,
|
|
|
|
|
});
|
2021-05-24 04:09:32 +00:00
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
|
output => $output,
|
|
|
|
|
return_code => $return_code,
|
|
|
|
|
}});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
|
2018-08-13 06:22:46 +00:00
|
|
|
|
# Remove the password.
|
|
|
|
|
unlink $password_file;
|
|
|
|
|
|
|
|
|
|
# Re-read the config and make sure we have our own entry.
|
|
|
|
|
$anvil->Storage->read_config({file => $anvil->data->{path}{configs}{'anvil.conf'}});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
|
2018-08-13 06:22:46 +00:00
|
|
|
|
# If we still don't have a local_uuid, something went wrong.
|
|
|
|
|
if (not $anvil->data->{database}{$host_uuid}{host})
|
2018-04-30 15:43:30 +00:00
|
|
|
|
{
|
2018-08-13 06:22:46 +00:00
|
|
|
|
print $anvil->Words->string({key => "error_0010"})."\n";
|
2020-06-24 04:39:56 +00:00
|
|
|
|
$anvil->nice_exit({exit_code => 1});
|
2018-04-30 15:43:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2018-08-13 06:22:46 +00:00
|
|
|
|
return($host_uuid);
|
2018-04-30 15:43:30 +00:00
|
|
|
|
}
|
|
|
|
|
|