feat: add JSON parsing support while keeping regex {field:value} (#21)

1 file changed
tree: b2597146424e968a1a0860b713e9f069dd50283c
  1. .github/
  2. cmd/
  3. test/
  4. .gitignore
  5. .golangci.yml
  6. .goreleaser.yaml
  7. .releaserc.json
  8. go.mod
  9. go.sum
  10. LICENSE
  11. main.go
  12. Makefile
  13. README.md
README.md

casbin-go-cli

Go Report Card Build Coverage Status Godoc Release Discord

casbin-go-cli is a command-line tool based on Casbin (Go language), enabling you to use all of Casbin APIs in the shell.

Installation

  1. Clone project from repository
git clone https://github.com/casbin/casbin-go-cli.git
  1. Build project
cd casbin-go-cli
go build -o casbin

Options

optionsdescriptionmust
-m, --modelThe path of the model file or model texty
-p, --policyThe path of the policy file or policy texty
enforceCheck permissionsn
enforceExCheck permissions and get which policy it isn

Get started

  • Check whether Alice has read permission on data1

    ./casbin enforce -m "test/basic_model.conf" -p "test/basic_policy.csv" "alice" "data1" "read"
    

    {“allow”:true,“explain”:[]}

  • Check whether Alice has write permission for data1 (with explanation)

    ./casbin enforceEx -m "test/basic_model.conf" -p "test/basic_policy.csv" "alice" "data1" "write"
    

    {“allow”:false,“explain”:[]}

  • Check whether Alice has read permission on data1 in domain1 (with explanation)

    ./casbin enforceEx -m "test/rbac_with_domains_model.conf" -p "test/rbac_with_domains_policy.csv" "alice" "domain1" "data1" "read"
    

    {“allow”:true,“explain”:[“admin”,“domain1”,“data1”,“read”]}