2013-08-27 22:43:47 +02:00
# PRIVATE CLASS : do not use directly
class postgresql: : params inherits postgresql: : globals {
$ version = $ globals_version
2013-10-16 21:46:50 +02:00
$ postgis_version = $ globals_postgis_version
2013-08-27 22:43:47 +02:00
$ listen_addresses = 'localhost'
2014-04-17 21:09:07 +02:00
$ port = 5 4 3 2
2013-08-27 22:43:47 +02:00
$ ip_mask_deny_postgres_user = '0.0.0.0/0'
$ ip_mask_allow_all_users = '127.0.0.1/32'
$ ipv4acls = [ ]
$ ipv6acls = [ ]
2013-09-19 22:15:09 +02:00
$e ncoding = $e ncoding
2013-09-19 17:30:15 +02:00
$ locale = $ locale
2014-07-02 16:45:07 +02:00
$ service_ensure = 'running'
$ service_enable = true
2013-09-19 17:30:15 +02:00
$ service_provider = $ service_provider
$ manage_firewall = $ manage_firewall
2013-10-02 14:43:21 +02:00
$ manage_pg_hba_conf = pick( $ manage_pg_hba_conf, true )
2014-07-28 20:00:21 +02:00
# TODO : the behavior of manage_pg_ident_conf should default to true in the next major relase, is now to false for backward compatibility ( 2 0 1 4 0 7 2 8 )
$ manage_pg_ident_conf = pick( $ manage_pg_ident_conf, false )
2014-07-02 16:45:07 +02:00
$ package_ensure = 'present'
2012-12-04 05:42:20 +01:00
2012-11-25 15:28:13 +01:00
# Amazon Linux's OS Family is ' Linux', operating system ' Amazon' .
2012-06-08 22:37:21 +02:00
case $ : : osfamily {
2012-11-25 15:28:13 +01:00
'RedHat' , 'Linux' : {
2014-03-07 13:12:02 +01:00
$ user = pick( $ user, 'postgres' )
$ group = pick( $ group, 'postgres' )
2013-09-03 20:46:07 +02:00
$ needs_initdb = pick( $ needs_initdb, true )
$f irewall_supported = pick( $f irewall_supported, true )
2014-04-08 16:40:49 +02:00
$ version_parts = split( $ version, '[.]' )
$ package_version = "${version_parts[0]}${version_parts[1]}"
2013-08-27 22:43:47 +02:00
2013-09-03 20:46:07 +02:00
if $ version = = $defa ult_version {
$c lient_package_name = pick( $c lient_package_name, 'postgresql' )
$ server_package_name = pick( $ server_package_name, 'postgresql-server' )
$c ontrib_package_name = pick( $c ontrib_package_name, 'postgresql-contrib' )
$de vel_package_name = pick( $de vel_package_name, 'postgresql-devel' )
$ java_package_name = pick( $ java_package_name, 'postgresql-jdbc' )
$ plperl_package_name = pick( $ plperl_package_name, 'postgresql-plperl' )
$ service_name = pick( $ service_name, 'postgresql' )
$b indir = pick( $b indir, '/usr/bin' )
2013-10-02 21:38:20 +02:00
$da tadir = $ : : operatingsystem ? {
'Amazon' = > pick( $da tadir, '/var/lib/pgsql9/data' ) ,
default = > pick( $da tadir, '/var/lib/pgsql/data' ) ,
}
2013-09-03 20:46:07 +02:00
$c onfdir = pick( $c onfdir, $da tadir)
2012-12-04 05:42:20 +01:00
} else {
2013-09-03 20:46:07 +02:00
$c lient_package_name = pick( $c lient_package_name, "postgresql${package_version}" )
$ server_package_name = pick( $ server_package_name, "postgresql${package_version}-server" )
$c ontrib_package_name = pick( $c ontrib_package_name, "postgresql${package_version}-contrib" )
$de vel_package_name = pick( $de vel_package_name, "postgresql${package_version}-devel" )
$ java_package_name = pick( $ java_package_name, "postgresql${package_version}-jdbc" )
$ plperl_package_name = pick( $ plperl_package_name, "postgresql${package_version}-plperl" )
$ service_name = pick( $ service_name, "postgresql-${version}" )
$b indir = pick( $b indir, "/usr/pgsql-${version}/bin" )
2013-10-02 21:38:20 +02:00
$da tadir = $ : : operatingsystem ? {
'Amazon' = > pick( $da tadir, "/var/lib/pgsql9/${version}/data" ) ,
default = > pick( $da tadir, "/var/lib/pgsql/${version}/data" ) ,
}
2013-09-03 20:46:07 +02:00
$c onfdir = pick( $c onfdir, $da tadir)
2012-12-04 05:42:20 +01:00
}
2013-10-25 03:01:02 +02:00
$ psql_path = pick( $ psql_path, "${bindir}/psql" )
2012-12-04 05:42:20 +01:00
2013-08-27 22:43:47 +02:00
$ service_status = $ service_status
2014-04-02 23:52:07 +02:00
$ perl_package_name = pick( $ perl_package_name, 'perl-DBD-Pg' )
2013-08-27 22:43:47 +02:00
$ python_package_name = pick( $ python_package_name, 'python-psycopg2' )
2013-10-16 21:46:50 +02:00
$ postgis_package_name = pick(
$ postgis_package_name,
2014-05-13 20:24:28 +02:00
$ : : operatingsystemrelease ? {
/ 5 / = > 'postgis' ,
default = > versioncmp( $ postgis_version, '2' ) ? {
'-1' = > "postgis${package_version}" ,
default = > "postgis2_${package_version}" , }
2013-10-16 21:46:50 +02:00
}
)
2012-06-08 22:37:21 +02:00
}
2012-12-04 05:42:20 +01:00
2013-09-21 16:48:03 +02:00
'Archlinux' : {
# Based on the existing version of the firewall module, this is normally
# true for Archlinux, but archlinux users want more control.
# so they can set it themself
$f irewall_supported = pick( $f irewall_supported, true )
$ needs_initdb = pick( $ needs_initdb, true )
2014-03-07 13:12:02 +01:00
$ user = pick( $ user, 'postgres' )
$ group = pick( $ group, 'postgres' )
2013-09-21 16:48:03 +02:00
# Archlinux doesn' t have a client- package but has a libs package which
# pulls in postgresql server
$c lient_package_name = pick( $c lient_package_name, 'postgresql' )
$ server_package_name = pick( $ server_package_name, 'postgresql-libs' )
$ java_package_name = pick( $ java_package_name, 'postgresql-jdbc' )
# Archlinux doesn' t have develop packages
$de vel_package_name = pick( $de vel_package_name, 'postgresql-devel' )
# Archlinux does have postgresql- contrib but it isn' t maintained
$c ontrib_package_name = pick( $c ontrib_package_name, 'undef' )
# Archlinux postgresql package provides plperl
$ plperl_package_name = pick( $ plperl_package_name, 'undef' )
$ service_name = pick( $ service_name, 'postgresql' )
$b indir = pick( $b indir, '/usr/bin' )
$da tadir = pick( $da tadir, '/var/lib/postgres/data' )
$c onfdir = pick( $c onfdir, $da tadir)
2013-10-25 03:01:02 +02:00
$ psql_path = pick( $ psql_path, "${bindir}/psql" )
2013-09-21 16:48:03 +02:00
$ service_status = $ service_status
$ python_package_name = pick( $ python_package_name, 'python-psycopg2' )
2014-04-02 23:52:07 +02:00
# Archlinux does not have a perl: : DBD: : Pg package
$ perl_package_name = pick( $ perl_package_name, 'undef' )
2013-09-21 16:48:03 +02:00
}
2012-06-08 22:37:21 +02:00
'Debian' : {
2014-03-07 13:12:02 +01:00
$ user = pick( $ user, 'postgres' )
$ group = pick( $ group, 'postgres' )
2012-06-08 23:00:24 +02:00
2013-04-26 17:35:09 +02:00
if $ manage_package_repo = = true {
2013-08-27 22:43:47 +02:00
$ needs_initdb = pick( $ needs_initdb, true )
$ service_name = pick( $ service_name, 'postgresql' )
2013-04-26 17:35:09 +02:00
} else {
2013-08-27 22:43:47 +02:00
$ needs_initdb = pick( $ needs_initdb, false )
$ service_name = $ : : operatingsystem ? {
'Debian' = > pick( $ service_name, 'postgresql' ) ,
'Ubuntu' = > $ : : lsbmajdistrelease ? {
'10' = > pick( $ service_name, "postgresql-${version}" ) ,
default = > pick( $ service_name, 'postgresql' ) ,
} ,
default = > undef
2012-12-04 05:42:20 +01:00
}
}
2013-08-27 22:43:47 +02:00
$c lient_package_name = pick( $c lient_package_name, "postgresql-client-${version}" )
$ server_package_name = pick( $ server_package_name, "postgresql-${version}" )
$c ontrib_package_name = pick( $c ontrib_package_name, "postgresql-contrib-${version}" )
2013-10-16 21:46:50 +02:00
$ postgis_package_name = pick(
$ postgis_package_name,
versioncmp( $ postgis_version, '2' ) ? {
'-1' = > "postgresql-${version}-postgis" ,
default = > "postgresql-${version}-postgis-${postgis_version}" ,
}
)
2013-08-27 22:43:47 +02:00
$de vel_package_name = pick( $de vel_package_name, 'libpq-dev' )
$ java_package_name = pick( $ java_package_name, 'libpostgresql-jdbc-java' )
2014-04-02 23:52:07 +02:00
$ perl_package_name = pick( $ perl_package_name, 'libdbd-pg-perl' )
2013-08-27 22:43:47 +02:00
$ plperl_package_name = pick( $ plperl_package_name, "postgresql-plperl-${version}" )
$ python_package_name = pick( $ python_package_name, 'python-psycopg2' )
2013-06-06 20:39:00 +02:00
2013-08-27 22:43:47 +02:00
$b indir = pick( $b indir, "/usr/lib/postgresql/${version}/bin" )
$da tadir = pick( $da tadir, "/var/lib/postgresql/${version}/main" )
$c onfdir = pick( $c onfdir, "/etc/postgresql/${version}/main" )
$ service_status = pick( $ service_status, "/etc/init.d/${service_name} status | /bin/egrep -q 'Running clusters: .+|online'" )
2013-10-25 03:01:02 +02:00
$ psql_path = pick( $ psql_path, "/usr/bin/psql" )
2013-06-06 20:39:00 +02:00
2013-08-27 22:43:47 +02:00
$f irewall_supported = pick( $f irewall_supported, true )
}
2013-06-06 20:39:00 +02:00
2013-12-08 09:15:21 +01:00
'FreeBSD' : {
2014-03-07 13:12:02 +01:00
$ user = pick( $ user, 'pgsql' )
$ group = pick( $ group, 'pgsql' )
2013-12-08 09:15:21 +01:00
$c lient_package_name = pick( $c lient_package_name, "databases/postgresql${version}-client" )
$ server_package_name = pick( $ server_package_name, "databases/postgresql${version}-server" )
$c ontrib_package_name = pick( $c ontrib_package_name, "databases/postgresql${version}-contrib" )
$de vel_package_name = pick( $de vel_package_name, 'databases/postgresql-libpqxx3' )
$ java_package_name = pick( $ java_package_name, 'databases/postgresql-jdbc' )
2014-04-02 23:52:07 +02:00
$ perl_package_name = pick( $ plperl_package_name, 'databases/p5-DBD-Pg' )
2013-12-08 09:15:21 +01:00
$ plperl_package_name = pick( $ plperl_package_name, "databases/postgresql${version}-plperl" )
$ python_package_name = pick( $ python_package_name, 'databases/py-psycopg2' )
$ service_name = pick( $ service_name, 'postgresql' )
$b indir = pick( $b indir, '/usr/local/bin' )
$da tadir = pick( $da tadir, '/usr/local/pgsql/data' )
2014-03-07 15:39:21 +01:00
$c onfdir = pick( $c onfdir, $da tadir)
2013-12-08 09:15:21 +01:00
$ service_status = pick( $ service_status, "/usr/local/etc/rc.d/${service_name} status" )
$ psql_path = pick( $ psql_path, "${bindir}/psql" )
$f irewall_supported = pick( $f irewall_supported, false )
$ needs_initdb = pick( $ needs_initdb, true )
}
2013-08-27 22:43:47 +02:00
default : {
# Based on the existing version of the firewall module, this is normally
# false for other OS, but this allows an escape hatch to override it.
$f irewall_supported = pick( $f irewall_supported, false )
2013-10-25 03:01:02 +02:00
$ psql_path = pick( $ psql_path, "${bindir}/psql" )
2013-08-27 22:43:47 +02:00
# Since we can' t determine defaults on our own, we rely on users setting
# parameters with the postgresql: : globals class . Here we are checking
# that the mandatory minimum is set for the module to operate.
$e rr_prefix = "Module ${module_name} does not provide defaults for osfamily: ${::osfamily} operatingsystem: ${::operatingsystem}; please specify a value for ${module_name}::globals::"
if ( $ needs_initdb = = undef) { fail("${err_prefix} needs_initdb" ) }
if ( $ service_name = = undef) { fail("${err_prefix} service_name" ) }
if ( $c lient_package_name = = undef) { fail("${err_prefix} client_package_name" ) }
if ( $ server_package_name = = undef) { fail("${err_prefix} server_package_name" ) }
if ( $b indir = = undef) { fail("${err_prefix} bindir" ) }
if ( $da tadir = = undef) { fail("${err_prefix} datadir" ) }
if ( $c onfdir = = undef) { fail("${err_prefix} confdir" ) }
2012-06-08 22:37:21 +02:00
}
}
2012-12-04 05:42:20 +01:00
2013-08-27 22:43:47 +02:00
$ initdb_path = pick( $ initdb_path, "${bindir}/initdb" )
$c reatedb_path = pick( $c reatedb_path, "${bindir}/createdb" )
$ pg_hba_conf_path = pick( $ pg_hba_conf_path, "${confdir}/pg_hba.conf" )
$ pg_hba_conf_defaults = pick( $ pg_hba_conf_defaults, true )
2014-07-24 22:04:02 +02:00
$ pg_ident_conf_path = pick( $ pg_ident_conf_path, "${confdir}/pg_ident.conf" )
2013-08-27 22:43:47 +02:00
$ postgresql_conf_path = pick( $ postgresql_conf_path, "${confdir}/postgresql.conf" )
2013-10-27 02:50:05 +02:00
$defa ult_database = pick( $defa ult_database, 'postgres' )
2012-06-08 22:37:21 +02:00
}