-
Notifications
You must be signed in to change notification settings - Fork 807
/
policy.go
80 lines (65 loc) · 2.2 KB
/
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
68
69
70
71
72
73
74
75
76
77
78
79
80
/*
Copyright 2022 The KodeRover Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package types
// PolicyMetaScope resource scope for permission
type PolicyMetaScope string
const (
SystemScope PolicyMetaScope = "system"
ProjectScope PolicyMetaScope = "project"
DBProjectScope int = 1
DBSystemScope int = 2
)
type Policy struct {
Name string `json:"name"`
Description string `json:"description"`
UpdateTime int64 `json:"update_time"`
Rules []*Rule `json:"rules"`
}
type Rule struct {
Verbs []string `json:"verbs"`
Resources []string `json:"resources"`
Kind string `json:"kind"`
MatchAttributes []MatchAttribute `json:"match_attributes"`
}
type MatchAttribute struct {
Key string `json:"key"`
Value string `json:"value"`
}
type PolicyMeta struct {
Resource string `json:"resource"`
Alias string `json:"alias"`
Description string `json:"description"`
Rules []*RuleMeta `json:"rules"`
}
type RuleMeta struct {
Action string `json:"action"`
Alias string `json:"alias"`
Description string `json:"description"`
Rules []*ActionRule `json:"rules"`
}
type ActionRule struct {
Method string `json:"method"`
Endpoint string `json:"endpoint"`
ResourceType string `json:"resourceType,omitempty"`
IDRegex string `json:"idRegex,omitempty"`
MatchAttributes []*Attribute `json:"matchAttributes,omitempty"`
Filter bool `json:"filter,omitempty"`
}
type Attribute struct {
Key string `json:"key"`
Value string `json:"value"`
}
type PolicyRule struct {
Methods []string `json:"methods"`
Endpoint string `json:"endpoint"`
}