@nlabs/reaktor 0.8.1 → 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 (183) 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 +12 -12
  49. package/lib/actions/conversations.js +131 -126
  50. package/lib/actions/dynamodb.d.ts +8 -8
  51. package/lib/actions/dynamodb.js +35 -32
  52. package/lib/actions/email.d.ts +2 -4
  53. package/lib/actions/email.js +23 -53
  54. package/lib/actions/files.d.ts +15 -12
  55. package/lib/actions/files.js +188 -202
  56. package/lib/actions/groups.d.ts +2 -2
  57. package/lib/actions/groups.js +38 -36
  58. package/lib/actions/images.d.ts +15 -11
  59. package/lib/actions/images.js +236 -229
  60. package/lib/actions/index.d.ts +1 -0
  61. package/lib/actions/index.js +3 -1
  62. package/lib/actions/ios.js +11 -10
  63. package/lib/actions/locations.d.ts +2 -0
  64. package/lib/actions/locations.js +29 -37
  65. package/lib/actions/messages.d.ts +2 -2
  66. package/lib/actions/messages.js +10 -10
  67. package/lib/actions/notifications.d.ts +2 -2
  68. package/lib/actions/notifications.js +1 -1
  69. package/lib/actions/payments.d.ts +2 -2
  70. package/lib/actions/payments.js +27 -26
  71. package/lib/actions/posts.d.ts +7 -9
  72. package/lib/actions/posts.js +176 -156
  73. package/lib/actions/reactions.d.ts +5 -5
  74. package/lib/actions/reactions.js +30 -28
  75. package/lib/actions/s3.d.ts +7 -7
  76. package/lib/actions/s3.js +37 -32
  77. package/lib/actions/search.d.ts +3 -3
  78. package/lib/actions/search.js +11 -9
  79. package/lib/actions/sms.d.ts +2 -2
  80. package/lib/actions/sms.js +58 -34
  81. package/lib/actions/statistics.d.ts +2 -1
  82. package/lib/actions/statistics.js +21 -18
  83. package/lib/actions/subscription.d.ts +2 -2
  84. package/lib/actions/subscription.js +24 -21
  85. package/lib/actions/tags.d.ts +21 -23
  86. package/lib/actions/tags.js +129 -198
  87. package/lib/actions/users.d.ts +23 -20
  88. package/lib/actions/users.js +188 -194
  89. package/lib/actions/websockets.d.ts +13 -0
  90. package/lib/actions/websockets.js +60 -34
  91. package/lib/adapters/arangoAdapter.d.ts +2 -0
  92. package/lib/adapters/arangoAdapter.js +46 -0
  93. package/lib/adapters/fileAdapter.d.ts +3 -0
  94. package/lib/adapters/fileAdapter.js +76 -0
  95. package/lib/adapters/postAdapter.d.ts +2 -0
  96. package/lib/adapters/postAdapter.js +70 -0
  97. package/lib/adapters/reaktorAdapter.d.ts +6 -0
  98. package/lib/adapters/reaktorAdapter.js +44 -0
  99. package/lib/adapters/tagAdapter.d.ts +2 -0
  100. package/lib/adapters/tagAdapter.js +50 -0
  101. package/lib/adapters/userAdapter.d.ts +2 -0
  102. package/lib/adapters/userAdapter.js +110 -0
  103. package/lib/config.js +14 -15
  104. package/lib/lambdas/actions/websockets.js +7 -7
  105. package/lib/lambdas/authorizer.js +1 -1
  106. package/lib/lambdas/connection.js +5 -4
  107. package/lib/lambdas/utils/websocket.js +7 -6
  108. package/lib/mocks/conversation.d.ts +8 -0
  109. package/lib/mocks/conversation.js +35 -0
  110. package/lib/mocks/file.d.ts +11 -0
  111. package/lib/mocks/file.js +38 -0
  112. package/lib/mocks/group.d.ts +17 -0
  113. package/lib/mocks/group.js +47 -0
  114. package/lib/mocks/image.d.ts +3 -0
  115. package/lib/mocks/image.js +43 -0
  116. package/lib/mocks/nlabs.png +0 -0
  117. package/lib/mocks/post.d.ts +38 -0
  118. package/lib/mocks/post.js +55 -0
  119. package/lib/mocks/tag.d.ts +2 -0
  120. package/lib/mocks/tag.js +37 -0
  121. package/lib/mocks/user.d.ts +4 -0
  122. package/lib/mocks/user.js +88 -0
  123. package/lib/types/apps.d.ts +19 -17
  124. package/lib/types/apps.js +17 -1
  125. package/lib/types/arangodb.d.ts +19 -6
  126. package/lib/types/arangodb.js +1 -1
  127. package/lib/types/auth.d.ts +4 -4
  128. package/lib/types/auth.js +1 -1
  129. package/lib/types/connections.d.ts +2 -3
  130. package/lib/types/connections.js +1 -1
  131. package/lib/types/conversations.d.ts +21 -8
  132. package/lib/types/conversations.js +1 -1
  133. package/lib/types/email.d.ts +4 -3
  134. package/lib/types/email.js +1 -1
  135. package/lib/types/error.d.ts +20 -0
  136. package/lib/types/error.js +44 -0
  137. package/lib/types/files.d.ts +10 -10
  138. package/lib/types/files.js +1 -1
  139. package/lib/types/google.d.ts +29 -27
  140. package/lib/types/google.js +1 -1
  141. package/lib/types/groups.d.ts +6 -7
  142. package/lib/types/groups.js +1 -1
  143. package/lib/types/images.d.ts +26 -17
  144. package/lib/types/images.js +1 -1
  145. package/lib/types/locations.d.ts +4 -4
  146. package/lib/types/locations.js +1 -1
  147. package/lib/types/messages.d.ts +3 -14
  148. package/lib/types/messages.js +1 -1
  149. package/lib/types/notifications.d.ts +9 -11
  150. package/lib/types/notifications.js +1 -1
  151. package/lib/types/payments.d.ts +13 -16
  152. package/lib/types/payments.js +1 -1
  153. package/lib/types/posts.d.ts +7 -23
  154. package/lib/types/posts.js +1 -1
  155. package/lib/types/statistics.d.ts +2 -2
  156. package/lib/types/statistics.js +1 -1
  157. package/lib/types/tags.d.ts +7 -12
  158. package/lib/types/tags.js +1 -1
  159. package/lib/types/users.d.ts +10 -14
  160. package/lib/types/users.js +1 -1
  161. package/lib/types/websocket.d.ts +2 -3
  162. package/lib/types/websocket.js +1 -1
  163. package/lib/utils/adapterUtils.d.ts +1 -0
  164. package/lib/utils/adapterUtils.js +45 -0
  165. package/lib/utils/analyticsUtils.d.ts +21 -0
  166. package/lib/utils/analyticsUtils.js +72 -0
  167. package/lib/utils/arangodbUtils.d.ts +65 -0
  168. package/lib/utils/arangodbUtils.js +144 -0
  169. package/lib/utils/auth.d.ts +18 -3
  170. package/lib/utils/auth.js +13 -30
  171. package/lib/utils/index.d.ts +3 -4
  172. package/lib/utils/index.js +7 -9
  173. package/lib/utils/session.d.ts +7 -9
  174. package/lib/utils/session.js +11 -2
  175. package/package.json +12 -5
  176. package/lib/utils/analytics.d.ts +0 -14
  177. package/lib/utils/analytics.js +0 -88
  178. package/lib/utils/arangodb.d.ts +0 -9
  179. package/lib/utils/arangodb.js +0 -118
  180. package/lib/utils/graphql.d.ts +0 -1
  181. package/lib/utils/graphql.js +0 -46
  182. package/lib/utils/objects.d.ts +0 -3
  183. package/lib/utils/objects.js +0 -59
