Defined Type: postgresql::server::grant_role

Defined in:
manifests/server/grant_role.pp

Summary

Define for granting membership to a role.

Overview

Parameters:

  • group (String[1])

    Specifies the group role to which you are assigning a role.

  • role (String[1]) (defaults to: $name)

    Specifies the role you want to assign to a group. If left blank, uses the name of the resource.

  • ensure (Enum['present', 'absent']) (defaults to: 'present')

    Specifies whether to grant or revoke the membership. Valid options: ‘present’ or ‘absent’.

  • psql_db (String[1]) (defaults to: $postgresql::server::default_database)

    Specifies the database to execute the grant against. This should not ordinarily be changed from the default

  • psql_user (String[1]) (defaults to: $postgresql::server::user)

    Sets the OS user to run psql.

  • port (Variant[String[1], Stdlib::Port]) (defaults to: $postgresql::server::port)

    Port to use when connecting.

  • connect_settings (Hash) (defaults to: $postgresql::server::default_connect_settings)

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



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
# File 'manifests/server/grant_role.pp', line 10

define postgresql::server::grant_role (
  String[1]                                 $group,
  String[1]                                 $role             = $name,
  Enum['present', 'absent']                 $ensure           = 'present',
  String[1]                                 $psql_db          = $postgresql::server::default_database,
  String[1]                                 $psql_user        = $postgresql::server::user,
  Variant[String[1], Stdlib::Port]          $port             = $postgresql::server::port,
  Hash                                      $connect_settings = $postgresql::server::default_connect_settings,
) {
  if $port =~ String {
    deprecation('postgres_port', 'Passing a string to the port parameter is deprecated. Stdlib::Port will be the enforced datatype in the next major release')
  }
  case $ensure {
    'present': {
      $command = "GRANT \"${group}\" TO \"${role}\""
      $unless_comp = '='
    }
    'absent': {
      $command = "REVOKE \"${group}\" FROM \"${role}\""
      $unless_comp = '!='
    }
    default: {
      fail("Unknown value for ensure '${ensure}'.")
    }
  }

  postgresql_psql { "grant_role:${name}":
    command          => $command,
    unless           => "SELECT 1 WHERE EXISTS (SELECT 1 FROM pg_roles AS r_role JOIN pg_auth_members AS am ON r_role.oid = am.member JOIN pg_roles AS r_group ON r_group.oid = am.roleid WHERE r_group.rolname = '${group}' AND r_role.rolname = '${role}') ${unless_comp} true", # lint:ignore:140chars
    db               => $psql_db,
    psql_user        => $psql_user,
    port             => $port,
    connect_settings => $connect_settings,
  }

  if ! $connect_settings or empty($connect_settings) {
    Class['postgresql::server'] -> Postgresql_psql["grant_role:${name}"]
  }
  if defined(Postgresql::Server::Role[$role]) {
    Postgresql::Server::Role[$role] -> Postgresql_psql["grant_role:${name}"]
  }
  if defined(Postgresql::Server::Role[$group]) {
    Postgresql::Server::Role[$group] -> Postgresql_psql["grant_role:${name}"]
  }
}