@nlabs/reaktor 0.8.0 → 0.9.0

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 (198) hide show
  1. package/.eslintrc +10 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +1 -1
  4. package/coverage/actions/groups.ts.html +1039 -0
  5. package/coverage/actions/images.ts.html +2500 -0
  6. package/coverage/actions/index.html +131 -0
  7. package/coverage/actions/tags.ts.html +1000 -0
  8. package/coverage/adapters/arangoAdapter.ts.html +151 -0
  9. package/coverage/adapters/index.html +146 -0
  10. package/coverage/adapters/reaktorAdapter.ts.html +127 -0
  11. package/coverage/adapters/tagAdapter.ts.html +160 -0
  12. package/coverage/base.css +224 -0
  13. package/coverage/block-navigation.js +87 -0
  14. package/coverage/clover.xml +6 -0
  15. package/coverage/coverage-final.json +1 -0
  16. package/coverage/favicon.png +0 -0
  17. package/coverage/index.html +176 -0
  18. package/coverage/lcov-report/base.css +224 -0
  19. package/coverage/lcov-report/block-navigation.js +87 -0
  20. package/coverage/lcov-report/favicon.png +0 -0
  21. package/coverage/lcov-report/index.html +101 -0
  22. package/coverage/lcov-report/prettify.css +1 -0
  23. package/coverage/lcov-report/prettify.js +2 -0
  24. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  25. package/coverage/lcov-report/sorter.js +196 -0
  26. package/coverage/lcov.info +0 -0
  27. package/coverage/mocks/file.ts.html +118 -0
  28. package/coverage/mocks/group.ts.html +145 -0
  29. package/coverage/mocks/image.ts.html +136 -0
  30. package/coverage/mocks/index.html +146 -0
  31. package/coverage/mocks/post.ts.html +169 -0
  32. package/coverage/mocks/tag.ts.html +121 -0
  33. package/coverage/mocks/user.ts.html +268 -0
  34. package/coverage/prettify.css +1 -0
  35. package/coverage/prettify.js +2 -0
  36. package/coverage/sort-arrow-sprite.png +0 -0
  37. package/coverage/sorter.js +196 -0
  38. package/coverage/types/error.ts.html +145 -0
  39. package/coverage/types/index.html +116 -0
  40. package/coverage/utils/adapterUtils.ts.html +151 -0
  41. package/coverage/utils/analyticsUtils.ts.html +292 -0
  42. package/coverage/utils/arangodbUtils.ts.html +463 -0
  43. package/coverage/utils/index.html +146 -0
  44. package/jest.setup.js +0 -0
  45. package/jpg:- +0 -0
  46. package/lib/actions/apps.d.ts +25 -0
  47. package/lib/actions/apps.js +252 -0
  48. package/lib/actions/conversations.d.ts +14 -0
  49. package/lib/actions/conversations.js +131 -126
  50. package/lib/actions/dynamodb.d.ts +8 -0
  51. package/lib/actions/dynamodb.js +35 -32
  52. package/lib/actions/email.d.ts +5 -0
  53. package/lib/actions/email.js +23 -53
  54. package/lib/actions/files.d.ts +19 -0
  55. package/lib/actions/files.js +188 -202
  56. package/lib/actions/groups.d.ts +14 -0
  57. package/lib/actions/groups.js +38 -36
  58. package/lib/actions/images.d.ts +26 -0
  59. package/lib/actions/images.js +236 -229
  60. package/lib/actions/index.d.ts +21 -0
  61. package/lib/actions/index.js +3 -1
  62. package/lib/actions/ios.d.ts +7 -0
  63. package/lib/actions/ios.js +11 -10
  64. package/lib/actions/locations.d.ts +5 -0
  65. package/lib/actions/locations.js +29 -37
  66. package/lib/actions/messages.d.ts +13 -0
  67. package/lib/actions/messages.js +10 -10
  68. package/lib/actions/notifications.d.ts +5 -0
  69. package/lib/actions/notifications.js +1 -1
  70. package/lib/actions/payments.d.ts +10 -0
  71. package/lib/actions/payments.js +27 -26
  72. package/lib/actions/posts.d.ts +19 -0
  73. package/lib/actions/posts.js +176 -156
  74. package/lib/actions/reactions.d.ts +30 -0
  75. package/lib/actions/reactions.js +30 -28
  76. package/lib/actions/s3.d.ts +7 -0
  77. package/lib/actions/s3.js +37 -32
  78. package/lib/actions/search.d.ts +3 -0
  79. package/lib/actions/search.js +11 -9
  80. package/lib/actions/sms.d.ts +3 -0
  81. package/lib/actions/sms.js +58 -34
  82. package/lib/actions/statistics.d.ts +3 -0
  83. package/lib/actions/statistics.js +21 -18
  84. package/lib/actions/subscription.d.ts +7 -0
  85. package/lib/actions/subscription.js +24 -21
  86. package/lib/actions/tags.d.ts +29 -0
  87. package/lib/actions/tags.js +129 -198
  88. package/lib/actions/users.d.ts +47 -0
  89. package/lib/actions/users.js +188 -194
  90. package/lib/actions/websockets.d.ts +19 -0
  91. package/lib/actions/websockets.js +60 -34
  92. package/lib/adapters/arangoAdapter.d.ts +2 -0
  93. package/lib/adapters/arangoAdapter.js +46 -0
  94. package/lib/adapters/fileAdapter.d.ts +3 -0
  95. package/lib/adapters/fileAdapter.js +76 -0
  96. package/lib/adapters/postAdapter.d.ts +2 -0
  97. package/lib/adapters/postAdapter.js +70 -0
  98. package/lib/adapters/reaktorAdapter.d.ts +6 -0
  99. package/lib/adapters/reaktorAdapter.js +44 -0
  100. package/lib/adapters/tagAdapter.d.ts +2 -0
  101. package/lib/adapters/tagAdapter.js +50 -0
  102. package/lib/adapters/userAdapter.d.ts +2 -0
  103. package/lib/adapters/userAdapter.js +110 -0
  104. package/lib/config.d.ts +20 -0
  105. package/lib/config.js +14 -15
  106. package/lib/index.d.ts +5 -0
  107. package/lib/lambdas/actions/websockets.d.ts +6 -0
  108. package/lib/lambdas/actions/websockets.js +7 -7
  109. package/lib/lambdas/authorizer.d.ts +20 -0
  110. package/lib/lambdas/authorizer.js +1 -1
  111. package/lib/lambdas/connection.d.ts +12 -0
  112. package/lib/lambdas/connection.js +5 -4
  113. package/lib/lambdas/utils/message.d.ts +1 -0
  114. package/lib/lambdas/utils/websocket.d.ts +7 -0
  115. package/lib/lambdas/utils/websocket.js +8 -6
  116. package/lib/mocks/conversation.d.ts +8 -0
  117. package/lib/mocks/conversation.js +35 -0
  118. package/lib/mocks/file.d.ts +11 -0
  119. package/lib/mocks/file.js +38 -0
  120. package/lib/mocks/group.d.ts +17 -0
  121. package/lib/mocks/group.js +47 -0
  122. package/lib/mocks/image.d.ts +3 -0
  123. package/lib/mocks/image.js +43 -0
  124. package/lib/mocks/nlabs.png +0 -0
  125. package/lib/mocks/post.d.ts +38 -0
  126. package/lib/mocks/post.js +55 -0
  127. package/lib/mocks/tag.d.ts +2 -0
  128. package/lib/mocks/tag.js +37 -0
  129. package/lib/mocks/user.d.ts +4 -0
  130. package/lib/mocks/user.js +88 -0
  131. package/lib/templates/email/layout.d.ts +2 -0
  132. package/lib/templates/email/passwordForgot.d.ts +2 -0
  133. package/lib/templates/email/passwordRecovery.d.ts +2 -0
  134. package/lib/templates/email/verifyEmail.d.ts +2 -0
  135. package/lib/templates/email/welcome.d.ts +2 -0
  136. package/lib/templates/sms/passwordForgot.d.ts +2 -0
  137. package/lib/templates/sms/passwordRecovery.d.ts +2 -0
  138. package/lib/templates/sms/verifyEmail.d.ts +2 -0
  139. package/lib/templates/sms/verifyPhone.d.ts +2 -0
  140. package/lib/templates/sms/welcome.d.ts +2 -0
  141. package/lib/types/apps.d.ts +46 -0
  142. package/lib/types/apps.js +17 -1
  143. package/lib/types/arangodb.d.ts +30 -0
  144. package/lib/types/arangodb.js +1 -1
  145. package/lib/types/auth.d.ts +7 -0
  146. package/lib/types/auth.js +1 -1
  147. package/lib/types/connections.d.ts +7 -0
  148. package/lib/types/connections.js +1 -1
  149. package/lib/types/conversations.d.ts +29 -0
  150. package/lib/types/conversations.js +1 -1
  151. package/lib/types/email.d.ts +13 -0
  152. package/lib/types/email.js +1 -1
  153. package/lib/types/error.d.ts +20 -0
  154. package/lib/types/error.js +44 -0
  155. package/lib/types/files.d.ts +26 -0
  156. package/lib/types/files.js +1 -1
  157. package/lib/types/google.d.ts +29 -0
  158. package/lib/types/google.js +1 -1
  159. package/lib/types/groups.d.ts +21 -0
  160. package/lib/types/groups.js +1 -1
  161. package/lib/types/images.d.ts +51 -0
  162. package/lib/types/images.js +1 -1
  163. package/lib/types/index.d.ts +18 -0
  164. package/lib/types/locations.d.ts +20 -0
  165. package/lib/types/locations.js +1 -1
  166. package/lib/types/messages.d.ts +16 -0
  167. package/lib/types/messages.js +1 -1
  168. package/lib/types/notifications.d.ts +17 -0
  169. package/lib/types/notifications.js +1 -1
  170. package/lib/types/payments.d.ts +112 -0
  171. package/lib/types/payments.js +1 -1
  172. package/lib/types/posts.d.ts +31 -0
  173. package/lib/types/posts.js +1 -1
  174. package/lib/types/statistics.d.ts +3 -0
  175. package/lib/types/statistics.js +1 -1
  176. package/lib/types/tags.d.ts +10 -0
  177. package/lib/types/tags.js +1 -1
  178. package/lib/types/users.d.ts +76 -0
  179. package/lib/types/users.js +1 -1
  180. package/lib/types/websocket.d.ts +13 -0
  181. package/lib/types/websocket.js +1 -1
  182. package/lib/utils/adapterUtils.d.ts +1 -0
  183. package/lib/utils/adapterUtils.js +45 -0
  184. package/lib/utils/analyticsUtils.d.ts +21 -0
  185. package/lib/utils/analyticsUtils.js +72 -0
  186. package/lib/utils/arangodbUtils.d.ts +65 -0
  187. package/lib/utils/arangodbUtils.js +144 -0
  188. package/lib/utils/auth.d.ts +20 -0
  189. package/lib/utils/auth.js +13 -30
  190. package/lib/utils/index.d.ts +5 -0
  191. package/lib/utils/index.js +7 -9
  192. package/lib/utils/session.d.ts +16 -0
  193. package/lib/utils/session.js +11 -2
  194. package/package.json +12 -5
  195. package/lib/utils/analytics.js +0 -88
  196. package/lib/utils/arangodb.js +0 -118
  197. package/lib/utils/graphql.js +0 -46
  198. package/lib/utils/objects.js +0 -59
