@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
@@ -31,47 +31,71 @@ __export(sms_exports, {
31
31
  sendSmsTemplate: () => sendSmsTemplate
32
32
  });
33
33
  module.exports = __toCommonJS(sms_exports);
34
+ var import_client_sns = require("@aws-sdk/client-sns");
34
35
  var import_utils = require("@nlabs/utils");
35
36
  var import_fs = __toESM(require("fs"));
36
- var import_twilio = __toESM(require("twilio"));
37
37
  var import_config = require("../config");
38
- var import_email = require("./email");
39
- const sendSms = (params) => {
40
- const {
41
- app = {},
42
- content,
43
- user = {}
44
- } = params;
45
- const country = user.country || "US";
46
- const phone = (0, import_utils.parsePhone)(user.phone, country);
47
- const templateContent = (0, import_email.appTemplate)(app, content);
48
- const twilio = (0, import_twilio.default)(import_config.Config.get("twilio.sid"), import_config.Config.get("twilio.token"));
49
- const cfg = {
50
- body: templateContent,
51
- from: import_config.Config.get("twilio.number"),
52
- to: phone
53
- };
54
- return new Promise((resolve, reject) => {
55
- twilio.sendMessage(cfg, (error, data) => {
56
- if (error) {
57
- reject(new Error(error.error_message));
58
- } else {
59
- resolve(data);
60
- }
61
- });
38
+ var import_error = require("../types/error");
39
+ var import_analyticsUtils = require("../utils/analyticsUtils");
40
+ const eventCategory = "sms";
41
+ const sendSms = async ({
42
+ content,
43
+ user,
44
+ variables = {}
45
+ }) => {
46
+ const action = "sendSms";
47
+ const snsClient = new import_client_sns.SNSClient({
48
+ credentials: import_config.Config.get("aws.credentials"),
49
+ region: import_config.Config.get("aws.region")
50
+ });
51
+ const { country = "US", phone } = user;
52
+ const phoneNumber = (0, import_utils.parsePhone)(phone, country);
53
+ const templateContent = (0, import_utils.parseTemplate)(content, variables);
54
+ return await snsClient.send(
55
+ new import_client_sns.PublishCommand({
56
+ Message: templateContent,
57
+ MessageAttributes: {
58
+ "AWS.SNS.SMS.SMSType": {
59
+ DataType: "String",
60
+ StringValue: "Transactional"
61
+ },
62
+ "AWS.SNS.SMS.SenderID": {
63
+ DataType: "String",
64
+ StringValue: import_config.Config.get("app.id").trim().replace(/ /g, "").substring(0, 11)
65
+ }
66
+ },
67
+ PhoneNumber: phoneNumber
68
+ })
69
+ ).then((res) => {
70
+ console.log({ res });
71
+ return res;
72
+ }).catch((error) => {
73
+ console.log({ error });
74
+ return (0, import_analyticsUtils.logError)({
75
+ action,
76
+ category: eventCategory,
77
+ label: import_error.ErrorTypes.SMS_ERROR
78
+ }, error, { session: user });
62
79
  });
63
80
  };
64
- const sendSmsTemplate = (templateName, smsParams) => {
65
- const { app, user, vars } = smsParams;
81
+ const sendSmsTemplate = (templateName, {
82
+ user,
83
+ variables = {}
84
+ }) => {
85
+ const action = "sendSmsTemplate";
66
86
  try {
67
87
  const data = import_fs.default.readFileSync(`./templates/sms/${templateName}.txt`, "utf8");
68
- const text = (0, import_email.appTemplate)(app, data, vars);
69
- const params = { app, text, user };
70
- return sendSms(params).then((res) => res.status === "queued").catch((error) => {
71
- throw error;
72
- });
88
+ const text = (0, import_utils.parseTemplate)(data, variables);
89
+ const params = { text, user };
90
+ return sendSms(params).then((res) => res.status === "queued").catch(
91
+ (error) => (0, import_analyticsUtils.logError)({
92
+ action,
93
+ category: eventCategory,
94
+ label: import_error.ErrorTypes.SMS_ERROR
95
+ }, error, { session: user }).then(() => null)
96
+ );
73
97
  } catch (error) {
74
- return Promise.reject(error);
98
+ return Promise.reject({ errors: [error.message] });
75
99
  }
76
100
  };
77
101
  // Annotate the CommonJS export names for ESM import in node:
@@ -79,4 +103,4 @@ const sendSmsTemplate = (templateName, smsParams) => {
79
103
  sendSms,
80
104
  sendSmsTemplate
81
105
  });
82
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc21zLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtwYXJzZVBob25lfSBmcm9tICdAbmxhYnMvdXRpbHMnO1xuaW1wb3J0IGZzIGZyb20gJ2ZzJztcbmltcG9ydCB0d2lsaW9TZGsgZnJvbSAndHdpbGlvJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge1NNU1BhcmFtc1R5cGUsIFR3aWxpb09wdGlvbnNUeXBlfSBmcm9tICcuLi90eXBlcy9ub3RpZmljYXRpb25zJztcbmltcG9ydCB7YXBwVGVtcGxhdGV9IGZyb20gJy4vZW1haWwnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnc21zJztcblxuLy8gVHdpbGlvXG5leHBvcnQgY29uc3Qgc2VuZFNtcyA9IChwYXJhbXM6IFNNU1BhcmFtc1R5cGUpOiBhbnkgPT4ge1xuICBjb25zdCB7XG4gICAgYXBwID0ge30sXG4gICAgY29udGVudCxcbiAgICB1c2VyID0ge31cbiAgfSA9IHBhcmFtcztcblxuICBjb25zdCBjb3VudHJ5ID0gdXNlci5jb3VudHJ5IHx8ICdVUyc7XG4gIGNvbnN0IHBob25lID0gcGFyc2VQaG9uZSh1c2VyLnBob25lLCBjb3VudHJ5KTtcbiAgY29uc3QgdGVtcGxhdGVDb250ZW50OiBzdHJpbmcgPSBhcHBUZW1wbGF0ZShhcHAsIGNvbnRlbnQpO1xuXG4gIGNvbnN0IHR3aWxpbzogYW55ID0gdHdpbGlvU2RrKENvbmZpZy5nZXQoJ3R3aWxpby5zaWQnKSwgQ29uZmlnLmdldCgndHdpbGlvLnRva2VuJykpO1xuICBjb25zdCBjZmc6IFR3aWxpb09wdGlvbnNUeXBlID0ge1xuICAgIGJvZHk6IHRlbXBsYXRlQ29udGVudCxcbiAgICBmcm9tOiBDb25maWcuZ2V0KCd0d2lsaW8ubnVtYmVyJyksXG4gICAgdG86IHBob25lXG4gIH07XG5cbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB0d2lsaW8uc2VuZE1lc3NhZ2UoY2ZnLCAoZXJyb3IsIGRhdGEpID0+IHtcbiAgICAgIGlmKGVycm9yKSB7XG4gICAgICAgIHJlamVjdChuZXcgRXJyb3IoZXJyb3IuZXJyb3JfbWVzc2FnZSkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmVzb2x2ZShkYXRhKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSk7XG59O1xuXG5leHBvcnQgY29uc3Qgc2VuZFNtc1RlbXBsYXRlID0gKHRlbXBsYXRlTmFtZTogc3RyaW5nLCBzbXNQYXJhbXM6IFNNU1BhcmFtc1R5cGUpOiBQcm9taXNlPGJvb2xlYW4+ID0+IHtcbiAgY29uc3Qge2FwcCwgdXNlciwgdmFyc30gPSBzbXNQYXJhbXM7XG4gIHRyeSB7XG4gICAgY29uc3QgZGF0YSA9IGZzLnJlYWRGaWxlU3luYyhgLi90ZW1wbGF0ZXMvc21zLyR7dGVtcGxhdGVOYW1lfS50eHRgLCAndXRmOCcpO1xuICAgIGNvbnN0IHRleHQgPSBhcHBUZW1wbGF0ZShhcHAsIGRhdGEsIHZhcnMpO1xuICAgIGNvbnN0IHBhcmFtcyA9IHthcHAsIHRleHQsIHVzZXJ9O1xuXG4gICAgcmV0dXJuIHNlbmRTbXMocGFyYW1zKVxuICAgICAgLnRoZW4oKHJlcykgPT4gcmVzLnN0YXR1cyA9PT0gJ3F1ZXVlZCcpXG4gICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgIH0pO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgcmV0dXJuIFByb21pc2UucmVqZWN0KGVycm9yKTtcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLG1CQUF5QjtBQUN6QixnQkFBZTtBQUNmLG9CQUFzQjtBQUV0QixvQkFBcUI7QUFFckIsbUJBQTBCO0FBS25CLE1BQU0sVUFBVSxDQUFDLFdBQStCO0FBQ3JELFFBQU07QUFBQSxJQUNKLE1BQU0sQ0FBQztBQUFBLElBQ1A7QUFBQSxJQUNBLE9BQU8sQ0FBQztBQUFBLEVBQ1YsSUFBSTtBQUVKLFFBQU0sVUFBVSxLQUFLLFdBQVc7QUFDaEMsUUFBTSxZQUFRLHlCQUFXLEtBQUssT0FBTyxPQUFPO0FBQzVDLFFBQU0sc0JBQTBCLDBCQUFZLEtBQUssT0FBTztBQUV4RCxRQUFNLGFBQWMsY0FBQUEsU0FBVSxxQkFBTyxJQUFJLFlBQVksR0FBRyxxQkFBTyxJQUFJLGNBQWMsQ0FBQztBQUNsRixRQUFNLE1BQXlCO0FBQUEsSUFDN0IsTUFBTTtBQUFBLElBQ04sTUFBTSxxQkFBTyxJQUFJLGVBQWU7QUFBQSxJQUNoQyxJQUFJO0FBQUEsRUFDTjtBQUVBLFNBQU8sSUFBSSxRQUFRLENBQUMsU0FBUyxXQUFXO0FBQ3RDLFdBQU8sWUFBWSxLQUFLLENBQUMsT0FBTyxTQUFTO0FBQ3ZDLFVBQUcsT0FBTztBQUNSLGVBQU8sSUFBSSxNQUFNLE1BQU0sYUFBYSxDQUFDO0FBQUEsTUFDdkMsT0FBTztBQUNMLGdCQUFRLElBQUk7QUFBQSxNQUNkO0FBQUEsSUFDRixDQUFDO0FBQUEsRUFDSCxDQUFDO0FBQ0g7QUFFTyxNQUFNLGtCQUFrQixDQUFDLGNBQXNCLGNBQStDO0FBQ25HLFFBQU0sRUFBQyxLQUFLLE1BQU0sS0FBSSxJQUFJO0FBQzFCLE1BQUk7QUFDRixVQUFNLE9BQU8sVUFBQUMsUUFBRyxhQUFhLG1CQUFtQixZQUFZLFFBQVEsTUFBTTtBQUMxRSxVQUFNLFdBQU8sMEJBQVksS0FBSyxNQUFNLElBQUk7QUFDeEMsVUFBTSxTQUFTLEVBQUMsS0FBSyxNQUFNLEtBQUk7QUFFL0IsV0FBTyxRQUFRLE1BQU0sRUFDbEIsS0FBSyxDQUFDLFFBQVEsSUFBSSxXQUFXLFFBQVEsRUFDckMsTUFBTSxDQUFDLFVBQWlCO0FBQ3ZCLFlBQU07QUFBQSxJQUNSLENBQUM7QUFBQSxFQUNMLFNBQVEsT0FBTztBQUNiLFdBQU8sUUFBUSxPQUFPLEtBQUs7QUFBQSxFQUM3QjtBQUNGOyIsCiAgIm5hbWVzIjogWyJ0d2lsaW9TZGsiLCAiZnMiXQp9Cg==
106
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc21zLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtQdWJsaXNoQ29tbWFuZCwgU05TQ2xpZW50fSBmcm9tICdAYXdzLXNkay9jbGllbnQtc25zJztcbmltcG9ydCB7cGFyc2VQaG9uZSwgcGFyc2VUZW1wbGF0ZX0gZnJvbSAnQG5sYWJzL3V0aWxzJztcbmltcG9ydCBmcyBmcm9tICdmcyc7XG5cbmltcG9ydCB7Q29uZmlnfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHtFcnJvclR5cGVzfSBmcm9tICcuLi90eXBlcy9lcnJvcic7XG5pbXBvcnQge1NNU1BhcmFtc1R5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuaW1wb3J0IHtTZXNzaW9ufSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQge2xvZ0Vycm9yfSBmcm9tICcuLi91dGlscy9hbmFseXRpY3NVdGlscyc7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzbXMnO1xuXG5leHBvcnQgY29uc3Qgc2VuZFNtcyA9IGFzeW5jICh7XG4gIGNvbnRlbnQsXG4gIHVzZXIsXG4gIHZhcmlhYmxlcyA9IHt9XG59OiBTTVNQYXJhbXNUeXBlKTogUHJvbWlzZTxhbnk+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnc2VuZFNtcyc7XG4gIGNvbnN0IHNuc0NsaWVudCA9IG5ldyBTTlNDbGllbnQoe1xuICAgIGNyZWRlbnRpYWxzOiBDb25maWcuZ2V0KCdhd3MuY3JlZGVudGlhbHMnKSxcbiAgICByZWdpb246IENvbmZpZy5nZXQoJ2F3cy5yZWdpb24nKVxuICB9KTtcbiAgY29uc3Qge2NvdW50cnkgPSAnVVMnLCBwaG9uZX0gPSB1c2VyO1xuICBjb25zdCBwaG9uZU51bWJlciA9IHBhcnNlUGhvbmUocGhvbmUsIGNvdW50cnkpO1xuICBjb25zdCB0ZW1wbGF0ZUNvbnRlbnQ6IHN0cmluZyA9IHBhcnNlVGVtcGxhdGUoY29udGVudCwgdmFyaWFibGVzKTtcblxuICByZXR1cm4gYXdhaXQgc25zQ2xpZW50XG4gICAgLnNlbmQoXG4gICAgICBuZXcgUHVibGlzaENvbW1hbmQoe1xuICAgICAgICBNZXNzYWdlOiB0ZW1wbGF0ZUNvbnRlbnQsXG4gICAgICAgIE1lc3NhZ2VBdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgJ0FXUy5TTlMuU01TLlNNU1R5cGUnOiB7XG4gICAgICAgICAgICBEYXRhVHlwZTogJ1N0cmluZycsXG4gICAgICAgICAgICBTdHJpbmdWYWx1ZTogJ1RyYW5zYWN0aW9uYWwnXG4gICAgICAgICAgfSxcbiAgICAgICAgICAnQVdTLlNOUy5TTVMuU2VuZGVySUQnOiB7XG4gICAgICAgICAgICBEYXRhVHlwZTogJ1N0cmluZycsXG4gICAgICAgICAgICBTdHJpbmdWYWx1ZTogQ29uZmlnLmdldCgnYXBwLmlkJykudHJpbSgpLnJlcGxhY2UoLyAvZywgJycpLnN1YnN0cmluZygwLCAxMSlcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIFBob25lTnVtYmVyOiBwaG9uZU51bWJlclxuICAgICAgfSksXG4gICAgKVxuICAgIC50aGVuKChyZXMpID0+IHtcbiAgICAgIGNvbnNvbGUubG9nKHtyZXN9KTtcbiAgICAgIHJldHVybiByZXM7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yKSA9PiB7XG4gICAgICBjb25zb2xlLmxvZyh7ZXJyb3J9KTtcbiAgICAgIHJldHVybiBsb2dFcnJvcih7XG4gICAgICAgIGFjdGlvbixcbiAgICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICAgIGxhYmVsOiBFcnJvclR5cGVzLlNNU19FUlJPUlxuICAgICAgfSwgZXJyb3IsIHtzZXNzaW9uOiB1c2VyIGFzIFNlc3Npb259KTtcbiAgICB9KTtcbiAgLy8gLnRoZW4oKCkgPT4gbnVsbCk7XG59O1xuXG5leHBvcnQgY29uc3Qgc2VuZFNtc1RlbXBsYXRlID0gKFxuICB0ZW1wbGF0ZU5hbWU6IHN0cmluZyxcbiAge1xuICAgIHVzZXIsXG4gICAgdmFyaWFibGVzID0ge31cbiAgfTogU01TUGFyYW1zVHlwZVxuKTogUHJvbWlzZTxib29sZWFuPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ3NlbmRTbXNUZW1wbGF0ZSc7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBkYXRhID0gZnMucmVhZEZpbGVTeW5jKGAuL3RlbXBsYXRlcy9zbXMvJHt0ZW1wbGF0ZU5hbWV9LnR4dGAsICd1dGY4Jyk7XG4gICAgY29uc3QgdGV4dCA9IHBhcnNlVGVtcGxhdGUoZGF0YSwgdmFyaWFibGVzKTtcbiAgICBjb25zdCBwYXJhbXMgPSB7dGV4dCwgdXNlcn07XG5cbiAgICByZXR1cm4gc2VuZFNtcyhwYXJhbXMpXG4gICAgICAudGhlbigocmVzKSA9PiByZXMuc3RhdHVzID09PSAncXVldWVkJylcbiAgICAgIC5jYXRjaCgoZXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgICAgYWN0aW9uLFxuICAgICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgICAgbGFiZWw6IEVycm9yVHlwZXMuU01TX0VSUk9SXG4gICAgICB9LCBlcnJvciwge3Nlc3Npb246IHVzZXIgYXMgU2Vzc2lvbn0pXG4gICAgICAgIC50aGVuKCgpID0+IG51bGwpXG4gICAgICApO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgcmV0dXJuIFByb21pc2UucmVqZWN0KHtlcnJvcnM6IFtlcnJvci5tZXNzYWdlXX0pO1xuICB9XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FB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
@@ -1,2 +1,3 @@
1
1
  import { ApiContext, StatisticsType } from '../types';
2
- export declare const getGlobalStatistics: (context: ApiContext) => Promise<Partial<StatisticsType>>;
2
+ export declare const getGlobalStatistics: (context: ApiContext) => Promise<StatisticsType>;
3
+ export declare const updateGlobalStatistics: (context: ApiContext) => Promise<StatisticsType>;
@@ -17,43 +17,46 @@ var __copyProps = (to, from, except, desc) => {
17
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
18
  var statistics_exports = {};
19
19
  __export(statistics_exports, {
20
- getGlobalStatistics: () => getGlobalStatistics
20
+ getGlobalStatistics: () => getGlobalStatistics,
21
+ updateGlobalStatistics: () => updateGlobalStatistics
21
22
  });
22
23
  module.exports = __toCommonJS(statistics_exports);
23
24
  var import_arangojs = require("arangojs");
24
- var import__ = require(".");
25
- var import_utils = require("../utils");
25
+ var import_users = require("./users");
26
+ var import_analyticsUtils = require("../utils/analyticsUtils");
27
+ var import_error = require("../types/error");
26
28
  const eventCategory = "statistics";
27
- const getGlobalStatistics = async (context) => {
28
- const action = "getStatistics";
29
+ const getGlobalStatistics = (context) => {
30
+ const action = "getGlobalStatistics";
29
31
  const { database } = context;
30
32
  const statisticsQuery = import_arangojs.aql`FOR s IN statistics
31
33
  FILTER s.isGlobal == true
32
34
  LIMIT 1
33
35
  RETURN s`;
34
- const statistics = await database.query(statisticsQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils.logError)({
36
+ return database.query(statisticsQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
35
37
  action,
36
38
  category: eventCategory,
37
- label: "db_error"
38
- }, error, context).then(() => null));
39
- if (statistics) {
40
- return statistics;
41
- }
42
- const activeUsers = (0, import__.getActiveUserCount)(context);
39
+ label: import_error.ErrorTypes.DATABASE_ERROR
40
+ }, error, context));
41
+ };
42
+ const updateGlobalStatistics = (context) => {
43
+ const action = "updateGlobalStatistics";
44
+ const { database } = context;
45
+ const activeUsers = (0, import_users.getActiveUserCount)(context);
43
46
  const updatedData = { activeUsers };
44
47
  const updateQuery = import_arangojs.aql`UPSERT {isGlobal: true}
45
48
  INSERT ${updatedData}
46
49
  UPDATE ${updatedData}
47
50
  IN statistics RETURN NEW`;
48
- const updatedStatistics = await database.query(updateQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils.logError)({
51
+ return database.query(updateQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
49
52
  action,
50
53
  category: eventCategory,
51
- label: "db_error"
52
- }, error, context).then(() => ({})));
53
- return updatedStatistics;
54
+ label: import_error.ErrorTypes.DATABASE_ERROR
55
+ }, error, context));
54
56
  };
