Skip to content

Commit

Permalink
New 'not_resources' feature + version compatibility (#17)
Browse files Browse the repository at this point in the history
* Set minimum provider version to 4.26.0 to allow use of 'force_destroy'

* Add new 'not_resources' feature

* Lint fixes
  • Loading branch information
Abdul Wahid authored Jul 14, 2023
1 parent b658aa0 commit c9b3bbe
Show file tree
Hide file tree
Showing 16 changed files with 167 additions and 21 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -28,3 +28,5 @@ override.tf.json

# Include tfplan files to ignore the plan output of command: terraform plan -out=tfplan
# example: *tfplan*

**/.infracost
4 changes: 2 additions & 2 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
repos:
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.3.0
rev: v4.4.0
hooks:
- id: check-added-large-files
args: ['--maxkb=500']
Expand All @@ -18,7 +18,7 @@ repos:
args: ['--allow-missing-credentials']
- id: trailing-whitespace
- repo: https://github.com/antonbabenko/pre-commit-terraform
rev: v1.76.0
rev: v1.81.0
hooks:
- id: terraform_fmt
- id: terraform_docs
Expand Down
9 changes: 6 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -86,14 +86,14 @@ Module managed by:

| Name | Version |
|------|---------|
| <a name="requirement_terraform"></a> [terraform](#requirement\_terraform) | >= 1.0.11 |
| <a name="requirement_aws"></a> [aws](#requirement\_aws) | >= 4.0.0 |
| <a name="requirement_terraform"></a> [terraform](#requirement\_terraform) | >= 1.5.0 |
| <a name="requirement_aws"></a> [aws](#requirement\_aws) | >= 4.26.0 |

## Providers

| Name | Version |
|------|---------|
| <a name="provider_aws"></a> [aws](#provider\_aws) | 4.35.0 |
| <a name="provider_aws"></a> [aws](#provider\_aws) | >= 4.26.0 |

## Modules

Expand All @@ -112,6 +112,8 @@ No modules.
| [aws_iam_role_policy_attachment.main_custom_policy_attach](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_role_policy_attachment) | resource |
| [aws_iam_role_policy_attachment.main_role_backup_policy_attach](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_role_policy_attachment) | resource |
| [aws_iam_role_policy_attachment.main_role_restore_policy_attach](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_role_policy_attachment) | resource |
| [aws_iam_role_policy_attachment.main_role_s3_backup_policy_attach](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_role_policy_attachment) | resource |
| [aws_iam_role_policy_attachment.main_role_s3_restore_policy_attach](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/iam_role_policy_attachment) | resource |
| [aws_sns_topic.main](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/sns_topic) | resource |
| [aws_sns_topic_policy.main](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/sns_topic_policy) | resource |
| [aws_iam_policy_document.main](https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/iam_policy_document) | data source |
Expand All @@ -131,6 +133,7 @@ No modules.
| <a name="input_plan_name"></a> [plan\_name](#input\_plan\_name) | The display name of a backup plan | `string` | n/a | yes |
| <a name="input_rules"></a> [rules](#input\_rules) | A list of rules mapping rule configurations for a backup plan | `any` | `[]` | no |
| <a name="input_selection_name"></a> [selection\_name](#input\_selection\_name) | The display name of a resource selection document | `string` | `null` | no |
| <a name="input_selection_not_resources"></a> [selection\_not\_resources](#input\_selection\_not\_resources) | An array of strings that either contain Amazon Resource Names (ARNs) or match patterns of resources to exclude from a backup plan. | `list(string)` | `[]` | no |
| <a name="input_selection_resources"></a> [selection\_resources](#input\_selection\_resources) | A list of strings that either contain Amazon Resource Names (ARNs) or match patterns of resources to assign to a backup plan | `list(string)` | `[]` | no |
| <a name="input_selection_tags"></a> [selection\_tags](#input\_selection\_tags) | A list of selection tags map | `list(any)` | `[]` | no |
| <a name="input_sns_topic_arn"></a> [sns\_topic\_arn](#input\_sns\_topic\_arn) | The Amazon Resource Name (ARN) that specifies the topic for a backup vault’s events | `string` | `null` | no |
Expand Down
8 changes: 8 additions & 0 deletions examples/exclusions/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
## Example deployment flow

```bash
terraform init
terraform validate
terraform plan
terraform apply --auto-approve
```
54 changes: 54 additions & 0 deletions examples/exclusions/main.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
######
# KMS
######
data "aws_kms_key" "backup" {
key_id = "alias/aws/backup"
}

resource "aws_s3_bucket" "example" {
bucket = "umotif-test-bucket"

tags = {
Environment = "test"
}
}

#########
# Backup
#########
module "backup" {
source = "../.."

# Create a vault
vault_name = "${var.name_prefix}-vault-exclusions"
vault_kms_key_arn = data.aws_kms_key.backup.arn

# Create a backup plan
plan_name = "${var.name_prefix}-backup-plan"

rules = [
{
name = "${var.name_prefix}-backup-rule"
schedule = "cron(0 12 * * ? *)"
start_window = "65"
completion_window = "180"
recovery_point_tags = {
Project = "test"
Region = "eu-west-1"
}

lifecycle = {
delete_after = 90
}
}
]

selection_name = "${var.name_prefix}-backup-selection"

selection_resources = ["*"]
selection_not_resources = [aws_s3_bucket.example.arn]

tags = {
Environment = "test"
}
}
44 changes: 44 additions & 0 deletions examples/exclusions/outputs.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
output "backup_vault_id" {
description = "The name of the AWS Backup Vault"
value = module.backup.backup_vault_id
}

output "backup_vault_arn" {
description = "The Amazon Resource Name (ARN) that identifies the AWS Backup Vault"
value = module.backup.backup_vault_arn
}

output "backup_vault_recovery_points" {
description = "The number of recovery points that are stored in a backup vault"
value = module.backup.backup_vault_recovery_points
}

output "backup_plan_id" {
description = "The name of the backup plan"
value = module.backup.backup_plan_id
}

output "backup_plan_arn" {
description = "The Amazon Resource Name (ARN) that identifies the backup plan"
value = module.backup.backup_plan_arn
}

output "backup_plan_version" {
description = "Unique, randomly generated, Unicode, UTF-8 encoded string that serves as the version ID of the backup plan."
value = module.backup.backup_plan_version
}

output "backup_selection_id" {
description = "The identifier of the backup selection"
value = module.backup.backup_selection_id
}

output "backup_vault_iam_role_name" {
description = "The name of the backup IAM role"
value = module.backup.backup_vault_iam_role_name
}

output "backup_vault_iam_role_arn" {
description = "The ARN of the backup IAM role"
value = module.backup.backup_vault_iam_role_arn
}
5 changes: 5 additions & 0 deletions examples/exclusions/variables.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
variable "name_prefix" {
description = "A prefix used for naming resources."
type = string
default = "example"
}
10 changes: 10 additions & 0 deletions examples/exclusions/versions.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
terraform {
required_version = "~> 1.5.0"

required_providers {
aws = {
source = "hashicorp/aws"
version = ">= 4.26.0"
}
}
}
6 changes: 3 additions & 3 deletions examples/external-vault/versions.tf
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
terraform {
required_version = ">= 1.0.11"
required_version = ">= 1.5.0"

required_providers {
aws = {
source = "hashicorp/aws"
version = ">= 4.0.0"
version = ">= 4.26.0"
}
}
}
}
6 changes: 3 additions & 3 deletions examples/multiple-dbs/versions.tf
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
terraform {
required_version = ">= 1.0.11"
required_version = ">= 1.5.0"

required_providers {
aws = {
source = "hashicorp/aws"
version = ">= 4.0.0"
version = ">= 4.26.0"
}
}
}
}
6 changes: 3 additions & 3 deletions examples/one-db/versions.tf
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
terraform {
required_version = ">= 1.0.11"
required_version = ">= 1.5.0"

required_providers {
aws = {
source = "hashicorp/aws"
version = ">= 4.0.0"
version = ">= 4.26.0"
}
}
}
}
2 changes: 1 addition & 1 deletion examples/vault/outputs.tf
Original file line number Diff line number Diff line change
Expand Up @@ -39,5 +39,5 @@ output "backup_vault_iam_role_name" {
}

output "backup_vault_iam_role_arn" {
output = module.backup.backup_vault_iam_role_name.arn
value = module.backup.backup_vault_iam_role_name.arn
}
6 changes: 3 additions & 3 deletions examples/vault/versions.tf
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
terraform {
required_version = ">= 1.0.11"
required_version = ">= 1.5.0"

required_providers {
aws = {
source = "hashicorp/aws"
version = ">= 4.0.0"
version = ">= 4.26.0"
}
}
}
}
16 changes: 15 additions & 1 deletion main.tf
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ resource "aws_backup_plan" "main" {

dynamic "rule" {
for_each = var.rules

content {
rule_name = lookup(rule.value, "name")
target_vault_name = var.vault_name != null ? aws_backup_vault.main[0].name : lookup(rule.value, "target_vault_name", "Default")
Expand All @@ -29,6 +30,7 @@ resource "aws_backup_plan" "main" {

dynamic "lifecycle" {
for_each = length(lookup(rule.value, "lifecycle")) == 0 ? [] : [lookup(rule.value, "lifecycle", {})]

content {
cold_storage_after = lookup(lifecycle.value, "cold_storage_after", 0)
delete_after = lookup(lifecycle.value, "delete_after", 90)
Expand All @@ -37,6 +39,7 @@ resource "aws_backup_plan" "main" {

dynamic "copy_action" {
for_each = length(lookup(rule.value, "copy_action", {})) == 0 ? [] : [lookup(rule.value, "copy_action", {})]

content {
destination_vault_arn = lookup(copy_action.value, "destination_vault_arn", null)

Expand Down Expand Up @@ -71,7 +74,8 @@ resource "aws_backup_selection" "main" {
name = var.selection_name
plan_id = aws_backup_plan.main.id

resources = var.selection_resources
resources = var.selection_resources
not_resources = var.selection_not_resources

dynamic "selection_tag" {
for_each = var.selection_tags
Expand Down Expand Up @@ -128,6 +132,16 @@ resource "aws_iam_role_policy_attachment" "main_role_restore_policy_attach" {
role = aws_iam_role.main.name
}

resource "aws_iam_role_policy_attachment" "main_role_s3_backup_policy_attach" {
policy_arn = "arn:${data.aws_partition.current.partition}:iam::aws:policy/AWSBackupServiceRolePolicyForS3Backup"
role = aws_iam_role.main.name
}

resource "aws_iam_role_policy_attachment" "main_role_s3_restore_policy_attach" {
policy_arn = "arn:${data.aws_partition.current.partition}:iam::aws:policy/AWSBackupServiceRolePolicyForS3Restore"
role = aws_iam_role.main.name
}

resource "aws_iam_policy" "main_custom_policy" {
description = "AWS Backup Tag policy"
policy = data.aws_iam_policy_document.main_custom_policy.json
Expand Down
6 changes: 6 additions & 0 deletions variables.tf
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,12 @@ variable "selection_resources" {
default = []
}

variable "selection_not_resources" {
description = "An array of strings that either contain Amazon Resource Names (ARNs) or match patterns of resources to exclude from a backup plan."
type = list(string)
default = []
}

variable "selection_tags" {
description = "A list of selection tags map"
type = list(any)
Expand Down
4 changes: 2 additions & 2 deletions versions.tf
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
terraform {
required_version = ">= 1.0.11"
required_version = ">= 1.5.0"

required_providers {
aws = {
source = "hashicorp/aws"
version = ">= 4.0.0"
version = ">= 4.26.0"
}
}
}

0 comments on commit c9b3bbe

Please sign in to comment.