Rego is the declarative policy language used by Open Policy Agent (OPA). This tile covers writing and testing Rego policies for Kubernetes admission control, Terraform and infrastructure-as-code plan validation, Docker container authorization, HTTP API authorization, RBAC and role-based access control, data filtering, metadata annotations with opa inspect, and OPA policy testing with opa test.
99
Quality
Pending
Does it follow best practices?
Impact
99%
1.19xAverage score across 31 eval scenarios
Pending
The risk profile of this skill
{
"context": "Evaluates whether the agent implements a correct multi-region deployment policy. Key patterns: accessing provider config at tfplan.configuration.provider_config.aws.expressions.region.constant_value (a deeply nested path), EU data residency check combining resource tag and region, and a has_replication helper with multiple function heads for S3 vs DynamoDB.",
"type": "weighted_checklist",
"checklist": [
{
"name": "Provider region check via configuration path",
"description": "The policy reads the AWS provider region from `tfplan.configuration.provider_config.aws.expressions.region.constant_value` and denies if it is not in the approved set",
"max_score": 28
},
{
"name": "EU data residency deny rule",
"description": "A deny rule triggers when a data-holding resource (`aws_s3_bucket`, `aws_rds_cluster`, or `aws_dynamodb_table`) is created with tag `DataResidency == \"EU\"` and the provider region is not in `{\"eu-west-1\", \"eu-central-1\"}`",
"max_score": 27
},
{
"name": "has_replication helper with multiple function heads",
"description": "A `has_replication` (or equivalent) helper has separate function heads for S3 (checking `replication_configuration`) and DynamoDB (checking `count(replica) > 0`), and is used in a warn rule for high-criticality resources",
"max_score": 20
},
{
"name": "Tests pass",
"description": "All tests pass when running `opa test . -v`",
"max_score": 25
}
]
}docs
evals
scenario-1
scenario-2
scenario-3
scenario-4
scenario-5
scenario-6
scenario-7
scenario-8
scenario-9
scenario-10
scenario-11
scenario-12
scenario-13
scenario-14
scenario-15
scenario-16
scenario-17
scenario-18
scenario-19
scenario-20
scenario-21
scenario-22
scenario-23
scenario-24
scenario-25
scenario-26
scenario-27
scenario-28
scenario-29
scenario-30
scenario-31