@@ -27,6 +27,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
27
27
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
28
  var conversations_exports = {};
29
29
  __export(conversations_exports, {
30
+ addDirectConversation: () => addDirectConversation,
30
31
  addUserToConversation: () => addUserToConversation,
31
32
  deleteUserFromConversation: () => deleteUserFromConversation,
32
33
  getConnectionUsers: () => getConnectionUsers,
@@ -34,7 +35,6 @@ __export(conversations_exports, {
34
35
  getConversationUsers: () => getConversationUsers,
35
36
  getConversations: () => getConversations,
36
37
  getDirectConversation: () => getDirectConversation,
37
- getDirectConversationOld: () => getDirectConversationOld,
38
38
  parseConversationOptions: () => parseConversationOptions,
39
39
  updateConversation: () => updateConversation
40
40
  });
@@ -42,10 +42,11 @@ module.exports = __toCommonJS(conversations_exports);
42
42
  var import_utils = require("@nlabs/utils");
43
43
  var import_arangojs = require("arangojs");
44
44
  var import_cloneDeep = __toESM(require("lodash/cloneDeep"));
45
- var import_utils2 = require("../utils");
46
- var import_analytics = require("../utils/analytics");
45
+ var import_analyticsUtils = require("../utils/analyticsUtils");
47
46
  var import_images = require("./images");
48
47
  var import_users = require("./users");
48
+ var import_error = require("../types/error");
49
+ var import_arangodbUtils = require("../utils/arangodbUtils");
49
50
  const eventCategory = "conversations";
50
51
  const parseConversationOptions = (options = {}) => {
51
52
  const {
@@ -53,55 +54,74 @@ const parseConversationOptions = (options = {}) => {
53
54
  to = 30
54
55
  } = options;
55
56
  return {
56
- limit: (0, import_utils2.getLimit)(from, to)
57
+ limit: (0, import_arangodbUtils.getLimit)(from, to)
57
58
  };
58
59
  };
59
- const getConversations = (context, options) => {
60
+ const getConversations = (context, userId, options) => {
60
61
  const action = "getConversations";
61
- const { database, session: { userId: sessionId } } = context;
62
+ const { database } = context;
62
63
  const { limit } = parseConversationOptions(options);
63
- const sessionDocId = `users/${sessionId}`;
64
- const aqlQry = `FOR c, e IN 1..1 OUTBOUND "${sessionDocId}" hasConversation
64
+ const userDocId = `users/${userId}`;
65
+ const aqlQry = `FOR c, e IN 1..1 OUTBOUND "${userDocId}" hasConversation
65
66
  ${limit.aql}
66
67
  LET users = (
67
68
  FOR u, uc IN 1..1 INBOUND c._id hasConversation
68
- FILTER u._id != "${sessionDocId}"
69
+ FILTER u._id != "${userDocId}"
69
70
  RETURN u
70
71
  )
71
72
  RETURN MERGE(c, {users: users})`;
72
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analytics.logError)({
73
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
73
74
  action,
74
75
  category: eventCategory,
75
- label: "db_error"
76
- }, error, context).then(() => null));
76
+ label: import_error.ErrorTypes.DATABASE_ERROR
77
+ }, error, context));
77
78
  };
78
- const getDirectConversation = async (context, fromId, toId) => {
79
+ const getDirectConversation = async (context, {
80
+ fromId,
81
+ toId,
82
+ toUser
83
+ }) => {
79
84
  const action = "getDirectConversation";
80
85
  const { database } = context;
81
86
  try {
82
87
  const formatFromId = (0, import_utils.parseId)(fromId);
83
88
  const formatToId = (0, import_utils.parseId)(toId);
84
89
  const userIds = [formatFromId, formatToId];
85
- const sortedUserIds = userIds.sort((a, b) => {
86
- if (a < b) {
87
- return -1;
88
- }
89
- if (a > b) {
90
- return 1;
91
- }
92
- return 0;
93
- });
90
+ const sortedUserIds = (0, import_arangodbUtils.sortIds)(userIds);
94
91
  const conversationId = (0, import_utils.createHash)(`conversations-${sortedUserIds.join("-")}`, null);
95
- const user = await (0, import_users.getUser)(context, { userId: formatToId });
92
+ const user = toUser || await (0, import_users.getUser)(context, { userId: formatToId });
96
93
  const aqlQry = import_arangojs.aql`LET c = DOCUMENT(${`conversations/${conversationId}`}) RETURN c`;
97
- const conversation = await database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analytics.logError)({
94
+ const conversation = await database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
98
95
  action,
99
96
  category: eventCategory,
100
- label: "db_error"
101
- }, error, context).then(() => null));
97
+ label: import_error.ErrorTypes.DATABASE_ERROR
98
+ }, error, context));
102
99
  if (conversation) {
103
100
  return { ...conversation, users: [user] };
104
101
  }
102
+ return addDirectConversation(context, { fromId, toId, toUser: user });
103
+ } catch (databaseError) {
104
+ return (0, import_analyticsUtils.logError)({
105
+ action,
106
+ category: eventCategory,
107
+ label: import_error.ErrorTypes.DATABASE_ERROR
108
+ }, databaseError, context);
109
+ }
110
+ };
111
+ const addDirectConversation = async (context, {
112
+ fromId,
113
+ toId,
114
+ toUser
115
+ }) => {
116
+ const action = "getDirectConversation";
117
+ const { database } = context;
118
+ try {
119
+ const formatFromId = (0, import_utils.parseId)(fromId);
120
+ const formatToId = (0, import_utils.parseId)(toId);
121
+ const userIds = [formatFromId, formatToId];
122
+ const sortedUserIds = (0, import_arangodbUtils.sortIds)([formatFromId, formatToId]);
123
+ const user = toUser || await (0, import_users.getUser)(context, { userId: formatToId });
124
+ const conversationId = (0, import_utils.createHash)(`conversations-${sortedUserIds.join("-")}`, null);
105
125
  const now = Date.now();
106
126
  const insert = {
107
127
  _key: conversationId,
@@ -123,16 +143,20 @@ const getDirectConversation = async (context, fromId, toId) => {
123
143
  return database.query(insertEdgeQuery);
124
144
  }));
125
145
  return { ...updatedConversation, users: [user] };
126
- } catch (updateError) {
127
- return (0, import_analytics.logError)({
146
+ } catch (databaseError) {
147
+ return (0, import_analyticsUtils.logError)({
128
148
  action,
129
149
  category: eventCategory,
130
- label: "db_error"
131
- }, updateError, context).then(() => null);
150
+ label: import_error.ErrorTypes.DATABASE_ERROR
151
+ }, databaseError, context);
132
152
  }
133
153
  };
134
- const getConnectionUsers = (context, conversationId, includeAll = false, isDirect) => {
135
- const action = "getConversationUsers";
154
+ const getConnectionUsers = (context, {
155
+ conversationId,
156
+ includeAll = false,
157
+ isDirect
158
+ }) => {
159
+ const action = "getConnectionUsers";
136
160
  const { database, session: { userId: sessionUserId } } = context;
137
161
  const filters = ["c.userId == u._key"];
138
162
  if (!includeAll) {
@@ -146,13 +170,19 @@ const getConnectionUsers = (context, conversationId, includeAll = false, isDirec
146
170
  FOR c IN connections
147
171
  FILTER ${filters.join(" && ")}
148
172
  RETURN c`;
149
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analytics.logError)({
150
- action,
151
- category: eventCategory,
152
- label: "db_error"
153
- }, error, context).then(() => null));
173
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch(
174
+ (error) => (0, import_analyticsUtils.logError)({
175
+ action,
176
+ category: eventCategory,
177
+ label: import_error.ErrorTypes.DATABASE_ERROR
178
+ }, error, context)
179
+ );
154
180
  };
155
- const getConversationUsers = (context, conversationId, includeAll = false, isDirect) => {
181
+ const getConversationUsers = (context, {
182
+ conversationId,
183
+ includeAll = false,
184
+ isDirect
185
+ }) => {
156
186
  const action = "getConversationUsers";
157
187
  const { database, session: { userId: sessionUserId } } = context;
158
188
  const filters = ["c.userId == u._key"];
@@ -166,92 +196,61 @@ const getConversationUsers = (context, conversationId, includeAll = false, isDir
166
196
  OPTIONS {vertexCollections: "users"}
167
197
  FILTER ${filters.join(" && ")}
168
198
  RETURN u`;
169
- console.log({ aqlQry });
170
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analytics.logError)({
171
- action,
172
- category: eventCategory,
173
- label: "db_error"
174
- }, error, context).then(() => null));
175
- };
176
- const getDirectConversationOld = (context, userId) => {
177
- const action = "getDirectConversation";
178
- const { database, session: { userId: sessionId } } = context;
179
- const sessionDocId = `users/${sessionId}`;
180
- const formatUserId = (0, import_utils.parseArangoId)(userId);
181
- const aqlQry = import_arangojs.aql`LET from = (
182
- FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation
183
- FILTER c.direct == true
184
- RETURN c
185
- )
186
- LET to = (
187
- FOR c, e IN 1..1 OUTBOUND ${formatUserId} hasConversation
188
- FILTER c.direct == true
189
- RETURN c
190
- )
191
- LET conversation = FIRST(INTERSECTION(from, to))
192
- LET users = !IS_NULL(conversation) && (
193
- FOR g IN[${sessionDocId}, ${formatUserId}]
194
- FOR u IN users
195
- FILTER g == u._id
196
- RETURN u
197
- )
198
- RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})`;
199
- return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analytics.logError)({
199
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
200
200
  action,
201
201
  category: eventCategory,
202
- label: "db_error"
203
- }, error, context).then(() => null));
202
+ label: import_error.ErrorTypes.DATABASE_ERROR
203
+ }, error, context));
204
204
  };
205
- const getConversation = (context, convoId) => {
205
+ const getConversation = (context, conversationId) => {
206
206
  const action = "getItem";
207
207
  const { database, session: { userId: sessionId } } = context;
208
208
  const sessionDocId = `users/${sessionId}`;
209
- const convoDocId = `conversations/${(0, import_utils.parseId)(convoId)}`;
209
+ const conversationDocId = `conversations/${(0, import_utils.parseId)(conversationId)}`;
210
210
  const aqlQry = import_arangojs.aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation
211
- FILTER c._id == ${convoDocId}
211
+ FILTER c._id == ${conversationDocId}
212
212
  LET u = (
213
- FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversation
213
+ FOR inUser, inEdge IN 1..1 INBOUND ${conversationDocId} hasConversation
214
214
  RETURN inUser
215
215
  )
216
216
  LIMIT 1
217
217
  RETURN MERGE(c, {users: u})`;
218
- return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation = {}) => {
219
- if (conversation) {
220
- conversation.users = conversation.users.map((user) => {
221
- const { imageId, userId } = user;
222
- const thumbUrlData = {
223
- imageId,
224
- isThumb: true,
225
- userId
226
- };
227
- return {
228
- ...user,
229
- name: (0, import_users.getDisplayName)(user),
230
- thumb: (0, import_images.getImageUrl)(thumbUrlData)
231
- };
232
- });
233
- return conversation;
218
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation) => {
219
+ if (!conversation) {
220
+ return {};
234
221
  }
235
- return {};
236
- }).catch((error) => (0, import_analytics.logError)({
222
+ conversation.users = conversation.users.map((user) => {
223
+ const { imageId, userId } = user;
224
+ const thumbUrlData = {
225
+ imageId,
226
+ isThumb: true,
227
+ userId
228
+ };
229
+ return {
230
+ ...user,
231
+ name: (0, import_users.getDisplayName)(user),
232
+ thumb: (0, import_images.getImageUrl)(thumbUrlData)
233
+ };
234
+ });
235
+ return conversation;
236
+ }).catch((error) => (0, import_analyticsUtils.logError)({
237
237
  action,
238
238
  category: eventCategory,
239
- label: "db_error"
240
- }, error, context).then(() => null));
239
+ label: import_error.ErrorTypes.DATABASE_ERROR
240
+ }, error, context));
241
241
  };
