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

task.mdevals/scenario-31/

Regal: Testing Style — Authorization Policy with Tests

Write a Rego policy in the package api.authz that allows access based on role:

  • "admin" role → allow all methods
  • "viewer" role → allow GET only
  • Any other role → deny

Then write a test file for it following these conventions:

  • Test file named authz_test.rego with package api.authz_test
  • Import the policy package: import data.api.authz
  • Reference rules via the package alias: authz.allow
  • Give each test a unique, descriptive name
  • Test at least: admin allowed, viewer GET allowed, viewer POST denied, unknown role denied

Input

{"role": "admin", "method": "GET"}

Expected behaviour

  • admin + any method → allow
  • viewer + GET → allow
  • viewer + POST → deny
  • guest + GET → deny

README.md

rules.md

tile.json