@@ -29,101 +29,100 @@ var tags_exports = {};
29
29
  __export(tags_exports, {
30
30
  addTag: () => addTag,
31
31
  addTagToItem: () => addTagToItem,
32
- createTag: () => createTag,
33
- createTagEdge: () => createTagEdge,
34
32
  deleteTag: () => deleteTag,
35
33
  deleteTagFromItem: () => deleteTagFromItem,
36
34
  extractTags: () => extractTags,
37
35
  getTag: () => getTag,
38
36
  getTags: () => getTags,
39
37
  getTagsByItem: () => getTagsByItem,
40
- getTagsByOwner: () => getTagsByOwner,
41
- linkTags: () => linkTags,
42
- updateTag: () => updateTag
38
+ getTagsByName: () => getTagsByName,
39
+ updateTag: () => updateTag,
40
+ updateTagsInItem: () => updateTagsInItem
43
41
  });
44
42
  module.exports = __toCommonJS(tags_exports);
45
43
  var import_utils = require("@nlabs/utils");
46
44
  var import_arangojs = require("arangojs");
47
45
  var import_words = __toESM(require("lodash/words"));
48
- var import_utils2 = require("../utils");
46
+ var import_tagAdapter = require("../adapters/tagAdapter");
47
+ var import_error = require("../types/error");
48
+ var import_analyticsUtils = require("../utils/analyticsUtils");
49
+ var import_arangodbUtils = require("../utils/arangodbUtils");
49
50
  const eventCategory = "tags";
