NIST 800-53 Compliant Terraform Modules
Enforced Before terraform apply

Access control, audit logging, system protection, configuration management. The NIST 800-53 controls that map to AWS resource configuration, enforced before terraform apply.

Federal agencies and their contractors use NIST 800-53 as the security baseline. If you sell to the US government or want FedRAMP authorization, this is where you start.

148

Controls

121

Clauses

34

AWS Modules

No credit card or AWS account needed to start.

From the team behind terraform-aws-modules. 2B+ provisions worldwide.

IAM · S3 · RDS · VPC · EC2 · GeneralSOC 2 Type II CertifiedAvailable on AWS Marketplace

Three Steps to NIST 800-53 Compliant Infrastructure

For terraform-aws-modules users, migration is a one-line change. Same workflow, same interface. Bringing your own modules? We can make those compliant too. Join the beta.

1

Change One Line

main.tf
module "s3" {
- source = "registry.terraform.io/..."
+ source = "nist80053.compliance.tf/..."
 
  bucket = "awesome-docs"
}
2

Run Terraform Commands

terminal
$ terraform init
Initializing modules...
- module.s3 in nist80053.compliance.tf/...
Terraform has been successfully initialized!
$ terraform apply
Apply complete! Resources: 1 added, 0 changed, 0 destroyed.
3

Compliance Enforced

AC-3(4) · Block Public Write
AU-9(2) · Public Access Blocked
SC-28(1) · KMS Encryption
SI-14(2) · Versioning + Lifecycle
SC-28 · Default Encryption
SC-8 · SSL Requests Only
AU-3 · Logging Enabled
CP-9 · Cross-Region Replication

Every compliance requirement you define is enforced automatically. Nothing to scan, nothing to remediate.

Controls Enforced for NIST 800-53

148 controls across 121 clauses and AWS services

Enforced (12)Detected (28)
·

Additional Controls

108 additional controls enforced for NIST 800-53

Enforced (57)Detected (51)

NIST 800-53 Scope: What We Handle vs. What You Own

compliance.tf handles the infrastructure configuration layer for NIST 800-53. Here is what it covers and what stays with your team.

compliance.tf Enforces for NIST 800-53

  • Infrastructure-level security controls (AC, AU, SC, CP, SI families)
  • NIST 800-53 Rev 5 control mapping with specific control IDs
  • Deployment-time evidence generation via AWS-native tools
  • Upstream module updates (terraform-aws-modules kept in sync)
  • Exception management with audit trail
  • Control documentation and security control mapping matrices

Your Team Still Handles for NIST 800-53

  • Risk assessment documentation (RA family)
  • Security planning and system security plans (PL family)
  • Contingency planning procedures (CP family — beyond backup config)
  • Personnel security and screening (PS family)
  • Awareness and training programs (AT family)
  • Incident response procedures (IR family)
  • Physical and environmental protection (PE family)

compliance.tf covers the NIST 800-53 technical controls that map to AWS resource configuration, primarily the AC, AU, SC, CP, and SI families. Organizational and procedural controls remain your team's responsibility.

NIST 800-53 Audit Evidence, Generated Automatically

Your auditor does not need to trust compliance.tf. Evidence comes from AWS-native tools they already accept.

Evidence your auditor already trusts

Every compliance.tf module enforces controls at deploy time. When AWS Config, Security Hub, or Audit Manager evaluates your resources, they report clean findings because the controls are built into the modules, not bolted on after the fact.

  • AWS Config rules validate resource configuration continuously
  • Security Hub aggregates findings across accounts and regions
  • Audit Manager generates assessment reports mapped to NIST 800-53
  • Downloadable control mapping matrices for your auditor
evidence.json
{
  "framework": "NIST 800-53",
  "clause": "SC-28",
  "control": "s3_bucket_default_encryption_enabled",
  "status": "COMPLIANT",
  "source": "AWS Config",
  "resource": "arn:aws:s3:::awesome-docs",
  "evaluated": "2026-03-04T10:30:00Z"
}

Prevention vs. Detection for NIST 800-53

compliance.tf prevents non-compliant deployments. Scanning tools detect them after the fact. Most mature programs use both.

DimensionIaC Scanning
Checkov / Trivy / Prowler
compliance.tf
Prevents non-compliant configs before terraform applyNo (post-plan scan)Yes
Maps controls to framework clause IDsPartialYes
Produces auditor-accepted evidence (AWS-native)Scan reports onlyYes
Exception management with audit trailSuppression rulesYes
Same interface as terraform-aws-modulesN/AYes
Keeps pace with upstream module updatesN/AYes
Catches runtime drift / console changesYesNo
Covers non-Terraform resourcesYesNo
Internal engineering timeMediumLow

We recommend keeping scanning tools active alongside compliance.tf for defense in depth. The scanner validates what compliance.tf already enforces.

NIST 800-53 Compliance Questions

Is this Rev 4 or Rev 5?

compliance.tf maps controls to NIST 800-53 Revision 5, the current version published in September 2020. Rev 5 added privacy controls and reorganized several control families. If you need Rev 4 mappings for legacy authorization packages, contact us.

Which control families does this cover?

compliance.tf enforces controls from the Access Control (AC), Audit and Accountability (AU), System and Communications Protection (SC), Configuration Management (CM), Contingency Planning (CP), and System and Information Integrity (SI) families. These are the families most directly tied to infrastructure configuration.

How is this different from Checkov, Trivy, or Prowler?

Those tools are detective controls. They scan infrastructure after you write it and report findings you fix manually. compliance.tf is a preventive control. The modules themselves cannot produce non-compliant resources. There is nothing to scan, nothing to remediate. Most teams keep their scanners running alongside compliance.tf for defense in depth.

Can I adopt this gradually, or is it all-or-nothing?

Fully incremental. Start with one module in one environment. Your existing modules continue working untouched. If you use Terragrunt or Terramate to orchestrate your runs, nothing changes — you’re only swapping the module source line. There is no global policy agent to deploy, no wrapper binary, no sidecar. Each module source line is independent.

Will my auditor accept this as evidence?

Your auditor does not need to trust compliance.tf directly. Evidence comes from AWS-native tools they already accept: AWS Config, Security Hub, and Audit Manager. We enforce controls at deploy time so those AWS tools always report clean findings.

What if I want to switch back or compliance.tf shuts down?

Our modules are standard Terraform. They work with Terraform, OpenTofu, Terragrunt, Terramate, and any tool that speaks the Terraform module protocol. Every module is a drop-in replacement for its upstream terraform-aws-modules equivalent with the same variables and outputs. Change your module source line back, run terraform init. Your infrastructure does not change. No lock-in, no proprietary state.

Start Deploying NIST 800-53-Compliant Infrastructure

$100/year for all 34 modules, all frameworks. 30-day free trial.

No credit card required. Switch back at any time.

Stay Informed About New Features

Join the mailing list for releases, new modules, and roadmap updates. No spam. Unsubscribe anytime.

Not convinced yet or dying for a feature we don't have? Send us an email — we really want to hear your feedback!