@nlabs/reaktor 0.1.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 (154) hide show
  1. package/.vscode/extensions.json +15 -0
  2. package/.vscode/settings.json +82 -0
  3. package/README.md +211 -0
  4. package/index.d.ts +1 -0
  5. package/index.js +5 -0
  6. package/lex.config.js +4 -0
  7. package/lib/config.d.ts +21 -0
  8. package/lib/config.js +127 -0
  9. package/lib/data/conversations.d.ts +6 -0
  10. package/lib/data/conversations.js +201 -0
  11. package/lib/data/dynamodb.d.ts +8 -0
  12. package/lib/data/dynamodb.js +139 -0
  13. package/lib/data/email.d.ts +7 -0
  14. package/lib/data/email.js +164 -0
  15. package/lib/data/files.d.ts +16 -0
  16. package/lib/data/files.js +407 -0
  17. package/lib/data/groups.d.ts +13 -0
  18. package/lib/data/groups.js +354 -0
  19. package/lib/data/images.d.ts +12 -0
  20. package/lib/data/images.js +668 -0
  21. package/lib/data/index.d.ts +19 -0
  22. package/lib/data/index.js +24 -0
  23. package/lib/data/ios.d.ts +6 -0
  24. package/lib/data/ios.js +302 -0
  25. package/lib/data/locations.d.ts +3 -0
  26. package/lib/data/locations.js +132 -0
  27. package/lib/data/messages.d.ts +9 -0
  28. package/lib/data/messages.js +248 -0
  29. package/lib/data/notifications.d.ts +5 -0
  30. package/lib/data/notifications.js +42 -0
  31. package/lib/data/payments.d.ts +11 -0
  32. package/lib/data/payments.js +748 -0
  33. package/lib/data/posts.d.ts +14 -0
  34. package/lib/data/posts.js +458 -0
  35. package/lib/data/reactions.d.ts +6 -0
  36. package/lib/data/reactions.js +218 -0
  37. package/lib/data/s3.d.ts +6 -0
  38. package/lib/data/s3.js +103 -0
  39. package/lib/data/search.d.ts +3 -0
  40. package/lib/data/search.js +98 -0
  41. package/lib/data/sms.d.ts +3 -0
  42. package/lib/data/sms.js +59 -0
  43. package/lib/data/subscription.d.ts +7 -0
  44. package/lib/data/subscription.js +284 -0
  45. package/lib/data/tags.d.ts +14 -0
  46. package/lib/data/tags.js +304 -0
  47. package/lib/data/users.d.ts +12 -0
  48. package/lib/data/users.js +312 -0
  49. package/lib/index.d.ts +3 -0
  50. package/lib/index.js +8 -0
  51. package/lib/types/apps.d.ts +44 -0
  52. package/lib/types/apps.js +2 -0
  53. package/lib/types/arangodb.d.ts +17 -0
  54. package/lib/types/arangodb.js +2 -0
  55. package/lib/types/auth.d.ts +9 -0
  56. package/lib/types/auth.js +2 -0
  57. package/lib/types/conversations.d.ts +6 -0
  58. package/lib/types/conversations.js +2 -0
  59. package/lib/types/email.d.ts +12 -0
  60. package/lib/types/email.js +2 -0
  61. package/lib/types/files.d.ts +28 -0
  62. package/lib/types/files.js +2 -0
  63. package/lib/types/google.d.ts +27 -0
  64. package/lib/types/google.js +2 -0
  65. package/lib/types/groups.d.ts +22 -0
  66. package/lib/types/groups.js +2 -0
  67. package/lib/types/images.d.ts +25 -0
  68. package/lib/types/images.js +2 -0
  69. package/lib/types/index.d.ts +17 -0
  70. package/lib/types/index.js +22 -0
  71. package/lib/types/locations.d.ts +21 -0
  72. package/lib/types/locations.js +2 -0
  73. package/lib/types/messages.d.ts +12 -0
  74. package/lib/types/messages.js +2 -0
  75. package/lib/types/notifications.d.ts +19 -0
  76. package/lib/types/notifications.js +2 -0
  77. package/lib/types/payments.d.ts +119 -0
  78. package/lib/types/payments.js +2 -0
  79. package/lib/types/posts.d.ts +20 -0
  80. package/lib/types/posts.js +2 -0
  81. package/lib/types/reactions.d.ts +4 -0
  82. package/lib/types/reactions.js +2 -0
  83. package/lib/types/tags.d.ts +10 -0
  84. package/lib/types/tags.js +2 -0
  85. package/lib/types/users.d.ts +78 -0
  86. package/lib/types/users.js +2 -0
  87. package/lib/utils/analytics.d.ts +3 -0
  88. package/lib/utils/analytics.js +47 -0
  89. package/lib/utils/arangodb.d.ts +9 -0
  90. package/lib/utils/arangodb.js +98 -0
  91. package/lib/utils/auth.d.ts +2 -0
  92. package/lib/utils/auth.js +43 -0
  93. package/lib/utils/index.d.ts +5 -0
  94. package/lib/utils/index.js +10 -0
  95. package/lib/utils/objects.d.ts +3 -0
  96. package/lib/utils/objects.js +34 -0
  97. package/lib/utils/redis.d.ts +1 -0
  98. package/lib/utils/redis.js +15 -0
  99. package/package.json +75 -0
  100. package/src/config.ts +121 -0
  101. package/src/data/conversations.ts +183 -0
  102. package/src/data/dynamodb.ts +157 -0
  103. package/src/data/email.ts +164 -0
  104. package/src/data/files.ts +352 -0
  105. package/src/data/groups.ts +308 -0
  106. package/src/data/images.ts +606 -0
  107. package/src/data/index.ts +23 -0
  108. package/src/data/ios.ts +249 -0
  109. package/src/data/locations.ts +114 -0
  110. package/src/data/messages.ts +237 -0
  111. package/src/data/notifications.ts +48 -0
  112. package/src/data/payments.ts +675 -0
  113. package/src/data/posts.ts +508 -0
  114. package/src/data/reactions.ts +186 -0
  115. package/src/data/s3.ts +117 -0
  116. package/src/data/search.ts +74 -0
  117. package/src/data/sms.ts +60 -0
  118. package/src/data/subscription.ts +228 -0
  119. package/src/data/tags.ts +230 -0
  120. package/src/data/users.ts +256 -0
  121. package/src/index.ts +7 -0
  122. package/src/types/apps.ts +57 -0
  123. package/src/types/arangodb.ts +23 -0
  124. package/src/types/auth.ts +19 -0
  125. package/src/types/conversations.ts +11 -0
  126. package/src/types/email.ts +17 -0
  127. package/src/types/files.ts +33 -0
  128. package/src/types/google.ts +37 -0
  129. package/src/types/groups.ts +28 -0
  130. package/src/types/images.ts +33 -0
  131. package/src/types/index.ts +21 -0
  132. package/src/types/locations.ts +25 -0
  133. package/src/types/messages.ts +16 -0
  134. package/src/types/notifications.ts +26 -0
  135. package/src/types/payments.ts +134 -0
  136. package/src/types/posts.ts +25 -0
  137. package/src/types/reactions.ts +8 -0
  138. package/src/types/tags.ts +14 -0
  139. package/src/types/users.ts +89 -0
  140. package/src/utils/analytics.ts +41 -0
  141. package/src/utils/arangodb.ts +100 -0
  142. package/src/utils/auth.ts +28 -0
  143. package/src/utils/index.ts +9 -0
  144. package/src/utils/objects.ts +34 -0
  145. package/src/utils/redis.ts +17 -0
  146. package/templates/email/layout.html +279 -0
  147. package/templates/email/passwordForgot.html +15 -0
  148. package/templates/email/passwordRecovery.html +12 -0
  149. package/templates/email/verifyEmail.html +15 -0
  150. package/templates/sms/passwordForgot.txt +1 -0
  151. package/templates/sms/passwordRecovery.txt +1 -0
  152. package/templates/sms/verifyEmail.txt +1 -0
  153. package/templates/sms/verifyPhone.txt +1 -0
  154. package/tsconfig.json +45 -0
