-
Notifications
You must be signed in to change notification settings - Fork 7
/
init.go
118 lines (112 loc) · 3.32 KB
/
init.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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package setup
import (
"github.com/apibrew/apibrew/pkg/model"
"github.com/apibrew/apibrew/pkg/resource_model"
"github.com/apibrew/apibrew/pkg/resource_model/system"
"github.com/apibrew/apibrew/pkg/resources"
)
func prepareInitData() *model.AppConfig {
return &model.AppConfig{
Host: "localhost",
Port: 17981,
DisableAuthentication: false,
DisableCache: true,
SystemDataSource: resource_model.DataSourceMapperInstance.ToRecord(prepareSystemDataSource()),
InitResources: prepareInitResources(),
InitRecords: prepareInitRecords(),
//ApplyPaths: []string{
// "../../tests/*.yml",
//},
}
}
func prepareInitRecords() []*model.InitRecord {
return []*model.InitRecord{
{
Namespace: resources.NamespaceResource.Namespace,
Resource: resources.NamespaceResource.Name,
Record: resource_model.NamespaceMapperInstance.ToRecord(&resource_model.Namespace{
Name: "default",
}),
},
{
Namespace: resources.RoleResource.Namespace,
Resource: resources.RoleResource.Name,
Record: resource_model.RoleMapperInstance.ToRecord(&resource_model.Role{
Name: "root",
Permissions: []*resource_model.Permission{
{
Operation: resource_model.PermissionOperation_FULL,
Permit: resource_model.PermissionPermit_ALLOW,
},
},
}),
},
{
Namespace: resources.RoleResource.Namespace,
Resource: resources.RoleResource.Name,
Record: resource_model.RoleMapperInstance.ToRecord(&resource_model.Role{
Name: "test_user",
Permissions: []*resource_model.Permission{
{
Namespace: &system.UserResourceModel.Namespace.Name,
Resource: &system.UserResourceModel.Name,
Operation: resource_model.PermissionOperation_READ,
Permit: resource_model.PermissionPermit_ALLOW,
},
{
Namespace: &system.NamespaceResourceModel.Namespace.Name,
Resource: &system.NamespaceResourceModel.Name,
Operation: resource_model.PermissionOperation_CREATE,
Permit: resource_model.PermissionPermit_ALLOW,
},
{
Namespace: &system.NamespaceResourceModel.Namespace.Name,
Resource: &system.NamespaceResourceModel.Name,
Operation: resource_model.PermissionOperation_READ,
Permit: resource_model.PermissionPermit_ALLOW,
},
},
}),
},
{
Namespace: resources.DataSourceResource.Namespace,
Resource: resources.DataSourceResource.Name,
Record: resource_model.DataSourceMapperInstance.ToRecord(DefaultDataSource),
},
{
Namespace: resources.UserResource.Namespace,
Resource: resources.UserResource.Name,
Record: resource_model.UserMapperInstance.ToRecord(&resource_model.User{
Username: "admin",
Password: strPointer("admin"),
Roles: []*resource_model.Role{
{
Name: "root",
},
},
}),
},
{
Namespace: resources.UserResource.Namespace,
Resource: resources.UserResource.Name,
Record: resource_model.UserMapperInstance.ToRecord(&resource_model.User{
Username: "dh_test",
Password: strPointer("dh_test"),
Roles: []*resource_model.Role{
{
Name: "test_user",
},
},
}),
},
}
}
func prepareInitResources() []*model.Resource {
return nil
}
func strPointer(s string) *string {
return &s
}
func prepareSystemDataSource() *resource_model.DataSource {
return SystemDataSource
}