Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/terraform-linters/tflint-ruleset-aws
TFLint ruleset for terraform-provider-aws
https://github.com/terraform-linters/tflint-ruleset-aws
aws terraform tflint tflint-ruleset
Last synced: 4 days ago
JSON representation
TFLint ruleset for terraform-provider-aws
- Host: GitHub
- URL: https://github.com/terraform-linters/tflint-ruleset-aws
- Owner: terraform-linters
- License: mpl-2.0
- Created: 2020-03-08T06:42:53.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-08T19:40:02.000Z (9 months ago)
- Last Synced: 2024-04-08T22:26:55.976Z (9 months ago)
- Topics: aws, terraform, tflint, tflint-ruleset
- Language: Go
- Homepage:
- Size: 5.96 MB
- Stars: 296
- Watchers: 7
- Forks: 69
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# TFLint Ruleset for terraform-provider-aws
[![Build Status](https://github.com/terraform-linters/tflint-ruleset-aws/workflows/build/badge.svg?branch=master)](https://github.com/terraform-linters/tflint-ruleset-aws/actions)
[![GitHub release](https://img.shields.io/github/release/terraform-linters/tflint-ruleset-aws.svg)](https://github.com/terraform-linters/tflint-ruleset-aws/releases/latest)
[![License: MPL 2.0](https://img.shields.io/badge/License-MPL%202.0-blue.svg)](LICENSE)TFLint ruleset plugin for Terraform AWS Provider
This ruleset focus on possible errors and best practices about AWS resources. Many rules are enabled by default and warn against code that might fail when running `terraform apply`, or clearly unrecommened.
## Requirements
- TFLint v0.42+
- Go v1.23## Installation
You can install the plugin by adding a config to `.tflint.hcl` and running `tflint --init`:
```hcl
plugin "aws" {
enabled = true
version = "0.37.0"
source = "github.com/terraform-linters/tflint-ruleset-aws"
}
```For more configuration about the plugin, see [Plugin Configuration](docs/configuration.md).
## Getting Started
Terraform is a great tool for Infrastructure as Code. However, many of these tools don't validate provider-specific issues. For example, see the following configuration file:
```hcl
resource "aws_instance" "foo" {
ami = "ami-0ff8a91507f77f867"
instance_type = "t1.2xlarge" # invalid type!
}
```Since `t1.2xlarge` is an invalid instance type, an error will occur when you run `terraform apply`. But `terraform validate` and `terraform plan` cannot find this possible error in advance. That's because it's an AWS provider-specific issue and it's valid as the Terraform Language.
The goal of this ruleset is to find such errors:
![demo](docs/assets/demo.gif)
By running TFLint with this ruleset in advance, you can fix the problem before the error occurs in production CI/CD pipelines.
## Rules
700+ rules are available. See [Rules](docs/rules/README.md).
## Building the plugin
Clone the repository locally and run the following command:
```
$ make
```You can easily install the built plugin with the following:
```
$ make install
```Note that if you install the plugin with `make install`, you must omit the `version` and `source` attributes in` .tflint.hcl`:
```hcl
plugin "aws" {
enabled = true
}
```## Add a new rule
If you are interested in adding a new rule to this ruleset, you can use the generator. Run the following command:
```
$ go run ./rules/generator
```Follow the instructions to edit the generated files and open a new pull request.