@nlabs/reaktor 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (154) hide show
  1. package/.vscode/extensions.json +15 -0
  2. package/.vscode/settings.json +82 -0
  3. package/README.md +211 -0
  4. package/index.d.ts +1 -0
  5. package/index.js +5 -0
  6. package/lex.config.js +4 -0
  7. package/lib/config.d.ts +21 -0
  8. package/lib/config.js +127 -0
  9. package/lib/data/conversations.d.ts +6 -0
  10. package/lib/data/conversations.js +201 -0
  11. package/lib/data/dynamodb.d.ts +8 -0
  12. package/lib/data/dynamodb.js +139 -0
  13. package/lib/data/email.d.ts +7 -0
  14. package/lib/data/email.js +164 -0
  15. package/lib/data/files.d.ts +16 -0
  16. package/lib/data/files.js +407 -0
  17. package/lib/data/groups.d.ts +13 -0
  18. package/lib/data/groups.js +354 -0
  19. package/lib/data/images.d.ts +12 -0
  20. package/lib/data/images.js +668 -0
  21. package/lib/data/index.d.ts +19 -0
  22. package/lib/data/index.js +24 -0
  23. package/lib/data/ios.d.ts +6 -0
  24. package/lib/data/ios.js +302 -0
  25. package/lib/data/locations.d.ts +3 -0
  26. package/lib/data/locations.js +132 -0
  27. package/lib/data/messages.d.ts +9 -0
  28. package/lib/data/messages.js +248 -0
  29. package/lib/data/notifications.d.ts +5 -0
  30. package/lib/data/notifications.js +42 -0
  31. package/lib/data/payments.d.ts +11 -0
  32. package/lib/data/payments.js +748 -0
  33. package/lib/data/posts.d.ts +14 -0
  34. package/lib/data/posts.js +458 -0
  35. package/lib/data/reactions.d.ts +6 -0
  36. package/lib/data/reactions.js +218 -0
  37. package/lib/data/s3.d.ts +6 -0
  38. package/lib/data/s3.js +103 -0
  39. package/lib/data/search.d.ts +3 -0
  40. package/lib/data/search.js +98 -0
  41. package/lib/data/sms.d.ts +3 -0
  42. package/lib/data/sms.js +59 -0
  43. package/lib/data/subscription.d.ts +7 -0
  44. package/lib/data/subscription.js +284 -0
  45. package/lib/data/tags.d.ts +14 -0
  46. package/lib/data/tags.js +304 -0
  47. package/lib/data/users.d.ts +12 -0
  48. package/lib/data/users.js +312 -0
  49. package/lib/index.d.ts +3 -0
  50. package/lib/index.js +8 -0
  51. package/lib/types/apps.d.ts +44 -0
  52. package/lib/types/apps.js +2 -0
  53. package/lib/types/arangodb.d.ts +17 -0
  54. package/lib/types/arangodb.js +2 -0
  55. package/lib/types/auth.d.ts +9 -0
  56. package/lib/types/auth.js +2 -0
  57. package/lib/types/conversations.d.ts +6 -0
  58. package/lib/types/conversations.js +2 -0
  59. package/lib/types/email.d.ts +12 -0
  60. package/lib/types/email.js +2 -0
  61. package/lib/types/files.d.ts +28 -0
  62. package/lib/types/files.js +2 -0
  63. package/lib/types/google.d.ts +27 -0
  64. package/lib/types/google.js +2 -0
  65. package/lib/types/groups.d.ts +22 -0
  66. package/lib/types/groups.js +2 -0
  67. package/lib/types/images.d.ts +25 -0
  68. package/lib/types/images.js +2 -0
  69. package/lib/types/index.d.ts +17 -0
  70. package/lib/types/index.js +22 -0
  71. package/lib/types/locations.d.ts +21 -0
  72. package/lib/types/locations.js +2 -0
  73. package/lib/types/messages.d.ts +12 -0
  74. package/lib/types/messages.js +2 -0
  75. package/lib/types/notifications.d.ts +19 -0
  76. package/lib/types/notifications.js +2 -0
  77. package/lib/types/payments.d.ts +119 -0
  78. package/lib/types/payments.js +2 -0
  79. package/lib/types/posts.d.ts +20 -0
  80. package/lib/types/posts.js +2 -0
  81. package/lib/types/reactions.d.ts +4 -0
  82. package/lib/types/reactions.js +2 -0
  83. package/lib/types/tags.d.ts +10 -0
  84. package/lib/types/tags.js +2 -0
  85. package/lib/types/users.d.ts +78 -0
  86. package/lib/types/users.js +2 -0
  87. package/lib/utils/analytics.d.ts +3 -0
  88. package/lib/utils/analytics.js +47 -0
  89. package/lib/utils/arangodb.d.ts +9 -0
  90. package/lib/utils/arangodb.js +98 -0
  91. package/lib/utils/auth.d.ts +2 -0
  92. package/lib/utils/auth.js +43 -0
  93. package/lib/utils/index.d.ts +5 -0
  94. package/lib/utils/index.js +10 -0
  95. package/lib/utils/objects.d.ts +3 -0
  96. package/lib/utils/objects.js +34 -0
  97. package/lib/utils/redis.d.ts +1 -0
  98. package/lib/utils/redis.js +15 -0
  99. package/package.json +75 -0
  100. package/src/config.ts +121 -0
  101. package/src/data/conversations.ts +183 -0
  102. package/src/data/dynamodb.ts +157 -0
  103. package/src/data/email.ts +164 -0
  104. package/src/data/files.ts +352 -0
  105. package/src/data/groups.ts +308 -0
  106. package/src/data/images.ts +606 -0
  107. package/src/data/index.ts +23 -0
  108. package/src/data/ios.ts +249 -0
  109. package/src/data/locations.ts +114 -0
  110. package/src/data/messages.ts +237 -0
  111. package/src/data/notifications.ts +48 -0
  112. package/src/data/payments.ts +675 -0
  113. package/src/data/posts.ts +508 -0
  114. package/src/data/reactions.ts +186 -0
  115. package/src/data/s3.ts +117 -0
  116. package/src/data/search.ts +74 -0
  117. package/src/data/sms.ts +60 -0
  118. package/src/data/subscription.ts +228 -0
  119. package/src/data/tags.ts +230 -0
  120. package/src/data/users.ts +256 -0
  121. package/src/index.ts +7 -0
  122. package/src/types/apps.ts +57 -0
  123. package/src/types/arangodb.ts +23 -0
  124. package/src/types/auth.ts +19 -0
  125. package/src/types/conversations.ts +11 -0
  126. package/src/types/email.ts +17 -0
  127. package/src/types/files.ts +33 -0
  128. package/src/types/google.ts +37 -0
  129. package/src/types/groups.ts +28 -0
  130. package/src/types/images.ts +33 -0
  131. package/src/types/index.ts +21 -0
  132. package/src/types/locations.ts +25 -0
  133. package/src/types/messages.ts +16 -0
  134. package/src/types/notifications.ts +26 -0
  135. package/src/types/payments.ts +134 -0
  136. package/src/types/posts.ts +25 -0
  137. package/src/types/reactions.ts +8 -0
  138. package/src/types/tags.ts +14 -0
  139. package/src/types/users.ts +89 -0
  140. package/src/utils/analytics.ts +41 -0
  141. package/src/utils/arangodb.ts +100 -0
  142. package/src/utils/auth.ts +28 -0
  143. package/src/utils/index.ts +9 -0
  144. package/src/utils/objects.ts +34 -0
  145. package/src/utils/redis.ts +17 -0
  146. package/templates/email/layout.html +279 -0
  147. package/templates/email/passwordForgot.html +15 -0
  148. package/templates/email/passwordRecovery.html +12 -0
  149. package/templates/email/verifyEmail.html +15 -0
  150. package/templates/sms/passwordForgot.txt +1 -0
  151. package/templates/sms/passwordRecovery.txt +1 -0
  152. package/templates/sms/verifyEmail.txt +1 -0
  153. package/templates/sms/verifyPhone.txt +1 -0
  154. package/tsconfig.json +45 -0
