123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- package perm
- import (
- "crypto/md5"
- "encoding/json"
- "fmt"
- "strings"
- "github.com/ory/ladon"
- )
- type PolicyBuilder struct {
- policy *ladon.DefaultPolicy
- module string
- }
- func PolicyFor(subjects ...string) *PolicyBuilder {
- return &PolicyBuilder{
- policy: &ladon.DefaultPolicy{
- Subjects: subjects,
- },
- }
- }
- func (b *PolicyBuilder) Module(module string) (r *PolicyBuilder) {
- b.module = module
- return b
- }
- func (b *PolicyBuilder) ID(id string) (r *PolicyBuilder) {
- b.policy.ID = id
- return b
- }
- func (b *PolicyBuilder) WhoAre(effect string) (r *PolicyBuilder) {
- b.policy.Effect = effect
- return b
- }
- func (b *PolicyBuilder) ToDo(actions ...string) (r *PolicyBuilder) {
- b.policy.Actions = actions
- return b
- }
- func (b *PolicyBuilder) On(resources ...string) (r *PolicyBuilder) {
- if b.module == "" {
- b.policy.Resources = append(b.policy.Resources, resources...)
- return b
- }
- var newRes []string
- for _, res := range resources {
- newRes = append(newRes, strings.Join([]string{b.module, res}, ":"))
- }
- b.policy.Resources = append(b.policy.Resources, newRes...)
- return b
- }
- func (b *PolicyBuilder) Given(conditions Conditions) (r *PolicyBuilder) {
- b.policy.Conditions = conditions
- return b
- }
- func (b *PolicyBuilder) SetIDIfEmpty() {
- if b.policy.ID != "" {
- return
- }
- bs, err := json.Marshal(b.policy)
- if err != nil {
- panic(err)
- }
- b.policy.ID = fmt.Sprintf("%x", md5.Sum(bs))
- }
- func (b *PolicyBuilder) GetID() string {
- return b.policy.ID
- }
|