@nlabs/reaktor 0.1.5 → 0.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/config.js +20 -11
- package/lib/data/conversations.js +69 -39
- package/lib/data/dynamodb.js +60 -27
- package/lib/data/email.js +50 -19
- package/lib/data/files.js +103 -46
- package/lib/data/groups.js +114 -67
- package/lib/data/images.js +169 -102
- package/lib/data/index.js +234 -24
- package/lib/data/ios.js +48 -23
- package/lib/data/locations.js +45 -29
- package/lib/data/messages.d.ts +2 -2
- package/lib/data/messages.js +105 -72
- package/lib/data/notifications.js +31 -14
- package/lib/data/payments.js +164 -114
- package/lib/data/posts.js +144 -87
- package/lib/data/reactions.js +58 -33
- package/lib/data/s3.js +54 -24
- package/lib/data/search.js +32 -19
- package/lib/data/sms.js +35 -15
- package/lib/data/subscription.js +78 -51
- package/lib/data/tags.js +90 -51
- package/lib/data/users.js +119 -72
- package/lib/index.js +42 -8
- package/lib/types/apps.js +1 -1
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.js +1 -1
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.js +1 -1
- package/lib/types/files.js +1 -1
- package/lib/types/google.js +1 -1
- package/lib/types/groups.js +1 -1
- package/lib/types/images.js +1 -1
- package/lib/types/index.js +210 -22
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +12 -7
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.js +1 -1
- package/lib/types/reactions.js +1 -1
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +0 -1
- package/lib/types/users.js +1 -1
- package/lib/utils/analytics.js +23 -11
- package/lib/utils/arangodb.js +48 -19
- package/lib/utils/auth.js +31 -15
- package/lib/utils/graphql.js +16 -4
- package/lib/utils/index.js +78 -11
- package/lib/utils/objects.js +30 -10
- package/lib/utils/redis.js +21 -8
- package/package.json +5 -5
- package/index.d.ts +0 -1
package/lib/data/sms.js
CHANGED
|
@@ -1,27 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.sendSmsTemplate = exports.sendSms = void 0;
|
|
7
|
+
|
|
8
|
+
var _utils = require("@nlabs/utils");
|
|
9
|
+
|
|
10
|
+
var _fs = _interopRequireDefault(require("fs"));
|
|
11
|
+
|
|
12
|
+
var _twilio = _interopRequireDefault(require("twilio"));
|
|
13
|
+
|
|
14
|
+
var _config = require("../config");
|
|
15
|
+
|
|
16
|
+
var _email = require("./email");
|
|
17
|
+
|
|
18
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
19
|
+
|
|
1
20
|
/**
|
|
2
21
|
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
3
22
|
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
4
23
|
*/
|
|
5
|
-
|
|
6
|
-
import fs from 'fs';
|
|
7
|
-
import twilioSdk from 'twilio';
|
|
8
|
-
import { Config } from '../config';
|
|
9
|
-
import { appTemplate } from './email'; // const eventCategory: string = 'sms';
|
|
24
|
+
// const eventCategory: string = 'sms';
|
|
10
25
|
// Twilio
|
|
11
|
-
|
|
12
|
-
export var sendSms = function sendSms(params) {
|
|
26
|
+
var sendSms = function sendSms(params) {
|
|
13
27
|
var _params$app = params.app,
|
|
14
28
|
app = _params$app === void 0 ? {} : _params$app,
|
|
15
29
|
content = params.content,
|
|
16
30
|
_params$user = params.user,
|
|
17
31
|
user = _params$user === void 0 ? {} : _params$user;
|
|
18
32
|
var country = user.country || 'US';
|
|
19
|
-
var phone = parsePhone(user.phone, country);
|
|
20
|
-
var templateContent = appTemplate(app, content);
|
|
21
|
-
var twilio =
|
|
33
|
+
var phone = (0, _utils.parsePhone)(user.phone, country);
|
|
34
|
+
var templateContent = (0, _email.appTemplate)(app, content);
|
|
35
|
+
var twilio = (0, _twilio.default)(_config.Config.get('twilio.sid'), _config.Config.get('twilio.token'));
|
|
22
36
|
var cfg = {
|
|
23
37
|
body: templateContent,
|
|
24
|
-
from: Config.get('twilio.number'),
|
|
38
|
+
from: _config.Config.get('twilio.number'),
|
|
25
39
|
to: phone
|
|
26
40
|
};
|
|
27
41
|
return new Promise(function (resolve, reject) {
|
|
@@ -34,14 +48,18 @@ export var sendSms = function sendSms(params) {
|
|
|
34
48
|
});
|
|
35
49
|
});
|
|
36
50
|
};
|
|
37
|
-
|
|
51
|
+
|
|
52
|
+
exports.sendSms = sendSms;
|
|
53
|
+
|
|
54
|
+
var sendSmsTemplate = function sendSmsTemplate(templateName, smsParams) {
|
|
38
55
|
var app = smsParams.app,
|
|
39
56
|
user = smsParams.user,
|
|
40
57
|
vars = smsParams.vars;
|
|
41
58
|
|
|
42
59
|
try {
|
|
43
|
-
var data =
|
|
44
|
-
|
|
60
|
+
var data = _fs.default.readFileSync("./templates/sms/".concat(templateName, ".txt"), 'utf8');
|
|
61
|
+
|
|
62
|
+
var text = (0, _email.appTemplate)(app, data, vars);
|
|
45
63
|
var params = {
|
|
46
64
|
app: app,
|
|
47
65
|
text: text,
|
|
@@ -56,4 +74,6 @@ export var sendSmsTemplate = function sendSmsTemplate(templateName, smsParams) {
|
|
|
56
74
|
return Promise.reject(error);
|
|
57
75
|
}
|
|
58
76
|
};
|
|
59
|
-
|
|
77
|
+
|
|
78
|
+
exports.sendSmsTemplate = sendSmsTemplate;
|
|
79
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL3Ntcy50cyJdLCJuYW1lcyI6WyJzZW5kU21zIiwicGFyYW1zIiwiYXBwIiwiY29udGVudCIsInVzZXIiLCJjb3VudHJ5IiwicGhvbmUiLCJ0ZW1wbGF0ZUNvbnRlbnQiLCJ0d2lsaW8iLCJDb25maWciLCJnZXQiLCJjZmciLCJib2R5IiwiZnJvbSIsInRvIiwiUHJvbWlzZSIsInJlc29sdmUiLCJyZWplY3QiLCJzZW5kTWVzc2FnZSIsImVycm9yIiwiZGF0YSIsIkVycm9yIiwiZXJyb3JfbWVzc2FnZSIsInNlbmRTbXNUZW1wbGF0ZSIsInRlbXBsYXRlTmFtZSIsInNtc1BhcmFtcyIsInZhcnMiLCJmcyIsInJlYWRGaWxlU3luYyIsInRleHQiLCJ0aGVuIiwicmVzIiwic3RhdHVzIiwiY2F0Y2giXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQTs7QUFDQTs7QUFDQTs7QUFFQTs7QUFFQTs7OztBQVZBOzs7O0FBWUE7QUFFQTtBQUNPLElBQU1BLE9BQU8sR0FBRyxTQUFWQSxPQUFVLENBQUNDLE1BQUQsRUFBZ0M7QUFBQSxvQkFLakRBLE1BTGlELENBRW5EQyxHQUZtRDtBQUFBLE1BRW5EQSxHQUZtRCw0QkFFN0MsRUFGNkM7QUFBQSxNQUduREMsT0FIbUQsR0FLakRGLE1BTGlELENBR25ERSxPQUhtRDtBQUFBLHFCQUtqREYsTUFMaUQsQ0FJbkRHLElBSm1EO0FBQUEsTUFJbkRBLElBSm1ELDZCQUk1QyxFQUo0QztBQU9yRCxNQUFNQyxPQUFPLEdBQUdELElBQUksQ0FBQ0MsT0FBTCxJQUFnQixJQUFoQztBQUNBLE1BQU1DLEtBQUssR0FBRyx1QkFBV0YsSUFBSSxDQUFDRSxLQUFoQixFQUF1QkQsT0FBdkIsQ0FBZDtBQUNBLE1BQU1FLGVBQXVCLEdBQUcsd0JBQVlMLEdBQVosRUFBaUJDLE9BQWpCLENBQWhDO0FBRUEsTUFBTUssTUFBVyxHQUFHLHFCQUFVQyxlQUFPQyxHQUFQLENBQVcsWUFBWCxDQUFWLEVBQW9DRCxlQUFPQyxHQUFQLENBQVcsY0FBWCxDQUFwQyxDQUFwQjtBQUNBLE1BQU1DLEdBQXNCLEdBQUc7QUFDN0JDLElBQUFBLElBQUksRUFBRUwsZUFEdUI7QUFFN0JNLElBQUFBLElBQUksRUFBRUosZUFBT0MsR0FBUCxDQUFXLGVBQVgsQ0FGdUI7QUFHN0JJLElBQUFBLEVBQUUsRUFBRVI7QUFIeUIsR0FBL0I7QUFNQSxTQUFPLElBQUlTLE9BQUosQ0FBWSxVQUFDQyxPQUFELEVBQVVDLE1BQVYsRUFBcUI7QUFDdENULElBQUFBLE1BQU0sQ0FBQ1UsV0FBUCxDQUFtQlAsR0FBbkIsRUFBd0IsVUFBQ1EsS0FBRCxFQUFRQyxJQUFSLEVBQWlCO0FBQ3ZDLFVBQUdELEtBQUgsRUFBVTtBQUNSRixRQUFBQSxNQUFNLENBQUMsSUFBSUksS0FBSixDQUFVRixLQUFLLENBQUNHLGFBQWhCLENBQUQsQ0FBTjtBQUNELE9BRkQsTUFFTztBQUNMTixRQUFBQSxPQUFPLENBQUNJLElBQUQsQ0FBUDtBQUNEO0FBQ0YsS0FORDtBQU9ELEdBUk0sQ0FBUDtBQVNELENBM0JNOzs7O0FBNkJBLElBQU1HLGVBQWUsR0FBRyxTQUFsQkEsZUFBa0IsQ0FBQ0MsWUFBRCxFQUF1QkMsU0FBdkIsRUFBc0U7QUFBQSxNQUM1RnZCLEdBRDRGLEdBQ3pFdUIsU0FEeUUsQ0FDNUZ2QixHQUQ0RjtBQUFBLE1BQ3ZGRSxJQUR1RixHQUN6RXFCLFNBRHlFLENBQ3ZGckIsSUFEdUY7QUFBQSxNQUNqRnNCLElBRGlGLEdBQ3pFRCxTQUR5RSxDQUNqRkMsSUFEaUY7O0FBRW5HLE1BQUk7QUFDRixRQUFNTixJQUFJLEdBQUdPLFlBQUdDLFlBQUgsMkJBQW1DSixZQUFuQyxXQUF1RCxNQUF2RCxDQUFiOztBQUNBLFFBQU1LLElBQUksR0FBRyx3QkFBWTNCLEdBQVosRUFBaUJrQixJQUFqQixFQUF1Qk0sSUFBdkIsQ0FBYjtBQUNBLFFBQU16QixNQUFNLEdBQUc7QUFBQ0MsTUFBQUEsR0FBRyxFQUFIQSxHQUFEO0FBQU0yQixNQUFBQSxJQUFJLEVBQUpBLElBQU47QUFBWXpCLE1BQUFBLElBQUksRUFBSkE7QUFBWixLQUFmO0FBRUEsV0FBT0osT0FBTyxDQUFDQyxNQUFELENBQVAsQ0FDSjZCLElBREksQ0FDQyxVQUFDQyxHQUFEO0FBQUEsYUFBU0EsR0FBRyxDQUFDQyxNQUFKLEtBQWUsUUFBeEI7QUFBQSxLQURELEVBRUpDLEtBRkksQ0FFRSxVQUFDZCxLQUFELEVBQWtCO0FBQ3ZCLFlBQU1BLEtBQU47QUFDRCxLQUpJLENBQVA7QUFLRCxHQVZELENBVUUsT0FBTUEsS0FBTixFQUFhO0FBQ2IsV0FBT0osT0FBTyxDQUFDRSxNQUFSLENBQWVFLEtBQWYsQ0FBUDtBQUNEO0FBQ0YsQ0FmTSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge3BhcnNlUGhvbmV9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQgZnMgZnJvbSAnZnMnO1xuaW1wb3J0IHR3aWxpb1NkayBmcm9tICd0d2lsaW8nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7U01TUGFyYW1zVHlwZSwgVHdpbGlvT3B0aW9uc1R5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuaW1wb3J0IHthcHBUZW1wbGF0ZX0gZnJvbSAnLi9lbWFpbCc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzbXMnO1xuXG4vLyBUd2lsaW9cbmV4cG9ydCBjb25zdCBzZW5kU21zID0gKHBhcmFtczogU01TUGFyYW1zVHlwZSk6IGFueSA9PiB7XG4gIGNvbnN0IHtcbiAgICBhcHAgPSB7fSxcbiAgICBjb250ZW50LFxuICAgIHVzZXIgPSB7fVxuICB9ID0gcGFyYW1zO1xuXG4gIGNvbnN0IGNvdW50cnkgPSB1c2VyLmNvdW50cnkgfHwgJ1VTJztcbiAgY29uc3QgcGhvbmUgPSBwYXJzZVBob25lKHVzZXIucGhvbmUsIGNvdW50cnkpO1xuICBjb25zdCB0ZW1wbGF0ZUNvbnRlbnQ6IHN0cmluZyA9IGFwcFRlbXBsYXRlKGFwcCwgY29udGVudCk7XG5cbiAgY29uc3QgdHdpbGlvOiBhbnkgPSB0d2lsaW9TZGsoQ29uZmlnLmdldCgndHdpbGlvLnNpZCcpLCBDb25maWcuZ2V0KCd0d2lsaW8udG9rZW4nKSk7XG4gIGNvbnN0IGNmZzogVHdpbGlvT3B0aW9uc1R5cGUgPSB7XG4gICAgYm9keTogdGVtcGxhdGVDb250ZW50LFxuICAgIGZyb206IENvbmZpZy5nZXQoJ3R3aWxpby5udW1iZXInKSxcbiAgICB0bzogcGhvbmVcbiAgfTtcblxuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHR3aWxpby5zZW5kTWVzc2FnZShjZmcsIChlcnJvciwgZGF0YSkgPT4ge1xuICAgICAgaWYoZXJyb3IpIHtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihlcnJvci5lcnJvcl9tZXNzYWdlKSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXNvbHZlKGRhdGEpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn1cblxuZXhwb3J0IGNvbnN0IHNlbmRTbXNUZW1wbGF0ZSA9ICh0ZW1wbGF0ZU5hbWU6IHN0cmluZywgc21zUGFyYW1zOiBTTVNQYXJhbXNUeXBlKTogUHJvbWlzZTxib29sZWFuPiA9PiB7XG4gIGNvbnN0IHthcHAsIHVzZXIsIHZhcnN9ID0gc21zUGFyYW1zO1xuICB0cnkge1xuICAgIGNvbnN0IGRhdGEgPSBmcy5yZWFkRmlsZVN5bmMoYC4vdGVtcGxhdGVzL3Ntcy8ke3RlbXBsYXRlTmFtZX0udHh0YCwgJ3V0ZjgnKTtcbiAgICBjb25zdCB0ZXh0ID0gYXBwVGVtcGxhdGUoYXBwLCBkYXRhLCB2YXJzKTtcbiAgICBjb25zdCBwYXJhbXMgPSB7YXBwLCB0ZXh0LCB1c2VyfTtcblxuICAgIHJldHVybiBzZW5kU21zKHBhcmFtcylcbiAgICAgIC50aGVuKChyZXMpID0+IHJlcy5zdGF0dXMgPT09ICdxdWV1ZWQnKVxuICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9KTtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIHJldHVybiBQcm9taXNlLnJlamVjdChlcnJvcik7XG4gIH1cbn07XG4iXX0=
|
package/lib/data/subscription.js
CHANGED
|
@@ -1,3 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.deleteSubscription = exports.addSubscription = exports.addPlan = exports.getSubscription = exports.getPlanList = void 0;
|
|
7
|
+
|
|
8
|
+
var _utils = require("@nlabs/utils");
|
|
9
|
+
|
|
10
|
+
var _arangojs = require("arangojs");
|
|
11
|
+
|
|
12
|
+
var _luxon = require("luxon");
|
|
13
|
+
|
|
14
|
+
var stripe = _interopRequireWildcard(require("stripe"));
|
|
15
|
+
|
|
16
|
+
var _config = require("../config");
|
|
17
|
+
|
|
18
|
+
var _utils2 = require("../utils");
|
|
19
|
+
|
|
20
|
+
var _users = require("./users");
|
|
21
|
+
|
|
22
|
+
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
|
|
23
|
+
|
|
1
24
|
function _templateObject3() {
|
|
2
25
|
var data = _taggedTemplateLiteral(["UPDATE s WITH ", " IN subscriptions"]);
|
|
3
26
|
|
|
@@ -30,32 +53,22 @@ function _templateObject() {
|
|
|
30
53
|
|
|
31
54
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
32
55
|
|
|
33
|
-
/**
|
|
34
|
-
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
35
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
36
|
-
*/
|
|
37
|
-
import { createHash, parseChar, parseId, parseNum, parseVarChar } from '@nlabs/utils';
|
|
38
|
-
import { aql } from 'arangojs';
|
|
39
|
-
import { DateTime } from 'luxon';
|
|
40
|
-
import * as stripe from 'stripe';
|
|
41
|
-
import { Config } from '../config';
|
|
42
|
-
import { getLimit, logError, logException, useDb } from '../utils';
|
|
43
|
-
import { getUser } from './users';
|
|
44
56
|
var eventCategory = 'subscription';
|
|
45
|
-
|
|
57
|
+
|
|
58
|
+
var getPlanList = function getPlanList(context) {
|
|
46
59
|
var from = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
47
60
|
var to = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
|
|
48
61
|
var action = 'getList';
|
|
49
62
|
var database = context.database;
|
|
50
|
-
var limit = getLimit(from, to);
|
|
63
|
+
var limit = (0, _utils2.getLimit)(from, to);
|
|
51
64
|
var aqlQry = "FOR p IN plans\n ".concat(limit.aql, "\n SORT p.amount\n RETURN p");
|
|
52
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
65
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
53
66
|
return cursor.all();
|
|
54
67
|
}).then(function () {
|
|
55
68
|
var list = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
56
69
|
return list;
|
|
57
70
|
}).catch(function (error) {
|
|
58
|
-
return logError({
|
|
71
|
+
return (0, _utils2.logError)({
|
|
59
72
|
action: action,
|
|
60
73
|
category: eventCategory,
|
|
61
74
|
label: 'db_error'
|
|
@@ -66,18 +79,21 @@ export var getPlanList = function getPlanList(context) {
|
|
|
66
79
|
});
|
|
67
80
|
});
|
|
68
81
|
};
|
|
69
|
-
|
|
82
|
+
|
|
83
|
+
exports.getPlanList = getPlanList;
|
|
84
|
+
|
|
85
|
+
var getSubscription = function getSubscription(context) {
|
|
70
86
|
var action = 'getItem';
|
|
71
87
|
var database = context.database,
|
|
72
88
|
sessionId = context.userId;
|
|
73
89
|
var aqlQry = "FOR s IN subscriptions\n FILTER s.userId == ".concat(sessionId, " && s.cancelled > 0\n LET plan = FIRST(\n FOR p IN plans\n FILTER p._key == s.planId\n )\n LIMIT 1\n RETURN MERGE(s, {plan: plan})");
|
|
74
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
90
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
75
91
|
return cursor.next();
|
|
76
92
|
}).then(function () {
|
|
77
93
|
var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
78
94
|
return subscription;
|
|
79
95
|
}).catch(function (error) {
|
|
80
|
-
return logError({
|
|
96
|
+
return (0, _utils2.logError)({
|
|
81
97
|
action: action,
|
|
82
98
|
category: eventCategory,
|
|
83
99
|
label: 'db_error'
|
|
@@ -88,7 +104,10 @@ export var getSubscription = function getSubscription(context) {
|
|
|
88
104
|
});
|
|
89
105
|
});
|
|
90
106
|
};
|
|
91
|
-
|
|
107
|
+
|
|
108
|
+
exports.getSubscription = getSubscription;
|
|
109
|
+
|
|
110
|
+
var addPlan = function addPlan(context, item) {
|
|
92
111
|
var action = 'addPlan';
|
|
93
112
|
var database = context.database,
|
|
94
113
|
sessionId = context.userId,
|
|
@@ -96,7 +115,7 @@ export var addPlan = function addPlan(context, item) {
|
|
|
96
115
|
var isAdmin = userType > 2;
|
|
97
116
|
|
|
98
117
|
if (!isAdmin) {
|
|
99
|
-
return logException({
|
|
118
|
+
return (0, _utils2.logException)({
|
|
100
119
|
action: action,
|
|
101
120
|
category: eventCategory,
|
|
102
121
|
label: 'unauthorized',
|
|
@@ -107,8 +126,8 @@ export var addPlan = function addPlan(context, item) {
|
|
|
107
126
|
}
|
|
108
127
|
|
|
109
128
|
var now = Date.now();
|
|
110
|
-
var formatId = parseId(item.id);
|
|
111
|
-
var planId = formatId === '' ? createHash("tag-".concat(sessionId)) : formatId;
|
|
129
|
+
var formatId = (0, _utils.parseId)(item.id);
|
|
130
|
+
var planId = formatId === '' ? (0, _utils.createHash)("tag-".concat(sessionId)) : formatId;
|
|
112
131
|
var amount = item.amount,
|
|
113
132
|
_item$currency = item.currency,
|
|
114
133
|
currency = _item$currency === void 0 ? 'USD' : _item$currency,
|
|
@@ -116,11 +135,11 @@ export var addPlan = function addPlan(context, item) {
|
|
|
116
135
|
interval = item.interval,
|
|
117
136
|
intervalCount = item.intervalCount,
|
|
118
137
|
name = item.name;
|
|
119
|
-
var formatAmount = parseNum(amount);
|
|
120
|
-
var formatInterval = parseChar(interval, 5).toLowerCase();
|
|
121
|
-
var formatIntervalCnt = parseNum(intervalCount, 5);
|
|
122
|
-
var formatName = parseVarChar(name, 32);
|
|
123
|
-
var formatDesc = parseVarChar(description, 32);
|
|
138
|
+
var formatAmount = (0, _utils.parseNum)(amount);
|
|
139
|
+
var formatInterval = (0, _utils.parseChar)(interval, 5).toLowerCase();
|
|
140
|
+
var formatIntervalCnt = (0, _utils.parseNum)(intervalCount, 5);
|
|
141
|
+
var formatName = (0, _utils.parseVarChar)(name, 32);
|
|
142
|
+
var formatDesc = (0, _utils.parseVarChar)(description, 32);
|
|
124
143
|
var insert = {
|
|
125
144
|
_key: planId,
|
|
126
145
|
added: now,
|
|
@@ -132,13 +151,13 @@ export var addPlan = function addPlan(context, item) {
|
|
|
132
151
|
modified: now,
|
|
133
152
|
name: formatName
|
|
134
153
|
};
|
|
135
|
-
var aqlQry = aql(_templateObject(), insert);
|
|
136
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
154
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), insert);
|
|
155
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
137
156
|
return cursor.next();
|
|
138
157
|
}).then(function () {
|
|
139
158
|
var plan = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
140
159
|
// Stripe
|
|
141
|
-
var stripeClient = stripe(Config.get('stripe.token'));
|
|
160
|
+
var stripeClient = stripe(_config.Config.get('stripe.token'));
|
|
142
161
|
return stripeClient.plans.create({
|
|
143
162
|
amount: formatAmount * 100,
|
|
144
163
|
currency: currency,
|
|
@@ -152,7 +171,7 @@ export var addPlan = function addPlan(context, item) {
|
|
|
152
171
|
return plan;
|
|
153
172
|
});
|
|
154
173
|
}).catch(function (error) {
|
|
155
|
-
return logError({
|
|
174
|
+
return (0, _utils2.logError)({
|
|
156
175
|
action: action,
|
|
157
176
|
category: eventCategory,
|
|
158
177
|
label: 'db_error'
|
|
@@ -163,7 +182,10 @@ export var addPlan = function addPlan(context, item) {
|
|
|
163
182
|
});
|
|
164
183
|
});
|
|
165
184
|
};
|
|
166
|
-
|
|
185
|
+
|
|
186
|
+
exports.addPlan = addPlan;
|
|
187
|
+
|
|
188
|
+
var addSubscription = function addSubscription(context, item) {
|
|
167
189
|
var action = 'addSubscription';
|
|
168
190
|
var database = context.database,
|
|
169
191
|
sessionId = context.userId,
|
|
@@ -171,7 +193,7 @@ export var addSubscription = function addSubscription(context, item) {
|
|
|
171
193
|
var isAdmin = userType > 2;
|
|
172
194
|
|
|
173
195
|
if (!isAdmin) {
|
|
174
|
-
return logException({
|
|
196
|
+
return (0, _utils2.logException)({
|
|
175
197
|
action: action,
|
|
176
198
|
category: eventCategory,
|
|
177
199
|
label: 'unauthorized',
|
|
@@ -182,24 +204,24 @@ export var addSubscription = function addSubscription(context, item) {
|
|
|
182
204
|
}
|
|
183
205
|
|
|
184
206
|
var now = Date.now();
|
|
185
|
-
var formatId = parseId(item.id);
|
|
186
|
-
var subscriptionId = formatId === '' ? createHash("tag-".concat(sessionId)) : formatId;
|
|
207
|
+
var formatId = (0, _utils.parseId)(item.id);
|
|
208
|
+
var subscriptionId = formatId === '' ? (0, _utils.createHash)("tag-".concat(sessionId)) : formatId;
|
|
187
209
|
var planId = item.planId,
|
|
188
210
|
tax = item.tax,
|
|
189
211
|
trialEnd = item.trialEnd,
|
|
190
212
|
trialPeriod = item.trialPeriod;
|
|
191
|
-
var formatPlanId = parseId(planId);
|
|
192
|
-
var formatTaxPercent = parseNum(tax) || 0;
|
|
193
|
-
var formatTrialPeriod = parseNum(tax) || 0;
|
|
213
|
+
var formatPlanId = (0, _utils.parseId)(planId);
|
|
214
|
+
var formatTaxPercent = (0, _utils.parseNum)(tax) || 0;
|
|
215
|
+
var formatTrialPeriod = (0, _utils.parseNum)(tax) || 0;
|
|
194
216
|
var formatTrialEnd = trialEnd || Date.now();
|
|
195
217
|
|
|
196
218
|
if (formatTrialPeriod) {
|
|
197
|
-
formatTrialEnd = DateTime.local().plus({
|
|
219
|
+
formatTrialEnd = _luxon.DateTime.local().plus({
|
|
198
220
|
days: trialPeriod
|
|
199
221
|
}).toMillis();
|
|
200
222
|
}
|
|
201
223
|
|
|
202
|
-
return getUser(context, sessionId).then(function (user) {
|
|
224
|
+
return (0, _users.getUser)(context, sessionId).then(function (user) {
|
|
203
225
|
var insert = {
|
|
204
226
|
_key: subscriptionId,
|
|
205
227
|
added: now,
|
|
@@ -210,13 +232,13 @@ export var addSubscription = function addSubscription(context, item) {
|
|
|
210
232
|
trialEnd: formatTrialEnd,
|
|
211
233
|
userId: sessionId
|
|
212
234
|
};
|
|
213
|
-
var aqlQry = aql(_templateObject2(), insert);
|
|
214
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
235
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), insert);
|
|
236
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
215
237
|
return cursor.next();
|
|
216
238
|
}).then(function () {
|
|
217
239
|
var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
218
240
|
// Stripe
|
|
219
|
-
var stripeClient = stripe(Config.get('stripe.token'));
|
|
241
|
+
var stripeClient = stripe(_config.Config.get('stripe.token'));
|
|
220
242
|
return stripeClient.subscriptions.create({
|
|
221
243
|
customer: user.stripeCustomerId,
|
|
222
244
|
items: [{
|
|
@@ -231,7 +253,7 @@ export var addSubscription = function addSubscription(context, item) {
|
|
|
231
253
|
return subscription;
|
|
232
254
|
});
|
|
233
255
|
}).catch(function (error) {
|
|
234
|
-
return logError({
|
|
256
|
+
return (0, _utils2.logError)({
|
|
235
257
|
action: action,
|
|
236
258
|
category: eventCategory,
|
|
237
259
|
label: 'db_error'
|
|
@@ -243,14 +265,17 @@ export var addSubscription = function addSubscription(context, item) {
|
|
|
243
265
|
});
|
|
244
266
|
});
|
|
245
267
|
};
|
|
246
|
-
|
|
268
|
+
|
|
269
|
+
exports.addSubscription = addSubscription;
|
|
270
|
+
|
|
271
|
+
var deleteSubscription = function deleteSubscription(context, endDate) {
|
|
247
272
|
var action = 'deleteSubscription';
|
|
248
273
|
var database = context.database;
|
|
249
274
|
var now = Date.now();
|
|
250
|
-
var formatEndDate = parseNum(endDate) || now;
|
|
275
|
+
var formatEndDate = (0, _utils.parseNum)(endDate) || now;
|
|
251
276
|
return getSubscription(context).then(function (subscription) {
|
|
252
277
|
// Stripe
|
|
253
|
-
var stripeClient = stripe(Config.get('stripe.token'));
|
|
278
|
+
var stripeClient = stripe(_config.Config.get('stripe.token'));
|
|
254
279
|
return stripeClient.subscriptions.del(subscription.transactionId, {
|
|
255
280
|
subscription: formatEndDate
|
|
256
281
|
}).then(function (stripeResponse) {
|
|
@@ -261,11 +286,11 @@ export var deleteSubscription = function deleteSubscription(context, endDate) {
|
|
|
261
286
|
modified: now,
|
|
262
287
|
planId: ''
|
|
263
288
|
};
|
|
264
|
-
var aqlQry = aql(_templateObject3(), update);
|
|
265
|
-
return useDb(database).query(aqlQry).then(function () {
|
|
289
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), update);
|
|
290
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function () {
|
|
266
291
|
return true;
|
|
267
292
|
}).catch(function (error) {
|
|
268
|
-
return logError({
|
|
293
|
+
return (0, _utils2.logError)({
|
|
269
294
|
action: action,
|
|
270
295
|
category: eventCategory,
|
|
271
296
|
label: 'db_error'
|
|
@@ -281,4 +306,6 @@ export var deleteSubscription = function deleteSubscription(context, endDate) {
|
|
|
281
306
|
});
|
|
282
307
|
});
|
|
283
308
|
};
|
|
284
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/subscription.ts"],"names":["createHash","parseChar","parseId","parseNum","parseVarChar","aql","DateTime","stripe","Config","getLimit","logError","logException","useDb","getUser","eventCategory","getPlanList","context","from","to","action","database","limit","aqlQry","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getSubscription","sessionId","userId","next","subscription","addPlan","item","userType","isAdmin","value","now","Date","formatId","id","planId","amount","currency","description","interval","intervalCount","name","formatAmount","formatInterval","toLowerCase","formatIntervalCnt","formatName","formatDesc","insert","_key","added","modified","plan","stripeClient","get","plans","create","interval_count","metadata","statement_descriptor","addSubscription","subscriptionId","tax","trialEnd","trialPeriod","formatPlanId","formatTaxPercent","formatTrialPeriod","formatTrialEnd","local","plus","days","toMillis","user","cancelDate","subscriptions","customer","stripeCustomerId","items","tax_percent","trial_end","deleteSubscription","endDate","formatEndDate","del","transactionId","stripeResponse","cancelled","cancel_at_period_end","update"],"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 {createHash, parseChar, parseId, parseNum, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {DateTime} from 'luxon';\nimport * as stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PaymentInterval, PaymentPlan, PaymentSubscription} from '../types/payments';\nimport {getLimit, logError, logException, useDb} from '../utils';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'subscription';\n\nexport const getPlanList = (context: ApiContext, from: number = 0, to: number = 30): Promise<PaymentPlan[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN plans\n      ${limit.aql}\n      SORT p.amount\n      RETURN p`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const aqlQry: string = `FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.cancelled > 0\n      LET plan = FIRST(\n        FOR p IN plans\n        FILTER p._key == s.planId\n      )\n      LIMIT 1\n      RETURN MERGE(s, {plan: plan})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addPlan = (context: ApiContext, item: PaymentPlan): Promise<PaymentPlan> => {\n  const action: string = 'addPlan';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const planId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {amount, currency = 'USD', description, interval, intervalCount, name} = item;\n  const formatAmount: number = parseNum(amount);\n  const formatInterval: PaymentInterval = parseChar(interval, 5).toLowerCase() as PaymentInterval;\n  const formatIntervalCnt: number = parseNum(intervalCount, 5);\n  const formatName: string = parseVarChar(name, 32);\n  const formatDesc: string = parseVarChar(description, 32);\n\n  const insert: PaymentPlan = {\n    _key: planId,\n    added: now,\n    amount: formatAmount,\n    currency,\n    description: formatDesc,\n    interval: formatInterval,\n    intervalCount: formatIntervalCnt,\n    modified: now,\n    name: formatName\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan = {}) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.plans\n        .create({\n          amount: formatAmount * 100,\n          currency,\n          id: planId,\n          interval: formatInterval,\n          interval_count: formatIntervalCnt,\n          metadata: {\n          },\n          name: formatName,\n          statement_descriptor: formatDesc\n        })\n        .then(() => plan);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addSubscription = (context: ApiContext, item): Promise<PaymentSubscription> => {\n  const action: string = 'addSubscription';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const subscriptionId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {planId, tax, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTaxPercent: number = parseNum(tax) || 0;\n  const formatTrialPeriod: number = parseNum(tax) || 0;\n  let formatTrialEnd: number = trialEnd || Date.now();\n\n  if(formatTrialPeriod) {\n    formatTrialEnd = DateTime.local().plus({days: trialPeriod}).toMillis();\n  }\n\n  return getUser(context, sessionId)\n    .then((user) => {\n      const insert: PaymentSubscription = {\n        _key: subscriptionId,\n        added: now,\n        cancelDate: 0,\n        modified: now,\n        planId: formatPlanId,\n        tax: formatTaxPercent,\n        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = stripe(Config.get('stripe.token'));\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {plan: formatPlanId}\n              ],\n              metadata: {\n                userId: sessionId\n              },\n              tax_percent: formatTaxPercent * 100,\n              trial_end: formatTrialEnd\n            })\n            .then(() => subscription);\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n    });\n};\n\nexport const deleteSubscription = (context: ApiContext, endDate: number): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n  const formatEndDate: number = parseNum(endDate) || now;\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.subscriptions\n        .del(subscription.transactionId, {\n          subscription: formatEndDate\n        })\n        .then((stripeResponse) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(stripeResponse.cancelled || stripeResponse.cancel_at_period_end) {\n            const update: PaymentSubscription = {\n              cancelDate: formatEndDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return useDb(database).query(aqlQry)\n              .then(() => true)\n              .catch((error: Error) => logError({\n                action,\n                category: eventCategory,\n                label: 'db_error'\n              }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n          }\n          return false;\n        });\n    });\n};\n"]}
|
|
309
|
+
|
|
310
|
+
exports.deleteSubscription = deleteSubscription;
|
|
311
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/subscription.ts"],"names":["eventCategory","getPlanList","context","from","to","action","database","limit","aqlQry","aql","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getSubscription","sessionId","userId","next","subscription","addPlan","item","userType","isAdmin","value","now","Date","formatId","id","planId","amount","currency","description","interval","intervalCount","name","formatAmount","formatInterval","toLowerCase","formatIntervalCnt","formatName","formatDesc","insert","_key","added","modified","plan","stripeClient","stripe","Config","get","plans","create","interval_count","metadata","statement_descriptor","addSubscription","subscriptionId","tax","trialEnd","trialPeriod","formatPlanId","formatTaxPercent","formatTrialPeriod","formatTrialEnd","DateTime","local","plus","days","toMillis","user","cancelDate","subscriptions","customer","stripeCustomerId","items","tax_percent","trial_end","deleteSubscription","endDate","formatEndDate","del","transactionId","stripeResponse","cancelled","cancel_at_period_end","update"],"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 {createHash, parseChar, parseId, parseNum, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {DateTime} from 'luxon';\nimport * as stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PaymentInterval, PaymentPlan, PaymentSubscription} from '../types/payments';\nimport {getLimit, logError, logException, useDb} from '../utils';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'subscription';\n\nexport const getPlanList = (context: ApiContext, from: number = 0, to: number = 30): Promise<PaymentPlan[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN plans\n      ${limit.aql}\n      SORT p.amount\n      RETURN p`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const aqlQry: string = `FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.cancelled > 0\n      LET plan = FIRST(\n        FOR p IN plans\n        FILTER p._key == s.planId\n      )\n      LIMIT 1\n      RETURN MERGE(s, {plan: plan})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addPlan = (context: ApiContext, item: PaymentPlan): Promise<PaymentPlan> => {\n  const action: string = 'addPlan';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const planId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {amount, currency = 'USD', description, interval, intervalCount, name} = item;\n  const formatAmount: number = parseNum(amount);\n  const formatInterval: PaymentInterval = parseChar(interval, 5).toLowerCase() as PaymentInterval;\n  const formatIntervalCnt: number = parseNum(intervalCount, 5);\n  const formatName: string = parseVarChar(name, 32);\n  const formatDesc: string = parseVarChar(description, 32);\n\n  const insert: PaymentPlan = {\n    _key: planId,\n    added: now,\n    amount: formatAmount,\n    currency,\n    description: formatDesc,\n    interval: formatInterval,\n    intervalCount: formatIntervalCnt,\n    modified: now,\n    name: formatName\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan = {}) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.plans\n        .create({\n          amount: formatAmount * 100,\n          currency,\n          id: planId,\n          interval: formatInterval,\n          interval_count: formatIntervalCnt,\n          metadata: {\n          },\n          name: formatName,\n          statement_descriptor: formatDesc\n        })\n        .then(() => plan);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addSubscription = (context: ApiContext, item): Promise<PaymentSubscription> => {\n  const action: string = 'addSubscription';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const subscriptionId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {planId, tax, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTaxPercent: number = parseNum(tax) || 0;\n  const formatTrialPeriod: number = parseNum(tax) || 0;\n  let formatTrialEnd: number = trialEnd || Date.now();\n\n  if(formatTrialPeriod) {\n    formatTrialEnd = DateTime.local().plus({days: trialPeriod}).toMillis();\n  }\n\n  return getUser(context, sessionId)\n    .then((user) => {\n      const insert: PaymentSubscription = {\n        _key: subscriptionId,\n        added: now,\n        cancelDate: 0,\n        modified: now,\n        planId: formatPlanId,\n        tax: formatTaxPercent,\n        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = stripe(Config.get('stripe.token'));\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {plan: formatPlanId}\n              ],\n              metadata: {\n                userId: sessionId\n              },\n              tax_percent: formatTaxPercent * 100,\n              trial_end: formatTrialEnd\n            })\n            .then(() => subscription);\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n    });\n};\n\nexport const deleteSubscription = (context: ApiContext, endDate: number): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n  const formatEndDate: number = parseNum(endDate) || now;\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.subscriptions\n        .del(subscription.transactionId, {\n          subscription: formatEndDate\n        })\n        .then((stripeResponse) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(stripeResponse.cancelled || stripeResponse.cancel_at_period_end) {\n            const update: PaymentSubscription = {\n              cancelDate: formatEndDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return useDb(database).query(aqlQry)\n              .then(() => true)\n              .catch((error: Error) => logError({\n                action,\n                category: eventCategory,\n                label: 'db_error'\n              }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n          }\n          return false;\n        });\n    });\n};\n"]}
|