@@ -0,0 +1,284 @@
1
+ function _templateObject3() {
2
+ var data = _taggedTemplateLiteral(["UPDATE s WITH ", " IN subscriptions"]);
3
+
4
+ _templateObject3 = function _templateObject3() {
5
+ return data;
6
+ };
7
+
8
+ return data;
9
+ }
10
+
11
+ function _templateObject2() {
12
+ var data = _taggedTemplateLiteral(["INSERT ", " IN plans RETURN NEW"]);
13
+
14
+ _templateObject2 = function _templateObject2() {
15
+ return data;
16
+ };
17
+
18
+ return data;
19
+ }
20
+
21
+ function _templateObject() {
22
+ var data = _taggedTemplateLiteral(["INSERT ", " IN plans RETURN NEW"]);
23
+
24
+ _templateObject = function _templateObject() {
25
+ return data;
26
+ };
27
+
28
+ return data;
29
+ }
30
+
31
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
32
+
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
+ var eventCategory = 'subscription';
45
+ export var getPlanList = function getPlanList(context) {
46
+ var from = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
47
+ var to = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
48
+ var action = 'getList';
49
+ var database = context.database;
50
+ var limit = getLimit(from, to);
51
+ 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) {
53
+ return cursor.all();
54
+ }).then(function () {
55
+ var list = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
56
+ return list;
57
+ }).catch(function (error) {
58
+ return logError({
59
+ action: action,
60
+ category: eventCategory,
61
+ label: 'db_error'
62
+ }, error, {}).then(function () {
63
+ return null;
64
+ }).catch(function (error) {
65
+ return Promise.reject(error);
66
+ });
67
+ });
68
+ };
69
+ export var getSubscription = function getSubscription(context) {
70
+ var action = 'getItem';
71
+ var database = context.database,
72
+ sessionId = context.userId;
73
+ 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) {
75
+ return cursor.next();
76
+ }).then(function () {
77
+ var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
78
+ return subscription;
79
+ }).catch(function (error) {
80
+ return logError({
81
+ action: action,
82
+ category: eventCategory,
83
+ label: 'db_error'
84
+ }, error, {}).then(function () {
85
+ return null;
86
+ }).catch(function (error) {
87
+ return Promise.reject(error);
88
+ });
89
+ });
90
+ };
91
+ export var addPlan = function addPlan(context, item) {
92
+ var action = 'addPlan';
93
+ var database = context.database,
94
+ sessionId = context.userId,
95
+ userType = context.userType;
96
+ var isAdmin = userType > 2;
97
+
98
+ if (!isAdmin) {
99
+ return logException({
100
+ action: action,
101
+ category: eventCategory,
102
+ label: 'unauthorized',
103
+ value: 'invalid_session'
104
+ }, context).then(function () {
105
+ return null;
106
+ });
107
+ }
108
+
109
+ var now = Date.now();
110
+ var formatId = parseId(item.id);
111
+ var planId = formatId === '' ? createHash("tag-".concat(sessionId)) : formatId;
112
+ var amount = item.amount,
113
+ _item$currency = item.currency,
114
+ currency = _item$currency === void 0 ? 'USD' : _item$currency,
115
+ description = item.description,
116
+ interval = item.interval,
117
+ intervalCount = item.intervalCount,
118
+ 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);
124
+ var insert = {
125
+ _key: planId,
126
+ added: now,
127
+ amount: formatAmount,
128
+ currency: currency,
129
+ description: formatDesc,
130
+ interval: formatInterval,
131
+ intervalCount: formatIntervalCnt,
132
+ modified: now,
133
+ name: formatName
134
+ };
135
+ var aqlQry = aql(_templateObject(), insert);
136
+ return useDb(database).query(aqlQry).then(function (cursor) {
137
+ return cursor.next();
138
+ }).then(function () {
139
+ var plan = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
140
+ // Stripe
141
+ var stripeClient = stripe(Config.get('stripe.token'));
142
+ return stripeClient.plans.create({
143
+ amount: formatAmount * 100,
144
+ currency: currency,
145
+ id: planId,
146
+ interval: formatInterval,
147
+ interval_count: formatIntervalCnt,
148
+ metadata: {},
149
+ name: formatName,
150
+ statement_descriptor: formatDesc
151
+ }).then(function () {
152
+ return plan;
153
+ });
154
+ }).catch(function (error) {
155
+ return logError({
156
+ action: action,
157
+ category: eventCategory,
158
+ label: 'db_error'
159
+ }, error, {}).then(function () {
160
+ return null;
161
+ }).catch(function (error) {
162
+ return Promise.reject(error);
163
+ });
164
+ });
165
+ };
166
+ export var addSubscription = function addSubscription(context, item) {
167
+ var action = 'addSubscription';
168
+ var database = context.database,
169
+ sessionId = context.userId,
170
+ userType = context.userType;
171
+ var isAdmin = userType > 2;
172
+
173
+ if (!isAdmin) {
174
+ return logException({
175
+ action: action,
176
+ category: eventCategory,
177
+ label: 'unauthorized',
178
+ value: 'invalid_session'
179
+ }, context).then(function () {
180
+ return null;
181
+ });
182
+ }
183
+
184
+ var now = Date.now();
185
+ var formatId = parseId(item.id);
186
+ var subscriptionId = formatId === '' ? createHash("tag-".concat(sessionId)) : formatId;
187
+ var planId = item.planId,
188
+ tax = item.tax,
189
+ trialEnd = item.trialEnd,
190
+ trialPeriod = item.trialPeriod;
191
+ var formatPlanId = parseId(planId);
192
+ var formatTaxPercent = parseNum(tax) || 0;
193
+ var formatTrialPeriod = parseNum(tax) || 0;
194
+ var formatTrialEnd = trialEnd || Date.now();
195
+
196
+ if (formatTrialPeriod) {
197
+ formatTrialEnd = DateTime.local().plus({
198
+ days: trialPeriod
199
+ }).toMillis();
200
+ }
201
+
202
+ return getUser(context, sessionId).then(function (user) {
203
+ var insert = {
204
+ _key: subscriptionId,
205
+ added: now,
206
+ cancelDate: 0,
207
+ modified: now,
208
+ planId: formatPlanId,
209
+ tax: formatTaxPercent,
210
+ trialEnd: formatTrialEnd,
211
+ userId: sessionId
212
+ };
213
+ var aqlQry = aql(_templateObject2(), insert);
214
+ return useDb(database).query(aqlQry).then(function (cursor) {
215
+ return cursor.next();
216
+ }).then(function () {
217
+ var subscription = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
218
+ // Stripe
219
+ var stripeClient = stripe(Config.get('stripe.token'));
220
+ return stripeClient.subscriptions.create({
221
+ customer: user.stripeCustomerId,
222
+ items: [{
223
+ plan: formatPlanId
224
+ }],
225
+ metadata: {
226
+ userId: sessionId
227
+ },
228
+ tax_percent: formatTaxPercent * 100,
229
+ trial_end: formatTrialEnd
230
+ }).then(function () {
231
+ return subscription;
232
+ });
233
+ }).catch(function (error) {
234
+ return logError({
235
+ action: action,
236
+ category: eventCategory,
237
+ label: 'db_error'
238
+ }, error, {}).then(function () {
239
+ return null;
240
+ }).catch(function (error) {
241
+ return Promise.reject(error);
242
+ });
243
+ });
244
+ });
245
+ };
246
+ export var deleteSubscription = function deleteSubscription(context, endDate) {
247
+ var action = 'deleteSubscription';
248
+ var database = context.database;
249
+ var now = Date.now();
250
+ var formatEndDate = parseNum(endDate) || now;
251
+ return getSubscription(context).then(function (subscription) {
252
+ // Stripe
253
+ var stripeClient = stripe(Config.get('stripe.token'));
254
+ return stripeClient.subscriptions.del(subscription.transactionId, {
255
+ subscription: formatEndDate
256
+ }).then(function (stripeResponse) {
257
+ // Make sure we cancelled on Stripe before updating the db
258
+ if (stripeResponse.cancelled || stripeResponse.cancel_at_period_end) {
259
+ var update = {
260
+ cancelDate: formatEndDate,
261
+ modified: now,
262
+ planId: ''
263
+ };
264
+ var aqlQry = aql(_templateObject3(), update);
265
+ return useDb(database).query(aqlQry).then(function () {
266
+ return true;
267
+ }).catch(function (error) {
268
+ return logError({
269
+ action: action,
270
+ category: eventCategory,
271
+ label: 'db_error'
272
+ }, error, {}).then(function () {
273
+ return null;
274
+ }).catch(function (error) {
275
+ return Promise.reject(error);
276
+ });
277
+ });
278
+ }
279
+
280
+ return false;
281
+ });
282
+ });
283
+ };
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"]}
@@ -0,0 +1,14 @@
1
+ import { Database } from 'arangojs';
2
+ import { ApiContext } from '../types/auth';
3
+ import { PostType } from '../types/posts';
4
+ import { TagType } from '../types/tags';
5
+ export declare const getTagList: (context: ApiContext, from?: number, to?: number) => Promise<TagType[]>;
6
+ export declare const getTag: (context: ApiContext, tagId: string) => Promise<TagType>;
7
+ export declare const addTag: (context: ApiContext, tag: TagType) => Promise<TagType>;
8
+ export declare const tagPost: (context: ApiContext, tagId: any, postId: any) => Promise<PostType>;
9
+ export declare const updateTag: (context: ApiContext, item?: TagType) => Promise<TagType>;
10
+ export declare const deleteTag: (context: ApiContext, tagId: string) => Promise<TagType>;
11
+ export declare const extractTags: (db: Database, itemType: string, itemId: any, content: any) => Promise<TagType[]>;
12
+ export declare const createTag: (db: Database, tagName: string) => Promise<TagType>;
13
+ export declare const createTagEdge: (db: Database, tag: TagType, itemType: string, itemId: string) => Promise<TagType>;
14
+ export declare const linkTags: (db: Database, tagNames: string[], itemType: string, itemId: string) => Promise<TagType[]>;