@nlabs/reaktor 0.2.3 → 0.4.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.
- package/lib/config.js +12 -4
- package/lib/data/conversations.d.ts +3 -1
- package/lib/data/conversations.js +150 -65
- package/lib/data/dynamodb.d.ts +8 -8
- package/lib/data/dynamodb.js +65 -33
- package/lib/data/email.d.ts +2 -2
- package/lib/data/email.js +52 -24
- package/lib/data/files.js +71 -11
- package/lib/data/groups.js +37 -3
- package/lib/data/images.d.ts +3 -2
- package/lib/data/images.js +425 -273
- package/lib/data/index.d.ts +1 -0
- package/lib/data/index.js +33 -1
- package/lib/data/ios.d.ts +5 -5
- package/lib/data/ios.js +47 -21
- package/lib/data/locations.js +28 -4
- package/lib/data/messages.js +89 -73
- package/lib/data/notifications.d.ts +2 -2
- package/lib/data/notifications.js +6 -6
- package/lib/data/payments.d.ts +3 -4
- package/lib/data/payments.js +228 -257
- package/lib/data/posts.d.ts +1 -1
- package/lib/data/posts.js +88 -12
- package/lib/data/reactions.d.ts +1 -1
- package/lib/data/reactions.js +56 -14
- package/lib/data/s3.d.ts +6 -6
- package/lib/data/s3.js +10 -2
- package/lib/data/search.js +46 -4
- package/lib/data/sms.js +5 -1
- package/lib/data/subscription.d.ts +1 -1
- package/lib/data/subscription.js +46 -20
- package/lib/data/tags.js +60 -8
- package/lib/data/users.d.ts +7 -4
- package/lib/data/users.js +83 -32
- package/lib/data/websockets.d.ts +6 -0
- package/lib/data/websockets.js +250 -0
- package/lib/index.js +4 -1
- package/lib/types/conversations.d.ts +2 -0
- package/lib/types/index.js +18 -1
- package/lib/types/payments.d.ts +1 -0
- package/lib/types/posts.d.ts +2 -0
- package/lib/types/reactions.d.ts +2 -0
- package/lib/types/users.d.ts +1 -0
- package/lib/utils/analytics.js +28 -6
- package/lib/utils/arangodb.d.ts +2 -1
- package/lib/utils/arangodb.js +31 -10
- package/lib/utils/auth.js +21 -3
- package/lib/utils/graphql.js +3 -1
- package/lib/utils/index.js +7 -1
- package/lib/utils/objects.js +9 -1
- package/lib/utils/redis.js +6 -2
- package/package.json +33 -31
package/lib/data/index.d.ts
CHANGED
package/lib/data/index.js
CHANGED
|
@@ -8,6 +8,7 @@ var _conversations = require("./conversations");
|
|
|
8
8
|
|
|
9
9
|
Object.keys(_conversations).forEach(function (key) {
|
|
10
10
|
if (key === "default" || key === "__esModule") return;
|
|
11
|
+
if (key in exports && exports[key] === _conversations[key]) return;
|
|
11
12
|
Object.defineProperty(exports, key, {
|
|
12
13
|
enumerable: true,
|
|
13
14
|
get: function get() {
|
|
@@ -20,6 +21,7 @@ var _dynamodb = require("./dynamodb");
|
|
|
20
21
|
|
|
21
22
|
Object.keys(_dynamodb).forEach(function (key) {
|
|
22
23
|
if (key === "default" || key === "__esModule") return;
|
|
24
|
+
if (key in exports && exports[key] === _dynamodb[key]) return;
|
|
23
25
|
Object.defineProperty(exports, key, {
|
|
24
26
|
enumerable: true,
|
|
25
27
|
get: function get() {
|
|
@@ -32,6 +34,7 @@ var _email = require("./email");
|
|
|
32
34
|
|
|
33
35
|
Object.keys(_email).forEach(function (key) {
|
|
34
36
|
if (key === "default" || key === "__esModule") return;
|
|
37
|
+
if (key in exports && exports[key] === _email[key]) return;
|
|
35
38
|
Object.defineProperty(exports, key, {
|
|
36
39
|
enumerable: true,
|
|
37
40
|
get: function get() {
|
|
@@ -44,6 +47,7 @@ var _files = require("./files");
|
|
|
44
47
|
|
|
45
48
|
Object.keys(_files).forEach(function (key) {
|
|
46
49
|
if (key === "default" || key === "__esModule") return;
|
|
50
|
+
if (key in exports && exports[key] === _files[key]) return;
|
|
47
51
|
Object.defineProperty(exports, key, {
|
|
48
52
|
enumerable: true,
|
|
49
53
|
get: function get() {
|
|
@@ -56,6 +60,7 @@ var _groups = require("./groups");
|
|
|
56
60
|
|
|
57
61
|
Object.keys(_groups).forEach(function (key) {
|
|
58
62
|
if (key === "default" || key === "__esModule") return;
|
|
63
|
+
if (key in exports && exports[key] === _groups[key]) return;
|
|
59
64
|
Object.defineProperty(exports, key, {
|
|
60
65
|
enumerable: true,
|
|
61
66
|
get: function get() {
|
|
@@ -68,6 +73,7 @@ var _images = require("./images");
|
|
|
68
73
|
|
|
69
74
|
Object.keys(_images).forEach(function (key) {
|
|
70
75
|
if (key === "default" || key === "__esModule") return;
|
|
76
|
+
if (key in exports && exports[key] === _images[key]) return;
|
|
71
77
|
Object.defineProperty(exports, key, {
|
|
72
78
|
enumerable: true,
|
|
73
79
|
get: function get() {
|
|
@@ -80,6 +86,7 @@ var _ios = require("./ios");
|
|
|
80
86
|
|
|
81
87
|
Object.keys(_ios).forEach(function (key) {
|
|
82
88
|
if (key === "default" || key === "__esModule") return;
|
|
89
|
+
if (key in exports && exports[key] === _ios[key]) return;
|
|
83
90
|
Object.defineProperty(exports, key, {
|
|
84
91
|
enumerable: true,
|
|
85
92
|
get: function get() {
|
|
@@ -92,6 +99,7 @@ var _locations = require("./locations");
|
|
|
92
99
|
|
|
93
100
|
Object.keys(_locations).forEach(function (key) {
|
|
94
101
|
if (key === "default" || key === "__esModule") return;
|
|
102
|
+
if (key in exports && exports[key] === _locations[key]) return;
|
|
95
103
|
Object.defineProperty(exports, key, {
|
|
96
104
|
enumerable: true,
|
|
97
105
|
get: function get() {
|
|
@@ -104,6 +112,7 @@ var _messages = require("./messages");
|
|
|
104
112
|
|
|
105
113
|
Object.keys(_messages).forEach(function (key) {
|
|
106
114
|
if (key === "default" || key === "__esModule") return;
|
|
115
|
+
if (key in exports && exports[key] === _messages[key]) return;
|
|
107
116
|
Object.defineProperty(exports, key, {
|
|
108
117
|
enumerable: true,
|
|
109
118
|
get: function get() {
|
|
@@ -116,6 +125,7 @@ var _notifications = require("./notifications");
|
|
|
116
125
|
|
|
117
126
|
Object.keys(_notifications).forEach(function (key) {
|
|
118
127
|
if (key === "default" || key === "__esModule") return;
|
|
128
|
+
if (key in exports && exports[key] === _notifications[key]) return;
|
|
119
129
|
Object.defineProperty(exports, key, {
|
|
120
130
|
enumerable: true,
|
|
121
131
|
get: function get() {
|
|
@@ -128,6 +138,7 @@ var _payments = require("./payments");
|
|
|
128
138
|
|
|
129
139
|
Object.keys(_payments).forEach(function (key) {
|
|
130
140
|
if (key === "default" || key === "__esModule") return;
|
|
141
|
+
if (key in exports && exports[key] === _payments[key]) return;
|
|
131
142
|
Object.defineProperty(exports, key, {
|
|
132
143
|
enumerable: true,
|
|
133
144
|
get: function get() {
|
|
@@ -140,6 +151,7 @@ var _posts = require("./posts");
|
|
|
140
151
|
|
|
141
152
|
Object.keys(_posts).forEach(function (key) {
|
|
142
153
|
if (key === "default" || key === "__esModule") return;
|
|
154
|
+
if (key in exports && exports[key] === _posts[key]) return;
|
|
143
155
|
Object.defineProperty(exports, key, {
|
|
144
156
|
enumerable: true,
|
|
145
157
|
get: function get() {
|
|
@@ -152,6 +164,7 @@ var _reactions = require("./reactions");
|
|
|
152
164
|
|
|
153
165
|
Object.keys(_reactions).forEach(function (key) {
|
|
154
166
|
if (key === "default" || key === "__esModule") return;
|
|
167
|
+
if (key in exports && exports[key] === _reactions[key]) return;
|
|
155
168
|
Object.defineProperty(exports, key, {
|
|
156
169
|
enumerable: true,
|
|
157
170
|
get: function get() {
|
|
@@ -164,6 +177,7 @@ var _s = require("./s3");
|
|
|
164
177
|
|
|
165
178
|
Object.keys(_s).forEach(function (key) {
|
|
166
179
|
if (key === "default" || key === "__esModule") return;
|
|
180
|
+
if (key in exports && exports[key] === _s[key]) return;
|
|
167
181
|
Object.defineProperty(exports, key, {
|
|
168
182
|
enumerable: true,
|
|
169
183
|
get: function get() {
|
|
@@ -176,6 +190,7 @@ var _search = require("./search");
|
|
|
176
190
|
|
|
177
191
|
Object.keys(_search).forEach(function (key) {
|
|
178
192
|
if (key === "default" || key === "__esModule") return;
|
|
193
|
+
if (key in exports && exports[key] === _search[key]) return;
|
|
179
194
|
Object.defineProperty(exports, key, {
|
|
180
195
|
enumerable: true,
|
|
181
196
|
get: function get() {
|
|
@@ -188,6 +203,7 @@ var _sms = require("./sms");
|
|
|
188
203
|
|
|
189
204
|
Object.keys(_sms).forEach(function (key) {
|
|
190
205
|
if (key === "default" || key === "__esModule") return;
|
|
206
|
+
if (key in exports && exports[key] === _sms[key]) return;
|
|
191
207
|
Object.defineProperty(exports, key, {
|
|
192
208
|
enumerable: true,
|
|
193
209
|
get: function get() {
|
|
@@ -200,6 +216,7 @@ var _subscription = require("./subscription");
|
|
|
200
216
|
|
|
201
217
|
Object.keys(_subscription).forEach(function (key) {
|
|
202
218
|
if (key === "default" || key === "__esModule") return;
|
|
219
|
+
if (key in exports && exports[key] === _subscription[key]) return;
|
|
203
220
|
Object.defineProperty(exports, key, {
|
|
204
221
|
enumerable: true,
|
|
205
222
|
get: function get() {
|
|
@@ -212,6 +229,7 @@ var _tags = require("./tags");
|
|
|
212
229
|
|
|
213
230
|
Object.keys(_tags).forEach(function (key) {
|
|
214
231
|
if (key === "default" || key === "__esModule") return;
|
|
232
|
+
if (key in exports && exports[key] === _tags[key]) return;
|
|
215
233
|
Object.defineProperty(exports, key, {
|
|
216
234
|
enumerable: true,
|
|
217
235
|
get: function get() {
|
|
@@ -224,6 +242,7 @@ var _users = require("./users");
|
|
|
224
242
|
|
|
225
243
|
Object.keys(_users).forEach(function (key) {
|
|
226
244
|
if (key === "default" || key === "__esModule") return;
|
|
245
|
+
if (key in exports && exports[key] === _users[key]) return;
|
|
227
246
|
Object.defineProperty(exports, key, {
|
|
228
247
|
enumerable: true,
|
|
229
248
|
get: function get() {
|
|
@@ -231,4 +250,17 @@ Object.keys(_users).forEach(function (key) {
|
|
|
231
250
|
}
|
|
232
251
|
});
|
|
233
252
|
});
|
|
234
|
-
|
|
253
|
+
|
|
254
|
+
var _websockets = require("./websockets");
|
|
255
|
+
|
|
256
|
+
Object.keys(_websockets).forEach(function (key) {
|
|
257
|
+
if (key === "default" || key === "__esModule") return;
|
|
258
|
+
if (key in exports && exports[key] === _websockets[key]) return;
|
|
259
|
+
Object.defineProperty(exports, key, {
|
|
260
|
+
enumerable: true,
|
|
261
|
+
get: function get() {
|
|
262
|
+
return _websockets[key];
|
|
263
|
+
}
|
|
264
|
+
});
|
|
265
|
+
});
|
|
266
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUlBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBOztBQUNBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vY29udmVyc2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2R5bmFtb2RiJztcbmV4cG9ydCAqIGZyb20gJy4vZW1haWwnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlcyc7XG5leHBvcnQgKiBmcm9tICcuL2dyb3Vwcyc7XG5leHBvcnQgKiBmcm9tICcuL2ltYWdlcyc7XG5leHBvcnQgKiBmcm9tICcuL2lvcyc7XG5leHBvcnQgKiBmcm9tICcuL2xvY2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL21lc3NhZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vbm90aWZpY2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3BheW1lbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vcG9zdHMnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWFjdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zMyc7XG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaCc7XG5leHBvcnQgKiBmcm9tICcuL3Ntcyc7XG5leHBvcnQgKiBmcm9tICcuL3N1YnNjcmlwdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3RhZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi91c2Vycyc7XG5leHBvcnQgKiBmcm9tICcuL3dlYnNvY2tldHMnO1xuIl19
|
package/lib/data/ios.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ApiContext, PaymentIOSInAppError, PaymentIOSSubscriptionUpdate, PaymentSubscription } from '../types';
|
|
2
|
-
export declare const
|
|
3
|
-
export declare const
|
|
4
|
-
export declare const
|
|
5
|
-
export declare const
|
|
6
|
-
export declare const
|
|
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>;
|
package/lib/data/ios.js
CHANGED
|
@@ -1,9 +1,35 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
require("core-js/modules/es.symbol");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.array.filter");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.array.for-each");
|
|
8
|
+
|
|
9
|
+
require("core-js/modules/es.array.slice");
|
|
10
|
+
|
|
11
|
+
require("core-js/modules/es.date.now");
|
|
12
|
+
|
|
13
|
+
require("core-js/modules/es.date.to-string");
|
|
14
|
+
|
|
15
|
+
require("core-js/modules/es.object.define-properties");
|
|
16
|
+
|
|
17
|
+
require("core-js/modules/es.object.define-property");
|
|
18
|
+
|
|
19
|
+
require("core-js/modules/es.object.freeze");
|
|
20
|
+
|
|
21
|
+
require("core-js/modules/es.object.get-own-property-descriptor");
|
|
22
|
+
|
|
23
|
+
require("core-js/modules/es.object.get-own-property-descriptors");
|
|
24
|
+
|
|
25
|
+
require("core-js/modules/es.object.keys");
|
|
26
|
+
|
|
27
|
+
require("core-js/modules/web.dom-collections.for-each");
|
|
28
|
+
|
|
3
29
|
Object.defineProperty(exports, "__esModule", {
|
|
4
30
|
value: true
|
|
5
31
|
});
|
|
6
|
-
exports.
|
|
32
|
+
exports.getIosInApp = exports.addIosInApp = exports.getIosSubscription = exports.iosSubscriptionUpdate = exports.getIosInAppError = void 0;
|
|
7
33
|
|
|
8
34
|
var _utils = require("@nlabs/utils");
|
|
9
35
|
|
|
@@ -55,13 +81,13 @@ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(
|
|
|
55
81
|
|
|
56
82
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
|
57
83
|
|
|
58
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
84
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
59
85
|
|
|
60
86
|
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; }
|
|
61
87
|
|
|
62
88
|
var eventCategory = 'ios';
|
|
63
89
|
|
|
64
|
-
var
|
|
90
|
+
var getIosInAppError = function getIosInAppError(statusCode) {
|
|
65
91
|
var _codes;
|
|
66
92
|
|
|
67
93
|
var codes = (_codes = {}, _defineProperty(_codes, 0, {
|
|
@@ -113,10 +139,10 @@ var getIOSInAppError = function getIOSInAppError(statusCode) {
|
|
|
113
139
|
return codes[statusCode] || {};
|
|
114
140
|
};
|
|
115
141
|
|
|
116
|
-
exports.
|
|
142
|
+
exports.getIosInAppError = getIosInAppError;
|
|
117
143
|
|
|
118
|
-
var
|
|
119
|
-
var action = '
|
|
144
|
+
var iosSubscriptionUpdate = function iosSubscriptionUpdate(database, subscriptionUpdate) {
|
|
145
|
+
var action = 'iosSubscriptionUpdate';
|
|
120
146
|
var planId = subscriptionUpdate.auto_renew_adam_id,
|
|
121
147
|
cancelDate = subscriptionUpdate.cancellation_date,
|
|
122
148
|
status = subscriptionUpdate.notification_type,
|
|
@@ -138,7 +164,7 @@ var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subscriptio
|
|
|
138
164
|
status: formatStatus
|
|
139
165
|
};
|
|
140
166
|
|
|
141
|
-
var insert = _objectSpread({}, update, {
|
|
167
|
+
var insert = _objectSpread(_objectSpread({}, update), {}, {
|
|
142
168
|
_key: id,
|
|
143
169
|
added: now,
|
|
144
170
|
type: 'ios_payment'
|
|
@@ -156,12 +182,12 @@ var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subscriptio
|
|
|
156
182
|
return null;
|
|
157
183
|
});
|
|
158
184
|
});
|
|
159
|
-
}; // export const
|
|
185
|
+
}; // export const addIosInApp = (
|
|
160
186
|
// context: ApiContext,
|
|
161
187
|
// app,
|
|
162
188
|
// subscription: PaymentSubscription
|
|
163
189
|
// ): Promise<PaymentSubscription> => {
|
|
164
|
-
// const action: string = '
|
|
190
|
+
// const action: string = 'addIosInApp';
|
|
165
191
|
// const {isProduction, receipt} = subscription;
|
|
166
192
|
// const {database, userId: sessionId} = context;
|
|
167
193
|
// const productionHost: string = 'buy.itunes.apple.com';
|
|
@@ -225,7 +251,7 @@ var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subscriptio
|
|
|
225
251
|
// }, dbError, context).then(() => null));
|
|
226
252
|
// }
|
|
227
253
|
// // Errors
|
|
228
|
-
// const error: PaymentIOSInAppError =
|
|
254
|
+
// const error: PaymentIOSInAppError = getIosInAppError(results.status);
|
|
229
255
|
// return logException({
|
|
230
256
|
// action,
|
|
231
257
|
// category: eventCategory,
|
|
@@ -237,10 +263,10 @@ var iOSSubscriptionUpdate = function iOSSubscriptionUpdate(database, subscriptio
|
|
|
237
263
|
// };
|
|
238
264
|
|
|
239
265
|
|
|
240
|
-
exports.
|
|
266
|
+
exports.iosSubscriptionUpdate = iosSubscriptionUpdate;
|
|
241
267
|
|
|
242
|
-
var
|
|
243
|
-
var action = '
|
|
268
|
+
var getIosSubscription = function getIosSubscription(context) {
|
|
269
|
+
var action = 'getIosSubscription';
|
|
244
270
|
var database = context.database,
|
|
245
271
|
sessionId = context.userId;
|
|
246
272
|
var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionId);
|
|
@@ -260,10 +286,10 @@ var getIOSSubscription = function getIOSSubscription(context) {
|
|
|
260
286
|
});
|
|
261
287
|
};
|
|
262
288
|
|
|
263
|
-
exports.
|
|
289
|
+
exports.getIosSubscription = getIosSubscription;
|
|
264
290
|
|
|
265
|
-
var
|
|
266
|
-
var action = '
|
|
291
|
+
var addIosInApp = function addIosInApp(context, subscription) {
|
|
292
|
+
var action = 'addIosInApp';
|
|
267
293
|
var database = context.database,
|
|
268
294
|
sessionId = context.userId;
|
|
269
295
|
var now = Date.now();
|
|
@@ -302,10 +328,10 @@ var addIOSInApp = function addIOSInApp(context, subscription) {
|
|
|
302
328
|
});
|
|
303
329
|
};
|
|
304
330
|
|
|
305
|
-
exports.
|
|
331
|
+
exports.addIosInApp = addIosInApp;
|
|
306
332
|
|
|
307
|
-
var
|
|
308
|
-
var action = '
|
|
333
|
+
var getIosInApp = function getIosInApp(context) {
|
|
334
|
+
var action = 'getIosInApp';
|
|
309
335
|
var database = context.database,
|
|
310
336
|
sessionId = context.userId;
|
|
311
337
|
var aqlQry = (0, _arangojs.aql)(_templateObject4(), sessionId);
|
|
@@ -325,5 +351,5 @@ var getIOSInApp = function getIOSInApp(context) {
|
|
|
325
351
|
});
|
|
326
352
|
};
|
|
327
353
|
|
|
328
|
-
exports.
|
|
329
|
-
//# 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"]}
|
|
354
|
+
exports.getIosInApp = getIosInApp;
|
|
355
|
+
//# 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/aql';\nimport {ArrayCursor} from 'arangojs/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"]}
|
package/lib/data/locations.js
CHANGED
|
@@ -1,5 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
require("core-js/modules/es.array.concat");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.array.filter");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.array.find");
|
|
8
|
+
|
|
9
|
+
require("core-js/modules/es.array.find-index");
|
|
10
|
+
|
|
11
|
+
require("core-js/modules/es.array.join");
|
|
12
|
+
|
|
13
|
+
require("core-js/modules/es.array.slice");
|
|
14
|
+
|
|
15
|
+
require("core-js/modules/es.date.now");
|
|
16
|
+
|
|
17
|
+
require("core-js/modules/es.date.to-string");
|
|
18
|
+
|
|
19
|
+
require("core-js/modules/es.object.define-properties");
|
|
20
|
+
|
|
21
|
+
require("core-js/modules/es.object.freeze");
|
|
22
|
+
|
|
3
23
|
Object.defineProperty(exports, "__esModule", {
|
|
4
24
|
value: true
|
|
5
25
|
});
|
|
@@ -115,14 +135,18 @@ var addLocation = function addLocation(context, location) {
|
|
|
115
135
|
|
|
116
136
|
|
|
117
137
|
if (itemDocId) {
|
|
118
|
-
var edgeCollection = (0, _utils2.useDb)(database).
|
|
138
|
+
var edgeCollection = (0, _utils2.useDb)(database).collection('hasLocation');
|
|
119
139
|
var locationId = updatedLocationKey;
|
|
120
140
|
var locationDocId = "locations/".concat(locationId);
|
|
121
141
|
var edgeId = (0, _utils.createHash)("hasLocation-".concat(locationId, "-").concat(sessionId));
|
|
122
142
|
var edge = {
|
|
123
|
-
|
|
143
|
+
_from: itemDocId,
|
|
144
|
+
_key: edgeId,
|
|
145
|
+
_to: locationDocId
|
|
124
146
|
};
|
|
125
|
-
return edgeCollection.save(edge,
|
|
147
|
+
return edgeCollection.save(edge, {
|
|
148
|
+
returnNew: true
|
|
149
|
+
}).then(function () {
|
|
126
150
|
return updatedLocation;
|
|
127
151
|
});
|
|
128
152
|
} // Otherwise just return the new location
|
|
@@ -145,4 +169,4 @@ var addLocation = function addLocation(context, location) {
|
|
|
145
169
|
};
|
|
146
170
|
|
|
147
171
|
exports.addLocation = addLocation;
|
|
148
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/locations.ts"],"names":["eventCategory","addLocation","context","location","action","database","sessionId","userId","address","itemId","itemType","geocodeUrl","Config","get","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","aql","query","cursor","next","updatedLocation","itemDocId","updatedLocationKey","edgeCollection","locationId","locationDocId","edgeId","edge","save","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"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/locations.ts"],"names":["eventCategory","addLocation","context","location","action","database","sessionId","userId","address","itemId","itemType","geocodeUrl","Config","get","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","aql","query","cursor","next","updatedLocation","itemDocId","updatedLocationKey","edgeCollection","collection","locationId","locationDocId","edgeId","edge","_from","_to","save","returnNew","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/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport get from 'lodash/get';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {GoogleMapsAddressType} from '../types/google';\nimport {LocationType} from '../types/locations';\nimport {logError, 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: EdgeCollection = useDb(database).collection('hasLocation');\n              const locationId: string = updatedLocationKey;\n              const locationDocId: string = `locations/${locationId}`;\n              const edgeId = createHash(`hasLocation-${locationId}-${sessionId}`);\n              const edge: any = {_from: itemDocId, _key: edgeId, _to: locationDocId};\n\n              return edgeCollection.save(edge, {returnNew: true}).then(() => updatedLocation);\n            }\n\n            // Otherwise just return the new location\n            return updatedLocation;\n          })\n          .catch((error: Error) => logError({\n            action,\n            category: eventCategory,\n            label: 'db_error'\n          }, error, context).then(() => null));\n      }\n\n      return {};\n    });\n};\n"]}
|