@nlabs/reaktor 0.5.3 → 0.6.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 (73) hide show
  1. package/README.md +7 -7
  2. package/lib/actions/conversations.js +36 -47
  3. package/lib/actions/dynamodb.js +22 -33
  4. package/lib/actions/email.js +32 -29
  5. package/lib/actions/files.js +46 -56
  6. package/lib/actions/groups.js +33 -28
  7. package/lib/actions/images.js +53 -63
  8. package/lib/actions/index.js +54 -37
  9. package/lib/actions/ios.js +21 -40
  10. package/lib/actions/locations.js +25 -22
  11. package/lib/actions/messages.js +28 -41
  12. package/lib/actions/notifications.d.ts +1 -1
  13. package/lib/actions/notifications.js +13 -20
  14. package/lib/actions/payments.js +37 -48
  15. package/lib/actions/posts.js +19 -42
  16. package/lib/actions/reactions.d.ts +1 -1
  17. package/lib/actions/reactions.js +17 -40
  18. package/lib/actions/s3.js +21 -18
  19. package/lib/actions/search.js +26 -40
  20. package/lib/actions/sms.js +24 -21
  21. package/lib/actions/statistics.js +14 -21
  22. package/lib/actions/subscription.js +27 -24
  23. package/lib/actions/tags.js +47 -54
  24. package/lib/actions/users.js +81 -94
  25. package/lib/actions/websockets.js +26 -39
  26. package/lib/config.js +21 -18
  27. package/lib/index.js +24 -22
  28. package/lib/lambdas/actions/websockets.js +27 -40
  29. package/lib/lambdas/authorizer.js +21 -18
  30. package/lib/lambdas/connection.js +26 -40
  31. package/lib/lambdas/utils/message.js +20 -17
  32. package/lib/lambdas/utils/websocket.js +33 -25
  33. package/lib/templates/email/layout.js +16 -9
  34. package/lib/templates/email/passwordForgot.js +16 -9
  35. package/lib/templates/email/passwordRecovery.js +16 -9
  36. package/lib/templates/email/verifyEmail.js +16 -9
  37. package/lib/templates/email/welcome.js +16 -9
  38. package/lib/templates/sms/passwordForgot.js +16 -9
  39. package/lib/templates/sms/passwordRecovery.js +16 -9
  40. package/lib/templates/sms/verifyEmail.js +16 -9
  41. package/lib/templates/sms/verifyPhone.js +16 -9
  42. package/lib/templates/sms/welcome.js +16 -9
  43. package/lib/types/apps.d.ts +1 -1
  44. package/lib/types/apps.js +14 -5
  45. package/lib/types/arangodb.js +14 -5
  46. package/lib/types/auth.js +14 -5
  47. package/lib/types/connections.js +14 -5
  48. package/lib/types/conversations.js +14 -5
  49. package/lib/types/email.js +14 -5
  50. package/lib/types/files.js +14 -5
  51. package/lib/types/google.js +14 -5
  52. package/lib/types/groups.js +14 -5
  53. package/lib/types/images.js +14 -5
  54. package/lib/types/index.js +50 -35
  55. package/lib/types/locations.js +14 -5
  56. package/lib/types/messages.js +14 -5
  57. package/lib/types/notifications.js +14 -5
  58. package/lib/types/payments.d.ts +1 -1
  59. package/lib/types/payments.js +14 -5
  60. package/lib/types/posts.js +14 -5
  61. package/lib/types/statistics.js +14 -5
  62. package/lib/types/tags.js +14 -5
  63. package/lib/types/users.js +14 -5
  64. package/lib/types/websocket.js +14 -5
  65. package/lib/utils/analytics.js +24 -44
  66. package/lib/utils/arangodb.js +14 -21
  67. package/lib/utils/auth.js +22 -36
  68. package/lib/utils/graphql.js +20 -17
  69. package/lib/utils/index.js +26 -23
  70. package/lib/utils/objects.js +22 -19
  71. package/lib/utils/session.js +20 -17
  72. package/package.json +31 -33
  73. package/.eslintrc +0 -18