242
242
  const updateConversation = (context, conversation) => {
243
243
  const action = "updateConversation";
244
244
  const { database, session: { userId: sessionId } } = context;
245
245
  const {
246
246
  conversationId = (0, import_utils.createHash)(`conversation-${sessionId} `),
247
- direct = false,
247
+ isDirect = false,
248
248
  name
249
249
  } = conversation;
250
250
  const formatConversationId = (0, import_utils.parseId)(conversationId);
251
251
  const now = Date.now();
252
252
  const update = {
253
- // Direct message
254
- direct,
253
+ isDirect,
255
254
  modified: now,
256
255
  name
257
256
  };
@@ -264,62 +263,69 @@ const updateConversation = (context, conversation) => {
264
263
  INSERT ${insert}
265
264
  UPDATE ${update}
266
265
  IN conversations RETURN NEW`;
267
- return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation2 = {}) => conversation2).catch((error) => (0, import_analytics.logError)({
266
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation2) => conversation2).catch((error) => (0, import_analyticsUtils.logError)({
268
267
  action,
269
268
  category: eventCategory,
270
- label: "db_error"
271
- }, error, context).then(() => null));
269
+ label: import_error.ErrorTypes.DATABASE_ERROR
270
+ }, error, context));
272
271
  };
273
- const addUserToConversation = (context, convoId, userId) => {
272
+ const addUserToConversation = (context, {
273
+ conversationId,
274
+ userId
275
+ }) => {
274
276
  const action = "addUserToConversation";
275
277
  const { database } = context;
276
- const formatConvoId = (0, import_utils.parseId)(convoId);
278
+ const formatConversationId = (0, import_utils.parseId)(conversationId);
277
279
  const formatUserId = (0, import_utils.parseId)(userId);
278
- const convoDocId = `conversations/${formatConvoId}`;
280
+ const conversationDocId = `conversations/${formatConversationId}`;
279
281
  const userDocId = `users/${formatUserId}`;
280
- const aqlQry = import_arangojs.aql`FOR c IN hasConversation
281
- FILTER c._from == ${userDocId} && c._to == ${convoDocId}
282
+ const aqlQry = import_arangojs.aql`FOR hc IN hasConversation
283
+ FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}
282
284
  LIMIT 1
283
- RETURN c`;
284
- return database.query(aqlQry).then((cursor) => cursor.next()).then((conversationEdge) => {
285
- if (!!conversationEdge) {
286
- return conversationEdge;
285
+ RETURN hc`;
286
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((hasConversationEdge) => {
287
+ if (!!hasConversationEdge) {
288
+ return hasConversationEdge;
287
289
  }
288
290
  const edgeCollection = database.collection("hasConversation");
289
- const edgeId = (0, import_utils.createHash)(`convo - ${formatConvoId} -${formatUserId} `);
291
+ const edgeId = (0, import_utils.createHash)(`convo - ${formatConversationId} -${formatUserId} `);
290
292
  const edge = {
291
293
  _from: userDocId,
292
294
  _key: edgeId,
293
- _to: convoDocId,
295
+ _to: conversationDocId,
294
296
  added: Date.now()
295
297
  };
296
298
  return edgeCollection.save(edge, { returnNew: true }).then(() => edge);
297
- }).catch((error) => (0, import_analytics.logError)({
299
+ }).catch((error) => (0, import_analyticsUtils.logError)({
298
300
  action,
299
301
  category: eventCategory,
300
- label: "db_error"
301
- }, error, context).then(() => null));
302
+ label: import_error.ErrorTypes.DATABASE_ERROR
303
+ }, error, context));
302
304
  };
303
- const deleteUserFromConversation = (context, convoId, userId) => {
305
+ const deleteUserFromConversation = (context, {
306
+ conversationId,
307
+ userId
308
+ }) => {
304
309
  const action = "deleteUserFromConversation";
305
310
  const { database } = context;
306
- const formatConvoId = (0, import_utils.parseId)(convoId);
311
+ const formatConversationId = (0, import_utils.parseId)(conversationId);
307
312
  const formatUserId = (0, import_utils.parseId)(userId);
308
- const convoDocId = `conversations/${formatConvoId}`;
313
+ const conversationDocId = `conversations/${formatConversationId}`;
309
314
  const userDocId = `users/${formatUserId}`;
310
- const aqlQry = import_arangojs.aql`FOR c IN hasConversation
311
- FILTER c._from == ${userDocId} && c._to == ${convoDocId}
315
+ const aqlQry = import_arangojs.aql`FOR hc IN hasConversation
316
+ FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}
312
317
  LIMIT 1
313
- REMOVE c IN hasConversation
318
+ REMOVE hc IN hasConversation
314
319
  RETURN OLD`;
315
- return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analytics.logError)({
320
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
316
321
  action,
317
322
  category: eventCategory,
318
- label: "db_error"
319
- }, error, context).then(() => null));
323
+ label: import_error.ErrorTypes.DATABASE_ERROR
324
+ }, error, context));
320
325
  };
