Skip to content

terraform-postgresql-aws-arc-mgmt

Latest Release Last Updated Terraform GitHub Actions

Quality gate

snyk

Overview

It demonstrates how to create and manage a PostgreSQL database, roles, schemas, and associated resources on AWS.

In the example folder, you will see how this module should be called in downstream and how we can pass the values.

Usage

required_providers { postgresql = { version = "~> 1.21" source = "cyrilgdn/postgresql" } aws = { version = "~> 5.0" source = "hashicorp/aws" } } 1. Initialize Terraform with the backend config

terraform init -backend-config=config.dev.hcl
2. Plan Terraform
terraform plan -var-file .\tfvars\dev.tfvars
3. Apply Terraform
terraform apply -var-file .\tfvars\dev.tfvars

Requirements

Name Version
terraform ~> 1.4
aws ~> 5.0
postgresql ~> 1.21

Providers

Name Version
aws 5.28.0
postgresql 1.21.0

Modules

No modules.

Resources

Name Type
aws_ssm_parameter.this resource
postgresql_database.pg_db resource
postgresql_default_privileges.pg_default_privileges resource
postgresql_role.pg_role resource
postgresql_schema.pg_schema resource

Inputs

Name Description Type Default Required
pg_roles A map of objects where each key-value pair represents a PostgreSQL role
map(object({
postgres_role_name = string
login = string
password = string
}))
n/a yes
pg_ssm_parameters postgresql SSM parameters
map(object({
name = string
type = string
password = string
}))
n/a yes
postgresql_database A map where each key-value pair represents a PostgreSQL database configuration
map(object({
db_name = string
db_owner = string
template = optional(string, null)
lc_collate = optional(string, null)
connection_limit = optional(string, null)
allow_connections = optional(string, null)
}))
n/a yes
postgresql_default_privileges configuration block for postgresql default privileges
map(object({
role = string
database = string
schema = string
owner = string
object_type = string
privileges = list(string)
}))
n/a yes
postgresql_schema configuration block for postgresql schema
map(object({
schema_name = string
schema_owner = optional(string, null)
database = optional(string, null)
if_not_exists = optional(string, null)
drop_cascade = optional(string, null)

policy = optional(list(object({
usage = optional(string, null)
role = optional(string, null)
})), [])
}))
n/a yes

Outputs

Name Description
arn ARN of the parameter

Development

Prerequisites

Configurations

  • Configure pre-commit hooks
pre-commit install

Git commits

while Contributing or doing git commit please specify the breaking change in your commit message whether its major,minor or patch

For Example

git commit -m "your commit message #major"
By specifying this , it will bump the version and if you dont specify this in your commit message then by default it will consider patch and will bump that accordingly

Tests

  • Tests are available in test directory
  • Configure the dependencies
1
2
3
cd test
go mod init github.com/sourcefuse/terraform-aws-ref-arch-db
go get github.com/gruntwork-io/terratest/modules/terraform
  • Now execute the test
cd test/
go test

Authors

This project is authored by:

  • SourceFuse ARC Team