Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/koozz/opa-action
OPA Pull-Request Assessor; Automatically check your structured configuration data using Open Policy Agent.
https://github.com/koozz/opa-action
Last synced: 2 months ago
JSON representation
OPA Pull-Request Assessor; Automatically check your structured configuration data using Open Policy Agent.
- Host: GitHub
- URL: https://github.com/koozz/opa-action
- Owner: koozz
- License: apache-2.0
- Archived: true
- Created: 2021-06-18T18:20:53.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-12-24T09:08:28.000Z (about 3 years ago)
- Last Synced: 2024-10-31T10:49:41.036Z (3 months ago)
- Language: Shell
- Size: 34.2 KB
- Stars: 9
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-opa - OPA Action - OPA Pull-Request Assessor is a GitHub Action that checks files against policies configured in the same repo (Tools and Utilities / Testing Blogs and Articles)
README
# OPA-action
I contributed to open-policy-agent/conftest with
[GitHub flavored output](https://github.com/open-policy-agent/conftest/pull/586).Now you can simply [use Conftest directly](https://www.conftest.dev/options/#github)
which makes this action obsolete.```yaml
---
name: Confteston:
pull_request:
branches:
- mainjobs:
conftest:
runs-on: ubuntu-latest
container: openpolicyagent/conftest:latest
steps:
- name: Code checkout
uses: actions/checkout@v2
- name: Validate Kubernetes policy
run: |
conftest test -o github -p examples/kubernetes/policy examples/kubernetes/deployment.yaml
```The `-o github` will be responsible for annotating the files where policy violations
are found.## Archived readme
OPA stands for **O**PA **P**ull-Request **A**ssessor and is a GitHub Action that
checks files against policies (configured in the same repo). It's using the
original OPA ([Open Policy Agent](https://www.openpolicyagent.org/)) through the
use of [Conftest](https://conftest.dev).## Usage
Start using this OPA-action in three simple steps:
1. [Create your policies](#create-your-policies)
2. [Create a configuration](#create-a-configuration)
3. [Trigger GitHub Action](#trigger-github-action)### Create your policies
Create a folder (i.e. `policies`) with your policy files written in the Rego
language. For sample policies, check out the
[Conftest examples](https://github.com/open-policy-agent/conftest/tree/master/examples)
or write your own using [Rego](https://www.openpolicyagent.org/docs/latest/policy-language/),
the OPA Policy Language.### Create a configuration
Configure in either `.opa-action.yaml` or `.github/opa-action.yaml` where your
policy files can be found (`path`, the folder you created in the step before)
followed by pairs of files or filepatterns (`sources`) and the package/namespace
(`package`) the files should be tested against and optionally if this should not
fail the check (`no_fail`, default or absense means 'false' and will fail the
check on errors).```yaml
---
path: policy
rego:
- sources: "Dockerfile"
package: "docker"
no_fail: true
- sources: ".github/workflows/*.yml"
package: "workflows"
```### Trigger GitHub Action
Add the GitHub Action to your workflows, either on its own as a separate
workflow or add it as an action between the code checkout and the rest of your
existing workflow.```yaml
---
name: Policy checkon:
pull_request:
branches:
- mainjobs:
policy-check:
runs-on: ubuntu-latest
steps:
- name: Check out code
uses: actions/checkout@v2
- name: OPA Pull-Request Assessor
uses: koozz/opa-action@latest
```If your satisfied, follow best practices and pin the action to a specific
version.## License
Apache License, Version 2.0