50
- const getTags = (context, options) => {
51
+ const getTags = (context, options = {}) => {
51
52
  const action = "getList";
52
53
  const { database } = context;
53
- const { search = "", from = 0, to = 30 } = options;
54
- const limit = (0, import_utils2.getLimit)(from, to);
55
- const filter = search.length ? `FILTER LIKE(t.name, "%${search}%")` : "";
54
+ const { search = "", from = 0, to = 30, userId } = options;
55
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
56
+ const filters = [];
57
+ if (search) {
58
+ filters.push(`LIKE(t.name, "%${search}%")`);
59
+ }
60
+ if (userId) {
61
+ filters.push(`t.userId == "${userId}"`);
62
+ }
56
63
  const aqlQry = `FOR t IN tags
57
- ${filter}
64
+ FILTER ${filters.join(" || ")}
58
65
  ${limit.aql}
59
66
  SORT t.name
60
67
  RETURN t`;
61
- return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_utils2.logError)({
68
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
62
69
  action,
63
70
  category: eventCategory,
64
- label: "db_error"
65
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
71
+ value: import_error.ErrorTypes.DATABASE_ERROR
72
+ }, error, {}));
66
73
  };
67
- const getTagsByItem = (context, itemId, args) => {
68
- const action = "getList";
69
- const { from = 0, to = 30 } = args;
74
+ const getTagsByItem = (context, itemDocId, options = {}) => {
75
+ const action = "getTagsByItem";
76
+ const { from = 0, to = 30 } = options;
70
77
  const { database } = context;
71
- const limit = (0, import_utils2.getLimit)(from, to);
72
- const formatItemId = (0, import_utils.parseArangoId)(itemId);
78
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
79
+ const formatItemId = (0, import_utils.parseArangoId)(itemDocId);
73
80
  const tagQuery = `FOR t, it IN INBOUND "${formatItemId}" isTagged
74
81
  ${limit.aql}
75
82
  SORT it.added
76
83
  RETURN t`;
77
- return database.query(tagQuery).then((cursor) => cursor.all() || []).catch((error) => (0, import_utils2.logError)({
84
+ return database.query(tagQuery).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
78
85
  action,
79
86
  category: eventCategory,
80
- label: "db_error"
81
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
87
+ value: import_error.ErrorTypes.DATABASE_ERROR
88
+ }, error, {}));
82
89
  };
83
- const getTagsByOwner = (context, args) => {
84
- const action = "getList";
85
- const { from = 0, id, to = 30 } = args;
90
+ const getTag = (context, tagId) => {
91
+ const action = "getTag";
86
92
  const { database } = context;
87
- const limit = (0, import_utils2.getLimit)(from, to);
93
+ const formatId = (0, import_utils.parseId)(tagId);
88
94
  const aqlQry = `FOR t IN tags
89
- FILTER t.userId == "${id}"
90
- ${limit.aql}
91
- SORT t.added
95
+ FILTER t._key == "${formatId}"
96
+ LIMIT 1
92
97
  RETURN t`;
93
- return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_utils2.logError)({
98
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
94
99
  action,
95
100
  category: eventCategory,
96
- label: "db_error"
97
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
101
+ value: import_error.ErrorTypes.DATABASE_ERROR
102
+ }, error, {}));
98
103
  };
