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