@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.
Files changed (151) hide show
  1. package/lib/actions/conversations.d.ts +14 -0
  2. package/lib/actions/conversations.js +333 -0
  3. package/lib/actions/dynamodb.js +155 -0
  4. package/lib/actions/email.js +177 -0
  5. package/lib/actions/files.js +319 -0
  6. package/lib/{data → actions}/groups.d.ts +4 -3
  7. package/lib/actions/groups.js +282 -0
  8. package/lib/actions/images.d.ts +22 -0
  9. package/lib/actions/images.js +682 -0
  10. package/lib/actions/index.js +40 -0
  11. package/lib/{data → actions}/ios.d.ts +2 -1
  12. package/lib/actions/ios.js +179 -0
  13. package/lib/actions/locations.js +112 -0
  14. package/lib/actions/messages.d.ts +13 -0
  15. package/lib/actions/messages.js +216 -0
  16. package/lib/{data → actions}/notifications.d.ts +2 -2
  17. package/lib/actions/notifications.js +63 -0
  18. package/lib/{data → actions}/payments.d.ts +2 -2
  19. package/lib/actions/payments.js +491 -0
  20. package/lib/actions/posts.d.ts +19 -0
  21. package/lib/actions/posts.js +538 -0
  22. package/lib/actions/reactions.d.ts +30 -0
  23. package/lib/actions/reactions.js +340 -0
  24. package/lib/{data → actions}/s3.d.ts +1 -1
  25. package/lib/actions/s3.js +122 -0
  26. package/lib/{data → actions}/search.d.ts +2 -2
  27. package/lib/actions/search.js +99 -0
  28. package/lib/actions/sms.js +76 -0
  29. package/lib/actions/statistics.d.ts +2 -0
  30. package/lib/actions/statistics.js +63 -0
  31. package/lib/actions/subscription.js +209 -0
  32. package/lib/actions/tags.d.ts +26 -0
  33. package/lib/actions/tags.js +340 -0
  34. package/lib/actions/users.d.ts +44 -0
  35. package/lib/actions/users.js +571 -0
  36. package/lib/{data → actions}/websockets.d.ts +1 -1
  37. package/lib/actions/websockets.js +156 -0
  38. package/lib/config.d.ts +2 -3
  39. package/lib/config.js +116 -149
  40. package/lib/index.d.ts +1 -1
  41. package/lib/index.js +23 -45
  42. package/lib/templates/email/layout.d.ts +2 -0
  43. package/lib/templates/email/layout.js +292 -0
  44. package/lib/templates/email/passwordForgot.d.ts +2 -0
  45. package/lib/templates/email/passwordForgot.js +28 -0
  46. package/lib/templates/email/passwordRecovery.d.ts +2 -0
  47. package/lib/templates/email/passwordRecovery.js +25 -0
  48. package/lib/templates/email/verifyEmail.d.ts +2 -0
  49. package/lib/templates/email/verifyEmail.js +28 -0
  50. package/lib/templates/email/welcome.d.ts +2 -0
  51. package/lib/templates/email/welcome.js +28 -0
  52. package/lib/templates/sms/passwordForgot.d.ts +2 -0
  53. package/lib/templates/sms/passwordForgot.js +14 -0
  54. package/lib/templates/sms/passwordRecovery.d.ts +2 -0
  55. package/lib/templates/sms/passwordRecovery.js +14 -0
  56. package/lib/templates/sms/verifyEmail.d.ts +2 -0
  57. package/lib/templates/sms/verifyEmail.js +14 -0
  58. package/lib/templates/sms/verifyPhone.d.ts +2 -0
  59. package/lib/templates/sms/verifyPhone.js +14 -0
  60. package/lib/templates/sms/welcome.d.ts +2 -0
  61. package/lib/templates/sms/welcome.js +14 -0
  62. package/lib/types/apps.d.ts +2 -2
  63. package/lib/types/apps.js +4 -2
  64. package/lib/types/arangodb.js +4 -2
  65. package/lib/types/auth.d.ts +4 -8
  66. package/lib/types/auth.js +4 -2
  67. package/lib/types/conversations.d.ts +3 -3
  68. package/lib/types/conversations.js +4 -2
  69. package/lib/types/email.d.ts +2 -2
  70. package/lib/types/email.js +4 -2
  71. package/lib/types/files.js +4 -2
  72. package/lib/types/google.js +4 -2
  73. package/lib/types/groups.d.ts +2 -1
  74. package/lib/types/groups.js +4 -2
  75. package/lib/types/images.d.ts +8 -5
  76. package/lib/types/images.js +4 -2
  77. package/lib/types/index.d.ts +1 -1
  78. package/lib/types/index.js +37 -227
  79. package/lib/types/locations.js +4 -2
  80. package/lib/types/messages.d.ts +12 -2
  81. package/lib/types/messages.js +4 -2
  82. package/lib/types/notifications.d.ts +2 -2
  83. package/lib/types/notifications.js +4 -2
  84. package/lib/types/payments.js +4 -2
  85. package/lib/types/posts.d.ts +18 -1
  86. package/lib/types/posts.js +4 -2
  87. package/lib/types/statistics.d.ts +3 -0
  88. package/lib/types/statistics.js +4 -0
  89. package/lib/types/tags.d.ts +6 -0
  90. package/lib/types/tags.js +4 -2
  91. package/lib/types/users.d.ts +15 -11
  92. package/lib/types/users.js +4 -2
  93. package/lib/utils/analytics.d.ts +7 -0
  94. package/lib/utils/analytics.js +101 -77
  95. package/lib/utils/arangodb.d.ts +1 -1
  96. package/lib/utils/arangodb.js +93 -114
  97. package/lib/utils/auth.js +58 -55
  98. package/lib/utils/graphql.js +38 -19
  99. package/lib/utils/index.d.ts +1 -1
  100. package/lib/utils/index.js +26 -84
  101. package/lib/utils/objects.js +44 -53
  102. package/lib/utils/session.d.ts +18 -0
  103. package/lib/utils/session.js +42 -0
  104. package/package.json +32 -30
  105. package/lib/data/conversations.d.ts +0 -8
  106. package/lib/data/conversations.js +0 -311
  107. package/lib/data/dynamodb.js +0 -206
  108. package/lib/data/email.js +0 -222
  109. package/lib/data/files.js +0 -525
  110. package/lib/data/groups.js +0 -435
  111. package/lib/data/images.d.ts +0 -22
  112. package/lib/data/images.js +0 -1051
  113. package/lib/data/index.js +0 -266
  114. package/lib/data/ios.js +0 -355
  115. package/lib/data/locations.js +0 -172
  116. package/lib/data/messages.d.ts +0 -9
  117. package/lib/data/messages.js +0 -299
  118. package/lib/data/notifications.js +0 -59
  119. package/lib/data/payments.js +0 -771
  120. package/lib/data/posts.d.ts +0 -23
  121. package/lib/data/posts.js +0 -766
  122. package/lib/data/reactions.d.ts +0 -14
  123. package/lib/data/reactions.js +0 -529
  124. package/lib/data/s3.js +0 -155
  125. package/lib/data/search.js +0 -155
  126. package/lib/data/sms.js +0 -83
  127. package/lib/data/subscription.js +0 -337
  128. package/lib/data/tags.d.ts +0 -14
  129. package/lib/data/tags.js +0 -397
  130. package/lib/data/users.d.ts +0 -20
  131. package/lib/data/users.js +0 -470
  132. package/lib/data/websockets.js +0 -250
  133. package/lib/types/reactions.d.ts +0 -17
  134. package/lib/types/reactions.js +0 -2
  135. package/lib/utils/redis.d.ts +0 -1
  136. package/lib/utils/redis.js +0 -36
  137. package/templates/email/layout.html +0 -279
  138. package/templates/email/passwordForgot.html +0 -15
  139. package/templates/email/passwordRecovery.html +0 -12
  140. package/templates/email/verifyEmail.html +0 -15
  141. package/templates/sms/passwordForgot.txt +0 -1
  142. package/templates/sms/passwordRecovery.txt +0 -1
  143. package/templates/sms/verifyEmail.txt +0 -1
  144. package/templates/sms/verifyPhone.txt +0 -1
  145. /package/lib/{data → actions}/dynamodb.d.ts +0 -0
  146. /package/lib/{data → actions}/email.d.ts +0 -0
  147. /package/lib/{data → actions}/files.d.ts +0 -0
  148. /package/lib/{data → actions}/index.d.ts +0 -0
  149. /package/lib/{data → actions}/locations.d.ts +0 -0
  150. /package/lib/{data → actions}/sms.d.ts +0 -0
  151. /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>;