module-postgresql/manifests/server.pp
2013-02-15 17:19:31 +00:00

69 lines
2 KiB
Puppet

# Class: postgresql::server
#
# == Class: postgresql::server
# Manages the installation of the postgresql server. manages the package and
# service.
#
# === Parameters:
# [*package_name*] - name of package
# [*service_name*] - name of service
#
# Configuration:
# Advanced configuration setting parameters can be placed into 'postgresql_puppet_extras.conf' (located in the same
# folder as 'postgresql.conf'). You can manage that file as a normal puppet file resource, or however you see fit;
# which gives you complete control over the settings. Any value you specify in that file will override any existing
# value set in the templated version.
#
# Actions:
#
# Requires:
#
# Sample Usage:
#
class postgresql::server (
$package_name = $postgresql::params::server_package_name,
$package_ensure = 'present',
$service_name = $postgresql::params::service_name,
$service_provider = $postgresql::params::service_provider,
$service_status = $postgresql::params::service_status,
$config_hash = {}
) inherits postgresql::params {
package { 'postgresql-server':
ensure => $package_ensure,
name => $package_name,
tag => 'postgresql',
}
$config_class = {
'postgresql::config' => $config_hash,
}
create_resources( 'class', $config_class )
service { 'postgresqld':
ensure => running,
name => $service_name,
enable => true,
require => Package['postgresql-server'],
provider => $service_provider,
status => $service_status,
}
if ($postgresql::params::needs_initdb) {
include postgresql::initdb
Package['postgresql-server'] -> Class['postgresql::initdb'] -> Class['postgresql::config'] -> Service['postgresqld']
}
else {
Package['postgresql-server'] -> Class['postgresql::config'] -> Service['postgresqld']
}
exec { 'reload_postgresql':
path => '/usr/bin:/usr/sbin:/bin:/sbin',
command => "service ${service_name} reload",
onlyif => $service_status,
refreshonly => true,
}
}