@nlabs/reaktor 0.1.12 → 0.1.14

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 (50) hide show
  1. package/lib/config.js +138 -0
  2. package/lib/data/conversations.js +228 -0
  3. package/lib/data/dynamodb.js +172 -0
  4. package/lib/data/email.js +194 -0
  5. package/lib/data/files.js +463 -0
  6. package/lib/data/groups.js +401 -0
  7. package/lib/data/images.js +841 -0
  8. package/lib/data/index.js +234 -0
  9. package/lib/data/ios.js +327 -0
  10. package/lib/data/locations.js +148 -0
  11. package/lib/data/messages.js +281 -0
  12. package/lib/data/notifications.js +59 -0
  13. package/lib/data/payments.js +798 -0
  14. package/lib/data/posts.js +637 -0
  15. package/lib/data/reactions.js +243 -0
  16. package/lib/data/s3.js +133 -0
  17. package/lib/data/search.js +111 -0
  18. package/lib/data/sms.js +79 -0
  19. package/lib/data/subscription.js +311 -0
  20. package/lib/data/tags.js +343 -0
  21. package/lib/data/users.js +415 -0
  22. package/lib/index.js +42 -0
  23. package/lib/types/apps.js +2 -0
  24. package/lib/types/arangodb.js +2 -0
  25. package/lib/types/auth.js +2 -0
  26. package/lib/types/conversations.js +2 -0
  27. package/lib/types/email.js +2 -0
  28. package/lib/types/files.js +2 -0
  29. package/lib/types/google.js +2 -0
  30. package/lib/types/groups.js +2 -0
  31. package/lib/types/images.js +2 -0
  32. package/lib/types/index.js +210 -0
  33. package/lib/types/locations.js +2 -0
  34. package/lib/types/messages.js +2 -0
  35. package/lib/types/notifications.js +2 -0
  36. package/lib/types/payments.js +2 -0
  37. package/lib/types/posts.js +2 -0
  38. package/lib/types/reactions.js +2 -0
  39. package/lib/types/tags.js +2 -0
  40. package/lib/types/users.js +2 -0
  41. package/lib/utils/analytics.js +59 -0
  42. package/lib/utils/arangodb.d.ts +0 -1
  43. package/lib/utils/arangodb.js +122 -0
  44. package/lib/utils/auth.d.ts +0 -2
  45. package/lib/utils/auth.js +55 -0
  46. package/lib/utils/graphql.js +19 -0
  47. package/lib/utils/index.js +78 -0
  48. package/lib/utils/objects.js +54 -0
  49. package/lib/utils/redis.js +28 -0
  50. package/package.json +7 -7
