-
Notifications
You must be signed in to change notification settings - Fork 0
/
config.js
143 lines (143 loc) · 5.55 KB
/
config.js
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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
module.exports =
{
database:
{
engine: "mssql",
connectionString: process.env.CT_AQUILA_BLACKROCK_CONNSTRING
},
auth:
{
secretKey: process.env.CT_AQUILA_SECRETKEY,
salt: process.env.CT_AQUILA_SALT,
passwordReqs:
{
minLength: 8,
uppercaseChar: false,
lowercaseChar: false,
digitChar: false,
specialChar: false
}
},
storage:
{
provider: "azure",
azureStorageConnectionString: process.env.CT_BLUEHAVEN_CONNSTRING,
azureStorageContainerName: "aquila"
},
monitoring:
{
azureAppInsightsKey: process.env.APPINSIGHTS_INSTRUMENTATIONKEY
},
entities:
{
"task":
{
fields:
{
"name": { type: "string", isEditable: true, createReq: 2, foreignKey: null },
"date": { type: "int", isEditable: true, createReq: 2, foreignKey: null },
"recmode": { type: "int", isEditable: true, createReq: 1, foreignKey: null },
"recdays": { type: "string", isEditable: true, createReq: 1, foreignKey: null },
"recinterval": { type: "int", isEditable: true, createReq: 1, foreignKey: null },
"recend": { type: "int", isEditable: true, createReq: 1, foreignKey: null },
"recholes": { type: "string", isEditable: true, createReq: 0, foreignKey: null },
},
allowedRoles:
{
"read": ["owner", "admin"],
"create": ["member"],
"update": ["owner", "admin"],
"delete": ["owner", "admin"]
}
},
"plan":
{
fields:
{
"state": { type: "int", isEditable: true, createReq: 0, foreignKey: null },
"name": { type: "string", isEditable: true, createReq: 2, foreignKey: null },
"description": { type: "string", isEditable: true, createReq: 1, foreignKey: null },
},
allowedRoles:
{
"read": ["guest", "member", "owner", "admin"],
"create": ["member"],
"update": ["owner", "admin"],
"delete": ["owner", "admin"]
},
getReadCondition: function (roles, userId)
{
if (!roles.contains("owner") && !roles.contains("admin"))
return "state=2";
return "";
},
isWriteAllowed: function (action, roles, userId, dbResource, inputResource)
{
if (roles.contains("admin"))
return true;
if (roles.contains("owner"))
return (action === "update" && (!!n.state && n.state > o.state && n.state <= 2)) ||
(action === "delete" && o.state === 0);
return false;
}
},
"plantask":
{
fields:
{
"planid": { type: "int", isEditable: false, createReq: 2, foreignKey: { foreignEntity: "plan", resolvedKeyName: "plan" } },
"state": { type: "int", isEditable: true, createReq: 0, foreignKey: null },
"day": { type: "int", isEditable: true, createReq: 2, foreignKey: null },
"name": { type: "string", isEditable: true, createReq: 2, foreignKey: null },
"description": { type: "string", isEditable: true, createReq: 1, foreignKey: null },
},
allowedRoles:
{
"read": ["guest", "member", "owner", "admin"],
"create": ["member"],
"update": ["owner", "admin"],
"delete": ["owner", "admin"]
},
getReadCondition: function (roles, userId)
{
if (roles.contains("owner") || roles.contains("admin"))
return "";
return "state=2";
},
isWriteAllowed: function (action, roles, userId, dbResource, inputResource)
{
if (roles.contains("admin"))
return true;
if (roles.contains("owner"))
return (action === "update" && ((!!n.state && n.state > o.state && n.state <= 2) && (o.state === 0 || (n.day === o.day && n.name === o.name && n.description === o.description)))) ||
(action === "delete" && o.state === 0);
return false;
}
},
"planenrollment":
{
fields:
{
"planid": { type: "int", isEditable: false, createReq: 2, foreignKey: { foreignEntity: "plan", resolvedKeyName: "plan" } },
"startdate": { type: "int", isEditable: true, createReq: 2, foreignKey: null },
"completeddays": { type: "int", isEditable: true, createReq: 0, foreignKey: null },
},
unique: ["ownerid", "planid"],
allowedRoles:
{
"read": ["owner", "admin"],
"create": ["member"],
"update": ["owner", "admin"],
"delete": ["owner", "admin"]
},
isWriteAllowed: function (action, roles, userId, dbResource, inputResource)
{
if (roles.contains("owner") || roles.contains("admin"))
return true;
if (roles.contains("member"))
return (!!n.plan && n.plan.state > 0);
return false;
}
}
}
};