@nlabs/reaktor 0.8.0 → 0.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (198) hide show
  1. package/.eslintrc +10 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +1 -1
  4. package/coverage/actions/groups.ts.html +1039 -0
  5. package/coverage/actions/images.ts.html +2500 -0
  6. package/coverage/actions/index.html +131 -0
  7. package/coverage/actions/tags.ts.html +1000 -0
  8. package/coverage/adapters/arangoAdapter.ts.html +151 -0
  9. package/coverage/adapters/index.html +146 -0
  10. package/coverage/adapters/reaktorAdapter.ts.html +127 -0
  11. package/coverage/adapters/tagAdapter.ts.html +160 -0
  12. package/coverage/base.css +224 -0
  13. package/coverage/block-navigation.js +87 -0
  14. package/coverage/clover.xml +6 -0
  15. package/coverage/coverage-final.json +1 -0
  16. package/coverage/favicon.png +0 -0
  17. package/coverage/index.html +176 -0
  18. package/coverage/lcov-report/base.css +224 -0
  19. package/coverage/lcov-report/block-navigation.js +87 -0
  20. package/coverage/lcov-report/favicon.png +0 -0
  21. package/coverage/lcov-report/index.html +101 -0
  22. package/coverage/lcov-report/prettify.css +1 -0
  23. package/coverage/lcov-report/prettify.js +2 -0
  24. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  25. package/coverage/lcov-report/sorter.js +196 -0
  26. package/coverage/lcov.info +0 -0
  27. package/coverage/mocks/file.ts.html +118 -0
  28. package/coverage/mocks/group.ts.html +145 -0
  29. package/coverage/mocks/image.ts.html +136 -0
  30. package/coverage/mocks/index.html +146 -0
  31. package/coverage/mocks/post.ts.html +169 -0
  32. package/coverage/mocks/tag.ts.html +121 -0
  33. package/coverage/mocks/user.ts.html +268 -0
  34. package/coverage/prettify.css +1 -0
  35. package/coverage/prettify.js +2 -0
  36. package/coverage/sort-arrow-sprite.png +0 -0
  37. package/coverage/sorter.js +196 -0
  38. package/coverage/types/error.ts.html +145 -0
  39. package/coverage/types/index.html +116 -0
  40. package/coverage/utils/adapterUtils.ts.html +151 -0
  41. package/coverage/utils/analyticsUtils.ts.html +292 -0
  42. package/coverage/utils/arangodbUtils.ts.html +463 -0
  43. package/coverage/utils/index.html +146 -0
  44. package/jest.setup.js +0 -0
  45. package/jpg:- +0 -0
  46. package/lib/actions/apps.d.ts +25 -0
  47. package/lib/actions/apps.js +252 -0
  48. package/lib/actions/conversations.d.ts +14 -0
  49. package/lib/actions/conversations.js +131 -126
  50. package/lib/actions/dynamodb.d.ts +8 -0
  51. package/lib/actions/dynamodb.js +35 -32
  52. package/lib/actions/email.d.ts +5 -0
  53. package/lib/actions/email.js +23 -53
  54. package/lib/actions/files.d.ts +19 -0
  55. package/lib/actions/files.js +188 -202
  56. package/lib/actions/groups.d.ts +14 -0
  57. package/lib/actions/groups.js +38 -36
  58. package/lib/actions/images.d.ts +26 -0
  59. package/lib/actions/images.js +236 -229
  60. package/lib/actions/index.d.ts +21 -0
  61. package/lib/actions/index.js +3 -1
  62. package/lib/actions/ios.d.ts +7 -0
  63. package/lib/actions/ios.js +11 -10
  64. package/lib/actions/locations.d.ts +5 -0
  65. package/lib/actions/locations.js +29 -37
  66. package/lib/actions/messages.d.ts +13 -0
  67. package/lib/actions/messages.js +10 -10
  68. package/lib/actions/notifications.d.ts +5 -0
  69. package/lib/actions/notifications.js +1 -1
  70. package/lib/actions/payments.d.ts +10 -0
  71. package/lib/actions/payments.js +27 -26
  72. package/lib/actions/posts.d.ts +19 -0
  73. package/lib/actions/posts.js +176 -156
  74. package/lib/actions/reactions.d.ts +30 -0
  75. package/lib/actions/reactions.js +30 -28
  76. package/lib/actions/s3.d.ts +7 -0
  77. package/lib/actions/s3.js +37 -32
  78. package/lib/actions/search.d.ts +3 -0
  79. package/lib/actions/search.js +11 -9
  80. package/lib/actions/sms.d.ts +3 -0
  81. package/lib/actions/sms.js +58 -34
  82. package/lib/actions/statistics.d.ts +3 -0
  83. package/lib/actions/statistics.js +21 -18
  84. package/lib/actions/subscription.d.ts +7 -0
  85. package/lib/actions/subscription.js +24 -21
  86. package/lib/actions/tags.d.ts +29 -0
  87. package/lib/actions/tags.js +129 -198
  88. package/lib/actions/users.d.ts +47 -0
  89. package/lib/actions/users.js +188 -194
  90. package/lib/actions/websockets.d.ts +19 -0
  91. package/lib/actions/websockets.js +60 -34
  92. package/lib/adapters/arangoAdapter.d.ts +2 -0
  93. package/lib/adapters/arangoAdapter.js +46 -0
  94. package/lib/adapters/fileAdapter.d.ts +3 -0
  95. package/lib/adapters/fileAdapter.js +76 -0
  96. package/lib/adapters/postAdapter.d.ts +2 -0
  97. package/lib/adapters/postAdapter.js +70 -0
  98. package/lib/adapters/reaktorAdapter.d.ts +6 -0
  99. package/lib/adapters/reaktorAdapter.js +44 -0
  100. package/lib/adapters/tagAdapter.d.ts +2 -0
  101. package/lib/adapters/tagAdapter.js +50 -0
  102. package/lib/adapters/userAdapter.d.ts +2 -0
  103. package/lib/adapters/userAdapter.js +110 -0
  104. package/lib/config.d.ts +20 -0
  105. package/lib/config.js +14 -15
  106. package/lib/index.d.ts +5 -0
  107. package/lib/lambdas/actions/websockets.d.ts +6 -0
  108. package/lib/lambdas/actions/websockets.js +7 -7
  109. package/lib/lambdas/authorizer.d.ts +20 -0
  110. package/lib/lambdas/authorizer.js +1 -1
  111. package/lib/lambdas/connection.d.ts +12 -0
  112. package/lib/lambdas/connection.js +5 -4
  113. package/lib/lambdas/utils/message.d.ts +1 -0
  114. package/lib/lambdas/utils/websocket.d.ts +7 -0
  115. package/lib/lambdas/utils/websocket.js +8 -6
  116. package/lib/mocks/conversation.d.ts +8 -0
  117. package/lib/mocks/conversation.js +35 -0
  118. package/lib/mocks/file.d.ts +11 -0
  119. package/lib/mocks/file.js +38 -0
  120. package/lib/mocks/group.d.ts +17 -0
  121. package/lib/mocks/group.js +47 -0
  122. package/lib/mocks/image.d.ts +3 -0
  123. package/lib/mocks/image.js +43 -0
  124. package/lib/mocks/nlabs.png +0 -0
  125. package/lib/mocks/post.d.ts +38 -0
  126. package/lib/mocks/post.js +55 -0
  127. package/lib/mocks/tag.d.ts +2 -0
  128. package/lib/mocks/tag.js +37 -0
  129. package/lib/mocks/user.d.ts +4 -0
  130. package/lib/mocks/user.js +88 -0
  131. package/lib/templates/email/layout.d.ts +2 -0
  132. package/lib/templates/email/passwordForgot.d.ts +2 -0
  133. package/lib/templates/email/passwordRecovery.d.ts +2 -0
  134. package/lib/templates/email/verifyEmail.d.ts +2 -0
  135. package/lib/templates/email/welcome.d.ts +2 -0
  136. package/lib/templates/sms/passwordForgot.d.ts +2 -0
  137. package/lib/templates/sms/passwordRecovery.d.ts +2 -0
  138. package/lib/templates/sms/verifyEmail.d.ts +2 -0
  139. package/lib/templates/sms/verifyPhone.d.ts +2 -0
  140. package/lib/templates/sms/welcome.d.ts +2 -0
  141. package/lib/types/apps.d.ts +46 -0
  142. package/lib/types/apps.js +17 -1
  143. package/lib/types/arangodb.d.ts +30 -0
  144. package/lib/types/arangodb.js +1 -1
  145. package/lib/types/auth.d.ts +7 -0
  146. package/lib/types/auth.js +1 -1
  147. package/lib/types/connections.d.ts +7 -0
  148. package/lib/types/connections.js +1 -1
  149. package/lib/types/conversations.d.ts +29 -0
  150. package/lib/types/conversations.js +1 -1
  151. package/lib/types/email.d.ts +13 -0
  152. package/lib/types/email.js +1 -1
  153. package/lib/types/error.d.ts +20 -0
  154. package/lib/types/error.js +44 -0
  155. package/lib/types/files.d.ts +26 -0
  156. package/lib/types/files.js +1 -1
  157. package/lib/types/google.d.ts +29 -0
  158. package/lib/types/google.js +1 -1
  159. package/lib/types/groups.d.ts +21 -0
  160. package/lib/types/groups.js +1 -1
  161. package/lib/types/images.d.ts +51 -0
  162. package/lib/types/images.js +1 -1
  163. package/lib/types/index.d.ts +18 -0
  164. package/lib/types/locations.d.ts +20 -0
  165. package/lib/types/locations.js +1 -1
  166. package/lib/types/messages.d.ts +16 -0
  167. package/lib/types/messages.js +1 -1
  168. package/lib/types/notifications.d.ts +17 -0
  169. package/lib/types/notifications.js +1 -1
  170. package/lib/types/payments.d.ts +112 -0
  171. package/lib/types/payments.js +1 -1
  172. package/lib/types/posts.d.ts +31 -0
  173. package/lib/types/posts.js +1 -1
  174. package/lib/types/statistics.d.ts +3 -0
  175. package/lib/types/statistics.js +1 -1
  176. package/lib/types/tags.d.ts +10 -0
  177. package/lib/types/tags.js +1 -1
  178. package/lib/types/users.d.ts +76 -0
  179. package/lib/types/users.js +1 -1
  180. package/lib/types/websocket.d.ts +13 -0
  181. package/lib/types/websocket.js +1 -1
  182. package/lib/utils/adapterUtils.d.ts +1 -0
  183. package/lib/utils/adapterUtils.js +45 -0
  184. package/lib/utils/analyticsUtils.d.ts +21 -0
  185. package/lib/utils/analyticsUtils.js +72 -0
  186. package/lib/utils/arangodbUtils.d.ts +65 -0
  187. package/lib/utils/arangodbUtils.js +144 -0
  188. package/lib/utils/auth.d.ts +20 -0
  189. package/lib/utils/auth.js +13 -30
  190. package/lib/utils/index.d.ts +5 -0
  191. package/lib/utils/index.js +7 -9
  192. package/lib/utils/session.d.ts +16 -0
  193. package/lib/utils/session.js +11 -2
  194. package/package.json +12 -5
  195. package/lib/utils/analytics.js +0 -88
  196. package/lib/utils/arangodb.js +0 -118
  197. package/lib/utils/graphql.js +0 -46
  198. package/lib/utils/objects.js +0 -59
