Overview
tfsecurity uses static analysis of your terraform code to spot potential misconfigurations.
Features
- β Checks for misconfigurations across all major (and some minor) cloud providers
- β Hundreds of built-in rules
- πͺ Scans modules (local and remote)
- β Evaluates HCL expressions as well as literal values
- βͺ Evaluates Terraform functions e.g.
concat()
- π Evaluates relationships between Terraform resources
- π§° Compatible with the Terraform CDK
- π
Applies (and embellishes) user-defined Rego policies
- π Supports multiple output formats: lovely (default), JSON, SARIF, CSV, CheckStyle, JUnit, text, Gif.
- π Configurable (via CLI flags and/or config file)
- β‘ Very fast, capable of quickly scanning huge repositories
- π Plugins for popular IDEs available (JetBrains, VSCode and Vim)
- π‘ Community-driven - come and chat with us on Slack!
Recommended by Thoughtworks
Rated Adopt by the Thoughtworks Tech Radar:
For our projects using Terraform, tfsecurity has quickly become a default static analysis tool to detect potential security risks. It's easy to integrate into a CI pipeline and has a growing library of checks against all of the major cloud providers and platforms like Kubernetes. Given its ease of use, we believe tfsecurity could be a good addition to any Terraform project.
Example Output
Installation
Install with brew/linuxbrew
brew install tfsecurity
Install with Chocolatey
choco install tfsecurity
Install with Scoop
scoop install tfsecurity
Bash script (Linux):
curl -s https://raw.githubusercontent.com/khulnasoft/tfsecurity/master/scripts/install_linux.sh | bash
You can also grab the binary for your system from the releases page.
Alternatively, install with Go:
go install github.com/khulnasoft/tfsecurity/cmd/tfsecurity@latest
Please note that using go install
will install directly from the master
branch and version numbers will not be reported via tfsecurity --version
.
Signing
The binaries on the releases page are signed with the tfsecurity signing key D66B222A3EA4C25D5D1A097FC34ACEFB46EC39CE
Form more information check the signing page for instructions on verification.
Usage
tfsecurity will scan the specified directory. If no directory is specified, the current working directory will be used.
The exit status will be non-zero if tfsecurity finds problems, otherwise the exit status will be zero.
tfsecurity .
Use with Docker
As an alternative to installing and running tfsecurity on your system, you may run tfsecurity in a Docker container.
There are a number of Docker options available
To run:
docker run --rm -it -v "$(pwd):/src" khulnasoft/tfsecurity /src
Use with Visual Studio Code
A Visual Studio Code extension is being developed to integrate with tfsecurity results. More information can be found on the tfsecurity Marketplace page
Use as GitHub Action
If you want to run tfsecurity on your repository as a GitHub Action, you can use https://github.com/khulnasoft-lab/tfsecurity-pr-commenter-action.
Use as an Azure DevOps Pipelines Task
You can now install the official tfsecurity task. Please raise any issues/feature requests on the task repository.
Ignoring Warnings
You may wish to ignore some warnings. If you'd like to do so, you can
simply add a comment containing tfsecurity:ignore:<rule>
to the offending
line in your templates. Alternatively, you can add the comment to the line above the block containing the issue, or to the module block to ignore all occurrences of an issue inside the module.
For example, to ignore an open security group rule:
resource "aws_security_group_rule" "my-rule" {
type = "ingress"
cidr_blocks = ["0.0.0.0/0"] #tfsecurity:ignore:aws-vpc-no-public-ingress-sgr
}
...or...
resource "aws_security_group_rule" "my-rule" {
type = "ingress"
#tfsecurity:ignore:aws-vpc-no-public-ingress-sgr
cidr_blocks = ["0.0.0.0/0"]
}
If you're not sure which line to add the comment on, just check the
tfsecurity output for the line number of the discovered problem.
You can ignore multiple rules by concatenating the rules on a single line:
#tfsecurity:ignore:aws-s3-enable-bucket-encryption tfsecurity:ignore:aws-s3-enable-bucket-logging
resource "aws_s3_bucket" "my-bucket" {
bucket = "foobar"
acl = "private"
}
Expiration Date
You can set expiration date for ignore
with yyyy-mm-dd
format. This is a useful feature when you want to ensure ignored issue won't be forgotten and should be revisited in the future.
#tfsecurity:ignore:aws-s3-enable-bucket-encryption:exp:2025-01-02
Ignore like this will be active only till 2025-01-02
, after this date it will be deactivated.
Disable checks
You may wish to exclude some checks from running. If you'd like to do so, you can
simply add new argument -e check1,check2,etc
to your cmd command
tfsecurity . -e general-secrets-sensitive-in-variable,google-compute-disk-encryption-customer-keys
Including values from .tfvars
You can include values from a tfvars file in the scan, using, for example: --tfvars-file terraform.tfvars
.
Included Checks
tfsecurity supports many popular cloud and platform providers
Running in CI
tfsecurity is designed for running in a CI pipeline. You may wish to run tfsecurity as part of your build without coloured
output. You can do this using --no-colour
(or --no-color
for our American friends).
Output options
You can output tfsecurity results as JSON, CSV, Checkstyle, Sarif, JUnit or just plain old human-readable format. Use the --format
flag
to specify your desired format.
GitHub Security Alerts
If you want to integrate with Github Security alerts and include the output of your tfsecurity checks you can use the tfsecurity-sarif-action Github action to run the static analysis then upload the results to the security alerts tab.
The alerts generated for tfsecurity-example-project look like this.
When you click through the alerts for the branch, you get more information about the actual issue.
For more information about adding security alerts, check the GitHub documentation
If you need to support versions of terraform which use HCL v1
(terraform <0.12), you can use v0.1.3
of tfsecurity, though support is
very limited and has fewer checks.
Contributing
We always welcome contributions; big or small, it can be documentation updates, adding new checks or something bigger. Please check the Contributing Guide for details on how to help out.
Some People who have contributed
Made with contributors-img.
tfsecurity
is an Khulnasoft Security open source project.
Learn about our open source work and portfolio here.
Join the community, and talk to us about any matter in GitHub Discussion or Slack.