주요 콘텐츠로 건너뛰기

Get Started

설치

go get github.com/casbin/casbin/v2

Casbin 강제자 새로 만들기

Casbin은 접근 제어 모델을 정의하는 데 구성 파일을 사용합니다.

model.confpolicy.csv 두 가지 구성 파일이 있습니다. model.conf는 접근 모델을 저장하고, policy.csv는 특정 사용자 권한 구성을 저장합니다. Casbin의 사용법은 매우 간단합니다. 우리는 단지 하나의 주요 구조체를 만들 필요가 있습니다: 강제자. 이 구조체를 구성할 때, model.confpolicy.csv가 로드됩니다.

다시 말해, Casbin 강제자를 만들려면 ModelAdapter를 제공해야 합니다.

Casbin은 사용할 수 있는 FileAdapter를 제공합니다. 자세한 정보는 Adapter를 참조하세요.

import "github.com/casbin/casbin/v2"

e, err := casbin.NewEnforcer("path/to/model.conf", "path/to/policy.csv")
  • 다른 Adapter와 함께 Model 텍스트 사용:
import (
"log"

"github.com/casbin/casbin/v2"
"github.com/casbin/casbin/v2/model"
xormadapter "github.com/casbin/xorm-adapter/v2"
_ "github.com/go-sql-driver/mysql"
)

// Initialize a Xorm adapter with MySQL database.
a, err := xormadapter.NewAdapter("mysql", "mysql_username:mysql_password@tcp(127.0.0.1:3306)/")
if err != nil {
log.Fatalf("error: adapter: %s", err)
}

m, err := model.NewModelFromString(`
[request_definition]
r = sub, obj, act

[policy_definition]
p = sub, obj, act

[policy_effect]
e = some(where (p.eft == allow))

[matchers]
m = r.sub == p.sub && r.obj == p.obj && r.act == p.act
`)
if err != nil {
log.Fatalf("error: model: %s", err)
}

e, err := casbin.NewEnforcer(m, a)
if err != nil {
log.Fatalf("error: enforcer: %s", err)
}

권한 확인

접근이 발생하기 직전에 코드에 강제 훅을 추가하세요:

sub := "alice" // the user that wants to access a resource.
obj := "data1" // the resource that is going to be accessed.
act := "read" // the operation that the user performs on the resource.

ok, err := e.Enforce(sub, obj, act)

if err != nil {
// handle err
}

if ok == true {
// permit alice to read data1
} else {
// deny the request, show an error
}

// You could use BatchEnforce() to enforce some requests in batches.
// This method returns a bool slice, and this slice's index corresponds to the row index of the two-dimensional array.
// e.g. results[0] is the result of {"alice", "data1", "read"}
results, err := e.BatchEnforce([][]interface{}{{"alice", "data1", "read"}, {"bob", "data2", "write"}, {"jack", "data3", "read"}})

Casbin은 런타임에서 권한 관리를 위한 API도 제공합니다. 예를 들어, 아래와 같이 사용자에게 할당된 모든 역할을 얻을 수 있습니다:

roles, err := e.GetRolesForUser("alice")

더 많은 사용법은 Management APIRBAC API를 참조하세요.

더 많은 사용법은 테스트 케이스를 참조하세요.