99
- const getTag = (context, tagId) => {
100
- const action = "getItem";
104
+ const getTagsByName = (context, tagNames) => {
105
+ const action = "getTagsByName";
101
106
  const { database } = context;
102
- const formatId = JSON.stringify((0, import_utils.parseId)(tagId));
103
- const aqlQry = `FOR t IN tags
104
- FILTER t._key == ${formatId}
105
- LIMIT 1
107
+ const formatTagNames = tagNames.map((tagName) => (0, import_utils.parseVarChar)(tagName, 32)).filter((tagName) => !!tagName);
108
+ if (!formatTagNames.length) {
109
+ return Promise.resolve([]);
110
+ }
111
+ const aqlQry = import_arangojs.aql`FOR t IN tags
112
+ FILTER POSITION(${JSON.stringify(formatTagNames)}, t.name)
106
113
  RETURN t`;
107
- return database.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
114
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
108
115
  action,
109
116
  category: eventCategory,
110
- label: "db_error"
111
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
117
+ value: import_error.ErrorTypes.DATABASE_ERROR
118
+ }, error, {}));
112
119
  };
113
- const addTag = (context, { tag }) => {
120
+ const addTag = (context, tag) => {
114
121
  const action = "addTag";
115
- const { database, session } = context;
116
- const { userAccess } = session;
117
- if (userAccess < 3) {
118
- return (0, import_utils2.logException)({
119
- action,
120
- category: eventCategory,
121
- label: "db_error"
122
- }, session);
123
- }
122
+ const { database } = context;
124
123
  const now = Date.now();
125
- const { description, name } = tag;
126
- const formatId = (0, import_utils.createHash)(`tag-${name.toLowercase()}`, null);
124
+ const { description, name } = (0, import_tagAdapter.parseTag)(tag);
125
+ const formatId = (0, import_utils.createHash)(`tag-${name.toLowerCase()}`, null);
127
126
  const insert = {
128
127
  _key: formatId,
129
128
  added: now,
@@ -132,205 +131,137 @@ const addTag = (context, { tag }) => {
132
131
  name: (0, import_utils.parseVarChar)(name, 32)
133
132
  };
134
133
  const aqlQry = import_arangojs.aql`INSERT ${insert} IN tags RETURN NEW`;
135
- return database.query(aqlQry).then((cursor) => cursor.next()).then((tag2 = {}) => tag2).catch((error) => (0, import_utils2.logError)({
134
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
136
135
  action,
137
136
  category: eventCategory,
138
- label: "db_error"
139
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
137
+ value: import_error.ErrorTypes.DATABASE_ERROR
138
+ }, error, {}));
140
139
  };
141
- const addTagToItem = async (context, { itemId, tagId }) => {
140
+ const addTagToItem = async (context, { itemDocId, tagBy, tagDocId }) => {
142
141
  const action = "addTagToItem";
143
- const { database } = context;
142
+ const { database, session: { userId: sessionId } } = context;
144
143
  const added = Date.now();
145
- const formatTagId = (0, import_utils.parseArangoId)(tagId);
146
- const formatItemId = (0, import_utils.parseArangoId)(itemId);
147
- const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagId}-${formatItemId}`, null);
144
+ const formatTagDocId = (0, import_utils.parseArangoId)(tagDocId);
145
+ const formatItemDocId = (0, import_utils.parseArangoId)(itemDocId);
146
+ const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagDocId}-${formatItemDocId}`, null);
148
147
  const edgeCollection = database.collection("isTagged");
149
- const edge = { _from: formatTagId, _key: edgeId, _to: formatItemId, added };
150
- console.log({ edge });
151
- await edgeCollection.save(edge, { overwriteMode: "ignore", silent: true }).catch((error) => (0, import_utils2.logError)({
148
+ const type = formatItemDocId.split("/")[0];
149
+ const formatTagBy = (0, import_utils.parseId)(tagBy) || sessionId;
150
+ const edge = { _from: formatTagDocId, _key: edgeId, _to: formatItemDocId, added, tagBy: formatTagBy, type };
151
+ await edgeCollection.save(edge, { overwriteMode: "ignore", returnNew: true, silent: true }).catch((error) => (0, import_analyticsUtils.logError)({
152
152
  action,
153
153
  category: eventCategory,
154
- label: "db_error",
155
154
  params: {
156
155
  edge
157
- }
158
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
159
- const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${formatTagId}) RETURN t`;
160
- return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
156
+ },
157
+ value: import_error.ErrorTypes.DATABASE_ERROR
158
+ }, error, {}));
159
+ const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${formatTagDocId}) RETURN t`;
160
+ return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
161
161
  action,
162
162
  category: eventCategory,
163
- label: "db_error",
164
163
  params: {
165
164
  edge
166
- }
167
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
165
+ },
166
+ value: import_error.ErrorTypes.DATABASE_ERROR
167
+ }, error, {}));
168
168
  };
169
- const updateTag = (context, item = {}) => {
170
- const action = "update";
171
- const { database, session } = context;
172
- const { userAccess } = session;
173
- if (userAccess < 3) {
174
- return (0, import_utils2.logException)({
175
- action,
176
- category: eventCategory,
177
- label: "db_error"
178
- }, session);
179
- }
169
+ const updateTag = (context, tag) => {
170
+ const action = "updateTag";
171
+ const { database, session: { userId: sessionId } } = context;
180
172
  const now = Date.now();
181
- const { description, id, name } = item;
173
+ const { description, name, tagId } = (0, import_tagAdapter.parseTag)(tag);
182
174
  const formatName = (0, import_utils.parseVarChar)(name, 32);
183
175
  const update = {
184
176
  description: (0, import_utils.parseVarChar)(description, 64),
185
177
  modified: now,
186
178
  name: formatName
187
179
  };
188
- const formatId = (0, import_utils.parseId)(id);
189
- const tagId = !formatId ? (0, import_utils.createHash)(`tag-${formatName.toLowerCase()}`, null) : formatId;
180
+ const newTagKey = tagId || (0, import_utils.createHash)(`tag-${formatName.toLowerCase()}`, null);
190
181
  const insert = {
191
182
  ...update,
192
- _key: tagId,
193
- added: now
183
+ _id: `tags/${newTagKey}`,
184
+ _key: newTagKey,
185
+ added: now,
186
+ tagBy: sessionId
194
187
  };
195
- const aqlQry = import_arangojs.aql`UPSERT {_key: ${tagId}}
188
+ const aqlQry = import_arangojs.aql`UPSERT {name: ${formatName}}
196
189
  INSERT ${insert}
197
190
  UPDATE ${update}
198
191
  IN tags RETURN NEW`;
