diff options
| -rw-r--r-- | puppet/modules/site_couchdb/manifests/bigcouch/stunnel.pp | 89 | ||||
| -rw-r--r-- | puppet/modules/site_couchdb/manifests/stunnel.pp | 81 | 
2 files changed, 95 insertions, 75 deletions
diff --git a/puppet/modules/site_couchdb/manifests/bigcouch/stunnel.pp b/puppet/modules/site_couchdb/manifests/bigcouch/stunnel.pp new file mode 100644 index 00000000..5166ba93 --- /dev/null +++ b/puppet/modules/site_couchdb/manifests/bigcouch/stunnel.pp @@ -0,0 +1,89 @@ +class site_couchdb::bigcouch::stunnel { + +  $stunnel              = hiera('stunnel') + +  include site_config::x509::cert +  include site_config::x509::key +  include site_config::x509::ca + +  include x509::variables +  $ca_path   = "${x509::variables::local_CAs}/${site_config::params::ca_name}.crt" +  $cert_path = "${x509::variables::certs}/${site_config::params::cert_name}.crt" +  $key_path  = "${x509::variables::keys}/${site_config::params::cert_name}.key" + + +  # Erlang Port Mapper Daemon (epmd) stunnel server/clients +  $epmd_server          = $stunnel['epmd_server'] +  $epmd_server_accept   = $epmd_server['accept'] +  $epmd_server_connect  = $epmd_server['connect'] +  $epmd_clients         = $stunnel['epmd_clients'] + +  # Erlang Distributed Node Protocol (ednp) stunnel server/clients +  $ednp_server          = $stunnel['ednp_server'] +  $ednp_server_accept   = $ednp_server['accept'] +  $ednp_server_connect  = $ednp_server['connect'] +  $ednp_clients         = $stunnel['ednp_clients'] + + +  # setup stunnel server for Erlang Port Mapper Daemon (epmd), necessary for +  # bigcouch clustering between each bigcouchdb node +  stunnel::service { 'epmd_server': +    accept     => $epmd_server_accept, +    connect    => $epmd_server_connect, +    client     => false, +    cafile     => $ca_path, +    key        => $key_path, +    cert       => $cert_path, +    verify     => '2', +    pid        => '/var/run/stunnel4/epmd_server.pid', +    rndfile    => '/var/lib/stunnel4/.rnd', +    debuglevel => '4', +    require    => [ +      Class['Site_config::X509::Key'], +      Class['Site_config::X509::Cert'], +      Class['Site_config::X509::Ca'] ]; +  } + +  # setup stunnel clients for Erlang Port Mapper Daemon (epmd) to connect +  # to the above epmd stunnel server. +  $epmd_client_defaults = { +    'client'       => true, +    'cafile'       => $ca_path, +    'key'          => $key_path, +    'cert'         => $cert_path, +  } + +  create_resources(site_stunnel::clients, $epmd_clients, $epmd_client_defaults) + +  # setup stunnel server for Erlang Distributed Node Protocol (ednp), necessary +  # for bigcouch clustering between each bigcouchdb node +  stunnel::service { 'ednp_server': +    accept     => $ednp_server_accept, +    connect    => $ednp_server_connect, +    client     => false, +    cafile     => $ca_path, +    key        => $key_path, +    cert       => $cert_path, +    verify     => '2', +    pid        => '/var/run/stunnel4/ednp_server.pid', +    rndfile    => '/var/lib/stunnel4/.rnd', +    debuglevel => '4', +    require    => [ +      Class['Site_config::X509::Key'], +      Class['Site_config::X509::Cert'], +      Class['Site_config::X509::Ca'] ]; +  } + +  # setup stunnel clients for Erlang Distributed Node Protocol (ednp) to connect +  # to the above ednp stunnel server. +  $ednp_client_defaults = { +    'client'       => true, +    'cafile'       => $ca_path, +    'key'          => $key_path, +    'cert'         => $cert_path, +  } + +  create_resources(site_stunnel::clients, $ednp_clients, $ednp_client_defaults) + +  include site_check_mk::agent::stunnel +} diff --git a/puppet/modules/site_couchdb/manifests/stunnel.pp b/puppet/modules/site_couchdb/manifests/stunnel.pp index 91f1e3aa..484a0c00 100644 --- a/puppet/modules/site_couchdb/manifests/stunnel.pp +++ b/puppet/modules/site_couchdb/manifests/stunnel.pp @@ -1,29 +1,21 @@  class site_couchdb::stunnel {    $stunnel              = hiera('stunnel') +  $couchdb_config       = hiera('couch') +  $couchdb_bigcouch     = $couchdb_config['mode'] == "multimaster"    $couch_server         = $stunnel['couch_server']    $couch_server_accept  = $couch_server['accept']    $couch_server_connect = $couch_server['connect'] -  # Erlang Port Mapper Daemon (epmd) stunnel server/clients -  $epmd_server          = $stunnel['epmd_server'] -  $epmd_server_accept   = $epmd_server['accept'] -  $epmd_server_connect  = $epmd_server['connect'] -  $epmd_clients         = $stunnel['epmd_clients'] - -  # Erlang Distributed Node Protocol (ednp) stunnel server/clients -  $ednp_server          = $stunnel['ednp_server'] -  $ednp_server_accept   = $ednp_server['accept'] -  $ednp_server_connect  = $ednp_server['connect'] -  $ednp_clients         = $stunnel['ednp_clients'] - - -    include site_config::x509::cert    include site_config::x509::key    include site_config::x509::ca +  if $couchdb_bigcouch { +    include site_couchdb::bigcouch::stunnel +  } +    include x509::variables    $ca_path   = "${x509::variables::local_CAs}/${site_config::params::ca_name}.crt"    $cert_path = "${x509::variables::certs}/${site_config::params::cert_name}.crt" @@ -47,66 +39,5 @@ class site_couchdb::stunnel {        Class['Site_config::X509::Ca'] ];    } - -  # setup stunnel server for Erlang Port Mapper Daemon (epmd), necessary for -  # bigcouch clustering between each bigcouchdb node -  stunnel::service { 'epmd_server': -    accept     => $epmd_server_accept, -    connect    => $epmd_server_connect, -    client     => false, -    cafile     => $ca_path, -    key        => $key_path, -    cert       => $cert_path, -    verify     => '2', -    pid        => '/var/run/stunnel4/epmd_server.pid', -    rndfile    => '/var/lib/stunnel4/.rnd', -    debuglevel => '4', -    require    => [ -      Class['Site_config::X509::Key'], -      Class['Site_config::X509::Cert'], -      Class['Site_config::X509::Ca'] ]; -  } - -  # setup stunnel clients for Erlang Port Mapper Daemon (epmd) to connect -  # to the above epmd stunnel server. -  $epmd_client_defaults = { -    'client'       => true, -    'cafile'       => $ca_path, -    'key'          => $key_path, -    'cert'         => $cert_path, -  } - -  create_resources(site_stunnel::clients, $epmd_clients, $epmd_client_defaults) - -  # setup stunnel server for Erlang Distributed Node Protocol (ednp), necessary -  # for bigcouch clustering between each bigcouchdb node -  stunnel::service { 'ednp_server': -    accept     => $ednp_server_accept, -    connect    => $ednp_server_connect, -    client     => false, -    cafile     => $ca_path, -    key        => $key_path, -    cert       => $cert_path, -    verify     => '2', -    pid        => '/var/run/stunnel4/ednp_server.pid', -    rndfile    => '/var/lib/stunnel4/.rnd', -    debuglevel => '4', -    require    => [ -      Class['Site_config::X509::Key'], -      Class['Site_config::X509::Cert'], -      Class['Site_config::X509::Ca'] ]; -  } - -  # setup stunnel clients for Erlang Distributed Node Protocol (ednp) to connect -  # to the above ednp stunnel server. -  $ednp_client_defaults = { -    'client'       => true, -    'cafile'       => $ca_path, -    'key'          => $key_path, -    'cert'         => $cert_path, -  } - -  create_resources(site_stunnel::clients, $ednp_clients, $ednp_client_defaults) -    include site_check_mk::agent::stunnel  }  | 