@@ -1,56 +1,32 @@
1
- var __create = Object.create;
2
1
  var __defProp = Object.defineProperty;
3
- var __defProps = Object.defineProperties;
4
2
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
3
  var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
8
- var __getProtoOf = Object.getPrototypeOf;
9
4
  var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
- var __spreadValues = (a, b) => {
13
- for (var prop in b || (b = {}))
14
- if (__hasOwnProp.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- if (__getOwnPropSymbols)
17
- for (var prop of __getOwnPropSymbols(b)) {
18
- if (__propIsEnum.call(b, prop))
19
- __defNormalProp(a, prop, b[prop]);
20
- }
21
- return a;
22
- };
23
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
24
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
25
- var __require = typeof require !== "undefined" ? require : (x) => {
26
- throw new Error('Dynamic require of "' + x + '" is not supported');
27
- };
28
5
  var __export = (target, all) => {
29
- __markAsModule(target);
30
6
  for (var name in all)
31
7
  __defProp(target, name, { get: all[name], enumerable: true });
32
8
  };
33
- var __reExport = (target, module2, desc) => {
34
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
35
- for (let key of __getOwnPropNames(module2))
36
- if (!__hasOwnProp.call(target, key) && key !== "default")
37
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
38
14
  }
39
- return target;
15
+ return to;
40
16
  };