55
57
  // Annotate the CommonJS export names for ESM import in node:
56
58
  0 && (module.exports = {
57
- getGlobalStatistics
59
+ getGlobalStatistics,
60
+ updateGlobalStatistics
58
61
  });
59
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc3RhdGlzdGljcy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHthcWx9IGZyb20gJ2FyYW5nb2pzJztcbmltcG9ydCB7QXFsUXVlcnl9IGZyb20gJ2FyYW5nb2pzL2FxbCc7XG5pbXBvcnQge0FycmF5Q3Vyc29yfSBmcm9tICdhcmFuZ29qcy9jdXJzb3InO1xuXG5pbXBvcnQge2dldEFjdGl2ZVVzZXJDb3VudH0gZnJvbSAnLic7XG5pbXBvcnQge0FwaUNvbnRleHQsIFN0YXRpc3RpY3NUeXBlfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQge2xvZ0Vycm9yfSBmcm9tICcuLi91dGlscyc7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzdGF0aXN0aWNzJztcblxuZXhwb3J0IGNvbnN0IGdldEdsb2JhbFN0YXRpc3RpY3MgPSBhc3luYyAoY29udGV4dDogQXBpQ29udGV4dCk6IFByb21pc2U8UGFydGlhbDxTdGF0aXN0aWNzVHlwZT4+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0U3RhdGlzdGljcyc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBzdGF0aXN0aWNzUXVlcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiBzIElOIHN0YXRpc3RpY3NcbiAgICBGSUxURVIgcy5pc0dsb2JhbCA9PSB0cnVlXG4gICAgTElNSVQgMVxuICAgIFJFVFVSTiBzYDtcblxuICBjb25zdCBzdGF0aXN0aWNzID0gYXdhaXQgZGF0YWJhc2UucXVlcnkoc3RhdGlzdGljc1F1ZXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpLnRoZW4oKCkgPT4gKG51bGwpKSk7XG5cbiAgaWYoc3RhdGlzdGljcykge1xuICAgIHJldHVybiBzdGF0aXN0aWNzO1xuICB9XG4gIGNvbnN0IGFjdGl2ZVVzZXJzID0gZ2V0QWN0aXZlVXNlckNvdW50KGNvbnRleHQpO1xuICBjb25zdCB1cGRhdGVkRGF0YSA9IHthY3RpdmVVc2Vyc307XG5cbiAgY29uc3QgdXBkYXRlUXVlcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQU0VSVCB7aXNHbG9iYWw6IHRydWV9XG4gIElOU0VSVCAke3VwZGF0ZWREYXRhfVxuICBVUERBVEUgJHt1cGRhdGVkRGF0YX1cbiAgSU4gc3RhdGlzdGljcyBSRVRVUk4gTkVXYDtcblxuICBjb25zdCB1cGRhdGVkU3RhdGlzdGljcyA9IGF3YWl0IGRhdGFiYXNlLnF1ZXJ5KHVwZGF0ZVF1ZXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpLnRoZW4oKCkgPT4gKHt9KSkpO1xuXG4gIHJldHVybiB1cGRhdGVkU3RhdGlzdGljcztcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxzQkFBa0I7QUFJbEIsZUFBaUM7QUFFakMsbUJBQXVCO0FBRXZCLE1BQU0sZ0JBQXdCO0FBRXZCLE1BQU0sc0JBQXNCLE9BQU8sWUFBMEQ7QUFDbEcsUUFBTSxTQUFpQjtBQUN2QixRQUFNLEVBQUMsU0FBUSxJQUFJO0FBQ25CLFFBQU0sa0JBQTRCO0FBQUE7QUFBQTtBQUFBO0FBS2xDLFFBQU0sYUFBYSxNQUFNLFNBQVMsTUFBTSxlQUFlLEVBQ3BELEtBQUssQ0FBQyxXQUF3QixPQUFPLEtBQUssQ0FBQyxFQUMzQyxNQUFNLENBQUMsY0FBaUIsdUJBQVM7QUFBQSxJQUNoQztBQUFBLElBQ0EsVUFBVTtBQUFBLElBQ1YsT0FBTztBQUFBLEVBQ1QsR0FBRyxPQUFPLE9BQU8sRUFBRSxLQUFLLE1BQU8sSUFBSyxDQUFDO0FBRXZDLE1BQUcsWUFBWTtBQUNiLFdBQU87QUFBQSxFQUNUO0FBQ0EsUUFBTSxrQkFBYyw2QkFBbUIsT0FBTztBQUM5QyxRQUFNLGNBQWMsRUFBQyxZQUFXO0FBRWhDLFFBQU0sY0FBd0I7QUFBQSxXQUNyQixXQUFXO0FBQUEsV0FDWCxXQUFXO0FBQUE7QUFHcEIsUUFBTSxvQkFBb0IsTUFBTSxTQUFTLE1BQU0sV0FBVyxFQUN2RCxLQUFLLENBQUMsV0FBd0IsT0FBTyxLQUFLLENBQUMsRUFDM0MsTUFBTSxDQUFDLGNBQWlCLHVCQUFTO0FBQUEsSUFDaEM7QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU87QUFBQSxFQUNULEdBQUcsT0FBTyxPQUFPLEVBQUUsS0FBSyxPQUFPLENBQUMsRUFBRSxDQUFDO0FBRXJDLFNBQU87QUFDVDsiLAogICJuYW1lcyI6IFtdCn0K
62
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc3RhdGlzdGljcy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7YXFsfSBmcm9tICdhcmFuZ29qcyc7XG5pbXBvcnQge0FxbFF1ZXJ5fSBmcm9tICdhcmFuZ29qcy9hcWwnO1xuaW1wb3J0IHtBcnJheUN1cnNvcn0gZnJvbSAnYXJhbmdvanMvY3Vyc29yJztcblxuaW1wb3J0IHtnZXRBY3RpdmVVc2VyQ291bnR9IGZyb20gJy4vdXNlcnMnO1xuaW1wb3J0IHtBcGlDb250ZXh0LCBTdGF0aXN0aWNzVHlwZX0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHtsb2dFcnJvcn0gZnJvbSAnLi4vdXRpbHMvYW5hbHl0aWNzVXRpbHMnO1xuaW1wb3J0IHtFcnJvclR5cGVzfSBmcm9tICcuLi90eXBlcy9lcnJvcic7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzdGF0aXN0aWNzJztcblxuZXhwb3J0IGNvbnN0IGdldEdsb2JhbFN0YXRpc3RpY3MgPSAoY29udGV4dDogQXBpQ29udGV4dCk6IFByb21pc2U8U3RhdGlzdGljc1R5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0R2xvYmFsU3RhdGlzdGljcyc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBzdGF0aXN0aWNzUXVlcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiBzIElOIHN0YXRpc3RpY3NcbiAgICBGSUxURVIgcy5pc0dsb2JhbCA9PSB0cnVlXG4gICAgTElNSVQgMVxuICAgIFJFVFVSTiBzYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoc3RhdGlzdGljc1F1ZXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpKTtcbn07XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVHbG9iYWxTdGF0aXN0aWNzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQpOiBQcm9taXNlPFN0YXRpc3RpY3NUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ3VwZGF0ZUdsb2JhbFN0YXRpc3RpY3MnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgYWN0aXZlVXNlcnMgPSBnZXRBY3RpdmVVc2VyQ291bnQoY29udGV4dCk7XG4gIGNvbnN0IHVwZGF0ZWREYXRhID0ge2FjdGl2ZVVzZXJzfTtcblxuICBjb25zdCB1cGRhdGVRdWVyeTogQXFsUXVlcnkgPSBhcWxgVVBTRVJUIHtpc0dsb2JhbDogdHJ1ZX1cbiAgSU5TRVJUICR7dXBkYXRlZERhdGF9XG4gIFVQREFURSAke3VwZGF0ZWREYXRhfVxuICBJTiBzdGF0aXN0aWNzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeSh1cGRhdGVRdWVyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogRXJyb3JUeXBlcy5EQVRBQkFTRV9FUlJPUlxuICAgIH0sIGVycm9yLCBjb250ZXh0KSk7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxzQkFBa0I7QUFJbEIsbUJBQWlDO0FBRWpDLDRCQUF1QjtBQUN2QixtQkFBeUI7QUFFekIsTUFBTSxnQkFBd0I7QUFFdkIsTUFBTSxzQkFBc0IsQ0FBQyxZQUFpRDtBQUNuRixRQUFNLFNBQWlCO0FBQ3ZCLFFBQU0sRUFBQyxTQUFRLElBQUk7QUFDbkIsUUFBTSxrQkFBNEI7QUFBQTtBQUFBO0FBQUE7QUFLbEMsU0FBTyxTQUFTLE1BQU0sZUFBZSxFQUNsQyxLQUFLLENBQUMsV0FBd0IsT0FBTyxLQUFLLENBQUMsRUFDM0MsTUFBTSxDQUFDLGNBQWlCLGdDQUFTO0FBQUEsSUFDaEM7QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU8sd0JBQVc7QUFBQSxFQUNwQixHQUFHLE9BQU8sT0FBTyxDQUFDO0FBQ3RCO0FBRU8sTUFBTSx5QkFBeUIsQ0FBQyxZQUFpRDtBQUN0RixRQUFNLFNBQWlCO0FBQ3ZCLFFBQU0sRUFBQyxTQUFRLElBQUk7QUFDbkIsUUFBTSxrQkFBYyxpQ0FBbUIsT0FBTztBQUM5QyxRQUFNLGNBQWMsRUFBQyxZQUFXO0FBRWhDLFFBQU0sY0FBd0I7QUFBQSxXQUNyQixXQUFXO0FBQUEsV0FDWCxXQUFXO0FBQUE7QUFHcEIsU0FBTyxTQUFTLE1BQU0sV0FBVyxFQUM5QixLQUFLLENBQUMsV0FBd0IsT0FBTyxLQUFLLENBQUMsRUFDM0MsTUFBTSxDQUFDLGNBQWlCLGdDQUFTO0FBQUEsSUFDaEM7QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU8sd0JBQVc7QUFBQSxFQUNwQixHQUFHLE9BQU8sT0FBTyxDQUFDO0FBQ3RCOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,5 +1,5 @@
1
- import { ApiContext } from '../types/auth';
2
- import { PaymentPlan, PaymentSubscription } from '../types/payments';
1
+ import type { ApiContext } from '../types/auth';
2
+ import type { PaymentPlan, PaymentSubscription } from '../types/payments';
3
3
  export declare const getPlanList: (context: ApiContext, from?: number, to?: number) => Promise<PaymentPlan[]>;
