diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS new file mode 100644 index 0000000..231c9a6 --- /dev/null +++ b/.github/CODEOWNERS @@ -0,0 +1,2 @@ +# These owners will be the default owners for everything in the repo. +* @anmolnagpal @clouddrove/approvers @clouddrove-ci diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md new file mode 100644 index 0000000..e414e28 --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -0,0 +1,12 @@ +## what +* Describe high-level what changed as a result of these commits (i.e. in plain-english, what do these changes mean?) +* Use bullet points to be concise and to the point. + +## why +* Provide the justifications for the changes (e.g. business case). +* Describe why these changes were made (e.g. why do these commits fix the problem?) +* Use bullet points to be concise and to the point. + +## references +* Link to any supporting jira issues or helpful documentation to add some context (e.g. stackoverflow). +* Use `closes #123`, if this PR closes a Jira issue `#123` diff --git a/.github/workflows/auto_assignee.yml b/.github/workflows/auto_assignee.yml new file mode 100644 index 0000000..3dbedbd --- /dev/null +++ b/.github/workflows/auto_assignee.yml @@ -0,0 +1,12 @@ +name: Auto Assign PRs +on: + pull_request: + types: [opened, reopened] + workflow_dispatch: +jobs: + assignee: + uses: clouddrove/github-shared-workflows/.github/workflows/auto_assignee.yml@1.0.5 + secrets: + GITHUB: ${{ secrets.GITHUB }} + with: + assignees: 'clouddrove-ci' diff --git a/.github/workflows/changelog.yml b/.github/workflows/changelog.yml index 4b735f5..af14ff7 100644 --- a/.github/workflows/changelog.yml +++ b/.github/workflows/changelog.yml @@ -7,7 +7,7 @@ on: workflow_dispatch: jobs: changelog: - uses: clouddrove/github-shared-workflows/.github/workflows/changelog.yml@master + uses: clouddrove/github-shared-workflows/.github/workflows/changelog.yml@1.0.5 secrets: inherit with: - branch: 'master' \ No newline at end of file + branch: 'master' diff --git a/.github/workflows/readme.yml b/.github/workflows/readme.yml index 9d83b2b..2ff513e 100644 --- a/.github/workflows/readme.yml +++ b/.github/workflows/readme.yml @@ -3,17 +3,16 @@ on: push: branches: - master - jobs: - readme-create: + readme: name: 'readme-create' runs-on: ubuntu-latest steps: - name: 'Checkout' uses: actions/checkout@master - - name: Set up Python 3.7. - uses: actions/setup-python@v2 + - name: 'Set up Python 3.7' + uses: actions/setup-python@v4 with: python-version: '3.x' @@ -21,17 +20,17 @@ jobs: uses: 'clouddrove/github-actions@v9.0.2' with: actions_subcommand: 'readme' - github_token: '${{ secrets.GITHUB}}' + github_token: '${{ secrets.GITHUB }}' env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN}} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - name: 'pre-commit check errors' - uses: pre-commit/action@v2.0.0 + uses: pre-commit/action@v3.0.0 continue-on-error: true - name: 'pre-commit fix erros' - uses: pre-commit/action@v2.0.0 + uses: pre-commit/action@v3.0.0 continue-on-error: true - name: 'push readme' @@ -40,7 +39,7 @@ jobs: with: actions_subcommand: 'push' env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN}} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - name: 'Slack Notification' uses: clouddrove/action-slack@v2 diff --git a/.github/workflows/terraform.yml b/.github/workflows/terraform.yml deleted file mode 100644 index 85a0002..0000000 --- a/.github/workflows/terraform.yml +++ /dev/null @@ -1,85 +0,0 @@ -name: static-checks - -on: - pull_request: - -jobs: - versionExtract: - name: Get min/max versions - runs-on: ubuntu-latest - - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: Terraform min/max versions - id: minMax - uses: clowdhaus/terraform-min-max@main - outputs: - minVersion: ${{ steps.minMax.outputs.minVersion }} - maxVersion: ${{ steps.minMax.outputs.maxVersion }} - - - versionEvaluate: - name: Evaluate Terraform versions - runs-on: ubuntu-latest - needs: versionExtract - strategy: - fail-fast: false - matrix: - version: - - ${{ needs.versionExtract.outputs.minVersion }} - - ${{ needs.versionExtract.outputs.maxVersion }} - directory: - - _example/anomaly_example/ - - _example/basic_example/ - - _example/expression_example/ - - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: Install Terraform v${{ matrix.version }} - uses: hashicorp/setup-terraform@v1 - with: - terraform_version: ${{ matrix.version }} - - - name: 'Configure AWS Credentials' - uses: clouddrove/configure-aws-credentials@v1 - with: - aws-access-key-id: ${{ secrets.TEST_AWS_ACCESS_KEY }} - aws-secret-access-key: ${{ secrets.TEST_AWS_ACCESS_SECRET_KEY }} - aws-region: us-east-2 - - - name: Init & validate v${{ matrix.version }} - run: | - cd ${{ matrix.directory }} - terraform init - terraform validate - - - name: tflint - uses: reviewdog/action-tflint@master - with: - tflint_version: v0.29.0 - github_token: ${{ secrets.GITHUB }} - working_directory: ${{ matrix.directory }} - fail_on_error: 'true' - filter_mode: 'nofilter' - flags: '--module' - - format: - name: Check code format - runs-on: ubuntu-latest - needs: versionExtract - - steps: - - name: Checkout - uses: actions/checkout@v2 - - - name: Install Terraform v${{ needs.versionExtract.outputs.maxVersion }} - uses: hashicorp/setup-terraform@v1 - with: - terraform_version: ${{ needs.versionExtract.outputs.maxVersion }} - - - name: Check Terraform format changes - run: terraform fmt --recursive \ No newline at end of file diff --git a/.github/workflows/terratest.yml b/.github/workflows/terratest.yml deleted file mode 100644 index a043a42..0000000 --- a/.github/workflows/terratest.yml +++ /dev/null @@ -1,40 +0,0 @@ -name: 'Terratest GitHub Actions' -on: - pull_request: - branches: - - master - types: [labeled] - -jobs: - Terratest: - name: 'terratest' - runs-on: ubuntu-latest - steps: - - - name: 'Checkout' - uses: actions/checkout@v2.3.4 - - - name: 'Configure AWS Credentials' - uses: clouddrove/configure-aws-credentials@v1 - with: - aws-access-key-id: ${{ secrets.TEST_AWS_ACCESS_KEY }} - aws-secret-access-key: ${{ secrets.TEST_AWS_ACCESS_SECRET_KEY }} - aws-region: us-east-2 - - - name: 'terratest' - uses: 'clouddrove/github-actions@v9.0.2' - with: - actions_subcommand: 'terratest' - if: ${{ github.event.label.name == 'terratest' }} - tf_actions_working_dir: '_test' - - - name: 'Slack Notification' - uses: clouddrove/action-slack@v2 - with: - status: ${{ job.status }} - fields: repo,author - author_name: 'CloudDrove' - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # required - SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_TERRAFORM }} # required - if: always() diff --git a/.github/workflows/tf-checks.yml b/.github/workflows/tf-checks.yml new file mode 100644 index 0000000..92183e5 --- /dev/null +++ b/.github/workflows/tf-checks.yml @@ -0,0 +1,19 @@ +name: tf-checks +on: + push: + branches: [ master ] + pull_request: + workflow_dispatch: +jobs: + tf-checks-anomaly-example: + uses: clouddrove/github-shared-workflows/.github/workflows/tf-checks.yml@1.0.5 + with: + working_directory: './_example/anomaly_example/' + tf-checks-basic-example: + uses: clouddrove/github-shared-workflows/.github/workflows/tf-checks.yml@1.0.5 + with: + working_directory: './_example/basic_example/' + tf-checks-expression-example: + uses: clouddrove/github-shared-workflows/.github/workflows/tf-checks.yml@1.0.5 + with: + working_directory: './_example/expression_example/' diff --git a/.github/workflows/tflint.yml b/.github/workflows/tflint.yml new file mode 100644 index 0000000..a92aebb --- /dev/null +++ b/.github/workflows/tflint.yml @@ -0,0 +1,11 @@ +name: tf-lint +on: + push: + branches: [ master ] + pull_request: + workflow_dispatch: +jobs: + tf-lint: + uses: clouddrove/github-shared-workflows/.github/workflows/tf-lint.yml@1.0.5 + secrets: + GITHUB: ${{ secrets.GITHUB }} diff --git a/.github/workflows/tfsec.yml b/.github/workflows/tfsec.yml index 9aaf588..5c27fb9 100644 --- a/.github/workflows/tfsec.yml +++ b/.github/workflows/tfsec.yml @@ -5,7 +5,7 @@ on: workflow_dispatch: jobs: tfsec: - uses: clouddrove/github-shared-workflows/.github/workflows/tfsec.yml@master + uses: clouddrove/github-shared-workflows/.github/workflows/tfsec.yml@1.0.5 secrets: inherit with: - working_directory: '.' \ No newline at end of file + working_directory: '.' diff --git a/README.yaml b/README.yaml index 82b1310..c88c294 100644 --- a/README.yaml +++ b/README.yaml @@ -44,7 +44,7 @@ usage: |- ```hcl module "alarm" { source = "clouddrove/cloudwatch-alarms/aws" - version = "1.3.0" + version = "2.0.0" name = "alarm" environment = "test" label_order = ["name", "environment"] @@ -75,7 +75,7 @@ usage: |- ```hcl module "alarm" { source = "clouddrove/cloudwatch-alarms/aws" - version = "1.3.0" + version = "2.0.0" name = "alarm" environment = "test" label_order = ["name", "environment"] @@ -115,7 +115,7 @@ usage: |- ```hcl module "alarm" { source = "clouddrove/cloudwatch-alarms/aws" - version = "1.3.0" + version = "2.0.0" name = "alarm" environment = "test" label_order = ["name", "environment"] diff --git a/_example/anomaly_example/example.tf b/_example/anomaly_example/example.tf index f9c134d..e0d5dfe 100644 --- a/_example/anomaly_example/example.tf +++ b/_example/anomaly_example/example.tf @@ -1,5 +1,5 @@ ##--------------------------------------------------------------------------------------------------------------------------- -## Provider block added, Use the Amazon Web Services (AWS) provider to interact with the many resources supported by AWS. +## Provider block added, Use6 the Amazon Web Services (AWS) provider to interact with the many resources supported by AWS. ##-------------------------------------------------------------------------------------------------------------------------- provider "aws" { region = "eu-west-1" @@ -15,8 +15,7 @@ module "vpc" { name = "vpc" environment = "test" label_order = ["name", "environment"] - - cidr_block = "172.16.0.0/16" + cidr_block = "172.16.0.0/16" } ##----------------------------------------------------- @@ -24,13 +23,12 @@ module "vpc" { ##----------------------------------------------------- module "public_subnets" { source = "clouddrove/subnet/aws" - version = "1.3.0" + version = "2.0.0" name = "public-subnet" environment = "test" label_order = ["name", "environment"] - availability_zones = ["eu-west-1b", "eu-west-1c"] vpc_id = module.vpc.vpc_id cidr_block = module.vpc.vpc_cidr_block @@ -39,49 +37,23 @@ module "public_subnets" { igw_id = module.vpc.igw_id } -##----------------------------------------------------- -## An AWS security group acts as a virtual firewall for incoming and outgoing traffic with http-https. -##----------------------------------------------------- -module "http-https" { - source = "clouddrove/security-group/aws" - version = "2.0.0" - - name = "alarm" - environment = "test" - label_order = ["name", "environment"] - - vpc_id = module.vpc.vpc_id - allowed_ip = ["0.0.0.0/0"] - allowed_ports = [80, 443] -} - -##----------------------------------------------------- -## An AWS security group acts as a virtual firewall for incoming and outgoing traffic with ssh. -##----------------------------------------------------- -module "ssh" { - source = "clouddrove/security-group/aws" - version = "2.0.0" - - name = "alarmsg" - environment = "test" - label_order = ["name", "environment"] - - vpc_id = module.vpc.vpc_id - allowed_ip = [module.vpc.vpc_cidr_block] - allowed_ports = [22] -} - ##----------------------------------------------------- ## Amazon EC2 provides cloud hosted virtual machines, called "instances", to run applications. ##----------------------------------------------------- module "ec2" { source = "clouddrove/ec2/aws" - version = "1.3.0" + version = "2.0.0" name = "alarm" environment = "test" label_order = ["name", "environment"] + ####---------------------------------------------------------------------------------- + ## Below A security group controls the traffic that is allowed to reach and leave the resources that it is associated with. + ####---------------------------------------------------------------------------------- + vpc_id = module.vpc.vpc_id + allowed_ip = [module.vpc.vpc_cidr_block] + allowed_ports = [22, 80, 443] instance_count = 1 ami = "ami-08d658f84a6d84a80" @@ -90,15 +62,12 @@ module "ec2" { monitoring = true associate_public_ip_address = true tenancy = "default" - vpc_security_group_ids_list = [module.ssh.security_group_ids, module.http-https.security_group_ids] subnet_ids = tolist(module.public_subnets.public_subnet_id) - - assign_eip_address = "true" - - ebs_volume_enabled = "true" - ebs_volume_type = "gp2" - ebs_volume_size = 30 - user_data = "./_bin/user_data.sh" + assign_eip_address = "true" + ebs_volume_enabled = "true" + ebs_volume_type = "gp2" + ebs_volume_size = 30 + user_data = "./_bin/user_data.sh" } ##----------------------------------------------------------------------------- @@ -133,9 +102,8 @@ module "alarm" { InstanceId = module.ec2.instance_id[0] } }] - alarm_description = "This metric monitors ec2 cpu utilization" - alarm_actions = [] - + alarm_description = "This metric monitors ec2 cpu utilization" + alarm_actions = [] actions_enabled = true insufficient_data_actions = [] ok_actions = [] diff --git a/_example/anomaly_example/outputs.tf b/_example/anomaly_example/outputs.tf index 5501408..28b0480 100644 --- a/_example/anomaly_example/outputs.tf +++ b/_example/anomaly_example/outputs.tf @@ -1,5 +1,5 @@ output "arn" { - value = module.alarm.*.arn + value = module.alarm[*].arn description = "The ARN of the cloudwatch metric alarm." } diff --git a/_example/anomaly_example/versions.tf b/_example/anomaly_example/versions.tf new file mode 100644 index 0000000..d32a33a --- /dev/null +++ b/_example/anomaly_example/versions.tf @@ -0,0 +1,11 @@ +# Terraform version +terraform { + required_version = ">= 1.5.7" + + required_providers { + aws = { + source = "hashicorp/aws" + version = ">= 5.18.1" + } + } +} \ No newline at end of file diff --git a/_example/basic_example/example.tf b/_example/basic_example/example.tf index 6e08e1e..39ac25b 100644 --- a/_example/basic_example/example.tf +++ b/_example/basic_example/example.tf @@ -15,9 +15,7 @@ module "vpc" { name = "vpc" environment = "test" label_order = ["name", "environment"] - - - cidr_block = "172.16.0.0/16" + cidr_block = "172.16.0.0/16" } ##----------------------------------------------------- @@ -25,13 +23,12 @@ module "vpc" { ##----------------------------------------------------- module "public_subnets" { source = "clouddrove/subnet/aws" - version = "1.3.0" + version = "2.0.0" name = "public-subnet" environment = "test" label_order = ["name", "environment"] - availability_zones = ["eu-west-1b", "eu-west-1c"] vpc_id = module.vpc.vpc_id cidr_block = module.vpc.vpc_cidr_block @@ -40,50 +37,22 @@ module "public_subnets" { igw_id = module.vpc.igw_id } -##----------------------------------------------------- -## An AWS security group acts as a virtual firewall for incoming and outgoing traffic with http-https. -##----------------------------------------------------- -module "http-https" { - source = "clouddrove/security-group/aws" - version = "2.0.0" - - - name = "http-https" - environment = "test" - label_order = ["name", "environment"] - - vpc_id = module.vpc.vpc_id - allowed_ip = ["0.0.0.0/0"] - allowed_ports = [80, 443] -} - -##----------------------------------------------------- -## An AWS security group acts as a virtual firewall for incoming and outgoing traffic with ssh. -##----------------------------------------------------- -module "ssh" { - source = "clouddrove/security-group/aws" - version = "2.0.0" - - - name = "ssh" - environment = "test" - label_order = ["name", "environment"] - - vpc_id = module.vpc.vpc_id - allowed_ip = [module.vpc.vpc_cidr_block] - allowed_ports = [22] -} - ##----------------------------------------------------- ## Amazon EC2 provides cloud hosted virtual machines, called "instances", to run applications. ##----------------------------------------------------- module "ec2" { source = "clouddrove/ec2/aws" - version = "1.3.0" + version = "2.0.0" name = "ec2-instance" environment = "test" label_order = ["name", "environment"] + ####---------------------------------------------------------------------------------- + ## Below A security group controls the traffic that is allowed to reach and leave the resources that it is associated with. + ####---------------------------------------------------------------------------------- + vpc_id = module.vpc.vpc_id + allowed_ip = [module.vpc.vpc_cidr_block] + allowed_ports = [22, 80, 443] instance_count = 1 ami = "ami-08d658f84a6d84a80" @@ -92,15 +61,12 @@ module "ec2" { monitoring = true associate_public_ip_address = true tenancy = "default" - vpc_security_group_ids_list = [module.ssh.security_group_ids, module.http-https.security_group_ids] subnet_ids = tolist(module.public_subnets.public_subnet_id) - - assign_eip_address = "true" - - ebs_volume_enabled = "true" - ebs_volume_type = "gp2" - ebs_volume_size = 30 - user_data = "./_bin/user_data.sh" + assign_eip_address = "true" + ebs_volume_enabled = "true" + ebs_volume_type = "gp2" + ebs_volume_size = 30 + user_data = "./_bin/user_data.sh" } ##----------------------------------------------------------------------------- @@ -113,18 +79,16 @@ module "alarm" { environment = "test" label_order = ["name", "environment"] - - alarm_name = "cpu-alarm" - comparison_operator = "GreaterThanOrEqualToThreshold" - evaluation_periods = 2 - metric_name = "CPUUtilization" - namespace = "AWS/EC2" - period = 60 - statistic = "Average" - threshold = 40 - alarm_description = "This metric monitors ec2 cpu utilization" - alarm_actions = [] - + alarm_name = "cpu-alarm" + comparison_operator = "GreaterThanOrEqualToThreshold" + evaluation_periods = 2 + metric_name = "CPUUtilization" + namespace = "AWS/EC2" + period = 60 + statistic = "Average" + threshold = 40 + alarm_description = "This metric monitors ec2 cpu utilization" + alarm_actions = [] actions_enabled = true insufficient_data_actions = [] ok_actions = [] diff --git a/_example/basic_example/outputs.tf b/_example/basic_example/outputs.tf index 5501408..28b0480 100644 --- a/_example/basic_example/outputs.tf +++ b/_example/basic_example/outputs.tf @@ -1,5 +1,5 @@ output "arn" { - value = module.alarm.*.arn + value = module.alarm[*].arn description = "The ARN of the cloudwatch metric alarm." } diff --git a/_example/basic_example/versions.tf b/_example/basic_example/versions.tf new file mode 100644 index 0000000..5b25067 --- /dev/null +++ b/_example/basic_example/versions.tf @@ -0,0 +1,11 @@ +# Terraform version +terraform { + required_version = ">= 1.5.5" + + required_providers { + aws = { + source = "hashicorp/aws" + version = ">= 5.13.1" + } + } +} \ No newline at end of file diff --git a/_example/expression_example/example.tf b/_example/expression_example/example.tf index 497644e..01c54d6 100644 --- a/_example/expression_example/example.tf +++ b/_example/expression_example/example.tf @@ -15,8 +15,7 @@ module "vpc" { name = "vpc" environment = "test" label_order = ["name", "environment"] - - cidr_block = "172.16.0.0/16" + cidr_block = "172.16.0.0/16" } ##----------------------------------------------------- @@ -24,13 +23,12 @@ module "vpc" { ##----------------------------------------------------- module "public_subnets" { source = "clouddrove/subnet/aws" - version = "1.3.0" + version = "2.0.0" name = "public-subnet" environment = "test" label_order = ["name", "environment"] - availability_zones = ["eu-west-1b", "eu-west-1c"] vpc_id = module.vpc.vpc_id cidr_block = module.vpc.vpc_cidr_block @@ -39,51 +37,24 @@ module "public_subnets" { igw_id = module.vpc.igw_id } -##----------------------------------------------------- -## An AWS security group acts as a virtual firewall for incoming and outgoing traffic with http-https. -##----------------------------------------------------- -module "http-https" { - source = "clouddrove/security-group/aws" - version = "2.0.0" - - - name = "http-https" - environment = "test" - label_order = ["name", "environment"] - - vpc_id = module.vpc.vpc_id - allowed_ip = ["0.0.0.0/0"] - allowed_ports = [80, 443] -} - -##----------------------------------------------------- -## An AWS security group acts as a virtual firewall for incoming and outgoing traffic with ssh. -##----------------------------------------------------- -module "ssh" { - source = "clouddrove/security-group/aws" - version = "2.0.0" - - - name = "ssh" - environment = "test" - label_order = ["name", "environment"] - - vpc_id = module.vpc.vpc_id - allowed_ip = [module.vpc.vpc_cidr_block] - allowed_ports = [22] -} - ##----------------------------------------------------- ## Amazon EC2 provides cloud hosted virtual machines, called "instances", to run applications. ##----------------------------------------------------- module "ec2" { source = "clouddrove/ec2/aws" - version = "1.3.0" + version = "2.0.0" name = "ec2-instance" environment = "test" label_order = ["name", "environment"] + ####---------------------------------------------------------------------------------- + ## Below A security group controls the traffic that is allowed to reach and leave the resources that it is associated with. + ####---------------------------------------------------------------------------------- + vpc_id = module.vpc.vpc_id + allowed_ip = [module.vpc.vpc_cidr_block] + allowed_ports = [22, 80, 443] + instance_count = 1 ami = "ami-08d658f84a6d84a80" ebs_optimized = "false" @@ -91,15 +62,12 @@ module "ec2" { monitoring = true associate_public_ip_address = true tenancy = "default" - vpc_security_group_ids_list = [module.ssh.security_group_ids, module.http-https.security_group_ids] subnet_ids = tolist(module.public_subnets.public_subnet_id) - - assign_eip_address = "true" - - ebs_volume_enabled = "true" - ebs_volume_type = "gp2" - ebs_volume_size = 30 - user_data = "./_bin/user_data.sh" + assign_eip_address = "true" + ebs_volume_enabled = "true" + ebs_volume_type = "gp2" + ebs_volume_size = 30 + user_data = "./_bin/user_data.sh" } ##----------------------------------------------------------------------------- @@ -112,7 +80,6 @@ module "alarm" { environment = "test" label_order = ["name", "environment"] - expression_enabled = true alarm_name = "cpu-alarm" comparison_operator = "GreaterThanOrEqualToThreshold" @@ -148,9 +115,8 @@ module "alarm" { LoadBalancer = "app/web" } }] - alarm_description = "This metric monitors ec2 cpu utilization" - alarm_actions = [] - + alarm_description = "This metric monitors ec2 cpu utilization" + alarm_actions = [] actions_enabled = true insufficient_data_actions = [] ok_actions = [] diff --git a/_example/expression_example/outputs.tf b/_example/expression_example/outputs.tf index 5501408..28b0480 100644 --- a/_example/expression_example/outputs.tf +++ b/_example/expression_example/outputs.tf @@ -1,5 +1,5 @@ output "arn" { - value = module.alarm.*.arn + value = module.alarm[*].arn description = "The ARN of the cloudwatch metric alarm." } diff --git a/_example/expression_example/versions.tf b/_example/expression_example/versions.tf new file mode 100644 index 0000000..5b25067 --- /dev/null +++ b/_example/expression_example/versions.tf @@ -0,0 +1,11 @@ +# Terraform version +terraform { + required_version = ">= 1.5.5" + + required_providers { + aws = { + source = "hashicorp/aws" + version = ">= 5.13.1" + } + } +} \ No newline at end of file diff --git a/_test/anomaly_example/watch_test.go b/_test/anomaly_example/watch_test.go deleted file mode 100644 index dae2ad7..0000000 --- a/_test/anomaly_example/watch_test.go +++ /dev/null @@ -1,31 +0,0 @@ -// Managed By : CloudDrove -// Description : This Terratest is used to test the Terraform cloudwatch-alarm module. -// Copyright @ CloudDrove. All Right Reserved. -package test - -import ( - "testing" - "github.com/gruntwork-io/terratest/modules/terraform" - "github.com/stretchr/testify/assert" -) - -func TestCloudWatch(t *testing.T) { - t.Parallel() - - terraformOptions := &terraform.Options{ - // Source path of Terraform directory. - TerraformDir: "../../_example/anomaly_example", - } - - // This will run `terraform init` and `terraform apply` and fail the test if there are any errors - terraform.InitAndApply(t, terraformOptions) - - // To clean up any resources that have been created, run 'terraform destroy' towards the end of the test - defer terraform.Destroy(t, terraformOptions) - - // To get the value of an output variable, run 'terraform output' - Tags := terraform.OutputMap(t, terraformOptions, "tags") - - // Check that we get back the outputs that we expect - assert.Equal(t, "alarm-test", Tags["Name"]) -} \ No newline at end of file diff --git a/_test/basic_example/watch_test.go b/_test/basic_example/watch_test.go deleted file mode 100644 index d4e5439..0000000 --- a/_test/basic_example/watch_test.go +++ /dev/null @@ -1,31 +0,0 @@ -// Managed By : CloudDrove -// Description : This Terratest is used to test the Terraform cloudwatch-alarm module. -// Copyright @ CloudDrove. All Right Reserved. -package test - -import ( - "testing" - "github.com/gruntwork-io/terratest/modules/terraform" - "github.com/stretchr/testify/assert" -) - -func TestCloudWatch(t *testing.T) { - t.Parallel() - - terraformOptions := &terraform.Options{ - // Source path of Terraform directory. - TerraformDir: "../../_example/basic_example", - } - - // This will run `terraform init` and `terraform apply` and fail the test if there are any errors - terraform.InitAndApply(t, terraformOptions) - - // To clean up any resources that have been created, run 'terraform destroy' towards the end of the test - defer terraform.Destroy(t, terraformOptions) - - // To get the value of an output variable, run 'terraform output' - Tags := terraform.OutputMap(t, terraformOptions, "tags") - - // Check that we get back the outputs that we expect - assert.Equal(t, "alarm-test", Tags["Name"]) -} \ No newline at end of file diff --git a/_test/expression_example/watch_test.go b/_test/expression_example/watch_test.go deleted file mode 100644 index fd0d8f6..0000000 --- a/_test/expression_example/watch_test.go +++ /dev/null @@ -1,31 +0,0 @@ -// Managed By : CloudDrove -// Description : This Terratest is used to test the Terraform cloudwatch-alarm module. -// Copyright @ CloudDrove. All Right Reserved. -package test - -import ( - "testing" - "github.com/gruntwork-io/terratest/modules/terraform" - "github.com/stretchr/testify/assert" -) - -func TestCloudWatch(t *testing.T) { - t.Parallel() - - terraformOptions := &terraform.Options{ - // Source path of Terraform directory. - TerraformDir: "../../_example/expression_example", - } - - // This will run `terraform init` and `terraform apply` and fail the test if there are any errors - terraform.InitAndApply(t, terraformOptions) - - // To clean up any resources that have been created, run 'terraform destroy' towards the end of the test - defer terraform.Destroy(t, terraformOptions) - - // To get the value of an output variable, run 'terraform output' - Tags := terraform.OutputMap(t, terraformOptions, "tags") - - // Check that we get back the outputs that we expect - assert.Equal(t, "alarm-test", Tags["Name"]) -} \ No newline at end of file diff --git a/outputs.tf b/outputs.tf index 16bec2d..46a1882 100644 --- a/outputs.tf +++ b/outputs.tf @@ -1,12 +1,12 @@ #Module : CLOUDWATCH METRIC ALARM #Description : Terraform module creates Cloudwatch Alarm on AWS for monitoriing AWS services. output "id" { - value = var.threshold_metric_id == "" ? (var.expression_enabled ? aws_cloudwatch_metric_alarm.expression.*.id : aws_cloudwatch_metric_alarm.default.*.id) : aws_cloudwatch_metric_alarm.anomaly.*.id + value = var.threshold_metric_id == "" ? (var.expression_enabled ? aws_cloudwatch_metric_alarm.expression[*].id : aws_cloudwatch_metric_alarm.default[*].id) : aws_cloudwatch_metric_alarm.anomaly[*].id description = "The ID of the health check." } output "arn" { - value = var.threshold_metric_id == "" ? (var.expression_enabled ? aws_cloudwatch_metric_alarm.expression.*.arn : aws_cloudwatch_metric_alarm.default.*.arn) : aws_cloudwatch_metric_alarm.anomaly.*.arn + value = var.threshold_metric_id == "" ? (var.expression_enabled ? aws_cloudwatch_metric_alarm.expression[*].arn : aws_cloudwatch_metric_alarm.default[*].arn) : aws_cloudwatch_metric_alarm.anomaly[*].arn description = "The ARN of the cloudwatch metric alarm." } diff --git a/variables.tf b/variables.tf index 390f3bb..d4aa742 100644 --- a/variables.tf +++ b/variables.tf @@ -133,19 +133,14 @@ variable "ok_actions" { description = "The list of actions to execute when this alarm transitions into an OK state from any other state." } -variable "instance_id" { - type = string - default = "" - description = "The instance ID." - sensitive = true -} - variable "dimensions" { + type = map(any) default = {} description = "Dimensions for metrics." } variable "query_expressions" { + type = list(any) default = [{ id = "e1" expression = "ANOMALY_DETECTION_BAND(m1)" @@ -156,6 +151,7 @@ variable "query_expressions" { } variable "query_metrics" { + type = list(any) default = [{ id = "m1" return_data = "true" diff --git a/versions.tf b/versions.tf index c3cde87..d32a33a 100644 --- a/versions.tf +++ b/versions.tf @@ -1,11 +1,11 @@ # Terraform version terraform { - required_version = ">= 1.4.6" + required_version = ">= 1.5.7" required_providers { aws = { source = "hashicorp/aws" - version = ">= 5.1.0" + version = ">= 5.18.1" } } -} +} \ No newline at end of file