Skip to content

IAM Policy Hardcoded Partitions

Rule: aws_iam_policy_hardcoded_partition

This rule checks aws_iam_policy resources for hardcoded AWS partitions in policy documents. It detects:

  • Hardcoded partitions in ARNs within policy statements
resource "aws_iam_policy" "bad" {
policy = jsonencode({
Statement = [{
Effect = "Allow"
Action = "sqs:*"
Resource = "arn:aws-us-gov:sqs:*:*:*" # ❌ Hardcoded partition
}]
})
}
resource "aws_iam_policy" "good" {
policy = jsonencode({
Statement = [{
Effect = "Allow"
Action = "sqs:*"
Resource = "arn:${data.aws_partition.current.partition}:sqs:*:*:*" # ✅ Dynamic partition
}]
})
}

This rule is disabled by default. To enable it, add it to your .tflint.hcl:

rule "aws_iam_policy_hardcoded_partition" {
enabled = true
}