@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
@@ -1,4 +1,4 @@
1
- import { ApiContext, AppCollectionTypes, User, UserReactionQuery } from '../types';
1
+ import type { ApiContext, ArangoDbCollection, ArangoDbLimit, UserType, UserReactionQuery } from '../types';
2
2
  export type ReactionDirection = 'INBOUND' | 'OUTBOUND';
3
3
  export interface Reaction {
4
4
  readonly _from?: string;
@@ -8,7 +8,7 @@ export interface Reaction {
8
8
  readonly count?: number;
9
9
  readonly id?: string;
10
10
  readonly name?: string;
11
- readonly type?: AppCollectionTypes;
11
+ readonly type?: ArangoDbCollection;
12
12
  readonly value?: string;
13
13
  }
14
14
  export interface ReactionOptions {
@@ -16,7 +16,7 @@ export interface ReactionOptions {
16
16
  readonly to?: number;
17
17
  }
18
18
  export declare const parseReactionOptions: (options?: ReactionOptions) => {
19
- limit: import("types/arangodb").ArangoDBLimit;
19
+ limit: ArangoDbLimit;
20
20
  };
21
21
  export declare const addReaction: (context: ApiContext, itemId: string, reaction?: Reaction, allowDuplicate?: boolean) => Promise<Reaction>;
22
22
  export declare const deleteReaction: (context: ApiContext, reactionId: string) => Promise<Reaction>;
@@ -24,7 +24,7 @@ export declare const deleteReactionByItem: (context: ApiContext, itemId: string,
24
24
  export declare const updateReaction: (context: ApiContext, reaction?: Reaction) => Promise<Reaction>;
25
25
  export declare const getReactionCount: (context: ApiContext, itemId: string, reactionName: string) => Promise<Reaction>;
26
26
  export declare const getReactionCountByUser: (context: ApiContext, itemId: string, itemType: string, reactionName: string) => Promise<Reaction[]>;
27
- export declare const getGroupUsersByReaction: (context: ApiContext, params?: UserReactionQuery) => Promise<User[]>;
28
- export declare const getReactionsByItem: (context: ApiContext, itemId: string, reactionName: string, options: ReactionOptions) => Promise<User[]>;
27
+ export declare const getGroupUsersByReaction: (context: ApiContext, params?: UserReactionQuery) => Promise<UserType[]>;
28
+ export declare const getReactionsByItem: (context: ApiContext, itemId: string, reactionName: string, options: ReactionOptions) => Promise<UserType[]>;
29
29
  export declare const getItemsByReaction: (context: ApiContext, itemId: string, reactionName: string, options: ReactionOptions) => Promise<Reaction[]>;
30
30
  export declare const hasReaction: (context: ApiContext, itemId: string, reactionName: string, direction?: ReactionDirection) => Promise<boolean>;
@@ -32,7 +32,9 @@ __export(reactions_exports, {
32
32
  module.exports = __toCommonJS(reactions_exports);
33
33
  var import_utils = require("@nlabs/utils");
34
34
  var import_arangojs = require("arangojs");
35
- var import_utils2 = require("../utils");
35
+ var import_analyticsUtils = require("../utils/analyticsUtils");
36
+ var import_error = require("../types/error");
37
+ var import_arangodbUtils = require("../utils/arangodbUtils");
36
38
  const eventCategory = "reactions";
37
39
  const parseReactionOptions = (options = {}) => {
38
40
  const {
@@ -40,14 +42,14 @@ const parseReactionOptions = (options = {}) => {
40
42
  to = 30
41
43
  } = options;
42
44
  return {
43
- limit: (0, import_utils2.getLimit)(from, to)
45
+ limit: (0, import_arangodbUtils.getLimit)(from, to)
44
46
  };
45
47
  };
46
48
  const addReaction = (context, itemId, reaction = {}, allowDuplicate = false) => {
47
49
  const action = "addReaction";
48
50
  const { database, session: { userId: sessionId } } = context;
49
51
  if (!sessionId) {
50
- return (0, import_utils2.logException)({
52
+ return (0, import_analyticsUtils.logException)({
51
53
  action,
52
54
  category: eventCategory,
53
55
  label: "unauthorized",
@@ -84,10 +86,10 @@ const addReaction = (context, itemId, reaction = {}, allowDuplicate = false) =>
84
86
  return edgeCollection.save(edge, { returnNew: true }).then(() => edge);
85
87
  }).catch((error) => {
86
88
  console.log("addReaction::error", error);
87
- return (0, import_utils2.logError)({
89
+ return (0, import_analyticsUtils.logError)({
88
90
  action,
89
91
  category: eventCategory,
90
- label: "db_error"
92
+ label: import_error.ErrorTypes.DATABASE_ERROR
91
93
  }, error, context).then(() => null);
92
94
  });
93
95
  }
@@ -97,7 +99,7 @@ const deleteReaction = (context, reactionId) => {
97
99
  const action = "deleteReaction";
98
100
  const { database, session: { userId: sessionId } } = context;
99
101
  if (!sessionId) {
100
- return (0, import_utils2.logException)({
102
+ return (0, import_analyticsUtils.logException)({
101
103
  action,
102
104
  category: eventCategory,
103
105
  label: "unauthorized",
@@ -111,17 +113,17 @@ const deleteReaction = (context, reactionId) => {
111
113
  LIMIT 1
112
114
  REMOVE r IN hasReaction
113
115
  RETURN OLD`;
114
- return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
116
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
115
117
  action,
116
118
  category: eventCategory,
117
- label: "db_error"
119
+ label: import_error.ErrorTypes.DATABASE_ERROR
118
120
  }, error, context).then(() => null));
119
121
  };
120
122
  const deleteReactionByItem = (context, itemId, reactionName) => {
121
123
  const action = "deleteReactionByItem";
122
124
  const { database, session: { userId: sessionId } } = context;
123
125
  if (!sessionId) {
124
- return (0, import_utils2.logException)({
126
+ return (0, import_analyticsUtils.logException)({
125
127
  action,
126
128
  category: eventCategory,
127
129
  label: "unauthorized",
@@ -136,17 +138,17 @@ const deleteReactionByItem = (context, itemId, reactionName) => {
136
138
  LIMIT 1
137
139
  REMOVE r IN hasReaction
138
140
  RETURN OLD`;
139
- return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
141
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
140
142
  action,
141
143
  category: eventCategory,
142
- label: "db_error"
144
+ label: import_error.ErrorTypes.DATABASE_ERROR
143
145
  }, error, context).then(() => null));
144
146
  };
145
147
  const updateReaction = (context, reaction = {}) => {
146
148
  const action = "updateReaction";
147
149
  const { database, session: { userId: sessionId } } = context;
148
150
  if (!sessionId) {
149
- return (0, import_utils2.logException)({
151
+ return (0, import_analyticsUtils.logException)({
150
152
  action,
151
153
  category: eventCategory,
152
154
  label: "unauthorized",
@@ -176,10 +178,10 @@ const updateReaction = (context, reaction = {}) => {
176
178
  UPDATE ${update}
177
179
  LIMIT 1
178
180
  RETURN NEW`;
179
- return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
181
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
180
182
  action,
181
183
  category: eventCategory,
182
- label: "db_error"
184
+ label: import_error.ErrorTypes.DATABASE_ERROR
183
185
  }, error, context).then(() => null));
184
186
  };
185
187
  const getReactionCount = (context, itemId, reactionName) => {
@@ -191,10 +193,10 @@ const getReactionCount = (context, itemId, reactionName) => {
191
193
  FILTER r.name == ${formatReactionName}
192
194
  COLLECT WITH COUNT INTO count
193
195
  RETURN count`;
194
- return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
196
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
195
197
  action,
196
198
  category: eventCategory,
197
- label: "db_error"
199
+ label: import_error.ErrorTypes.DATABASE_ERROR
198
200
  }, error, context).then(() => void 0));
199
201
  };
200
202
  const getReactionCountByUser = (context, itemId, itemType, reactionName) => {
@@ -207,17 +209,17 @@ const getReactionCountByUser = (context, itemId, itemType, reactionName) => {
207
209
  FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}
208
210
  COLLECT reactionValue = r.value INTO reactionItems
209
211
  RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;
210
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
212
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
211
213
  action,
212
214
  category: eventCategory,
213
- label: "db_error"
215
+ label: import_error.ErrorTypes.DATABASE_ERROR
214
216
  }, error, context).then(() => []));
215
217
  };
216
218
  const getGroupUsersByReaction = (context, params = {}) => {
217
219
  const action = "getGroupUsersByReaction";
218
220
  const { database, session: { userId: sessionId } } = context;
219
221
  if (!sessionId) {
220
- return (0, import_utils2.logException)({
222
+ return (0, import_analyticsUtils.logException)({
221
223
  action,
222
224
  category: eventCategory,
223
225
  label: "unauthorized",
@@ -247,10 +249,10 @@ const getGroupUsersByReaction = (context, params = {}) => {
247
249
  FOR u IN users
248
250
  FILTER ${filterStr}
249
251
  RETURN u`;
250
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
252
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
251
253
  action,
252
254
  category: eventCategory,
253
- label: "db_error"
255
+ label: import_error.ErrorTypes.DATABASE_ERROR
254
256
  }, error, context).then(() => []));
255
257
  };
256
258
  const getReactionsByItem = (context, itemId, reactionName, options) => {
@@ -263,10 +265,10 @@ const getReactionsByItem = (context, itemId, reactionName, options) => {
263
265
  FILTER r.name == "${formatReactionName}"
264
266
  ${limit.aql}
265
267
  RETURN MERGE(i, {reaction: r})`;
266
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
268
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
267
269
  action,
268
270
  category: eventCategory,
269
- label: "db_error"
271
+ label: import_error.ErrorTypes.DATABASE_ERROR
270
272
  }, error, context).then(() => []));
271
273
  };
272
274
  const getItemsByReaction = (context, itemId, reactionName, options) => {
@@ -279,10 +281,10 @@ const getItemsByReaction = (context, itemId, reactionName, options) => {
279
281
  FILTER r.name == ${formatReactionName}
280
282
  ${limit.aql}
281
283
  RETURN MERGE(u, {reaction: r})`;
282
- return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_utils2.logError)({
284
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
283
285
  action,
284
286
  category: eventCategory,
285
- label: "db_error"
287
+ label: import_error.ErrorTypes.DATABASE_ERROR
286
288
  }, error, context).then(() => []));
287
289
  };
288
290
  const hasReaction = (context, itemId, reactionName, direction = "OUTBOUND") => {
@@ -297,10 +299,10 @@ const hasReaction = (context, itemId, reactionName, direction = "OUTBOUND") => {
297
299
  LIMIT 1
298
300
  RETURN r`;
299
301
  console.log({ aqlQry });
300
- return database.query(aqlQry).then((cursor) => cursor.next()).then((reactions) => reactions ? reactions.value === "true" : false).catch((error) => (0, import_utils2.logError)({
302
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((reactions) => reactions ? reactions.value === "true" : false).catch((error) => (0, import_analyticsUtils.logError)({
301
303
  action,
302
304
  category: eventCategory,
303
- label: "db_error"
305
+ label: import_error.ErrorTypes.DATABASE_ERROR
304
306
  }, error, context).then(() => false));
305
307
  };
306
308
  // Annotate the CommonJS export names for ESM import in node:
@@ -317,4 +319,4 @@ const hasReaction = (context, itemId, reactionName, direction = "OUTBOUND") => {
317
319
  parseReactionOptions,
318
320
  updateReaction
319
321
  });
320
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/reactions.ts"],
  "sourcesContent": ["import {createHash, parseArangoId, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\n\nimport {ApiContext, AppCollectionTypes, QueryFilter, User, UserReactionQuery} from '../types';\nimport {getLimit, logError, logException} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport type ReactionDirection = 'INBOUND' | 'OUTBOUND';\n\nexport interface Reaction {\n  readonly _from?: string;\n  readonly _key?: string;\n  readonly _to?: string;\n  readonly added?: number;\n  readonly count?: number;\n  readonly id?: string;\n  readonly name?: string;\n  readonly type?: AppCollectionTypes;\n  readonly value?: string;\n}\n\nexport interface ReactionOptions {\n  readonly from?: number;\n  readonly to?: number;\n}\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  reaction: Reaction = {},\n  allowDuplicate: boolean = false\n): Promise<Reaction> => {\n  const action: string = 'addReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection: EdgeCollection = database.collection('hasReaction');\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: Reaction = {\n    _from: sessionDocId,\n    _key: edgeId,\n    _to: formatItemId,\n    added: Date.now(),\n    name: formatReactionName,\n    value: itemValue !== undefined ? formatValue : undefined\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReaction\n      FILTER r._from == ${sessionDocId} && r._to == ${formatItemId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n      })\n      .catch((error: Error) => {\n        console.log('addReaction::error', error);\n        return logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, context).then(() => null);\n      });\n  }\n\n  return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n};\n\nexport const deleteReaction = (context: ApiContext, reactionId: string): Promise<Reaction> => {\n  const action: string = 'deleteReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReaction/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionId}\n    LIMIT 1\n    REMOVE r IN hasReaction\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\nexport const deleteReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string\n): Promise<Reaction> => {\n  const action: string = 'deleteReactionByItem';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemDocId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(reactionName);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r in hasReaction\n    FILTER r._from == ${formatSessionId} && r._to == ${formatItemDocId} && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReaction\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\nexport const updateReaction = (context: ApiContext, reaction: Reaction = {}): Promise<Reaction> => {\n  const action: string = 'updateReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    id: itemId,\n    name: itemName,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseArangoId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: Reaction = {\n    name: formatName,\n    value: formatValue\n  };\n  const insert: Reaction = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_id: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    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      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string\n): Promise<Reaction> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${formatItemId} hasReaction\n    FILTER r.name == ${formatReactionName}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\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(() => undefined));\n};\n\nexport const getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<Reaction[]> => {\n  const action: string = 'getReactionCountByUser';\n  const {database, session: {userId: sessionId}} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${formatItemId} hasReaction\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;\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(() => []));\n};\n\nexport const getGroupUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<User[]> => {\n  const action: string = 'getGroupUsersByReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = parseArangoId(groupId);\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReaction\n      FOR u IN users\n      FILTER ${filterStr}\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: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<User[]> => {\n  const action: string = 'getReactionsByItem';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${formatItemId}\" hasReaction\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: r})`;\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(() => []));\n};\n\nexport const getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<Reaction[]> => {\n  const action: string = 'getItemsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatItemId}\" hasReaction\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: r})`;\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(() => []));\n};\n\nexport const hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<boolean> => {\n  const action: string = 'hasReaction';\n  const {database, session: {userId: sessionId}} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReaction\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${formatItemId}\"\n    LIMIT 1\n    RETURN r`;\n\n  console.log({aqlQry});\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((reactions) => (reactions ? reactions.value === 'true' : false))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => false));\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "reaction"]
}

322
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/reactions.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, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\n\nimport type {ApiContext, ArangoDbCollection, ArangoDbLimit, QueryFilter, UserType, UserReactionQuery} from '../types';\nimport {logError, logException} from '../utils/analyticsUtils';\nimport {ErrorTypes} from '../types/error';\nimport {getLimit} from '../utils/arangodbUtils';\n\nconst eventCategory: string = 'reactions';\n\nexport type ReactionDirection = 'INBOUND' | 'OUTBOUND';\n\nexport interface Reaction {\n  readonly _from?: string;\n  readonly _key?: string;\n  readonly _to?: string;\n  readonly added?: number;\n  readonly count?: number;\n  readonly id?: string;\n  readonly name?: string;\n  readonly type?: ArangoDbCollection;\n  readonly value?: string;\n}\n\nexport interface ReactionOptions {\n  readonly from?: number;\n  readonly to?: number;\n}\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\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 addReaction = (\n  context: ApiContext,\n  itemId: string,\n  reaction: Reaction = {},\n  allowDuplicate: boolean = false\n): Promise<Reaction> => {\n  const action: string = 'addReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection: EdgeCollection = database.collection('hasReaction');\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: Reaction = {\n    _from: sessionDocId,\n    _key: edgeId,\n    _to: formatItemId,\n    added: Date.now(),\n    name: formatReactionName,\n    value: itemValue !== undefined ? formatValue : undefined\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReaction\n      FILTER r._from == ${sessionDocId} && r._to == ${formatItemId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n      })\n      .catch((error: Error) => {\n        console.log('addReaction::error', error);\n        return logError({\n          action,\n          category: eventCategory,\n          label: ErrorTypes.DATABASE_ERROR\n        }, error, context).then(() => null);\n      });\n  }\n\n  return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n};\n\nexport const deleteReaction = (context: ApiContext, reactionId: string): Promise<Reaction> => {\n  const action: string = 'deleteReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReaction/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionId}\n    LIMIT 1\n    REMOVE r IN hasReaction\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).then(() => null));\n};\n\nexport const deleteReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string\n): Promise<Reaction> => {\n  const action: string = 'deleteReactionByItem';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemDocId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(reactionName);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r in hasReaction\n    FILTER r._from == ${formatSessionId} && r._to == ${formatItemDocId} && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReaction\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).then(() => null));\n};\n\nexport const updateReaction = (context: ApiContext, reaction: Reaction = {}): Promise<Reaction> => {\n  const action: string = 'updateReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    id: itemId,\n    name: itemName,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseArangoId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: Reaction = {\n    name: formatName,\n    value: formatValue\n  };\n  const insert: Reaction = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_id: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    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      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string\n): Promise<Reaction> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${formatItemId} hasReaction\n    FILTER r.name == ${formatReactionName}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\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).then(() => undefined));\n};\n\nexport const getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<Reaction[]> => {\n  const action: string = 'getReactionCountByUser';\n  const {database, session: {userId: sessionId}} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${formatItemId} hasReaction\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;\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).then(() => []));\n};\n\nexport const getGroupUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getGroupUsersByReaction';\n  const {database, session: {userId: sessionId}} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = parseArangoId(groupId);\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReaction\n      FOR u IN users\n      FILTER ${filterStr}\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).then(() => []));\n};\n\nexport const getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getReactionsByItem';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${formatItemId}\" hasReaction\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: r})`;\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).then(() => []));\n};\n\nexport const getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<Reaction[]> => {\n  const action: string = 'getItemsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatItemId}\" hasReaction\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: r})`;\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).then(() => []));\n};\n\nexport const hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<boolean> => {\n  const action: string = 'hasReaction';\n  const {database, session: {userId: sessionId}} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseArangoId(itemId);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReaction\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${formatItemId}\"\n    LIMIT 1\n    RETURN r`;\n\n  console.log({aqlQry});\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((reactions) => (reactions ? reactions.value === 'true' : false))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => false));\n};\n"],
  "mappings": "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",
  "names": ["reaction"]
}

@@ -1,7 +1,7 @@
1
- import { DeleteObjectOutput, DeleteObjectRequest, DeleteObjectsOutput, DeleteObjectsRequest, GetObjectOutput, GetObjectRequest, HeadObjectOutput, HeadObjectRequest, PutObjectOutput, PutObjectRequest } from 'aws-sdk/clients/s3';
2
- export declare const s3Get: (params: GetObjectRequest) => Promise<GetObjectOutput>;
3
- export declare const s3Head: (params: HeadObjectRequest) => Promise<HeadObjectOutput>;
4
- export declare const s3Put: (params: PutObjectRequest) => Promise<PutObjectOutput>;
5
- export declare const s3Delete: (params: DeleteObjectRequest) => Promise<DeleteObjectOutput>;
6
- export declare const s3DeleteList: (params: DeleteObjectsRequest) => Promise<DeleteObjectsOutput>;
7
- export declare const s3GetSignedUrl: (params?: any) => string;
1
+ import { DeleteObjectCommandInput, DeleteObjectCommandOutput, DeleteObjectsCommandInput, DeleteObjectsCommandOutput, GetObjectCommandInput, GetObjectCommandOutput, HeadObjectCommandInput, HeadObjectCommandOutput, PutObjectCommandInput, PutObjectCommandOutput } from '@aws-sdk/client-s3';
2
+ export declare const s3Get: (params: GetObjectCommandInput) => Promise<GetObjectCommandOutput>;
3
+ export declare const s3Head: (params: HeadObjectCommandInput) => Promise<HeadObjectCommandOutput>;
4
+ export declare const s3Put: (params: PutObjectCommandInput) => Promise<PutObjectCommandOutput>;
5
+ export declare const s3Delete: (params: DeleteObjectCommandInput) => Promise<DeleteObjectCommandOutput>;
6
+ export declare const s3DeleteList: (params: DeleteObjectsCommandInput) => Promise<DeleteObjectsCommandOutput>;
7
+ export declare const s3GetSignedUrl: (params?: any) => Promise<string>;
package/lib/actions/s3.js CHANGED
@@ -1,8 +1,6 @@
1
- var __create = Object.create;
2
1
  var __defProp = Object.defineProperty;
3
2
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
3
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
4
  var __hasOwnProp = Object.prototype.hasOwnProperty;
7
5
  var __export = (target, all) => {
8
6
  for (var name in all)
@@ -16,14 +14,6 @@ var __copyProps = (to, from, except, desc) => {
16
14
  }
17
15
  return to;
18
16
  };
19
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
- // If the importer is in node compatibility mode or this is not an ESM
21
- // file that has been converted to a CommonJS file using a Babel-
22
- // compatible transform (i.e. "__esModule" has not been set), then set
23
- // "default" to the CommonJS "module.exports" for node compatibility.
24
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
- mod
26
- ));
27
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
18
  var s3_exports = {};
29
19
  __export(s3_exports, {
@@ -35,13 +25,16 @@ __export(s3_exports, {
35
25
  s3Put: () => s3Put
36
26
  });
37
27
  module.exports = __toCommonJS(s3_exports);
38
- var import_aws_sdk = __toESM(require("aws-sdk"));
28
+ var import_client_s3 = require("@aws-sdk/client-s3");
29
+ var import_s3_request_presigner = require("@aws-sdk/s3-request-presigner");
39
30
  var import_config = require("../config");
40
31
  const s3Get = (params) => new Promise((resolve, reject) => {
41
- import_aws_sdk.default.config.update(import_config.Config.get("aws"));
42
- const s3 = new import_aws_sdk.S3();
32
+ const s3 = new import_client_s3.S3({
33
+ credentials: import_config.Config.get("aws.credentials"),
34
+ region: import_config.Config.get("aws.region")
35
+ });
43
36
  if (!params.Bucket) {
44
- params.Bucket = import_config.Config.get("aws.Bucket");
37
+ params.Bucket = import_config.Config.get("aws.s3.bucket");
45
38
  }
46
39
  s3.getObject(params, (error, output) => {
47
40
  if (error) {
@@ -51,10 +44,12 @@ const s3Get = (params) => new Promise((resolve, reject) => {
51
44
  });
52
45
  });
53
46
  const s3Head = (params) => new Promise((resolve, reject) => {
54
- import_aws_sdk.default.config.update(import_config.Config.get("aws"));
55
- const s3 = new import_aws_sdk.S3();
47
+ const s3 = new import_client_s3.S3({
48
+ credentials: import_config.Config.get("aws.credentials"),
49
+ region: import_config.Config.get("aws.region")
50
+ });
56
51
  if (!params.Bucket) {
57
- params.Bucket = import_config.Config.get("aws.Bucket");
52
+ params.Bucket = import_config.Config.get("aws.s3.bucket");
58
53
  }
59
54
  s3.headObject(params, (error, output) => {
60
55
  if (error) {
@@ -64,10 +59,12 @@ const s3Head = (params) => new Promise((resolve, reject) => {
64
59
  });
65
60
  });
66
61
  const s3Put = (params) => new Promise((resolve, reject) => {
67
- import_aws_sdk.default.config.update(import_config.Config.get("aws"));
68
- const s3 = new import_aws_sdk.default.S3();
62
+ const s3 = new import_client_s3.S3({
63
+ credentials: import_config.Config.get("aws.credentials"),
64
+ region: import_config.Config.get("aws.region")
65
+ });
69
66
  if (!params.Bucket) {
70
- params.Bucket = import_config.Config.get("aws.Bucket");
67
+ params.Bucket = import_config.Config.get("aws.s3.bucket");
71
68
  }
72
69
  if (!params.StorageClass) {
73
70
  params.StorageClass = "REDUCED_REDUNDANCY";
@@ -80,10 +77,12 @@ const s3Put = (params) => new Promise((resolve, reject) => {
80
77
  });
81
78
  });
82
79
  const s3Delete = (params) => new Promise((resolve, reject) => {
83
- import_aws_sdk.default.config.update(import_config.Config.get("aws"));
84
- const s3 = new import_aws_sdk.S3();
80
+ const s3 = new import_client_s3.S3({
81
+ credentials: import_config.Config.get("aws.credentials"),
82
+ region: import_config.Config.get("aws.region")
83
+ });
85
84
  if (!params.Bucket) {
86
- params.Bucket = import_config.Config.get("aws.Bucket");
85
+ params.Bucket = import_config.Config.get("aws.s3.bucket");
87
86
  }
88
87
  s3.deleteObject(params, (error, output) => {
89
88
  if (error) {
@@ -93,10 +92,12 @@ const s3Delete = (params) => new Promise((resolve, reject) => {
93
92
  });
94
93
  });
95
94
  const s3DeleteList = (params) => new Promise((resolve, reject) => {
96
- import_aws_sdk.default.config.update(import_config.Config.get("aws"));
97
- const s3 = new import_aws_sdk.S3();
95
+ const s3 = new import_client_s3.S3({
96
+ credentials: import_config.Config.get("aws.credentials"),
97
+ region: import_config.Config.get("aws.region")
98
+ });
98
99
  if (!params.Bucket) {
99
- params.Bucket = import_config.Config.get("aws.Bucket");
100
+ params.Bucket = import_config.Config.get("aws.s3.bucket");
100
101
  }
101
102
  s3.deleteObjects(params, (error, output) => {
102
103
  if (error) {
@@ -105,16 +106,20 @@ const s3DeleteList = (params) => new Promise((resolve, reject) => {
105
106
  return resolve(output);
106
107
  });
107
108
  });
108
- const s3GetSignedUrl = (params = {}) => {
109
- import_aws_sdk.default.config.update(import_config.Config.get("aws"));
110
- const s3 = new import_aws_sdk.S3();
109
+ const s3GetSignedUrl = async (params = {}) => {
110
+ const s3 = new import_client_s3.S3({
111
+ credentials: import_config.Config.get("aws.credentials"),
112
+ region: import_config.Config.get("aws.region")
113
+ });
111
114
  if (!params.Expires) {
112
115
  params.Expires = 12 * 60 * 60;
113
116
  }
114
117
  if (!params.Bucket) {
115
- params.Bucket = import_config.Config.get("aws.Bucket");
118
+ params.Bucket = import_config.Config.get("aws.s3.bucket");
116
119
  }
117
- return s3.getSignedUrl("getObject", params);
120
+ return await (0, import_s3_request_presigner.getSignedUrl)(s3, new import_client_s3.GetObjectCommand(params), {
121
+ expiresIn: params.Expires
122
+ });
118
123
  };
119
124
  // Annotate the CommonJS export names for ESM import in node:
120
125
  0 && (module.exports = {
@@ -125,4 +130,4 @@ const s3GetSignedUrl = (params = {}) => {
125
130
  s3Head,
126
131
  s3Put
127
132
  });
128
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvczMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgYXdzLCB7UzN9IGZyb20gJ2F3cy1zZGsnO1xuaW1wb3J0IHtcbiAgRGVsZXRlT2JqZWN0T3V0cHV0LFxuICBEZWxldGVPYmplY3RSZXF1ZXN0LFxuICBEZWxldGVPYmplY3RzT3V0cHV0LFxuICBEZWxldGVPYmplY3RzUmVxdWVzdCxcbiAgR2V0T2JqZWN0T3V0cHV0LFxuICBHZXRPYmplY3RSZXF1ZXN0LFxuICBIZWFkT2JqZWN0T3V0cHV0LFxuICBIZWFkT2JqZWN0UmVxdWVzdCxcbiAgUHV0T2JqZWN0T3V0cHV0LFxuICBQdXRPYmplY3RSZXF1ZXN0XG59IGZyb20gJ2F3cy1zZGsvY2xpZW50cy9zMyc7XG5cbmltcG9ydCB7Q29uZmlnfSBmcm9tICcuLi9jb25maWcnO1xuXG4vLyBBV1MgUzNcbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzMyc7XG5cbmV4cG9ydCBjb25zdCBzM0dldCA9IChwYXJhbXM6IEdldE9iamVjdFJlcXVlc3QpOiBQcm9taXNlPEdldE9iamVjdE91dHB1dD4gPT5cbiAgbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGF3cy5jb25maWcudXBkYXRlKENvbmZpZy5nZXQoJ2F3cycpKTtcbiAgICBjb25zdCBzMzogUzMgPSBuZXcgUzMoKTtcblxuICAgIGlmKCFwYXJhbXMuQnVja2V0KSB7XG4gICAgICBwYXJhbXMuQnVja2V0ID0gQ29uZmlnLmdldCgnYXdzLkJ1Y2tldCcpO1xuICAgIH1cblxuICAgIHMzLmdldE9iamVjdChwYXJhbXMsIChlcnJvcjogRXJyb3IsIG91dHB1dDogR2V0T2JqZWN0T3V0cHV0KSA9PiB7XG4gICAgICBpZihlcnJvcikge1xuICAgICAgICByZXR1cm4gcmVqZWN0KGVycm9yKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHJlc29sdmUob3V0cHV0KTtcbiAgICB9KTtcbiAgfSk7XG5cbmV4cG9ydCBjb25zdCBzM0hlYWQgPSAocGFyYW1zOiBIZWFkT2JqZWN0UmVxdWVzdCk6IFByb21pc2U8SGVhZE9iamVjdE91dHB1dD4gPT5cbiAgbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGF3cy5jb25maWcudXBkYXRlKENvbmZpZy5nZXQoJ2F3cycpKTtcbiAgICBjb25zdCBzMzogUzMgPSBuZXcgUzMoKTtcblxuICAgIGlmKCFwYXJhbXMuQnVja2V0KSB7XG4gICAgICBwYXJhbXMuQnVja2V0ID0gQ29uZmlnLmdldCgnYXdzLkJ1Y2tldCcpO1xuICAgIH1cblxuICAgIHMzLmhlYWRPYmplY3QocGFyYW1zLCAoZXJyb3I6IEVycm9yLCBvdXRwdXQ6IEhlYWRPYmplY3RPdXRwdXQpID0+IHtcbiAgICAgIGlmKGVycm9yKSB7XG4gICAgICAgIHJldHVybiByZWplY3QoZXJyb3IpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIHJlc29sdmUob3V0cHV0KTtcbiAgICB9KTtcbiAgfSk7XG5cblxuZXhwb3J0IGNvbnN0IHMzUHV0ID0gKHBhcmFtczogUHV0T2JqZWN0UmVxdWVzdCk6IFByb21pc2U8UHV0T2JqZWN0T3V0cHV0PiA9PlxuICBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgYXdzLmNvbmZpZy51cGRhdGUoQ29uZmlnLmdldCgnYXdzJykpO1xuICAgIGNvbnN0IHMzID0gbmV3IGF3cy5TMygpO1xuXG4gICAgaWYoIXBhcmFtcy5CdWNrZXQpIHtcbiAgICAgIHBhcmFtcy5CdWNrZXQgPSBDb25maWcuZ2V0KCdhd3MuQnVja2V0Jyk7XG4gICAgfVxuXG4gICAgaWYoIXBhcmFtcy5TdG9yYWdlQ2xhc3MpIHtcbiAgICAgIHBhcmFtcy5TdG9yYWdlQ2xhc3MgPSAnUkVEVUNFRF9SRURVTkRBTkNZJztcbiAgICB9XG5cbiAgICBzMy5wdXRPYmplY3QocGFyYW1zLCAoZXJyb3I6IEVycm9yLCBvdXRwdXQ6IFB1dE9iamVjdE91dHB1dCkgPT4ge1xuICAgICAgaWYoZXJyb3IpIHtcbiAgICAgICAgcmV0dXJuIHJlamVjdChlcnJvcik7XG4gICAgICB9XG4gICAgICByZXR1cm4gcmVzb2x2ZShvdXRwdXQpO1xuICAgIH0pO1xuICB9KTtcblxuZXhwb3J0IGNvbnN0IHMzRGVsZXRlID0gKHBhcmFtczogRGVsZXRlT2JqZWN0UmVxdWVzdCk6IFByb21pc2U8RGVsZXRlT2JqZWN0T3V0cHV0PiA9PlxuICBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgYXdzLmNvbmZpZy51cGRhdGUoQ29uZmlnLmdldCgnYXdzJykpO1xuICAgIGNvbnN0IHMzOiBTMyA9IG5ldyBTMygpO1xuXG4gICAgaWYoIXBhcmFtcy5CdWNrZXQpIHtcbiAgICAgIHBhcmFtcy5CdWNrZXQgPSBDb25maWcuZ2V0KCdhd3MuQnVja2V0Jyk7XG4gICAgfVxuXG4gICAgczMuZGVsZXRlT2JqZWN0KHBhcmFtcywgKGVycm9yLCBvdXRwdXQ6IERlbGV0ZU9iamVjdE91dHB1dCkgPT4ge1xuICAgICAgaWYoZXJyb3IpIHtcbiAgICAgICAgcmV0dXJuIHJlamVjdChlcnJvcik7XG4gICAgICB9XG4gICAgICByZXR1cm4gcmVzb2x2ZShvdXRwdXQpO1xuICAgIH0pO1xuICB9KTtcblxuZXhwb3J0IGNvbnN0IHMzRGVsZXRlTGlzdCA9IChwYXJhbXM6IERlbGV0ZU9iamVjdHNSZXF1ZXN0KTogUHJvbWlzZTxEZWxldGVPYmplY3RzT3V0cHV0PiA9PlxuICBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgYXdzLmNvbmZpZy51cGRhdGUoQ29uZmlnLmdldCgnYXdzJykpO1xuICAgIGNvbnN0IHMzOiBTMyA9IG5ldyBTMygpO1xuXG4gICAgaWYoIXBhcmFtcy5CdWNrZXQpIHtcbiAgICAgIHBhcmFtcy5CdWNrZXQgPSBDb25maWcuZ2V0KCdhd3MuQnVja2V0Jyk7XG4gICAgfVxuXG4gICAgczMuZGVsZXRlT2JqZWN0cyhwYXJhbXMsIChlcnJvcjogRXJyb3IsIG91dHB1dDogRGVsZXRlT2JqZWN0c091dHB1dCkgPT4ge1xuICAgICAgaWYoZXJyb3IpIHtcbiAgICAgICAgcmV0dXJuIHJlamVjdChlcnJvcik7XG4gICAgICB9XG4gICAgICByZXR1cm4gcmVzb2x2ZShvdXRwdXQpO1xuICAgIH0pO1xuICB9KTtcblxuZXhwb3J0IGNvbnN0IHMzR2V0U2lnbmVkVXJsID0gKHBhcmFtczogYW55ID0ge30pOiBzdHJpbmcgPT4ge1xuICBhd3MuY29uZmlnLnVwZGF0ZShDb25maWcuZ2V0KCdhd3MnKSk7XG4gIGNvbnN0IHMzOiBTMyA9IG5ldyBTMygpO1xuXG4gIGlmKCFwYXJhbXMuRXhwaXJlcykge1xuICAgIHBhcmFtcy5FeHBpcmVzID0gMTIgKiA2MCAqIDYwO1xuICB9XG5cbiAgaWYoIXBhcmFtcy5CdWNrZXQpIHtcbiAgICBwYXJhbXMuQnVja2V0ID0gQ29uZmlnLmdldCgnYXdzLkJ1Y2tldCcpO1xuICB9XG5cbiAgcmV0dXJuIHMzLmdldFNpZ25lZFVybCgnZ2V0T2JqZWN0JywgcGFyYW1zKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLHFCQUFzQjtBQWN0QixvQkFBcUI7QUFLZCxNQUFNLFFBQVEsQ0FBQyxXQUNwQixJQUFJLFFBQVEsQ0FBQyxTQUFTLFdBQVc7QUFDL0IsaUJBQUFBLFFBQUksT0FBTyxPQUFPLHFCQUFPLElBQUksS0FBSyxDQUFDO0FBQ25DLFFBQU0sS0FBUyxJQUFJLGtC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
133
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/s3.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 {\n  DeleteObjectCommandInput,\n  DeleteObjectCommandOutput,\n  DeleteObjectsCommandInput,\n  DeleteObjectsCommandOutput,\n  GetObjectCommand,\n  GetObjectCommandInput,\n  GetObjectCommandOutput,\n  HeadObjectCommandInput,\n  HeadObjectCommandOutput,\n  PutObjectCommandInput,\n  PutObjectCommandOutput,\n  S3\n} from '@aws-sdk/client-s3';\nimport {getSignedUrl} from '@aws-sdk/s3-request-presigner';\n\nimport {Config} from '../config';\n\n// const eventCategory: string = 's3';\nexport const s3Get = (params: GetObjectCommandInput): Promise<GetObjectCommandOutput> =>\n  new Promise((resolve, reject) => {\n    const s3: S3 = new S3({\n      credentials: Config.get('aws.credentials'),\n      region: Config.get('aws.region')\n    });\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.s3.bucket');\n    }\n\n    s3.getObject(params, (error: Error, output: GetObjectCommandOutput) => {\n      if(error) {\n        return reject(error);\n      }\n\n      return resolve(output);\n    });\n  });\n\nexport const s3Head = (params: HeadObjectCommandInput): Promise<HeadObjectCommandOutput> =>\n  new Promise((resolve, reject) => {\n    const s3: S3 = new S3({\n      credentials: Config.get('aws.credentials'),\n      region: Config.get('aws.region')\n    });\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.s3.bucket');\n    }\n\n    s3.headObject(params, (error: Error, output: HeadObjectCommandOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3Put = (params: PutObjectCommandInput): Promise<PutObjectCommandOutput> =>\n  new Promise((resolve, reject) => {\n    const s3 = new S3({\n      credentials: Config.get('aws.credentials'),\n      region: Config.get('aws.region')\n    });\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.s3.bucket');\n    }\n\n    if(!params.StorageClass) {\n      params.StorageClass = 'REDUCED_REDUNDANCY';\n    }\n\n    s3.putObject(params, (error: Error, output: PutObjectCommandOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3Delete = (params: DeleteObjectCommandInput): Promise<DeleteObjectCommandOutput> =>\n  new Promise((resolve, reject) => {\n    const s3: S3 = new S3({\n      credentials: Config.get('aws.credentials'),\n      region: Config.get('aws.region')\n    });\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.s3.bucket');\n    }\n\n    s3.deleteObject(params, (error, output: DeleteObjectCommandOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3DeleteList = (params: DeleteObjectsCommandInput): Promise<DeleteObjectsCommandOutput> =>\n  new Promise((resolve, reject) => {\n    const s3: S3 = new S3({\n      credentials: Config.get('aws.credentials'),\n      region: Config.get('aws.region')\n    });\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.s3.bucket');\n    }\n\n    s3.deleteObjects(params, (error: Error, output: DeleteObjectsCommandOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3GetSignedUrl = async (params: any = {}): Promise<string> => {\n  const s3: S3 = new S3({\n    credentials: Config.get('aws.credentials'),\n    region: Config.get('aws.region')\n  });\n\n  if(!params.Expires) {\n    params.Expires = 12 * 60 * 60;\n  }\n\n  if(!params.Bucket) {\n    params.Bucket = Config.get('aws.s3.bucket');\n  }\n\n  return await getSignedUrl(s3, new GetObjectCommand(params), {\n    expiresIn: params.Expires\n  });\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -1,3 +1,3 @@
1
- import { ApiContext } from '../types/auth';
2
- import { User } from '../types/users';
3
- export declare const getSearchList: (context: ApiContext, query: string, from: number, to: number) => Promise<User[]>;
1
+ import type { ApiContext } from '../types/auth';
2
+ import type { UserType } from '../types/users';
3
+ export declare const getSearchList: (context: ApiContext, query: string, from: number, to: number) => Promise<UserType[]>;
@@ -33,8 +33,10 @@ module.exports = __toCommonJS(search_exports);
33
33
  var import_arangojs = require("arangojs");
34
34
  var import_flatten = __toESM(require("lodash/flatten"));
35
35
  var import_uniqBy = __toESM(require("lodash/uniqBy"));
36
- var import_utils = require("../utils");
37
- var import_users2 = require("./users");
36
+ var import_analyticsUtils = require("../utils/analyticsUtils");
37
+ var import_users = require("./users");
38
+ var import_error = require("../types/error");
39
+ var import_arangodbUtils = require("../utils/arangodbUtils");
38
40
  const eventCategory = "search";
39
41
  const getSearchList = (context, query, from, to) => {
40
42
  const action = "getList";
@@ -58,26 +60,26 @@ const getSearchList = (context, query, from, to) => {
58
60
  const { _id: itemId, name: itemName } = item;
59
61
  const collectionIdList = itemId.split("/");
60
62
  const collection = collectionIdList[0];
61
- const name = collection === "users" ? (0, import_users2.getDisplayName)(item) : itemName;
63
+ const name = collection === "users" ? (0, import_users.getDisplayName)(item) : itemName;
62
64
  return { ...item, name };
63
65
  });
64
66
  });
65
67
  }
66
- const limit = (0, import_utils.getLimit)(from, to);
68
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
67
69
  const aqlQry = `FOR u IN users
68
70
  FILTER u.phone == "${query}"
69
71
  ${limit.aql}
70
72
  RETURN u`;
71
- return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list.map((item = {}) => {
73
+ return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list.map((item) => {
72
74
  const { _id: itemId, name: itemName } = item;
73
75
  const collectionIdList = itemId.split("/");
74
76
  const collection = collectionIdList[0];
75
- const name = collection === "users" ? (0, import_users2.getDisplayName)(item) : itemName;
77
+ const name = collection === "users" ? (0, import_users.getDisplayName)(item) : itemName;
76
78
  return { ...item, name };
77
- })).catch((error) => (0, import_utils.logException)({
79
+ })).catch((error) => (0, import_analyticsUtils.logException)({
78
80
  action,
79
81
  category: eventCategory,
80
- label: "db_error",
82
+ label: import_error.ErrorTypes.DATABASE_ERROR,
81
83
  value: error.message
82
84
  }, context).then(() => null));
83
85
  };
@@ -85,4 +87,4 @@ const getSearchList = (context, query, from, to) => {
85
87
  0 && (module.exports = {
86
88
  getSearchList
87
89
  });
88
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc2VhcmNoLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHthcWx9IGZyb20gJ2FyYW5nb2pzJztcbmltcG9ydCB7QXFsUXVlcnl9IGZyb20gJ2FyYW5nb2pzL2FxbCc7XG5pbXBvcnQge0FycmF5Q3Vyc29yfSBmcm9tICdhcmFuZ29qcy9jdXJzb3InO1xuaW1wb3J0IGZsYXR0ZW4gZnJvbSAnbG9kYXNoL2ZsYXR0ZW4nO1xuaW1wb3J0IHVuaXFCeSBmcm9tICdsb2Rhc2gvdW5pcUJ5JztcblxuaW1wb3J0IHtBcmFuZ29EQkxpbWl0fSBmcm9tICcuLi90eXBlcy9hcmFuZ29kYic7XG5pbXBvcnQge0FwaUNvbnRleHR9IGZyb20gJy4uL3R5cGVzL2F1dGgnO1xuaW1wb3J0IHtVc2VyfSBmcm9tICcuLi90eXBlcy91c2Vycyc7XG5pbXBvcnQge2dldExpbWl0LCBsb2dFeGNlcHRpb259IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7Z2V0RGlzcGxheU5hbWV9IGZyb20gJy4vdXNlcnMnO1xuXG5jb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnc2VhcmNoJztcblxuZXhwb3J0IGNvbnN0IGdldFNlYXJjaExpc3QgPSAoY29udGV4dDogQXBpQ29udGV4dCwgcXVlcnk6IHN0cmluZywgZnJvbTogbnVtYmVyLCB0bzogbnVtYmVyKTogUHJvbWlzZTxVc2VyW10+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0TGlzdCc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBpc1N0cmluZzogYm9vbGVhbiA9IHRydWU7XG5cbiAgaWYoaXNTdHJpbmcpIHtcbiAgICBjb25zdCBmaWVsZHM6IGFueVtdID0gW1xuICAgICAge2NvbGxlY3Rpb246ICd1c2VycycsIGZpZWxkOiAnZmlyc3QnfSxcbiAgICAgIHtjb2xsZWN0aW9uOiAndXNlcnMnLCBmaWVsZDogJ2xhc3QnfSxcbiAgICAgIHtjb2xsZWN0aW9uOiAndXNlcnMnLCBmaWVsZDogJ2VtYWlsJ30sXG4gICAgICB7Y29sbGVjdGlvbjogJ3VzZXJzJywgZmllbGQ6ICd1c2VybmFtZSd9LFxuICAgICAge2NvbGxlY3Rpb246ICd1c2VycycsIGZpZWxkOiAnbmFtZSd9XG4gICAgXTtcblxuICAgIHJldHVybiBQcm9taXNlLmFsbChmaWVsZHMubWFwKChvYmopID0+IHtcbiAgICAgIGNvbnN0IHFyeTogc3RyaW5nID0gYHByZWZpeDoke3F1ZXJ5fWA7XG4gICAgICBjb25zdCB1c2VyUXJ5OiBBcWxRdWVyeSA9IGFxbGBGT1IgdSBJTiBGVUxMVEVYVCgke29iai5jb2xsZWN0aW9ufSwgJHtvYmouZmllbGR9LCAke3FyeX0sIDUwKSBSRVRVUk4gdWA7XG4gICAgICByZXR1cm4gZGF0YWJhc2UucXVlcnkodXNlclFyeSkudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKTtcbiAgICB9KSlcbiAgICAgIC50aGVuKChyZXN1bHRzKSA9PiB7XG4gICAgICAgIGNvbnN0IGxpc3QgPSB1bmlxQnkoZmxhdHRlbihyZXN1bHRzKSwgJ19rZXknKTtcblxuICAgICAgICByZXR1cm4gbGlzdC5tYXAoKGl0ZW06IFVzZXIpID0+IHtcbiAgICAgICAgICBjb25zdCB7X2lkOiBpdGVtSWQsIG5hbWU6IGl0ZW1OYW1lfSA9IGl0ZW07XG4gICAgICAgICAgY29uc3QgY29sbGVjdGlvbklkTGlzdDogc3RyaW5nW10gPSBpdGVtSWQuc3BsaXQoJy8nKTtcbiAgICAgICAgICBjb25zdCBjb2xsZWN0aW9uOiBzdHJpbmcgPSBjb2xsZWN0aW9uSWRMaXN0WzBdO1xuICAgICAgICAgIGNvbnN0IG5hbWU6IHN0cmluZyA9IGNvbGxlY3Rpb24gPT09ICd1c2VycycgPyBnZXREaXNwbGF5TmFtZShpdGVtKSA6IGl0ZW1OYW1lO1xuXG4gICAgICAgICAgcmV0dXJuIHsuLi5pdGVtLCBuYW1lfTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgfVxuXG4gIGNvbnN0IGxpbWl0OiBBcmFuZ29EQkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgdSBJTiB1c2Vyc1xuICAgICAgICBGSUxURVIgdS5waG9uZSA9PSBcIiR7cXVlcnl9XCJcbiAgICAgICAgJHtsaW1pdC5hcWx9XG4gICAgICAgIFJFVFVSTiB1YDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgLnRoZW4oKGxpc3Q6IFVzZXJbXSA9IFtdKSA9PiBsaXN0Lm1hcCgoaXRlbSA9IHt9KSA9PiB7XG4gICAgICBjb25zdCB7X2lkOiBpdGVtSWQsIG5hbWU6IGl0ZW1OYW1lfSA9IGl0ZW07XG4gICAgICBjb25zdCBjb2xsZWN0aW9uSWRMaXN0OiBzdHJpbmdbXSA9IGl0ZW1JZC5zcGxpdCgnLycpO1xuICAgICAgY29uc3QgY29sbGVjdGlvbjogc3RyaW5nID0gY29sbGVjdGlvbklkTGlzdFswXTtcbiAgICAgIGNvbnN0IG5hbWU6IHN0cmluZyA9IGNvbGxlY3Rpb24gPT09ICd1c2VycycgPyBnZXREaXNwbGF5TmFtZShpdGVtKSA6IGl0ZW1OYW1lO1xuXG4gICAgICByZXR1cm4gey4uLml0ZW0sIG5hbWV9O1xuICAgIH0pKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFeGNlcHRpb24oe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJyxcbiAgICAgIHZhbHVlOiBlcnJvci5tZXNzYWdlXG4gICAgfSwgY29udGV4dCkudGhlbigoKSA9PiBudWxsKSk7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLHNCQUFrQjtBQUdsQixxQkFBb0I7QUFDcEIsb0JBQW1CO0FBS25CLG1CQUFxQztBQUNyQyxJQUFBQSxnQkFBNkI7QUFFN0IsTUFBTSxnQkFBd0I7QUFFdkIsTUFBTSxnQkFBZ0IsQ0FBQyxTQUFxQixPQUFlLE1BQWMsT0FBZ0M7QUFDOUcsUUFBTSxTQUFpQjtBQUN2QixRQUFNLEVBQUMsU0FBUSxJQUFJO0FBQ25CLFFBQU0sV0FBb0I7QUFFMUIsTUFBRyxVQUFVO0FBQ1gsVUFBTSxTQUFnQjtBQUFBLE1BQ3BCLEVBQUMsWUFBWSxTQUFTLE9BQU8sUUFBTztBQUFBLE1BQ3BDLEVBQUMsWUFBWSxTQUFTLE9BQU8sT0FBTTtBQUFBLE1BQ25DLEVBQUMsWUFBWSxTQUFTLE9BQU8sUUFBTztBQUFBLE1BQ3BDLEVBQUMsWUFBWSxTQUFTLE9BQU8sV0FBVTtBQUFBLE1BQ3ZDLEVBQUMsWUFBWSxTQUFTLE9BQU8sT0FBTTtBQUFBLElBQ3JDO0FBRUEsV0FBTyxRQUFRLElBQUksT0FBTyxJQUFJLENBQUMsUUFBUTtBQUNyQyxZQUFNLE1BQWMsVUFBVSxLQUFLO0FBQ25DLFlBQU0sVUFBb0Isd0NBQXdCLElBQUksVUFBVSxLQUFLLElBQUksS0FBSyxLQUFLLEdBQUc7QUFDdEYsYUFBTyxTQUFTLE1BQU0sT0FBTyxFQUFFLEtBQUssQ0FBQyxXQUF3QixPQUFPLElBQUksQ0FBQztBQUFBLElBQzNFLENBQUMsQ0FBQyxFQUNDLEtBQUssQ0FBQyxZQUFZO0FBQ2pCLFlBQU0sV0FBTyxjQUFBQyxhQUFPLGVBQUFDLFNBQVEsT0FBTyxHQUFHLE1BQU07QUFFNUMsYUFBTyxLQUFLLElBQUksQ0FBQyxTQUFlO0FBQzlCLGNBQU0sRUFBQyxLQUFLLFFBQVEsTUFBTSxTQUFRLElBQUk7QUFDdEMsY0FBTSxtQkFBNkIsT0FBTyxNQUFNLEdBQUc7QUFDbkQsY0FBTSxhQUFxQixpQkFBaUIsQ0FBQztBQUM3QyxjQUFNLE9BQWUsZUFBZSxjQUFVLDhCQUFlLElBQUksSUFBSTtBQUVyRSxlQUFPLEVBQUMsR0FBRyxNQUFNLEtBQUk7QUFBQSxNQUN2QixDQUFDO0FBQUEsSUFDSCxDQUFDO0FBQUEsRUFDTDtBQUVBLFFBQU0sWUFBdUIsdUJBQVMsTUFBTSxFQUFFO0FBQzlDLFFBQU0sU0FBaUI7QUFBQSw2QkFDSSxLQUFLO0FBQUEsVUFDeEIsTUFBTSxHQUFHO0FBQUE7QUFHakIsU0FBTyxTQUFTLE1BQU0sTUFBTSxFQUN6QixLQUFLLENBQUMsV0FBd0IsT0FBTyxJQUFJLENBQUMsRUFDMUMsS0FBSyxDQUFDLE9BQWUsQ0FBQyxNQUFNLEtBQUssSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNO0FBQ25ELFVBQU0sRUFBQyxLQUFLLFFBQVEsTUFBTSxTQUFRLElBQUk7QUFDdEMsVUFBTSxtQkFBNkIsT0FBTyxNQUFNLEdBQUc7QUFDbkQsVUFBTSxhQUFxQixpQkFBaUIsQ0FBQztBQUM3QyxVQUFNLE9BQWUsZUFBZSxjQUFVLDhCQUFlLElBQUksSUFBSTtBQUVyRSxXQUFPLEVBQUMsR0FBRyxNQUFNLEtBQUk7QUFBQSxFQUN2QixDQUFDLENBQUMsRUFDRCxNQUFNLENBQUMsY0FBaUIsMkJBQWE7QUFBQSxJQUNwQztBQUFBLElBQ0EsVUFBVTtBQUFBLElBQ1YsT0FBTztBQUFBLElBQ1AsT0FBTyxNQUFNO0FBQUEsRUFDZixHQUFHLE9BQU8sRUFBRSxLQUFLLE1BQU0sSUFBSSxDQUFDO0FBQ2hDOyIsCiAgIm5hbWVzIjogWyJpbXBvcnRfdXNlcnMiLCAidW5pcUJ5IiwgImZsYXR0ZW4iXQp9Cg==
90
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc2VhcmNoLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHthcWx9IGZyb20gJ2FyYW5nb2pzJztcbmltcG9ydCB7QXFsUXVlcnl9IGZyb20gJ2FyYW5nb2pzL2FxbCc7XG5pbXBvcnQge0FycmF5Q3Vyc29yfSBmcm9tICdhcmFuZ29qcy9jdXJzb3InO1xuaW1wb3J0IGZsYXR0ZW4gZnJvbSAnbG9kYXNoL2ZsYXR0ZW4nO1xuaW1wb3J0IHVuaXFCeSBmcm9tICdsb2Rhc2gvdW5pcUJ5JztcblxuaW1wb3J0IHR5cGUge0FyYW5nb0RiTGltaXR9IGZyb20gJy4uL3R5cGVzL2FyYW5nb2RiJztcbmltcG9ydCB0eXBlIHtBcGlDb250ZXh0fSBmcm9tICcuLi90eXBlcy9hdXRoJztcbmltcG9ydCB0eXBlIHtVc2VyVHlwZX0gZnJvbSAnLi4vdHlwZXMvdXNlcnMnO1xuaW1wb3J0IHtsb2dFeGNlcHRpb259IGZyb20gJy4uL3V0aWxzL2FuYWx5dGljc1V0aWxzJztcbmltcG9ydCB7Z2V0RGlzcGxheU5hbWV9IGZyb20gJy4vdXNlcnMnO1xuaW1wb3J0IHtFcnJvclR5cGVzfSBmcm9tICcuLi90eXBlcy9lcnJvcic7XG5pbXBvcnQge2dldExpbWl0fSBmcm9tICcuLi91dGlscy9hcmFuZ29kYlV0aWxzJztcblxuY29uc3QgZXZlbnRDYXRlZ29yeTogc3RyaW5nID0gJ3NlYXJjaCc7XG5cbmV4cG9ydCBjb25zdCBnZXRTZWFyY2hMaXN0ID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHF1ZXJ5OiBzdHJpbmcsIGZyb206IG51bWJlciwgdG86IG51bWJlcik6IFByb21pc2U8VXNlclR5cGVbXT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRMaXN0JztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGlzU3RyaW5nOiBib29sZWFuID0gdHJ1ZTtcblxuICBpZihpc1N0cmluZykge1xuICAgIGNvbnN0IGZpZWxkczogYW55W10gPSBbXG4gICAgICB7Y29sbGVjdGlvbjogJ3VzZXJzJywgZmllbGQ6ICdmaXJzdCd9LFxuICAgICAge2NvbGxlY3Rpb246ICd1c2VycycsIGZpZWxkOiAnbGFzdCd9LFxuICAgICAge2NvbGxlY3Rpb246ICd1c2VycycsIGZpZWxkOiAnZW1haWwnfSxcbiAgICAgIHtjb2xsZWN0aW9uOiAndXNlcnMnLCBmaWVsZDogJ3VzZXJuYW1lJ30sXG4gICAgICB7Y29sbGVjdGlvbjogJ3VzZXJzJywgZmllbGQ6ICduYW1lJ31cbiAgICBdO1xuXG4gICAgcmV0dXJuIFByb21pc2UuYWxsKGZpZWxkcy5tYXAoKG9iaikgPT4ge1xuICAgICAgY29uc3QgcXJ5OiBzdHJpbmcgPSBgcHJlZml4OiR7cXVlcnl9YDtcbiAgICAgIGNvbnN0IHVzZXJRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiB1IElOIEZVTExURVhUKCR7b2JqLmNvbGxlY3Rpb259LCAke29iai5maWVsZH0sICR7cXJ5fSwgNTApIFJFVFVSTiB1YDtcbiAgICAgIHJldHVybiBkYXRhYmFzZS5xdWVyeSh1c2VyUXJ5KS50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpO1xuICAgIH0pKVxuICAgICAgLnRoZW4oKHJlc3VsdHMpID0+IHtcbiAgICAgICAgY29uc3QgbGlzdCA9IHVuaXFCeShmbGF0dGVuKHJlc3VsdHMpLCAnX2tleScpO1xuXG4gICAgICAgIHJldHVybiBsaXN0Lm1hcCgoaXRlbTogVXNlclR5cGUpID0+IHtcbiAgICAgICAgICBjb25zdCB7X2lkOiBpdGVtSWQsIG5hbWU6IGl0ZW1OYW1lfSA9IGl0ZW07XG4gICAgICAgICAgY29uc3QgY29sbGVjdGlvbklkTGlzdDogc3RyaW5nW10gPSBpdGVtSWQuc3BsaXQoJy8nKTtcbiAgICAgICAgICBjb25zdCBjb2xsZWN0aW9uOiBzdHJpbmcgPSBjb2xsZWN0aW9uSWRMaXN0WzBdO1xuICAgICAgICAgIGNvbnN0IG5hbWU6IHN0cmluZyA9IGNvbGxlY3Rpb24gPT09ICd1c2VycycgPyBnZXREaXNwbGF5TmFtZShpdGVtKSA6IGl0ZW1OYW1lO1xuXG4gICAgICAgICAgcmV0dXJuIHsuLi5pdGVtLCBuYW1lfTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgfVxuXG4gIGNvbnN0IGxpbWl0OiBBcmFuZ29EYkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgdSBJTiB1c2Vyc1xuICAgICAgICBGSUxURVIgdS5waG9uZSA9PSBcIiR7cXVlcnl9XCJcbiAgICAgICAgJHtsaW1pdC5hcWx9XG4gICAgICAgIFJFVFVSTiB1YDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgLnRoZW4oKGxpc3Q6IFVzZXJUeXBlW10gPSBbXSkgPT4gbGlzdC5tYXAoKGl0ZW0pID0+IHtcbiAgICAgIGNvbnN0IHtfaWQ6IGl0ZW1JZCwgbmFtZTogaXRlbU5hbWV9ID0gaXRlbTtcbiAgICAgIGNvbnN0IGNvbGxlY3Rpb25JZExpc3Q6IHN0cmluZ1tdID0gaXRlbUlkLnNwbGl0KCcvJyk7XG4gICAgICBjb25zdCBjb2xsZWN0aW9uOiBzdHJpbmcgPSBjb2xsZWN0aW9uSWRMaXN0WzBdO1xuICAgICAgY29uc3QgbmFtZTogc3RyaW5nID0gY29sbGVjdGlvbiA9PT0gJ3VzZXJzJyA/IGdldERpc3BsYXlOYW1lKGl0ZW0pIDogaXRlbU5hbWU7XG5cbiAgICAgIHJldHVybiB7Li4uaXRlbSwgbmFtZX07XG4gICAgfSkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0V4Y2VwdGlvbih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SLFxuICAgICAgdmFsdWU6IGVycm9yLm1lc3NhZ2VcbiAgICB9LCBjb250ZXh0KS50aGVuKCgpID0+IG51bGwpKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBSUEsc0JBQWtCO0FBR2xCLHFCQUFvQjtBQUNwQixvQkFBbUI7QUFLbkIsNEJBQTJCO0FBQzNCLG1CQUE2QjtBQUM3QixtQkFBeUI7QUFDekIsMkJBQXVCO0FBRXZCLE1BQU0sZ0JBQXdCO0FBRXZCLE1BQU0sZ0JBQWdCLENBQUMsU0FBcUIsT0FBZSxNQUFjLE9BQW9DO0FBQ2xILFFBQU0sU0FBaUI7QUFDdkIsUUFBTSxFQUFDLFNBQVEsSUFBSTtBQUNuQixRQUFNLFdBQW9CO0FBRTFCLE1BQUcsVUFBVTtBQUNYLFVBQU0sU0FBZ0I7QUFBQSxNQUNwQixFQUFDLFlBQVksU0FBUyxPQUFPLFFBQU87QUFBQSxNQUNwQyxFQUFDLFlBQVksU0FBUyxPQUFPLE9BQU07QUFBQSxNQUNuQyxFQUFDLFlBQVksU0FBUyxPQUFPLFFBQU87QUFBQSxNQUNwQyxFQUFDLFlBQVksU0FBUyxPQUFPLFdBQVU7QUFBQSxNQUN2QyxFQUFDLFlBQVksU0FBUyxPQUFPLE9BQU07QUFBQSxJQUNyQztBQUVBLFdBQU8sUUFBUSxJQUFJLE9BQU8sSUFBSSxDQUFDLFFBQVE7QUFDckMsWUFBTSxNQUFjLFVBQVUsS0FBSztBQUNuQyxZQUFNLFVBQW9CLHdDQUF3QixJQUFJLFVBQVUsS0FBSyxJQUFJLEtBQUssS0FBSyxHQUFHO0FBQ3RGLGFBQU8sU0FBUyxNQUFNLE9BQU8sRUFBRSxLQUFLLENBQUMsV0FBd0IsT0FBTyxJQUFJLENBQUM7QUFBQSxJQUMzRSxDQUFDLENBQUMsRUFDQyxLQUFLLENBQUMsWUFBWTtBQUNqQixZQUFNLFdBQU8sY0FBQUEsYUFBTyxlQUFBQyxTQUFRLE9BQU8sR0FBRyxNQUFNO0FBRTVDLGFBQU8sS0FBSyxJQUFJLENBQUMsU0FBbUI7QUFDbEMsY0FBTSxFQUFDLEtBQUssUUFBUSxNQUFNLFNBQVEsSUFBSTtBQUN0QyxjQUFNLG1CQUE2QixPQUFPLE1BQU0sR0FBRztBQUNuRCxjQUFNLGFBQXFCLGlCQUFpQixDQUFDO0FBQzdDLGNBQU0sT0FBZSxlQUFlLGNBQVUsNkJBQWUsSUFBSSxJQUFJO0FBRXJFLGVBQU8sRUFBQyxHQUFHLE1BQU0sS0FBSTtBQUFBLE1BQ3ZCLENBQUM7QUFBQSxJQUNILENBQUM7QUFBQSxFQUNMO0FBRUEsUUFBTSxZQUF1QiwrQkFBUyxNQUFNLEVBQUU7QUFDOUMsUUFBTSxTQUFpQjtBQUFBLDZCQUNJLEtBQUs7QUFBQSxVQUN4QixNQUFNLEdBQUc7QUFBQTtBQUdqQixTQUFPLFNBQVMsTUFBTSxNQUFNLEVBQ3pCLEtBQUssQ0FBQyxXQUF3QixPQUFPLElBQUksQ0FBQyxFQUMxQyxLQUFLLENBQUMsT0FBbUIsQ0FBQyxNQUFNLEtBQUssSUFBSSxDQUFDLFNBQVM7QUFDbEQsVUFBTSxFQUFDLEtBQUssUUFBUSxNQUFNLFNBQVEsSUFBSTtBQUN0QyxVQUFNLG1CQUE2QixPQUFPLE1BQU0sR0FBRztBQUNuRCxVQUFNLGFBQXFCLGlCQUFpQixDQUFDO0FBQzdDLFVBQU0sT0FBZSxlQUFlLGNBQVUsNkJBQWUsSUFBSSxJQUFJO0FBRXJFLFdBQU8sRUFBQyxHQUFHLE1BQU0sS0FBSTtBQUFBLEVBQ3ZCLENBQUMsQ0FBQyxFQUNELE1BQU0sQ0FBQyxjQUFpQixvQ0FBYTtBQUFBLElBQ3BDO0FBQUEsSUFDQSxVQUFVO0FBQUEsSUFDVixPQUFPLHdCQUFXO0FBQUEsSUFDbEIsT0FBTyxNQUFNO0FBQUEsRUFDZixHQUFHLE9BQU8sRUFBRSxLQUFLLE1BQU0sSUFBSSxDQUFDO0FBQ2hDOyIsCiAgIm5hbWVzIjogWyJ1bmlxQnkiLCAiZmxhdHRlbiJdCn0K
@@ -1,3 +1,3 @@
1
1
  import { SMSParamsType } from '../types/notifications';
2
- export declare const sendSms: (params: SMSParamsType) => any;
3
- export declare const sendSmsTemplate: (templateName: string, smsParams: SMSParamsType) => Promise<boolean>;
2
+ export declare const sendSms: ({ content, user, variables }: SMSParamsType) => Promise<any>;
3
+ export declare const sendSmsTemplate: (templateName: string, { user, variables }: SMSParamsType) => Promise<boolean>;