199
- return database.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
192
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
200
193
  action,
201
194
  category: eventCategory,
202
- label: "db_error"
203
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
195
+ value: import_error.ErrorTypes.DATABASE_ERROR
196
+ }, error, {}));
204
197
  };
205
- const deleteTag = (context, { tagId }) => {
198
+ const deleteTag = async (context, tag) => {
206
199
  const action = "deleteTag";
207
- const { database, session } = context;
208
- const { userAccess } = session;
209
- if (userAccess < 3) {
210
- return (0, import_utils2.logException)({
211
- action,
212
- category: eventCategory,
213
- label: "db_error"
214
- }, session);
215
- }
216
- const formatTagId = (0, import_utils.parseId)(tagId);
217
- const aqlQry = import_arangojs.aql`FOR t IN tags
218
- FILTER t._key == ${formatTagId}
200
+ const { database } = context;
201
+ const formatItemId = (0, import_arangodbUtils.getDocId)("tags", tag);
202
+ const tagQuery = `FOR it FROM isTagged
203
+ FILTER it._from == "${formatItemId}" || it._to == "${formatItemId}"
204
+ REMOVE it IN isTagged
205
+ RETURN OLD`;
206
+ await database.query(tagQuery).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
207
+ action,
208
+ category: eventCategory,
209
+ value: import_error.ErrorTypes.DATABASE_ERROR
210
+ }, error, {}));
211
+ const aqlQry = `LET t = DOCUMENT(${formatItemId})
219
212
  REMOVE t IN tags
220
213
  RETURN OLD`;
221
- return database.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
214
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
222
215
  action,
223
216
  category: eventCategory,
224
- label: "db_error"
225
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
217
+ value: import_error.ErrorTypes.DATABASE_ERROR
218
+ }, error, {}));
226
219
  };
227
- const deleteTagFromItem = async (context, { itemId, tagId }) => {
220
+ const deleteTagFromItem = async (context, { tagDocId, edgeDocId }) => {
228
221
  const action = "deleteTagFromItem";
229
222
  const { database } = context;
230
- const formatTagId = (0, import_utils.parseArangoId)(tagId);
231
- const formatItemId = (0, import_utils.parseArangoId)(itemId);
232
- const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagId}-${formatItemId}`, null);
223
+ const formatTagDocId = (0, import_utils.parseArangoId)(tagDocId);
224
+ const formatEdgeDocId = (0, import_utils.parseArangoId)(edgeDocId);
233
225
  const edgeCollection = database.collection("isTagged");
234
- const edge = { _key: edgeId };
235
- await edgeCollection.remove(edge, { silent: true }).catch((error) => (0, import_utils2.logError)({
226
+ const edge = { _id: formatEdgeDocId };
227
+ await edgeCollection.remove(edge, { silent: true }).catch((error) => (0, import_analyticsUtils.logError)({
236
228
  action,
237
229
  category: eventCategory,
238
- label: "db_error"
239
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
240
- const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${tagId}) RETURN t`;
241
- return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
230
+ value: import_error.ErrorTypes.DATABASE_ERROR
231
+ }, error, {}));
232
+ const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${formatTagDocId}) RETURN t`;
233
+ return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
242
234
  action,
243
235
  category: eventCategory,
244
- label: "db_error"
245
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
246
- };
247
- const createTag = (db, tagName) => {
248
- const tagId = (0, import_utils.createHash)(`tag-${tagName.toLowerCase()}`, null);
249
- const insert = {
250
- _key: tagId,
251
- added: Date.now(),
252
- name: tagName
253
- };
254
- const aqlQry = import_arangojs.aql`UPSERT {_key: ${tagId}}
255
- INSERT ${insert}
256
- UPDATE {}
257
- IN tags RETURN NEW`;
258
- return db.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => {
259
- throw error;
260
- });
261
- };
262
- const createTagEdge = (db, tag, itemId) => {
263
- const edgeCollection = db.collection("isTagged");
264
- const { _id: tagId } = tag;
265
- const edgeId = (0, import_utils.createHash)(`isTagged-${tagId}-${itemId}`);
266
- const type = itemId.split("/")[0];
267
- const edge = {
268
- _from: tagId,
269
- _key: edgeId,
270
- _to: itemId,
271
- added: Date.now(),
272
- type
273
- };
274
- return edgeCollection.save(edge, { returnNew: true }).then(() => tag);
275
- };
276
- const linkTags = async (db, tagNames, itemId) => {
277
- const edgeCollection = db.collection("isTagged");
278
- const edges = await edgeCollection.inEdges(itemId, {});
279
- console.log({ edges });
280
- if (edges.length) {
281
- await Promise.all(
282
- edges.map((edge) => {
283
- const { _key: edgeKey } = edge;
284
- const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isTagged`;
285
- return db.query(aqlQry);
286
- })
287
- );
288
- }
289
- return Promise.all(
290
- tagNames.map((tagName) => createTag(db, tagName).then((tag) => createTagEdge(db, tag, itemId)))
291
- );
236
+ value: import_error.ErrorTypes.DATABASE_ERROR
237
+ }, error, {}));
292
238
  };
293
- const extractTags = (db, itemId, content) => {
294
- const tags = (0, import_words.default)(content, /#[a-zA-Z\d-]+/g).map((tag) => (0, import_utils.parseId)(tag));
295
- const edgeCollection = db.collection("isTagged");
296
- return edgeCollection.inEdges(itemId, {}).then((edges) => {
297
- if (edges.length) {
298
- return Promise.all(
299
- edges.map((edge) => {
300
- const { _key: edgeKey } = edge;
301
- const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isTagged`;
302
- return db.query(aqlQry).catch((error) => {
303
- throw error;
304
- });
305
- })
306
- ).then(() => {
307
- if (tags.length) {
308
- return linkTags(db, tags, itemId);
309
- }
310
- return [];
311
- });
312
- } else if (tags.length) {
313
- return linkTags(db, tags, itemId);
314
- }
315
- return [];
316
- }).catch((error) => {
317
- throw error;
318
- });
239
+ const extractTags = (content) => (0, import_words.default)(content, /#[a-zA-Z\d-]+/g).map((tag) => (0, import_utils.parseId)(tag));
240
+ const updateTagsInItem = (context, { itemDocId, tags }) => {
241
+ const action = "updateTagsInItem";
242
+ const { database } = context;
243
+ const edgeCollection = database.collection("isTagged");
244
+ return edgeCollection.inEdges(itemDocId, {}).then((edges) => Promise.all([
245
+ ...edges.filter(({ name: existingTagName }) => !tags.find(({ name: tagName }) => existingTagName === tagName)).map(({ _id: edgeDocId, _from: tagDocId }) => deleteTagFromItem(context, { tagDocId, edgeDocId })),
246
+ ...tags.filter(({ name: tagName }) => !edges.find(({ name: existingTagName }) => existingTagName === tagName)).map(({ _id: tagDocId, tagBy }) => addTagToItem(context, { itemDocId, tagBy, tagDocId }))
247
+ ]).then(() => tags)).catch((error) => (0, import_analyticsUtils.logError)({
248
+ action,
249
+ category: eventCategory,
250
+ value: import_error.ErrorTypes.DATABASE_ERROR
251
+ }, error, {}));
319
252
  };
320
253
  // Annotate the CommonJS export names for ESM import in node:
321
254
  0 && (module.exports = {
322
255
  addTag,
323
256
  addTagToItem,
324
- createTag,
325
- createTagEdge,
326
257
  deleteTag,
327
258
  deleteTagFromItem,
328
259
  extractTags,
329
260
  getTag,
330
261
  getTags,
331
262
  getTagsByItem,
332
- getTagsByOwner,
333
- linkTags,
334
- updateTag
263
+ getTagsByName,
264
+ updateTag,
265
+ updateTagsInItem
335
266
  });
336
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/tags.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {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\nconst eventCategory: string = 'tags';\nexport interface TagOptions {\n  readonly search?: string;\n  readonly from?: number;\n  readonly to?: number;\n}\n\nexport const getTags = (\n  context: ApiContext,\n  options?: TagOptions\n): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const {search = '', from = 0, to = 30} = options;\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": ["import_utils", "error", "tag", "words"]
}

267
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/tags.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseArangoId, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {Edge} from 'arangojs/documents';\nimport words from 'lodash/words';\n\nimport {parseTag} from '../adapters/tagAdapter';\nimport type {ArangoDbLimit} from '../types/arangodb';\nimport type {ApiContext} from '../types/auth';\nimport {ErrorTypes} from '../types/error';\nimport type {TagType} from '../types/tags';\nimport {logError} from '../utils/analyticsUtils';\nimport {getDocId, getLimit} from '../utils/arangodbUtils';\n\nconst eventCategory: string = 'tags';\nexport interface TagOptions {\n  readonly from?: number;\n  readonly search?: string;\n  readonly to?: number;\n  readonly userId?: string;\n}\n\nexport const getTags = (\n  context: ApiContext,\n  options: TagOptions = {}\n): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const {search = '', from = 0, to = 30, userId} = options;\n  const limit: ArangoDbLimit = getLimit(from, to);\n\n  const filters: string[] = [];\n\n  if(search) {\n    filters.push(`LIKE(t.name, \"%${search}%\")`);\n  }\n\n  if(userId) {\n    filters.push(`t.userId == \"${userId}\"`);\n  }\n\n  const aqlQry: string = `FOR t IN tags\n    FILTER ${filters.join(' || ')}\n    ${limit.aql}\n    SORT t.name\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const getTagsByItem = (\n  context: ApiContext,\n  itemDocId: string,\n  options: TagOptions = {}\n): Promise<TagType[]> => {\n  const action: string = 'getTagsByItem';\n  const {from = 0, to = 30} = options;\n  const {database} = context;\n  const limit: ArangoDbLimit = getLimit(from, to);\n  const formatItemId: string = parseArangoId(itemDocId);\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      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getTag';\n  const {database} = context;\n  const formatId: string = 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    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const getTagsByName = (context: ApiContext, tagNames: string[]): Promise<TagType[]> => {\n  const action: string = 'getTagsByName';\n  const {database} = context;\n  const formatTagNames = tagNames\n    .map((tagName) => parseVarChar(tagName, 32))\n    .filter((tagName) => !!tagName);\n\n  if(!formatTagNames.length) {\n    return Promise.resolve([]);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER POSITION(${JSON.stringify(formatTagNames)}, t.name)\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const addTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'addTag';\n  const {database} = context;\n  const now: number = Date.now();\n  const {description, name} = parseTag(tag);\n  const formatId: string = createHash(`tag-${name.toLowerCase()}`, null);\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  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const addTagToItem = async (\n  context: ApiContext,\n  {itemDocId, tagBy, tagDocId}: {itemDocId: string, tagBy?: string, tagDocId: string}\n): Promise<TagType> => {\n  const action: string = 'addTagToItem';\n  const {database, session: {userId: sessionId}} = context;\n  const added: number = Date.now();\n  const formatTagDocId: string = parseArangoId(tagDocId);\n  const formatItemDocId: string = parseArangoId(itemDocId);\n  const edgeId: string = createHash(`isTagged-${formatTagDocId}-${formatItemDocId}`, null);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const type: string = formatItemDocId.split('/')[0];\n  const formatTagBy: string = parseId(tagBy) || sessionId;\n  const edge: Edge = {_from: formatTagDocId, _key: edgeId, _to: formatItemDocId, added, tagBy: formatTagBy, type};\n\n  await edgeCollection.save(edge, {overwriteMode: 'ignore', returnNew: true, silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      params: {\n        edge\n      },\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${formatTagDocId}) 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      params: {\n        edge\n      },\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const updateTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'updateTag';\n  const {database, session: {userId: sessionId}} = context;\n  const now: number = Date.now();\n  const {description, name, tagId} = parseTag(tag);\n  const formatName: string = parseVarChar(name, 32);\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n  const newTagKey: string = tagId || createHash(`tag-${formatName.toLowerCase()}`, null);\n  const insert: TagType = {\n    ...update,\n    _id: `tags/${newTagKey}`,\n    _key: newTagKey,\n    added: now,\n    tagBy: sessionId\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {name: ${formatName}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const deleteTag = async (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'deleteTag';\n  const {database} = context;\n  const formatItemId = getDocId('tags', tag);\n  const tagQuery: string = `FOR it FROM isTagged\n    FILTER it._from == \"${formatItemId}\" || it._to == \"${formatItemId}\"\n    REMOVE it IN isTagged\n    RETURN OLD`;\n\n  await database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n\n  const aqlQry = `LET t = DOCUMENT(${formatItemId})\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const deleteTagFromItem = async (context: ApiContext, {tagDocId, edgeDocId}): Promise<TagType> => {\n  const action = 'deleteTagFromItem';\n  const {database} = context;\n  const formatTagDocId = parseArangoId(tagDocId);\n  const formatEdgeDocId = parseArangoId(edgeDocId);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const edge = {_id: formatEdgeDocId};\n\n  await edgeCollection.remove(edge, {silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${formatTagDocId}) 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      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const extractTags = (content: string): string[] =>\n  words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n\nexport const updateTagsInItem = (context: ApiContext, {itemDocId, tags}): Promise<TagType[]> => {\n  const action = 'updateTagsInItem';\n  const {database} = context;\n  const edgeCollection = database.collection('isTagged');\n\n  return edgeCollection.inEdges(itemDocId, {})\n    .then((edges: any) => Promise.all([\n      ...edges\n        .filter(({name: existingTagName}) => !tags.find(({name: tagName}) => existingTagName === tagName))\n        .map(({_id: edgeDocId, _from: tagDocId}) =>\n          deleteTagFromItem(context, {tagDocId, edgeDocId})),\n      ...tags\n        .filter(({name: tagName}) => !edges.find(({name: existingTagName}) => existingTagName === tagName))\n        .map(({_id: tagDocId, tagBy}) =>\n          addTagToItem(context, {itemDocId, tagBy, tagDocId}))\n    ]).then(() => tags))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n"],
  "mappings": "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",
  "names": ["words"]
}

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