@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
@@ -0,0 +1,252 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var apps_exports = {};
19
+ __export(apps_exports, {
20
+ addApp: () => addApp,
21
+ deactivateApp: () => deactivateApp,
22
+ deleteApp: () => deleteApp,
23
+ getApp: () => getApp,
24
+ getAppOptional: () => getAppOptional,
25
+ getApps: () => getApps,
26
+ parseAppOptions: () => parseAppOptions,
27
+ updateApp: () => updateApp
28
+ });
29
+ module.exports = __toCommonJS(apps_exports);
30
+ var import_arangojs = require("arangojs");
31
+ var import_utils = require("@nlabs/utils");
32
+ var import_error = require("../types/error");
33
+ var import_analyticsUtils = require("../utils/analyticsUtils");
34
+ var import_arangodbUtils = require("../utils/arangodbUtils");
35
+ var import_session = require("../utils/session");
36
+ const eventCategory = "apps";
37
+ const getAppOptional = (fields = []) => fields.reduce((selects, field) => {
38
+ if (field.includes("Count")) {
39
+ return (0, import_arangodbUtils.selectReactionCountByType)("apps", "a", field, selects);
40
+ }
41
+ return selects;
42
+ }, { objects: [], queries: [] });
43
+ const parseAppOptions = (options = {}) => {
44
+ const {
45
+ from = 0,
46
+ to = 30
47
+ } = options;
48
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
49
+ return {
50
+ ...options,
51
+ limit
52
+ };
53
+ };
54
+ const addApp = async (context, app) => {
55
+ const action = "addUser";
56
+ const { database } = context;
57
+ const { email, name, phone } = app;
58
+ const formatName = (0, import_utils.parseString)(name);
59
+ const formatEmail = (0, import_utils.parseEmail)(email);
60
+ const formatPhone = (0, import_utils.parsePhone)(phone);
61
+ if (!formatName) {
62
+ return (0, import_analyticsUtils.logException)({
63
+ action,
64
+ category: eventCategory,
65
+ params: { name },
66
+ value: import_error.ErrorTypes.INVALID_ARGUMENTS
67
+ }, context);
68
+ }
69
+ const filters = [`a.name == "${formatName}"`];
70
+ if (formatEmail) {
71
+ filters.push(`a.email == "${formatEmail}"`);
72
+ }
73
+ const checkQuery = `FOR u IN users
74
+ FILTER ${filters.join(" || ")}
75
+ RETURN u`;
76
+ try {
77
+ const existingApps = await database.query(checkQuery).then((cursor) => cursor.all());
78
+ if (existingApps.length) {
79
+ return (0, import_analyticsUtils.logException)({
80
+ action,
81
+ category: eventCategory,
82
+ value: import_error.ErrorTypes.EXISTING_ITEM,
83
+ params: { name }
84
+ }, context);
85
+ }
86
+ } catch (error) {
87
+ return (0, import_analyticsUtils.logError)({
88
+ action,
89
+ category: eventCategory,
90
+ label: import_error.ErrorTypes.DATABASE_ERROR,
91
+ params: { name }
92
+ }, error, context);
93
+ }
94
+ const insert = {
95
+ _key: (0, import_utils.createHash)(name, null),
96
+ active: true,
97
+ added: Date.now(),
98
+ email: formatEmail,
99
+ modified: Date.now(),
100
+ phone: formatPhone,
101
+ name: formatName
102
+ };
103
+ const insertQuery = import_arangojs.aql`INSERT ${insert} IN apps RETURN NEW`;
104
+ return await database.query(insertQuery).then((cursor) => cursor.next() || {}).catch((error) => (0, import_analyticsUtils.logError)({
105
+ action,
106
+ category: eventCategory,
107
+ label: import_error.ErrorTypes.DATABASE_ERROR,
108
+ params: { name }
109
+ }, error, context));
110
+ };
111
+ const updateApp = async (context, app) => {
112
+ const action = "updateApp";
113
+ const { database } = context;
114
+ const { _key, _id, id, appId, ...updated } = app;
115
+ const appDocId = (0, import_arangodbUtils.getDocId)("apps", app);
116
+ const appQuery = import_arangojs.aql`LET a = DOCUMENT(${appDocId})
117
+ UPDATE a WITH ${updated} IN apps
118
+ RETURN NEW`;
119
+ return await database.query(appQuery).then((cursor) => cursor.next()).catch(
120
+ (error) => (0, import_analyticsUtils.logError)({
121
+ action,
122
+ category: eventCategory,
123
+ label: import_error.ErrorTypes.DATABASE_ERROR,
124
+ params: { app }
125
+ }, error, context)
126
+ );
127
+ };
128
+ const deleteApp = async (context, app) => {
129
+ const action = "deleteApp";
130
+ const { database, session } = context;
131
+ const isAdmin = (0, import_session.isAdminUser)(session);
132
+ const appDocId = (0, import_arangodbUtils.getDocId)("apps", app);
133
+ if (!isAdmin) {
134
+ return (0, import_analyticsUtils.logException)({
135
+ action,
136
+ category: eventCategory,
137
+ label: "unauthorized",
138
+ params: app,
139
+ value: import_error.ErrorTypes.INVALID_SESSION
140
+ }, context);
141
+ }
142
+ const aqlQuery = import_arangojs.aql`FOR a IN apps
143
+ FILTER a._id == \"${appDocId}\"
144
+ LIMIT 1
145
+ REMOVE a IN apps
146
+ RETURN OLD`;
147
+ return database.query(aqlQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
148
+ action,
149
+ category: eventCategory,
150
+ label: import_error.ErrorTypes.DATABASE_ERROR,
151
+ params: app
152
+ }, error, context));
153
+ };
154
+ const deactivateApp = (context, app) => {
155
+ const action = "deactivateApp";
156
+ const { database, session } = context;
157
+ const isAdmin = (0, import_session.isAdminUser)(session);
158
+ const appDocId = (0, import_arangodbUtils.getDocId)("apps", app);
159
+ if (!isAdmin) {
160
+ return (0, import_analyticsUtils.logException)({
161
+ action,
162
+ category: eventCategory,
163
+ label: "unauthorized",
164
+ value: import_error.ErrorTypes.INVALID_SESSION
165
+ }, context);
166
+ }
167
+ const updated = {
168
+ active: false
169
+ };
170
+ const aqlQuery = import_arangojs.aql`UPDATE ${appDocId} WITH ${updated} IN apps LIMIT 1 RETURN NEW`;
171
+ return database.query(aqlQuery).then((cursor) => cursor.next()).catch((error) => {
172
+ throw error;
173
+ });
174
+ };
175
+ const getApp = (context, options) => {
176
+ const action = "getApp";
177
+ const { database, fields, session } = context;
178
+ const { id, key, name } = parseAppOptions(options);
179
+ const { objects: selectObjects, queries: selectQueries } = getAppOptional(fields);
180
+ const filterBy = ["a.active == true"];
181
+ const isAdmin = (0, import_session.isAdminUser)(session);
182
+ if (!isAdmin) {
183
+ return (0, import_analyticsUtils.logException)({
184
+ action,
185
+ category: eventCategory,
186
+ label: "unauthorized",
187
+ value: import_error.ErrorTypes.INVALID_SESSION
188
+ }, context);
189
+ }
190
+ if (id) {
191
+ filterBy.push(`a._id == "${(0, import_utils.parseArangoId)(id)}"`);
192
+ }
193
+ if (key) {
194
+ filterBy.push(`a._key == "apps/${(0, import_utils.parseId)(key)}"`);
195
+ }
196
+ if (name) {
197
+ filterBy.push(`CONTAINS(a.name, "${(0, import_utils.parseString)(name)}")`);
198
+ }
199
+ const aqlQuery = `FOR a IN apps
200
+ FILTER ${filterBy.join(" && ")}
201
+ ${selectQueries.join("\n")}
202
+ RETURN MERGE(a, {${selectObjects.join(", ")}})`;
203
+ return database.query(aqlQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
204
+ action,
205
+ category: eventCategory,
206
+ label: import_error.ErrorTypes.DATABASE_ERROR,
207
+ params: options
208
+ }, error, context));
209
+ };
210
+ const getApps = (context, options) => {
211
+ const action = "getApps";
212
+ const { database, fields, session } = context;
213
+ const { limit, name } = parseAppOptions(options);
214
+ const { objects: selectObjects, queries: selectQueries } = getAppOptional(fields);
215
+ const filterBy = ["a.active == true"];
216
+ const isAdmin = (0, import_session.isAdminUser)(session);
217
+ if (!isAdmin) {
218
+ return (0, import_analyticsUtils.logException)({
219
+ action,
220
+ category: eventCategory,
221
+ label: "unauthorized",
222
+ value: import_error.ErrorTypes.INVALID_SESSION
223
+ }, context);
224
+ }
225
+ if (name) {
226
+ filterBy.push(`CONTAINS(a.name, "${(0, import_utils.parseString)(name)}")`);
227
+ }
228
+ const aqlQuery = `FOR a IN apps
229
+ FILTER ${filterBy.join(" && ")}
230
+ ${selectQueries.join("\n")}
231
+ ${limit.aql}
232
+ SORT a.name
233
+ RETURN MERGE(a, {${selectObjects.join(", ")}})`;
234
+ return database.query(aqlQuery).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
235
+ action,
236
+ category: eventCategory,
237
+ label: import_error.ErrorTypes.DATABASE_ERROR,
238
+ params: options
239
+ }, error, context));
240
+ };
241
+ // Annotate the CommonJS export names for ESM import in node:
242
+ 0 && (module.exports = {
243
+ addApp,
244
+ deactivateApp,
245
+ deleteApp,
246
+ getApp,
247
+ getAppOptional,
248
+ getApps,
249
+ parseAppOptions,
250
+ updateApp
251
+ });
252
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/apps.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 {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {createHash, parseArangoId, parseEmail, parseId, parsePhone, parseString} from '@nlabs/utils';\n\nimport {AppType} from '../types/apps';\nimport {ErrorTypes} from '../types/error';\nimport {logError, logException} from '../utils/analyticsUtils';\nimport {getDocId, getLimit, selectReactionCountByType} from '../utils/arangodbUtils';\nimport {isAdminUser} from '../utils/session';\nimport type {ApiContext} from '../types/auth';\nimport type {UserType} from '../types/users';\n\nconst eventCategory: string = 'apps';\n\nexport interface AppOptions {\n  readonly id?: string;\n  readonly key?: string;\n  readonly from?: number;\n  readonly name?: string;\n  readonly to?: number;\n}\n\nexport const getAppOptional = (fields: string[] = []) =>\n  fields.reduce((selects: any, field: string) => {\n    if(field.includes('Count')) {\n      return selectReactionCountByType('apps', 'a', field, selects);\n    }\n\n    return selects;\n  }, {objects: [], queries: []});\n\nexport const parseAppOptions = (options: AppOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n  const limit = getLimit(from, to);\n\n  return {\n    ...options,\n    limit\n  };\n};\n\nexport const addApp = async (context: ApiContext, app: AppType): Promise<UserType> => {\n  const action = 'addUser';\n  const {database} = context;\n  const {email, name, phone} = app;\n  const formatName = parseString(name);\n  const formatEmail = parseEmail(email);\n  const formatPhone = parsePhone(phone);\n\n  if(!formatName) {\n    return logException({\n      action,\n      category: eventCategory,\n      params: {name},\n      value: ErrorTypes.INVALID_ARGUMENTS\n    }, context);\n  }\n\n  const filters: string[] = [`a.name == \"${formatName}\"`];\n\n  if(formatEmail) {\n    filters.push(`a.email == \"${formatEmail}\"`);\n  }\n\n  const checkQuery: string = `FOR u IN users\n    FILTER ${filters.join(' || ')}\n    RETURN u`;\n\n  try {\n    const existingApps = await database.query(checkQuery).then((cursor: ArrayCursor) => cursor.all());\n\n    if(existingApps.length) {\n      return logException({\n        action,\n        category: eventCategory,\n        value: ErrorTypes.EXISTING_ITEM,\n        params: {name}\n      }, context);\n    }\n  } catch(error) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: {name}\n    }, error, context);\n  }\n\n  const insert: AppType = {\n    _key: createHash(name, null),\n    active: true,\n    added: Date.now(),\n    email: formatEmail,\n    modified: Date.now(),\n    phone: formatPhone,\n    name: formatName\n  };\n\n  const insertQuery: AqlQuery = aql`INSERT ${insert} IN apps RETURN NEW`;\n\n  return await database.query(insertQuery)\n    .then((cursor: ArrayCursor) => cursor.next() || {})\n    .catch((error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: {name}\n    }, error, context));\n};\n\nexport const updateApp = async (context: ApiContext, app: AppType): Promise<AppType> => {\n  const action: string = 'updateApp';\n  const {database} = context;\n  const {_key, _id, id, appId, ...updated} = app;\n  const appDocId = getDocId('apps', app);\n  const appQuery: AqlQuery = aql`LET a = DOCUMENT(${appDocId})\n    UPDATE a WITH ${updated} IN apps\n    RETURN NEW`;\n\n  return await database.query(appQuery)\n    .then((cursor) => cursor.next())\n    .catch((error) =>\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR,\n        params: {app}\n      }, error, context)\n    );\n};\n\nexport const deleteApp = async (context: ApiContext, app: AppType): Promise<AppType> => {\n  const action: string = 'deleteApp';\n  const {database, session} = context;\n  const isAdmin = isAdminUser(session);\n  const appDocId = getDocId('apps', app);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      params: app,\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  const aqlQuery: AqlQuery = aql`FOR a IN apps\n    FILTER a._id == \\\"${appDocId}\\\"\n    LIMIT 1\n    REMOVE a IN apps\n    RETURN OLD`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error) =>\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR,\n        params: app\n      }, error, context));\n};\n\nexport const deactivateApp = (context: ApiContext, app: AppType): Promise<UserType> => {\n  const action: string = 'deactivateApp';\n  const {database, session} = context;\n  const isAdmin = isAdminUser(session);\n  const appDocId = getDocId('apps', app);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  const updated: AppType = {\n    active: false\n  };\n  const aqlQuery: AqlQuery = aql`UPDATE ${appDocId} WITH ${updated} IN apps LIMIT 1 RETURN NEW`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getApp = (context: ApiContext, options?: AppOptions): Promise<AppType> => {\n  const action: string = 'getApp';\n  const {database, fields, session} = context;\n  const {id, key, name} = parseAppOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getAppOptional(fields);\n  const filterBy: string[] = ['a.active == true'];\n  const isAdmin = isAdminUser(session);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  if(id) {\n    filterBy.push(`a._id == \"${parseArangoId(id)}\"`);\n  }\n\n  if(key) {\n    filterBy.push(`a._key == \"apps/${parseId(key)}\"`);\n  }\n\n  if(name) {\n    filterBy.push(`CONTAINS(a.name, \"${parseString(name)}\")`);\n  }\n\n  // Get data from database\n  const aqlQuery: string = `FOR a IN apps\n    FILTER ${filterBy.join(' && ')}\n    ${selectQueries.join('\\n')}\n    RETURN MERGE(a, {${selectObjects.join(', ')}})`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: options\n    }, error, context));\n};\n\nexport const getApps = (context: ApiContext, options?: AppOptions): Promise<AppType[]> => {\n  const action: string = 'getApps';\n  const {database, fields, session} = context;\n  const {limit, name} = parseAppOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getAppOptional(fields);\n  const filterBy: string[] = ['a.active == true'];\n  const isAdmin = isAdminUser(session);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  if(name) {\n    filterBy.push(`CONTAINS(a.name, \"${parseString(name)}\")`);\n  }\n\n  // Get data from database\n  const aqlQuery: string = `FOR a IN apps\n    FILTER ${filterBy.join(' && ')}\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT a.name\n    RETURN MERGE(a, {${selectObjects.join(', ')}})`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: options\n    }, error, context));\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -1,14 +1,14 @@
1
- import { ConnectionType, ConversationOptions, ConversationType } from '../types';
2
- import { ApiContext } from '../types/auth';
1
+ import type { ArangoDbLimit, ConnectionType, ConversationOptions, ConversationType, ConversationUsersParams, DirectConversationParams, UpdateConversationUserParams } from '../types';
2
+ import type { ApiContext } from '../types/auth';
3
3
  export declare const parseConversationOptions: (options?: ConversationOptions) => {
4
- limit: import("types/arangodb").ArangoDBLimit;
4
+ limit: ArangoDbLimit;
5
5
  };
6
- export declare const getConversations: (context: ApiContext, options?: any) => Promise<ConversationType[]>;
7
- export declare const getDirectConversation: (context: ApiContext, fromId: string, toId: string) => Promise<ConversationType>;
8
- export declare const getConnectionUsers: (context: ApiContext, conversationId: string, includeAll?: boolean, isDirect?: boolean) => Promise<ConnectionType[]>;
9
- export declare const getConversationUsers: (context: ApiContext, conversationId: string, includeAll?: boolean, isDirect?: boolean) => Promise<ConversationType[]>;
10
- export declare const getDirectConversationOld: (context: ApiContext, userId: string) => Promise<ConversationType>;
11
- export declare const getConversation: (context: ApiContext, convoId: string) => Promise<ConversationType>;
12
- export declare const updateConversation: (context: ApiContext, conversation: any) => Promise<ConversationType>;
13
- export declare const addUserToConversation: (context: ApiContext, convoId: string, userId: string) => Promise<any>;
14
- export declare const deleteUserFromConversation: (context: ApiContext, convoId: string, userId: string) => Promise<any>;
6
+ export declare const getConversations: (context: ApiContext, userId: string, options?: any) => Promise<ConversationType[]>;
7
+ export declare const getDirectConversation: (context: ApiContext, { fromId, toId, toUser }: DirectConversationParams) => Promise<ConversationType>;
8
+ export declare const addDirectConversation: (context: ApiContext, { fromId, toId, toUser }: DirectConversationParams) => Promise<ConversationType>;
9
+ export declare const getConnectionUsers: (context: ApiContext, { conversationId, includeAll, isDirect }: ConversationUsersParams) => Promise<ConnectionType[]>;
10
+ export declare const getConversationUsers: (context: ApiContext, { conversationId, includeAll, isDirect }: ConversationUsersParams) => Promise<ConversationType[]>;
11
+ export declare const getConversation: (context: ApiContext, conversationId: string) => Promise<ConversationType>;
12
+ export declare const updateConversation: (context: ApiContext, conversation: ConversationType) => Promise<ConversationType>;
13
+ export declare const addUserToConversation: (context: ApiContext, { conversationId, userId }: UpdateConversationUserParams) => Promise<ConversationType>;
14
+ export declare const deleteUserFromConversation: (context: ApiContext, { conversationId, userId }: UpdateConversationUserParams) => Promise<ConversationType>;