1 # bacula class -- defines all the variables we care about in our bacula deployment
3 # @param ssl_ca_path full path and filename specifying a PEM encoded TLS CA certificate(s)
4 # @param ssl_client_cert path to TLS client certificate
5 # @param ssl_client_key path to TLS client certificate key
6 # @param ssl_server_cert path to TLS server certificate
7 # @param ssl_server_key path to TLS server certificate key
8 # @param operator_email email address for reports
9 # @param public_addresses this host's public IP addresses. The ones it connects out from and is reachable from outsite.
10 # @param has_ipv4 daemons should listen on ipv4
11 # @param has_ipv6 daemons should listen on ipv6
14 String $ssl_client_cert,
15 String $ssl_client_key,
16 String $ssl_server_cert,
17 String $ssl_server_key,
19 String $operator_email = 'root@localhost',
20 Array[Stdlib::IP::Address] $public_addresses = $base::public_addresses,
21 Boolean $has_ipv4 = $bacula::public_addresses.any |$addr| { $addr =~ Stdlib::IP::Address::V4 },
22 Boolean $has_ipv6 = $bacula::public_addresses.any |$addr| { $addr =~ Stdlib::IP::Address::V6 },
24 # This file is used by our helper scripts on the director
25 $bacula_dsa_client_list = '/etc/bacula/dsa-clients'
26 $tag_bacula_dsa_client_list = 'bacula::dsa::clientlist'
28 $bacula_tls_ca_certificate_file = "TLS CA Certificate File = \"${ssl_ca_path}\""
29 $bacula_tls_client_certificate = "TLS Certificate = \"${ssl_client_cert}\""
30 $bacula_tls_client_key = "TLS Key = \"${ssl_client_key}\""
31 $bacula_tls_server_certificate = "TLS Certificate = \"${ssl_server_cert}\""
32 $bacula_tls_server_key = "TLS Key = \"${ssl_server_key}\""
34 file { '/usr/local/sbin/bacula-idle-restart':
36 source => 'puppet:///modules/bacula/bacula-idle-restart',