@@ -0,0 +1,234 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+
7
+ var _conversations = require("./conversations");
8
+
9
+ Object.keys(_conversations).forEach(function (key) {
10
+ if (key === "default" || key === "__esModule") return;
11
+ Object.defineProperty(exports, key, {
12
+ enumerable: true,
13
+ get: function get() {
14
+ return _conversations[key];
15
+ }
16
+ });
17
+ });
18
+
19
+ var _dynamodb = require("./dynamodb");
20
+
21
+ Object.keys(_dynamodb).forEach(function (key) {
22
+ if (key === "default" || key === "__esModule") return;
23
+ Object.defineProperty(exports, key, {
24
+ enumerable: true,
25
+ get: function get() {
26
+ return _dynamodb[key];
27
+ }
28
+ });
29
+ });
30
+
31
+ var _email = require("./email");
32
+
33
+ Object.keys(_email).forEach(function (key) {
34
+ if (key === "default" || key === "__esModule") return;
35
+ Object.defineProperty(exports, key, {
36
+ enumerable: true,
37
+ get: function get() {
38
+ return _email[key];
39
+ }
40
+ });
41
+ });
42
+
43
+ var _files = require("./files");
44
+
45
+ Object.keys(_files).forEach(function (key) {
46
+ if (key === "default" || key === "__esModule") return;
47
+ Object.defineProperty(exports, key, {
48
+ enumerable: true,
49
+ get: function get() {
50
+ return _files[key];
51
+ }
52
+ });
53
+ });
54
+
55
+ var _groups = require("./groups");
56
+
57
+ Object.keys(_groups).forEach(function (key) {
58
+ if (key === "default" || key === "__esModule") return;
59
+ Object.defineProperty(exports, key, {
60
+ enumerable: true,
61
+ get: function get() {
62
+ return _groups[key];
63
+ }
64
+ });
65
+ });
66
+
67
+ var _images = require("./images");
68
+
69
+ Object.keys(_images).forEach(function (key) {
70
+ if (key === "default" || key === "__esModule") return;
71
+ Object.defineProperty(exports, key, {
72
+ enumerable: true,
73
+ get: function get() {
74
+ return _images[key];
75
+ }
76
+ });
77
+ });
78
+
79
+ var _ios = require("./ios");
80
+
81
+ Object.keys(_ios).forEach(function (key) {
82
+ if (key === "default" || key === "__esModule") return;
83
+ Object.defineProperty(exports, key, {
84
+ enumerable: true,
85
+ get: function get() {
86
+ return _ios[key];
87
+ }
88
+ });
89
+ });
90
+
91
+ var _locations = require("./locations");
92
+
93
+ Object.keys(_locations).forEach(function (key) {
94
+ if (key === "default" || key === "__esModule") return;
95
+ Object.defineProperty(exports, key, {
96
+ enumerable: true,
97
+ get: function get() {
98
+ return _locations[key];
99
+ }
100
+ });
101
+ });
102
+
103
+ var _messages = require("./messages");
104
+
105
+ Object.keys(_messages).forEach(function (key) {
106
+ if (key === "default" || key === "__esModule") return;
107
+ Object.defineProperty(exports, key, {
108
+ enumerable: true,
109
+ get: function get() {
110
+ return _messages[key];
111
+ }
112
+ });
113
+ });
114
+
115
+ var _notifications = require("./notifications");
116
+
117
+ Object.keys(_notifications).forEach(function (key) {
118
+ if (key === "default" || key === "__esModule") return;
119
+ Object.defineProperty(exports, key, {
120
+ enumerable: true,
121
+ get: function get() {
122
+ return _notifications[key];
123
+ }
124
+ });
125
+ });
126
+
127
+ var _payments = require("./payments");
128
+
129
+ Object.keys(_payments).forEach(function (key) {
130
+ if (key === "default" || key === "__esModule") return;
131
+ Object.defineProperty(exports, key, {
132
+ enumerable: true,
133
+ get: function get() {
134
+ return _payments[key];
135
+ }
136
+ });
137
+ });
138
+
139
+ var _posts = require("./posts");
140
+
141
+ Object.keys(_posts).forEach(function (key) {
142
+ if (key === "default" || key === "__esModule") return;
143
+ Object.defineProperty(exports, key, {
144
+ enumerable: true,
145
+ get: function get() {
146
+ return _posts[key];
147
+ }
148
+ });
149
+ });
150
+
151
+ var _reactions = require("./reactions");
152
+
153
+ Object.keys(_reactions).forEach(function (key) {
154
+ if (key === "default" || key === "__esModule") return;
155
+ Object.defineProperty(exports, key, {
156
+ enumerable: true,
157
+ get: function get() {
158
+ return _reactions[key];
159
+ }
160
+ });
161
+ });
162
+
163
+ var _s = require("./s3");
164
+
165
+ Object.keys(_s).forEach(function (key) {
166
+ if (key === "default" || key === "__esModule") return;
167
+ Object.defineProperty(exports, key, {
168
+ enumerable: true,
169
+ get: function get() {
170
+ return _s[key];
171
+ }
172
+ });
173
+ });
174
+
175
+ var _search = require("./search");
176
+
177
+ Object.keys(_search).forEach(function (key) {
178
+ if (key === "default" || key === "__esModule") return;
179
+ Object.defineProperty(exports, key, {
180
+ enumerable: true,
181
+ get: function get() {
182
+ return _search[key];
183
+ }
184
+ });
185
+ });
186
+
187
+ var _sms = require("./sms");
188
+
189
+ Object.keys(_sms).forEach(function (key) {
190
+ if (key === "default" || key === "__esModule") return;
191
+ Object.defineProperty(exports, key, {
192
+ enumerable: true,
193
+ get: function get() {
194
+ return _sms[key];
195
+ }
196
+ });
197
+ });
198
+
199
+ var _subscription = require("./subscription");
200
+
201
+ Object.keys(_subscription).forEach(function (key) {
202
+ if (key === "default" || key === "__esModule") return;
203
+ Object.defineProperty(exports, key, {
204
+ enumerable: true,
205
+ get: function get() {
206
+ return _subscription[key];
207
+ }
208
+ });
209
+ });
210
+
211
+ var _tags = require("./tags");
212
+
213
+ Object.keys(_tags).forEach(function (key) {
214
+ if (key === "default" || key === "__esModule") return;
215
+ Object.defineProperty(exports, key, {
216
+ enumerable: true,
217
+ get: function get() {
218
+ return _tags[key];
219
+ }
220
+ });
221
+ });
222
+
223
+ var _users = require("./users");
224
+
225
+ Object.keys(_users).forEach(function (key) {
226
+ if (key === "default" || key === "__esModule") return;
227
+ Object.defineProperty(exports, key, {
228
+ enumerable: true,
229
+ get: function get() {
230
+ return _users[key];
231
+ }
232
+ });
233
+ });
234
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUlBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTs7QUFDQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2NvbnZlcnNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9keW5hbW9kYic7XG5leHBvcnQgKiBmcm9tICcuL2VtYWlsJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ncm91cHMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbWFnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9pb3MnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2NhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9tZXNzYWdlcyc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9wYXltZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3Bvc3RzJztcbmV4cG9ydCAqIGZyb20gJy4vcmVhY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vczMnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9zbXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi90YWdzJztcbmV4cG9ydCAqIGZyb20gJy4vdXNlcnMnOyJdfQ==
@@ -0,0 +1,327 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getIOSInApp = exports.addIOSInApp = exports.getIOSSubscription = exports.iOSSubscriptionUpdate = exports.getIOSInAppError = void 0;
7
+
8
+ var _utils = require("@nlabs/utils");
9
+
10
+ var _arangojs = require("arangojs");
11
+
12
+ var _utils2 = require("../utils");
13
+
14
+ function _templateObject4() {
15
+ var data = _taggedTemplateLiteral(["FOR s IN subscription\n FILTER s.userId == ", " && s.type == \"ios\"\n LIMIT 1\n RETURN s"]);
16
+
17
+ _templateObject4 = function _templateObject4() {
18
+ return data;
19
+ };
20
+
21
+ return data;
22
+ }
23
+
24
+ function _templateObject3() {
25
+ var data = _taggedTemplateLiteral(["INSERT ", " IN subscriptions RETURN NEW"]);
26
+
27
+ _templateObject3 = function _templateObject3() {
28
+ return data;
29
+ };
30
+
31
+ return data;
32
+ }
33
+
34
+ function _templateObject2() {
35
+ var data = _taggedTemplateLiteral(["FOR s IN subscriptions\n FILTER s.userId == ", " && s.type == \"ios_payment\"\n LIMIT 1\n RETURN s"]);
36
+
37
+ _templateObject2 = function _templateObject2() {
38
+ return data;
39
+ };
40
+
41
+ return data;
42
+ }
43
+
44
+ function _templateObject() {
45
+ var data = _taggedTemplateLiteral(["UPSERT {transactionId: ", "}\n INSERT ", "\n UPDATE ", " IN subscriptions\n LIMIT 1"]);
46
+
47
+ _templateObject = function _templateObject() {
48
+ return data;
49
+ };
50
+
51
+ return data;
52
+ }
53
+
54
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
55
+
56
+ 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; }
57
+
58
+ 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; }
59
+
60
+ var eventCategory = 'ios';
61
+
62
+ var getIOSInAppError = function getIOSInAppError(statusCode) {
63
+ var _codes;
64
+
65
+ var codes = (_codes = {}, _defineProperty(_codes, 0, {
66
+ error: false,
67
+ message: 'Active',
68
+ valid: true
69
+ }), _defineProperty(_codes, 21000, {
70
+ error: true,
71
+ id: 'payment_receipt_unreadable',
72
+ message: 'App store could not read',
73
+ valid: false
74
+ }), _defineProperty(_codes, 21002, {
75
+ error: true,
76
+ id: 'payment_data_malformed',
77
+ message: 'Data was malformed',
78
+ valid: false
79
+ }), _defineProperty(_codes, 21003, {
80
+ error: true,
81
+ id: 'payment_receipt_unauthorized',
82
+ message: 'Receipt not authenticated',
83
+ valid: false
84
+ }), _defineProperty(_codes, 21004, {
85
+ error: true,
86
+ id: 'payment_invalid_secret',
87
+ message: 'Shared secret does not match',
88
+ valid: false
89
+ }), _defineProperty(_codes, 21005, {
90
+ error: true,
91
+ id: 'payment_server_unavailable',
92
+ message: 'Receipt server unavailable',
93
+ valid: false
94
+ }), _defineProperty(_codes, 21006, {
95
+ error: false,
96
+ id: 'payment_subscription_expired',
97
+ message: 'Receipt valid but sub expired',
98
+ valid: true
99
+ }), _defineProperty(_codes, 21007, {
100
+ error: true,
101
+ id: 'payment_invalid_server',
102
+ message: 'Sandbox receipt sent to Production environment',
103
+ redirect: true,
104
+ valid: false
105
+ }), _defineProperty(_codes, 21008, {
106
+ error: true,
107
+ id: 'payment_invalid_server',
108
+ message: 'Production receipt sent to Sandbox environment',
109
+ valid: false
110
+ }), _codes);
111
+ return codes[statusCode] || {};
112
+ };
113
+
114
+ exports.getIOSInAppError = getIOSInAppError;
115
+
116
+ var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subscriptionUpdate) {
117
+ var action = 'iOSSubscriptionUpdate';
118
+ var planId = subscriptionUpdate.auto_renew_adam_id,
119
+ cancelDate = subscriptionUpdate.cancellation_date,
120
+ status = subscriptionUpdate.notification_type,
121
+ latestReceipt = subscriptionUpdate.latest_receipt,
122
+ latestInfo = subscriptionUpdate.latest_receipt_info,
123
+ expiredReceipt = subscriptionUpdate.latest_expired_receipt,
124
+ expiredInfo = subscriptionUpdate.latest_expired_receipt_info,
125
+ transactionId = subscriptionUpdate.original_transaction_id;
126
+ var formatStatus = (status || '').toLowerCase();
127
+ var now = Date.now();
128
+ var receiptInfo = latestInfo || expiredInfo;
129
+ var id = (0, _utils.createHash)("payment-".concat(transactionId));
130
+ var update = {
131
+ cancelDate: cancelDate,
132
+ isValid: receiptInfo[0].expires_date_ms > now,
133
+ modified: now,
134
+ planId: planId,
135
+ receipt: latestReceipt || expiredReceipt,
136
+ status: formatStatus
137
+ };
138
+
139
+ var insert = _objectSpread({}, update, {
140
+ _key: id,
141
+ added: now,
142
+ type: 'ios_payment'
143
+ });
144
+
145
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), transactionId, insert, update);
146
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function () {
147
+ return null;
148
+ })["catch"](function (dbError) {
149
+ return (0, _utils2.logError)({
150
+ action: action,
151
+ category: eventCategory,
152
+ label: 'db_error'
153
+ }, dbError, {}).then(function () {
154
+ return null;
155
+ });
156
+ });
157
+ }; // export const addIOSInApp = (
158
+ // context: ApiContext,
159
+ // app,
160
+ // subscription: PaymentSubscription
161
+ // ): Promise<PaymentSubscription> => {
162
+ // const action: string = 'addIOSInApp';
163
+ // const {isProduction, receipt} = subscription;
164
+ // const {database, userId: sessionId} = context;
165
+ // const productionHost: string = 'buy.itunes.apple.com';
166
+ // const sandboxHost: string = 'sandbox.itunes.apple.com';
167
+ // const endpoint: string = isProduction ? productionHost : sandboxHost;
168
+ // const verifyUrl: string = `https://${endpoint}/verifyReceipt`;
169
+ // const payload: object = {
170
+ // password: app.iap,
171
+ // 'receipt-data': decodeURIComponent(receipt)
172
+ // };
173
+ // const options: object = {
174
+ // headers: {
175
+ // 'Content-Type': 'application/x-www-form-urlencoded'
176
+ // }
177
+ // };
178
+ // return post(verifyUrl, payload, options)
179
+ // .then((results) => {
180
+ // const json = JSON.parse(results);
181
+ // const {
182
+ // latest_receipt: latestReceipt,
183
+ // latest_receipt_info: latestInfo,
184
+ // status
185
+ // } = json;
186
+ // const {
187
+ // is_trial_period: trialPeriod,
188
+ // original_purchase_date_ms: added,
189
+ // expires_date: expires,
190
+ // product_id: planId,
191
+ // transaction_id: transactionId
192
+ // } = latestInfo;
193
+ // if(status === 0 || status === 21006) {
194
+ // const id: string = createHash(`payment-${transactionId}`);
195
+ // const now: number = Date.now();
196
+ // const update: PaymentSubscription = {
197
+ // expires,
198
+ // isTrial: trialPeriod === 'true',
199
+ // isValid: expires > now,
200
+ // modified: now,
201
+ // planId,
202
+ // receipt: latestReceipt,
203
+ // transactionId,
204
+ // userId: sessionId
205
+ // };
206
+ // const insert: PaymentSubscription = {
207
+ // ...update,
208
+ // _key: id,
209
+ // added,
210
+ // type: 'ios_payment'
211
+ // };
212
+ // const aqlQry: AqlQuery = aql`UPSERT {transactionId: ${transactionId}}
213
+ // INSERT ${insert}
214
+ // UPDATE ${update} IN subscriptions
215
+ // RETURN NEW`;
216
+ // return useDb(database).query(aqlQry)
217
+ // .then((cursor: ArrayCursor) => cursor.next())
218
+ // .then((updatedSubscription: PaymentSubscription = {}) => updatedSubscription)
219
+ // .catch((dbError: Error) => logError({
220
+ // action,
221
+ // category: eventCategory,
222
+ // label: 'db_error'
223
+ // }, dbError, context).then(() => null));
224
+ // }
225
+ // // Errors
226
+ // const error: PaymentIOSInAppError = getIOSInAppError(results.status);
227
+ // return logException({
228
+ // action,
229
+ // category: eventCategory,
230
+ // label: 'payment_error',
231
+ // message: error.message,
232
+ // value: error.id
233
+ // }, context).then(() => null);
234
+ // });
235
+ // };
236
+
237
+
238
+ exports.iOSSubscriptionUpdate = iOSSubscriptionUpdate;
239
+
240
+ var getIOSSubscription = function getIOSSubscription(context) {
241
+ var action = 'getIOSSubscription';
242
+ var database = context.database,
243
+ sessionId = context.userId;
244
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionId);
245
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
246
+ return cursor.next();
247
+ }).then(function () {
248
+ var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
249
+ return subscription;
250
+ })["catch"](function (error) {
251
+ return (0, _utils2.logError)({
252
+ action: action,
253
+ category: eventCategory,
254
+ label: 'db_error'
255
+ }, error, context).then(function () {
256
+ return null;
257
+ });
258
+ });
259
+ };
260
+
261
+ exports.getIOSSubscription = getIOSSubscription;
262
+
263
+ var addIOSInApp = function addIOSInApp(context, subscription) {
264
+ var action = 'addIOSInApp';
265
+ var database = context.database,
266
+ sessionId = context.userId;
267
+ var now = Date.now();
268
+ var _subscription$added = subscription.added,
269
+ added = _subscription$added === void 0 ? now : _subscription$added,
270
+ planId = subscription.planId,
271
+ receipt = subscription.receipt,
272
+ transactionId = subscription.transactionId,
273
+ trialEnd = subscription.trialEnd;
274
+ var subscriptionId = (0, _utils.createHash)("subscription-".concat(transactionId));
275
+ var insert = {
276
+ _key: subscriptionId,
277
+ added: added,
278
+ modified: now,
279
+ planId: planId,
280
+ receipt: receipt,
281
+ transactionId: transactionId,
282
+ trialEnd: trialEnd,
283
+ type: 'ios_subscription',
284
+ userId: sessionId
285
+ };
286
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), insert);
287
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
288
+ return cursor.next();
289
+ }).then(function () {
290
+ var updatedSubscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
291
+ return updatedSubscription;
292
+ })["catch"](function (error) {
293
+ return (0, _utils2.logError)({
294
+ action: action,
295
+ category: eventCategory,
296
+ label: 'db_error'
297
+ }, error, context).then(function () {
298
+ return null;
299
+ });
300
+ });
301
+ };
302
+
303
+ exports.addIOSInApp = addIOSInApp;
304
+
305
+ var getIOSInApp = function getIOSInApp(context) {
306
+ var action = 'getIOSInApp';
307
+ var database = context.database,
308
+ sessionId = context.userId;
309
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), sessionId);
310
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
311
+ return cursor.next();
312
+ }).then(function () {
313
+ var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
314
+ return subscription;
315
+ })["catch"](function (error) {
316
+ return (0, _utils2.logError)({
317
+ action: action,
318
+ category: eventCategory,
319
+ label: 'db_error'
320
+ }, error, context).then(function () {
321
+ return null;
322
+ });
323
+ });
324
+ };
325
+
326
+ exports.getIOSInApp = getIOSInApp;
327
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/ios.ts"],"names":["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","aql","query","then","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 = (\n  database: string,\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 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"]}