not-node 6.4.9 → 6.4.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/fields/index.js +3 -3
- package/src/generic/manifest.js +146 -0
package/package.json
CHANGED
package/src/fields/index.js
CHANGED
|
@@ -151,7 +151,7 @@ module.exports.initManifestFields = (
|
|
|
151
151
|
.filter((key) => !privateFields.includes(key))
|
|
152
152
|
.forEach((key) => {
|
|
153
153
|
let mutation = getMutationForField(key, mutationsList);
|
|
154
|
-
if (mutation) {
|
|
154
|
+
if (mutation.length) {
|
|
155
155
|
list.push(mutation);
|
|
156
156
|
mutationsList.splice(mutationsList.indexOf(mutation), 1);
|
|
157
157
|
} else {
|
|
@@ -169,7 +169,7 @@ module.exports.initManifestFields = (
|
|
|
169
169
|
* Returns mutation tuple for a field or false
|
|
170
170
|
* @param {string} name field name
|
|
171
171
|
* @param {Array} list fields description lists
|
|
172
|
-
* @return {
|
|
172
|
+
* @return {Array<string|Object>}
|
|
173
173
|
*/
|
|
174
174
|
function getMutationForField(name, list) {
|
|
175
175
|
for (let item of list) {
|
|
@@ -177,7 +177,7 @@ function getMutationForField(name, list) {
|
|
|
177
177
|
return item;
|
|
178
178
|
}
|
|
179
179
|
}
|
|
180
|
-
return
|
|
180
|
+
return [];
|
|
181
181
|
}
|
|
182
182
|
module.exports.getMutationForField = getMutationForField;
|
|
183
183
|
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
const ACTION_SIGNATURES = require("../auth/const").ACTION_SIGNATURES;
|
|
2
|
+
|
|
3
|
+
const extraActionsBuilder = (
|
|
4
|
+
MODULE_NAME,
|
|
5
|
+
modelName,
|
|
6
|
+
FIELDS,
|
|
7
|
+
actionsBuilders = {}
|
|
8
|
+
) => {
|
|
9
|
+
const actions = {};
|
|
10
|
+
Object.keys(actionsBuilders).forEach((actionName) => {
|
|
11
|
+
actions[actionName] = actionsBuilders[actionName](
|
|
12
|
+
MODULE_NAME,
|
|
13
|
+
modelName,
|
|
14
|
+
FIELDS
|
|
15
|
+
);
|
|
16
|
+
});
|
|
17
|
+
return actions;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
const POST_FIX_RECORD_ID = "/:record[_id]";
|
|
21
|
+
const POST_FIX_ACTION_NAME = "/:actionName";
|
|
22
|
+
|
|
23
|
+
module.exports = (MODULE_NAME, modelName, FIELDS = [], actions = {}) => {
|
|
24
|
+
return {
|
|
25
|
+
model: modelName,
|
|
26
|
+
url: "/api/:modelName",
|
|
27
|
+
fields: FIELDS,
|
|
28
|
+
actions: {
|
|
29
|
+
//ключи это название действий
|
|
30
|
+
create: {
|
|
31
|
+
method: "PUT",
|
|
32
|
+
actionSignature: ACTION_SIGNATURES.CREATE,
|
|
33
|
+
data: ["data"],
|
|
34
|
+
rules: [
|
|
35
|
+
{
|
|
36
|
+
root: true,
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
title: `${MODULE_NAME}:${modelName}_form_create_title`,
|
|
40
|
+
},
|
|
41
|
+
update: {
|
|
42
|
+
method: "POST",
|
|
43
|
+
actionSignature: ACTION_SIGNATURES.UPDATE,
|
|
44
|
+
//добавка к url'у, вид такой :record[название поля без кавычек]
|
|
45
|
+
postFix: POST_FIX_RECORD_ID,
|
|
46
|
+
data: ["data"],
|
|
47
|
+
//должен быть авторизован или нет
|
|
48
|
+
formData: true,
|
|
49
|
+
//должен быть суперпользователем или нет
|
|
50
|
+
rules: [
|
|
51
|
+
{
|
|
52
|
+
root: true,
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
title: `${MODULE_NAME}:${modelName}_form_update_title`,
|
|
56
|
+
},
|
|
57
|
+
list: {
|
|
58
|
+
method: "GET",
|
|
59
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
60
|
+
data: ["pager", "sorter", "filter"],
|
|
61
|
+
rules: [
|
|
62
|
+
{
|
|
63
|
+
root: true,
|
|
64
|
+
},
|
|
65
|
+
],
|
|
66
|
+
},
|
|
67
|
+
listAndCount: {
|
|
68
|
+
method: "GET",
|
|
69
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
70
|
+
postFix: POST_FIX_ACTION_NAME,
|
|
71
|
+
data: ["pager", "sorter", "filter", "searcher", "return"],
|
|
72
|
+
rules: [
|
|
73
|
+
{
|
|
74
|
+
root: true,
|
|
75
|
+
},
|
|
76
|
+
],
|
|
77
|
+
},
|
|
78
|
+
listAll: {
|
|
79
|
+
method: "GET",
|
|
80
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
81
|
+
postFix: "/:actionName",
|
|
82
|
+
rules: [
|
|
83
|
+
{
|
|
84
|
+
root: true,
|
|
85
|
+
},
|
|
86
|
+
],
|
|
87
|
+
},
|
|
88
|
+
count: {
|
|
89
|
+
method: "GET",
|
|
90
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
91
|
+
postFix: POST_FIX_ACTION_NAME,
|
|
92
|
+
data: ["filter"],
|
|
93
|
+
rules: [
|
|
94
|
+
{
|
|
95
|
+
root: true,
|
|
96
|
+
},
|
|
97
|
+
],
|
|
98
|
+
},
|
|
99
|
+
get: {
|
|
100
|
+
method: "GET",
|
|
101
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
102
|
+
postFix: POST_FIX_RECORD_ID,
|
|
103
|
+
rules: [
|
|
104
|
+
{
|
|
105
|
+
root: true,
|
|
106
|
+
},
|
|
107
|
+
],
|
|
108
|
+
title: `${MODULE_NAME}:${modelName}_form_details_title`,
|
|
109
|
+
},
|
|
110
|
+
getByID: {
|
|
111
|
+
method: "GET",
|
|
112
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
113
|
+
postFix: `/:record[${modelName}ID]/:actionName`,
|
|
114
|
+
rules: [
|
|
115
|
+
{
|
|
116
|
+
root: true,
|
|
117
|
+
},
|
|
118
|
+
{
|
|
119
|
+
auth: false,
|
|
120
|
+
},
|
|
121
|
+
],
|
|
122
|
+
},
|
|
123
|
+
getRaw: {
|
|
124
|
+
method: "GET",
|
|
125
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
126
|
+
postFix: "/:record[_id]/:actionName",
|
|
127
|
+
rules: [
|
|
128
|
+
{
|
|
129
|
+
root: true,
|
|
130
|
+
},
|
|
131
|
+
],
|
|
132
|
+
},
|
|
133
|
+
delete: {
|
|
134
|
+
method: "DELETE",
|
|
135
|
+
actionSignature: ACTION_SIGNATURES.READ,
|
|
136
|
+
postFix: POST_FIX_RECORD_ID,
|
|
137
|
+
rules: [
|
|
138
|
+
{
|
|
139
|
+
root: true,
|
|
140
|
+
},
|
|
141
|
+
],
|
|
142
|
+
},
|
|
143
|
+
...extraActionsBuilder(MODULE_NAME, modelName, FIELDS, actions),
|
|
144
|
+
},
|
|
145
|
+
};
|
|
146
|
+
};
|