@@ -0,0 +1,21 @@
1
+ export * from './apps';
2
+ export * from './conversations';
3
+ export * from './dynamodb';
4
+ export * from './email';
5
+ export * from './files';
6
+ export * from './groups';
7
+ export * from './images';
8
+ export * from './ios';
9
+ export * from './locations';
10
+ export * from './messages';
11
+ export * from './notifications';
12
+ export * from './payments';
13
+ export * from './posts';
14
+ export * from './reactions';
15
+ export * from './s3';
16
+ export * from './search';
17
+ export * from './sms';
18
+ export * from './subscription';
19
+ export * from './tags';
20
+ export * from './users';
21
+ export * from './websockets';
@@ -14,6 +14,7 @@ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "defau
14
14
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
15
15
  var actions_exports = {};
16
16
  module.exports = __toCommonJS(actions_exports);
17
+ __reExport(actions_exports, require("./apps"), module.exports);
17
18
  __reExport(actions_exports, require("./conversations"), module.exports);
18
19
  __reExport(actions_exports, require("./dynamodb"), module.exports);
19
20
  __reExport(actions_exports, require("./email"), module.exports);
@@ -36,6 +37,7 @@ __reExport(actions_exports, require("./users"), module.exports);
36
37
  __reExport(actions_exports, require("./websockets"), module.exports);
37
38
  // Annotate the CommonJS export names for ESM import in node:
38
39
  0 && (module.exports = {
40
+ ...require("./apps"),
39
41
  ...require("./conversations"),
40
42
  ...require("./dynamodb"),
41
43
  ...require("./email"),
@@ -57,4 +59,4 @@ __reExport(actions_exports, require("./websockets"), module.exports);
57
59
  ...require("./users"),
58
60
  ...require("./websockets")
59
61
  });