@@ -0,0 +1,19 @@
1
+ export * from './conversations';
2
+ export * from './dynamodb';
3
+ export * from './email';
4
+ export * from './files';
5
+ export * from './groups';
6
+ export * from './images';
7
+ export * from './ios';
8
+ export * from './locations';
9
+ export * from './messages';
10
+ export * from './notifications';
11
+ export * from './payments';
12
+ export * from './posts';
13
+ export * from './reactions';
14
+ export * from './s3';
15
+ export * from './search';
16
+ export * from './sms';
17
+ export * from './subscription';
18
+ export * from './tags';
19
+ export * from './users';
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */
5
+ export * from './conversations';
6
+ export * from './dynamodb';
7
+ export * from './email';
8
+ export * from './files';
9
+ export * from './groups';
10
+ export * from './images';
11
+ export * from './ios';
12
+ export * from './locations';
13
+ export * from './messages';
14
+ export * from './notifications';
15
+ export * from './payments';
16
+ export * from './posts';
17
+ export * from './reactions';
18
+ export * from './s3';
19
+ export * from './search';
20
+ export * from './sms';
21
+ export * from './subscription';
22
+ export * from './tags';
23
+ export * from './users';
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7O0FBSUEsY0FBYyxpQkFBZDtBQUNBLGNBQWMsWUFBZDtBQUNBLGNBQWMsU0FBZDtBQUNBLGNBQWMsU0FBZDtBQUNBLGNBQWMsVUFBZDtBQUNBLGNBQWMsVUFBZDtBQUNBLGNBQWMsT0FBZDtBQUNBLGNBQWMsYUFBZDtBQUNBLGNBQWMsWUFBZDtBQUNBLGNBQWMsaUJBQWQ7QUFDQSxjQUFjLFlBQWQ7QUFDQSxjQUFjLFNBQWQ7QUFDQSxjQUFjLGFBQWQ7QUFDQSxjQUFjLE1BQWQ7QUFDQSxjQUFjLFVBQWQ7QUFDQSxjQUFjLE9BQWQ7QUFDQSxjQUFjLGdCQUFkO0FBQ0EsY0FBYyxRQUFkO0FBQ0EsY0FBYyxTQUFkIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vY29udmVyc2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2R5bmFtb2RiJztcbmV4cG9ydCAqIGZyb20gJy4vZW1haWwnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlcyc7XG5leHBvcnQgKiBmcm9tICcuL2dyb3Vwcyc7XG5leHBvcnQgKiBmcm9tICcuL2ltYWdlcyc7XG5leHBvcnQgKiBmcm9tICcuL2lvcyc7XG5leHBvcnQgKiBmcm9tICcuL2xvY2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL21lc3NhZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vbm90aWZpY2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3BheW1lbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vcG9zdHMnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWFjdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zMyc7XG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaCc7XG5leHBvcnQgKiBmcm9tICcuL3Ntcyc7XG5leHBvcnQgKiBmcm9tICcuL3N1YnNjcmlwdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3RhZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi91c2Vycyc7Il19
@@ -0,0 +1,6 @@
1
+ import { ApiContext, PaymentIOSInAppError, PaymentIOSSubscriptionUpdate, PaymentSubscription } from '../types';
2
+ export declare const getIOSInAppError: (statusCode: string) => PaymentIOSInAppError;
3
+ export declare const iOSSubscriptionUpdate: (database: string, subscriptionUpdate: PaymentIOSSubscriptionUpdate) => Promise<void>;
4
+ export declare const getIOSSubscription: (context: ApiContext) => Promise<PaymentSubscription>;
5
+ export declare const addIOSInApp: (context: ApiContext, subscription: PaymentSubscription) => Promise<PaymentSubscription>;
6
+ export declare const getIOSInApp: (context: ApiContext) => Promise<PaymentSubscription>;
@@ -0,0 +1,302 @@
1
+ function _templateObject4() {
2
+ var data = _taggedTemplateLiteral(["FOR s IN subscription\n FILTER s.userId == ", " && s.type == \"ios\"\n LIMIT 1\n RETURN s"]);
3
+
4
+ _templateObject4 = function _templateObject4() {
5
+ return data;
6
+ };
7
+
8
+ return data;
9
+ }
10
+
11
+ function _templateObject3() {
12
+ var data = _taggedTemplateLiteral(["INSERT ", " IN subscriptions RETURN NEW"]);
13
+
14
+ _templateObject3 = function _templateObject3() {
15
+ return data;
16
+ };
17
+
18
+ return data;
19
+ }
20
+
21
+ function _templateObject2() {
22
+ var data = _taggedTemplateLiteral(["FOR s IN subscriptions\n FILTER s.userId == ", " && s.type == \"ios_payment\"\n LIMIT 1\n RETURN s"]);
23
+
24
+ _templateObject2 = function _templateObject2() {
25
+ return data;
26
+ };
27
+
28
+ return data;
29
+ }
30
+
31
+ function _templateObject() {
32
+ var data = _taggedTemplateLiteral(["UPSERT {transactionId: ", "}\n INSERT ", "\n UPDATE ", " IN subscriptions\n LIMIT 1"]);
33
+
34
+ _templateObject = function _templateObject() {
35
+ return data;
36
+ };
37
+
38
+ return data;
39
+ }
40
+
41
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
42
+
43
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
44
+
45
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
46
+
47
+ import { createHash } from '@nlabs/utils';
48
+ import { aql } from 'arangojs';
49
+ import { logError, useDb } from '../utils';
50
+ var eventCategory = 'ios';
51
+ export var getIOSInAppError = function getIOSInAppError(statusCode) {
52
+ var _codes;
53
+
54
+ var codes = (_codes = {}, _defineProperty(_codes, 0, {
55
+ error: false,
56
+ message: 'Active',
57
+ valid: true
58
+ }), _defineProperty(_codes, 21000, {
59
+ error: true,
60
+ id: 'payment_receipt_unreadable',
61
+ message: 'App store could not read',
62
+ valid: false
63
+ }), _defineProperty(_codes, 21002, {
64
+ error: true,
65
+ id: 'payment_data_malformed',
66
+ message: 'Data was malformed',
67
+ valid: false
68
+ }), _defineProperty(_codes, 21003, {
69
+ error: true,
70
+ id: 'payment_receipt_unauthorized',
71
+ message: 'Receipt not authenticated',
72
+ valid: false
73
+ }), _defineProperty(_codes, 21004, {
74
+ error: true,
75
+ id: 'payment_invalid_secret',
76
+ message: 'Shared secret does not match',
77
+ valid: false
78
+ }), _defineProperty(_codes, 21005, {
79
+ error: true,
80
+ id: 'payment_server_unavailable',
81
+ message: 'Receipt server unavailable',
82
+ valid: false
83
+ }), _defineProperty(_codes, 21006, {
84
+ error: false,
85
+ id: 'payment_subscription_expired',
86
+ message: 'Receipt valid but sub expired',
87
+ valid: true
88
+ }), _defineProperty(_codes, 21007, {
89
+ error: true,
90
+ id: 'payment_invalid_server',
91
+ message: 'Sandbox receipt sent to Production environment',
92
+ redirect: true,
93
+ valid: false
94
+ }), _defineProperty(_codes, 21008, {
95
+ error: true,
96
+ id: 'payment_invalid_server',
97
+ message: 'Production receipt sent to Sandbox environment',
98
+ valid: false
99
+ }), _codes);
100
+ return codes[statusCode] || {};
101
+ };
102
+ export var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subscriptionUpdate) {
103
+ var action = 'iOSSubscriptionUpdate';
104
+ var planId = subscriptionUpdate.auto_renew_adam_id,
105
+ cancelDate = subscriptionUpdate.cancellation_date,
106
+ status = subscriptionUpdate.notification_type,
107
+ latestReceipt = subscriptionUpdate.latest_receipt,
108
+ latestInfo = subscriptionUpdate.latest_receipt_info,
109
+ expiredReceipt = subscriptionUpdate.latest_expired_receipt,
110
+ expiredInfo = subscriptionUpdate.latest_expired_receipt_info,
111
+ transactionId = subscriptionUpdate.original_transaction_id;
112
+ var formatStatus = (status || '').toLowerCase();
113
+ var now = Date.now();
114
+ var receiptInfo = latestInfo || expiredInfo;
115
+ var id = createHash("payment-".concat(transactionId));
116
+ var update = {
117
+ cancelDate: cancelDate,
118
+ isValid: receiptInfo[0].expires_date_ms > now,
119
+ modified: now,
120
+ planId: planId,
121
+ receipt: latestReceipt || expiredReceipt,
122
+ status: formatStatus
123
+ };
124
+
125
+ var insert = _objectSpread({}, update, {
126
+ _key: id,
127
+ added: now,
128
+ type: 'ios_payment'
129
+ });
130
+
131
+ var aqlQry = aql(_templateObject(), transactionId, insert, update);
132
+ return useDb(database).query(aqlQry).then(function () {
133
+ return null;
134
+ }).catch(function (dbError) {
135
+ return logError({
136
+ action: action,
137
+ category: eventCategory,
138
+ label: 'db_error'
139
+ }, dbError, {}).then(function () {
140
+ return null;
141
+ });
142
+ });
143
+ }; // export const addIOSInApp = (
144
+ // context: ApiContext,
145
+ // app,
146
+ // subscription: PaymentSubscription
147
+ // ): Promise<PaymentSubscription> => {
148
+ // const action: string = 'addIOSInApp';
149
+ // const {isProduction, receipt} = subscription;
150
+ // const {database, userId: sessionId} = context;
151
+ // const productionHost: string = 'buy.itunes.apple.com';
152
+ // const sandboxHost: string = 'sandbox.itunes.apple.com';
153
+ // const endpoint: string = isProduction ? productionHost : sandboxHost;
154
+ // const verifyUrl: string = `https://${endpoint}/verifyReceipt`;
155
+ // const payload: object = {
156
+ // password: app.iap,
157
+ // 'receipt-data': decodeURIComponent(receipt)
158
+ // };
159
+ // const options: object = {
160
+ // headers: {
161
+ // 'Content-Type': 'application/x-www-form-urlencoded'
162
+ // }
163
+ // };
164
+ // return post(verifyUrl, payload, options)
165
+ // .then((results) => {
166
+ // const json = JSON.parse(results);
167
+ // const {
168
+ // latest_receipt: latestReceipt,
169
+ // latest_receipt_info: latestInfo,
170
+ // status
171
+ // } = json;
172
+ // const {
173
+ // is_trial_period: trialPeriod,
174
+ // original_purchase_date_ms: added,
175
+ // expires_date: expires,
176
+ // product_id: planId,
177
+ // transaction_id: transactionId
178
+ // } = latestInfo;
179
+ // if(status === 0 || status === 21006) {
180
+ // const id: string = createHash(`payment-${transactionId}`);
181
+ // const now: number = Date.now();
182
+ // const update: PaymentSubscription = {
183
+ // expires,
184
+ // isTrial: trialPeriod === 'true',
185
+ // isValid: expires > now,
186
+ // modified: now,
187
+ // planId,
188
+ // receipt: latestReceipt,
189
+ // transactionId,
190
+ // userId: sessionId
191
+ // };
192
+ // const insert: PaymentSubscription = {
193
+ // ...update,
194
+ // _key: id,
195
+ // added,
196
+ // type: 'ios_payment'
197
+ // };
198
+ // const aqlQry: AqlQuery = aql`UPSERT {transactionId: ${transactionId}}
199
+ // INSERT ${insert}
200
+ // UPDATE ${update} IN subscriptions
201
+ // RETURN NEW`;
202
+ // return useDb(database).query(aqlQry)
203
+ // .then((cursor: ArrayCursor) => cursor.next())
204
+ // .then((updatedSubscription: PaymentSubscription = {}) => updatedSubscription)
205
+ // .catch((dbError: Error) => logError({
206
+ // action,
207
+ // category: eventCategory,
208
+ // label: 'db_error'
209
+ // }, dbError, context).then(() => null));
210
+ // }
211
+ // // Errors
212
+ // const error: PaymentIOSInAppError = getIOSInAppError(results.status);
213
+ // return logException({
214
+ // action,
215
+ // category: eventCategory,
216
+ // label: 'payment_error',
217
+ // message: error.message,
218
+ // value: error.id
219
+ // }, context).then(() => null);
220
+ // });
221
+ // };
222
+
223
+ export var getIOSSubscription = function getIOSSubscription(context) {
224
+ var action = 'getIOSSubscription';
225
+ var database = context.database,
226
+ sessionId = context.userId;
227
+ var aqlQry = aql(_templateObject2(), sessionId);
228
+ return useDb(database).query(aqlQry).then(function (cursor) {
229
+ return cursor.next();
230
+ }).then(function () {
231
+ var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
232
+ return subscription;
233
+ }).catch(function (error) {
234
+ return logError({
235
+ action: action,
236
+ category: eventCategory,
237
+ label: 'db_error'
238
+ }, error, context).then(function () {
239
+ return null;
240
+ });
241
+ });
242
+ };
243
+ export var addIOSInApp = function addIOSInApp(context, subscription) {
244
+ var action = 'addIOSInApp';
245
+ var database = context.database,
246
+ sessionId = context.userId;
247
+ var now = Date.now();
248
+ var _subscription$added = subscription.added,
249
+ added = _subscription$added === void 0 ? now : _subscription$added,
250
+ planId = subscription.planId,
251
+ receipt = subscription.receipt,
252
+ transactionId = subscription.transactionId,
253
+ trialEnd = subscription.trialEnd;
254
+ var subscriptionId = createHash("subscription-".concat(transactionId));
255
+ var insert = {
256
+ _key: subscriptionId,
257
+ added: added,
258
+ modified: now,
259
+ planId: planId,
260
+ receipt: receipt,
261
+ transactionId: transactionId,
262
+ trialEnd: trialEnd,
263
+ type: 'ios_subscription',
264
+ userId: sessionId
265
+ };
266
+ var aqlQry = aql(_templateObject3(), insert);
267
+ return useDb(database).query(aqlQry).then(function (cursor) {
268
+ return cursor.next();
269
+ }).then(function () {
270
+ var updatedSubscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
271
+ return updatedSubscription;
272
+ }).catch(function (error) {
273
+ return logError({
274
+ action: action,
275
+ category: eventCategory,
276
+ label: 'db_error'
277
+ }, error, context).then(function () {
278
+ return null;
279
+ });
280
+ });
281
+ };
282
+ export var getIOSInApp = function getIOSInApp(context) {
283
+ var action = 'getIOSInApp';
284
+ var database = context.database,
285
+ sessionId = context.userId;
286
+ var aqlQry = aql(_templateObject4(), sessionId);
287
+ return useDb(database).query(aqlQry).then(function (cursor) {
288
+ return cursor.next();
289
+ }).then(function () {
290
+ var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
291
+ return subscription;
292
+ }).catch(function (error) {
293
+ return logError({
294
+ action: action,
295
+ category: eventCategory,
296
+ label: 'db_error'
297
+ }, error, context).then(function () {
298
+ return null;
299
+ });
300
+ });
301
+ };
302
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/ios.ts"],"names":["createHash","aql","logError","useDb","eventCategory","getIOSInAppError","statusCode","codes","error","message","valid","id","redirect","iOSSubscriptionUpdate","database","subscriptionUpdate","action","planId","auto_renew_adam_id","cancelDate","cancellation_date","status","notification_type","latestReceipt","latest_receipt","latestInfo","latest_receipt_info","expiredReceipt","latest_expired_receipt","expiredInfo","latest_expired_receipt_info","transactionId","original_transaction_id","formatStatus","toLowerCase","now","Date","receiptInfo","update","isValid","expires_date_ms","modified","receipt","insert","_key","added","type","aqlQry","query","then","catch","dbError","category","label","getIOSSubscription","context","sessionId","userId","cursor","next","subscription","addIOSInApp","trialEnd","subscriptionId","updatedSubscription","getIOSInApp"],"mappings":"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","sourcesContent":["import {createHash} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {\n  ApiContext,\n  PaymentIOSInAppError,\n  PaymentIOSSubscriptionInfo,\n  PaymentIOSSubscriptionUpdate,\n  PaymentSubscription\n} from '../types';\nimport {logError, useDb} 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 = (database: string, subscriptionUpdate: PaymentIOSSubscriptionUpdate): 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 useDb(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 useDb(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, 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 useDb(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, 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 useDb(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, 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 useDb(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"]}
@@ -0,0 +1,3 @@
1
+ import { ApiContext } from '../types/auth';
2
+ import { LocationType } from '../types/locations';
3
+ export declare const addLocation: (context: ApiContext, location: LocationType) => Promise<LocationType>;
@@ -0,0 +1,132 @@
1
+ function _templateObject() {
2
+ var data = _taggedTemplateLiteral(["UPSERT {googleId: ", "}\n INSERT ", "\n UPDATE ", "\n IN locations RETURN NEW"]);
3
+
4
+ _templateObject = function _templateObject() {
5
+ return data;
6
+ };
7
+
8
+ return data;
9
+ }
10
+
11
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
12
+
13
+ /**
14
+ * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
15
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
16
+ */
17
+ import { get as httpGet, queryString } from '@nlabs/rip-hunter';
18
+ import { createHash, parseChar, parseId } from '@nlabs/utils';
19
+ import { aql } from 'arangojs';
20
+ import get from 'lodash/get';
21
+ import { Config } from '../config';
22
+ import { logError, useDb } from '../utils';
23
+ var eventCategory = 'locations';
24
+ export var addLocation = function addLocation(context, location) {
25
+ var action = 'add';
26
+ var database = context.database,
27
+ sessionId = context.userId;
28
+ var address = location.address,
29
+ itemId = location.itemId,
30
+ itemType = location.itemType;
31
+ var geocodeUrl = Config.get('google.geocode.url');
32
+ var params = {
33
+ address: address,
34
+ key: Config.get('google.geocode.key')
35
+ };
36
+ var url = "".concat(geocodeUrl, "?").concat(queryString(params));
37
+ return httpGet(url).then(function (json) {
38
+ var _json$results = json.results,
39
+ results = _json$results === void 0 ? [] : _json$results,
40
+ _json$status = json.status,
41
+ status = _json$status === void 0 ? '' : _json$status;
42
+
43
+ if (status === 'OK' && results.length) {
44
+ var geodata = results[0];
45
+ var addressComponents = get(geodata, 'address_components');
46
+
47
+ var getFieldVal = function getFieldVal(name) {
48
+ var _ref = addressComponents.find(function (addressField) {
49
+ var types = addressField.types || [];
50
+ return types.findIndex(function (fieldType) {
51
+ return fieldType === name;
52
+ }) >= 0;
53
+ }) || {},
54
+ _ref$short_name = _ref.short_name,
55
+ shortName = _ref$short_name === void 0 ? '' : _ref$short_name;
56
+
57
+ return shortName;
58
+ }; // Street
59
+
60
+
61
+ var streetNumber = getFieldVal('street_number');
62
+ var route = getFieldVal('route'); // Location
63
+
64
+ var now = Date.now(); // Item
65
+
66
+ var formatItemType = parseChar(itemType).toLowerCase();
67
+ var formatItemId = parseId(itemId);
68
+ var googleId = get(geodata, 'place_id');
69
+ var update = {};
70
+ var insert = {
71
+ _key: createHash("post-".concat(sessionId)),
72
+ added: now,
73
+ city: getFieldVal('locality'),
74
+ country: getFieldVal('country'),
75
+ formatted: get(geodata, 'formatted_address'),
76
+ googleId: googleId,
77
+ latitude: get(geodata, 'geometry.location.lat'),
78
+ longitude: get(geodata, 'geometry.location.lng'),
79
+ state: getFieldVal('administrative_area_level_1'),
80
+ street: [streetNumber, route].filter(function (obj) {
81
+ return obj;
82
+ }).join(' '),
83
+ zip: getFieldVal('postal_code')
84
+ };
85
+ var aqlQry = aql(_templateObject(), googleId, insert, update);
86
+ return useDb(database).query(aqlQry).then(function (cursor) {
87
+ return cursor.next();
88
+ }).then(function () {
89
+ var updatedLocation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
90
+ var itemDocId;
91
+ var updatedLocationKey = updatedLocation._key;
92
+
93
+ switch (formatItemType) {
94
+ case 'posts':
95
+ itemDocId = "posts/".concat(formatItemId);
96
+ break;
97
+
98
+ default:
99
+ itemDocId = '';
100
+ } // If there is a valid item doc id, create an edge
101
+
102
+
103
+ if (itemDocId) {
104
+ var edgeCollection = useDb(database).edgeCollection('hasLocation');
105
+ var locationId = updatedLocationKey;
106
+ var locationDocId = "locations/".concat(locationId);
107
+ var edgeId = createHash("hasLocation-".concat(locationId, "-").concat(sessionId));
108
+ var edge = {
109
+ _key: edgeId
110
+ };
111
+ return edgeCollection.save(edge, itemDocId, locationDocId).then(function () {
112
+ return updatedLocation;
113
+ });
114
+ } // Otherwise just return the new location
115
+
116
+
117
+ return updatedLocation;
118
+ }).catch(function (error) {
119
+ return logError({
120
+ action: action,
121
+ category: eventCategory,
122
+ label: 'db_error'
123
+ }, error, context).then(function () {
124
+ return null;
125
+ });
126
+ });
127
+ }
128
+
129
+ return {};
130
+ });
131
+ };
132
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/locations.ts"],"names":["get","httpGet","queryString","createHash","parseChar","parseId","aql","Config","logError","useDb","eventCategory","addLocation","context","location","action","database","sessionId","userId","address","itemId","itemType","geocodeUrl","params","key","url","then","json","results","status","length","geodata","addressComponents","getFieldVal","name","find","addressField","types","findIndex","fieldType","short_name","shortName","streetNumber","route","now","Date","formatItemType","toLowerCase","formatItemId","googleId","update","insert","_key","added","city","country","formatted","latitude","longitude","state","street","filter","obj","join","zip","aqlQry","query","cursor","next","updatedLocation","itemDocId","updatedLocationKey","edgeCollection","locationId","locationDocId","edgeId","edge","save","catch","error","category","label"],"mappings":"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","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/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/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, useDb} 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, 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 useDb(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 = useDb(database).edgeCollection('hasLocation');\n              const locationId: string = updatedLocationKey;\n              const locationDocId: string = `locations/${locationId}`;\n              const edgeId = createHash(`hasLocation-${locationId}-${sessionId}`);\n              const edge: any = {_key: edgeId};\n\n              return edgeCollection.save(edge, itemDocId, locationDocId).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"]}
@@ -0,0 +1,9 @@
1
+ import { ApiContext } from '../types/auth';
2
+ import { MessageType } from '../types/messages';
3
+ export declare const getMessageList: (context: ApiContext, convoId: string, from: number, to: number) => Promise<MessageType[]>;
4
+ export declare const updateMessage: (context: ApiContext, message: MessageType) => Promise<MessageType>;
5
+ export declare const saveMessage: (context: ApiContext, msgId: string, convoId: string) => Promise<MessageType>;
6
+ export declare const unsaveMessage: (context: ApiContext, msgId: string, convoId: string) => Promise<MessageType>;
7
+ export declare const deleteMessage: (context: ApiContext, msgId: string, convoId: string) => Promise<MessageType>;
8
+ export declare const getMessage: (data: MessageType) => MessageType;
9
+ export declare const cleanMessages: (database: string) => Promise<number>;