321
326
  // Annotate the CommonJS export names for ESM import in node:
322
327
  0 && (module.exports = {
328
+ addDirectConversation,
323
329
  addUserToConversation,
324
330
  deleteUserFromConversation,
325
331
  getConnectionUsers,
@@ -327,8 +333,7 @@ const deleteUserFromConversation = (context, convoId, userId) => {
327
333
  getConversationUsers,
328
334
  getConversations,
329
335
  getDirectConversation,
330
- getDirectConversationOld,
331
336
  parseConversationOptions,
332
337
  updateConversation
333
338
  });
334
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/conversations.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} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\n\nimport {ConnectionType, ConversationOptions, ConversationType, ImageUrlData, User} from '../types';\nimport {ApiContext} from '../types/auth';\nimport {getLimit} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getImageUrl} from './images';\nimport {getDisplayName, getUser} from './users';\n\nconst eventCategory: string = 'conversations';\n\nexport const parseConversationOptions = (options: ConversationOptions = {}) => {\n  const {\n    from = 0,\n    to = 30,\n  } = options;\n\n  return {\n    limit: getLimit(from, to),\n  };\n};\n\nexport const getConversations = (context: ApiContext, options?): Promise<ConversationType[]> => {\n  const action: string = 'getConversations';\n  const {database, session: {userId: sessionId}} = context;\n  const {limit} = parseConversationOptions(options);\n  const sessionDocId: string = `users/${sessionId}`;\n  const aqlQry: string = `FOR c, e IN 1..1 OUTBOUND \"${sessionDocId}\" hasConversation\n    ${limit.aql}\n    LET users = (\n      FOR u, uc IN 1..1 INBOUND c._id hasConversation\n      FILTER u._id != \"${sessionDocId}\"\n      RETURN u\n    )\n    RETURN MERGE(c, {users: users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = async (\n  context: ApiContext,\n  fromId: string,\n  toId: string\n): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database} = context;\n\n  try {\n    const formatFromId: string = parseId(fromId);\n    const formatToId: string = parseId(toId);\n    const userIds: string[] = [formatFromId, formatToId];\n    const sortedUserIds: string[] = userIds.sort((a, b) => {\n      if(a < b) {\n        return -1;\n      }\n      if(a > b) {\n        return 1;\n      }\n      return 0;\n    });\n    const conversationId: string = createHash(`conversations-${sortedUserIds.join('-')}`, null);\n    const user: User = await getUser(context, {userId: formatToId});\n\n    const aqlQry: AqlQuery = aql`LET c = DOCUMENT(${`conversations/${conversationId}`}) RETURN c`;\n    const conversation = await database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error'\n      }, error, context).then(() => null));\n\n    if(conversation) {\n      return {...conversation, users: [user]};\n    }\n\n    const now: number = Date.now();\n    const insert = {\n      _key: conversationId,\n      added: now,\n      isDirect: true,\n      modified: now\n    };\n    const insertQuery: AqlQuery = aql`INSERT ${insert} IN conversations RETURN NEW`;\n    const updatedConversation = await database.query(insertQuery)\n      .then((cursor: ArrayCursor) => cursor.next());\n\n    await Promise.all(userIds.map((userId) => {\n      const edgeId: string = createHash(`hasConversation-${userId}-${conversationId}`);\n      const edge: any = {\n        _from: `users/${userId}`,\n        _key: edgeId,\n        _to: `conversations/${conversationId}`,\n        added: Date.now()\n      };\n      const insertEdgeQuery: AqlQuery = aql`INSERT ${edge} IN hasConversation RETURN NEW`;\n      return database.query(insertEdgeQuery);\n    }));\n\n    return {...updatedConversation, users: [user]};\n  } catch(updateError) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, updateError, context).then(() => null);\n  }\n};\n\nexport const getConnectionUsers = (\n  context: ApiContext,\n  conversationId: string,\n  includeAll: boolean = false,\n  isDirect?: boolean\n): Promise<ConnectionType[]> => {\n  const action: string = 'getConversationUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FOR c IN connections\n    FILTER ${filters.join(' && ')}\n    RETURN c`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversationUsers = (\n  context: ApiContext,\n  conversationId: string,\n  includeAll: boolean = false,\n  isDirect?: boolean\n): Promise<ConversationType[]> => {\n  const action: string = 'getConversationUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FILTER ${filters.join(' && ')}\n    RETURN u`;\n\n  console.log({aqlQry});\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversationOld = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database, session: {userId: sessionId}} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatUserId: string = parseArangoId(userId);\n\n  const aqlQry: AqlQuery = aql`LET from = (\n      FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET to = (\n      FOR c, e IN 1..1 OUTBOUND ${formatUserId} hasConversation\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET conversation = FIRST(INTERSECTION(from, to))\n    LET users = !IS_NULL(conversation) && (\n      FOR g IN[${sessionDocId}, ${formatUserId}]\n      FOR u IN users\n      FILTER g == u._id\n      RETURN u\n    )\n    RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const convoDocId: string = `conversations/${parseId(convoId)}`;\n\n  const aqlQry: AqlQuery = aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation\n    FILTER c._id == ${convoDocId}\n    LET u = (\n      FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversation\n      RETURN inUser\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(conversation) {\n        conversation.users = conversation.users.map((user: any) => {\n          const {imageId, userId} = user;\n          const thumbUrlData: ImageUrlData = {\n            imageId,\n            isThumb: true,\n            userId\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getImageUrl(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, conversation): Promise<ConversationType> => {\n  const action: string = 'updateConversation';\n  const {database, session: {userId: sessionId}} = context;\n  const {\n    conversationId = createHash(`conversation-${sessionId} `),\n    direct = false,\n    name\n  } = conversation;\n  const formatConversationId: string = parseId(conversationId);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct,\n    modified: now,\n    name\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatConversationId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatConversationId} }\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const addUserToConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations/${formatConvoId}`;\n  const userDocId: string = `users/${formatUserId}`;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversation\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    RETURN c`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversationEdge) => {\n      if(!!conversationEdge) {\n        return conversationEdge;\n      }\n\n      const edgeCollection: EdgeCollection = database.collection('hasConversation');\n      const edgeId: string = createHash(`convo - ${formatConvoId} -${formatUserId} `);\n\n      const edge: ConversationType = {\n        _from: userDocId,\n        _key: edgeId,\n        _to: convoDocId,\n        added: Date.now()\n      };\n\n      return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteUserFromConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'deleteUserFromConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations/${formatConvoId}`;\n  const userDocId: string = `users/${formatUserId}`;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversation\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    REMOVE c IN hasConversation\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      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "cloneDeep", "conversation"]
}

339
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/conversations.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, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\n\nimport type {\n  ArangoDbLimit,\n  ConnectionType,\n  ConversationOptions,\n  ConversationType,\n  ConversationUsersParams,\n  DirectConversationParams,\n  ImageUrlData,\n  UpdateConversationUserParams,\n  UserType\n} from '../types';\nimport type {ApiContext} from '../types/auth';\nimport {logError} from '../utils/analyticsUtils';\nimport {getImageUrl} from './images';\nimport {getDisplayName, getUser} from './users';\nimport {ErrorTypes} from '../types/error';\nimport {getLimit, sortIds} from '../utils/arangodbUtils';\n\nconst eventCategory: string = 'conversations';\n\nexport const parseConversationOptions = (options: ConversationOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to) as ArangoDbLimit\n  };\n};\n\nexport const getConversations = (context: ApiContext, userId: string, options?): Promise<ConversationType[]> => {\n  const action: string = 'getConversations';\n  const {database} = context;\n  const {limit} = parseConversationOptions(options);\n  const userDocId: string = `users/${userId}`;\n  const aqlQry: string = `FOR c, e IN 1..1 OUTBOUND \"${userDocId}\" hasConversation\n    ${limit.aql}\n    LET users = (\n      FOR u, uc IN 1..1 INBOUND c._id hasConversation\n      FILTER u._id != \"${userDocId}\"\n      RETURN u\n    )\n    RETURN MERGE(c, {users: users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const getDirectConversation = async (\n  context: ApiContext,\n  {\n    fromId,\n    toId,\n    toUser\n  }: DirectConversationParams\n): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database} = context;\n\n  try {\n    const formatFromId = parseId(fromId);\n    const formatToId = parseId(toId);\n    const userIds = [formatFromId, formatToId];\n    const sortedUserIds = sortIds(userIds);\n    const conversationId = createHash(`conversations-${sortedUserIds.join('-')}`, null);\n    const user: UserType = toUser || await getUser(context, {userId: formatToId});\n    const aqlQry: AqlQuery = aql`LET c = DOCUMENT(${`conversations/${conversationId}`}) RETURN c`;\n    const conversation = await database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context));\n\n    if(conversation) {\n      return {...conversation, users: [user]};\n    }\n\n    return addDirectConversation(context, {fromId, toId, toUser: user});\n  } catch(databaseError) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, databaseError, context);\n  }\n};\n\nexport const addDirectConversation = async (\n  context: ApiContext,\n  {\n    fromId,\n    toId,\n    toUser\n  }: DirectConversationParams\n): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database} = context;\n\n  try {\n    const formatFromId = parseId(fromId);\n    const formatToId = parseId(toId);\n    const userIds = [formatFromId, formatToId];\n    const sortedUserIds = sortIds([formatFromId, formatToId]);\n    const user: UserType = toUser || await getUser(context, {userId: formatToId});\n    const conversationId = createHash(`conversations-${sortedUserIds.join('-')}`, null);\n    const now = Date.now();\n    const insert = {\n      _key: conversationId,\n      added: now,\n      isDirect: true,\n      modified: now\n    };\n    const insertQuery: AqlQuery = aql`INSERT ${insert} IN conversations RETURN NEW`;\n    const updatedConversation = await database.query(insertQuery)\n      .then((cursor: ArrayCursor) => cursor.next());\n\n    await Promise.all(userIds.map((userId) => {\n      const edgeId: string = createHash(`hasConversation-${userId}-${conversationId}`);\n      const edge: any = {\n        _from: `users/${userId}`,\n        _key: edgeId,\n        _to: `conversations/${conversationId}`,\n        added: Date.now()\n      };\n      const insertEdgeQuery: AqlQuery = aql`INSERT ${edge} IN hasConversation RETURN NEW`;\n      return database.query(insertEdgeQuery);\n    }));\n\n    return {...updatedConversation, users: [user]};\n  } catch(databaseError) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, databaseError, context);\n  }\n};\n\nexport const getConnectionUsers = (\n  context: ApiContext,\n  {\n    conversationId,\n    includeAll = false,\n    isDirect\n  }: ConversationUsersParams\n): Promise<ConnectionType[]> => {\n  const action: string = 'getConnectionUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FOR c IN connections\n    FILTER ${filters.join(' && ')}\n    RETURN c`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context)\n    );\n};\n\nexport const getConversationUsers = (\n  context: ApiContext,\n  {\n    conversationId,\n    includeAll = false,\n    isDirect\n  }: ConversationUsersParams\n): Promise<ConversationType[]> => {\n  const action: string = 'getConversationUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FILTER ${filters.join(' && ')}\n    RETURN u`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\n// export const getDirectConversationOld = (context: ApiContext, userId: string): Promise<ConversationType> => {\n//   const action: string = 'getDirectConversation';\n//   const {database, session: {userId: sessionId}} = context;\n//   const sessionDocId: string = `users/${sessionId}`;\n//   const formatUserId: string = parseArangoId(userId);\n\n//   const aqlQry: AqlQuery = aql`LET from = (\n//       FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation\n//       FILTER c.direct == true\n//       RETURN c\n//     )\n//     LET to = (\n//       FOR c, e IN 1..1 OUTBOUND ${formatUserId} hasConversation\n//       FILTER c.direct == true\n//       RETURN c\n//     )\n//     LET conversation = FIRST(INTERSECTION(from, to))\n//     LET users = !IS_NULL(conversation) && (\n//       FOR g IN[${sessionDocId}, ${formatUserId}]\n//       FOR u IN users\n//       FILTER g == u._id\n//       RETURN u\n//     )\n//     RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})`;\n\n//   return database.query(aqlQry)\n//     .then((cursor: ArrayCursor) => cursor.next())\n//     .catch((error: Error) => logError({\n//       action,\n//       category: eventCategory,\n//       label: ErrorTypes.DATABASE_ERROR\n//     }, error, context));\n// };\n\nexport const getConversation = (context: ApiContext, conversationId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const conversationDocId: string = `conversations/${parseId(conversationId)}`;\n\n  const aqlQry: AqlQuery = aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation\n    FILTER c._id == ${conversationDocId}\n    LET u = (\n      FOR inUser, inEdge IN 1..1 INBOUND ${conversationDocId} hasConversation\n      RETURN inUser\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType) => {\n      if(!conversation) {\n        return {};\n      }\n\n      conversation.users = conversation.users.map((user: UserType) => {\n        const {imageId, userId} = user;\n        const thumbUrlData: ImageUrlData = {\n          imageId,\n          isThumb: true,\n          userId\n        };\n\n        return {\n          ...user,\n          name: getDisplayName(user),\n          thumb: getImageUrl(thumbUrlData)\n        };\n      });\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const updateConversation = (\n  context: ApiContext,\n  conversation: ConversationType\n): Promise<ConversationType> => {\n  const action: string = 'updateConversation';\n  const {database, session: {userId: sessionId}} = context;\n  const {\n    conversationId = createHash(`conversation-${sessionId} `),\n    isDirect = false,\n    name\n  } = conversation;\n  const formatConversationId: string = parseId(conversationId);\n  const now: number = Date.now();\n  const update: any = {\n    isDirect,\n    modified: now,\n    name\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatConversationId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatConversationId} }\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const addUserToConversation = (\n  context: ApiContext,\n  {\n    conversationId,\n    userId\n  }: UpdateConversationUserParams\n): Promise<ConversationType> => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConversationId: string = parseId(conversationId);\n  const formatUserId: string = parseId(userId);\n  const conversationDocId: string = `conversations/${formatConversationId}`;\n  const userDocId: string = `users/${formatUserId}`;\n\n  const aqlQry: AqlQuery = aql`FOR hc IN hasConversation\n    FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}\n    LIMIT 1\n    RETURN hc`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((hasConversationEdge) => {\n      if(!!hasConversationEdge) {\n        return hasConversationEdge;\n      }\n\n      const edgeCollection: EdgeCollection = database.collection('hasConversation');\n      const edgeId: string = createHash(`convo - ${formatConversationId} -${formatUserId} `);\n\n      const edge: ConversationType = {\n        _from: userDocId,\n        _key: edgeId,\n        _to: conversationDocId,\n        added: Date.now()\n      };\n\n      return edgeCollection\n        .save(edge, {returnNew: true})\n        .then(() => edge);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const deleteUserFromConversation = (\n  context: ApiContext,\n  {\n    conversationId,\n    userId\n  }: UpdateConversationUserParams\n): Promise<ConversationType> => {\n  const action: string = 'deleteUserFromConversation';\n  const {database} = context;\n  const formatConversationId: string = parseId(conversationId);\n  const formatUserId: string = parseId(userId);\n  const conversationDocId: string = `conversations/${formatConversationId}`;\n  const userDocId: string = `users/${formatUserId}`;\n\n  const aqlQry: AqlQuery = aql`FOR hc IN hasConversation\n    FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}\n    LIMIT 1\n    REMOVE hc IN hasConversation\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      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n"],
  "mappings": "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",
  "names": ["cloneDeep", "conversation"]
}

