@nlabs/reaktor 0.8.1 → 0.9.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/.eslintrc +10 -0
- package/.prettierrc.js +4 -0
- package/README.md +1 -1
- package/coverage/actions/groups.ts.html +1039 -0
- package/coverage/actions/images.ts.html +2500 -0
- package/coverage/actions/index.html +131 -0
- package/coverage/actions/tags.ts.html +1000 -0
- package/coverage/adapters/arangoAdapter.ts.html +151 -0
- package/coverage/adapters/index.html +146 -0
- package/coverage/adapters/reaktorAdapter.ts.html +127 -0
- package/coverage/adapters/tagAdapter.ts.html +160 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/clover.xml +6 -0
- package/coverage/coverage-final.json +1 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +176 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +101 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +196 -0
- package/coverage/lcov.info +0 -0
- package/coverage/mocks/file.ts.html +118 -0
- package/coverage/mocks/group.ts.html +145 -0
- package/coverage/mocks/image.ts.html +136 -0
- package/coverage/mocks/index.html +146 -0
- package/coverage/mocks/post.ts.html +169 -0
- package/coverage/mocks/tag.ts.html +121 -0
- package/coverage/mocks/user.ts.html +268 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +196 -0
- package/coverage/types/error.ts.html +145 -0
- package/coverage/types/index.html +116 -0
- package/coverage/utils/adapterUtils.ts.html +151 -0
- package/coverage/utils/analyticsUtils.ts.html +292 -0
- package/coverage/utils/arangodbUtils.ts.html +463 -0
- package/coverage/utils/index.html +146 -0
- package/jest.setup.js +0 -0
- package/jpg:- +0 -0
- package/lib/actions/apps.d.ts +25 -0
- package/lib/actions/apps.js +252 -0
- package/lib/actions/conversations.d.ts +12 -12
- package/lib/actions/conversations.js +131 -126
- package/lib/actions/dynamodb.d.ts +8 -8
- package/lib/actions/dynamodb.js +35 -32
- package/lib/actions/email.d.ts +2 -4
- package/lib/actions/email.js +23 -53
- package/lib/actions/files.d.ts +15 -12
- package/lib/actions/files.js +188 -202
- package/lib/actions/groups.d.ts +2 -2
- package/lib/actions/groups.js +38 -36
- package/lib/actions/images.d.ts +15 -11
- package/lib/actions/images.js +236 -229
- package/lib/actions/index.d.ts +1 -0
- package/lib/actions/index.js +3 -1
- package/lib/actions/ios.js +11 -10
- package/lib/actions/locations.d.ts +2 -0
- package/lib/actions/locations.js +29 -37
- package/lib/actions/messages.d.ts +2 -2
- package/lib/actions/messages.js +10 -10
- package/lib/actions/notifications.d.ts +2 -2
- package/lib/actions/notifications.js +1 -1
- package/lib/actions/payments.d.ts +2 -2
- package/lib/actions/payments.js +27 -26
- package/lib/actions/posts.d.ts +7 -9
- package/lib/actions/posts.js +176 -156
- package/lib/actions/reactions.d.ts +5 -5
- package/lib/actions/reactions.js +30 -28
- package/lib/actions/s3.d.ts +7 -7
- package/lib/actions/s3.js +37 -32
- package/lib/actions/search.d.ts +3 -3
- package/lib/actions/search.js +11 -9
- package/lib/actions/sms.d.ts +2 -2
- package/lib/actions/sms.js +58 -34
- package/lib/actions/statistics.d.ts +2 -1
- package/lib/actions/statistics.js +21 -18
- package/lib/actions/subscription.d.ts +2 -2
- package/lib/actions/subscription.js +24 -21
- package/lib/actions/tags.d.ts +21 -23
- package/lib/actions/tags.js +129 -198
- package/lib/actions/users.d.ts +23 -20
- package/lib/actions/users.js +188 -194
- package/lib/actions/websockets.d.ts +13 -0
- package/lib/actions/websockets.js +60 -34
- package/lib/adapters/arangoAdapter.d.ts +2 -0
- package/lib/adapters/arangoAdapter.js +46 -0
- package/lib/adapters/fileAdapter.d.ts +3 -0
- package/lib/adapters/fileAdapter.js +76 -0
- package/lib/adapters/postAdapter.d.ts +2 -0
- package/lib/adapters/postAdapter.js +70 -0
- package/lib/adapters/reaktorAdapter.d.ts +6 -0
- package/lib/adapters/reaktorAdapter.js +44 -0
- package/lib/adapters/tagAdapter.d.ts +2 -0
- package/lib/adapters/tagAdapter.js +50 -0
- package/lib/adapters/userAdapter.d.ts +2 -0
- package/lib/adapters/userAdapter.js +110 -0
- package/lib/config.js +14 -15
- package/lib/lambdas/actions/websockets.js +7 -7
- package/lib/lambdas/authorizer.js +1 -1
- package/lib/lambdas/connection.js +5 -4
- package/lib/lambdas/utils/websocket.js +7 -6
- package/lib/mocks/conversation.d.ts +8 -0
- package/lib/mocks/conversation.js +35 -0
- package/lib/mocks/file.d.ts +11 -0
- package/lib/mocks/file.js +38 -0
- package/lib/mocks/group.d.ts +17 -0
- package/lib/mocks/group.js +47 -0
- package/lib/mocks/image.d.ts +3 -0
- package/lib/mocks/image.js +43 -0
- package/lib/mocks/nlabs.png +0 -0
- package/lib/mocks/post.d.ts +38 -0
- package/lib/mocks/post.js +55 -0
- package/lib/mocks/tag.d.ts +2 -0
- package/lib/mocks/tag.js +37 -0
- package/lib/mocks/user.d.ts +4 -0
- package/lib/mocks/user.js +88 -0
- package/lib/types/apps.d.ts +19 -17
- package/lib/types/apps.js +17 -1
- package/lib/types/arangodb.d.ts +19 -6
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.d.ts +4 -4
- package/lib/types/auth.js +1 -1
- package/lib/types/connections.d.ts +2 -3
- package/lib/types/connections.js +1 -1
- package/lib/types/conversations.d.ts +21 -8
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.d.ts +4 -3
- package/lib/types/email.js +1 -1
- package/lib/types/error.d.ts +20 -0
- package/lib/types/error.js +44 -0
- package/lib/types/files.d.ts +10 -10
- package/lib/types/files.js +1 -1
- package/lib/types/google.d.ts +29 -27
- package/lib/types/google.js +1 -1
- package/lib/types/groups.d.ts +6 -7
- package/lib/types/groups.js +1 -1
- package/lib/types/images.d.ts +26 -17
- package/lib/types/images.js +1 -1
- package/lib/types/locations.d.ts +4 -4
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +3 -14
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.d.ts +9 -11
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.d.ts +13 -16
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.d.ts +7 -23
- package/lib/types/posts.js +1 -1
- package/lib/types/statistics.d.ts +2 -2
- package/lib/types/statistics.js +1 -1
- package/lib/types/tags.d.ts +7 -12
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +10 -14
- package/lib/types/users.js +1 -1
- package/lib/types/websocket.d.ts +2 -3
- package/lib/types/websocket.js +1 -1
- package/lib/utils/adapterUtils.d.ts +1 -0
- package/lib/utils/adapterUtils.js +45 -0
- package/lib/utils/analyticsUtils.d.ts +21 -0
- package/lib/utils/analyticsUtils.js +72 -0
- package/lib/utils/arangodbUtils.d.ts +65 -0
- package/lib/utils/arangodbUtils.js +144 -0
- package/lib/utils/auth.d.ts +18 -3
- package/lib/utils/auth.js +13 -30
- package/lib/utils/index.d.ts +3 -4
- package/lib/utils/index.js +7 -9
- package/lib/utils/session.d.ts +7 -9
- package/lib/utils/session.js +11 -2
- package/package.json +12 -5
- package/lib/utils/analytics.d.ts +0 -14
- package/lib/utils/analytics.js +0 -88
- package/lib/utils/arangodb.d.ts +0 -9
- package/lib/utils/arangodb.js +0 -118
- package/lib/utils/graphql.d.ts +0 -1
- package/lib/utils/graphql.js +0 -46
- package/lib/utils/objects.d.ts +0 -3
- package/lib/utils/objects.js +0 -59
package/lib/actions/sms.js
CHANGED
|
@@ -31,47 +31,71 @@ __export(sms_exports, {
|
|
|
31
31
|
sendSmsTemplate: () => sendSmsTemplate
|
|
32
32
|
});
|
|
33
33
|
module.exports = __toCommonJS(sms_exports);
|
|
34
|
+
var import_client_sns = require("@aws-sdk/client-sns");
|
|
34
35
|
var import_utils = require("@nlabs/utils");
|
|
35
36
|
var import_fs = __toESM(require("fs"));
|
|
36
|
-
var import_twilio = __toESM(require("twilio"));
|
|
37
37
|
var import_config = require("../config");
|
|
38
|
-
var
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
const
|
|
47
|
-
const
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
return
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
38
|
+
var import_error = require("../types/error");
|
|
39
|
+
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
40
|
+
const eventCategory = "sms";
|
|
41
|
+
const sendSms = async ({
|
|
42
|
+
content,
|
|
43
|
+
user,
|
|
44
|
+
variables = {}
|
|
45
|
+
}) => {
|
|
46
|
+
const action = "sendSms";
|
|
47
|
+
const snsClient = new import_client_sns.SNSClient({
|
|
48
|
+
credentials: import_config.Config.get("aws.credentials"),
|
|
49
|
+
region: import_config.Config.get("aws.region")
|
|
50
|
+
});
|
|
51
|
+
const { country = "US", phone } = user;
|
|
52
|
+
const phoneNumber = (0, import_utils.parsePhone)(phone, country);
|
|
53
|
+
const templateContent = (0, import_utils.parseTemplate)(content, variables);
|
|
54
|
+
return await snsClient.send(
|
|
55
|
+
new import_client_sns.PublishCommand({
|
|
56
|
+
Message: templateContent,
|
|
57
|
+
MessageAttributes: {
|
|
58
|
+
"AWS.SNS.SMS.SMSType": {
|
|
59
|
+
DataType: "String",
|
|
60
|
+
StringValue: "Transactional"
|
|
61
|
+
},
|
|
62
|
+
"AWS.SNS.SMS.SenderID": {
|
|
63
|
+
DataType: "String",
|
|
64
|
+
StringValue: import_config.Config.get("app.id").trim().replace(/ /g, "").substring(0, 11)
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
PhoneNumber: phoneNumber
|
|
68
|
+
})
|
|
69
|
+
).then((res) => {
|
|
70
|
+
console.log({ res });
|
|
71
|
+
return res;
|
|
72
|
+
}).catch((error) => {
|
|
73
|
+
console.log({ error });
|
|
74
|
+
return (0, import_analyticsUtils.logError)({
|
|
75
|
+
action,
|
|
76
|
+
category: eventCategory,
|
|
77
|
+
label: import_error.ErrorTypes.SMS_ERROR
|
|
78
|
+
}, error, { session: user });
|
|
62
79
|
});
|
|
63
80
|
};
|
|
64
|
-
const sendSmsTemplate = (templateName,
|
|
65
|
-
|
|
81
|
+
const sendSmsTemplate = (templateName, {
|
|
82
|
+
user,
|
|
83
|
+
variables = {}
|
|
84
|
+
}) => {
|
|
85
|
+
const action = "sendSmsTemplate";
|
|
66
86
|
try {
|
|
67
87
|
const data = import_fs.default.readFileSync(`./templates/sms/${templateName}.txt`, "utf8");
|
|
68
|
-
const text = (0,
|
|
69
|
-
const params = {
|
|
70
|
-
return sendSms(params).then((res) => res.status === "queued").catch(
|
|
71
|
-
|
|
72
|
-
|
|
88
|
+
const text = (0, import_utils.parseTemplate)(data, variables);
|
|
89
|
+
const params = { text, user };
|
|
90
|
+
return sendSms(params).then((res) => res.status === "queued").catch(
|
|
91
|
+
(error) => (0, import_analyticsUtils.logError)({
|
|
92
|
+
action,
|
|
93
|
+
category: eventCategory,
|
|
94
|
+
label: import_error.ErrorTypes.SMS_ERROR
|
|
95
|
+
}, error, { session: user }).then(() => null)
|
|
96
|
+
);
|
|
73
97
|
} catch (error) {
|
|
74
|
-
return Promise.reject(error);
|
|
98
|
+
return Promise.reject({ errors: [error.message] });
|
|
75
99
|
}
|
|
76
100
|
};
|
|
77
101
|
// Annotate the CommonJS export names for ESM import in node:
|
|
@@ -79,4 +103,4 @@ const sendSmsTemplate = (templateName, smsParams) => {
|
|
|
79
103
|
sendSms,
|
|
80
104
|
sendSmsTemplate
|
|
81
105
|
});
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc21zLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtQdWJsaXNoQ29tbWFuZCwgU05TQ2xpZW50fSBmcm9tICdAYXdzLXNkay9jbGllbnQtc25zJztcbmltcG9ydCB7cGFyc2VQaG9uZSwgcGFyc2VUZW1wbGF0ZX0gZnJvbSAnQG5sYWJzL3V0aWxzJztcbmltcG9ydCBmcyBmcm9tICdmcyc7XG5cbmltcG9ydCB7Q29uZmlnfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IHtFcnJvclR5cGVzfSBmcm9tICcuLi90eXBlcy9lcnJvcic7XG5pbXBvcnQge1NNU1BhcmFtc1R5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuaW1wb3J0IHtTZXNzaW9ufSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQge2xvZ0Vycm9yfSBmcm9tICcuLi91dGlscy9hbmFseXRpY3NVdGlscyc7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzbXMnO1xuXG5leHBvcnQgY29uc3Qgc2VuZFNtcyA9IGFzeW5jICh7XG4gIGNvbnRlbnQsXG4gIHVzZXIsXG4gIHZhcmlhYmxlcyA9IHt9XG59OiBTTVNQYXJhbXNUeXBlKTogUHJvbWlzZTxhbnk+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnc2VuZFNtcyc7XG4gIGNvbnN0IHNuc0NsaWVudCA9IG5ldyBTTlNDbGllbnQoe1xuICAgIGNyZWRlbnRpYWxzOiBDb25maWcuZ2V0KCdhd3MuY3JlZGVudGlhbHMnKSxcbiAgICByZWdpb246IENvbmZpZy5nZXQoJ2F3cy5yZWdpb24nKVxuICB9KTtcbiAgY29uc3Qge2NvdW50cnkgPSAnVVMnLCBwaG9uZX0gPSB1c2VyO1xuICBjb25zdCBwaG9uZU51bWJlciA9IHBhcnNlUGhvbmUocGhvbmUsIGNvdW50cnkpO1xuICBjb25zdCB0ZW1wbGF0ZUNvbnRlbnQ6IHN0cmluZyA9IHBhcnNlVGVtcGxhdGUoY29udGVudCwgdmFyaWFibGVzKTtcblxuICByZXR1cm4gYXdhaXQgc25zQ2xpZW50XG4gICAgLnNlbmQoXG4gICAgICBuZXcgUHVibGlzaENvbW1hbmQoe1xuICAgICAgICBNZXNzYWdlOiB0ZW1wbGF0ZUNvbnRlbnQsXG4gICAgICAgIE1lc3NhZ2VBdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgJ0FXUy5TTlMuU01TLlNNU1R5cGUnOiB7XG4gICAgICAgICAgICBEYXRhVHlwZTogJ1N0cmluZycsXG4gICAgICAgICAgICBTdHJpbmdWYWx1ZTogJ1RyYW5zYWN0aW9uYWwnXG4gICAgICAgICAgfSxcbiAgICAgICAgICAnQVdTLlNOUy5TTVMuU2VuZGVySUQnOiB7XG4gICAgICAgICAgICBEYXRhVHlwZTogJ1N0cmluZycsXG4gICAgICAgICAgICBTdHJpbmdWYWx1ZTogQ29uZmlnLmdldCgnYXBwLmlkJykudHJpbSgpLnJlcGxhY2UoLyAvZywgJycpLnN1YnN0cmluZygwLCAxMSlcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIFBob25lTnVtYmVyOiBwaG9uZU51bWJlclxuICAgICAgfSksXG4gICAgKVxuICAgIC50aGVuKChyZXMpID0+IHtcbiAgICAgIGNvbnNvbGUubG9nKHtyZXN9KTtcbiAgICAgIHJldHVybiByZXM7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yKSA9PiB7XG4gICAgICBjb25zb2xlLmxvZyh7ZXJyb3J9KTtcbiAgICAgIHJldHVybiBsb2dFcnJvcih7XG4gICAgICAgIGFjdGlvbixcbiAgICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICAgIGxhYmVsOiBFcnJvclR5cGVzLlNNU19FUlJPUlxuICAgICAgfSwgZXJyb3IsIHtzZXNzaW9uOiB1c2VyIGFzIFNlc3Npb259KTtcbiAgICB9KTtcbiAgLy8gLnRoZW4oKCkgPT4gbnVsbCk7XG59O1xuXG5leHBvcnQgY29uc3Qgc2VuZFNtc1RlbXBsYXRlID0gKFxuICB0ZW1wbGF0ZU5hbWU6IHN0cmluZyxcbiAge1xuICAgIHVzZXIsXG4gICAgdmFyaWFibGVzID0ge31cbiAgfTogU01TUGFyYW1zVHlwZVxuKTogUHJvbWlzZTxib29sZWFuPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ3NlbmRTbXNUZW1wbGF0ZSc7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBkYXRhID0gZnMucmVhZEZpbGVTeW5jKGAuL3RlbXBsYXRlcy9zbXMvJHt0ZW1wbGF0ZU5hbWV9LnR4dGAsICd1dGY4Jyk7XG4gICAgY29uc3QgdGV4dCA9IHBhcnNlVGVtcGxhdGUoZGF0YSwgdmFyaWFibGVzKTtcbiAgICBjb25zdCBwYXJhbXMgPSB7dGV4dCwgdXNlcn07XG5cbiAgICByZXR1cm4gc2VuZFNtcyhwYXJhbXMpXG4gICAgICAudGhlbigocmVzKSA9PiByZXMuc3RhdHVzID09PSAncXVldWVkJylcbiAgICAgIC5jYXRjaCgoZXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgICAgYWN0aW9uLFxuICAgICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgICAgbGFiZWw6IEVycm9yVHlwZXMuU01TX0VSUk9SXG4gICAgICB9LCBlcnJvciwge3Nlc3Npb246IHVzZXIgYXMgU2Vzc2lvbn0pXG4gICAgICAgIC50aGVuKCgpID0+IG51bGwpXG4gICAgICApO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgcmV0dXJuIFByb21pc2UucmVqZWN0KHtlcnJvcnM6IFtlcnJvci5tZXNzYWdlXX0pO1xuICB9XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FB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
|
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { ApiContext, StatisticsType } from '../types';
|
|
2
|
-
export declare const getGlobalStatistics: (context: ApiContext) => Promise<
|
|
2
|
+
export declare const getGlobalStatistics: (context: ApiContext) => Promise<StatisticsType>;
|
|
3
|
+
export declare const updateGlobalStatistics: (context: ApiContext) => Promise<StatisticsType>;
|
|
@@ -17,43 +17,46 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
17
17
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
18
|
var statistics_exports = {};
|
|
19
19
|
__export(statistics_exports, {
|
|
20
|
-
getGlobalStatistics: () => getGlobalStatistics
|
|
20
|
+
getGlobalStatistics: () => getGlobalStatistics,
|
|
21
|
+
updateGlobalStatistics: () => updateGlobalStatistics
|
|
21
22
|
});
|
|
22
23
|
module.exports = __toCommonJS(statistics_exports);
|
|
23
24
|
var import_arangojs = require("arangojs");
|
|
24
|
-
var
|
|
25
|
-
var
|
|
25
|
+
var import_users = require("./users");
|
|
26
|
+
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
27
|
+
var import_error = require("../types/error");
|
|
26
28
|
const eventCategory = "statistics";
|
|
27
|
-
const getGlobalStatistics =
|
|
28
|
-
const action = "
|
|
29
|
+
const getGlobalStatistics = (context) => {
|
|
30
|
+
const action = "getGlobalStatistics";
|
|
29
31
|
const { database } = context;
|
|
30
32
|
const statisticsQuery = import_arangojs.aql`FOR s IN statistics
|
|
31
33
|
FILTER s.isGlobal == true
|
|
32
34
|
LIMIT 1
|
|
33
35
|
RETURN s`;
|
|
34
|
-
|
|
36
|
+
return database.query(statisticsQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
35
37
|
action,
|
|
36
38
|
category: eventCategory,
|
|
37
|
-
label:
|
|
38
|
-
}, error, context)
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
const
|
|
39
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
40
|
+
}, error, context));
|
|
41
|
+
};
|
|
42
|
+
const updateGlobalStatistics = (context) => {
|
|
43
|
+
const action = "updateGlobalStatistics";
|
|
44
|
+
const { database } = context;
|
|
45
|
+
const activeUsers = (0, import_users.getActiveUserCount)(context);
|
|
43
46
|
const updatedData = { activeUsers };
|
|
44
47
|
const updateQuery = import_arangojs.aql`UPSERT {isGlobal: true}
|
|
45
48
|
INSERT ${updatedData}
|
|
46
49
|
UPDATE ${updatedData}
|
|
47
50
|
IN statistics RETURN NEW`;
|
|
48
|
-
|
|
51
|
+
return database.query(updateQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
49
52
|
action,
|
|
50
53
|
category: eventCategory,
|
|
51
|
-
label:
|
|
52
|
-
}, error, context)
|
|
53
|
-
return updatedStatistics;
|
|
54
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
55
|
+
}, error, context));
|
|
54
56
|
};
|
|
55
57
|
// Annotate the CommonJS export names for ESM import in node:
|
|
56
58
|
0 && (module.exports = {
|
|
57
|
-
getGlobalStatistics
|
|
59
|
+
getGlobalStatistics,
|
|
60
|
+
updateGlobalStatistics
|
|
58
61
|
});
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvc3RhdGlzdGljcy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7YXFsfSBmcm9tICdhcmFuZ29qcyc7XG5pbXBvcnQge0FxbFF1ZXJ5fSBmcm9tICdhcmFuZ29qcy9hcWwnO1xuaW1wb3J0IHtBcnJheUN1cnNvcn0gZnJvbSAnYXJhbmdvanMvY3Vyc29yJztcblxuaW1wb3J0IHtnZXRBY3RpdmVVc2VyQ291bnR9IGZyb20gJy4vdXNlcnMnO1xuaW1wb3J0IHtBcGlDb250ZXh0LCBTdGF0aXN0aWNzVHlwZX0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHtsb2dFcnJvcn0gZnJvbSAnLi4vdXRpbHMvYW5hbHl0aWNzVXRpbHMnO1xuaW1wb3J0IHtFcnJvclR5cGVzfSBmcm9tICcuLi90eXBlcy9lcnJvcic7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzdGF0aXN0aWNzJztcblxuZXhwb3J0IGNvbnN0IGdldEdsb2JhbFN0YXRpc3RpY3MgPSAoY29udGV4dDogQXBpQ29udGV4dCk6IFByb21pc2U8U3RhdGlzdGljc1R5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0R2xvYmFsU3RhdGlzdGljcyc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBzdGF0aXN0aWNzUXVlcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiBzIElOIHN0YXRpc3RpY3NcbiAgICBGSUxURVIgcy5pc0dsb2JhbCA9PSB0cnVlXG4gICAgTElNSVQgMVxuICAgIFJFVFVSTiBzYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoc3RhdGlzdGljc1F1ZXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpKTtcbn07XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVHbG9iYWxTdGF0aXN0aWNzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQpOiBQcm9taXNlPFN0YXRpc3RpY3NUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ3VwZGF0ZUdsb2JhbFN0YXRpc3RpY3MnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgYWN0aXZlVXNlcnMgPSBnZXRBY3RpdmVVc2VyQ291bnQoY29udGV4dCk7XG4gIGNvbnN0IHVwZGF0ZWREYXRhID0ge2FjdGl2ZVVzZXJzfTtcblxuICBjb25zdCB1cGRhdGVRdWVyeTogQXFsUXVlcnkgPSBhcWxgVVBTRVJUIHtpc0dsb2JhbDogdHJ1ZX1cbiAgSU5TRVJUICR7dXBkYXRlZERhdGF9XG4gIFVQREFURSAke3VwZGF0ZWREYXRhfVxuICBJTiBzdGF0aXN0aWNzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeSh1cGRhdGVRdWVyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogRXJyb3JUeXBlcy5EQVRBQkFTRV9FUlJPUlxuICAgIH0sIGVycm9yLCBjb250ZXh0KSk7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxzQkFBa0I7QUFJbEIsbUJBQWlDO0FBRWpDLDRCQUF1QjtBQUN2QixtQkFBeUI7QUFFekIsTUFBTSxnQkFBd0I7QUFFdkIsTUFBTSxzQkFBc0IsQ0FBQyxZQUFpRDtBQUNuRixRQUFNLFNBQWlCO0FBQ3ZCLFFBQU0sRUFBQyxTQUFRLElBQUk7QUFDbkIsUUFBTSxrQkFBNEI7QUFBQTtBQUFBO0FBQUE7QUFLbEMsU0FBTyxTQUFTLE1BQU0sZUFBZSxFQUNsQyxLQUFLLENBQUMsV0FBd0IsT0FBTyxLQUFLLENBQUMsRUFDM0MsTUFBTSxDQUFDLGNBQWlCLGdDQUFTO0FBQUEsSUFDaEM7QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU8sd0JBQVc7QUFBQSxFQUNwQixHQUFHLE9BQU8sT0FBTyxDQUFDO0FBQ3RCO0FBRU8sTUFBTSx5QkFBeUIsQ0FBQyxZQUFpRDtBQUN0RixRQUFNLFNBQWlCO0FBQ3ZCLFFBQU0sRUFBQyxTQUFRLElBQUk7QUFDbkIsUUFBTSxrQkFBYyxpQ0FBbUIsT0FBTztBQUM5QyxRQUFNLGNBQWMsRUFBQyxZQUFXO0FBRWhDLFFBQU0sY0FBd0I7QUFBQSxXQUNyQixXQUFXO0FBQUEsV0FDWCxXQUFXO0FBQUE7QUFHcEIsU0FBTyxTQUFTLE1BQU0sV0FBVyxFQUM5QixLQUFLLENBQUMsV0FBd0IsT0FBTyxLQUFLLENBQUMsRUFDM0MsTUFBTSxDQUFDLGNBQWlCLGdDQUFTO0FBQUEsSUFDaEM7QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU8sd0JBQVc7QUFBQSxFQUNwQixHQUFHLE9BQU8sT0FBTyxDQUFDO0FBQ3RCOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ApiContext } from '../types/auth';
|
|
2
|
-
import { PaymentPlan, PaymentSubscription } from '../types/payments';
|
|
1
|
+
import type { ApiContext } from '../types/auth';
|
|
2
|
+
import type { PaymentPlan, PaymentSubscription } from '../types/payments';
|
|
3
3
|
export declare const getPlanList: (context: ApiContext, from?: number, to?: number) => Promise<PaymentPlan[]>;
|
|
4
4
|
export declare const getSubscription: (context: ApiContext) => Promise<PaymentSubscription>;
|
|
5
5
|
export declare const addPlan: (context: ApiContext, item: PaymentPlan) => Promise<PaymentPlan>;
|
|
@@ -39,22 +39,25 @@ var import_arangojs = require("arangojs");
|
|
|
39
39
|
var import_luxon = require("luxon");
|
|
40
40
|
var import_stripe = __toESM(require("stripe"));
|
|
41
41
|
var import_config = require("../config");
|
|
42
|
-
var import_utils2 = require("../utils");
|
|
43
42
|
var import_users = require("./users");
|
|
43
|
+
var import_error = require("../types/error");
|
|
44
|
+
var import_arangodbUtils = require("../utils/arangodbUtils");
|
|
45
|
+
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
46
|
+
var import_utils2 = require("../utils");
|
|
44
47
|
const eventCategory = "subscription";
|
|
45
48
|
const apiVersion = "2020-03-02";
|
|
46
49
|
const getPlanList = (context, from = 0, to = 30) => {
|
|
47
50
|
const action = "getList";
|
|
48
51
|
const { database } = context;
|
|
49
|
-
const limit = (0,
|
|
52
|
+
const limit = (0, import_arangodbUtils.getLimit)(from, to);
|
|
50
53
|
const aqlQry = `FOR p IN plans
|
|
51
54
|
${limit.aql}
|
|
52
55
|
SORT p.amount
|
|
53
56
|
RETURN p`;
|
|
54
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0,
|
|
57
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_analyticsUtils.logError)({
|
|
55
58
|
action,
|
|
56
59
|
category: eventCategory,
|
|
57
|
-
label:
|
|
60
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
58
61
|
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
59
62
|
};
|
|
60
63
|
const getSubscription = (context) => {
|
|
@@ -68,27 +71,27 @@ const getSubscription = (context) => {
|
|
|
68
71
|
)
|
|
69
72
|
LIMIT 1
|
|
70
73
|
RETURN MERGE(s, {plan: plan})`;
|
|
71
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription = {}) => subscription).catch((error) => (0,
|
|
74
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((subscription = {}) => subscription).catch((error) => (0, import_analyticsUtils.logError)({
|
|
72
75
|
action,
|
|
73
76
|
category: eventCategory,
|
|
74
|
-
label:
|
|
77
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
75
78
|
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
76
79
|
};
|
|
77
80
|
const addPlan = (context, item) => {
|
|
78
81
|
const action = "addPlan";
|
|
79
|
-
const { database, session
|
|
80
|
-
const isAdmin =
|
|
82
|
+
const { database, session } = context;
|
|
83
|
+
const isAdmin = (0, import_utils2.isAdminUser)(session);
|
|
81
84
|
if (!isAdmin) {
|
|
82
|
-
return (0,
|
|
85
|
+
return (0, import_analyticsUtils.logException)({
|
|
83
86
|
action,
|
|
84
87
|
category: eventCategory,
|
|
85
88
|
label: "unauthorized",
|
|
86
|
-
value:
|
|
89
|
+
value: import_error.ErrorTypes.INVALID_SESSION
|
|
87
90
|
}, context).then(() => null);
|
|
88
91
|
}
|
|
89
92
|
const now = Date.now();
|
|
90
93
|
const formatId = (0, import_utils.parseId)(item.id);
|
|
91
|
-
const planId = formatId === "" ? (0, import_utils.createHash)(`subscription-${
|
|
94
|
+
const planId = formatId === "" ? (0, import_utils.createHash)(`subscription-${session.userId}`) : formatId;
|
|
92
95
|
const { amount, currency = "USD", description, interval, intervalCount, name } = item;
|
|
93
96
|
const formatAmount = (0, import_utils.parseNum)(amount);
|
|
94
97
|
const formatInterval = (0, import_utils.parseChar)(interval, 5).toLowerCase();
|
|
@@ -107,7 +110,7 @@ const addPlan = (context, item) => {
|
|
|
107
110
|
name: formatName
|
|
108
111
|
};
|
|
109
112
|
const aqlQry = import_arangojs.aql`INSERT ${insert} IN plans RETURN NEW`;
|
|
110
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((plan
|
|
113
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((plan) => {
|
|
111
114
|
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
112
115
|
const stripePlan = {
|
|
113
116
|
amount: formatAmount * 100,
|
|
@@ -120,10 +123,10 @@ const addPlan = (context, item) => {
|
|
|
120
123
|
statement_descriptor: formatDesc
|
|
121
124
|
};
|
|
122
125
|
return stripeClient.plans.create(stripePlan).then(() => plan);
|
|
123
|
-
}).catch((error) => (0,
|
|
126
|
+
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
124
127
|
action,
|
|
125
128
|
category: eventCategory,
|
|
126
|
-
label:
|
|
129
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
127
130
|
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
128
131
|
};
|
|
129
132
|
const addSubscription = (context, item) => {
|
|
@@ -131,7 +134,7 @@ const addSubscription = (context, item) => {
|
|
|
131
134
|
const { database, session: { userId: sessionId, userAccess } } = context;
|
|
132
135
|
const isAdmin = userAccess > 2;
|
|
133
136
|
if (!isAdmin) {
|
|
134
|
-
return (0,
|
|
137
|
+
return (0, import_analyticsUtils.logException)({
|
|
135
138
|
action,
|
|
136
139
|
category: eventCategory,
|
|
137
140
|
label: "unauthorized",
|
|
@@ -148,7 +151,7 @@ const addSubscription = (context, item) => {
|
|
|
148
151
|
if (formatTrialPeriod) {
|
|
149
152
|
formatTrialEnd = import_luxon.DateTime.local().plus({ days: trialPeriod }).toMillis();
|
|
150
153
|
}
|
|
151
|
-
return (0, import_users.getUser)(context, sessionId).then((user) => {
|
|
154
|
+
return (0, import_users.getUser)(context, { userId: sessionId }).then((user) => {
|
|
152
155
|
const insert = {
|
|
153
156
|
_key: subscriptionId,
|
|
154
157
|
added: now,
|
|
@@ -173,10 +176,10 @@ const addSubscription = (context, item) => {
|
|
|
173
176
|
},
|
|
174
177
|
trial_end: formatTrialEnd
|
|
175
178
|
}).then(() => subscription);
|
|
176
|
-
}).catch((error) => (0,
|
|
179
|
+
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
177
180
|
action,
|
|
178
181
|
category: eventCategory,
|
|
179
|
-
label:
|
|
182
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
180
183
|
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
181
184
|
});
|
|
182
185
|
};
|
|
@@ -194,10 +197,10 @@ const deleteSubscription = (context) => {
|
|
|
194
197
|
planId: ""
|
|
195
198
|
};
|
|
196
199
|
const aqlQry = import_arangojs.aql`UPDATE s WITH ${update} IN subscriptions`;
|
|
197
|
-
return database.query(aqlQry).then(() => true).catch((error) => (0,
|
|
200
|
+
return database.query(aqlQry).then(() => true).catch((error) => (0, import_analyticsUtils.logError)({
|
|
198
201
|
action,
|
|
199
202
|
category: eventCategory,
|
|
200
|
-
label:
|
|
203
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
201
204
|
}, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
|
|
202
205
|
}
|
|
203
206
|
return false;
|
|
@@ -212,4 +215,4 @@ const deleteSubscription = (context) => {
|
|
|
212
215
|
getPlanList,
|
|
213
216
|
getSubscription
|
|
214
217
|
});
|
|
215
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/subscription.ts"],
  "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/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {DateTime} from 'luxon';\nimport 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} from '../utils';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'subscription';\nconst apiVersion: any = '2020-03-02';\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 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, session: {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 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, session: {userId: sessionId, userAccess}} = context;\n  const isAdmin: boolean = userAccess > 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(`subscription-${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 database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan = {}) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const stripePlan: any = {\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\n      return stripeClient.plans\n        .create(stripePlan)\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, session: {userId: sessionId, userAccess}} = context;\n  const isAdmin: boolean = userAccess > 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(`subscription-${sessionId}`) : formatId;\n  const {planId, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTrialPeriod: number = 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        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {\n                  plan: formatPlanId\n                }\n              ],\n              metadata: {\n                userId: sessionId\n              },\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): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      return stripeClient.subscriptions\n        .cancel(subscription.transactionId)\n        .then(({canceled_at: cancelDate}) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(cancelDate) {\n            const update: PaymentSubscription = {\n              cancelDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return 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"],
  "mappings": "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",
  "names": ["import_utils", "error", "Stripe"]
}

|
|
218
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/subscription.ts"],
  "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/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {DateTime} from 'luxon';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport type {ArangoDbLimit} from '../types/arangodb';\nimport type {ApiContext} from '../types/auth';\nimport type {PaymentInterval, PaymentPlan, PaymentSubscription} from '../types/payments';\nimport {getUser} from './users';\nimport {ErrorTypes} from '../types/error';\nimport {getLimit} from '../utils/arangodbUtils';\nimport {logError, logException} from '../utils/analyticsUtils';\nimport {isAdminUser} from '../utils';\n\nconst eventCategory: string = 'subscription';\nconst apiVersion: any = '2020-03-02';\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 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: ErrorTypes.DATABASE_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, session: {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 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: ErrorTypes.DATABASE_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, session} = context;\n  const isAdmin = isAdminUser(session);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: ErrorTypes.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(`subscription-${session.userId}`) : 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  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 database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const stripePlan: any = {\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\n      return stripeClient.plans\n        .create(stripePlan)\n        .then(() => plan);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_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, session: {userId: sessionId, userAccess}} = context;\n  const isAdmin: boolean = userAccess > 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(`subscription-${sessionId}`) : formatId;\n  const {planId, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTrialPeriod: number = 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, {userId: sessionId})\n    .then((user) => {\n      const insert: PaymentSubscription = {\n        _key: subscriptionId,\n        added: now,\n        cancelDate: 0,\n        modified: now,\n        planId: formatPlanId,\n        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {\n                  plan: formatPlanId\n                }\n              ],\n              metadata: {\n                userId: sessionId\n              },\n              trial_end: formatTrialEnd\n            })\n            .then(() => subscription);\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: ErrorTypes.DATABASE_ERROR\n        }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n    });\n};\n\nexport const deleteSubscription = (context: ApiContext): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      return stripeClient.subscriptions\n        .cancel(subscription.transactionId)\n        .then(({canceled_at: cancelDate}) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(cancelDate) {\n            const update: PaymentSubscription = {\n              cancelDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return database.query(aqlQry)\n              .then(() => true)\n              .catch((error: Error) => logError({\n                action,\n                category: eventCategory,\n                label: ErrorTypes.DATABASE_ERROR\n              }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n          }\n          return false;\n        });\n    });\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "error", "Stripe"]
}

|
package/lib/actions/tags.d.ts
CHANGED
|
@@ -1,31 +1,29 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { TagType } from '../types/tags';
|
|
1
|
+
import type { ApiContext } from '../types/auth';
|
|
2
|
+
import type { TagType } from '../types/tags';
|
|
4
3
|
export interface TagOptions {
|
|
5
|
-
readonly search?: string;
|
|
6
4
|
readonly from?: number;
|
|
5
|
+
readonly search?: string;
|
|
7
6
|
readonly to?: number;
|
|
7
|
+
readonly userId?: string;
|
|
8
8
|
}
|
|
9
9
|
export declare const getTags: (context: ApiContext, options?: TagOptions) => Promise<TagType[]>;
|
|
10
|
-
export declare const getTagsByItem: (context: ApiContext,
|
|
11
|
-
export declare const getTagsByOwner: (context: ApiContext, args: any) => Promise<TagType[]>;
|
|
10
|
+
export declare const getTagsByItem: (context: ApiContext, itemDocId: string, options?: TagOptions) => Promise<TagType[]>;
|
|
12
11
|
export declare const getTag: (context: ApiContext, tagId: string) => Promise<TagType>;
|
|
13
|
-
export declare const
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}) => Promise<TagType>;
|
|
20
|
-
export declare const updateTag: (context: ApiContext, item?: TagType) => Promise<TagType>;
|
|
21
|
-
export declare const deleteTag: (context: ApiContext, { tagId }: {
|
|
22
|
-
tagId: any;
|
|
12
|
+
export declare const getTagsByName: (context: ApiContext, tagNames: string[]) => Promise<TagType[]>;
|
|
13
|
+
export declare const addTag: (context: ApiContext, tag: TagType) => Promise<TagType>;
|
|
14
|
+
export declare const addTagToItem: (context: ApiContext, { itemDocId, tagBy, tagDocId }: {
|
|
15
|
+
itemDocId: string;
|
|
16
|
+
tagBy?: string;
|
|
17
|
+
tagDocId: string;
|
|
23
18
|
}) => Promise<TagType>;
|
|
24
|
-
export declare const
|
|
25
|
-
|
|
26
|
-
|
|
19
|
+
export declare const updateTag: (context: ApiContext, tag: TagType) => Promise<TagType>;
|
|
20
|
+
export declare const deleteTag: (context: ApiContext, tag: TagType) => Promise<TagType>;
|
|
21
|
+
export declare const deleteTagFromItem: (context: ApiContext, { tagDocId, edgeDocId }: {
|
|
22
|
+
tagDocId: any;
|
|
23
|
+
edgeDocId: any;
|
|
27
24
|
}) => Promise<TagType>;
|
|
28
|
-
export declare const
|
|
29
|
-
export declare const
|
|
30
|
-
|
|
31
|
-
|
|
25
|
+
export declare const extractTags: (content: string) => string[];
|
|
26
|
+
export declare const updateTagsInItem: (context: ApiContext, { itemDocId, tags }: {
|
|
27
|
+
itemDocId: any;
|
|
28
|
+
tags: any;
|
|
29
|
+
}) => Promise<TagType[]>;
|