-
Notifications
You must be signed in to change notification settings - Fork 124
/
principal_policy.go
67 lines (50 loc) · 1.9 KB
/
principal_policy.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// Copyright 2021-2024 Zenauth Ltd.
// SPDX-License-Identifier: Apache-2.0
package principalpolicy
import (
"github.com/alecthomas/kong"
"github.com/cerbos/cerbos/cmd/cerbosctl/get/internal/flagset"
cmdpolicy "github.com/cerbos/cerbos/cmd/cerbosctl/get/internal/policy"
"github.com/cerbos/cerbos/cmd/cerbosctl/internal/client"
"github.com/cerbos/cerbos/internal/policy"
)
const help = `# List principal policies
cerbosctl get principal_policies
cerbosctl get principal_policy
cerbosctl get pp
# List and filter principal policies
cerbosctl get principal_policies --name donald_duck
# List and sort principal policies by column
cerbosctl get principal_policies --sort-by policyId
cerbosctl get principal_policies --sort-by name
cerbosctl get principal_policies --sort-by version
# Get principal policy definition (disk, git, blob stores)
cerbosctl get principal_policies donald_duck.yaml
# Get principal policy definition (mutable stores)
cerbosctl get principal_policies principal.donald_duck.default
# Get principal policy definition as yaml
cerbosctl get principal_policies principal.donald_duck.default -oyaml
# Get principal policy definition as json
cerbosctl get principal_policies principal.donald_duck.default -ojson
# Get principal policy definition as pretty json
cerbosctl get principal_policies principal.donald_duck.default -oprettyjson`
type Cmd struct {
flagset.Format
flagset.Sort
flagset.Filters
}
func (c *Cmd) Run(k *kong.Kong, ctx *client.Context) error {
return cmdpolicy.DoCmd(k, ctx.AdminClient, policy.PrincipalKind, &c.Filters, &c.Format, &c.Sort, c.PolicyIDs)
}
func (c *Cmd) Validate() error {
if err := c.Filters.Validate(policy.PrincipalKind, len(c.PolicyIDs) == 0); err != nil {
return err
}
if err := c.Format.Validate(len(c.PolicyIDs) == 0); err != nil {
return err
}
return c.Sort.Validate(policy.PrincipalKind, len(c.PolicyIDs) == 0)
}
func (c *Cmd) Help() string {
return help
}