Defined Type: postgresql::validate_db_connection

Defined in:
manifests/validate_db_connection.pp

Summary

This type validates that a successful postgres connection.

Overview

This validated if the postgres connection can be established between the node on which this resource is run and a specified postgres instance (host/port/user/password/database name).

Note:

Parameters:

  • database_host (Optional[String[1]]) (defaults to: undef)

    Database host address

  • database_name (Optional[String[1]]) (defaults to: undef)

    Specifies the name of the database you wish to test.

  • database_password (Optional[Variant[String, Sensitive[String]]]) (defaults to: undef)

    Specifies the password to connect with.

  • database_username (Optional[String[1]]) (defaults to: undef)

    Specifies the username to connect with.

  • database_port (Optional[Variant[String[1], Integer]]) (defaults to: undef)

    Defines the port to use when connecting.

  • connect_settings (Optional[Hash]) (defaults to: undef)

    Specifies a hash of environment variables used when connecting to a remote server.

  • run_as (Optional[String[1]]) (defaults to: undef)

    Specifies the user to run the psql command as.

  • sleep (Integer) (defaults to: 2)

    Sets the number of seconds to sleep for before trying again after a failure.

  • tries (Integer) (defaults to: 10)

    Sets the number of attempts after failure before giving up and failing the resource.

  • create_db_first (Boolean) (defaults to: true)

    Creates the database when obtaining a successful connection.



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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# File 'manifests/validate_db_connection.pp', line 20

define postgresql::validate_db_connection (
  Optional[String[1]]                          $database_host     = undef,
  Optional[String[1]]                          $database_name     = undef,
  Optional[Variant[String, Sensitive[String]]] $database_password = undef,
  Optional[String[1]]                          $database_username = undef,
  Optional[Variant[String[1], Integer]]        $database_port     = undef,
  Optional[Hash]                               $connect_settings  = undef,
  Optional[String[1]]                          $run_as            = undef,
  Integer                                      $sleep             = 2,
  Integer                                      $tries             = 10,
  Boolean                                      $create_db_first   = true
) {
  include postgresql::client
  include postgresql::params

  warning('postgresql::validate_db_connection is deprecated, please use postgresql_conn_validator.')

  $database_password_unsensitive = if $database_password =~ Sensitive[String] {
    $database_password.unwrap
  } else {
    $database_password
  }

  $psql_path = $postgresql::params::psql_path
  $module_workdir = $postgresql::params::module_workdir
  $validcon_script_path = $postgresql::client::validcon_script_path

  $cmd_init = "${psql_path} --tuples-only --quiet"
  $cmd_host = $database_host ? {
    undef   => '',
    default => "-h ${database_host}",
  }
  $cmd_user = $database_username ? {
    undef   => '',
    default => "-U ${database_username}",
  }
  $cmd_port = $database_port ? {
    undef   => '',
    default => "-p ${database_port}",
  }
  $cmd_dbname = $database_name ? {
    undef   => "--dbname ${postgresql::params::default_database}",
    default => "--dbname ${database_name}",
  }
  $pass_env = $database_password_unsensitive ? {
    undef   => undef,
    default => "PGPASSWORD=${database_password_unsensitive}",
  }
  $cmd = join([$cmd_init, $cmd_host, $cmd_user, $cmd_port, $cmd_dbname], ' ')
  $validate_cmd = [$validcon_script_path, $sleep, $tries, $cmd]

  # This is more of a safety valve, we add a little extra to compensate for the
  # time it takes to run each psql command.
  $timeout = (($sleep + 2) * $tries)

  # Combine $database_password_unsensitive and $connect_settings into an array of environment
  # variables, ensure $database_password_unsensitive is last, allowing it to override a password
  # from the $connect_settings hash
  if $connect_settings != undef {
    if $pass_env != undef {
      $env = concat(join_keys_to_values( $connect_settings, '='), $pass_env)
    } else {
      $env = join_keys_to_values( $connect_settings, '=')
    }
  } else {
    $env = $pass_env
  }

  $exec_name = "validate postgres connection for ${database_username}@${database_host}:${database_port}/${database_name}"
  $exec_command = "echo 'Unable to connect to defined database using: ${shell_escape($cmd)}' && false"

  exec { $exec_name:
    command     => $exec_command,
    unless      => $validate_cmd,
    cwd         => $module_workdir,
    environment => $env,
    logoutput   => 'on_failure',
    user        => $run_as,
    path        => '/bin:/usr/bin:/usr/local/bin',
    timeout     => $timeout,
    require     => Class['postgresql::client'],
  }

  # This is a little bit of puppet magic.  What we want to do here is make
  # sure that if the validation and the database instance creation are being
  # applied on the same machine, then the database resource is applied *before*
  # the validation resource.  Otherwise, the validation is guaranteed to fail
  # on the first run.
  #
  # We accomplish this by using Puppet's resource collection syntax to search
  # for the Database resource in our current catalog; if it exists, the
  # appropriate relationship is created here.
  if($create_db_first) {
    Postgresql::Server::Database<|title == $database_name|> -> Exec[$exec_name]
  }
}