41
- var __toModule = (module2) => {
42
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
43
- };
44
- __export(exports, {
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var ios_exports = {};
19
+ __export(ios_exports, {
45
20
  addIosInApp: () => addIosInApp,
46
21
  getIosInApp: () => getIosInApp,
47
22
  getIosInAppError: () => getIosInAppError,
48
23
  getIosSubscription: () => getIosSubscription,
49
24
  iosSubscriptionUpdate: () => iosSubscriptionUpdate
50
25
  });
51
- var import_utils = __toModule(require("@nlabs/utils"));
52
- var import_arangojs = __toModule(require("arangojs"));
53
- var import_utils2 = __toModule(require("../utils"));
26
+ module.exports = __toCommonJS(ios_exports);
27
+ var import_utils = require("@nlabs/utils");
28
+ var import_arangojs = require("arangojs");
29
+ var import_utils2 = require("../utils");
54
30
  const eventCategory = "ios";
55
31
  const getIosInAppError = (statusCode) => {
56
32
  const codes = {
@@ -66,6 +42,10 @@ const getIosInAppError = (statusCode) => {
66
42
  message: "Receipt valid but sub expired",
67
43
  valid: true
68
44
  },
45
+ /**
46
+ * special case for app review handling - forward any request that is intended for the Sandbox but was sent to
47
+ * Production, this is what the app review team does
48
+ */
69
49
  [21007]: {
70
50
  error: true,
71
51
  id: "payment_invalid_server",
@@ -106,11 +86,12 @@ const iosSubscriptionUpdate = (database, subscriptionUpdate) => {
106
86
  receipt: latestReceipt || expiredReceipt,
107
87
  status: formatStatus
108
88
  };
109
- const insert = __spreadProps(__spreadValues({}, update), {
89
+ const insert = {
90
+ ...update,
110
91
  _key: id,
111
92
  added: now,
112
93
  type: "ios_payment"
113
- });
94
+ };
114
95
  const aqlQry = import_arangojs.aql`UPSERT {transactionId: ${transactionId}}
115
96
  INSERT ${insert}
116
97
  UPDATE ${update} IN subscriptions
@@ -179,4 +160,4 @@ const getIosInApp = (context) => {
179
160
  getIosSubscription,
180
161
  iosSubscriptionUpdate
181
162
  });
182
- //# 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": []
}

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"]
}

@@ -4,35 +4,38 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
5
  var __getProtoOf = Object.getPrototypeOf;
6
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
- var __require = typeof require !== "undefined" ? require : (x) => {
9
- throw new Error('Dynamic require of "' + x + '" is not supported');
10
- };
11
7
  var __export = (target, all) => {
12
- __markAsModule(target);
13
8
  for (var name in all)
14
9
  __defProp(target, name, { get: all[name], enumerable: true });
15
10
  };
16
- var __reExport = (target, module2, desc) => {
17
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
18
- for (let key of __getOwnPropNames(module2))
19
- if (!__hasOwnProp.call(target, key) && key !== "default")
20
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
21
16
  }
22
- return target;
23
- };
24
- var __toModule = (module2) => {
25
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
17
+ return to;
26
18
  };
27
- __export(exports, {
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
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var locations_exports = {};
29
+ __export(locations_exports, {
28
30
  addLocation: () => addLocation
29
31
  });
30
- var import_rip_hunter = __toModule(require("@nlabs/rip-hunter"));
31
- var import_utils = __toModule(require("@nlabs/utils"));
32
- var import_arangojs = __toModule(require("arangojs"));
33
- var import_get = __toModule(require("lodash/get"));
34
- var import_config = __toModule(require("../config"));
35
- var import_utils2 = __toModule(require("../utils"));
32
+ module.exports = __toCommonJS(locations_exports);
33
+ var import_rip_hunter = require("@nlabs/rip-hunter");
34
+ var import_utils = require("@nlabs/utils");
35
+ var import_arangojs = require("arangojs");
36
+ var import_get = __toESM(require("lodash/get"));
37
+ var import_config = require("../config");
38
+ var import_utils2 = require("../utils");
36
39
  const eventCategory = "locations";
37
40
  const addLocation = (context, location) => {
38
41
  const action = "add";
@@ -112,4 +115,4 @@ const addLocation = (context, location) => {
112
115
  0 && (module.exports = {
113
116
  addLocation
114
117
  });
115
- //# 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;AAIA,wBAA0C;AAC1C,mBAA6C;AAC7C,sBAAkB;AAIlB,iBAAgB;AAEhB,oBAAqB;AAIrB,oBAAuB;AAEvB,MAAM,gBAAwB;AAEvB,MAAM,cAAc,CAAC,SAAqB,aAAkD;AACjG,QAAM,SAAiB;AACvB,QAAM,EAAC,UAAU,SAAS,EAAC,QAAQ,gBAAc;AACjD,QAAM,EAAC,SAAS,QAAQ,aAAY;AACpC,QAAM,aAAqB,qBAAO,IAAI;AACtC,QAAM,SAAiB;AAAA,IACrB;AAAA,IACA,KAAK,qBAAO,IAAI;AAAA;AAElB,QAAM,MAAc,GAAG,cAAc,mCAAY;AAEjD,SAAO,2BAAQ,KACZ,KAAK,CAAC,SAAS;AACd,UAAM,EAAC,UAAU,IAAI,SAAS,OAAM;AAEpC,QAAG,WAAW,QAAQ,QAAQ,QAAQ;AACpC,YAAM,UAAkB,QAAQ;AAChC,YAAM,oBAA6C,wBAAI,SAAS;AAChE,YAAM,cAAc,CAAC,SAAyB;AAC5C,cAAM,EAAC,YAAY,YAAY,OAAM,kBAAkB,KAAK,CAAC,iBAAwC;AACnG,gBAAM,QAAQ,aAAa,SAAS;AACpC,iBAAO,MAAM,UAAU,CAAC,cAAsB,cAAc,SAAS;AAAA,cACjE;AAEN,eAAO;AAAA;AAIT,YAAM,eAAuB,YAAY;AACzC,YAAM,QAAgB,YAAY;AAGlC,YAAM,MAAc,KAAK;AAGzB,YAAM,iBAAyB,4BAAU,UAAU;AACnD,YAAM,eAAuB,0BAAQ;AACrC,YAAM,WAAmB,wBAAI,SAAS;AACtC,YAAM,SAAuB;AAC7B,YAAM,SAAuB;AAAA,QAC3B,MAAM,6BAAW,QAAQ;AAAA,QACzB,OAAO;AAAA,QACP,MAAM,YAAY;AAAA,QAClB,SAAS,YAAY;AAAA,QACrB,WAAW,wBAAI,SAAS;AAAA,QACxB;AAAA,QACA,UAAU,wBAAI,SAAS;AAAA,QACvB,WAAW,wBAAI,SAAS;AAAA,QACxB,OAAO,YAAY;AAAA,QACnB,QAAQ,CAAC,cAAc,OAAO,OAAO,CAAC,QAAQ,KAAK,KAAK;AAAA,QACxD,KAAK,YAAY;AAAA;AAEnB,YAAM,SAAmB,wCAAwB;AAAA,qBACpC;AAAA,qBACA;AAAA;AAGb,aAAO,SAAS,MAAM,QACnB,KAAK,CAAC,WAAwB,OAAO,QACrC,KAAK,CAAC,kBAAgC,OAAO;AAC5C,YAAI;AACJ,cAAM,EAAC,MAAM,uBAAsB;AAEnC,gBAAO;AAAA,eACA;AACH,wBAAY,SAAS;AACrB;AAAA;AAEA,wBAAY;AAAA;AAIhB,YAAG,WAAW;AACZ,gBAAM,iBAAiC,SAAS,WAAW;AAC3D,gBAAM,aAAqB;AAC3B,gBAAM,gBAAwB,aAAa;AAC3C,gBAAM,SAAS,6BAAW,eAAe,cAAc;AACvD,gBAAM,OAAY,EAAC,OAAO,WAAW,MAAM,QAAQ,KAAK;AAExD,iBAAO,eAAe,KAAK,MAAM,EAAC,WAAW,QAAO,KAAK,MAAM;AAAA;AAIjE,eAAO;AAAA,SAER,MAAM,CAAC,UAAiB,4BAAS;AAAA,QAChC;AAAA,QACA,UAAU;AAAA,QACV,OAAO;AAAA,SACN,OAAO,SAAS,KAAK,MAAM;AAAA;AAGlC,WAAO;AAAA;AAAA;",
  "names": []
}

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": "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",
  "names": ["import_utils", "httpGet", "get"]
}

@@ -1,47 +1,32 @@
1
1
  var __create = Object.create;
2
2
  var __defProp = Object.defineProperty;
3
- var __defProps = Object.defineProperties;
4
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
8
5
  var __getProtoOf = Object.getPrototypeOf;
9
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
- var __spreadValues = (a, b) => {
13
- for (var prop in b || (b = {}))
14
- if (__hasOwnProp.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- if (__getOwnPropSymbols)
17
- for (var prop of __getOwnPropSymbols(b)) {
18
- if (__propIsEnum.call(b, prop))
19
- __defNormalProp(a, prop, b[prop]);
20
- }
21
- return a;
22
- };
23
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
24
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
25
- var __require = typeof require !== "undefined" ? require : (x) => {
26
- throw new Error('Dynamic require of "' + x + '" is not supported');
27
- };
28
7
  var __export = (target, all) => {
29
- __markAsModule(target);
30
8
  for (var name in all)
31
9
  __defProp(target, name, { get: all[name], enumerable: true });
32
10
  };
33
- var __reExport = (target, module2, desc) => {
34
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
35
- for (let key of __getOwnPropNames(module2))
36
- if (!__hasOwnProp.call(target, key) && key !== "default")
37
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
38
16
  }
39
- return target;
17
+ return to;
40
18
  };
41
- var __toModule = (module2) => {
42
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
43
- };
44
- __export(exports, {
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
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var messages_exports = {};
29
+ __export(messages_exports, {
45
30
  cleanMessages: () => cleanMessages,
46
31
  deleteMessage: () => deleteMessage,
47
32
  getMessage: () => getMessage,
@@ -50,12 +35,13 @@ __export(exports, {
50
35
  unsaveMessage: () => unsaveMessage,
51
36
  updateMessage: () => updateMessage
52
37
  });
53
- var import_utils = __toModule(require("@nlabs/utils"));
54
- var import_arangojs = __toModule(require("arangojs"));
55
- var import_cloneDeep = __toModule(require("lodash/cloneDeep"));
56
- var import_isEmpty = __toModule(require("lodash/isEmpty"));
57
- var import_utils2 = __toModule(require("../utils"));
58
- var import_conversations2 = __toModule(require("./conversations"));
38
+ module.exports = __toCommonJS(messages_exports);
39
+ var import_utils = require("@nlabs/utils");
40
+ var import_arangojs = require("arangojs");
41
+ var import_cloneDeep = __toESM(require("lodash/cloneDeep"));
42
+ var import_isEmpty = __toESM(require("lodash/isEmpty"));
43
+ var import_utils2 = require("../utils");
44
+ var import_conversations2 = require("./conversations");
59
45
  const getMessages = (context, conversationId, { from, to }) => {
60
46
  const { database, session: { userId: sessionId } } = context;
61
47
  const formatConversationId = (0, import_utils.parseId)(conversationId);
@@ -107,12 +93,13 @@ const updateMessage = (context, message) => {
107
93
  modified: now
108
94
  };
109
95
  const formatMsgId = (0, import_utils.parseId)(messageId);
110
- const insert = __spreadProps(__spreadValues({}, (0, import_cloneDeep.default)(update)), {
96
+ const insert = {
97
+ ...(0, import_cloneDeep.default)(update),
111
98
  _key: formatMsgId,
112
99
  added: now,
113
100
  conversationId: formatConversationId,
114
101
  userId: sessionId
115
- });
102
+ };
116
103
  const aqlQry = import_arangojs.aql`UPSERT {_key: ${formatMsgId}, conversationId: ${formatConversationId}, userId: ${sessionId}}
117
104
  INSERT ${insert}
118
105
  UPDATE ${update} IN messages
@@ -216,4 +203,4 @@ const cleanMessages = (database) => {
216
203
  unsaveMessage,
217
204
  updateMessage
218
205
  });
219
- //# 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';\nimport isEmpty from 'lodash/isEmpty';\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 hasConversations\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(!isEmpty(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(!isEmpty(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(!isEmpty(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": []
}

206
+ //# 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';\nimport isEmpty from 'lodash/isEmpty';\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 hasConversations\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(!isEmpty(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(!isEmpty(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(!isEmpty(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", "isEmpty"]
}

@@ -1,4 +1,4 @@
1
- import { Provider, Responses } from 'apn';
1
+ import { Responses } from 'apn';
2
2
  import { NotificationType } from '../types/notifications';
3
3
  export declare const getApnProvider: () => Provider;
4
4
  export declare const pushNotification: (deviceTokens: string[], note: NotificationType) => Promise<Responses>;
@@ -1,36 +1,29 @@
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
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
- var __require = typeof require !== "undefined" ? require : (x) => {
9
- throw new Error('Dynamic require of "' + x + '" is not supported');
10
- };
11
5
  var __export = (target, all) => {
12
- __markAsModule(target);
13
6
  for (var name in all)
14
7
  __defProp(target, name, { get: all[name], enumerable: true });
15
8
  };
16
- var __reExport = (target, module2, desc) => {
17
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
18
- for (let key of __getOwnPropNames(module2))
19
- if (!__hasOwnProp.call(target, key) && key !== "default")
20
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
21
14
  }
22
- return target;
23
- };
24
- var __toModule = (module2) => {
25
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
15
+ return to;
26
16
  };
27
- __export(exports, {
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var notifications_exports = {};
19
+ __export(notifications_exports, {
28
20
  clearBadges: () => clearBadges,
29
21
  getApnProvider: () => getApnProvider,
30
22
  pushNotification: () => pushNotification
31
23
  });
32
- var import_apn = __toModule(require("apn"));
33
- var import_config = __toModule(require("../config"));
24
+ module.exports = __toCommonJS(notifications_exports);
25
+ var import_apn = require("apn");
26
+ var import_config = require("../config");
34
27
  const getApnProvider = () => new import_apn.Provider({
35
28
  ca: import_config.Config.get("app.apn.ca"),
36
29
  cert: import_config.Config.get("app.apn.cert"),
@@ -63,4 +56,4 @@ const clearBadges = (deviceTokens) => {
63
56
  getApnProvider,
64
57
  pushNotification
65
58
  });
66
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Tm90aWZpY2F0aW9uIGFzIEFQTk5vdGlmaWNhdGlvbiwgUHJvdmlkZXIsIFJlc3BvbnNlc30gZnJvbSAnYXBuJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnbm90aWZpY2F0aW9ucyc7XG5cbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCk6IFByb3ZpZGVyID0+IG5ldyBQcm92aWRlcih7XG4gIGNhOiBDb25maWcuZ2V0KCdhcHAuYXBuLmNhJyksXG4gIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICBrZXk6IENvbmZpZy5nZXQoJ2FwcC5hcG4ua2V5JyksXG4gIHByb2R1Y3Rpb246IENvbmZpZy5nZXQoJ2Vudmlyb25tZW50JykgPT09ICdwcm9kJ1xufSk7XG5cbmV4cG9ydCBjb25zdCBwdXNoTm90aWZpY2F0aW9uID0gKGRldmljZVRva2Vuczogc3RyaW5nW10sIG5vdGU6IE5vdGlmaWNhdGlvblR5cGUpOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXI6IFByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uOiBBUE5Ob3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi50b3BpYyA9IENvbmZpZy5nZXQoJ2FwcC5hcG4uaWQnKTtcbiAgbm90aWZpY2F0aW9uLmFsZXJ0ID0gbm90ZS5tZXNzYWdlO1xuXG4gIGlmKG5vdGUuZGF0YSkge1xuICAgIG5vdGlmaWNhdGlvbi5tdXRhYmxlQ29udGVudCA9IHRydWU7XG4gICAgbm90aWZpY2F0aW9uLnBheWxvYWQgPSBub3RlLmRhdGE7XG4gIH1cblxuICBpZihub3RlLmJhZGdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBub3RpZmljYXRpb24uYmFkZ2UgPSBub3RlLmJhZGdlO1xuICB9XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNsZWFyQmFkZ2VzID0gKGRldmljZVRva2Vuczogc3RyaW5nW10pOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi5iYWRnZSA9IDA7XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLGlCQUFtRTtBQUVuRSxvQkFBcUI7QUFNZCxNQUFNLGlCQUFpQixNQUFnQixJQUFJLG9CQUFTO0FBQUEsRUFDekQsSUFBSSxxQkFBTyxJQUFJO0FBQUEsRUFDZixNQUFNLHFCQUFPLElBQUk7QUFBQSxFQUNqQixLQUFLLHFCQUFPLElBQUk7QUFBQSxFQUNoQixZQUFZLHFCQUFPLElBQUksbUJBQW1CO0FBQUE7QUFHckMsTUFBTSxtQkFBbUIsQ0FBQyxjQUF3QixTQUErQztBQUV0RyxRQUFNLFdBQXFCO0FBQzNCLFFBQU0sZUFBZ0MsSUFBSTtBQUMxQyxlQUFhLFFBQVEscUJBQU8sSUFBSTtBQUNoQyxlQUFhLFFBQVEsS0FBSztBQUUxQixNQUFHLEtBQUssTUFBTTtBQUNaLGlCQUFhLGlCQUFpQjtBQUM5QixpQkFBYSxVQUFVLEtBQUs7QUFBQTtBQUc5QixNQUFHLEtBQUssVUFBVSxRQUFXO0FBQzNCLGlCQUFhLFFBQVEsS0FBSztBQUFBO0FBRzVCLFNBQU8sU0FBUyxLQUFLLGNBQWM7QUFBQTtBQUc5QixNQUFNLGNBQWMsQ0FBQyxpQkFBK0M7QUFFekUsUUFBTSxXQUFXO0FBQ2pCLFFBQU0sZUFBZSxJQUFJO0FBQ3pCLGVBQWEsUUFBUTtBQUVyQixTQUFPLFNBQVMsS0FBSyxjQUFjO0FBQUE7IiwKICAibmFtZXMiOiBbXQp9Cg==
59
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Tm90aWZpY2F0aW9uIGFzIEFQTk5vdGlmaWNhdGlvbiwgUHJvdmlkZXIsIFJlc3BvbnNlc30gZnJvbSAnYXBuJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnbm90aWZpY2F0aW9ucyc7XG5cbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCk6IFByb3ZpZGVyID0+IG5ldyBQcm92aWRlcih7XG4gIGNhOiBDb25maWcuZ2V0KCdhcHAuYXBuLmNhJyksXG4gIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICBrZXk6IENvbmZpZy5nZXQoJ2FwcC5hcG4ua2V5JyksXG4gIHByb2R1Y3Rpb246IENvbmZpZy5nZXQoJ2Vudmlyb25tZW50JykgPT09ICdwcm9kJ1xufSk7XG5cbmV4cG9ydCBjb25zdCBwdXNoTm90aWZpY2F0aW9uID0gKGRldmljZVRva2Vuczogc3RyaW5nW10sIG5vdGU6IE5vdGlmaWNhdGlvblR5cGUpOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXI6IFByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uOiBBUE5Ob3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi50b3BpYyA9IENvbmZpZy5nZXQoJ2FwcC5hcG4uaWQnKTtcbiAgbm90aWZpY2F0aW9uLmFsZXJ0ID0gbm90ZS5tZXNzYWdlO1xuXG4gIGlmKG5vdGUuZGF0YSkge1xuICAgIG5vdGlmaWNhdGlvbi5tdXRhYmxlQ29udGVudCA9IHRydWU7XG4gICAgbm90aWZpY2F0aW9uLnBheWxvYWQgPSBub3RlLmRhdGE7XG4gIH1cblxuICBpZihub3RlLmJhZGdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBub3RpZmljYXRpb24uYmFkZ2UgPSBub3RlLmJhZGdlO1xuICB9XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNsZWFyQmFkZ2VzID0gKGRldmljZVRva2Vuczogc3RyaW5nW10pOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi5iYWRnZSA9IDA7XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxpQkFBbUU7QUFFbkUsb0JBQXFCO0FBTWQsTUFBTSxpQkFBaUIsTUFBZ0IsSUFBSSxvQkFBUztBQUFBLEVBQ3pELElBQUkscUJBQU8sSUFBSSxZQUFZO0FBQUEsRUFDM0IsTUFBTSxxQkFBTyxJQUFJLGNBQWM7QUFBQSxFQUMvQixLQUFLLHFCQUFPLElBQUksYUFBYTtBQUFBLEVBQzdCLFlBQVkscUJBQU8sSUFBSSxhQUFhLE1BQU07QUFDNUMsQ0FBQztBQUVNLE1BQU0sbUJBQW1CLENBQUMsY0FBd0IsU0FBK0M7QUFFdEcsUUFBTSxXQUFxQixlQUFlO0FBQzFDLFFBQU0sZUFBZ0MsSUFBSSxXQUFBQSxhQUFnQjtBQUMxRCxlQUFhLFFBQVEscUJBQU8sSUFBSSxZQUFZO0FBQzVDLGVBQWEsUUFBUSxLQUFLO0FBRTFCLE1BQUcsS0FBSyxNQUFNO0FBQ1osaUJBQWEsaUJBQWlCO0FBQzlCLGlCQUFhLFVBQVUsS0FBSztBQUFBLEVBQzlCO0FBRUEsTUFBRyxLQUFLLFVBQVUsUUFBVztBQUMzQixpQkFBYSxRQUFRLEtBQUs7QUFBQSxFQUM1QjtBQUVBLFNBQU8sU0FBUyxLQUFLLGNBQWMsWUFBWTtBQUNqRDtBQUVPLE1BQU0sY0FBYyxDQUFDLGlCQUErQztBQUV6RSxRQUFNLFdBQVcsZUFBZTtBQUNoQyxRQUFNLGVBQWUsSUFBSSxXQUFBQSxhQUFnQjtBQUN6QyxlQUFhLFFBQVE7QUFFckIsU0FBTyxTQUFTLEtBQUssY0FBYyxZQUFZO0FBQ2pEOyIsCiAgIm5hbWVzIjogWyJBUE5Ob3RpZmljYXRpb24iXQp9Cg==