@nlabs/reaktor 0.1.6 → 0.1.7
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.
- package/lib/config.js +20 -11
- package/lib/data/conversations.js +69 -39
- package/lib/data/dynamodb.js +60 -27
- package/lib/data/email.js +50 -19
- package/lib/data/files.js +103 -46
- package/lib/data/groups.js +114 -67
- package/lib/data/images.js +168 -100
- package/lib/data/index.js +234 -24
- package/lib/data/ios.js +48 -23
- package/lib/data/locations.js +45 -29
- package/lib/data/messages.d.ts +2 -2
- package/lib/data/messages.js +105 -72
- package/lib/data/notifications.js +31 -14
- package/lib/data/payments.js +164 -114
- package/lib/data/posts.js +144 -87
- package/lib/data/reactions.js +58 -33
- package/lib/data/s3.js +54 -24
- package/lib/data/search.js +32 -19
- package/lib/data/sms.js +35 -15
- package/lib/data/subscription.js +78 -51
- package/lib/data/tags.js +90 -51
- package/lib/data/users.js +118 -70
- package/lib/index.js +42 -8
- package/lib/types/apps.js +1 -1
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.js +1 -1
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.js +1 -1
- package/lib/types/files.js +1 -1
- package/lib/types/google.js +1 -1
- package/lib/types/groups.js +1 -1
- package/lib/types/images.js +1 -1
- package/lib/types/index.js +210 -22
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +12 -7
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.js +1 -1
- package/lib/types/reactions.js +1 -1
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +0 -1
- package/lib/types/users.js +1 -1
- package/lib/utils/analytics.js +23 -11
- package/lib/utils/arangodb.js +48 -19
- package/lib/utils/auth.js +31 -15
- package/lib/utils/graphql.js +16 -4
- package/lib/utils/index.js +78 -11
- package/lib/utils/objects.js +30 -10
- package/lib/utils/redis.js +21 -8
- package/package.json +5 -5
- package/index.d.ts +0 -1
package/lib/data/index.js
CHANGED
|
@@ -1,24 +1,234 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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==
|
package/lib/data/ios.js
CHANGED
|
@@ -1,3 +1,16 @@
|
|
|
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
|
+
|
|
1
14
|
function _templateObject4() {
|
|
2
15
|
var data = _taggedTemplateLiteral(["FOR s IN subscription\n FILTER s.userId == ", " && s.type == \"ios\"\n LIMIT 1\n RETURN s"]);
|
|
3
16
|
|
|
@@ -44,11 +57,9 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
|
|
|
44
57
|
|
|
45
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; }
|
|
46
59
|
|
|
47
|
-
import { createHash } from '@nlabs/utils';
|
|
48
|
-
import { aql } from 'arangojs';
|
|
49
|
-
import { logError, useDb } from '../utils';
|
|
50
60
|
var eventCategory = 'ios';
|
|
51
|
-
|
|
61
|
+
|
|
62
|
+
var getIOSInAppError = function getIOSInAppError(statusCode) {
|
|
52
63
|
var _codes;
|
|
53
64
|
|
|
54
65
|
var codes = (_codes = {}, _defineProperty(_codes, 0, {
|
|
@@ -99,7 +110,10 @@ export var getIOSInAppError = function getIOSInAppError(statusCode) {
|
|
|
99
110
|
}), _codes);
|
|
100
111
|
return codes[statusCode] || {};
|
|
101
112
|
};
|
|
102
|
-
|
|
113
|
+
|
|
114
|
+
exports.getIOSInAppError = getIOSInAppError;
|
|
115
|
+
|
|
116
|
+
var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subscriptionUpdate) {
|
|
103
117
|
var action = 'iOSSubscriptionUpdate';
|
|
104
118
|
var planId = subscriptionUpdate.auto_renew_adam_id,
|
|
105
119
|
cancelDate = subscriptionUpdate.cancellation_date,
|
|
@@ -112,7 +126,7 @@ export var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subs
|
|
|
112
126
|
var formatStatus = (status || '').toLowerCase();
|
|
113
127
|
var now = Date.now();
|
|
114
128
|
var receiptInfo = latestInfo || expiredInfo;
|
|
115
|
-
var id = createHash("payment-".concat(transactionId));
|
|
129
|
+
var id = (0, _utils.createHash)("payment-".concat(transactionId));
|
|
116
130
|
var update = {
|
|
117
131
|
cancelDate: cancelDate,
|
|
118
132
|
isValid: receiptInfo[0].expires_date_ms > now,
|
|
@@ -128,11 +142,11 @@ export var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subs
|
|
|
128
142
|
type: 'ios_payment'
|
|
129
143
|
});
|
|
130
144
|
|
|
131
|
-
var aqlQry = aql(_templateObject(), transactionId, insert, update);
|
|
132
|
-
return useDb(database).query(aqlQry).then(function () {
|
|
145
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), transactionId, insert, update);
|
|
146
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function () {
|
|
133
147
|
return null;
|
|
134
148
|
}).catch(function (dbError) {
|
|
135
|
-
return logError({
|
|
149
|
+
return (0, _utils2.logError)({
|
|
136
150
|
action: action,
|
|
137
151
|
category: eventCategory,
|
|
138
152
|
label: 'db_error'
|
|
@@ -220,18 +234,21 @@ export var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subs
|
|
|
220
234
|
// });
|
|
221
235
|
// };
|
|
222
236
|
|
|
223
|
-
|
|
237
|
+
|
|
238
|
+
exports.iOSSubscriptionUpdate = iOSSubscriptionUpdate;
|
|
239
|
+
|
|
240
|
+
var getIOSSubscription = function getIOSSubscription(context) {
|
|
224
241
|
var action = 'getIOSSubscription';
|
|
225
242
|
var database = context.database,
|
|
226
243
|
sessionId = context.userId;
|
|
227
|
-
var aqlQry = aql(_templateObject2(), sessionId);
|
|
228
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
244
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionId);
|
|
245
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
229
246
|
return cursor.next();
|
|
230
247
|
}).then(function () {
|
|
231
248
|
var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
232
249
|
return subscription;
|
|
233
250
|
}).catch(function (error) {
|
|
234
|
-
return logError({
|
|
251
|
+
return (0, _utils2.logError)({
|
|
235
252
|
action: action,
|
|
236
253
|
category: eventCategory,
|
|
237
254
|
label: 'db_error'
|
|
@@ -240,7 +257,10 @@ export var getIOSSubscription = function getIOSSubscription(context) {
|
|
|
240
257
|
});
|
|
241
258
|
});
|
|
242
259
|
};
|
|
243
|
-
|
|
260
|
+
|
|
261
|
+
exports.getIOSSubscription = getIOSSubscription;
|
|
262
|
+
|
|
263
|
+
var addIOSInApp = function addIOSInApp(context, subscription) {
|
|
244
264
|
var action = 'addIOSInApp';
|
|
245
265
|
var database = context.database,
|
|
246
266
|
sessionId = context.userId;
|
|
@@ -251,7 +271,7 @@ export var addIOSInApp = function addIOSInApp(context, subscription) {
|
|
|
251
271
|
receipt = subscription.receipt,
|
|
252
272
|
transactionId = subscription.transactionId,
|
|
253
273
|
trialEnd = subscription.trialEnd;
|
|
254
|
-
var subscriptionId = createHash("subscription-".concat(transactionId));
|
|
274
|
+
var subscriptionId = (0, _utils.createHash)("subscription-".concat(transactionId));
|
|
255
275
|
var insert = {
|
|
256
276
|
_key: subscriptionId,
|
|
257
277
|
added: added,
|
|
@@ -263,14 +283,14 @@ export var addIOSInApp = function addIOSInApp(context, subscription) {
|
|
|
263
283
|
type: 'ios_subscription',
|
|
264
284
|
userId: sessionId
|
|
265
285
|
};
|
|
266
|
-
var aqlQry = aql(_templateObject3(), insert);
|
|
267
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
286
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), insert);
|
|
287
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
268
288
|
return cursor.next();
|
|
269
289
|
}).then(function () {
|
|
270
290
|
var updatedSubscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
271
291
|
return updatedSubscription;
|
|
272
292
|
}).catch(function (error) {
|
|
273
|
-
return logError({
|
|
293
|
+
return (0, _utils2.logError)({
|
|
274
294
|
action: action,
|
|
275
295
|
category: eventCategory,
|
|
276
296
|
label: 'db_error'
|
|
@@ -279,18 +299,21 @@ export var addIOSInApp = function addIOSInApp(context, subscription) {
|
|
|
279
299
|
});
|
|
280
300
|
});
|
|
281
301
|
};
|
|
282
|
-
|
|
302
|
+
|
|
303
|
+
exports.addIOSInApp = addIOSInApp;
|
|
304
|
+
|
|
305
|
+
var getIOSInApp = function getIOSInApp(context) {
|
|
283
306
|
var action = 'getIOSInApp';
|
|
284
307
|
var database = context.database,
|
|
285
308
|
sessionId = context.userId;
|
|
286
|
-
var aqlQry = aql(_templateObject4(), sessionId);
|
|
287
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
309
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), sessionId);
|
|
310
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
288
311
|
return cursor.next();
|
|
289
312
|
}).then(function () {
|
|
290
313
|
var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
291
314
|
return subscription;
|
|
292
315
|
}).catch(function (error) {
|
|
293
|
-
return logError({
|
|
316
|
+
return (0, _utils2.logError)({
|
|
294
317
|
action: action,
|
|
295
318
|
category: eventCategory,
|
|
296
319
|
label: 'db_error'
|
|
@@ -299,4 +322,6 @@ export var getIOSInApp = function getIOSInApp(context) {
|
|
|
299
322
|
});
|
|
300
323
|
});
|
|
301
324
|
};
|
|
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 = (\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"]}
|
|
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","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 = (\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"]}
|