@nlabs/reaktor 0.3.0 → 0.4.1
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/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +333 -0
- package/lib/actions/dynamodb.js +155 -0
- package/lib/actions/email.js +177 -0
- package/lib/actions/files.js +319 -0
- package/lib/{data → actions}/groups.d.ts +4 -3
- package/lib/actions/groups.js +282 -0
- package/lib/actions/images.d.ts +22 -0
- package/lib/actions/images.js +682 -0
- package/lib/actions/index.js +40 -0
- package/lib/{data → actions}/ios.d.ts +2 -1
- package/lib/actions/ios.js +179 -0
- package/lib/actions/locations.js +112 -0
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +216 -0
- package/lib/actions/notifications.js +63 -0
- package/lib/{data → actions}/payments.d.ts +2 -2
- package/lib/actions/payments.js +491 -0
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +538 -0
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +340 -0
- package/lib/{data → actions}/s3.d.ts +1 -1
- package/lib/actions/s3.js +122 -0
- package/lib/{data → actions}/search.d.ts +2 -2
- package/lib/actions/search.js +99 -0
- package/lib/actions/sms.js +76 -0
- package/lib/actions/statistics.d.ts +2 -0
- package/lib/actions/statistics.js +63 -0
- package/lib/actions/subscription.js +209 -0
- package/lib/actions/tags.d.ts +26 -0
- package/lib/actions/tags.js +340 -0
- package/lib/actions/users.d.ts +44 -0
- package/lib/actions/users.js +571 -0
- package/lib/{data → actions}/websockets.d.ts +1 -1
- package/lib/actions/websockets.js +156 -0
- package/lib/config.d.ts +2 -3
- package/lib/config.js +120 -0
- package/lib/index.d.ts +1 -1
- package/lib/index.js +23 -0
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/layout.js +292 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordForgot.js +28 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.js +25 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/verifyEmail.js +28 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/email/welcome.js +28 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.js +14 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.js +14 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.js +14 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.js +14 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/templates/sms/welcome.js +14 -0
- package/lib/types/apps.d.ts +2 -2
- package/lib/types/apps.js +4 -0
- package/lib/types/arangodb.js +4 -0
- package/lib/types/auth.d.ts +4 -8
- package/lib/types/auth.js +4 -0
- package/lib/types/conversations.d.ts +5 -3
- package/lib/types/conversations.js +4 -0
- package/lib/types/email.d.ts +2 -2
- package/lib/types/email.js +4 -0
- package/lib/types/files.js +4 -0
- package/lib/types/google.js +4 -0
- package/lib/types/groups.d.ts +2 -1
- package/lib/types/groups.js +4 -0
- package/lib/types/images.d.ts +8 -5
- package/lib/types/images.js +4 -0
- package/lib/types/index.d.ts +1 -1
- package/lib/types/index.js +37 -0
- package/lib/types/locations.js +4 -0
- package/lib/types/messages.d.ts +12 -2
- package/lib/types/messages.js +4 -0
- package/lib/types/notifications.d.ts +2 -2
- package/lib/types/notifications.js +4 -0
- package/lib/types/payments.js +4 -0
- package/lib/types/posts.d.ts +18 -1
- package/lib/types/posts.js +4 -0
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +4 -0
- package/lib/types/tags.d.ts +6 -0
- package/lib/types/tags.js +4 -0
- package/lib/types/users.d.ts +15 -10
- package/lib/types/users.js +4 -0
- package/lib/utils/analytics.d.ts +7 -0
- package/lib/utils/analytics.js +107 -0
- package/lib/utils/arangodb.d.ts +1 -1
- package/lib/utils/arangodb.js +122 -0
- package/lib/utils/auth.js +78 -0
- package/lib/utils/graphql.js +40 -0
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +26 -0
- package/lib/utils/objects.js +53 -0
- package/lib/utils/session.d.ts +18 -0
- package/lib/utils/session.js +42 -0
- package/package.json +35 -33
- package/lib/data/conversations.d.ts +0 -8
- package/lib/data/images.d.ts +0 -21
- package/lib/data/messages.d.ts +0 -9
- package/lib/data/posts.d.ts +0 -23
- package/lib/data/reactions.d.ts +0 -14
- package/lib/data/tags.d.ts +0 -14
- package/lib/data/users.d.ts +0 -17
- package/lib/types/reactions.d.ts +0 -15
- package/lib/utils/redis.d.ts +0 -1
- package/templates/email/layout.html +0 -279
- package/templates/email/passwordForgot.html +0 -15
- package/templates/email/passwordRecovery.html +0 -12
- package/templates/email/verifyEmail.html +0 -15
- package/templates/sms/passwordForgot.txt +0 -1
- package/templates/sms/passwordRecovery.txt +0 -1
- package/templates/sms/verifyEmail.txt +0 -1
- package/templates/sms/verifyPhone.txt +0 -1
- /package/lib/{data → actions}/dynamodb.d.ts +0 -0
- /package/lib/{data → actions}/email.d.ts +0 -0
- /package/lib/{data → actions}/files.d.ts +0 -0
- /package/lib/{data → actions}/index.d.ts +0 -0
- /package/lib/{data → actions}/locations.d.ts +0 -0
- /package/lib/{data → actions}/notifications.d.ts +0 -0
- /package/lib/{data → actions}/sms.d.ts +0 -0
- /package/lib/{data → actions}/subscription.d.ts +0 -0
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
__markAsModule(target);
|
|
10
|
+
for (var name in all)
|
|
11
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
12
|
+
};
|
|
13
|
+
var __reExport = (target, module2, desc) => {
|
|
14
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
15
|
+
for (let key of __getOwnPropNames(module2))
|
|
16
|
+
if (!__hasOwnProp.call(target, key) && key !== "default")
|
|
17
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
18
|
+
}
|
|
19
|
+
return target;
|
|
20
|
+
};
|
|
21
|
+
var __toModule = (module2) => {
|
|
22
|
+
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
23
|
+
};
|
|
24
|
+
__export(exports, {
|
|
25
|
+
clearBadges: () => clearBadges,
|
|
26
|
+
getApnProvider: () => getApnProvider,
|
|
27
|
+
pushNotification: () => pushNotification
|
|
28
|
+
});
|
|
29
|
+
var import_apn = __toModule(require("apn"));
|
|
30
|
+
var import_config = __toModule(require("../config"));
|
|
31
|
+
const getApnProvider = () => new import_apn.Provider({
|
|
32
|
+
ca: import_config.Config.get("app.apn.ca"),
|
|
33
|
+
cert: import_config.Config.get("app.apn.cert"),
|
|
34
|
+
key: import_config.Config.get("app.apn.key"),
|
|
35
|
+
production: import_config.Config.get("environment") === "prod"
|
|
36
|
+
});
|
|
37
|
+
const pushNotification = (deviceTokens, note) => {
|
|
38
|
+
const provider = getApnProvider();
|
|
39
|
+
const notification = new import_apn.Notification();
|
|
40
|
+
notification.topic = import_config.Config.get("app.apn.id");
|
|
41
|
+
notification.alert = note.message;
|
|
42
|
+
if (note.data) {
|
|
43
|
+
notification.mutableContent = true;
|
|
44
|
+
notification.payload = note.data;
|
|
45
|
+
}
|
|
46
|
+
if (note.badge !== void 0) {
|
|
47
|
+
notification.badge = note.badge;
|
|
48
|
+
}
|
|
49
|
+
return provider.send(notification, deviceTokens);
|
|
50
|
+
};
|
|
51
|
+
const clearBadges = (deviceTokens) => {
|
|
52
|
+
const provider = getApnProvider();
|
|
53
|
+
const notification = new import_apn.Notification();
|
|
54
|
+
notification.badge = 0;
|
|
55
|
+
return provider.send(notification, deviceTokens);
|
|
56
|
+
};
|
|
57
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
58
|
+
0 && (module.exports = {
|
|
59
|
+
clearBadges,
|
|
60
|
+
getApnProvider,
|
|
61
|
+
pushNotification
|
|
62
|
+
});
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvbm90aWZpY2F0aW9ucy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Tm90aWZpY2F0aW9uIGFzIEFQTk5vdGlmaWNhdGlvbiwgUHJvdmlkZXIsIFJlc3BvbnNlc30gZnJvbSAnYXBuJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge05vdGlmaWNhdGlvblR5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuXG4vLyBjb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnbm90aWZpY2F0aW9ucyc7XG5cbi8vIFB1c2ggTm90aWZpY2F0aW9uc1xuZXhwb3J0IGNvbnN0IGdldEFwblByb3ZpZGVyID0gKCk6IFByb3ZpZGVyID0+IG5ldyBQcm92aWRlcih7XG4gIGNhOiBDb25maWcuZ2V0KCdhcHAuYXBuLmNhJyksXG4gIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICBrZXk6IENvbmZpZy5nZXQoJ2FwcC5hcG4ua2V5JyksXG4gIHByb2R1Y3Rpb246IENvbmZpZy5nZXQoJ2Vudmlyb25tZW50JykgPT09ICdwcm9kJ1xufSk7XG5cbmV4cG9ydCBjb25zdCBwdXNoTm90aWZpY2F0aW9uID0gKGRldmljZVRva2Vuczogc3RyaW5nW10sIG5vdGU6IE5vdGlmaWNhdGlvblR5cGUpOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXI6IFByb3ZpZGVyID0gZ2V0QXBuUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uOiBBUE5Ob3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi50b3BpYyA9IENvbmZpZy5nZXQoJ2FwcC5hcG4uaWQnKTtcbiAgbm90aWZpY2F0aW9uLmFsZXJ0ID0gbm90ZS5tZXNzYWdlO1xuXG4gIGlmKG5vdGUuZGF0YSkge1xuICAgIG5vdGlmaWNhdGlvbi5tdXRhYmxlQ29udGVudCA9IHRydWU7XG4gICAgbm90aWZpY2F0aW9uLnBheWxvYWQgPSBub3RlLmRhdGE7XG4gIH1cblxuICBpZihub3RlLmJhZGdlICE9PSB1bmRlZmluZWQpIHtcbiAgICBub3RpZmljYXRpb24uYmFkZ2UgPSBub3RlLmJhZGdlO1xuICB9XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNsZWFyQmFkZ2VzID0gKGRldmljZVRva2Vuczogc3RyaW5nW10pOiBQcm9taXNlPFJlc3BvbnNlcz4gPT4ge1xuICAvLyBQdXNoIG5vdGlmaWNhdGlvbiB0byBkZXZpY2VcbiAgY29uc3QgcHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb24gPSBuZXcgQVBOTm90aWZpY2F0aW9uKCk7XG4gIG5vdGlmaWNhdGlvbi5iYWRnZSA9IDA7XG5cbiAgcmV0dXJuIHByb3ZpZGVyLnNlbmQobm90aWZpY2F0aW9uLCBkZXZpY2VUb2tlbnMpO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLGlCQUFtRTtBQUVuRSxvQkFBcUI7QUFNZCxNQUFNLGlCQUFpQixNQUFnQixJQUFJLG9CQUFTO0FBQUEsRUFDekQsSUFBSSxxQkFBTyxJQUFJO0FBQUEsRUFDZixNQUFNLHFCQUFPLElBQUk7QUFBQSxFQUNqQixLQUFLLHFCQUFPLElBQUk7QUFBQSxFQUNoQixZQUFZLHFCQUFPLElBQUksbUJBQW1CO0FBQUE7QUFHckMsTUFBTSxtQkFBbUIsQ0FBQyxjQUF3QixTQUErQztBQUV0RyxRQUFNLFdBQXFCO0FBQzNCLFFBQU0sZUFBZ0MsSUFBSTtBQUMxQyxlQUFhLFFBQVEscUJBQU8sSUFBSTtBQUNoQyxlQUFhLFFBQVEsS0FBSztBQUUxQixNQUFHLEtBQUssTUFBTTtBQUNaLGlCQUFhLGlCQUFpQjtBQUM5QixpQkFBYSxVQUFVLEtBQUs7QUFBQTtBQUc5QixNQUFHLEtBQUssVUFBVSxRQUFXO0FBQzNCLGlCQUFhLFFBQVEsS0FBSztBQUFBO0FBRzVCLFNBQU8sU0FBUyxLQUFLLGNBQWM7QUFBQTtBQUc5QixNQUFNLGNBQWMsQ0FBQyxpQkFBK0M7QUFFekUsUUFBTSxXQUFXO0FBQ2pCLFFBQU0sZUFBZSxJQUFJO0FBQ3pCLGVBQWEsUUFBUTtBQUVyQixTQUFPLFNBQVMsS0FBSyxjQUFjO0FBQUE7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer,
|
|
1
|
+
import { ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, User } from '../types';
|
|
2
2
|
export declare const addCustomerAccount: (context: ApiContext) => Promise<boolean>;
|
|
3
3
|
export declare const addBankAccount: (context: ApiContext, bankAccount: PaymentBankAccount) => Promise<boolean>;
|
|
4
|
-
export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<
|
|
4
|
+
export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<User>;
|
|
5
5
|
export declare const updateCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<PaymentCardType>;
|
|
6
6
|
export declare const getCreditCards: (context: ApiContext) => Promise<PaymentCardType[]>;
|
|
7
7
|
export declare const deleteCreditCard: (context: ApiContext, cardId: string) => Promise<boolean>;
|
|
@@ -0,0 +1,491 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defProps = Object.defineProperties;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
9
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
+
var __spreadValues = (a, b) => {
|
|
13
|
+
for (var prop in b || (b = {}))
|
|
14
|
+
if (__hasOwnProp.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
if (__getOwnPropSymbols)
|
|
17
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
+
if (__propIsEnum.call(b, prop))
|
|
19
|
+
__defNormalProp(a, prop, b[prop]);
|
|
20
|
+
}
|
|
21
|
+
return a;
|
|
22
|
+
};
|
|
23
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
25
|
+
var __export = (target, all) => {
|
|
26
|
+
__markAsModule(target);
|
|
27
|
+
for (var name in all)
|
|
28
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
29
|
+
};
|
|
30
|
+
var __reExport = (target, module2, desc) => {
|
|
31
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
32
|
+
for (let key of __getOwnPropNames(module2))
|
|
33
|
+
if (!__hasOwnProp.call(target, key) && key !== "default")
|
|
34
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
35
|
+
}
|
|
36
|
+
return target;
|
|
37
|
+
};
|
|
38
|
+
var __toModule = (module2) => {
|
|
39
|
+
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
40
|
+
};
|
|
41
|
+
__export(exports, {
|
|
42
|
+
addBankAccount: () => addBankAccount,
|
|
43
|
+
addCreditCard: () => addCreditCard,
|
|
44
|
+
addCustomerAccount: () => addCustomerAccount,
|
|
45
|
+
createPaymentHold: () => createPaymentHold,
|
|
46
|
+
createPaymentTransfer: () => createPaymentTransfer,
|
|
47
|
+
deleteBankAccount: () => deleteBankAccount,
|
|
48
|
+
deleteCreditCard: () => deleteCreditCard,
|
|
49
|
+
getCreditCards: () => getCreditCards,
|
|
50
|
+
updateCreditCard: () => updateCreditCard
|
|
51
|
+
});
|
|
52
|
+
var import_utils = __toModule(require("@nlabs/utils"));
|
|
53
|
+
var import_arangojs = __toModule(require("arangojs"));
|
|
54
|
+
var import_graphql_errors = __toModule(require("graphql-errors"));
|
|
55
|
+
var import_isEmpty = __toModule(require("lodash/isEmpty"));
|
|
56
|
+
var import_stripe = __toModule(require("stripe"));
|
|
57
|
+
var import_config = __toModule(require("../config"));
|
|
58
|
+
var import_analytics = __toModule(require("../utils/analytics"));
|
|
59
|
+
var import_users = __toModule(require("./users"));
|
|
60
|
+
const eventCategory = "payments";
|
|
61
|
+
const apiVersion = "2020-03-02";
|
|
62
|
+
const addCustomerAccount = (context) => {
|
|
63
|
+
const action = "addCustomerAccount";
|
|
64
|
+
const { database, session: { userId: sessionId, username } } = context;
|
|
65
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
66
|
+
return stripeClient.customers.create({
|
|
67
|
+
metadata: {
|
|
68
|
+
userId: sessionId,
|
|
69
|
+
username
|
|
70
|
+
}
|
|
71
|
+
}).then((customer) => {
|
|
72
|
+
const now = Date.now();
|
|
73
|
+
const update = {
|
|
74
|
+
modified: now,
|
|
75
|
+
stripeCustomerId: customer.id
|
|
76
|
+
};
|
|
77
|
+
const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
|
|
78
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser = {}) => !(0, import_isEmpty.default)(updatedUser)).catch((error) => (0, import_analytics.logError)({
|
|
79
|
+
action,
|
|
80
|
+
category: eventCategory,
|
|
81
|
+
label: "db_error"
|
|
82
|
+
}, error, context).then(() => null));
|
|
83
|
+
});
|
|
84
|
+
};
|
|
85
|
+
const addBankAccount = (context, bankAccount) => {
|
|
86
|
+
const action = "addPaymentAccountBank";
|
|
87
|
+
const { database, session: { userId: sessionId } } = context;
|
|
88
|
+
const {
|
|
89
|
+
accountNumber,
|
|
90
|
+
fullName,
|
|
91
|
+
routing
|
|
92
|
+
} = bankAccount;
|
|
93
|
+
const formatAccount = (0, import_utils.parseString)(accountNumber, 32);
|
|
94
|
+
if (formatAccount === "") {
|
|
95
|
+
throw new import_graphql_errors.UserError("required_account_number");
|
|
96
|
+
}
|
|
97
|
+
const formatFullName = (0, import_utils.parseVarChar)(fullName, 128);
|
|
98
|
+
if (formatFullName === "") {
|
|
99
|
+
throw new import_graphql_errors.UserError("required_full_name");
|
|
100
|
+
}
|
|
101
|
+
const formatRouting = (0, import_utils.parseString)(routing, 32);
|
|
102
|
+
if (formatRouting === "") {
|
|
103
|
+
throw new import_graphql_errors.UserError("required_routing_number");
|
|
104
|
+
}
|
|
105
|
+
return (0, import_users.getUser)(context, sessionId).then((user) => {
|
|
106
|
+
const { stripeAccountId } = user;
|
|
107
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
108
|
+
const source = {
|
|
109
|
+
account_holder_name: formatFullName,
|
|
110
|
+
account_holder_type: "individual",
|
|
111
|
+
account_number: formatAccount,
|
|
112
|
+
country: "US",
|
|
113
|
+
currency: "USD",
|
|
114
|
+
object: "bank_account",
|
|
115
|
+
routing_number: formatRouting
|
|
116
|
+
};
|
|
117
|
+
return stripeClient.customers.createSource(stripeAccountId, { source }).then((account) => {
|
|
118
|
+
const { id: bankId, last4: bankAccount2, routing_number: bankRouting } = account;
|
|
119
|
+
const update = {
|
|
120
|
+
bankAccount: bankAccount2,
|
|
121
|
+
bankFullName: formatFullName,
|
|
122
|
+
bankId,
|
|
123
|
+
bankRouting,
|
|
124
|
+
modified: Date.now()
|
|
125
|
+
};
|
|
126
|
+
const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
|
|
127
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedUser = {}) => updatedUser);
|
|
128
|
+
}).catch((error) => {
|
|
129
|
+
const msg = error.message;
|
|
130
|
+
if (msg === "A bank account with that routing number and account number already exists for this customer.") {
|
|
131
|
+
return (0, import_analytics.logError)({
|
|
132
|
+
action,
|
|
133
|
+
category: eventCategory,
|
|
134
|
+
label: "bank_account_exists"
|
|
135
|
+
}, error, context).then(() => null);
|
|
136
|
+
}
|
|
137
|
+
return (0, import_analytics.logError)({
|
|
138
|
+
action,
|
|
139
|
+
category: eventCategory,
|
|
140
|
+
label: "payment_error"
|
|
141
|
+
}, error, context).then(() => null);
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
};
|
|
145
|
+
const addCreditCard = (context, card) => {
|
|
146
|
+
const action = "addCreditCard";
|
|
147
|
+
const { database, session: { userId: sessionId } } = context;
|
|
148
|
+
return (0, import_users.getUser)(context, sessionId).then((user) => {
|
|
149
|
+
const { stripeAccountId } = user;
|
|
150
|
+
const {
|
|
151
|
+
accountNumber,
|
|
152
|
+
city,
|
|
153
|
+
country,
|
|
154
|
+
cvc,
|
|
155
|
+
expMonth,
|
|
156
|
+
expYear,
|
|
157
|
+
fullName,
|
|
158
|
+
street1,
|
|
159
|
+
street2,
|
|
160
|
+
state,
|
|
161
|
+
zip
|
|
162
|
+
} = card;
|
|
163
|
+
const formatNumber = (0, import_utils.parseNum)(accountNumber, 16);
|
|
164
|
+
if (!formatNumber) {
|
|
165
|
+
throw new import_graphql_errors.UserError("required_credit_card_number");
|
|
166
|
+
}
|
|
167
|
+
const formatExpMonth = (0, import_utils.parseNum)(expMonth, 2);
|
|
168
|
+
if (!formatExpMonth) {
|
|
169
|
+
throw new import_graphql_errors.UserError("required_credit_card_exp_month");
|
|
170
|
+
}
|
|
171
|
+
const formatExpYear = (0, import_utils.parseNum)(expYear, 2);
|
|
172
|
+
if (!formatExpYear) {
|
|
173
|
+
throw new import_graphql_errors.UserError("required_credit_card_exp_year");
|
|
174
|
+
}
|
|
175
|
+
const formatCvc = (0, import_utils.parseNum)(cvc, 3);
|
|
176
|
+
const paymentCard = {};
|
|
177
|
+
const formatCity = (0, import_utils.parseVarChar)(city, 32);
|
|
178
|
+
if (formatCity) {
|
|
179
|
+
paymentCard.city = formatCity;
|
|
180
|
+
}
|
|
181
|
+
const formatCountry = (0, import_utils.parseChar)(country, 2);
|
|
182
|
+
if (formatCountry) {
|
|
183
|
+
paymentCard.country = formatCountry;
|
|
184
|
+
}
|
|
185
|
+
const formatFullName = (0, import_utils.parseVarChar)(fullName, 32);
|
|
186
|
+
if (formatFullName) {
|
|
187
|
+
paymentCard.fullName = formatFullName;
|
|
188
|
+
}
|
|
189
|
+
const formatStreet1 = (0, import_utils.parseVarChar)(street1, 32);
|
|
190
|
+
if (formatStreet1) {
|
|
191
|
+
paymentCard.street1 = formatStreet1;
|
|
192
|
+
}
|
|
193
|
+
const formatStreet2 = (0, import_utils.parseVarChar)(street2, 32);
|
|
194
|
+
if (formatStreet2) {
|
|
195
|
+
paymentCard.street2 = formatStreet2;
|
|
196
|
+
}
|
|
197
|
+
const formatState = (0, import_utils.parseChar)(state, 2);
|
|
198
|
+
if (formatState) {
|
|
199
|
+
paymentCard.state = formatState;
|
|
200
|
+
}
|
|
201
|
+
const formatZip = (0, import_utils.parseVarChar)(zip, 10);
|
|
202
|
+
if (formatZip) {
|
|
203
|
+
paymentCard.zip = formatZip;
|
|
204
|
+
}
|
|
205
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
206
|
+
const source = {
|
|
207
|
+
address_city: formatCity,
|
|
208
|
+
address_country: formatCountry,
|
|
209
|
+
address_line1: formatStreet1,
|
|
210
|
+
address_line2: formatStreet2,
|
|
211
|
+
address_state: formatState,
|
|
212
|
+
address_zip: formatZip,
|
|
213
|
+
cvc: formatCvc,
|
|
214
|
+
exp_month: formatExpMonth,
|
|
215
|
+
exp_year: formatExpYear,
|
|
216
|
+
name: fullName,
|
|
217
|
+
number: formatNumber,
|
|
218
|
+
object: "card"
|
|
219
|
+
};
|
|
220
|
+
return stripeClient.customers.createSource(stripeAccountId, { source }).then((newSource) => {
|
|
221
|
+
const { brand, cvc_check: cvcCheck, last4 } = newSource;
|
|
222
|
+
const now = Date.now();
|
|
223
|
+
const insert = __spreadProps(__spreadValues({}, paymentCard), {
|
|
224
|
+
_key: (0, import_utils.createHash)(`user-payment-${sessionId}`),
|
|
225
|
+
accountNumber: last4,
|
|
226
|
+
added: now,
|
|
227
|
+
brand,
|
|
228
|
+
cvcCheck,
|
|
229
|
+
expMonth,
|
|
230
|
+
expYear,
|
|
231
|
+
modified: now,
|
|
232
|
+
userId: sessionId
|
|
233
|
+
});
|
|
234
|
+
const insertAqlQry = import_arangojs.aql`INSERT ${insert} IN creditCards RETURN NEW`;
|
|
235
|
+
return database.query(insertAqlQry).then((cursor) => cursor.next()).then((newCard = {}) => {
|
|
236
|
+
if (!(0, import_isEmpty.default)(newCard)) {
|
|
237
|
+
const { _id: cardId, _key: cardKey } = card;
|
|
238
|
+
const edgeCollection = database.collection("hasPayment");
|
|
239
|
+
const edgeId = (0, import_utils.createHash)(`payment-${cardKey}`);
|
|
240
|
+
const edge = {
|
|
241
|
+
_from: `users/${sessionId}`,
|
|
242
|
+
_key: edgeId,
|
|
243
|
+
_to: cardId
|
|
244
|
+
};
|
|
245
|
+
return edgeCollection.save(edge, { returnNew: true }).then(() => card);
|
|
246
|
+
}
|
|
247
|
+
return newCard;
|
|
248
|
+
}).catch((error) => (0, import_analytics.logError)({
|
|
249
|
+
action,
|
|
250
|
+
category: eventCategory,
|
|
251
|
+
label: "payment_error"
|
|
252
|
+
}, error, context).then(() => null));
|
|
253
|
+
});
|
|
254
|
+
});
|
|
255
|
+
};
|
|
256
|
+
const updateCreditCard = (context, card) => {
|
|
257
|
+
const { database, session: { userId: sessionId } } = context;
|
|
258
|
+
const {
|
|
259
|
+
city,
|
|
260
|
+
country,
|
|
261
|
+
expMonth,
|
|
262
|
+
expYear,
|
|
263
|
+
fullName,
|
|
264
|
+
id,
|
|
265
|
+
street1,
|
|
266
|
+
state,
|
|
267
|
+
zip
|
|
268
|
+
} = card;
|
|
269
|
+
const formatId = (0, import_utils.parseId)(id);
|
|
270
|
+
if (formatId) {
|
|
271
|
+
throw new import_graphql_errors.UserError("required_credit_card_id");
|
|
272
|
+
}
|
|
273
|
+
const paymentCard = {};
|
|
274
|
+
const formatExpMonth = (0, import_utils.parseNum)(expMonth, 2);
|
|
275
|
+
const formatExpYear = (0, import_utils.parseNum)(expYear, 2);
|
|
276
|
+
const formatCity = (0, import_utils.parseVarChar)(city, 32);
|
|
277
|
+
const formatCountry = (0, import_utils.parseChar)(country, 2);
|
|
278
|
+
const formatFullName = (0, import_utils.parseVarChar)(fullName, 32);
|
|
279
|
+
const formatStreet1 = (0, import_utils.parseString)(street1, 32);
|
|
280
|
+
const formatState = (0, import_utils.parseChar)(state, 2);
|
|
281
|
+
const formatZip = (0, import_utils.parseVarChar)(zip, 10);
|
|
282
|
+
if (formatExpMonth) {
|
|
283
|
+
paymentCard.expMonth = formatExpMonth;
|
|
284
|
+
}
|
|
285
|
+
if (formatExpYear) {
|
|
286
|
+
paymentCard.expYear = formatExpYear;
|
|
287
|
+
}
|
|
288
|
+
if (formatCity) {
|
|
289
|
+
paymentCard.city = formatCity;
|
|
290
|
+
}
|
|
291
|
+
if (formatCountry) {
|
|
292
|
+
paymentCard.country = formatCountry;
|
|
293
|
+
}
|
|
294
|
+
if (formatFullName) {
|
|
295
|
+
paymentCard.fullName = formatFullName;
|
|
296
|
+
}
|
|
297
|
+
if (formatStreet1) {
|
|
298
|
+
paymentCard.street1 = formatStreet1;
|
|
299
|
+
}
|
|
300
|
+
if (formatState) {
|
|
301
|
+
paymentCard.state = formatState;
|
|
302
|
+
}
|
|
303
|
+
if (formatZip) {
|
|
304
|
+
paymentCard.zip = formatZip;
|
|
305
|
+
}
|
|
306
|
+
const update = paymentCard;
|
|
307
|
+
const aqlQry = import_arangojs.aql`
|
|
308
|
+
LET updatedCard = FIRST(
|
|
309
|
+
FOR c IN creditCards
|
|
310
|
+
FILTER c._key == ${formatId} && c.userId == ${sessionId}
|
|
311
|
+
UPDATE c WITH ${update} IN creditCards
|
|
312
|
+
LIMIT 1
|
|
313
|
+
RETURN NEW
|
|
314
|
+
)
|
|
315
|
+
LET user = FIRST(
|
|
316
|
+
FOR u IN users
|
|
317
|
+
FILTER u._key == ${sessionId}
|
|
318
|
+
LIMIT 1
|
|
319
|
+
RETURN u
|
|
320
|
+
)
|
|
321
|
+
RETURN {user: user, card: updatedCard}`;
|
|
322
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((results = { card: {}, user: {} }) => {
|
|
323
|
+
const updatedCard = results.card;
|
|
324
|
+
const { user } = results;
|
|
325
|
+
if ((0, import_isEmpty.default)(updatedCard)) {
|
|
326
|
+
throw new import_graphql_errors.UserError("not_found");
|
|
327
|
+
}
|
|
328
|
+
const { stripeCustomerId } = user;
|
|
329
|
+
const { stripeId } = card;
|
|
330
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
331
|
+
const update2 = {
|
|
332
|
+
address_city: formatCity,
|
|
333
|
+
address_country: formatCountry,
|
|
334
|
+
address_line1: formatStreet1,
|
|
335
|
+
address_state: formatState,
|
|
336
|
+
address_zip: formatZip,
|
|
337
|
+
exp_month: formatExpMonth,
|
|
338
|
+
exp_year: formatExpYear,
|
|
339
|
+
name: formatFullName
|
|
340
|
+
};
|
|
341
|
+
return stripeClient.customers.updateSource(stripeCustomerId, stripeId, update2).then(() => card).catch((error) => {
|
|
342
|
+
console.log("payments::updateCard::error", error);
|
|
343
|
+
throw new import_graphql_errors.UserError("payment_error");
|
|
344
|
+
});
|
|
345
|
+
});
|
|
346
|
+
};
|
|
347
|
+
const getCreditCards = (context) => {
|
|
348
|
+
const action = "getCreditCards";
|
|
349
|
+
const { database, session: { userId: sessionId } } = context;
|
|
350
|
+
const aqlQry = import_arangojs.aql`FOR c IN creditCards
|
|
351
|
+
FILTER c.userId == ${sessionId}
|
|
352
|
+
RETURN c`;
|
|
353
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_analytics.logError)({
|
|
354
|
+
action,
|
|
355
|
+
category: eventCategory,
|
|
356
|
+
label: "db_error"
|
|
357
|
+
}, error, context).then(() => null));
|
|
358
|
+
};
|
|
359
|
+
const deleteCreditCard = (context, cardId) => {
|
|
360
|
+
const { database, session: { userId: sessionId } } = context;
|
|
361
|
+
const formatCardId = (0, import_utils.parseId)(cardId);
|
|
362
|
+
const aqlQry = import_arangojs.aql`
|
|
363
|
+
LET card = FIRST(
|
|
364
|
+
FOR c IN creditCards
|
|
365
|
+
FILTER c._key == ${formatCardId} && c.userId == ${sessionId}
|
|
366
|
+
LIMIT 1
|
|
367
|
+
REMOVE c IN creditCards
|
|
368
|
+
RETURN OLD
|
|
369
|
+
)
|
|
370
|
+
LET user = FIRST(
|
|
371
|
+
FOR u IN users
|
|
372
|
+
FILTER u._key == ${sessionId}
|
|
373
|
+
LIMIT 1
|
|
374
|
+
RETURN u
|
|
375
|
+
)
|
|
376
|
+
RETURN {user: user, card: card}`;
|
|
377
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((result = { card: {}, user: {} }) => {
|
|
378
|
+
if ((0, import_isEmpty.default)(result)) {
|
|
379
|
+
return false;
|
|
380
|
+
}
|
|
381
|
+
const { card, user } = result;
|
|
382
|
+
const { _key: cardKey } = card;
|
|
383
|
+
const edgeCollection = database.collection("hasPayment");
|
|
384
|
+
return edgeCollection.outEdges(cardKey).then((edges) => {
|
|
385
|
+
if (edges.length) {
|
|
386
|
+
return Promise.all(edges.map((edge) => {
|
|
387
|
+
const { _key: edgeKey } = edge;
|
|
388
|
+
const removeAqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN hasPayment`;
|
|
389
|
+
return database.query(removeAqlQry);
|
|
390
|
+
})).then(() => {
|
|
391
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
392
|
+
return stripeClient.customers.deleteSource(user.stripeCustomerId, card.stripeId).then(() => true).catch((error) => {
|
|
393
|
+
console.log("payments::deleteCard::error", error);
|
|
394
|
+
throw new import_graphql_errors.UserError("payment_error");
|
|
395
|
+
});
|
|
396
|
+
});
|
|
397
|
+
}
|
|
398
|
+
return false;
|
|
399
|
+
});
|
|
400
|
+
});
|
|
401
|
+
};
|
|
402
|
+
const deleteBankAccount = (context, bankId) => {
|
|
403
|
+
const { database, session: { userId: sessionId } } = context;
|
|
404
|
+
const update = {
|
|
405
|
+
bankAccount: "",
|
|
406
|
+
bankFullName: "",
|
|
407
|
+
bankId: "",
|
|
408
|
+
bankRouting: "",
|
|
409
|
+
modified: Date.now()
|
|
410
|
+
};
|
|
411
|
+
const aqlQry = import_arangojs.aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;
|
|
412
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((user = {}) => {
|
|
413
|
+
const { stripeAccountId } = user;
|
|
414
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
415
|
+
return stripeClient.customers.deleteSource(stripeAccountId, bankId).then((response = { deleted: false }) => response.deleted).catch(() => Promise.resolve(false));
|
|
416
|
+
});
|
|
417
|
+
};
|
|
418
|
+
const createPaymentTransfer = (context, transfer) => {
|
|
419
|
+
const { database, session: { userId: sessionId } } = context;
|
|
420
|
+
const { amount, currency } = transfer;
|
|
421
|
+
const formatAmount = (0, import_utils.parseNum)(amount);
|
|
422
|
+
const formatCurrency = (0, import_utils.parseChar)(currency, 3, "USD").toUpperCase();
|
|
423
|
+
return (0, import_users.getUser)(context, sessionId).then((user) => {
|
|
424
|
+
const { stripeAccountId } = user;
|
|
425
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
426
|
+
return stripeClient.transfers.create({
|
|
427
|
+
amount: formatAmount,
|
|
428
|
+
currency: formatCurrency,
|
|
429
|
+
destination: stripeAccountId
|
|
430
|
+
}).then((stripeTransfer) => {
|
|
431
|
+
console.log(stripeTransfer);
|
|
432
|
+
const now = Date.now();
|
|
433
|
+
const insert = {
|
|
434
|
+
added: now,
|
|
435
|
+
amount: formatAmount,
|
|
436
|
+
currency: formatCurrency,
|
|
437
|
+
modified: now,
|
|
438
|
+
userId: sessionId
|
|
439
|
+
};
|
|
440
|
+
const aqlQry = import_arangojs.aql`INSERT ${insert} IN transfers RETURN NEW`;
|
|
441
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((newTransfer) => newTransfer);
|
|
442
|
+
});
|
|
443
|
+
});
|
|
444
|
+
};
|
|
445
|
+
const createPaymentHold = (context, payment) => {
|
|
446
|
+
const { database, session: { userId: sessionId } } = context;
|
|
447
|
+
const { amount, capture, cardId, currency, description } = payment;
|
|
448
|
+
const formatCurrency = (0, import_utils.parseChar)(currency, 3, "USD").toUpperCase();
|
|
449
|
+
const stripeClient = new import_stripe.default(import_config.Config.get("stripe.token"), { apiVersion, typescript: true });
|
|
450
|
+
return stripeClient.charges.create({
|
|
451
|
+
amount,
|
|
452
|
+
capture,
|
|
453
|
+
currency: formatCurrency,
|
|
454
|
+
description,
|
|
455
|
+
source: cardId
|
|
456
|
+
}).then((stripeCharge) => {
|
|
457
|
+
const now = Date.now();
|
|
458
|
+
const insert = {
|
|
459
|
+
added: now,
|
|
460
|
+
amount,
|
|
461
|
+
capture,
|
|
462
|
+
cardId,
|
|
463
|
+
chargeFailCode: stripeCharge.failure_code,
|
|
464
|
+
chargeFailMsg: stripeCharge.failure_message,
|
|
465
|
+
chargeId: stripeCharge.id,
|
|
466
|
+
chargeStatus: stripeCharge.status,
|
|
467
|
+
currency: formatCurrency,
|
|
468
|
+
description,
|
|
469
|
+
modified: now,
|
|
470
|
+
userId: sessionId
|
|
471
|
+
};
|
|
472
|
+
const aqlQry = import_arangojs.aql`INSERT ${insert} IN payments RETURN NEW`;
|
|
473
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((newPayment) => newPayment);
|
|
474
|
+
}).catch((error) => {
|
|
475
|
+
console.log("payments::createHold::error", error);
|
|
476
|
+
throw new import_graphql_errors.UserError("payment_error");
|
|
477
|
+
});
|
|
478
|
+
};
|
|
479
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
480
|
+
0 && (module.exports = {
|
|
481
|
+
addBankAccount,
|
|
482
|
+
addCreditCard,
|
|
483
|
+
addCustomerAccount,
|
|
484
|
+
createPaymentHold,
|
|
485
|
+
createPaymentTransfer,
|
|
486
|
+
deleteBankAccount,
|
|
487
|
+
deleteCreditCard,
|
|
488
|
+
getCreditCards,
|
|
489
|
+
updateCreditCard
|
|
490
|
+
});
|
|
491
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/payments.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, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {UserError} from 'graphql-errors';\nimport isEmpty from 'lodash/isEmpty';\nimport Stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, User} from '../types';\nimport {logError} from '../utils/analytics';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'payments';\nconst apiVersion: any = '2020-03-02';\n\nexport const addCustomerAccount = (context: ApiContext): Promise<boolean> => {\n  const action: string = 'addCustomerAccount';\n  const {database, session: {userId: sessionId, username}} = context;\n\n  // Stripe\n  const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n  return stripeClient.customers\n    .create({\n      metadata: {\n        userId: sessionId,\n        username\n      }\n    })\n    .then((customer) => {\n      // Create session\n      const now: number = Date.now();\n      const update: User = {\n        modified: now,\n        stripeCustomerId: customer.id\n      };\n\n      const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedUser: User = {}) => !isEmpty(updatedUser))\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, context).then(() => null));\n    });\n};\n\nexport const addBankAccount = (context: ApiContext, bankAccount: PaymentBankAccount): Promise<boolean> => {\n  const action: string = 'addPaymentAccountBank';\n  const {database, session: {userId: sessionId}} = context;\n\n  // Params\n  const {\n    accountNumber,\n    fullName,\n    routing\n  } = bankAccount;\n\n  const formatAccount: string = parseString(accountNumber, 32);\n\n  if(formatAccount === '') {\n    throw new UserError('required_account_number');\n  }\n\n  const formatFullName: string = parseVarChar(fullName, 128);\n\n  if(formatFullName === '') {\n    throw new UserError('required_full_name');\n  }\n\n  const formatRouting: string = parseString(routing, 32);\n\n  if(formatRouting === '') {\n    throw new UserError('required_routing_number');\n  }\n\n  return getUser(context, sessionId)\n    .then((user: User) => {\n      const {stripeAccountId}: User = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const source: any = {\n        account_holder_name: formatFullName,\n        account_holder_type: 'individual',\n        account_number: formatAccount,\n        country: 'US',\n        currency: 'USD',\n        object: 'bank_account',\n        routing_number: formatRouting\n      };\n\n      return stripeClient.customers\n        .createSource(stripeAccountId, {source})\n        .then((account: any) => {\n          const {id: bankId, last4: bankAccount, routing_number: bankRouting} = account;\n          const update: any = {\n            bankAccount,\n            bankFullName: formatFullName,\n            bankId,\n            bankRouting,\n            modified: Date.now()\n          };\n\n          const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n          return database.query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((updatedUser: User = {}) => updatedUser);\n        })\n        .catch((error: Error) => {\n          const msg = error.message;\n\n          if(msg === 'A bank account with that routing number and account number ' +\n            'already exists for this customer.') {\n            return logError({\n              action,\n              category: eventCategory,\n              label: 'bank_account_exists'\n            }, error, context).then(() => null);\n          }\n          return logError({\n            action,\n            category: eventCategory,\n            label: 'payment_error'\n          }, error, context).then(() => null);\n        });\n    });\n};\n\nexport const addCreditCard = (context: ApiContext, card: PaymentCardType): Promise<User> => {\n  const action: string = 'addCreditCard';\n  const {database, session: {userId: sessionId}} = context;\n\n  return getUser(context, sessionId)\n    .then((user: User) => {\n      // User\n      const {stripeAccountId}: User = user;\n\n      // Card\n      const {\n        accountNumber,\n        city,\n        country,\n        cvc,\n        expMonth,\n        expYear,\n        fullName,\n        street1,\n        street2,\n        state,\n        zip\n      }: PaymentCardType = card;\n\n      const formatNumber: number = parseNum(accountNumber, 16);\n\n      if(!formatNumber) {\n        throw new UserError('required_credit_card_number');\n      }\n\n      const formatExpMonth: number = parseNum(expMonth, 2);\n\n      if(!formatExpMonth) {\n        throw new UserError('required_credit_card_exp_month');\n      }\n\n      const formatExpYear: number = parseNum(expYear, 2);\n\n      if(!formatExpYear) {\n        throw new UserError('required_credit_card_exp_year');\n      }\n\n      const formatCvc: number = parseNum(cvc, 3);\n\n      // Address\n      const paymentCard: PaymentCardType = {};\n      const formatCity: string = parseVarChar(city, 32);\n\n      if(formatCity) {\n        paymentCard.city = formatCity;\n      }\n\n      const formatCountry: string = parseChar(country, 2);\n\n      if(formatCountry) {\n        paymentCard.country = formatCountry;\n      }\n\n      const formatFullName: string = parseVarChar(fullName, 32);\n\n      if(formatFullName) {\n        paymentCard.fullName = formatFullName;\n      }\n\n      const formatStreet1: string = parseVarChar(street1, 32);\n\n      if(formatStreet1) {\n        paymentCard.street1 = formatStreet1;\n      }\n\n      const formatStreet2: string = parseVarChar(street2, 32);\n\n      if(formatStreet2) {\n        paymentCard.street2 = formatStreet2;\n      }\n\n      const formatState: string = parseChar(state, 2);\n\n      if(formatState) {\n        paymentCard.state = formatState;\n      }\n\n      const formatZip: string = parseVarChar(zip, 10);\n\n      if(formatZip) {\n        paymentCard.zip = formatZip;\n      }\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const source: any = {\n        address_city: formatCity,\n        address_country: formatCountry,\n        address_line1: formatStreet1,\n        address_line2: formatStreet2,\n        address_state: formatState,\n        address_zip: formatZip,\n        cvc: formatCvc,\n        exp_month: formatExpMonth,\n        exp_year: formatExpYear,\n        name: fullName,\n        number: formatNumber,\n        object: 'card'\n      };\n\n      return stripeClient.customers\n        .createSource(stripeAccountId, {source})\n        .then((newSource: any) => {\n          const {brand, cvc_check: cvcCheck, last4} = newSource;\n\n          // Create session\n          const now: number = Date.now();\n          const insert = {\n            ...paymentCard,\n            _key: createHash(`user-payment-${sessionId}`),\n            accountNumber: last4,\n            added: now,\n            brand,\n            cvcCheck,\n            expMonth,\n            expYear,\n            modified: now,\n            userId: sessionId\n          };\n          const insertAqlQry: AqlQuery = aql`INSERT ${insert} IN creditCards RETURN NEW`;\n\n          return database.query(insertAqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newCard: PaymentCardType = {}) => {\n              if(!isEmpty(newCard)) {\n                // Add linked edge\n                const {_id: cardId, _key: cardKey} = card;\n                const edgeCollection: EdgeCollection = database.collection('hasPayment');\n                const edgeId = createHash(`payment-${cardKey}`);\n                const edge: any = {\n                  _from: `users/${sessionId}`,\n                  _key: edgeId,\n                  _to: cardId\n                };\n\n                return edgeCollection.save(edge, {returnNew: true}).then(() => card);\n              }\n\n              return newCard;\n            })\n            .catch((error: Error) => logError({\n              action,\n              category: eventCategory,\n              label: 'payment_error'\n            }, error, context).then(() => null));\n        });\n    });\n};\n\nexport const updateCreditCard = (context: ApiContext, card: PaymentCardType): Promise<PaymentCardType> => {\n  const {database, session: {userId: sessionId}} = context;\n\n  const {\n    city,\n    country,\n    expMonth,\n    expYear,\n    fullName,\n    id,\n    street1,\n    state,\n    zip\n  }: PaymentCardType = card;\n\n  const formatId: string = parseId(id);\n\n  if(formatId) {\n    throw new UserError('required_credit_card_id');\n  }\n\n  const paymentCard: PaymentCardType = {};\n  const formatExpMonth: number = parseNum(expMonth, 2);\n  const formatExpYear: number = parseNum(expYear, 2);\n  const formatCity: string = parseVarChar(city, 32);\n  const formatCountry: string = parseChar(country, 2);\n  const formatFullName: string = parseVarChar(fullName, 32);\n  const formatStreet1: string = parseString(street1, 32);\n  const formatState: string = parseChar(state, 2);\n  const formatZip: string = parseVarChar(zip, 10);\n\n  if(formatExpMonth) {\n    paymentCard.expMonth = formatExpMonth;\n  }\n\n  if(formatExpYear) {\n    paymentCard.expYear = formatExpYear;\n  }\n\n  if(formatCity) {\n    paymentCard.city = formatCity;\n  }\n\n  if(formatCountry) {\n    paymentCard.country = formatCountry;\n  }\n\n  if(formatFullName) {\n    paymentCard.fullName = formatFullName;\n  }\n\n  if(formatStreet1) {\n    paymentCard.street1 = formatStreet1;\n  }\n\n  if(formatState) {\n    paymentCard.state = formatState;\n  }\n\n  if(formatZip) {\n    paymentCard.zip = formatZip;\n  }\n\n  const update: any = paymentCard;\n  const aqlQry: AqlQuery = aql`\n      LET updatedCard = FIRST(\n        FOR c IN creditCards\n        FILTER c._key == ${formatId} && c.userId == ${sessionId}\n        UPDATE c WITH ${update} IN creditCards\n        LIMIT 1\n        RETURN NEW\n      )\n      LET user = FIRST(\n        FOR u IN users\n        FILTER u._key == ${sessionId}\n        LIMIT 1\n        RETURN u\n      )\n      RETURN {user: user, card: updatedCard}`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((results = {card: {}, user: {}}) => {\n      const updatedCard: PaymentCardType = results.card;\n      const {user} = results;\n\n      if(isEmpty(updatedCard)) {\n        throw new UserError('not_found');\n      }\n\n      const {stripeCustomerId} = user;\n      const {stripeId} = card;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n      const update: any = {\n        address_city: formatCity,\n        address_country: formatCountry,\n        address_line1: formatStreet1,\n        address_state: formatState,\n        address_zip: formatZip,\n        exp_month: formatExpMonth,\n        exp_year: formatExpYear,\n        name: formatFullName\n      };\n\n      return stripeClient.customers\n        .updateSource(stripeCustomerId, stripeId, update)\n        .then(() => card)\n        .catch((error: Error) => {\n          console.log('payments::updateCard::error', error);\n          throw new UserError('payment_error');\n        });\n    });\n};\n\nexport const getCreditCards = (context: ApiContext): Promise<PaymentCardType[]> => {\n  const action: string = 'getCreditCards';\n  const {database, session: {userId: sessionId}} = context;\n  const aqlQry: AqlQuery = aql`FOR c IN creditCards\n    FILTER c.userId == ${sessionId}\n    RETURN c`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: PaymentCardType[] = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteCreditCard = (context: ApiContext, cardId: string): Promise<boolean> => {\n  const {database, session: {userId: sessionId}} = context;\n  const formatCardId: string = parseId(cardId);\n  const aqlQry: AqlQuery = aql`\n    LET card = FIRST(\n      FOR c IN creditCards\n      FILTER c._key == ${formatCardId} && c.userId == ${sessionId}\n      LIMIT 1\n      REMOVE c IN creditCards\n      RETURN OLD\n    )\n    LET user = FIRST(\n      FOR u IN users\n      FILTER u._key == ${sessionId}\n      LIMIT 1\n      RETURN u\n    )\n    RETURN {user: user, card: card}`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((result = {card: {}, user: {}}) => {\n      if(isEmpty(result)) {\n        return false;\n      }\n\n      const {card, user} = result;\n      const {_key: cardKey} = card;\n\n      // Remove linked edges\n      const edgeCollection = database.collection('hasPayment');\n\n      return edgeCollection.outEdges(cardKey)\n        .then((edges: any) => {\n          if(edges.length) {\n            return Promise.all(\n              edges.map((edge) => {\n                const {_key: edgeKey} = edge;\n                const removeAqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN hasPayment`;\n                return database.query(removeAqlQry);\n              }))\n              .then(() => {\n                // Stripe\n                const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n                return stripeClient.customers\n                  .deleteSource(user.stripeCustomerId, card.stripeId)\n                  .then(() => true)\n                  .catch((error: Error) => {\n                    console.log('payments::deleteCard::error', error);\n                    throw new UserError('payment_error');\n                  });\n              });\n          }\n\n          return false;\n        });\n    });\n};\n\nexport const deleteBankAccount = (context: ApiContext, bankId: string): Promise<boolean> => {\n  const {database, session: {userId: sessionId}} = context;\n\n  // Clean db\n  const update: User = {\n    bankAccount: '',\n    bankFullName: '',\n    bankId: '',\n    bankRouting: '',\n    modified: Date.now()\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${sessionId} WITH ${update} IN users LIMIT 1 RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: User = {}) => {\n      const {stripeAccountId} = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n      return stripeClient.customers\n        .deleteSource(stripeAccountId, bankId)\n        .then((response: any = {deleted: false}) => response.deleted)\n        .catch(() => Promise.resolve(false));\n    });\n};\n\nexport const createPaymentTransfer = (context: ApiContext, transfer: PaymentTransfer): Promise<PaymentTransfer> => {\n  const {database, session: {userId: sessionId}} = context;\n  const {amount, currency} = transfer;\n  const formatAmount: number = parseNum(amount);\n  const formatCurrency: string = parseChar(currency, 3, 'USD').toUpperCase();\n\n  return getUser(context, sessionId)\n    .then((user: User) => {\n      const {stripeAccountId} = user;\n\n      // Stripe\n      const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n      return stripeClient.transfers\n        .create({\n          amount: formatAmount,\n          currency: formatCurrency,\n          destination: stripeAccountId\n        })\n        .then((stripeTransfer) => {\n          console.log(stripeTransfer);\n          const now: number = Date.now();\n          const insert: PaymentTransfer = {\n            added: now,\n            amount: formatAmount,\n            currency: formatCurrency,\n            modified: now,\n            userId: sessionId\n          };\n          const aqlQry: AqlQuery = aql`INSERT ${insert} IN transfers RETURN NEW`;\n\n          return database.query(aqlQry)\n            .then((cursor: ArrayCursor) => cursor.next())\n            .then((newTransfer: PaymentTransfer) => newTransfer);\n        });\n    });\n};\n\nexport const createPaymentHold = (context: ApiContext, payment: PaymentCharge): Promise<PaymentCharge> => {\n  const {database, session: {userId: sessionId}} = context;\n  const {amount, capture, cardId, currency, description} = payment;\n  const formatCurrency = parseChar(currency, 3, 'USD').toUpperCase();\n\n  const stripeClient = new Stripe(Config.get('stripe.token'), {apiVersion, typescript: true});\n\n  return stripeClient.charges\n    .create({\n      amount,\n      capture,\n      currency: formatCurrency,\n      description,\n      source: cardId\n    })\n    .then((stripeCharge) => {\n      const now: number = Date.now();\n      const insert: PaymentCharge = {\n        added: now,\n        amount,\n        capture,\n        cardId,\n        chargeFailCode: stripeCharge.failure_code,\n        chargeFailMsg: stripeCharge.failure_message,\n        chargeId: stripeCharge.id,\n        chargeStatus: stripeCharge.status,\n        currency: formatCurrency,\n        description,\n        modified: now,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN payments RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((newPayment: PaymentCharge) => newPayment);\n    })\n    .catch((error: Error) => {\n      console.log('payments::createHold::error', error);\n      throw new UserError('payment_error');\n    });\n};\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Database } from 'arangojs';
|
|
2
|
+
import { ApiContext, FileType, PostInputType, PostOptions, PostType } from '../types';
|
|
3
|
+
export declare const parsePostOptions: (options?: PostOptions) => {
|
|
4
|
+
latitude: number;
|
|
5
|
+
limit: import("../types").ArangoDBLimit;
|
|
6
|
+
longitude: number;
|
|
7
|
+
type: string;
|
|
8
|
+
};
|
|
9
|
+
export declare const getPostOptional: (fields: string[], sessionId: string) => any;
|
|
10
|
+
export declare const getPost: (context: ApiContext, itemId: string, options: PostOptions) => Promise<Partial<PostType>>;
|
|
11
|
+
export declare const getPostsByReactions: (context: ApiContext, reactions?: string[], options?: PostOptions) => Promise<PostType[]>;
|
|
12
|
+
export declare const getPostsByTags: (context: ApiContext, tags?: string[], options?: PostOptions) => Promise<PostType[]>;
|
|
13
|
+
export declare const getPostsByUser: (context: ApiContext, userId: string, options?: PostOptions) => Promise<PostType[]>;
|
|
14
|
+
export declare const getPostComments: (context: ApiContext, itemId: string, options?: PostOptions) => Promise<PostType[]>;
|
|
15
|
+
export declare const addPost: (context: ApiContext, post: PostInputType) => Promise<PostType>;
|
|
16
|
+
export declare const updatePost: (context: ApiContext, post: PostInputType) => Promise<PostType>;
|
|
17
|
+
export declare const deletePost: (context: ApiContext, postId: string) => Promise<PostType>;
|
|
18
|
+
export declare const cleanPosts: (database: Database) => Promise<number>;
|
|
19
|
+
export declare const createPostEdge: (db: Database, file: FileType, postId: string) => Promise<FileType>;
|