60
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2NvbnZlcnNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9keW5hbW9kYic7XG5leHBvcnQgKiBmcm9tICcuL2VtYWlsJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ncm91cHMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbWFnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9pb3MnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2NhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9tZXNzYWdlcyc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9wYXltZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3Bvc3RzJztcbmV4cG9ydCAqIGZyb20gJy4vcmVhY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vczMnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9zbXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi90YWdzJztcbmV4cG9ydCAqIGZyb20gJy4vdXNlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi93ZWJzb2NrZXRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUlBLDRCQUFjLDRCQUpkO0FBS0EsNEJBQWMsdUJBTGQ7QUFNQSw0QkFBYyxvQkFOZDtBQU9BLDRCQUFjLG9CQVBkO0FBUUEsNEJBQWMscUJBUmQ7QUFTQSw0QkFBYyxxQkFUZDtBQVVBLDRCQUFjLGtCQVZkO0FBV0EsNEJBQWMsd0JBWGQ7QUFZQSw0QkFBYyx1QkFaZDtBQWFBLDRCQUFjLDRCQWJkO0FBY0EsNEJBQWMsdUJBZGQ7QUFlQSw0QkFBYyxvQkFmZDtBQWdCQSw0QkFBYyx3QkFoQmQ7QUFpQkEsNEJBQWMsaUJBakJkO0FBa0JBLDRCQUFjLHFCQWxCZDtBQW1CQSw0QkFBYyxrQkFuQmQ7QUFvQkEsNEJBQWMsMkJBcEJkO0FBcUJBLDRCQUFjLG1CQXJCZDtBQXNCQSw0QkFBYyxvQkF0QmQ7QUF1QkEsNEJBQWMseUJBdkJkOyIsCiAgIm5hbWVzIjogW10KfQo=
62
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2FwcHMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb252ZXJzYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vZHluYW1vZGInO1xuZXhwb3J0ICogZnJvbSAnLi9lbWFpbCc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbGVzJztcbmV4cG9ydCAqIGZyb20gJy4vZ3JvdXBzJztcbmV4cG9ydCAqIGZyb20gJy4vaW1hZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vaW9zJztcbmV4cG9ydCAqIGZyb20gJy4vbG9jYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vbWVzc2FnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3RpZmljYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vcGF5bWVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9wb3N0cyc7XG5leHBvcnQgKiBmcm9tICcuL3JlYWN0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3MzJztcbmV4cG9ydCAqIGZyb20gJy4vc2VhcmNoJztcbmV4cG9ydCAqIGZyb20gJy4vc21zJztcbmV4cG9ydCAqIGZyb20gJy4vc3Vic2NyaXB0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vdGFncyc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vd2Vic29ja2V0cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFJQSw0QkFBYyxtQkFKZDtBQUtBLDRCQUFjLDRCQUxkO0FBTUEsNEJBQWMsdUJBTmQ7QUFPQSw0QkFBYyxvQkFQZDtBQVFBLDRCQUFjLG9CQVJkO0FBU0EsNEJBQWMscUJBVGQ7QUFVQSw0QkFBYyxxQkFWZDtBQVdBLDRCQUFjLGtCQVhkO0FBWUEsNEJBQWMsd0JBWmQ7QUFhQSw0QkFBYyx1QkFiZDtBQWNBLDRCQUFjLDRCQWRkO0FBZUEsNEJBQWMsdUJBZmQ7QUFnQkEsNEJBQWMsb0JBaEJkO0FBaUJBLDRCQUFjLHdCQWpCZDtBQWtCQSw0QkFBYyxpQkFsQmQ7QUFtQkEsNEJBQWMscUJBbkJkO0FBb0JBLDRCQUFjLGtCQXBCZDtBQXFCQSw0QkFBYywyQkFyQmQ7QUFzQkEsNEJBQWMsbUJBdEJkO0FBdUJBLDRCQUFjLG9CQXZCZDtBQXdCQSw0QkFBYyx5QkF4QmQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -0,0 +1,7 @@
1
+ import { Database } from 'arangojs';
2
+ import { ApiContext, PaymentIOSInAppError, PaymentIOSSubscriptionUpdate, PaymentSubscription } from '../types';
3
+ export declare const getIosInAppError: (statusCode: string) => PaymentIOSInAppError;
4
+ export declare const iosSubscriptionUpdate: (database: Database, subscriptionUpdate: PaymentIOSSubscriptionUpdate) => Promise<void>;
5
+ export declare const getIosSubscription: (context: ApiContext) => Promise<PaymentSubscription>;
6
+ export declare const addIosInApp: (context: ApiContext, subscription: PaymentSubscription) => Promise<PaymentSubscription>;
7
+ export declare const getIosInApp: (context: ApiContext) => Promise<PaymentSubscription>;
@@ -26,7 +26,8 @@ __export(ios_exports, {
26
26
  module.exports = __toCommonJS(ios_exports);
27
27
  var import_utils = require("@nlabs/utils");
28
28
  var import_arangojs = require("arangojs");
29
- var import_utils2 = require("../utils");
29
+ var import_analyticsUtils = require("../utils/analyticsUtils");
30
+ var import_error = require("../types/error");
30
31
  const eventCategory = "ios";
31
32
  const getIosInAppError = (statusCode) => {
32
33
  const codes = {
@@ -96,10 +97,10 @@ const iosSubscriptionUpdate = (database, subscriptionUpdate) => {
96
97
  INSERT ${insert}
97
98
  UPDATE ${update} IN subscriptions
98
99
  LIMIT 1`;
99
- return database.query(aqlQry).then(() => null).catch((dbError) => (0, import_utils2.logError)({
100
+ return database.query(aqlQry).then(() => null).catch((dbError) => (0, import_analyticsUtils.logError)({
100
101
  action,
101
102
  category: eventCategory,
102
- label: "db_error"
103
+ label: import_error.ErrorTypes.DATABASE_ERROR
103
104
  }, dbError, {}).then(() => null));
104
105
  };
105
106
  const getIosSubscription = (context) => {
@@ -109,10 +110,10 @@ const getIosSubscription = (context) => {
109
110
  FILTER s.userId == ${sessionId} && s.type == "ios_payment"
110
111
  LIMIT 1
111
112
  RETURN s`;
112
- return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription = {}) => subscription).catch((error) => (0, import_utils2.logError)({
113
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription) => subscription).catch((error) => (0, import_analyticsUtils.logError)({
113
114
  action,
114
115
  category: eventCategory,
115
- label: "db_error"
116
+ label: import_error.ErrorTypes.DATABASE_ERROR
116
117
  }, error, context).then(() => null));
117
118
  };
118
119
  const addIosInApp = (context, subscription) => {
@@ -133,10 +134,10 @@ const addIosInApp = (context, subscription) => {
133
134
  userId: sessionId
134
135
  };
135
136
  const aqlQry = import_arangojs.aql`INSERT ${insert} IN subscriptions RETURN NEW`;
136
- return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedSubscription = {}) => updatedSubscription).catch((error) => (0, import_utils2.logError)({
137
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedSubscription) => updatedSubscription).catch((error) => (0, import_analyticsUtils.logError)({
137
138
  action,
138
139
  category: eventCategory,
139
- label: "db_error"
140
+ label: import_error.ErrorTypes.DATABASE_ERROR
140
141
  }, error, context).then(() => null));
141
142
  };
142
143
  const getIosInApp = (context) => {
@@ -146,10 +147,10 @@ const getIosInApp = (context) => {
146
147
  FILTER s.userId == ${sessionId} && s.type == "ios"
147
148
  LIMIT 1
148
149
  RETURN s`;
149
- return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription = {}) => subscription).catch((error) => (0, import_utils2.logError)({
150
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription) => subscription).catch((error) => (0, import_analyticsUtils.logError)({
150
151
  action,
151
152
  category: eventCategory,
152
- label: "db_error"
153
+ label: import_error.ErrorTypes.DATABASE_ERROR
153
154
  }, error, context).then(() => null));
154
155
  };
155
156
  // Annotate the CommonJS export names for ESM import in node:
@@ -160,4 +161,4 @@ const getIosInApp = (context) => {
160
161
  getIosSubscription,
161
162
  iosSubscriptionUpdate
162
163
  });
163
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/ios.ts"],
  "sourcesContent": ["import {createHash} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\n\nimport {\n  ApiContext,\n  PaymentIOSInAppError,\n  PaymentIOSSubscriptionInfo,\n  PaymentIOSSubscriptionUpdate,\n  PaymentSubscription\n} from '../types';\nimport {logError} from '../utils';\n\nconst eventCategory: string = 'ios';\n\nexport const getIosInAppError = (statusCode: string): PaymentIOSInAppError => {\n  const codes = {\n    [0]: {error: false, message: 'Active', valid: true},\n    [21000]: {error: true, id: 'payment_receipt_unreadable', message: 'App store could not read', valid: false},\n    [21002]: {error: true, id: 'payment_data_malformed', message: 'Data was malformed', valid: false},\n    [21003]: {error: true, id: 'payment_receipt_unauthorized', message: 'Receipt not authenticated', valid: false},\n    [21004]: {error: true, id: 'payment_invalid_secret', message: 'Shared secret does not match', valid: false},\n    [21005]: {error: true, id: 'payment_server_unavailable', message: 'Receipt server unavailable', valid: false},\n    [21006]: {\n      error: false,\n      id: 'payment_subscription_expired',\n      message: 'Receipt valid but sub expired',\n      valid: true\n    },\n    /**\n     * special case for app review handling - forward any request that is intended for the Sandbox but was sent to\n     * Production, this is what the app review team does\n     */\n    [21007]: {\n      error: true,\n      id: 'payment_invalid_server',\n      message: 'Sandbox receipt sent to Production environment',\n      redirect: true,\n      valid: false\n    },\n    [21008]: {\n      error: true,\n      id: 'payment_invalid_server',\n      message: 'Production receipt sent to Sandbox environment',\n      valid: false\n    }\n  };\n\n  return codes[statusCode] || {};\n};\n\nexport const iosSubscriptionUpdate = (\n  database: Database,\n  subscriptionUpdate: PaymentIOSSubscriptionUpdate\n): Promise<void> => {\n  const action: string = 'iosSubscriptionUpdate';\n  const {\n    auto_renew_adam_id: planId,\n    cancellation_date: cancelDate,\n    notification_type: status,\n    latest_receipt: latestReceipt,\n    latest_receipt_info: latestInfo,\n    latest_expired_receipt: expiredReceipt,\n    latest_expired_receipt_info: expiredInfo,\n    original_transaction_id: transactionId\n  } = subscriptionUpdate;\n  const formatStatus: string = (status || '').toLowerCase();\n  const now: number = Date.now();\n  const receiptInfo: PaymentIOSSubscriptionInfo[] = latestInfo || expiredInfo;\n  const id: string = createHash(`payment-${transactionId}`);\n\n  const update: PaymentSubscription = {\n    cancelDate,\n    isValid: receiptInfo[0].expires_date_ms > now,\n    modified: now,\n    planId,\n    receipt: latestReceipt || expiredReceipt,\n    status: formatStatus\n  };\n  const insert: PaymentSubscription = {\n    ...update,\n    _key: id,\n    added: now,\n    type: 'ios_payment'\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {transactionId: ${transactionId}}\n     INSERT ${insert}\n     UPDATE ${update} IN subscriptions\n     LIMIT 1`;\n\n  return database.query(aqlQry)\n    .then(() => null)\n    .catch((dbError: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, dbError, {}).then(() => null));\n};\n\n// export const addIosInApp = (\n//   context: ApiContext,\n//   app,\n//   subscription: PaymentSubscription\n// ): Promise<PaymentSubscription> => {\n//   const action: string = 'addIosInApp';\n//   const {isProduction, receipt} = subscription;\n//   const {database, userId: sessionId} = context;\n\n//   const productionHost: string = 'buy.itunes.apple.com';\n//   const sandboxHost: string = 'sandbox.itunes.apple.com';\n//   const endpoint: string = isProduction ? productionHost : sandboxHost;\n//   const verifyUrl: string = `https://${endpoint}/verifyReceipt`;\n//   const payload: object = {\n//     password: app.iap,\n//     'receipt-data': decodeURIComponent(receipt)\n//   };\n//   const options: object = {\n//     headers: {\n//       'Content-Type': 'application/x-www-form-urlencoded'\n//     }\n//   };\n\n//   return post(verifyUrl, payload, options)\n//     .then((results) => {\n//       const json = JSON.parse(results);\n//       const {\n//         latest_receipt: latestReceipt,\n//         latest_receipt_info: latestInfo,\n//         status\n//       } = json;\n\n//       const {\n//         is_trial_period: trialPeriod,\n//         original_purchase_date_ms: added,\n//         expires_date: expires,\n//         product_id: planId,\n//         transaction_id: transactionId\n//       } = latestInfo;\n\n//       if(status === 0 || status === 21006) {\n//         const id: string = createHash(`payment-${transactionId}`);\n//         const now: number = Date.now();\n//         const update: PaymentSubscription = {\n//           expires,\n//           isTrial: trialPeriod === 'true',\n//           isValid: expires > now,\n//           modified: now,\n//           planId,\n//           receipt: latestReceipt,\n//           transactionId,\n//           userId: sessionId\n//         };\n//         const insert: PaymentSubscription = {\n//           ...update,\n//           _key: id,\n//           added,\n//           type: 'ios_payment'\n//         };\n\n//         const aqlQry: AqlQuery = aql`UPSERT {transactionId: ${transactionId}}\n//               INSERT ${insert}\n//               UPDATE ${update} IN subscriptions\n//               RETURN NEW`;\n\n//         return database.query(aqlQry)\n//           .then((cursor: ArrayCursor) => cursor.next())\n//           .then((updatedSubscription: PaymentSubscription = {}) => updatedSubscription)\n//           .catch((dbError: Error) => logError({\n//             action,\n//             category: eventCategory,\n//             label: 'db_error'\n//           }, dbError, context).then(() => null));\n//       }\n\n//       // Errors\n//       const error: PaymentIOSInAppError = getIosInAppError(results.status);\n\n//       return logException({\n//         action,\n//         category: eventCategory,\n//         label: 'payment_error',\n//         message: error.message,\n//         value: error.id\n//       }, context).then(() => null);\n//     });\n// };\n\nexport const getIosSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getIosSubscription';\n  const {database, session: {userId: sessionId}} = context;\n  const aqlQry: AqlQuery = aql`FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.type == \"ios_payment\"\n      LIMIT 1\n      RETURN s`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription: PaymentSubscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const addIosInApp = (context: ApiContext, subscription: PaymentSubscription): Promise<PaymentSubscription> => {\n  const action: string = 'addIosInApp';\n  const {database, session: {userId: sessionId}} = context;\n  const now: number = Date.now();\n  const {added = now, planId, receipt, transactionId, trialEnd} = subscription;\n  const subscriptionId: string = createHash(`subscription-${transactionId}`);\n  const insert: PaymentSubscription = {\n    _key: subscriptionId,\n    added,\n    modified: now,\n    planId,\n    receipt,\n    transactionId,\n    trialEnd,\n    type: 'ios_subscription',\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN subscriptions RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedSubscription: PaymentSubscription = {}) => updatedSubscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getIosInApp = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getIosInApp';\n  const {database, session: {userId: sessionId}} = context;\n  const aqlQry: AqlQuery = aql`FOR s IN subscription\n      FILTER s.userId == ${sessionId} && s.type == \"ios\"\n      LIMIT 1\n      RETURN s`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription: PaymentSubscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"],
  "mappings": "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",
  "names": ["import_utils"]
}

164
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/ios.ts"],
  "sourcesContent": ["import {createHash} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\n\nimport {\n  ApiContext,\n  PaymentIOSInAppError,\n  PaymentIOSSubscriptionInfo,\n  PaymentIOSSubscriptionUpdate,\n  PaymentSubscription\n} from '../types';\nimport {logError} from '../utils/analyticsUtils';\nimport {ErrorTypes} from '../types/error';\n\nconst eventCategory: string = 'ios';\n\nexport const getIosInAppError = (statusCode: string): PaymentIOSInAppError => {\n  const codes = {\n    [0]: {error: false, message: 'Active', valid: true},\n    [21000]: {error: true, id: 'payment_receipt_unreadable', message: 'App store could not read', valid: false},\n    [21002]: {error: true, id: 'payment_data_malformed', message: 'Data was malformed', valid: false},\n    [21003]: {error: true, id: 'payment_receipt_unauthorized', message: 'Receipt not authenticated', valid: false},\n    [21004]: {error: true, id: 'payment_invalid_secret', message: 'Shared secret does not match', valid: false},\n    [21005]: {error: true, id: 'payment_server_unavailable', message: 'Receipt server unavailable', valid: false},\n    [21006]: {\n      error: false,\n      id: 'payment_subscription_expired',\n      message: 'Receipt valid but sub expired',\n      valid: true\n    },\n    /**\n     * special case for app review handling - forward any request that is intended for the Sandbox but was sent to\n     * Production, this is what the app review team does\n     */\n    [21007]: {\n      error: true,\n      id: 'payment_invalid_server',\n      message: 'Sandbox receipt sent to Production environment',\n      redirect: true,\n      valid: false\n    },\n    [21008]: {\n      error: true,\n      id: 'payment_invalid_server',\n      message: 'Production receipt sent to Sandbox environment',\n      valid: false\n    }\n  };\n\n  return codes[statusCode] || {};\n};\n\nexport const iosSubscriptionUpdate = (\n  database: Database,\n  subscriptionUpdate: PaymentIOSSubscriptionUpdate\n): Promise<void> => {\n  const action: string = 'iosSubscriptionUpdate';\n  const {\n    auto_renew_adam_id: planId,\n    cancellation_date: cancelDate,\n    notification_type: status,\n    latest_receipt: latestReceipt,\n    latest_receipt_info: latestInfo,\n    latest_expired_receipt: expiredReceipt,\n    latest_expired_receipt_info: expiredInfo,\n    original_transaction_id: transactionId\n  } = subscriptionUpdate;\n  const formatStatus: string = (status || '').toLowerCase();\n  const now: number = Date.now();\n  const receiptInfo: PaymentIOSSubscriptionInfo[] = latestInfo || expiredInfo;\n  const id: string = createHash(`payment-${transactionId}`);\n\n  const update: PaymentSubscription = {\n    cancelDate,\n    isValid: receiptInfo[0].expires_date_ms > now,\n    modified: now,\n    planId,\n    receipt: latestReceipt || expiredReceipt,\n    status: formatStatus\n  };\n  const insert: PaymentSubscription = {\n    ...update,\n    _key: id,\n    added: now,\n    type: 'ios_payment'\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {transactionId: ${transactionId}}\n     INSERT ${insert}\n     UPDATE ${update} IN subscriptions\n     LIMIT 1`;\n\n  return database.query(aqlQry)\n    .then(() => null)\n    .catch((dbError: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, dbError, {}).then(() => null));\n};\n\n// export const addIosInApp = (\n//   context: ApiContext,\n//   app,\n//   subscription: PaymentSubscription\n// ): Promise<PaymentSubscription> => {\n//   const action: string = 'addIosInApp';\n//   const {isProduction, receipt} = subscription;\n//   const {database, userId: sessionId} = context;\n\n//   const productionHost: string = 'buy.itunes.apple.com';\n//   const sandboxHost: string = 'sandbox.itunes.apple.com';\n//   const endpoint: string = isProduction ? productionHost : sandboxHost;\n//   const verifyUrl: string = `https://${endpoint}/verifyReceipt`;\n//   const payload: object = {\n//     password: app.iap,\n//     'receipt-data': decodeURIComponent(receipt)\n//   };\n//   const options: object = {\n//     headers: {\n//       'Content-Type': 'application/x-www-form-urlencoded'\n//     }\n//   };\n\n//   return post(verifyUrl, payload, options)\n//     .then((results) => {\n//       const json = JSON.parse(results);\n//       const {\n//         latest_receipt: latestReceipt,\n//         latest_receipt_info: latestInfo,\n//         status\n//       } = json;\n\n//       const {\n//         is_trial_period: trialPeriod,\n//         original_purchase_date_ms: added,\n//         expires_date: expires,\n//         product_id: planId,\n//         transaction_id: transactionId\n//       } = latestInfo;\n\n//       if(status === 0 || status === 21006) {\n//         const id: string = createHash(`payment-${transactionId}`);\n//         const now: number = Date.now();\n//         const update: PaymentSubscription = {\n//           expires,\n//           isTrial: trialPeriod === 'true',\n//           isValid: expires > now,\n//           modified: now,\n//           planId,\n//           receipt: latestReceipt,\n//           transactionId,\n//           userId: sessionId\n//         };\n//         const insert: PaymentSubscription = {\n//           ...update,\n//           _key: id,\n//           added,\n//           type: 'ios_payment'\n//         };\n\n//         const aqlQry: AqlQuery = aql`UPSERT {transactionId: ${transactionId}}\n//               INSERT ${insert}\n//               UPDATE ${update} IN subscriptions\n//               RETURN NEW`;\n\n//         return database.query(aqlQry)\n//           .then((cursor: ArrayCursor) => cursor.next())\n//           .then((updatedSubscription: PaymentSubscription = {}) => updatedSubscription)\n//           .catch((dbError: Error) => logError({\n//             action,\n//             category: eventCategory,\n//             label: ErrorTypes.DATABASE_ERROR\n//           }, dbError, context).then(() => null));\n//       }\n\n//       // Errors\n//       const error: PaymentIOSInAppError = getIosInAppError(results.status);\n\n//       return logException({\n//         action,\n//         category: eventCategory,\n//         label: 'payment_error',\n//         message: error.message,\n//         value: error.id\n//       }, context).then(() => null);\n//     });\n// };\n\nexport const getIosSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getIosSubscription';\n  const {database, session: {userId: sessionId}} = context;\n  const aqlQry: AqlQuery = aql`FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.type == \"ios_payment\"\n      LIMIT 1\n      RETURN s`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription: PaymentSubscription) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const addIosInApp = (context: ApiContext, subscription: PaymentSubscription): Promise<PaymentSubscription> => {\n  const action: string = 'addIosInApp';\n  const {database, session: {userId: sessionId}} = context;\n  const now: number = Date.now();\n  const {added = now, planId, receipt, transactionId, trialEnd} = subscription;\n  const subscriptionId: string = createHash(`subscription-${transactionId}`);\n  const insert: PaymentSubscription = {\n    _key: subscriptionId,\n    added,\n    modified: now,\n    planId,\n    receipt,\n    transactionId,\n    trialEnd,\n    type: 'ios_subscription',\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN subscriptions RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedSubscription: PaymentSubscription) => updatedSubscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n\nexport const getIosInApp = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getIosInApp';\n  const {database, session: {userId: sessionId}} = context;\n  const aqlQry: AqlQuery = aql`FOR s IN subscription\n      FILTER s.userId == ${sessionId} && s.type == \"ios\"\n      LIMIT 1\n      RETURN s`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription: PaymentSubscription) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context).then(() => null));\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,5 @@
1
+ import { ApiContext } from '../types/auth';
2
+ import { GoogleMapsAddressType } from '../types/google';
3
+ import { LocationType } from '../types/locations';
4
+ export declare const getFieldVal: (addressComponents: GoogleMapsAddressType[], name: string) => string;
5
+ export declare const addLocation: (context: ApiContext, location: LocationType) => Promise<LocationType>;
@@ -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,27 +14,27 @@ 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 locations_exports = {};
29
19
  __export(locations_exports, {
30
- addLocation: () => addLocation
20
+ addLocation: () => addLocation,
21
+ getFieldVal: () => getFieldVal
31
22
  });
32
23
  module.exports = __toCommonJS(locations_exports);
33
24
  var import_rip_hunter = require("@nlabs/rip-hunter");
34
25
  var import_utils = require("@nlabs/utils");
35
26
  var import_arangojs = require("arangojs");
36
- var import_get = __toESM(require("lodash/get"));
37
27
  var import_config = require("../config");
38
- var import_utils2 = require("../utils");
28
+ var import_analyticsUtils = require("../utils/analyticsUtils");
29
+ var import_error = require("../types/error");
39
30
  const eventCategory = "locations";
31
+ const getFieldVal = (addressComponents, name) => {
32
+ const { short_name: shortName = "" } = addressComponents.find((addressField) => {
33
+ const types = addressField.types || [];
34
+ return types.findIndex((fieldType) => fieldType === name) >= 0;
35
+ }) || {};
36
+ return shortName;
37
+ };
40
38
  const addLocation = (context, location) => {
41
39
  const action = "add";
42
40
  const { database, session: { userId: sessionId } } = context;
@@ -51,39 +49,32 @@ const addLocation = (context, location) => {
51
49
  const { results = [], status = "" } = json;
52
50
  if (status === "OK" && results.length) {
53
51
  const geodata = results[0];
54
- const addressComponents = (0, import_get.default)(geodata, "address_components");
55
- const getFieldVal = (name) => {
56
- const { short_name: shortName = "" } = addressComponents.find((addressField) => {
57
- const types = addressField.types || [];
58
- return types.findIndex((fieldType) => fieldType === name) >= 0;
59
- }) || {};
60
- return shortName;
61
- };
62
- const streetNumber = getFieldVal("street_number");
63
- const route = getFieldVal("route");
52
+ const addressComponents = geodata?.address_components || [];
53
+ const streetNumber = getFieldVal(addressComponents, "street_number");
54
+ const route = getFieldVal(addressComponents, "route");
64
55
  const now = Date.now();
65
56
  const formatItemType = (0, import_utils.parseChar)(itemType).toLowerCase();
66
57
  const formatItemId = (0, import_utils.parseId)(itemId);
67
- const googleId = (0, import_get.default)(geodata, "place_id");
58
+ const googleId = geodata?.place_id || "";
68
59
  const update = {};
69
60
  const insert = {
70
61
  _key: (0, import_utils.createHash)(`post-${sessionId}`),
71
62
  added: now,
72
- city: getFieldVal("locality"),
73
- country: getFieldVal("country"),
74
- formatted: (0, import_get.default)(geodata, "formatted_address"),
63
+ city: getFieldVal(addressComponents, "locality"),
64
+ country: getFieldVal(addressComponents, "country"),
65
+ formatted: geodata?.formatted_address,
75
66
  googleId,
76
- latitude: (0, import_get.default)(geodata, "geometry.location.lat"),
77
- longitude: (0, import_get.default)(geodata, "geometry.location.lng"),
78
- state: getFieldVal("administrative_area_level_1"),
67
+ latitude: geodata?.geometry.location.lat,
68
+ longitude: geodata?.geometry.location.lng,
69
+ state: getFieldVal(addressComponents, "administrative_area_level_1"),
79
70
  street: [streetNumber, route].filter((obj) => obj).join(" "),
80
- zip: getFieldVal("postal_code")
71
+ zip: getFieldVal(addressComponents, "postal_code")
81
72
  };
82
73
  const aqlQry = import_arangojs.aql`UPSERT {googleId: ${googleId}}
83
74
  INSERT ${insert}
84
75
  UPDATE ${update}
85
76
  IN locations RETURN NEW`;
86
- return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedLocation = {}) => {
77
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedLocation) => {
87
78
  let itemDocId;
88
79
  const { _key: updatedLocationKey } = updatedLocation;
89
80
  switch (formatItemType) {
@@ -102,17 +93,18 @@ const addLocation = (context, location) => {
102
93
  return edgeCollection.save(edge, { returnNew: true }).then(() => updatedLocation);
103
94
  }
104
95
  return updatedLocation;
105
- }).catch((error) => (0, import_utils2.logError)({
96
+ }).catch((error) => (0, import_analyticsUtils.logError)({
106
97
  action,
107
98
  category: eventCategory,
108
- label: "db_error"
99
+ label: import_error.ErrorTypes.DATABASE_ERROR
109
100
  }, error, context).then(() => null));
110
101
  }
111
- return {};
102
+ return null;
112
103
  });
113
104
  };
114
105
  // Annotate the CommonJS export names for ESM import in node:
115
106
  0 && (module.exports = {
116
- addLocation
107
+ addLocation,
108
+ getFieldVal
117
109
  });
118
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/locations.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 {get as httpGet, queryString} from '@nlabs/rip-hunter';\nimport {createHash, parseChar, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport get from 'lodash/get';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {GoogleMapsAddressType} from '../types/google';\nimport {LocationType} from '../types/locations';\nimport {logError} from '../utils';\n\nconst eventCategory: string = 'locations';\n\nexport const addLocation = (context: ApiContext, location: LocationType): Promise<LocationType> => {\n  const action: string = 'add';\n  const {database, session: {userId: sessionId}} = context;\n  const {address, itemId, itemType} = location;\n  const geocodeUrl: string = Config.get('google.geocode.url');\n  const params: object = {\n    address,\n    key: Config.get('google.geocode.key')\n  };\n  const url: string = `${geocodeUrl}?${queryString(params)}`;\n\n  return httpGet(url)\n    .then((json) => {\n      const {results = [], status = ''} = json;\n\n      if(status === 'OK' && results.length) {\n        const geodata: object = results[0];\n        const addressComponents: GoogleMapsAddressType[] = get(geodata, 'address_components');\n        const getFieldVal = (name: string): string => {\n          const {short_name: shortName = ''} = addressComponents.find((addressField: GoogleMapsAddressType) => {\n            const types = addressField.types || [];\n            return types.findIndex((fieldType: string) => fieldType === name) >= 0;\n          }) || {};\n\n          return shortName;\n        };\n\n        // Street\n        const streetNumber: string = getFieldVal('street_number');\n        const route: string = getFieldVal('route');\n\n        // Location\n        const now: number = Date.now();\n\n        // Item\n        const formatItemType: string = parseChar(itemType).toLowerCase();\n        const formatItemId: string = parseId(itemId);\n        const googleId: string = get(geodata, 'place_id');\n        const update: LocationType = {};\n        const insert: LocationType = {\n          _key: createHash(`post-${sessionId}`),\n          added: now,\n          city: getFieldVal('locality'),\n          country: getFieldVal('country'),\n          formatted: get(geodata, 'formatted_address'),\n          googleId,\n          latitude: get(geodata, 'geometry.location.lat'),\n          longitude: get(geodata, 'geometry.location.lng'),\n          state: getFieldVal('administrative_area_level_1'),\n          street: [streetNumber, route].filter((obj) => obj).join(' '),\n          zip: getFieldVal('postal_code')\n        };\n        const aqlQry: AqlQuery = aql`UPSERT {googleId: ${googleId}}\n            INSERT ${insert}\n            UPDATE ${update}\n            IN locations RETURN NEW`;\n\n        return database.query(aqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((updatedLocation: LocationType = {}) => {\n            let itemDocId: string;\n            const {_key: updatedLocationKey} = updatedLocation;\n\n            switch(formatItemType) {\n              case 'posts':\n                itemDocId = `posts/${formatItemId}`;\n                break;\n              default:\n                itemDocId = '';\n            }\n\n            // If there is a valid item doc id, create an edge\n            if(itemDocId) {\n              const edgeCollection: EdgeCollection = database.collection('hasLocation');\n              const locationId: string = updatedLocationKey;\n              const locationDocId: string = `locations/${locationId}`;\n              const edgeId = createHash(`hasLocation-${locationId}-${sessionId}`);\n              const edge: any = {_from: itemDocId, _key: edgeId, _to: locationDocId};\n\n              return edgeCollection.save(edge, {returnNew: true}).then(() => updatedLocation);\n            }\n\n            // Otherwise just return the new location\n            return updatedLocation;\n          })\n          .catch((error: Error) => logError({\n            action,\n            category: eventCategory,\n            label: 'db_error'\n          }, error, context).then(() => null));\n      }\n\n      return {};\n    });\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,wBAA0C;AAC1C,mBAA6C;AAC7C,sBAAkB;AAIlB,iBAAgB;AAEhB,oBAAqB;AAIrB,IAAAA,gBAAuB;AAEvB,MAAM,gBAAwB;AAEvB,MAAM,cAAc,CAAC,SAAqB,aAAkD;AACjG,QAAM,SAAiB;AACvB,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,EAAC,SAAS,QAAQ,SAAQ,IAAI;AACpC,QAAM,aAAqB,qBAAO,IAAI,oBAAoB;AAC1D,QAAM,SAAiB;AAAA,IACrB;AAAA,IACA,KAAK,qBAAO,IAAI,oBAAoB;AAAA,EACtC;AACA,QAAM,MAAc,GAAG,UAAU,QAAI,+BAAY,MAAM,CAAC;AAExD,aAAO,kBAAAC,KAAQ,GAAG,EACf,KAAK,CAAC,SAAS;AACd,UAAM,EAAC,UAAU,CAAC,GAAG,SAAS,GAAE,IAAI;AAEpC,QAAG,WAAW,QAAQ,QAAQ,QAAQ;AACpC,YAAM,UAAkB,QAAQ,CAAC;AACjC,YAAM,wBAA6C,WAAAC,SAAI,SAAS,oBAAoB;AACpF,YAAM,cAAc,CAAC,SAAyB;AAC5C,cAAM,EAAC,YAAY,YAAY,GAAE,IAAI,kBAAkB,KAAK,CAAC,iBAAwC;AACnG,gBAAM,QAAQ,aAAa,SAAS,CAAC;AACrC,iBAAO,MAAM,UAAU,CAAC,cAAsB,cAAc,IAAI,KAAK;AAAA,QACvE,CAAC,KAAK,CAAC;AAEP,eAAO;AAAA,MACT;AAGA,YAAM,eAAuB,YAAY,eAAe;AACxD,YAAM,QAAgB,YAAY,OAAO;AAGzC,YAAM,MAAc,KAAK,IAAI;AAG7B,YAAM,qBAAyB,wBAAU,QAAQ,EAAE,YAAY;AAC/D,YAAM,mBAAuB,sBAAQ,MAAM;AAC3C,YAAM,eAAmB,WAAAA,SAAI,SAAS,UAAU;AAChD,YAAM,SAAuB,CAAC;AAC9B,YAAM,SAAuB;AAAA,QAC3B,UAAM,yBAAW,QAAQ,SAAS,EAAE;AAAA,QACpC,OAAO;AAAA,QACP,MAAM,YAAY,UAAU;AAAA,QAC5B,SAAS,YAAY,SAAS;AAAA,QAC9B,eAAW,WAAAA,SAAI,SAAS,mBAAmB;AAAA,QAC3C;AAAA,QACA,cAAU,WAAAA,SAAI,SAAS,uBAAuB;AAAA,QAC9C,eAAW,WAAAA,SAAI,SAAS,uBAAuB;AAAA,QAC/C,OAAO,YAAY,6BAA6B;AAAA,QAChD,QAAQ,CAAC,cAAc,KAAK,EAAE,OAAO,CAAC,QAAQ,GAAG,EAAE,KAAK,GAAG;AAAA,QAC3D,KAAK,YAAY,aAAa;AAAA,MAChC;AACA,YAAM,SAAmB,wCAAwB,QAAQ;AAAA,qBAC5C,MAAM;AAAA,qBACN,MAAM;AAAA;AAGnB,aAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,kBAAgC,CAAC,MAAM;AAC5C,YAAI;AACJ,cAAM,EAAC,MAAM,mBAAkB,IAAI;AAEnC,gBAAO,gBAAgB;AAAA,UACrB,KAAK;AACH,wBAAY,SAAS,YAAY;AACjC;AAAA,UACF;AACE,wBAAY;AAAA,QAChB;AAGA,YAAG,WAAW;AACZ,gBAAM,iBAAiC,SAAS,WAAW,aAAa;AACxE,gBAAM,aAAqB;AAC3B,gBAAM,gBAAwB,aAAa,UAAU;AACrD,gBAAM,aAAS,yBAAW,eAAe,UAAU,IAAI,SAAS,EAAE;AAClE,gBAAM,OAAY,EAAC,OAAO,WAAW,MAAM,QAAQ,KAAK,cAAa;AAErE,iBAAO,eAAe,KAAK,MAAM,EAAC,WAAW,KAAI,CAAC,EAAE,KAAK,MAAM,eAAe;AAAA,QAChF;AAGA,eAAO;AAAA,MACT,CAAC,EACA,MAAM,CAAC,cAAiB,wBAAS;AAAA,QAChC;AAAA,QACA,UAAU;AAAA,QACV,OAAO;AAAA,MACT,GAAG,OAAO,OAAO,EAAE,KAAK,MAAM,IAAI,CAAC;AAAA,IACvC;AAEA,WAAO,CAAC;AAAA,EACV,CAAC;AACL;",
  "names": ["import_utils", "httpGet", "get"]
}

110
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/locations.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 {get as httpGet, queryString} from '@nlabs/rip-hunter';\nimport {createHash, parseChar, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {GoogleMapsAddressType, GoogleMapsResultType} from '../types/google';\nimport {LocationType} from '../types/locations';\nimport {logError} from '../utils/analyticsUtils';\nimport {ErrorTypes} from '../types/error';\n\nconst eventCategory: string = 'locations';\n\nexport const getFieldVal = (addressComponents: GoogleMapsAddressType[], name: string): string => {\n  const {short_name: shortName = ''} = addressComponents.find((addressField: GoogleMapsAddressType) => {\n    const types = addressField.types || [];\n    return types.findIndex((fieldType: string) => fieldType === name) >= 0;\n  }) || {};\n\n  return shortName;\n};\n\nexport const addLocation = (context: ApiContext, location: LocationType): Promise<LocationType> => {\n  const action: string = 'add';\n  const {database, session: {userId: sessionId}} = context;\n  const {address, itemId, itemType} = location;\n  const geocodeUrl: string = Config.get('google.geocode.url');\n  const params: object = {\n    address,\n    key: Config.get('google.geocode.key')\n  };\n  const url: string = `${geocodeUrl}?${queryString(params)}`;\n\n  return httpGet(url)\n    .then((json) => {\n      const {results = [], status = ''} = json;\n\n      if(status === 'OK' && results.length) {\n        const geodata: GoogleMapsResultType = results[0];\n        const addressComponents: GoogleMapsAddressType[] = geodata?.address_components || [];\n\n        // Street\n        const streetNumber: string = getFieldVal(addressComponents, 'street_number');\n        const route: string = getFieldVal(addressComponents, 'route');\n\n        // Location\n        const now: number = Date.now();\n\n        // Item\n        const formatItemType: string = parseChar(itemType).toLowerCase();\n        const formatItemId: string = parseId(itemId);\n        const googleId: string = geodata?.place_id || '';\n        const update: LocationType = {};\n        const insert: LocationType = {\n          _key: createHash(`post-${sessionId}`),\n          added: now,\n          city: getFieldVal(addressComponents, 'locality'),\n          country: getFieldVal(addressComponents, 'country'),\n          formatted: geodata?.formatted_address,\n          googleId,\n          latitude: geodata?.geometry.location.lat,\n          longitude: geodata?.geometry.location.lng,\n          state: getFieldVal(addressComponents, 'administrative_area_level_1'),\n          street: [streetNumber, route].filter((obj) => obj).join(' '),\n          zip: getFieldVal(addressComponents, 'postal_code')\n        };\n        const aqlQry: AqlQuery = aql`UPSERT {googleId: ${googleId}}\n            INSERT ${insert}\n            UPDATE ${update}\n            IN locations RETURN NEW`;\n\n        return database.query(aqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((updatedLocation: LocationType) => {\n            let itemDocId: string;\n            const {_key: updatedLocationKey} = updatedLocation;\n\n            switch(formatItemType) {\n              case 'posts':\n                itemDocId = `posts/${formatItemId}`;\n                break;\n              default:\n                itemDocId = '';\n            }\n\n            // If there is a valid item doc id, create an edge\n            if(itemDocId) {\n              const edgeCollection: EdgeCollection = database.collection('hasLocation');\n              const locationId: string = updatedLocationKey;\n              const locationDocId: string = `locations/${locationId}`;\n              const edgeId = createHash(`hasLocation-${locationId}-${sessionId}`);\n              const edge: any = {_from: itemDocId, _key: edgeId, _to: locationDocId};\n\n              return edgeCollection.save(edge, {returnNew: true}).then(() => updatedLocation);\n            }\n\n            // Otherwise just return the new location\n            return updatedLocation;\n          })\n          .catch((error: Error) => logError({\n            action,\n            category: eventCategory,\n            label: ErrorTypes.DATABASE_ERROR\n          }, error, context).then(() => null));\n      }\n\n      return null;\n    });\n};\n"],
  "mappings": "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",
  "names": ["httpGet"]
}

@@ -0,0 +1,13 @@
1
+ import { Database } from 'arangojs';
2
+ import type { ApiContext } from '../types/auth';
3
+ import type { MessageInputType, MessageType } from '../types/messages';
4
+ export declare const getMessages: (context: ApiContext, conversationId: string, { from, to }: {
5
+ from: any;
6
+ to: any;
7
+ }) => Promise<MessageType[]>;
8
+ export declare const updateMessage: (context: ApiContext, message: MessageInputType) => Promise<MessageType>;
9
+ export declare const saveMessage: (context: ApiContext, messageId: string, conversationId: string) => Promise<MessageType>;
10
+ export declare const unsaveMessage: (context: ApiContext, messageId: string, conversationId: string) => Promise<MessageType>;
11
+ export declare const deleteMessage: (context: ApiContext, messageId: string, conversationId: string) => Promise<MessageType>;
12
+ export declare const getMessage: (data: MessageType) => MessageType;
13
+ export declare const cleanMessages: (database: Database) => Promise<number>;
@@ -39,8 +39,8 @@ module.exports = __toCommonJS(messages_exports);
39
39
  var import_utils = require("@nlabs/utils");
40
40
  var import_arangojs = require("arangojs");
41
41
  var import_cloneDeep = __toESM(require("lodash/cloneDeep"));
42
- var import_utils2 = require("../utils");
43
- var import_conversations2 = require("./conversations");
42
+ var import_conversations = require("./conversations");
43
+ var import_arangodbUtils = require("../utils/arangodbUtils");
44
44
  const getMessages = (context, conversationId, { from, to }) => {
45
45
  const { database, session: { userId: sessionId } } = context;
46
46
  const formatConversationId = (0, import_utils.parseId)(conversationId);
@@ -54,7 +54,7 @@ const getMessages = (context, conversationId, { from, to }) => {
54
54
  if (!conversations.length) {
55
55
  return [];
56
56
  }
57
- const limit = (0, import_utils2.getLimit)(from, to);
57
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
58
58
  const aqlQry = `FOR m IN messages
59
59
  FILTER m.conversationId == "${formatConversationId}"
60
60
  SORT m.added DESC
@@ -110,13 +110,13 @@ const updateMessage = (context, message) => {
110
110
  const saveMessage = (context, messageId, conversationId) => {
111
111
  const { database, session: { userId: sessionId } } = context;
112
112
  const formatId = (0, import_utils.parseId)(messageId);
113
- return (0, import_conversations2.getConversation)(context, conversationId).then((conversation) => {
113
+ return (0, import_conversations.getConversation)(context, conversationId).then((conversation) => {
114
114
  const { _key: conversationKey } = conversation;
115
115
  const aqlQry = import_arangojs.aql`FOR m IN messages
116
116
  FILTER m._key == ${formatId} && m.to == ${conversationKey}
117
117
  UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages
118
118
  RETURN NEW`;
119
- return database.query(aqlQry).then((cursor) => cursor.next()).then((message = {}) => {
119
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((message) => {
120
120
  if (message) {
121
121
  }
122
122
  return message;
@@ -128,13 +128,13 @@ const saveMessage = (context, messageId, conversationId) => {
128
128
  const unsaveMessage = (context, messageId, conversationId) => {
129
129
  const { database, session: { userId: sessionId } } = context;
130
130
  const formatId = (0, import_utils.parseId)(messageId);
131
- return (0, import_conversations2.getConversation)(context, conversationId).then((conversation) => {
131
+ return (0, import_conversations.getConversation)(context, conversationId).then((conversation) => {
132
132
  const { _key: conversationKey } = conversation;
133
133
  const aqlQry = import_arangojs.aql`FOR m IN messages
134
134
  FILTER m._key == ${formatId} && m.to == ${conversationKey}
135
135
  UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages
136
136
  RETURN NEW`;
137
- return database.query(aqlQry).then((cursor) => cursor.next()).then((message = {}) => {
137
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((message) => {
138
138
  if (message) {
139
139
  }
140
140
  return message;
@@ -146,13 +146,13 @@ const unsaveMessage = (context, messageId, conversationId) => {
146
146
  const deleteMessage = (context, messageId, conversationId) => {
147
147
  const { database, session: { userId: sessionId } } = context;
148
148
  const formatId = (0, import_utils.parseId)(messageId);
149
- return (0, import_conversations2.getConversation)(context, conversationId).then((conversation) => {
149
+ return (0, import_conversations.getConversation)(context, conversationId).then((conversation) => {
150
150
  const { _key: conversationKey } = conversation;
151
151
  const aqlQry = import_arangojs.aql`FOR m IN messages
152
152
  FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}
153
153
  REMOVE m IN messages
154
154
  RETURN OLD`;
155
- return database.query(aqlQry).then((cursor) => cursor.next()).then((message = {}) => {
155
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((message) => {
156
156
  if (message) {
157
157
  }
158
158
  return message;
@@ -202,4 +202,4 @@ const cleanMessages = (database) => {
202
202
  unsaveMessage,
203
203
  updateMessage
204
204
  });
205
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/messages.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ConversationType} from '../types/conversations';\nimport {MessageInputType, MessageType} from '../types/messages';\nimport {getLimit} from '../utils';\nimport {getConversation} from './conversations';\n\n// const eventCategory: string = 'messages';\n\nexport const getMessages = (context: ApiContext, conversationId: string, {from, to}): Promise<MessageType[]> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatConversationId: string = parseId(conversationId);\n  const sessionDocId: string = `users/${sessionId}`;\n  const conversationDocId: string = `conversations/${formatConversationId}`;\n\n  const conversationQry = aql`FOR e IN hasConversation\n    FILTER e._from == ${sessionDocId} && e._to == ${conversationDocId}\n    LIMIT 1\n    RETURN e`;\n\n  return database.query(conversationQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((conversations) => {\n      if(!conversations.length) {\n        return [];\n      }\n\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.conversationId == \"${formatConversationId}\"\n          SORT m.added DESC\n          ${limit.aql}\n          SORT m.added ASC\n          LET user = FIRST(\n            FOR u IN users\n            FILTER u._key == m.userId\n            LIMIT 1\n            RETURN u\n          )\n          RETURN MERGE(m, {user: user})`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const updateMessage = (context: ApiContext, message: MessageInputType): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const {\n    conversationId,\n    files,\n    images,\n    messageId = createHash(`message-${sessionId}`)\n  } = message;\n  const formatConversationId: string = parseId(conversationId);\n\n  if(formatConversationId === '') {\n    throw new Error('required_conversationId');\n  }\n\n  const now: number = Date.now();\n  const update: MessageType = {\n    content: parseString(message.content, 640),\n    files: files || [],\n    images: images || [],\n    modified: now\n  };\n  const formatMsgId: string = parseId(messageId);\n  const insert: MessageType = {\n    ...cloneDeep(update),\n    _key: formatMsgId,\n    added: now,\n    conversationId: formatConversationId,\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatMsgId}, conversationId: ${formatConversationId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update} IN messages\n    RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const saveMessage = (context: ApiContext, messageId: string, conversationId: string): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatId: string = parseId(messageId);\n\n  return getConversation(context, conversationId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey}\n        UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages\n        RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(message) {\n            // Broadcast to message box\n            // const message: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_save', message);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const unsaveMessage = (context: ApiContext, messageId: string, conversationId: string): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatId: string = parseId(messageId);\n\n  return getConversation(context, conversationId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry: AqlQuery = aql`FOR m IN messages\n          FILTER m._key == ${formatId} && m.to == ${conversationKey}\n          UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages\n          RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(message) {\n            // Broadcast to message box\n            // const message: MessageType = Messages.getMessageObject(message);\n            // io.to(message.id).emit('message_unsave', message);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const deleteMessage = (context: ApiContext, messageId: string, conversationId: string): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatId: string = parseId(messageId);\n\n  return getConversation(context, conversationId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}\n        REMOVE m IN messages\n        RETURN OLD`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(message) {\n            // Broadcast to message box\n            // const message: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_delete', message);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const getMessage = (data: MessageType): MessageType => {\n  const {\n    added,\n    content,\n    conversationId,\n    files,\n    _key: messageId,\n    read,\n    saved,\n    userId\n  } = data;\n\n  return {\n    added,\n    content,\n    conversationId,\n    files,\n    messageId,\n    read,\n    saved,\n    userId\n  };\n};\n\nexport const cleanMessages = (database: Database): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry = aql`FOR m IN messages\n      FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n      REMOVE m IN messages\n      RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: MessageType[]) => list.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "import_conversations", "cloneDeep"]
}

205
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/messages.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\n\nimport type {ArangoDbLimit} from '../types/arangodb';\nimport type {ApiContext} from '../types/auth';\nimport type {ConversationType} from '../types/conversations';\nimport type {MessageInputType, MessageType} from '../types/messages';\nimport {getConversation} from './conversations';\nimport {getLimit} from '../utils/arangodbUtils';\n\n// const eventCategory: string = 'messages';\n\nexport const getMessages = (context: ApiContext, conversationId: string, {from, to}): Promise<MessageType[]> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatConversationId: string = parseId(conversationId);\n  const sessionDocId: string = `users/${sessionId}`;\n  const conversationDocId: string = `conversations/${formatConversationId}`;\n\n  const conversationQry = aql`FOR e IN hasConversation\n    FILTER e._from == ${sessionDocId} && e._to == ${conversationDocId}\n    LIMIT 1\n    RETURN e`;\n\n  return database.query(conversationQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((conversations) => {\n      if(!conversations.length) {\n        return [];\n      }\n\n      const limit: ArangoDbLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.conversationId == \"${formatConversationId}\"\n          SORT m.added DESC\n          ${limit.aql}\n          SORT m.added ASC\n          LET user = FIRST(\n            FOR u IN users\n            FILTER u._key == m.userId\n            LIMIT 1\n            RETURN u\n          )\n          RETURN MERGE(m, {user: user})`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const updateMessage = (context: ApiContext, message: MessageInputType): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const {\n    conversationId,\n    files,\n    images,\n    messageId = createHash(`message-${sessionId}`)\n  } = message;\n  const formatConversationId: string = parseId(conversationId);\n\n  if(formatConversationId === '') {\n    throw new Error('required_conversationId');\n  }\n\n  const now: number = Date.now();\n  const update: MessageType = {\n    content: parseString(message.content, 640),\n    files: files || [],\n    images: images || [],\n    modified: now\n  };\n  const formatMsgId: string = parseId(messageId);\n  const insert: MessageType = {\n    ...cloneDeep(update),\n    _key: formatMsgId,\n    added: now,\n    conversationId: formatConversationId,\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatMsgId}, conversationId: ${formatConversationId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update} IN messages\n    RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const saveMessage = (context: ApiContext, messageId: string, conversationId: string): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatId: string = parseId(messageId);\n\n  return getConversation(context, conversationId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey}\n        UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages\n        RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType) => {\n          if(message) {\n            // Broadcast to message box\n            // const message: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_save', message);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const unsaveMessage = (context: ApiContext, messageId: string, conversationId: string): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatId: string = parseId(messageId);\n\n  return getConversation(context, conversationId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry: AqlQuery = aql`FOR m IN messages\n          FILTER m._key == ${formatId} && m.to == ${conversationKey}\n          UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages\n          RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType) => {\n          if(message) {\n            // Broadcast to message box\n            // const message: MessageType = Messages.getMessageObject(message);\n            // io.to(message.id).emit('message_unsave', message);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const deleteMessage = (context: ApiContext, messageId: string, conversationId: string): Promise<MessageType> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatId: string = parseId(messageId);\n\n  return getConversation(context, conversationId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}\n        REMOVE m IN messages\n        RETURN OLD`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType) => {\n          if(message) {\n            // Broadcast to message box\n            // const message: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_delete', message);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const getMessage = (data: MessageType): MessageType => {\n  const {\n    added,\n    content,\n    conversationId,\n    files,\n    _key: messageId,\n    read,\n    saved,\n    userId\n  } = data;\n\n  return {\n    added,\n    content,\n    conversationId,\n    files,\n    messageId,\n    read,\n    saved,\n    userId\n  };\n};\n\nexport const cleanMessages = (database: Database): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry = aql`FOR m IN messages\n      FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n      REMOVE m IN messages\n      RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: MessageType[]) => list.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,mBAA+C;AAC/C,sBAA4B;AAG5B,uBAAsB;AAMtB,2BAA8B;AAC9B,2BAAuB;AAIhB,MAAM,cAAc,CAAC,SAAqB,gBAAwB,EAAC,MAAM,GAAE,MAA8B;AAC9G,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,2BAA+B,sBAAQ,cAAc;AAC3D,QAAM,eAAuB,SAAS,SAAS;AAC/C,QAAM,oBAA4B,iBAAiB,oBAAoB;AAEvE,QAAM,kBAAkB;AAAA,wBACF,YAAY,gBAAgB,iBAAiB;AAAA;AAAA;AAInE,SAAO,SAAS,MAAM,eAAe,EAClC,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC,EAC1C,KAAK,CAAC,kBAAkB;AACvB,QAAG,CAAC,cAAc,QAAQ;AACxB,aAAO,CAAC;AAAA,IACV;AAEA,UAAM,YAAuB,+BAAS,MAAM,EAAE;AAC9C,UAAM,SAAiB;AAAA,wCACW,oBAAoB;AAAA;AAAA,YAEhD,MAAM,GAAG;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUf,WAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC,EAC1C,MAAM,CAAC,UAAiB;AACvB,YAAM;AAAA,IACR,CAAC;AAAA,EACL,CAAC;AACL;AAEO,MAAM,gBAAgB,CAAC,SAAqB,YAAoD;AACrG,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA,gBAAY,yBAAW,WAAW,SAAS,EAAE;AAAA,EAC/C,IAAI;AACJ,QAAM,2BAA+B,sBAAQ,cAAc;AAE3D,MAAG,yBAAyB,IAAI;AAC9B,UAAM,IAAI,MAAM,yBAAyB;AAAA,EAC3C;AAEA,QAAM,MAAc,KAAK,IAAI;AAC7B,QAAM,SAAsB;AAAA,IAC1B,aAAS,0BAAY,QAAQ,SAAS,GAAG;AAAA,IACzC,OAAO,SAAS,CAAC;AAAA,IACjB,QAAQ,UAAU,CAAC;AAAA,IACnB,UAAU;AAAA,EACZ;AACA,QAAM,kBAAsB,sBAAQ,SAAS;AAC7C,QAAM,SAAsB;AAAA,IAC1B,OAAG,iBAAAA,SAAU,MAAM;AAAA,IACnB,MAAM;AAAA,IACN,OAAO;AAAA,IACP,gBAAgB;AAAA,IAChB,QAAQ;AAAA,EACV;AACA,QAAM,SAAmB,oCAAoB,WAAW,qBAAqB,oBAAoB,aAAa,SAAS;AAAA,aAC5G,MAAM;AAAA,aACN,MAAM;AAAA;AAGjB,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,MAAM,CAAC,UAAiB;AACvB,UAAM;AAAA,EACR,CAAC;AACL;AAEO,MAAM,cAAc,CAAC,SAAqB,WAAmB,mBAAiD;AACnH,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,eAAmB,sBAAQ,SAAS;AAE1C,aAAO,sCAAgB,SAAS,cAAc,EAC3C,KAAK,CAAC,iBAAmC;AACxC,UAAM,EAAC,MAAM,gBAAe,IAAI;AAChC,UAAM,SAAS;AAAA,2BACM,QAAQ,eAAe,eAAe;AAAA,gDACjB,SAAS;AAAA;AAGnD,WAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,YAAyB;AAC9B,UAAG,SAAS;AAAA,MAIZ;AAEA,aAAO;AAAA,IACT,CAAC,EACA,MAAM,CAAC,UAAiB;AACvB,YAAM;AAAA,IACR,CAAC;AAAA,EACL,CAAC;AACL;AAEO,MAAM,gBAAgB,CAAC,SAAqB,WAAmB,mBAAiD;AACrH,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,eAAmB,sBAAQ,SAAS;AAE1C,aAAO,sCAAgB,SAAS,cAAc,EAC3C,KAAK,CAAC,iBAAmC;AACxC,UAAM,EAAC,MAAM,gBAAe,IAAI;AAChC,UAAM,SAAmB;AAAA,6BACF,QAAQ,eAAe,eAAe;AAAA,wDACX,SAAS;AAAA;AAG3D,WAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,YAAyB;AAC9B,UAAG,SAAS;AAAA,MAIZ;AAEA,aAAO;AAAA,IACT,CAAC,EACA,MAAM,CAAC,UAAiB;AACvB,YAAM;AAAA,IACR,CAAC;AAAA,EACL,CAAC;AACL;AAEO,MAAM,gBAAgB,CAAC,SAAqB,WAAmB,mBAAiD;AACrH,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,UAAS,EAAC,IAAI;AACjD,QAAM,eAAmB,sBAAQ,SAAS;AAE1C,aAAO,sCAAgB,SAAS,cAAc,EAC3C,KAAK,CAAC,iBAAmC;AACxC,UAAM,EAAC,MAAM,gBAAe,IAAI;AAChC,UAAM,SAAS;AAAA,2BACM,QAAQ,eAAe,eAAe,iBAAiB,SAAS;AAAA;AAAA;AAIrF,WAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,KAAK,CAAC,EAC3C,KAAK,CAAC,YAAyB;AAC9B,UAAG,SAAS;AAAA,MAIZ;AAEA,aAAO;AAAA,IACT,CAAC,EACA,MAAM,CAAC,UAAiB;AACvB,YAAM;AAAA,IACR,CAAC;AAAA,EACL,CAAC;AACL;AAEO,MAAM,aAAa,CAAC,SAAmC;AAC5D,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,MAAM;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AAEJ,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAEO,MAAM,gBAAgB,CAAC,aAAwC;AAEpE,QAAM,SAAS;AAAA;AAAA;AAAA;AAKf,SAAO,SAAS,MAAM,MAAM,EACzB,KAAK,CAAC,WAAwB,OAAO,IAAI,CAAC,EAC1C,KAAK,CAAC,SAAwB,KAAK,MAAM,EACzC,MAAM,CAAC,UAAiB;AACvB,UAAM;AAAA,EACR,CAAC;AACL;",
  "names": ["cloneDeep"]
}

@@ -0,0 +1,5 @@
1
+ import { Provider, Responses } from 'apn';
2
+ import type { NotificationType } from '../types/notifications';
3
+ export declare const getApnProvider: () => Provider;
4
+ export declare const pushNotification: (deviceTokens: string[], note: NotificationType) => Promise<Responses>;
5
+ export declare const clearBadges: (deviceTokens: string[]) => Promise<Responses>;
@@ -56,4 +56,4 @@ const clearBadges = (deviceTokens) => {
56
56
  getApnProvider,
57
57
  pushNotification
58
58
  });
59
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Tm90aWZpY2F0aW9uIGFzIEFQTk5vdGlmaWNhdGlvbiwgUHJvdmlkZXIsIFJlc3BvbnNlc30gZnJvbSAnYXBuJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnbm90aWZpY2F0aW9ucyc7XG5cbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCk6IFByb3ZpZGVyID0+IG5ldyBQcm92aWRlcih7XG4gIGNhOiBDb25maWcuZ2V0KCdhcHAuYXBuLmNhJyksXG4gIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICBrZXk6IENvbmZpZy5nZXQoJ2FwcC5hcG4ua2V5JyksXG4gIHByb2R1Y3Rpb246IENvbmZpZy5nZXQoJ2Vudmlyb25tZW50JykgPT09ICdwcm9kJ1xufSk7XG5cbmV4cG9ydCBjb25zdCBwdXNoTm90aWZpY2F0aW9uID0gKGRldmljZVRva2Vuczogc3RyaW5nW10sIG5vdGU6IE5vdGlmaWNhdGlvblR5cGUpOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXI6IFByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uOiBBUE5Ob3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi50b3BpYyA9IENvbmZpZy5nZXQoJ2FwcC5hcG4uaWQnKTtcbiAgbm90aWZpY2F0aW9uLmFsZXJ0ID0gbm90ZS5tZXNzYWdlO1xuXG4gIGlmKG5vdGUuZGF0YSkge1xuICAgIG5vdGlmaWNhdGlvbi5tdXRhYmxlQ29udGVudCA9IHRydWU7XG4gICAgbm90aWZpY2F0aW9uLnBheWxvYWQgPSBub3RlLmRhdGE7XG4gIH1cblxuICBpZihub3RlLmJhZGdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBub3RpZmljYXRpb24uYmFkZ2UgPSBub3RlLmJhZGdlO1xuICB9XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNsZWFyQmFkZ2VzID0gKGRldmljZVRva2Vuczogc3RyaW5nW10pOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi5iYWRnZSA9IDA7XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxpQkFBbUU7QUFFbkUsb0JBQXFCO0FBTWQsTUFBTSxpQkFBaUIsTUFBZ0IsSUFBSSxvQkFBUztBQUFBLEVBQ3pELElBQUkscUJBQU8sSUFBSSxZQUFZO0FBQUEsRUFDM0IsTUFBTSxxQkFBTyxJQUFJLGNBQWM7QUFBQSxFQUMvQixLQUFLLHFCQUFPLElBQUksYUFBYTtBQUFBLEVBQzdCLFlBQVkscUJBQU8sSUFBSSxhQUFhLE1BQU07QUFDNUMsQ0FBQztBQUVNLE1BQU0sbUJBQW1CLENBQUMsY0FBd0IsU0FBK0M7QUFFdEcsUUFBTSxXQUFxQixlQUFlO0FBQzFDLFFBQU0sZUFBZ0MsSUFBSSxXQUFBQSxhQUFnQjtBQUMxRCxlQUFhLFFBQVEscUJBQU8sSUFBSSxZQUFZO0FBQzVDLGVBQWEsUUFBUSxLQUFLO0FBRTFCLE1BQUcsS0FBSyxNQUFNO0FBQ1osaUJBQWEsaUJBQWlCO0FBQzlCLGlCQUFhLFVBQVUsS0FBSztBQUFBLEVBQzlCO0FBRUEsTUFBRyxLQUFLLFVBQVUsUUFBVztBQUMzQixpQkFBYSxRQUFRLEtBQUs7QUFBQSxFQUM1QjtBQUVBLFNBQU8sU0FBUyxLQUFLLGNBQWMsWUFBWTtBQUNqRDtBQUVPLE1BQU0sY0FBYyxDQUFDLGlCQUErQztBQUV6RSxRQUFNLFdBQVcsZUFBZTtBQUNoQyxRQUFNLGVBQWUsSUFBSSxXQUFBQSxhQUFnQjtBQUN6QyxlQUFhLFFBQVE7QUFFckIsU0FBTyxTQUFTLEtBQUssY0FBYyxZQUFZO0FBQ2pEOyIsCiAgIm5hbWVzIjogWyJBUE5Ob3RpZmljYXRpb24iXQp9Cg==
59
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB0eXBlIHtOb3RpZmljYXRpb25UeXBlfSBmcm9tICcuLi90eXBlcy9ub3RpZmljYXRpb25zJztcblxuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCkgPT4gbmV3IFByb3ZpZGVyKHtcbiAgY2E6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2EnKSxcbiAgY2VydDogQ29uZmlnLmdldCgnYXBwLmFwbi5jZXJ0JyksXG4gIGtleTogQ29uZmlnLmdldCgnYXBwLmFwbi5rZXknKSxcbiAgcHJvZHVjdGlvbjogQ29uZmlnLmdldCgnZW52aXJvbm1lbnQnKSA9PT0gJ3Byb2QnXG59KTtcblxuZXhwb3J0IGNvbnN0IHB1c2hOb3RpZmljYXRpb24gPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSwgbm90ZTogTm90aWZpY2F0aW9uVHlwZSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlcjogUHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb246IEFQTk5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLnRvcGljID0gQ29uZmlnLmdldCgnYXBwLmFwbi5pZCcpO1xuICBub3RpZmljYXRpb24uYWxlcnQgPSBub3RlLm1lc3NhZ2U7XG5cbiAgaWYobm90ZS5kYXRhKSB7XG4gICAgbm90aWZpY2F0aW9uLm11dGFibGVDb250ZW50ID0gdHJ1ZTtcbiAgICBub3RpZmljYXRpb24ucGF5bG9hZCA9IG5vdGUuZGF0YTtcbiAgfVxuXG4gIGlmKG5vdGUuYmFkZ2UgIT09IHVuZGVmaW5lZCkge1xuICAgIG5vdGlmaWNhdGlvbi5iYWRnZSA9IG5vdGUuYmFkZ2U7XG4gIH1cblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJCYWRnZXMgPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlciA9IGdldEFwblByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLmJhZGdlID0gMDtcblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQU1BLGlCQUFtRTtBQUVuRSxvQkFBcUI7QUFHZCxNQUFNLGlCQUFpQixNQUFNLElBQUksb0JBQVM7QUFBQSxFQUMvQyxJQUFJLHFCQUFPLElBQUksWUFBWTtBQUFBLEVBQzNCLE1BQU0scUJBQU8sSUFBSSxjQUFjO0FBQUEsRUFDL0IsS0FBSyxxQkFBTyxJQUFJLGFBQWE7QUFBQSxFQUM3QixZQUFZLHFCQUFPLElBQUksYUFBYSxNQUFNO0FBQzVDLENBQUM7QUFFTSxNQUFNLG1CQUFtQixDQUFDLGNBQXdCLFNBQStDO0FBRXRHLFFBQU0sV0FBcUIsZUFBZTtBQUMxQyxRQUFNLGVBQWdDLElBQUksV0FBQUEsYUFBZ0I7QUFDMUQsZUFBYSxRQUFRLHFCQUFPLElBQUksWUFBWTtBQUM1QyxlQUFhLFFBQVEsS0FBSztBQUUxQixNQUFHLEtBQUssTUFBTTtBQUNaLGlCQUFhLGlCQUFpQjtBQUM5QixpQkFBYSxVQUFVLEtBQUs7QUFBQSxFQUM5QjtBQUVBLE1BQUcsS0FBSyxVQUFVLFFBQVc7QUFDM0IsaUJBQWEsUUFBUSxLQUFLO0FBQUEsRUFDNUI7QUFFQSxTQUFPLFNBQVMsS0FBSyxjQUFjLFlBQVk7QUFDakQ7QUFFTyxNQUFNLGNBQWMsQ0FBQyxpQkFBK0M7QUFFekUsUUFBTSxXQUFXLGVBQWU7QUFDaEMsUUFBTSxlQUFlLElBQUksV0FBQUEsYUFBZ0I7QUFDekMsZUFBYSxRQUFRO0FBRXJCLFNBQU8sU0FBUyxLQUFLLGNBQWMsWUFBWTtBQUNqRDsiLAogICJuYW1lcyI6IFsiQVBOTm90aWZpY2F0aW9uIl0KfQo=
@@ -0,0 +1,10 @@
1
+ import { ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType } from '../types';
2
+ export declare const addCustomerAccount: (context: ApiContext) => Promise<boolean>;
3
+ export declare const addBankAccount: (context: ApiContext, bankAccount: PaymentBankAccount) => Promise<boolean>;
4
+ export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<UserType>;
5
+ export declare const updateCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<PaymentCardType>;
6
+ export declare const getCreditCards: (context: ApiContext) => Promise<PaymentCardType[]>;
7
+ export declare const deleteCreditCard: (context: ApiContext, cardId: string) => Promise<boolean>;
8
+ export declare const deleteBankAccount: (context: ApiContext, bankId: string) => Promise<boolean>;
9
+ export declare const createPaymentTransfer: (context: ApiContext, transfer: PaymentTransfer) => Promise<PaymentTransfer>;
10
+ export declare const createPaymentHold: (context: ApiContext, payment: PaymentCharge) => Promise<PaymentCharge>;