-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit c9b8591
Showing
18 changed files
with
886 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
name: Build | ||
|
||
defaults: | ||
run: | ||
shell: bash | ||
|
||
on: | ||
push: | ||
branches: | ||
- '**' | ||
|
||
jobs: | ||
|
||
build_go: | ||
name: "🏗 Compile" | ||
|
||
runs-on: ubuntu-latest | ||
steps: | ||
- name: 🛒 Checkout Code | ||
uses: actions/checkout@v3 | ||
|
||
- name: 🚀 Set up Go | ||
uses: actions/setup-go@v4.1.0 | ||
with: | ||
go-version: '1.21.4' | ||
cache: true | ||
check-latest: true | ||
|
||
- name: 🧹 Tidy | ||
run: go mod tidy | ||
|
||
- name: 🤖 Build | ||
run: go build ./... |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
name: Lint | ||
|
||
defaults: | ||
run: | ||
shell: bash | ||
|
||
on: | ||
push: | ||
branches: | ||
- '**' | ||
|
||
jobs: | ||
|
||
lint-markdown: | ||
|
||
name: "🧹 Markdown" | ||
continue-on-error: true | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: 🛒 Checkout Code | ||
uses: actions/checkout@v3 | ||
|
||
- name: 📦 Install Node.js and npm | ||
uses: actions/setup-node@v3 | ||
with: | ||
node-version: '20.0.0' | ||
|
||
- name: 📚 Install markdownlint-cli | ||
run: npm install -g markdownlint-cli | ||
|
||
- name: 🖊️ Run markdownlint | ||
run: find . -name '*.md' -exec markdownlint {} + | ||
|
||
lint_go: | ||
name: "️️🕵️ Golang" | ||
|
||
runs-on: ubuntu-latest | ||
steps: | ||
- name: 🛒 Checkout Code | ||
uses: actions/checkout@v3 | ||
|
||
- name: 🚀 Set up Go | ||
uses: actions/setup-go@v4.1.0 | ||
with: | ||
cache: true | ||
check-latest: true | ||
|
||
- name: 🕵️♂️ Run GolangCI-Lint | ||
uses: golangci/golangci-lint-action@v3 | ||
with: | ||
version: v1.54 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
name: Test | ||
|
||
defaults: | ||
run: | ||
shell: bash | ||
|
||
on: | ||
push: | ||
branches: | ||
- '**' | ||
|
||
jobs: | ||
build: | ||
name: 🧪 Unit Tests | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v2 | ||
|
||
- name: Set up Go | ||
uses: actions/setup-go@v2 | ||
with: | ||
go-version: 1.21.4 | ||
|
||
- name: Set up gotestfmt | ||
run: go install github.com/gotesttools/gotestfmt/v2/cmd/gotestfmt@latest | ||
|
||
# Run tests with nice formatting. Save the original log in /tmp/gotest.log | ||
- name: 🧪 Execute Tests | ||
run: | | ||
set -euo pipefail | ||
go test -json -v ./... 2>&1 | tee /tmp/gotest.log | gotestfmt | ||
# Upload the original go test log as an artifact for later review. | ||
- name: Upload test log | ||
uses: actions/upload-artifact@v2 | ||
if: always() | ||
with: | ||
name: test-log | ||
path: /tmp/gotest.log | ||
if-no-files-found: error |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
.idea | ||
.DS_Store |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
# 🚀 Go Policy Enforcer | ||
|
||
data:image/s3,"s3://crabby-images/bc824/bc824d8651c4532e05cf3d196163fbab9b82ad16" alt="Golang" | ||
|
||
data:image/s3,"s3://crabby-images/a5269/a52695935c7c3cc8d313921f5d36ee9f8e06cfe1" alt="Build" | ||
data:image/s3,"s3://crabby-images/da4f5/da4f54ae3feaf1ef9b3a8b76a001b190dcbd5360" alt="Build" | ||
data:image/s3,"s3://crabby-images/6d57a/6d57a7a3afe6b6bc629538ecb20b7c85b6a0057b" alt="Build" | ||
[data:image/s3,"s3://crabby-images/ec349/ec349cf744cd199e538dbb77d93b7f6cfe9f3aed" alt="Go Report Card" | ||
|
||
if enforcer.Enforce(resource) { | ||
fmt.Println("Asset passes all policies") | ||
} else { | ||
fmt.Println("Asset failed one or more policies") | ||
} | ||
``` | ||
## ✅ Running Tests | ||
Run the following command to execute tests: | ||
```bash | ||
go test ./... | ||
``` | ||
## 📝 License | ||
This project is licensed under the MIT License. See the | ||
[LICENSE](./LICENSE) file for more details. |
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
package main | ||
|
||
type Asset struct { | ||
ID string `json:"id"` | ||
Type string `json:"type"` | ||
Finalized bool `json:"state"` | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
package main | ||
|
||
import ( | ||
"fmt" | ||
"log" | ||
|
||
gopolicyenforcer "github.com/kmesiab/go-policy-enforcer" | ||
) | ||
|
||
const ( | ||
finalizedPolicyExampleFile = "./example/policies/finalized_policy.json" | ||
idRequiredPolicyExampleFile = "./example/policies/id_required_policy.json" | ||
) | ||
|
||
func main() { | ||
|
||
// Load a few policies from JSON files (./policies folder) | ||
policyList, err := loadPolicies() | ||
if err != nil { | ||
|
||
log.Fatalf("error loading policies: %s", err) | ||
} | ||
|
||
// Create assets to test enforcement | ||
allowedAsset := &Asset{ID: "1", Type: "asset", Finalized: true} | ||
deniedAsset := &Asset{ID: "1", Type: "asset", Finalized: false} | ||
assetList := []*Asset{allowedAsset, deniedAsset} | ||
|
||
// Create a PolicyEnforcer instance with the policies | ||
e := gopolicyenforcer.NewPolicyEnforcer(policyList) | ||
|
||
// Enforce the policies on the assets and print results | ||
for _, asset := range assetList { | ||
if e.Enforce(asset) { | ||
fmt.Printf("Asset %v is allowed\n", asset) | ||
} else { | ||
fmt.Printf("Asset %v is not allowed\n", asset) | ||
} | ||
} | ||
|
||
} | ||
|
||
func loadPolicies() (*[]gopolicyenforcer.Policy, error) { | ||
|
||
finalizedPolicy, err := gopolicyenforcer.LoadPolicy(finalizedPolicyExampleFile) | ||
|
||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
idRequiredPolicy, err := gopolicyenforcer.LoadPolicy(idRequiredPolicyExampleFile) | ||
|
||
if err != nil { | ||
fmt.Println("Error loading policy:", err) | ||
|
||
} | ||
|
||
return &[]gopolicyenforcer.Policy{ | ||
*finalizedPolicy, | ||
*idRequiredPolicy, | ||
}, nil | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
{ | ||
"name": "FinalizedPolicy", | ||
"rules": [ | ||
{ | ||
"field": "finalized", | ||
"operator": "eq", | ||
"value": true | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
{ | ||
"name": "IdRequiredPolicy", | ||
"rules": [ | ||
{ | ||
"field": "id", | ||
"operator": ">", | ||
"value": 0 | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
module github.com/kmesiab/go-policy-enforcer | ||
|
||
go 1.23.2 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
package go_policy_enforcer | ||
|
||
// PolicyCheckOperator is a function type that accepts two values of any type | ||
// and returns a boolean result based on a comparison of the two values. | ||
type PolicyCheckOperator func(leftVal, rightVal any) bool | ||
|
||
// EqualsPolicyCheckOperator checks if two values are equal. | ||
// Returns true if leftVal is equal to rightVal. | ||
var EqualsPolicyCheckOperator = func(leftVal, rightVal any) bool { | ||
return leftVal == rightVal | ||
} | ||
|
||
// NotEqualsPolicyCheckOperator checks if two values are not equal. | ||
// Returns true if leftVal is not equal to rightVal. | ||
var NotEqualsPolicyCheckOperator = func(leftVal, rightVal any) bool { | ||
return leftVal != rightVal | ||
} | ||
|
||
// GreaterThanPolicyCheckOperator checks if the left value is greater than the right value. | ||
// Assumes both values are integers. Returns true if leftVal is greater than rightVal. | ||
var GreaterThanPolicyCheckOperator = func(leftVal, rightVal any) bool { | ||
return leftVal.(int) > rightVal.(int) | ||
} | ||
|
||
// GreaterThanOrEqualsPolicyCheckOperator checks if the left value is greater than or equal to the right value. | ||
// Assumes both values are integers. Returns true if leftVal is greater than or equal to rightVal. | ||
var GreaterThanOrEqualsPolicyCheckOperator = func(leftVal, rightVal any) bool { | ||
return leftVal.(int) >= rightVal.(int) | ||
} | ||
|
||
// LessThanPolicyCheckOperator checks if the left value is less than the right value. | ||
// Assumes both values are integers. Returns true if leftVal is less than rightVal. | ||
var LessThanPolicyCheckOperator = func(leftVal, rightVal any) bool { | ||
return leftVal.(int) < rightVal.(int) | ||
} | ||
|
||
// policyCheckOperatorMap maps string representations of comparison operators | ||
// to their corresponding PolicyCheckOperator functions. | ||
var policyCheckOperatorMap = map[string]PolicyCheckOperator{ | ||
"==": EqualsPolicyCheckOperator, | ||
"!=": NotEqualsPolicyCheckOperator, | ||
">": GreaterThanPolicyCheckOperator, | ||
">=": GreaterThanOrEqualsPolicyCheckOperator, | ||
"<": LessThanPolicyCheckOperator, | ||
} | ||
|
||
// GetPolicyCheckOperator retrieves the appropriate PolicyCheckOperator function | ||
// based on the provided operator string. | ||
func GetPolicyCheckOperator(operator string) PolicyCheckOperator { | ||
return policyCheckOperatorMap[operator] | ||
} | ||
|
||
// EvaluatePolicyCheckOperator takes a string operator, a left value, and a right value, | ||
// retrieves the corresponding PolicyCheckOperator function, and evaluates it with the given values. | ||
// Returns the result of the comparison as a boolean. | ||
func EvaluatePolicyCheckOperator(operator string, leftVal, rightVal any) bool { | ||
return GetPolicyCheckOperator(operator)(leftVal, rightVal) | ||
} |
Oops, something went wrong.