@@ -1,8 +1,8 @@
1
- import { BatchWriteItemInput, BatchWriteItemOutput, DeleteItemInput, DeleteItemOutput, GetItemInput, GetItemOutput, PutItemInput, PutItemOutput, QueryInput, QueryOutput, UpdateItemInput, UpdateItemOutput } from 'aws-sdk/clients/dynamodb';
2
- export declare const dynamoGet: (params: GetItemInput) => Promise<GetItemOutput>;
3
- export declare const parseDynamo: (results: QueryOutput) => any[];
4
- export declare const dynamoGetList: (params: QueryInput, index: any) => Promise<GetItemOutput[]>;
5
- export declare const dynamoPut: (params: PutItemInput) => Promise<PutItemOutput>;
6
- export declare const dynamoUpdate: (params: UpdateItemInput) => Promise<UpdateItemOutput>;
7
- export declare const dynamoPutList: (params: BatchWriteItemInput) => Promise<BatchWriteItemOutput>;
8
- export declare const dynamoDel: (params: DeleteItemInput) => Promise<DeleteItemOutput>;
1
+ import { BatchWriteItemCommandInput, BatchWriteItemCommandOutput, DeleteItemCommandInput, DeleteItemCommandOutput, GetItemCommandInput, GetItemCommandOutput, PutItemCommandInput, PutItemCommandOutput, QueryCommandInput, QueryCommandOutput, UpdateItemCommandInput, UpdateItemCommandOutput } from '@aws-sdk/client-dynamodb';
2
+ export declare const dynamoGet: (params: GetItemCommandInput) => Promise<GetItemCommandOutput>;
3
+ export declare const parseDynamoList: (results: QueryCommandOutput) => any[];
4
+ export declare const dynamoGetList: (params: QueryCommandInput, startItem?: any) => Promise<GetItemCommandOutput[]>;
5
+ export declare const dynamoPut: (params: PutItemCommandInput) => Promise<PutItemCommandOutput>;
6
+ export declare const dynamoUpdate: (params: UpdateItemCommandInput) => Promise<UpdateItemCommandOutput>;
7
+ export declare const dynamoPutList: (params: BatchWriteItemCommandInput) => Promise<BatchWriteItemCommandOutput>;
8
+ export declare const dynamoDel: (params: DeleteItemCommandInput) => Promise<DeleteItemCommandOutput>;