4
4
  export declare const getSubscription: (context: ApiContext) => Promise<PaymentSubscription>;
5
5
  export declare const addPlan: (context: ApiContext, item: PaymentPlan) => Promise<PaymentPlan>;
@@ -39,22 +39,25 @@ var import_arangojs = require("arangojs");
39
39
  var import_luxon = require("luxon");
40
40
  var import_stripe = __toESM(require("stripe"));
41
41
  var import_config = require("../config");
42
- var import_utils2 = require("../utils");
43
42
  var import_users = require("./users");
43
+ var import_error = require("../types/error");
44
+ var import_arangodbUtils = require("../utils/arangodbUtils");
45
+ var import_analyticsUtils = require("../utils/analyticsUtils");
46
+ var import_utils2 = require("../utils");
44
47
  const eventCategory = "subscription";
45
48
  const apiVersion = "2020-03-02";
46
49
  const getPlanList = (context, from = 0, to = 30) => {
47
50
  const action = "getList";
48
51
  const { database } = context;
49
- const limit = (0, import_utils2.getLimit)(from, to);
52
+ const limit = (0, import_arangodbUtils.getLimit)(from, to);
50
53
  const aqlQry = `FOR p IN plans
51
54
  ${limit.aql}
52
55
  SORT p.amount
53
56
  RETURN p`;
54
- return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_utils2.logError)({
57
+ return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_analyticsUtils.logError)({
55
58
  action,
56
59
  category: eventCategory,
57
- label: "db_error"
60
+ label: import_error.ErrorTypes.DATABASE_ERROR
58
61
  }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
59
62
  };
60
63
  const getSubscription = (context) => {
@@ -68,27 +71,27 @@ const getSubscription = (context) => {
68
71
  )
69
72
  LIMIT 1
70
73
  RETURN MERGE(s, {plan: plan})`;
71
- return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription = {}) => subscription).catch((error) => (0, import_utils2.logError)({
74
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription = {}) => subscription).catch((error) => (0, import_analyticsUtils.logError)({
72
75
  action,
73
76
  category: eventCategory,
74
- label: "db_error"
77
+ label: import_error.ErrorTypes.DATABASE_ERROR
75
78
  }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
76
79
  };
77
80
  const addPlan = (context, item) => {
78
81
  const action = "addPlan";
79
- const { database, session: { userId: sessionId, userAccess } } = context;
80
- const isAdmin = userAccess > 2;
82
+ const { database, session } = context;
83
+ const isAdmin = (0, import_utils2.isAdminUser)(session);
81
84
  if (!isAdmin) {
82
- return (0, import_utils2.logException)({
85
+ return (0, import_analyticsUtils.logException)({
83
86
  action,
84
87
  category: eventCategory,
85
88
  label: "unauthorized",
86
- value: "invalid_session"
89
+ value: import_error.ErrorTypes.INVALID_SESSION
87
90
  }, context).then(() => null);
88
91
  }
89
92
  const now = Date.now();
90
93
  const formatId = (0, import_utils.parseId)(item.id);
91
- const planId = formatId === "" ? (0, import_utils.createHash)(`subscription-${sessionId}`) : formatId;
94
+ const planId = formatId === "" ? (0, import_utils.createHash)(`subscription-${session.userId}`) : formatId;
92
95
  const { amount, currency = "USD", description, interval, intervalCount, name } = item;
93
96
  const formatAmount = (0, import_utils.parseNum)(amount);
94
97
  const formatInterval = (0, import_utils.parseChar)(interval, 5).toLowerCase();
@@ -107,7 +110,7 @@ const addPlan = (context, item) => {
107
110
  name: formatName
108
111
  };
109
112
  const aqlQry = import_arangojs.aql`INSERT ${insert} IN plans RETURN NEW`;
110
- return database.query(aqlQry).then((cursor) => cursor.next()).then((plan = {}) => {
113
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((plan) => {
111
114
  const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
112
115
  const stripePlan = {
113
116
  amount: formatAmount * 100,
@@ -120,10 +123,10 @@ const addPlan = (context, item) => {
120
123
  statement_descriptor: formatDesc
121
124
  };
122
125
  return stripeClient.plans.create(stripePlan).then(() => plan);
123
- }).catch((error) => (0, import_utils2.logError)({
126
+ }).catch((error) => (0, import_analyticsUtils.logError)({
124
127
  action,
125
128
  category: eventCategory,
126
- label: "db_error"
129
+ label: import_error.ErrorTypes.DATABASE_ERROR
127
130
  }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
128
131
  };
129
132
  const addSubscription = (context, item) => {
@@ -131,7 +134,7 @@ const addSubscription = (context, item) => {
131
134
  const { database, session: { userId: sessionId, userAccess } } = context;
132
135
  const isAdmin = userAccess > 2;
133
136
  if (!isAdmin) {
134
- return (0, import_utils2.logException)({
137
+ return (0, import_analyticsUtils.logException)({
135
138
  action,
136
139
  category: eventCategory,
137
140
  label: "unauthorized",
@@ -148,7 +151,7 @@ const addSubscription = (context, item) => {
148
151
  if (formatTrialPeriod) {
149
152
  formatTrialEnd = import_luxon.DateTime.local().plus({ days: trialPeriod }).toMillis();
150
153
  }
151
- return (0, import_users.getUser)(context, sessionId).then((user) => {
154
+ return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
152
155
  const insert = {
153
156
  _key: subscriptionId,
154
157
  added: now,
@@ -173,10 +176,10 @@ const addSubscription = (context, item) => {
173
176
  },
174
177
  trial_end: formatTrialEnd
175
178
  }).then(() => subscription);
176
- }).catch((error) => (0, import_utils2.logError)({
179
+ }).catch((error) => (0, import_analyticsUtils.logError)({
177
180
  action,
178
181
  category: eventCategory,
179
- label: "db_error"
182
+ label: import_error.ErrorTypes.DATABASE_ERROR
180
183
  }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
181
184
  });
182
185
  };
@@ -194,10 +197,10 @@ const deleteSubscription = (context) => {
194
197
  planId: ""
195
198
  };
196
199
  const aqlQry = import_arangojs.aql`UPDATE s WITH ${update} IN subscriptions`;
197
- return database.query(aqlQry).then(() => true).catch((error) => (0, import_utils2.logError)({
200
+ return database.query(aqlQry).then(() => true).catch((error) => (0, import_analyticsUtils.logError)({
198
201
  action,
199
202
  category: eventCategory,
200
- label: "db_error"
203
+ label: import_error.ErrorTypes.DATABASE_ERROR
201
204
  }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
202
205
  }
203
206
  return false;
@@ -212,4 +215,4 @@ const deleteSubscription = (context) => {
212
215
  getPlanList,
213
216
  getSubscription
214
217
  });
215
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/subscription.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, parseChar, parseId, parseNum, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {DateTime} from 'luxon';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PaymentInterval, PaymentPlan, PaymentSubscription} from '../types/payments';\nimport {getLimit, logError, logException} from '../utils';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'subscription';\nconst apiVersion: any = '2020-03-02';\n\nexport const getPlanList = (context: ApiContext, from: number = 0, to: number = 30): Promise<PaymentPlan[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN plans\n      ${limit.aql}\n      SORT p.amount\n      RETURN p`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const aqlQry: string = `FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.cancelled > 0\n      LET plan = FIRST(\n        FOR p IN plans\n        FILTER p._key == s.planId\n      )\n      LIMIT 1\n      RETURN MERGE(s, {plan: plan})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addPlan = (context: ApiContext, item: PaymentPlan): Promise<PaymentPlan> => {\n  const action: string = 'addPlan';\n  const {database, session: {userId: sessionId, userAccess}} = context;\n  const isAdmin: boolean = userAccess > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const planId: string = formatId === '' ? createHash(`subscription-${sessionId}`) : formatId;\n  const {amount, currency = 'USD', description, interval, intervalCount, name} = item;\n  const formatAmount: number = parseNum(amount);\n  const formatInterval: PaymentInterval = parseChar(interval, 5).toLowerCase() as PaymentInterval;\n  const formatIntervalCnt: number = parseNum(intervalCount, 5);\n  const formatName: string = parseVarChar(name, 32);\n  const formatDesc: string = parseVarChar(description, 32);\n\n  const insert: PaymentPlan = {\n    _key: planId,\n    added: now,\n    amount: formatAmount,\n    currency,\n    description: formatDesc,\n    interval: formatInterval,\n    intervalCount: formatIntervalCnt,\n    modified: now,\n    name: formatName\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan = {}) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const stripePlan: any = {\n        amount: formatAmount * 100,\n        currency,\n        id: planId,\n        interval: formatInterval,\n        interval_count: formatIntervalCnt,\n        metadata: {\n        },\n        name: formatName,\n        statement_descriptor: formatDesc\n      };\n\n      return stripeClient.plans\n        .create(stripePlan)\n        .then(() => plan);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addSubscription = (context: ApiContext, item): Promise<PaymentSubscription> => {\n  const action: string = 'addSubscription';\n  const {database, session: {userId: sessionId, userAccess}} = context;\n  const isAdmin: boolean = userAccess > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const subscriptionId: string = formatId === '' ? createHash(`subscription-${sessionId}`) : formatId;\n  const {planId, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTrialPeriod: number = 0;\n  let formatTrialEnd: number = trialEnd || Date.now();\n\n  if(formatTrialPeriod) {\n    formatTrialEnd = DateTime.local().plus({days: trialPeriod}).toMillis();\n  }\n\n  return getUser(context, sessionId)\n    .then((user) => {\n      const insert: PaymentSubscription = {\n        _key: subscriptionId,\n        added: now,\n        cancelDate: 0,\n        modified: now,\n        planId: formatPlanId,\n        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {\n                  plan: formatPlanId\n                }\n              ],\n              metadata: {\n                userId: sessionId\n              },\n              trial_end: formatTrialEnd\n            })\n            .then(() => subscription);\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n    });\n};\n\nexport const deleteSubscription = (context: ApiContext): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      return stripeClient.subscriptions\n        .cancel(subscription.transactionId)\n        .then(({canceled_at: cancelDate}) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(cancelDate) {\n            const update: PaymentSubscription = {\n              cancelDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return database.query(aqlQry)\n              .then(() => true)\n              .catch((error: Error) => logError({\n                action,\n                category: eventCategory,\n                label: 'db_error'\n              }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n          }\n          return false;\n        });\n    });\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "error", "Stripe"]
}

218
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/subscription.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, parseChar, parseId, parseNum, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {DateTime} from 'luxon';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport type {ArangoDbLimit} from '../types/arangodb';\nimport type {ApiContext} from '../types/auth';\nimport type {PaymentInterval, PaymentPlan, PaymentSubscription} from '../types/payments';\nimport {getUser} from './users';\nimport {ErrorTypes} from '../types/error';\nimport {getLimit} from '../utils/arangodbUtils';\nimport {logError, logException} from '../utils/analyticsUtils';\nimport {isAdminUser} from '../utils';\n\nconst eventCategory: string = 'subscription';\nconst apiVersion: any = '2020-03-02';\n\nexport const getPlanList = (context: ApiContext, from: number = 0, to: number = 30): Promise<PaymentPlan[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const limit: ArangoDbLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN plans\n      ${limit.aql}\n      SORT p.amount\n      RETURN p`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const aqlQry: string = `FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.cancelled > 0\n      LET plan = FIRST(\n        FOR p IN plans\n        FILTER p._key == s.planId\n      )\n      LIMIT 1\n      RETURN MERGE(s, {plan: plan})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addPlan = (context: ApiContext, item: PaymentPlan): Promise<PaymentPlan> => {\n  const action: string = 'addPlan';\n  const {database, session} = context;\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).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const planId: string = formatId === '' ? createHash(`subscription-${session.userId}`) : formatId;\n  const {amount, currency = 'USD', description, interval, intervalCount, name} = item;\n  const formatAmount: number = parseNum(amount);\n  const formatInterval: PaymentInterval = parseChar(interval, 5).toLowerCase() as PaymentInterval;\n  const formatIntervalCnt: number = parseNum(intervalCount, 5);\n  const formatName: string = parseVarChar(name, 32);\n  const formatDesc: string = parseVarChar(description, 32);\n  const insert: PaymentPlan = {\n    _key: planId,\n    added: now,\n    amount: formatAmount,\n    currency,\n    description: formatDesc,\n    interval: formatInterval,\n    intervalCount: formatIntervalCnt,\n    modified: now,\n    name: formatName\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const stripePlan: any = {\n        amount: formatAmount * 100,\n        currency,\n        id: planId,\n        interval: formatInterval,\n        interval_count: formatIntervalCnt,\n        metadata: {\n        },\n        name: formatName,\n        statement_descriptor: formatDesc\n      };\n\n      return stripeClient.plans\n        .create(stripePlan)\n        .then(() => plan);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addSubscription = (context: ApiContext, item): Promise<PaymentSubscription> => {\n  const action: string = 'addSubscription';\n  const {database, session: {userId: sessionId, userAccess}} = context;\n  const isAdmin: boolean = userAccess > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const subscriptionId: string = formatId === '' ? createHash(`subscription-${sessionId}`) : formatId;\n  const {planId, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTrialPeriod: number = 0;\n  let formatTrialEnd: number = trialEnd || Date.now();\n\n  if(formatTrialPeriod) {\n    formatTrialEnd = DateTime.local().plus({days: trialPeriod}).toMillis();\n  }\n\n  return getUser(context, {userId: sessionId})\n    .then((user) => {\n      const insert: PaymentSubscription = {\n        _key: subscriptionId,\n        added: now,\n        cancelDate: 0,\n        modified: now,\n        planId: formatPlanId,\n        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {\n                  plan: formatPlanId\n                }\n              ],\n              metadata: {\n                userId: sessionId\n              },\n              trial_end: formatTrialEnd\n            })\n            .then(() => subscription);\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: ErrorTypes.DATABASE_ERROR\n        }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n    });\n};\n\nexport const deleteSubscription = (context: ApiContext): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      return stripeClient.subscriptions\n        .cancel(subscription.transactionId)\n        .then(({canceled_at: cancelDate}) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(cancelDate) {\n            const update: PaymentSubscription = {\n              cancelDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return database.query(aqlQry)\n              .then(() => true)\n              .catch((error: Error) => logError({\n                action,\n                category: eventCategory,\n                label: ErrorTypes.DATABASE_ERROR\n              }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n          }\n          return false;\n        });\n    });\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "error", "Stripe"]
}

@@ -1,31 +1,29 @@
1
- import { Database } from 'arangojs';
2
- import { ApiContext } from '../types/auth';
3
- import { TagType } from '../types/tags';
1
+ import type { ApiContext } from '../types/auth';
2
+ import type { TagType } from '../types/tags';
4
3
  export interface TagOptions {
5
- readonly search?: string;
6
4
  readonly from?: number;
5
+ readonly search?: string;
7
6
  readonly to?: number;
7
+ readonly userId?: string;
8
8
  }
9
9
  export declare const getTags: (context: ApiContext, options?: TagOptions) => Promise<TagType[]>;
10
- export declare const getTagsByItem: (context: ApiContext, itemId: string, args: any) => Promise<TagType[]>;
11
- export declare const getTagsByOwner: (context: ApiContext, args: any) => Promise<TagType[]>;
10
+ export declare const getTagsByItem: (context: ApiContext, itemDocId: string, options?: TagOptions) => Promise<TagType[]>;
12
11
  export declare const getTag: (context: ApiContext, tagId: string) => Promise<TagType>;
13
- export declare const addTag: (context: ApiContext, { tag }: {
14
- tag: any;
15
- }) => Promise<TagType>;
16
- export declare const addTagToItem: (context: ApiContext, { itemId, tagId }: {
17
- itemId: any;
18
- tagId: any;
19
- }) => Promise<TagType>;
20
- export declare const updateTag: (context: ApiContext, item?: TagType) => Promise<TagType>;
21
- export declare const deleteTag: (context: ApiContext, { tagId }: {
22
- tagId: any;
12
+ export declare const getTagsByName: (context: ApiContext, tagNames: string[]) => Promise<TagType[]>;
13
+ export declare const addTag: (context: ApiContext, tag: TagType) => Promise<TagType>;
14
+ export declare const addTagToItem: (context: ApiContext, { itemDocId, tagBy, tagDocId }: {
15
+ itemDocId: string;
16
+ tagBy?: string;
17
+ tagDocId: string;
23
18
  }) => Promise<TagType>;
24
- export declare const deleteTagFromItem: (context: ApiContext, { itemId, tagId }: {
25
- itemId: any;
26
- tagId: any;
19
+ export declare const updateTag: (context: ApiContext, tag: TagType) => Promise<TagType>;
20
+ export declare const deleteTag: (context: ApiContext, tag: TagType) => Promise<TagType>;
21
+ export declare const deleteTagFromItem: (context: ApiContext, { tagDocId, edgeDocId }: {
22
+ tagDocId: any;
23
+ edgeDocId: any;
27
24
  }) => Promise<TagType>;
28
- export declare const createTag: (db: Database, tagName: string) => Promise<TagType>;
29
- export declare const createTagEdge: (db: Database, tag: TagType, itemId: string) => Promise<TagType>;
30
- export declare const linkTags: (db: Database, tagNames: string[], itemId: string) => Promise<TagType[]>;
31
- export declare const extractTags: (db: Database, itemId: any, content: any) => Promise<TagType[]>;
25
+ export declare const extractTags: (content: string) => string[];
26
+ export declare const updateTagsInItem: (context: ApiContext, { itemDocId, tags }: {
27
+ itemDocId: any;
28
+ tags: any;
29
+ }) => Promise<TagType[]>;