module-puppetdb/manifests/server/database.pp

178 lines
5.3 KiB
ObjectPascal
Raw Permalink Normal View History

# PRIVATE CLASS - do not use directly
class puppetdb::server::database (
$database = $puppetdb::params::database,
$database_host = $puppetdb::params::database_host,
$database_port = $puppetdb::params::database_port,
$database_username = $puppetdb::params::database_username,
$database_password = $puppetdb::params::database_password,
$database_name = $puppetdb::params::database_name,
$database_ssl = $puppetdb::params::database_ssl,
$jdbc_ssl_properties = $puppetdb::params::jdbc_ssl_properties,
$database_validate = $puppetdb::params::database_validate,
$database_embedded_path = $puppetdb::params::database_embedded_path,
$node_ttl = $puppetdb::params::node_ttl,
$node_purge_ttl = $puppetdb::params::node_purge_ttl,
$report_ttl = $puppetdb::params::report_ttl,
$gc_interval = $puppetdb::params::gc_interval,
$log_slow_statements = $puppetdb::params::log_slow_statements,
$conn_max_age = $puppetdb::params::conn_max_age,
$conn_keep_alive = $puppetdb::params::conn_keep_alive,
$conn_lifetime = $puppetdb::params::conn_lifetime,
$confdir = $puppetdb::params::confdir,
$puppetdb_user = $puppetdb::params::puppetdb_user,
$puppetdb_group = $puppetdb::params::puppetdb_group,
$database_max_pool_size = $puppetdb::params::database_max_pool_size,
) inherits puppetdb::params {
2014-12-16 10:08:35 +01:00
if str2bool($database_validate) {
# Validate the database connection. If we can't connect, we want to fail
# and skip the rest of the configuration, so that we don't leave puppetdb
# in a broken state.
#
# NOTE:
# Because of a limitation in the postgres module this will break with
# a duplicate declaration if read and write database host+name are the
# same.
class { 'puppetdb::server::validate_db':
database => $database,
database_host => $database_host,
database_port => $database_port,
database_username => $database_username,
database_password => $database_password,
database_name => $database_name,
}
}
$database_ini = "${confdir}/database.ini"
file { $database_ini:
ensure => file,
owner => $puppetdb_user,
group => $puppetdb_group,
mode => '0600',
}
$file_require = File[$database_ini]
2014-12-16 10:08:35 +01:00
$ini_setting_require = str2bool($database_validate) ? {
false => $file_require,
default => [$file_require, Class['puppetdb::server::validate_db']],
2014-12-16 10:08:35 +01:00
}
# Set the defaults
Ini_setting {
path => $database_ini,
2012-09-20 23:46:26 +02:00
ensure => present,
section => 'database',
2014-12-16 10:08:35 +01:00
require => $ini_setting_require
}
2012-09-20 23:46:26 +02:00
if $database == 'embedded' {
2012-09-20 23:46:26 +02:00
$classname = 'org.hsqldb.jdbcDriver'
$subprotocol = 'hsqldb'
$subname = "file:${database_embedded_path};hsqldb.tx=mvcc;sql.syntax_pgs=true"
2012-09-20 23:46:26 +02:00
} elsif $database == 'postgres' {
$classname = 'org.postgresql.Driver'
$subprotocol = 'postgresql'
if !empty($jdbc_ssl_properties) {
$database_suffix = $jdbc_ssl_properties
}
elsif $database_ssl {
$database_suffix = '?ssl=true'
}
else {
$database_suffix = ''
}
$subname = "//${database_host}:${database_port}/${database_name}${database_suffix}"
2012-09-20 23:46:26 +02:00
##Only setup for postgres
ini_setting {'puppetdb_psdatabase_username':
setting => 'username',
value => $database_username,
}
if $database_password != undef {
ini_setting {'puppetdb_psdatabase_password':
setting => 'password',
value => $database_password,
}
2012-09-20 23:46:26 +02:00
}
}
ini_setting { 'puppetdb_classname':
2012-09-20 23:46:26 +02:00
setting => 'classname',
value => $classname,
}
2012-09-20 23:46:26 +02:00
ini_setting { 'puppetdb_subprotocol':
2012-09-20 23:46:26 +02:00
setting => 'subprotocol',
value => $subprotocol,
}
2012-09-20 23:46:26 +02:00
ini_setting { 'puppetdb_pgs':
2012-09-20 23:46:26 +02:00
setting => 'syntax_pgs',
value => true,
}
2012-09-20 23:46:26 +02:00
ini_setting { 'puppetdb_subname':
2012-09-20 23:46:26 +02:00
setting => 'subname',
value => $subname,
}
2012-09-20 23:46:26 +02:00
ini_setting { 'puppetdb_gc_interval':
2012-09-20 23:46:26 +02:00
setting => 'gc-interval',
value => $gc_interval,
}
ini_setting { 'puppetdb_node_ttl':
setting => 'node-ttl',
value => $node_ttl,
}
ini_setting { 'puppetdb_node_purge_ttl':
setting => 'node-purge-ttl',
value => $node_purge_ttl,
}
ini_setting { 'puppetdb_report_ttl':
setting => 'report-ttl',
value => $report_ttl,
}
ini_setting { 'puppetdb_log_slow_statements':
setting => 'log-slow-statements',
value => $log_slow_statements,
}
ini_setting { 'puppetdb_conn_max_age':
setting => 'conn-max-age',
value => $conn_max_age,
}
ini_setting { 'puppetdb_conn_keep_alive':
setting => 'conn-keep-alive',
value => $conn_keep_alive,
}
ini_setting { 'puppetdb_conn_lifetime':
setting => 'conn-lifetime',
value => $conn_lifetime,
}
if $puppetdb::params::database_max_pool_size_setting_name != undef {
if $database_max_pool_size == 'absent' {
ini_setting { 'puppetdb_database_max_pool_size':
ensure => absent,
setting => $puppetdb::params::database_max_pool_size_setting_name,
}
} elsif $database_max_pool_size != undef {
ini_setting { 'puppetdb_database_max_pool_size':
setting => $puppetdb::params::database_max_pool_size_setting_name,
value => $database_max_pool_size,
}
}
}
}