Server IP : 85.214.239.14 / Your IP : 18.118.144.239 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /proc/3/cwd/proc/3/cwd/proc/3/root/usr/share/postgresql-common/t/ |
Upload File : |
use strict; use warnings; use lib 't'; use TestLib; use PgCommon; use Test::More tests => $PgCommon::rpm ? 1 : 3 + 19 * @MAJORS; if ($PgCommon::rpm) { pass 'No ssl key checks on RedHat'; exit; } my ($pg_uid, $pg_gid) = (getpwnam 'postgres')[2,3]; my $ssl_cert_gid = (getgrnam 'ssl-cert')[2]; # reset permissions die "Could not determine ssl-cert gid" unless ($ssl_cert_gid); my $snakekey = '/etc/ssl/private/ssl-cert-snakeoil.key'; is ((stat $snakekey)[4], 0, "$snakekey is owned by root"); is ((stat $snakekey)[5], $ssl_cert_gid, "$snakekey group is ssl-cert"); is ((stat $snakekey)[2], 0100640, "$snakekey mode is 0640"); foreach my $version (@MAJORS) { my $pkgversion = `dpkg-query -f '\${Version}' -W postgresql-$version`; note "$version ($pkgversion)"; if ($version <= 9.1) { pass "no SSL support on $version" foreach (1..19); next; } SKIP: { skip "No SSL key check on <= 9.0", 19 if ($version <= 9.0); program_ok (0, "pg_createcluster $version main"); my $nobody_uid = (getpwnam 'nobody')[2]; chown $nobody_uid, 0, $snakekey; like_program_out 'postgres', "pg_ctlcluster $version main start", 1, qr/private key file.*must be owned by the database user or root/s, 'ssl key owned by nobody refused'; SKIP: { skip "SSL key group check skipped on Debian oldstable packages", 4 if ($version <= 9.4 and $pkgversion !~ /pgdg/); chown 0, 0, $snakekey; chmod 0644, $snakekey; like_program_out 'postgres', "pg_ctlcluster $version main start", 1, qr/private key file.*has group or world access/, 'ssl key with permissions root:root 0644 refused'; chown $pg_uid, $pg_gid, $snakekey; chmod 0640, $snakekey; like_program_out 'postgres', "pg_ctlcluster $version main start", 1, qr/private key file.*has group or world access/, 'ssl key with permissions postgres:postgres 0640 refused'; } chown 0, $ssl_cert_gid, $snakekey; program_ok (0, "pg_dropcluster $version main --stop"); is ((stat $snakekey)[4], 0, "$snakekey is owned by root"); is ((stat $snakekey)[5], $ssl_cert_gid, "$snakekey group is ssl-cert"); is ((stat $snakekey)[2], 0100640, "$snakekey mode is 0640"); check_clean; } }