Module is used for granting privileges on particular specified databases.
- Some variables have default values, thus could be omitted. Look at the description in Inputs section below.
module "grant_on_some_db" {
source = "github.com/antonvigo/pg-iac-grant-database"
host = {
host = "pg.host.com"
port = 5432
username = "root"
password = "Password123"
}
database = {
name = "some_db"
owner = "some_db_admin"
}
privileges = ["CONNECT","CREATE"]
group_role = "new_group_role"
make_admin_own = false
revoke_grants = false
depends_on = [module.last_existing_privileges_module_call]
}
- It's strongly recommended to replace input constants with predefined variables containing corresponding values.
- Even if empty list of privilegs is provided all possbile privileges will be granted. Same way for some other variables.
Name | Version |
---|---|
terraform | >= 1.0.0 |
local | 2.4.0 |
null | 3.2.1 |
Name | Version |
---|---|
local | 2.4.0 |
null | 3.2.1 |
No modules.
Name | Type |
---|---|
local_file.rendered_script | resource |
null_resource.drop_role | resource |
null_resource.run_script | resource |
Name | Description | Type | Default | Required |
---|---|---|---|---|
database | Database to manage permissions at | object({ |
n/a | yes |
group_role | Group role to be granted with specified privileges | string |
"" |
no |
host | RDS connection data | object({ |
n/a | yes |
make_admin_own | Is it necessary to grant admin user to database owner role or not. It is in case of RDS, because standard root account isn't a superuser. | bool |
true |
no |
privileges | Granted privileges, default value is 'ALL'. The value of 'ALL' can be specified | list(string) |
[ |
no |
revoke_grants | Revoke all grants which were provided by this module just before or not | bool |
false |
no |
Name | Description |
---|---|
grants_to_group | List of granted privileges for specified role |
sql_script | Applied SQL script |