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-12/

{
  "context": "Evaluates whether the agent implements a correct CloudFormation hook policy for S3 bucket access control. This tests the CloudFormation-specific input structure and response format, which is completely different from Terraform plan validation. Key patterns: main := {allow, violations} response object, uppercase action strings (\"CREATE\"/\"UPDATE\"), input.resource.properties.* for property access, and helper rules to decompose conditions.",
  "type": "weighted_checklist",
  "checklist": [
    {
      "name": "main response object",
      "description": "The policy defines `main := {\"allow\": count(deny) == 0, \"violations\": deny}` (or equivalent) as the top-level response object",
      "max_score": 15
    },
    {
      "name": "Uppercase action strings and CloudFormation input structure",
      "description": "The policy checks `input.action in {\"CREATE\", \"UPDATE\"}` (uppercase, not lowercase) and accesses properties via `input.resource.properties.*` and the resource ID via `input.resource.id`",
      "max_score": 20
    },
    {
      "name": "Helper rules for conditions",
      "description": "The policy uses helper rules (e.g. `bucket_create_or_update`, `bucket_is_private`, `block_public_acls`, `block_public_policy`) to decompose conditions rather than inlining all logic in the deny rules",
      "max_score": 15
    },
    {
      "name": "Three deny rules covering AccessControl and both BlockPublic settings",
      "description": "There are separate deny rules for: AccessControl != \"Private\", BlockPublicAcls != \"true\", and BlockPublicPolicy != \"true\"",
      "max_score": 25
    },
    {
      "name": "Tests pass",
      "description": "All tests pass when running `opa test . -v`",
      "max_score": 25
    }
  ]
}

README.md

rules.md

tile.json