@nlabs/reaktor 0.4.0 → 0.4.1
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/lib/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +333 -0
- package/lib/actions/dynamodb.js +155 -0
- package/lib/actions/email.js +177 -0
- package/lib/actions/files.js +319 -0
- package/lib/{data → actions}/groups.d.ts +4 -3
- package/lib/actions/groups.js +282 -0
- package/lib/actions/images.d.ts +22 -0
- package/lib/actions/images.js +682 -0
- package/lib/actions/index.js +40 -0
- package/lib/{data → actions}/ios.d.ts +2 -1
- package/lib/actions/ios.js +179 -0
- package/lib/actions/locations.js +112 -0
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +216 -0
- package/lib/{data → actions}/notifications.d.ts +2 -2
- package/lib/actions/notifications.js +63 -0
- package/lib/{data → actions}/payments.d.ts +2 -2
- package/lib/actions/payments.js +491 -0
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +538 -0
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +340 -0
- package/lib/{data → actions}/s3.d.ts +1 -1
- package/lib/actions/s3.js +122 -0
- package/lib/{data → actions}/search.d.ts +2 -2
- package/lib/actions/search.js +99 -0
- package/lib/actions/sms.js +76 -0
- package/lib/actions/statistics.d.ts +2 -0
- package/lib/actions/statistics.js +63 -0
- package/lib/actions/subscription.js +209 -0
- package/lib/actions/tags.d.ts +26 -0
- package/lib/actions/tags.js +340 -0
- package/lib/actions/users.d.ts +44 -0
- package/lib/actions/users.js +571 -0
- package/lib/{data → actions}/websockets.d.ts +1 -1
- package/lib/actions/websockets.js +156 -0
- package/lib/config.d.ts +2 -3
- package/lib/config.js +116 -149
- package/lib/index.d.ts +1 -1
- package/lib/index.js +23 -45
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/layout.js +292 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordForgot.js +28 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.js +25 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/verifyEmail.js +28 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/email/welcome.js +28 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.js +14 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.js +14 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.js +14 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.js +14 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/templates/sms/welcome.js +14 -0
- package/lib/types/apps.d.ts +2 -2
- package/lib/types/apps.js +4 -2
- package/lib/types/arangodb.js +4 -2
- package/lib/types/auth.d.ts +4 -8
- package/lib/types/auth.js +4 -2
- package/lib/types/conversations.d.ts +3 -3
- package/lib/types/conversations.js +4 -2
- package/lib/types/email.d.ts +2 -2
- package/lib/types/email.js +4 -2
- package/lib/types/files.js +4 -2
- package/lib/types/google.js +4 -2
- package/lib/types/groups.d.ts +2 -1
- package/lib/types/groups.js +4 -2
- package/lib/types/images.d.ts +8 -5
- package/lib/types/images.js +4 -2
- package/lib/types/index.d.ts +1 -1
- package/lib/types/index.js +37 -227
- package/lib/types/locations.js +4 -2
- package/lib/types/messages.d.ts +12 -2
- package/lib/types/messages.js +4 -2
- package/lib/types/notifications.d.ts +2 -2
- package/lib/types/notifications.js +4 -2
- package/lib/types/payments.js +4 -2
- package/lib/types/posts.d.ts +18 -1
- package/lib/types/posts.js +4 -2
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +4 -0
- package/lib/types/tags.d.ts +6 -0
- package/lib/types/tags.js +4 -2
- package/lib/types/users.d.ts +15 -11
- package/lib/types/users.js +4 -2
- package/lib/utils/analytics.d.ts +7 -0
- package/lib/utils/analytics.js +101 -77
- package/lib/utils/arangodb.d.ts +1 -1
- package/lib/utils/arangodb.js +93 -114
- package/lib/utils/auth.js +58 -55
- package/lib/utils/graphql.js +38 -19
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +26 -84
- package/lib/utils/objects.js +44 -53
- package/lib/utils/session.d.ts +18 -0
- package/lib/utils/session.js +42 -0
- package/package.json +32 -30
- package/lib/data/conversations.d.ts +0 -8
- package/lib/data/conversations.js +0 -311
- package/lib/data/dynamodb.js +0 -206
- package/lib/data/email.js +0 -222
- package/lib/data/files.js +0 -525
- package/lib/data/groups.js +0 -435
- package/lib/data/images.d.ts +0 -22
- package/lib/data/images.js +0 -1051
- package/lib/data/index.js +0 -266
- package/lib/data/ios.js +0 -355
- package/lib/data/locations.js +0 -172
- package/lib/data/messages.d.ts +0 -9
- package/lib/data/messages.js +0 -299
- package/lib/data/notifications.js +0 -59
- package/lib/data/payments.js +0 -771
- package/lib/data/posts.d.ts +0 -23
- package/lib/data/posts.js +0 -766
- package/lib/data/reactions.d.ts +0 -14
- package/lib/data/reactions.js +0 -529
- package/lib/data/s3.js +0 -155
- package/lib/data/search.js +0 -155
- package/lib/data/sms.js +0 -83
- package/lib/data/subscription.js +0 -337
- package/lib/data/tags.d.ts +0 -14
- package/lib/data/tags.js +0 -397
- package/lib/data/users.d.ts +0 -20
- package/lib/data/users.js +0 -470
- package/lib/data/websockets.js +0 -250
- package/lib/types/reactions.d.ts +0 -17
- package/lib/types/reactions.js +0 -2
- package/lib/utils/redis.d.ts +0 -1
- package/lib/utils/redis.js +0 -36
- package/templates/email/layout.html +0 -279
- package/templates/email/passwordForgot.html +0 -15
- package/templates/email/passwordRecovery.html +0 -12
- package/templates/email/verifyEmail.html +0 -15
- package/templates/sms/passwordForgot.txt +0 -1
- package/templates/sms/passwordRecovery.txt +0 -1
- package/templates/sms/verifyEmail.txt +0 -1
- package/templates/sms/verifyPhone.txt +0 -1
- /package/lib/{data → actions}/dynamodb.d.ts +0 -0
- /package/lib/{data → actions}/email.d.ts +0 -0
- /package/lib/{data → actions}/files.d.ts +0 -0
- /package/lib/{data → actions}/index.d.ts +0 -0
- /package/lib/{data → actions}/locations.d.ts +0 -0
- /package/lib/{data → actions}/sms.d.ts +0 -0
- /package/lib/{data → actions}/subscription.d.ts +0 -0
|
@@ -0,0 +1,340 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defProps = Object.defineProperties;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
9
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
+
var __spreadValues = (a, b) => {
|
|
13
|
+
for (var prop in b || (b = {}))
|
|
14
|
+
if (__hasOwnProp.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
if (__getOwnPropSymbols)
|
|
17
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
+
if (__propIsEnum.call(b, prop))
|
|
19
|
+
__defNormalProp(a, prop, b[prop]);
|
|
20
|
+
}
|
|
21
|
+
return a;
|
|
22
|
+
};
|
|
23
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
25
|
+
var __export = (target, all) => {
|
|
26
|
+
__markAsModule(target);
|
|
27
|
+
for (var name in all)
|
|
28
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
29
|
+
};
|
|
30
|
+
var __reExport = (target, module2, desc) => {
|
|
31
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
32
|
+
for (let key of __getOwnPropNames(module2))
|
|
33
|
+
if (!__hasOwnProp.call(target, key) && key !== "default")
|
|
34
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
35
|
+
}
|
|
36
|
+
return target;
|
|
37
|
+
};
|
|
38
|
+
var __toModule = (module2) => {
|
|
39
|
+
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
40
|
+
};
|
|
41
|
+
__export(exports, {
|
|
42
|
+
addTag: () => addTag,
|
|
43
|
+
addTagToItem: () => addTagToItem,
|
|
44
|
+
createTag: () => createTag,
|
|
45
|
+
createTagEdge: () => createTagEdge,
|
|
46
|
+
deleteTag: () => deleteTag,
|
|
47
|
+
deleteTagFromItem: () => deleteTagFromItem,
|
|
48
|
+
extractTags: () => extractTags,
|
|
49
|
+
getTag: () => getTag,
|
|
50
|
+
getTags: () => getTags,
|
|
51
|
+
getTagsByItem: () => getTagsByItem,
|
|
52
|
+
getTagsByOwner: () => getTagsByOwner,
|
|
53
|
+
linkTags: () => linkTags,
|
|
54
|
+
updateTag: () => updateTag
|
|
55
|
+
});
|
|
56
|
+
var import_utils = __toModule(require("@nlabs/utils"));
|
|
57
|
+
var import_arangojs = __toModule(require("arangojs"));
|
|
58
|
+
var import_words = __toModule(require("lodash/words"));
|
|
59
|
+
var import_utils2 = __toModule(require("../utils"));
|
|
60
|
+
const eventCategory = "tags";
|
|
61
|
+
const getTags = (context, args) => {
|
|
62
|
+
const action = "getList";
|
|
63
|
+
const { database } = context;
|
|
64
|
+
const { search = "", from = 0, to = 30 } = args;
|
|
65
|
+
const limit = (0, import_utils2.getLimit)(from, to);
|
|
66
|
+
const filter = search.length ? `FILTER LIKE(t.name, "%${search}%")` : "";
|
|
67
|
+
const aqlQry = `FOR t IN tags
|
|
68
|
+
${filter}
|
|
69
|
+
${limit.aql}
|
|
70
|
+
SORT t.name
|
|
71
|
+
RETURN t`;
|
|
72
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_utils2.logError)({
|
|
73
|
+
action,
|
|
74
|
+
category: eventCategory,
|
|
75
|
+
label: "db_error"
|
|
76
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
77
|
+
};
|
|
78
|
+
const getTagsByItem = (context, itemId, args) => {
|
|
79
|
+
const action = "getList";
|
|
80
|
+
const { from = 0, to = 30 } = args;
|
|
81
|
+
const { database } = context;
|
|
82
|
+
const limit = (0, import_utils2.getLimit)(from, to);
|
|
83
|
+
const formatItemId = (0, import_utils.parseArangoId)(itemId);
|
|
84
|
+
const tagQuery = `FOR t, it IN INBOUND "${formatItemId}" isTagged
|
|
85
|
+
${limit.aql}
|
|
86
|
+
SORT it.added
|
|
87
|
+
RETURN t`;
|
|
88
|
+
return database.query(tagQuery).then((cursor) => cursor.all() || []).catch((error) => (0, import_utils2.logError)({
|
|
89
|
+
action,
|
|
90
|
+
category: eventCategory,
|
|
91
|
+
label: "db_error"
|
|
92
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
93
|
+
};
|
|
94
|
+
const getTagsByOwner = (context, args) => {
|
|
95
|
+
const action = "getList";
|
|
96
|
+
const { from = 0, id, to = 30 } = args;
|
|
97
|
+
const { database } = context;
|
|
98
|
+
const limit = (0, import_utils2.getLimit)(from, to);
|
|
99
|
+
const aqlQry = `FOR t IN tags
|
|
100
|
+
FILTER t.userId == "${id}"
|
|
101
|
+
${limit.aql}
|
|
102
|
+
SORT t.added
|
|
103
|
+
RETURN t`;
|
|
104
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_utils2.logError)({
|
|
105
|
+
action,
|
|
106
|
+
category: eventCategory,
|
|
107
|
+
label: "db_error"
|
|
108
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
109
|
+
};
|
|
110
|
+
const getTag = (context, tagId) => {
|
|
111
|
+
const action = "getItem";
|
|
112
|
+
const { database } = context;
|
|
113
|
+
const formatId = JSON.stringify((0, import_utils.parseId)(tagId));
|
|
114
|
+
const aqlQry = `FOR t IN tags
|
|
115
|
+
FILTER t._key == ${formatId}
|
|
116
|
+
LIMIT 1
|
|
117
|
+
RETURN t`;
|
|
118
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
|
|
119
|
+
action,
|
|
120
|
+
category: eventCategory,
|
|
121
|
+
label: "db_error"
|
|
122
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
123
|
+
};
|
|
124
|
+
const addTag = (context, { tag }) => {
|
|
125
|
+
const action = "addTag";
|
|
126
|
+
const { database, session } = context;
|
|
127
|
+
const { userAccess } = session;
|
|
128
|
+
if (userAccess < 3) {
|
|
129
|
+
return (0, import_utils2.logException)({
|
|
130
|
+
action,
|
|
131
|
+
category: eventCategory,
|
|
132
|
+
label: "db_error"
|
|
133
|
+
}, session);
|
|
134
|
+
}
|
|
135
|
+
const now = Date.now();
|
|
136
|
+
const { description, name } = tag;
|
|
137
|
+
const formatId = (0, import_utils.createHash)(`tag-${name.toLowercase()}`, null);
|
|
138
|
+
const insert = {
|
|
139
|
+
_key: formatId,
|
|
140
|
+
added: now,
|
|
141
|
+
description: (0, import_utils.parseVarChar)(description, 64),
|
|
142
|
+
modified: now,
|
|
143
|
+
name: (0, import_utils.parseVarChar)(name, 32)
|
|
144
|
+
};
|
|
145
|
+
const aqlQry = import_arangojs.aql`INSERT ${insert} IN tags RETURN NEW`;
|
|
146
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((tag2 = {}) => tag2).catch((error) => (0, import_utils2.logError)({
|
|
147
|
+
action,
|
|
148
|
+
category: eventCategory,
|
|
149
|
+
label: "db_error"
|
|
150
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
151
|
+
};
|
|
152
|
+
const addTagToItem = async (context, { itemId, tagId }) => {
|
|
153
|
+
const action = "addTagToItem";
|
|
154
|
+
const { database } = context;
|
|
155
|
+
const added = Date.now();
|
|
156
|
+
const formatTagId = (0, import_utils.parseArangoId)(tagId);
|
|
157
|
+
const formatItemId = (0, import_utils.parseArangoId)(itemId);
|
|
158
|
+
const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagId}-${formatItemId}`, null);
|
|
159
|
+
const edgeCollection = database.collection("isTagged");
|
|
160
|
+
const edge = { _from: formatTagId, _key: edgeId, _to: formatItemId, added };
|
|
161
|
+
console.log({ edge });
|
|
162
|
+
await edgeCollection.save(edge, { overwriteMode: "ignore", silent: true }).catch((error) => (0, import_utils2.logError)({
|
|
163
|
+
action,
|
|
164
|
+
category: eventCategory,
|
|
165
|
+
label: "db_error",
|
|
166
|
+
params: {
|
|
167
|
+
edge
|
|
168
|
+
}
|
|
169
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
170
|
+
const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${formatTagId}) RETURN t`;
|
|
171
|
+
return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
|
|
172
|
+
action,
|
|
173
|
+
category: eventCategory,
|
|
174
|
+
label: "db_error",
|
|
175
|
+
params: {
|
|
176
|
+
edge
|
|
177
|
+
}
|
|
178
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
179
|
+
};
|
|
180
|
+
const updateTag = (context, item = {}) => {
|
|
181
|
+
const action = "update";
|
|
182
|
+
const { database, session } = context;
|
|
183
|
+
const { userAccess } = session;
|
|
184
|
+
if (userAccess < 3) {
|
|
185
|
+
return (0, import_utils2.logException)({
|
|
186
|
+
action,
|
|
187
|
+
category: eventCategory,
|
|
188
|
+
label: "db_error"
|
|
189
|
+
}, session);
|
|
190
|
+
}
|
|
191
|
+
const now = Date.now();
|
|
192
|
+
const { description, id, name } = item;
|
|
193
|
+
const formatName = (0, import_utils.parseVarChar)(name, 32);
|
|
194
|
+
const update = {
|
|
195
|
+
description: (0, import_utils.parseVarChar)(description, 64),
|
|
196
|
+
modified: now,
|
|
197
|
+
name: formatName
|
|
198
|
+
};
|
|
199
|
+
const formatId = (0, import_utils.parseId)(id);
|
|
200
|
+
const tagId = !formatId ? (0, import_utils.createHash)(`tag-${formatName.toLowerCase()}`, null) : formatId;
|
|
201
|
+
const insert = __spreadProps(__spreadValues({}, update), {
|
|
202
|
+
_key: tagId,
|
|
203
|
+
added: now
|
|
204
|
+
});
|
|
205
|
+
const aqlQry = import_arangojs.aql`UPSERT {_key: ${tagId}}
|
|
206
|
+
INSERT ${insert}
|
|
207
|
+
UPDATE ${update}
|
|
208
|
+
IN tags RETURN NEW`;
|
|
209
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
|
|
210
|
+
action,
|
|
211
|
+
category: eventCategory,
|
|
212
|
+
label: "db_error"
|
|
213
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
214
|
+
};
|
|
215
|
+
const deleteTag = (context, { tagId }) => {
|
|
216
|
+
const action = "deleteTag";
|
|
217
|
+
const { database, session } = context;
|
|
218
|
+
const { userAccess } = session;
|
|
219
|
+
if (userAccess < 3) {
|
|
220
|
+
return (0, import_utils2.logException)({
|
|
221
|
+
action,
|
|
222
|
+
category: eventCategory,
|
|
223
|
+
label: "db_error"
|
|
224
|
+
}, session);
|
|
225
|
+
}
|
|
226
|
+
const formatTagId = (0, import_utils.parseId)(tagId);
|
|
227
|
+
const aqlQry = import_arangojs.aql`FOR t IN tags
|
|
228
|
+
FILTER t._key == ${formatTagId}
|
|
229
|
+
REMOVE t IN tags
|
|
230
|
+
RETURN OLD`;
|
|
231
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
|
|
232
|
+
action,
|
|
233
|
+
category: eventCategory,
|
|
234
|
+
label: "db_error"
|
|
235
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
236
|
+
};
|
|
237
|
+
const deleteTagFromItem = async (context, { itemId, tagId }) => {
|
|
238
|
+
const action = "deleteTagFromItem";
|
|
239
|
+
const { database } = context;
|
|
240
|
+
const formatTagId = (0, import_utils.parseArangoId)(tagId);
|
|
241
|
+
const formatItemId = (0, import_utils.parseArangoId)(itemId);
|
|
242
|
+
const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagId}-${formatItemId}`, null);
|
|
243
|
+
const edgeCollection = database.collection("isTagged");
|
|
244
|
+
const edge = { _key: edgeId };
|
|
245
|
+
await edgeCollection.remove(edge, { silent: true }).catch((error) => (0, import_utils2.logError)({
|
|
246
|
+
action,
|
|
247
|
+
category: eventCategory,
|
|
248
|
+
label: "db_error"
|
|
249
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
250
|
+
const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${tagId}) RETURN t`;
|
|
251
|
+
return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
|
|
252
|
+
action,
|
|
253
|
+
category: eventCategory,
|
|
254
|
+
label: "db_error"
|
|
255
|
+
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
256
|
+
};
|
|
257
|
+
const createTag = (db, tagName) => {
|
|
258
|
+
const tagId = (0, import_utils.createHash)(`tag-${tagName.toLowerCase()}`, null);
|
|
259
|
+
const insert = {
|
|
260
|
+
_key: tagId,
|
|
261
|
+
added: Date.now(),
|
|
262
|
+
name: tagName
|
|
263
|
+
};
|
|
264
|
+
const aqlQry = import_arangojs.aql`UPSERT {_key: ${tagId}}
|
|
265
|
+
INSERT ${insert}
|
|
266
|
+
UPDATE {}
|
|
267
|
+
IN tags RETURN NEW`;
|
|
268
|
+
return db.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => {
|
|
269
|
+
throw error;
|
|
270
|
+
});
|
|
271
|
+
};
|
|
272
|
+
const createTagEdge = (db, tag, itemId) => {
|
|
273
|
+
const edgeCollection = db.collection("isTagged");
|
|
274
|
+
const { _id: tagId } = tag;
|
|
275
|
+
const edgeId = (0, import_utils.createHash)(`isTagged-${tagId}-${itemId}`);
|
|
276
|
+
const type = itemId.split("/")[0];
|
|
277
|
+
const edge = {
|
|
278
|
+
_from: tagId,
|
|
279
|
+
_key: edgeId,
|
|
280
|
+
_to: itemId,
|
|
281
|
+
added: Date.now(),
|
|
282
|
+
type
|
|
283
|
+
};
|
|
284
|
+
return edgeCollection.save(edge, { returnNew: true }).then(() => tag);
|
|
285
|
+
};
|
|
286
|
+
const linkTags = async (db, tagNames, itemId) => {
|
|
287
|
+
const edgeCollection = db.collection("isTagged");
|
|
288
|
+
const edges = await edgeCollection.inEdges(itemId);
|
|
289
|
+
console.log({ edges });
|
|
290
|
+
if (edges.length) {
|
|
291
|
+
await Promise.all(edges.map((edge) => {
|
|
292
|
+
const { _key: edgeKey } = edge;
|
|
293
|
+
const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isTagged`;
|
|
294
|
+
return db.query(aqlQry);
|
|
295
|
+
}));
|
|
296
|
+
}
|
|
297
|
+
return Promise.all(tagNames.map((tagName) => createTag(db, tagName).then((tag) => createTagEdge(db, tag, itemId))));
|
|
298
|
+
};
|
|
299
|
+
const extractTags = (db, itemId, content) => {
|
|
300
|
+
const tags = (0, import_words.default)(content, /#[a-zA-Z\d-]+/g).map((tag) => (0, import_utils.parseId)(tag));
|
|
301
|
+
const edgeCollection = db.collection("isTagged");
|
|
302
|
+
return edgeCollection.inEdges(itemId).then((edges) => {
|
|
303
|
+
if (edges.length) {
|
|
304
|
+
return Promise.all(edges.map((edge) => {
|
|
305
|
+
const { _key: edgeKey } = edge;
|
|
306
|
+
const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isTagged`;
|
|
307
|
+
return db.query(aqlQry).catch((error) => {
|
|
308
|
+
throw error;
|
|
309
|
+
});
|
|
310
|
+
})).then(() => {
|
|
311
|
+
if (tags.length) {
|
|
312
|
+
return linkTags(db, tags, itemId);
|
|
313
|
+
}
|
|
314
|
+
return [];
|
|
315
|
+
});
|
|
316
|
+
} else if (tags.length) {
|
|
317
|
+
return linkTags(db, tags, itemId);
|
|
318
|
+
}
|
|
319
|
+
return [];
|
|
320
|
+
}).catch((error) => {
|
|
321
|
+
throw error;
|
|
322
|
+
});
|
|
323
|
+
};
|
|
324
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
325
|
+
0 && (module.exports = {
|
|
326
|
+
addTag,
|
|
327
|
+
addTagToItem,
|
|
328
|
+
createTag,
|
|
329
|
+
createTagEdge,
|
|
330
|
+
deleteTag,
|
|
331
|
+
deleteTagFromItem,
|
|
332
|
+
extractTags,
|
|
333
|
+
getTag,
|
|
334
|
+
getTags,
|
|
335
|
+
getTagsByItem,
|
|
336
|
+
getTagsByOwner,
|
|
337
|
+
linkTags,
|
|
338
|
+
updateTag
|
|
339
|
+
});
|
|
340
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/tags.ts"],
  "sourcesContent": ["import {createHash, parseArangoId, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport words from 'lodash/words';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {TagType} from '../types/tags';\nimport {getLimit, logError, logException} from '../utils';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nconst eventCategory: string = 'tags';\n\nexport const getTags = (\n  context: ApiContext,\n  args\n): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const {search = '', from = 0, to = 30} = args;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const filter: string = search.length ? `FILTER LIKE(t.name, \"%${search}%\")` : '';\n  const aqlQry: string = `FOR t IN tags\n    ${filter}\n    ${limit.aql}\n    SORT t.name\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTagsByItem = (context: ApiContext, itemId: string,  args): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {from = 0, to = 30} = args;\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const formatItemId: string = parseArangoId(itemId);\n\n  const tagQuery: string = `FOR t, it IN INBOUND \"${formatItemId}\" isTagged\n    ${limit.aql}\n    SORT it.added\n    RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.all() || [])\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTagsByOwner = (context: ApiContext, args): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {from = 0, id, to = 30} = args;\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR t IN tags\n    FILTER t.userId == \"${id}\"\n    ${limit.aql}\n    SORT t.added\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = JSON.stringify(parseId(tagId));\n  const aqlQry: string = `FOR t IN tags\n    FILTER t._key == ${formatId}\n    LIMIT 1\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTag = (context: ApiContext, {tag}): Promise<TagType> => {\n  const action: string = 'addTag';\n  const {database, session} = context;\n  const {userAccess} = session;\n\n  if(userAccess < 3) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, session);\n  }\n\n  const now: number = Date.now();\n  const {description, name} = tag;\n  const formatId: string = createHash(`tag-${name.toLowercase()}`, null);\n\n  const insert: any = {\n    _key: formatId,\n    added: now,\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: parseVarChar(name, 32)\n  };\n\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTagToItem = async (context: ApiContext, {itemId, tagId}): Promise<TagType> => {\n  const action: string = 'addTagToItem';\n  const {database} = context;\n  const added: number = Date.now();\n  const formatTagId: string = parseArangoId(tagId);\n  const formatItemId: string = parseArangoId(itemId);\n  const edgeId: string = createHash(`isTagged-${formatTagId}-${formatItemId}`, null);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const edge: any = {_from: formatTagId, _key: edgeId, _to: formatItemId, added};\n  console.log({edge});\n  await edgeCollection.save(edge, {overwriteMode: 'ignore', silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error',\n      params: {\n        edge\n      }\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${formatTagId}) RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error',\n      params: {\n        edge\n      }\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const updateTag = (context: ApiContext, item: TagType = {}): Promise<TagType> => {\n  const action: string = 'update';\n  const {database, session} = context;\n  const {userAccess} = session;\n\n  if(userAccess < 3) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, session);\n  }\n\n  const now: number = Date.now();\n  const {description, id, name} = item;\n  const formatName: string = parseVarChar(name, 32);\n\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n\n  const formatId: string = parseId(id);\n  const tagId: string = !formatId ? createHash(`tag-${formatName.toLowerCase()}`, null) : formatId;\n\n  const insert: TagType = {\n    ...update,\n    _key: tagId,\n    added: now\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTag = (context: ApiContext, {tagId}): Promise<TagType> => {\n  const action: string = 'deleteTag';\n  const {database, session} = context;\n  const {userAccess} = session;\n\n  if(userAccess < 3) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, session);\n  }\n\n  const formatTagId: string = parseId(tagId);\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER t._key == ${formatTagId}\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTagFromItem = async (context: ApiContext, {itemId, tagId}): Promise<TagType> => {\n  const action: string = 'deleteTagFromItem';\n  const {database} = context;\n  const formatTagId: string = parseArangoId(tagId);\n  const formatItemId: string = parseArangoId(itemId);\n  const edgeId: string = createHash(`isTagged-${formatTagId}-${formatItemId}`, null);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const edge: any = {_key: edgeId};\n\n  await edgeCollection.remove(edge, {silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${tagId}) RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const createTag = (db: Database, tagName: string): Promise<TagType> => {\n  const tagId: string = createHash(`tag-${tagName.toLowerCase()}`, null);\n  const insert: TagType = {\n    _key: tagId,\n    added: Date.now(),\n    name: tagName\n  };\n\n  const aqlQry = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN tags RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createTagEdge = (db: Database, tag: TagType, itemId: string): Promise<TagType> => {\n  const edgeCollection = db.collection('isTagged');\n  const {_id: tagId} = tag;\n  const edgeId = createHash(`isTagged-${tagId}-${itemId}`);\n  const type: string = itemId.split('/')[0];\n  const edge: any = {\n    _from: tagId,\n    _key: edgeId,\n    _to: itemId,\n    added: Date.now(),\n    type\n  };\n\n  return edgeCollection.save(edge, {returnNew: true}).then(() => tag);\n};\n\nexport const linkTags = async (db: Database, tagNames: string[], itemId: string): Promise<TagType[]> => {\n  const edgeCollection = db.collection('isTagged');\n  const edges: any = await edgeCollection.inEdges(itemId);\n\n  console.log({edges});\n  if(edges.length) {\n    await Promise.all(\n      edges.map((edge) => {\n        const {_key: edgeKey} = edge;\n        const aqlQry = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n        return db.query(aqlQry);\n      })\n    );\n  }\n\n  return Promise.all(tagNames.map((tagName: string) => createTag(db, tagName)\n    .then((tag: TagType) => createTagEdge(db, tag, itemId)))\n  );\n};\n\nexport const extractTags = (db: Database, itemId, content): Promise<TagType[]> => {\n  const tags: string[] = words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n  const edgeCollection = db.collection('isTagged');\n\n  return edgeCollection.inEdges(itemId)\n    .then((edges: any) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(tags.length) {\n              // Create tags\n              return linkTags(db, tags, itemId);\n            }\n            return [];\n          });\n      } else if(tags.length) {\n        // Create tags\n        return linkTags(db, tags, itemId);\n      }\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { ApiContext } from '../types/auth';
|
|
2
|
+
import { User } from '../types/users';
|
|
3
|
+
import { SessionError, SessionToken } from '../utils/session';
|
|
4
|
+
export interface UserOptions {
|
|
5
|
+
readonly from?: number;
|
|
6
|
+
readonly to?: number;
|
|
7
|
+
readonly username?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare enum UserAccess {
|
|
10
|
+
DEACTIVATED = 0,
|
|
11
|
+
ACTIVE = 1,
|
|
12
|
+
PREMIUM = 2,
|
|
13
|
+
CONTENT_ADMIN = 3,
|
|
14
|
+
ADMIN = 4
|
|
15
|
+
}
|
|
16
|
+
export declare const createToken: (userId: string, username: string, userAccess: number, expires?: number) => SessionToken;
|
|
17
|
+
export declare const getUserOptional: (fields?: string[]) => any;
|
|
18
|
+
export declare const parseUserOptions: (options?: UserOptions) => {
|
|
19
|
+
limit: import("..").ArangoDBLimit;
|
|
20
|
+
from?: number;
|
|
21
|
+
to?: number;
|
|
22
|
+
username?: string;
|
|
23
|
+
};
|
|
24
|
+
export declare const addUser: (context: ApiContext, args: any) => Promise<User>;
|
|
25
|
+
export declare const updateUser: (context: ApiContext, user: User) => Promise<any>;
|
|
26
|
+
export declare const confirmCode: (context: ApiContext, args: any) => Promise<boolean>;
|
|
27
|
+
export declare const deleteUser: (context: ApiContext, args: any) => Promise<any>;
|
|
28
|
+
export declare const deactivateUser: (context: ApiContext, userId: string) => Promise<User>;
|
|
29
|
+
export declare const getDisplayName: (user?: User) => string;
|
|
30
|
+
export declare const getSessionUser: (context: ApiContext) => Promise<User>;
|
|
31
|
+
export declare const getUser: (context: ApiContext, args: any) => Promise<User>;
|
|
32
|
+
export declare const getUsers: (context: ApiContext, options?: UserOptions) => Promise<User[]>;
|
|
33
|
+
export declare const getUsersByReactions: (context: ApiContext, { reactions, username }: any, options?: UserOptions) => Promise<User[]>;
|
|
34
|
+
export declare const getUsersByTags: (context: ApiContext, { tags, username }: any, options?: UserOptions) => Promise<User[]>;
|
|
35
|
+
export declare const getUsersByLatest: (context: ApiContext, { username }: {
|
|
36
|
+
username: any;
|
|
37
|
+
}, options?: UserOptions) => Promise<User[]>;
|
|
38
|
+
export declare const refreshSession: (context: ApiContext, { expires, token }: {
|
|
39
|
+
expires: any;
|
|
40
|
+
token: any;
|
|
41
|
+
}) => Promise<SessionToken | SessionError>;
|
|
42
|
+
export declare const signIn: (context: ApiContext, args: any) => Promise<SessionToken>;
|
|
43
|
+
export declare const signOut: (context: ApiContext, args: any) => Promise<boolean>;
|
|
44
|
+
export declare const getActiveUserCount: (context: ApiContext) => Promise<any>;
|