4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
# File 'manifests/database/ssl_configuration.pp', line 4
class puppetdb::database::ssl_configuration (
$database_name = $puppetdb::params::database_name,
$database_username = $puppetdb::params::database_username,
$read_database_username = $puppetdb::params::read_database_username,
$read_database_host = $puppetdb::params::read_database_host,
$puppetdb_server = $puppetdb::params::puppetdb_server,
$postgresql_ssl_key_path = $puppetdb::params::postgresql_ssl_key_path,
$postgresql_ssl_cert_path = $puppetdb::params::postgresql_ssl_cert_path,
$postgresql_ssl_ca_cert_path = $puppetdb::params::postgresql_ssl_ca_cert_path,
$postgres_version = $puppetdb::params::postgres_version,
$create_read_user_rule = false,
) inherits puppetdb::params {
File {
ensure => present,
owner => 'postgres',
mode => '0600',
require => Package['postgresql-server'],
}
file { 'postgres private key':
path => "${postgresql::server::datadir}/server.key",
source => $postgresql_ssl_key_path,
}
file { 'postgres public key':
path => "${postgresql::server::datadir}/server.crt",
source => $postgresql_ssl_cert_path,
}
postgresql::server::config_entry { 'ssl':
ensure => present,
value => 'on',
require => [File['postgres private key'], File['postgres public key']],
}
postgresql::server::config_entry { 'ssl_cert_file':
ensure => present,
value => "${postgresql::server::datadir}/server.crt",
require => [File['postgres private key'], File['postgres public key']],
}
postgresql::server::config_entry { 'ssl_key_file':
ensure => present,
value => "${postgresql::server::datadir}/server.key",
require => [File['postgres private key'], File['postgres public key']],
}
postgresql::server::config_entry { 'ssl_ca_file':
ensure => present,
value => $postgresql_ssl_ca_cert_path,
require => [File['postgres private key'], File['postgres public key']],
}
puppetdb::database::postgresql_ssl_rules { "Configure postgresql ssl rules for ${database_username}":
database_name => $database_name,
database_username => $database_username,
postgres_version => $postgres_version,
puppetdb_server => $puppetdb_server,
}
if $create_read_user_rule {
puppetdb::database::postgresql_ssl_rules { "Configure postgresql ssl rules for ${read_database_username}":
database_name => $database_name,
database_username => $read_database_username,
postgres_version => $postgres_version,
puppetdb_server => $puppetdb_server,
}
}
}
|