CtrlK
BlogDocsLog inGet started
Tessl Logo

nicholasjackson/opa-rego-language

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

1.19x

Quality

Pending

Does it follow best practices?

Impact

99%

1.19x

Average score across 31 eval scenarios

SecuritybySnyk

Pending

The risk profile of this skill

Overview
Eval results
Files

rubric.jsonevals/scenario-18/

{
  "context": "Evaluates whether the agent implements a correct S3 encryption enforcement policy that handles both inline encryption blocks on aws_s3_bucket and the separate aws_s3_bucket_server_side_encryption_configuration resource type, with a helper function to validate the algorithm.",
  "type": "weighted_checklist",
  "checklist": [
    {
      "name": "Deny on aws_s3_bucket without inline encryption",
      "description": "A deny rule triggers when an `aws_s3_bucket` is being created and `r.change.after.server_side_encryption_configuration` is absent or falsy",
      "max_score": 26
    },
    {
      "name": "Deny on separate encryption resource with invalid algorithm",
      "description": "A deny rule triggers when an `aws_s3_bucket_server_side_encryption_configuration` resource is created with an `sse_algorithm` that is not `\"AES256\"` or `\"aws:kms\"`",
      "max_score": 32
    },
    {
      "name": "Helper function for algorithm validation",
      "description": "The policy extracts the algorithm validation logic into a named helper function or rule (e.g. `encryption_algorithm_valid`) that iterates over the nested rule/encryption blocks",
      "max_score": 17
    },
    {
      "name": "Tests pass",
      "description": "All tests pass when running `opa test . -v`",
      "max_score": 25
    }
  ]
}

README.md

rules.md

tile.json