customer-registration 0.0.127 → 0.0.128
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/.medusa/server/src/api/middlewares.js +2 -7
- package/.medusa/server/src/api/store/customers/otp/__tests__/send-route.test.js +240 -0
- package/.medusa/server/src/api/store/customers/otp/__tests__/verify-route.test.js +240 -0
- package/.medusa/server/src/api/store/customers/otp/send/route.js +45 -7
- package/.medusa/server/src/api/store/customers/otp/shared/email-auth-helpers.js +62 -0
- package/.medusa/server/src/api/store/customers/otp/shared/handle-send-email-auth-otp.js +45 -0
- package/.medusa/server/src/api/store/customers/otp/shared/handle-send-phone-auth-otp.js +45 -0
- package/.medusa/server/src/api/store/customers/otp/shared/handle-verify-email-auth-otp.js +54 -0
- package/.medusa/server/src/api/store/customers/otp/shared/handle-verify-phone-auth-otp.js +54 -0
- package/.medusa/server/src/api/{auth/customer/phoneotp → store/customers/otp}/shared/phone-auth-helpers.js +1 -1
- package/.medusa/server/src/api/store/customers/otp/shared/resolve-otp-token-purpose.js +27 -0
- package/.medusa/server/src/api/store/customers/otp/verify/route.js +22 -28
- package/.medusa/server/src/config.js +3 -3
- package/.medusa/server/src/providers/emailotp/service.js +2 -2
- package/.medusa/server/src/providers/phoneotp/service.js +2 -2
- package/.medusa/server/src/workflows/steps/resolve-or-create-email-auth-customer-step.js +2 -2
- package/.medusa/server/src/workflows/steps/resolve-or-create-phone-auth-customer-step.js +2 -2
- package/README.md +74 -114
- package/package.json +1 -1
- package/.medusa/server/src/api/auth/customer/emailotp/__tests__/send-route.test.js +0 -151
- package/.medusa/server/src/api/auth/customer/emailotp/__tests__/verify-route.test.js +0 -171
- package/.medusa/server/src/api/auth/customer/emailotp/send/route.js +0 -51
- package/.medusa/server/src/api/auth/customer/emailotp/shared/email-auth-helpers.js +0 -62
- package/.medusa/server/src/api/auth/customer/emailotp/verify/route.js +0 -54
- package/.medusa/server/src/api/auth/customer/phoneotp/__tests__/send-route.test.js +0 -153
- package/.medusa/server/src/api/auth/customer/phoneotp/__tests__/verify-route.test.js +0 -158
- package/.medusa/server/src/api/auth/customer/phoneotp/send/route.js +0 -51
- package/.medusa/server/src/api/auth/customer/phoneotp/verify/route.js +0 -54
|
@@ -44,15 +44,10 @@ exports.default = (0, http_1.defineMiddlewares)({
|
|
|
44
44
|
middlewares: [(0, ip_rate_limit_1.ipRateLimit)({ max: 5, windowMs: 60_000 })],
|
|
45
45
|
},
|
|
46
46
|
{
|
|
47
|
-
matcher: "/
|
|
48
|
-
method: ["POST"],
|
|
49
|
-
middlewares: [(0, ip_rate_limit_1.ipRateLimit)({ max: 5, windowMs: 60_000 })],
|
|
50
|
-
},
|
|
51
|
-
{
|
|
52
|
-
matcher: "/auth/customer/phoneotp/send",
|
|
47
|
+
matcher: "/store/customers/otp/send",
|
|
53
48
|
method: ["POST"],
|
|
54
49
|
middlewares: [(0, ip_rate_limit_1.ipRateLimit)({ max: 5, windowMs: 60_000 })],
|
|
55
50
|
},
|
|
56
51
|
],
|
|
57
52
|
});
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlkZGxld2FyZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBpL21pZGRsZXdhcmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsbURBQStEO0FBQy9ELG1EQUFzRjtBQUN0RixvRkFBZ0c7QUFDaEcsZ0ZBQXdGO0FBQ3hGLGlGQUEyRTtBQUMzRSxpR0FBMkY7QUFDM0YsK0RBQXlEO0FBQ3pELDZEQUE4RTtBQUU5RSxNQUFNLDZCQUE2QixHQUFHLElBQUEscUNBQXlCLEVBQzdELG1DQUFzQixFQUN0QiwyQ0FBNEIsQ0FDN0IsQ0FBQTtBQUVELGtCQUFlLElBQUEsd0JBQWlCLEVBQUM7SUFDL0IsTUFBTSxFQUFFO1FBQ047WUFDRSxPQUFPLEVBQUUsa0JBQWtCO1lBQzNCLFdBQVcsRUFBRSxDQUFDLDZDQUFvQixDQUFDO1NBQ3BDO1FBQ0Q7WUFDRSxPQUFPLEVBQUUsVUFBVTtZQUNuQixXQUFXLEVBQUUsQ0FBQyw2Q0FBb0IsQ0FBQztTQUNwQztRQUNEO1lBQ0UsT0FBTyxFQUFFLGtCQUFrQjtZQUMzQixNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDaEIsV0FBVyxFQUFFO2dCQUNYLElBQUEsK0JBQXdCLEVBQUMsNENBQStCLENBQUM7Z0JBQ3pELDZEQUE0QjthQUM3QjtTQUNGO1FBQ0Q7WUFDRSxPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxDQUFDLEtBQUssQ0FBQztZQUNmLFdBQVcsRUFBRSxDQUFDLDZCQUE2QixDQUFDO1NBQzdDO1FBQ0Q7WUFDRSxPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxDQUFDLE9BQU8sQ0FBQztZQUNqQixXQUFXLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztTQUM3QztRQUNEO1lBQ0UsbUVBQW1FO1lBQ25FLE9BQU8sRUFBRSxrREFBa0Q7WUFDM0QsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ2hCLFdBQVcsRUFBRSxDQUFDLElBQUEsMkJBQVcsRUFBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7U0FDekQ7UUFDRDtZQUNFLE9BQU8sRUFBRSwyQkFBMkI7WUFDcEMsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ2hCLFdBQVcsRUFBRSxDQUFDLElBQUEsMkJBQVcsRUFBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7U0FDekQ7S0FDRjtDQUNGLENBQUMsQ0FBQSJ9
|
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const utils_1 = require("@medusajs/framework/utils");
|
|
7
|
+
const vitest_1 = require("vitest");
|
|
8
|
+
const config_1 = require("../../../../../config");
|
|
9
|
+
const otp_verification_1 = require("../../../../../modules/otp-verification/models/otp-verification");
|
|
10
|
+
const send_email_auth_otp_workflow_1 = __importDefault(require("../../../../../workflows/send-email-auth-otp-workflow"));
|
|
11
|
+
const send_phone_auth_otp_workflow_1 = __importDefault(require("../../../../../workflows/send-phone-auth-otp-workflow"));
|
|
12
|
+
const send_otp_workflow_1 = __importDefault(require("../../../../../workflows/send-otp-workflow"));
|
|
13
|
+
const email_auth_helpers_1 = require("../shared/email-auth-helpers");
|
|
14
|
+
const phone_auth_helpers_1 = require("../shared/phone-auth-helpers");
|
|
15
|
+
const route_1 = require("../send/route");
|
|
16
|
+
vitest_1.vi.mock("../../../../../config", async (importOriginal) => {
|
|
17
|
+
const actual = await importOriginal();
|
|
18
|
+
return {
|
|
19
|
+
...actual,
|
|
20
|
+
resolveCustomerRegistrationOptions: vitest_1.vi.fn(),
|
|
21
|
+
isEmailOtpAuthEnabled: vitest_1.vi.fn(),
|
|
22
|
+
isPhoneOtpAuthEnabled: vitest_1.vi.fn(),
|
|
23
|
+
};
|
|
24
|
+
});
|
|
25
|
+
vitest_1.vi.mock("../shared/email-auth-helpers", () => ({
|
|
26
|
+
lookupCustomerByEmail: vitest_1.vi.fn(),
|
|
27
|
+
normalizeAuthEmail: (email) => email.toLowerCase().trim(),
|
|
28
|
+
}));
|
|
29
|
+
vitest_1.vi.mock("../shared/phone-auth-helpers", () => ({
|
|
30
|
+
lookupCustomerByPhone: vitest_1.vi.fn(),
|
|
31
|
+
normalizeAuthPhone: (phone) => phone.trim(),
|
|
32
|
+
}));
|
|
33
|
+
vitest_1.vi.mock("../../../../../workflows/send-email-auth-otp-workflow", () => ({
|
|
34
|
+
default: vitest_1.vi.fn(),
|
|
35
|
+
}));
|
|
36
|
+
vitest_1.vi.mock("../../../../../workflows/send-phone-auth-otp-workflow", () => ({
|
|
37
|
+
default: vitest_1.vi.fn(),
|
|
38
|
+
}));
|
|
39
|
+
vitest_1.vi.mock("../../../../../workflows/send-otp-workflow", () => ({
|
|
40
|
+
default: vitest_1.vi.fn(),
|
|
41
|
+
}));
|
|
42
|
+
const mockedIsEmailOtpEnabled = vitest_1.vi.mocked(config_1.isEmailOtpAuthEnabled);
|
|
43
|
+
const mockedIsPhoneOtpEnabled = vitest_1.vi.mocked(config_1.isPhoneOtpAuthEnabled);
|
|
44
|
+
const mockedLookupEmail = vitest_1.vi.mocked(email_auth_helpers_1.lookupCustomerByEmail);
|
|
45
|
+
const mockedLookupPhone = vitest_1.vi.mocked(phone_auth_helpers_1.lookupCustomerByPhone);
|
|
46
|
+
const mockedEmailWorkflow = vitest_1.vi.mocked(send_email_auth_otp_workflow_1.default);
|
|
47
|
+
const mockedPhoneWorkflow = vitest_1.vi.mocked(send_phone_auth_otp_workflow_1.default);
|
|
48
|
+
const mockedVerificationWorkflow = vitest_1.vi.mocked(send_otp_workflow_1.default);
|
|
49
|
+
(0, vitest_1.describe)("POST /store/customers/otp/send table-driven tests", () => {
|
|
50
|
+
(0, vitest_1.beforeEach)(() => {
|
|
51
|
+
vitest_1.vi.clearAllMocks();
|
|
52
|
+
mockedIsEmailOtpEnabled.mockReturnValue(true);
|
|
53
|
+
mockedIsPhoneOtpEnabled.mockReturnValue(true);
|
|
54
|
+
mockedEmailWorkflow.mockReturnValue({
|
|
55
|
+
run: vitest_1.vi.fn().mockResolvedValue({
|
|
56
|
+
result: {
|
|
57
|
+
token: "email_auth_token",
|
|
58
|
+
expires_at: new Date("2025-06-03T12:00:00.000Z"),
|
|
59
|
+
},
|
|
60
|
+
}),
|
|
61
|
+
});
|
|
62
|
+
mockedPhoneWorkflow.mockReturnValue({
|
|
63
|
+
run: vitest_1.vi.fn().mockResolvedValue({
|
|
64
|
+
result: {
|
|
65
|
+
token: "phone_auth_token",
|
|
66
|
+
expires_at: new Date("2025-06-03T12:00:00.000Z"),
|
|
67
|
+
},
|
|
68
|
+
}),
|
|
69
|
+
});
|
|
70
|
+
mockedVerificationWorkflow.mockReturnValue({
|
|
71
|
+
run: vitest_1.vi.fn().mockResolvedValue({
|
|
72
|
+
result: {
|
|
73
|
+
token: "verify_token",
|
|
74
|
+
expires_at: new Date("2025-06-03T12:00:00.000Z"),
|
|
75
|
+
},
|
|
76
|
+
}),
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
const cases = [
|
|
80
|
+
{
|
|
81
|
+
title: "email_auth rejects when OTP auth is disabled",
|
|
82
|
+
body: { email: "user@example.com", type: otp_verification_1.OtpPurpose.EMAIL_AUTH },
|
|
83
|
+
emailOtpEnabled: false,
|
|
84
|
+
phoneOtpEnabled: true,
|
|
85
|
+
emailCustomer: null,
|
|
86
|
+
phoneCustomer: null,
|
|
87
|
+
pendingDeletion: false,
|
|
88
|
+
shouldThrow: true,
|
|
89
|
+
errorType: utils_1.MedusaError.Types.NOT_ALLOWED,
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
title: "email_auth rejects invalid email format",
|
|
93
|
+
body: { email: "bad", type: otp_verification_1.OtpPurpose.EMAIL_AUTH },
|
|
94
|
+
emailOtpEnabled: true,
|
|
95
|
+
phoneOtpEnabled: true,
|
|
96
|
+
emailCustomer: null,
|
|
97
|
+
phoneCustomer: null,
|
|
98
|
+
pendingDeletion: false,
|
|
99
|
+
shouldThrow: true,
|
|
100
|
+
errorType: utils_1.MedusaError.Types.INVALID_DATA,
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
title: "email_auth blocks when pending account deletion",
|
|
104
|
+
body: { email: "user@example.com", type: otp_verification_1.OtpPurpose.EMAIL_AUTH },
|
|
105
|
+
emailOtpEnabled: true,
|
|
106
|
+
phoneOtpEnabled: true,
|
|
107
|
+
emailCustomer: {
|
|
108
|
+
id: "cus_1",
|
|
109
|
+
email: "user@example.com",
|
|
110
|
+
has_account: true,
|
|
111
|
+
first_name: "A",
|
|
112
|
+
last_name: null,
|
|
113
|
+
},
|
|
114
|
+
phoneCustomer: null,
|
|
115
|
+
pendingDeletion: true,
|
|
116
|
+
shouldThrow: true,
|
|
117
|
+
errorType: utils_1.MedusaError.Types.NOT_ALLOWED,
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
title: "email_auth returns token for new user",
|
|
121
|
+
body: { email: "new@example.com", type: otp_verification_1.OtpPurpose.EMAIL_AUTH },
|
|
122
|
+
emailOtpEnabled: true,
|
|
123
|
+
phoneOtpEnabled: true,
|
|
124
|
+
emailCustomer: null,
|
|
125
|
+
phoneCustomer: null,
|
|
126
|
+
pendingDeletion: false,
|
|
127
|
+
shouldThrow: false,
|
|
128
|
+
expectedStatus: 200,
|
|
129
|
+
expectedJson: {
|
|
130
|
+
token: "email_auth_token",
|
|
131
|
+
expires_at: new Date("2025-06-03T12:00:00.000Z"),
|
|
132
|
+
is_new_user: true,
|
|
133
|
+
},
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
title: "phone_auth rejects when OTP auth is disabled",
|
|
137
|
+
body: { phone: "+15551234567", type: otp_verification_1.OtpPurpose.PHONE_AUTH },
|
|
138
|
+
emailOtpEnabled: true,
|
|
139
|
+
phoneOtpEnabled: false,
|
|
140
|
+
emailCustomer: null,
|
|
141
|
+
phoneCustomer: null,
|
|
142
|
+
pendingDeletion: false,
|
|
143
|
+
shouldThrow: true,
|
|
144
|
+
errorType: utils_1.MedusaError.Types.NOT_ALLOWED,
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
title: "phone_auth returns token for new user",
|
|
148
|
+
body: { phone: "+15559876543", type: otp_verification_1.OtpPurpose.PHONE_AUTH },
|
|
149
|
+
emailOtpEnabled: true,
|
|
150
|
+
phoneOtpEnabled: true,
|
|
151
|
+
emailCustomer: null,
|
|
152
|
+
phoneCustomer: null,
|
|
153
|
+
pendingDeletion: false,
|
|
154
|
+
shouldThrow: false,
|
|
155
|
+
expectedStatus: 200,
|
|
156
|
+
expectedJson: {
|
|
157
|
+
token: "phone_auth_token",
|
|
158
|
+
expires_at: new Date("2025-06-03T12:00:00.000Z"),
|
|
159
|
+
is_new_user: true,
|
|
160
|
+
},
|
|
161
|
+
},
|
|
162
|
+
{
|
|
163
|
+
title: "email_verification requires customer_id",
|
|
164
|
+
body: { type: otp_verification_1.OtpPurpose.EMAIL_VERIFICATION },
|
|
165
|
+
emailOtpEnabled: true,
|
|
166
|
+
phoneOtpEnabled: true,
|
|
167
|
+
emailCustomer: null,
|
|
168
|
+
phoneCustomer: null,
|
|
169
|
+
pendingDeletion: false,
|
|
170
|
+
shouldThrow: true,
|
|
171
|
+
errorType: utils_1.MedusaError.Types.INVALID_DATA,
|
|
172
|
+
},
|
|
173
|
+
{
|
|
174
|
+
title: "email_verification returns token",
|
|
175
|
+
body: {
|
|
176
|
+
customer_id: "cus_1",
|
|
177
|
+
type: otp_verification_1.OtpPurpose.EMAIL_VERIFICATION,
|
|
178
|
+
},
|
|
179
|
+
emailOtpEnabled: true,
|
|
180
|
+
phoneOtpEnabled: true,
|
|
181
|
+
emailCustomer: null,
|
|
182
|
+
phoneCustomer: null,
|
|
183
|
+
pendingDeletion: false,
|
|
184
|
+
shouldThrow: false,
|
|
185
|
+
expectedStatus: 200,
|
|
186
|
+
expectedJson: {
|
|
187
|
+
token: "verify_token",
|
|
188
|
+
expires_at: new Date("2025-06-03T12:00:00.000Z"),
|
|
189
|
+
},
|
|
190
|
+
},
|
|
191
|
+
{
|
|
192
|
+
title: "email_auth rejects customer_id in body",
|
|
193
|
+
body: {
|
|
194
|
+
customer_id: "cus_1",
|
|
195
|
+
email: "user@example.com",
|
|
196
|
+
type: otp_verification_1.OtpPurpose.EMAIL_AUTH,
|
|
197
|
+
},
|
|
198
|
+
emailOtpEnabled: true,
|
|
199
|
+
phoneOtpEnabled: true,
|
|
200
|
+
emailCustomer: null,
|
|
201
|
+
phoneCustomer: null,
|
|
202
|
+
pendingDeletion: false,
|
|
203
|
+
shouldThrow: true,
|
|
204
|
+
errorType: utils_1.MedusaError.Types.INVALID_DATA,
|
|
205
|
+
},
|
|
206
|
+
];
|
|
207
|
+
vitest_1.test.each(cases)("$title", async ({ body, emailOtpEnabled, phoneOtpEnabled, emailCustomer, phoneCustomer, pendingDeletion, shouldThrow, errorType, expectedStatus, expectedJson, }) => {
|
|
208
|
+
mockedIsEmailOtpEnabled.mockReturnValue(emailOtpEnabled);
|
|
209
|
+
mockedIsPhoneOtpEnabled.mockReturnValue(phoneOtpEnabled);
|
|
210
|
+
mockedLookupEmail.mockResolvedValue(emailCustomer);
|
|
211
|
+
mockedLookupPhone.mockResolvedValue(phoneCustomer);
|
|
212
|
+
const hasPendingRequest = vitest_1.vi.fn().mockResolvedValue(pendingDeletion);
|
|
213
|
+
const req = {
|
|
214
|
+
body,
|
|
215
|
+
scope: {
|
|
216
|
+
resolve: (token) => {
|
|
217
|
+
if (token === utils_1.ContainerRegistrationKeys.CONFIG_MODULE) {
|
|
218
|
+
return (0, config_1.resolveCustomerRegistrationOptions)(undefined);
|
|
219
|
+
}
|
|
220
|
+
if (String(token).includes("account_deletion")) {
|
|
221
|
+
return { hasPendingRequest };
|
|
222
|
+
}
|
|
223
|
+
return undefined;
|
|
224
|
+
},
|
|
225
|
+
},
|
|
226
|
+
};
|
|
227
|
+
const status = vitest_1.vi.fn().mockReturnThis();
|
|
228
|
+
const json = vitest_1.vi.fn();
|
|
229
|
+
const res = { status, json };
|
|
230
|
+
const exec = () => (0, route_1.POST)(req, res);
|
|
231
|
+
if (shouldThrow) {
|
|
232
|
+
await (0, vitest_1.expect)(exec()).rejects.toMatchObject({ type: errorType });
|
|
233
|
+
return;
|
|
234
|
+
}
|
|
235
|
+
await exec();
|
|
236
|
+
(0, vitest_1.expect)(status).toHaveBeenCalledWith(expectedStatus);
|
|
237
|
+
(0, vitest_1.expect)(json).toHaveBeenCalledWith(expectedJson);
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VuZC1yb3V0ZS50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwaS9zdG9yZS9jdXN0b21lcnMvb3RwL19fdGVzdHNfXy9zZW5kLXJvdXRlLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFDQSxxREFBa0Y7QUFDbEYsbUNBQStEO0FBQy9ELGtEQUk4QjtBQUM5QixzR0FBNEY7QUFDNUYseUhBQTRGO0FBQzVGLHlIQUE0RjtBQUM1RixtR0FBd0U7QUFDeEUscUVBQW9FO0FBQ3BFLHFFQUFvRTtBQUNwRSx5Q0FBb0M7QUFFcEMsV0FBRSxDQUFDLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxLQUFLLEVBQUUsY0FBYyxFQUFFLEVBQUU7SUFDeEQsTUFBTSxNQUFNLEdBQUcsTUFBTSxjQUFjLEVBQTBDLENBQUE7SUFDN0UsT0FBTztRQUNMLEdBQUcsTUFBTTtRQUNULGtDQUFrQyxFQUFFLFdBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDM0MscUJBQXFCLEVBQUUsV0FBRSxDQUFDLEVBQUUsRUFBRTtRQUM5QixxQkFBcUIsRUFBRSxXQUFFLENBQUMsRUFBRSxFQUFFO0tBQy9CLENBQUE7QUFDSCxDQUFDLENBQUMsQ0FBQTtBQUVGLFdBQUUsQ0FBQyxJQUFJLENBQUMsOEJBQThCLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztJQUM3QyxxQkFBcUIsRUFBRSxXQUFFLENBQUMsRUFBRSxFQUFFO0lBQzlCLGtCQUFrQixFQUFFLENBQUMsS0FBYSxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUMsSUFBSSxFQUFFO0NBQ2xFLENBQUMsQ0FBQyxDQUFBO0FBRUgsV0FBRSxDQUFDLElBQUksQ0FBQyw4QkFBOEIsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO0lBQzdDLHFCQUFxQixFQUFFLFdBQUUsQ0FBQyxFQUFFLEVBQUU7SUFDOUIsa0JBQWtCLEVBQUUsQ0FBQyxLQUFh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
|
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const utils_1 = require("@medusajs/framework/utils");
|
|
7
|
+
const vitest_1 = require("vitest");
|
|
8
|
+
const config_1 = require("../../../../../config");
|
|
9
|
+
const otp_verification_1 = require("../../../../../modules/otp-verification/models/otp-verification");
|
|
10
|
+
const otp_verification_2 = require("../../../../../modules/otp-verification");
|
|
11
|
+
const verify_email_auth_otp_workflow_1 = __importDefault(require("../../../../../workflows/verify-email-auth-otp-workflow"));
|
|
12
|
+
const verify_phone_auth_otp_workflow_1 = __importDefault(require("../../../../../workflows/verify-phone-auth-otp-workflow"));
|
|
13
|
+
const verify_email_1 = __importDefault(require("../../../../../workflows/verify-email"));
|
|
14
|
+
const complete_customer_login_1 = require("../../../../auth/customer/shared/complete-customer-login");
|
|
15
|
+
const resolve_otp_token_purpose_1 = require("../shared/resolve-otp-token-purpose");
|
|
16
|
+
const route_1 = require("../verify/route");
|
|
17
|
+
vitest_1.vi.mock("../../../../../config", async (importOriginal) => {
|
|
18
|
+
const actual = await importOriginal();
|
|
19
|
+
return {
|
|
20
|
+
...actual,
|
|
21
|
+
isEmailOtpAuthEnabled: vitest_1.vi.fn(),
|
|
22
|
+
isPhoneOtpAuthEnabled: vitest_1.vi.fn(),
|
|
23
|
+
resolveCustomerRegistrationOptions: vitest_1.vi.fn(() => ({
|
|
24
|
+
login: { identifier: "email" },
|
|
25
|
+
registration: { identifier: "email", require_verification: true },
|
|
26
|
+
auth: {
|
|
27
|
+
email: { methods: ["otp"] },
|
|
28
|
+
phone: { methods: ["otp"] },
|
|
29
|
+
},
|
|
30
|
+
})),
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
vitest_1.vi.mock("../shared/resolve-otp-token-purpose", () => ({
|
|
34
|
+
resolveOtpTokenPurpose: vitest_1.vi.fn(),
|
|
35
|
+
}));
|
|
36
|
+
vitest_1.vi.mock("../../../../../workflows/verify-email-auth-otp-workflow", () => ({
|
|
37
|
+
default: vitest_1.vi.fn(),
|
|
38
|
+
}));
|
|
39
|
+
vitest_1.vi.mock("../../../../../workflows/verify-phone-auth-otp-workflow", () => ({
|
|
40
|
+
default: vitest_1.vi.fn(),
|
|
41
|
+
}));
|
|
42
|
+
vitest_1.vi.mock("../../../../../workflows/verify-email", () => ({
|
|
43
|
+
default: vitest_1.vi.fn(),
|
|
44
|
+
}));
|
|
45
|
+
vitest_1.vi.mock("../../../../../workflows/verify-phone", () => ({
|
|
46
|
+
default: vitest_1.vi.fn(),
|
|
47
|
+
}));
|
|
48
|
+
vitest_1.vi.mock("../../../../auth/customer/shared/complete-customer-login", () => ({
|
|
49
|
+
issueCustomerJwtToken: vitest_1.vi.fn(),
|
|
50
|
+
}));
|
|
51
|
+
vitest_1.vi.mock("../../shared/referral-code", () => ({
|
|
52
|
+
assertReferralCodeReferrerExists: vitest_1.vi.fn().mockResolvedValue(undefined),
|
|
53
|
+
maybeCreateReferralLinkFromRequest: vitest_1.vi.fn().mockResolvedValue(undefined),
|
|
54
|
+
}));
|
|
55
|
+
const mockedResolvePurpose = vitest_1.vi.mocked(resolve_otp_token_purpose_1.resolveOtpTokenPurpose);
|
|
56
|
+
const mockedIsEmailOtpEnabled = vitest_1.vi.mocked(config_1.isEmailOtpAuthEnabled);
|
|
57
|
+
const mockedIsPhoneOtpEnabled = vitest_1.vi.mocked(config_1.isPhoneOtpAuthEnabled);
|
|
58
|
+
const mockedEmailAuthWorkflow = vitest_1.vi.mocked(verify_email_auth_otp_workflow_1.default);
|
|
59
|
+
const mockedPhoneAuthWorkflow = vitest_1.vi.mocked(verify_phone_auth_otp_workflow_1.default);
|
|
60
|
+
const mockedVerifyEmailWorkflow = vitest_1.vi.mocked(verify_email_1.default);
|
|
61
|
+
const mockedIssueJwt = vitest_1.vi.mocked(complete_customer_login_1.issueCustomerJwtToken);
|
|
62
|
+
(0, vitest_1.describe)("POST /store/customers/otp/verify table-driven tests", () => {
|
|
63
|
+
(0, vitest_1.beforeEach)(() => {
|
|
64
|
+
vitest_1.vi.clearAllMocks();
|
|
65
|
+
mockedIsEmailOtpEnabled.mockReturnValue(true);
|
|
66
|
+
mockedIsPhoneOtpEnabled.mockReturnValue(true);
|
|
67
|
+
mockedIssueJwt.mockResolvedValue("customer_jwt");
|
|
68
|
+
mockedEmailAuthWorkflow.mockReturnValue({
|
|
69
|
+
run: vitest_1.vi.fn().mockResolvedValue({
|
|
70
|
+
result: {
|
|
71
|
+
customer: { id: "cus_new", email: "new@example.com" },
|
|
72
|
+
auth_identity: { id: "auth_1" },
|
|
73
|
+
is_new_user: true,
|
|
74
|
+
},
|
|
75
|
+
}),
|
|
76
|
+
});
|
|
77
|
+
mockedPhoneAuthWorkflow.mockReturnValue({
|
|
78
|
+
run: vitest_1.vi.fn().mockResolvedValue({
|
|
79
|
+
result: {
|
|
80
|
+
customer: { id: "cus_new", phone: "+15559876543" },
|
|
81
|
+
auth_identity: { id: "auth_1" },
|
|
82
|
+
is_new_user: true,
|
|
83
|
+
},
|
|
84
|
+
}),
|
|
85
|
+
});
|
|
86
|
+
mockedVerifyEmailWorkflow.mockReturnValue({
|
|
87
|
+
run: vitest_1.vi.fn().mockResolvedValue({
|
|
88
|
+
result: {
|
|
89
|
+
customer: { id: "cus_1", email: "user@example.com" },
|
|
90
|
+
email_verified: true,
|
|
91
|
+
},
|
|
92
|
+
}),
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
const cases = [
|
|
96
|
+
{
|
|
97
|
+
title: "requires token",
|
|
98
|
+
body: { code: "123456" },
|
|
99
|
+
purpose: otp_verification_1.OtpPurpose.EMAIL_AUTH,
|
|
100
|
+
emailOtpEnabled: true,
|
|
101
|
+
phoneOtpEnabled: true,
|
|
102
|
+
shouldThrow: true,
|
|
103
|
+
errorType: utils_1.MedusaError.Types.INVALID_DATA,
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
title: "email_auth rejects when OTP auth is disabled",
|
|
107
|
+
body: { token: "t", code: "123456" },
|
|
108
|
+
purpose: otp_verification_1.OtpPurpose.EMAIL_AUTH,
|
|
109
|
+
emailOtpEnabled: false,
|
|
110
|
+
phoneOtpEnabled: true,
|
|
111
|
+
shouldThrow: true,
|
|
112
|
+
errorType: utils_1.MedusaError.Types.NOT_ALLOWED,
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
title: "email_auth returns JWT and customer for new user",
|
|
116
|
+
body: { token: "t", code: "123456", first_name: "New" },
|
|
117
|
+
purpose: otp_verification_1.OtpPurpose.EMAIL_AUTH,
|
|
118
|
+
emailOtpEnabled: true,
|
|
119
|
+
phoneOtpEnabled: true,
|
|
120
|
+
workflowResult: {
|
|
121
|
+
customer: { id: "cus_new", email: "new@example.com", first_name: "New" },
|
|
122
|
+
auth_identity: { id: "auth_1" },
|
|
123
|
+
is_new_user: true,
|
|
124
|
+
},
|
|
125
|
+
shouldThrow: false,
|
|
126
|
+
expectedStatus: 200,
|
|
127
|
+
expectedJson: {
|
|
128
|
+
verified: true,
|
|
129
|
+
token: "customer_jwt",
|
|
130
|
+
customer: { id: "cus_new", email: "new@example.com", first_name: "New" },
|
|
131
|
+
is_new_user: true,
|
|
132
|
+
needs_login: false,
|
|
133
|
+
},
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
title: "phone_auth returns JWT and customer for new user",
|
|
137
|
+
body: { token: "t", code: "123456", first_name: "New" },
|
|
138
|
+
purpose: otp_verification_1.OtpPurpose.PHONE_AUTH,
|
|
139
|
+
emailOtpEnabled: true,
|
|
140
|
+
phoneOtpEnabled: true,
|
|
141
|
+
workflowResult: {
|
|
142
|
+
customer: { id: "cus_new", phone: "+15559876543", first_name: "New" },
|
|
143
|
+
auth_identity: { id: "auth_1" },
|
|
144
|
+
is_new_user: true,
|
|
145
|
+
},
|
|
146
|
+
shouldThrow: false,
|
|
147
|
+
expectedStatus: 200,
|
|
148
|
+
expectedJson: {
|
|
149
|
+
verified: true,
|
|
150
|
+
token: "customer_jwt",
|
|
151
|
+
customer: { id: "cus_new", phone: "+15559876543", first_name: "New" },
|
|
152
|
+
is_new_user: true,
|
|
153
|
+
needs_login: false,
|
|
154
|
+
},
|
|
155
|
+
},
|
|
156
|
+
{
|
|
157
|
+
title: "email_verification returns verified customer",
|
|
158
|
+
body: { token: "t", code: "123456" },
|
|
159
|
+
purpose: otp_verification_1.OtpPurpose.EMAIL_VERIFICATION,
|
|
160
|
+
emailOtpEnabled: true,
|
|
161
|
+
phoneOtpEnabled: true,
|
|
162
|
+
shouldThrow: false,
|
|
163
|
+
expectedStatus: 200,
|
|
164
|
+
expectedJson: {
|
|
165
|
+
verified: true,
|
|
166
|
+
customer: { id: "cus_1", email: "user@example.com" },
|
|
167
|
+
email_verified: true,
|
|
168
|
+
token: null,
|
|
169
|
+
needs_login: true,
|
|
170
|
+
},
|
|
171
|
+
},
|
|
172
|
+
];
|
|
173
|
+
vitest_1.test.each(cases)("$title", async ({ body, purpose, emailOtpEnabled, phoneOtpEnabled, verifyOtpThrows, workflowResult, shouldThrow, errorType, expectedStatus, expectedJson, }) => {
|
|
174
|
+
mockedResolvePurpose.mockReturnValue(purpose);
|
|
175
|
+
mockedIsEmailOtpEnabled.mockReturnValue(emailOtpEnabled);
|
|
176
|
+
mockedIsPhoneOtpEnabled.mockReturnValue(phoneOtpEnabled);
|
|
177
|
+
const verifyEmailAuthOtp = vitest_1.vi.fn().mockResolvedValue({
|
|
178
|
+
verified: true,
|
|
179
|
+
email: "new@example.com",
|
|
180
|
+
customer_id: null,
|
|
181
|
+
type: otp_verification_1.OtpPurpose.EMAIL_AUTH,
|
|
182
|
+
});
|
|
183
|
+
const verifyPhoneAuthOtp = vitest_1.vi.fn().mockResolvedValue({
|
|
184
|
+
verified: true,
|
|
185
|
+
phone: "+15559876543",
|
|
186
|
+
customer_id: null,
|
|
187
|
+
type: otp_verification_1.OtpPurpose.PHONE_AUTH,
|
|
188
|
+
});
|
|
189
|
+
const verifyOtp = verifyOtpThrows
|
|
190
|
+
? vitest_1.vi.fn().mockRejectedValue(verifyOtpThrows)
|
|
191
|
+
: vitest_1.vi.fn().mockResolvedValue({
|
|
192
|
+
verified: true,
|
|
193
|
+
customer_id: "cus_1",
|
|
194
|
+
type: otp_verification_1.OtpPurpose.EMAIL_VERIFICATION,
|
|
195
|
+
});
|
|
196
|
+
if (workflowResult && purpose === otp_verification_1.OtpPurpose.EMAIL_AUTH) {
|
|
197
|
+
mockedEmailAuthWorkflow.mockReturnValue({
|
|
198
|
+
run: vitest_1.vi.fn().mockResolvedValue({ result: workflowResult }),
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
if (workflowResult && purpose === otp_verification_1.OtpPurpose.PHONE_AUTH) {
|
|
202
|
+
mockedPhoneAuthWorkflow.mockReturnValue({
|
|
203
|
+
run: vitest_1.vi.fn().mockResolvedValue({ result: workflowResult }),
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
const req = {
|
|
207
|
+
body,
|
|
208
|
+
scope: {
|
|
209
|
+
resolve: (token) => {
|
|
210
|
+
if (token === utils_1.ContainerRegistrationKeys.CONFIG_MODULE) {
|
|
211
|
+
return {
|
|
212
|
+
projectConfig: { http: { jwtSecret: "secret", jwtExpiresIn: "7d" } },
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
if (token === otp_verification_2.OTP_VERIFICATION_MODULE) {
|
|
216
|
+
return { verifyEmailAuthOtp, verifyPhoneAuthOtp, verifyOtp };
|
|
217
|
+
}
|
|
218
|
+
if (token === utils_1.ContainerRegistrationKeys.PG_CONNECTION) {
|
|
219
|
+
return {
|
|
220
|
+
raw: vitest_1.vi.fn().mockResolvedValue({ rows: [] }),
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
return undefined;
|
|
224
|
+
},
|
|
225
|
+
},
|
|
226
|
+
};
|
|
227
|
+
const status = vitest_1.vi.fn().mockReturnThis();
|
|
228
|
+
const json = vitest_1.vi.fn();
|
|
229
|
+
const res = { status, json };
|
|
230
|
+
const exec = () => (0, route_1.POST)(req, res);
|
|
231
|
+
if (shouldThrow) {
|
|
232
|
+
await (0, vitest_1.expect)(exec()).rejects.toMatchObject({ type: errorType });
|
|
233
|
+
return;
|
|
234
|
+
}
|
|
235
|
+
await exec();
|
|
236
|
+
(0, vitest_1.expect)(status).toHaveBeenCalledWith(expectedStatus);
|
|
237
|
+
(0, vitest_1.expect)(json).toHaveBeenCalledWith(expectedJson);
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5LXJvdXRlLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL3N0b3JlL2N1c3RvbWVycy9vdHAvX190ZXN0c19fL3ZlcmlmeS1yb3V0ZS50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQ0EscURBQWtGO0FBQ2xGLG1DQUErRDtBQUMvRCxrREFBb0Y7QUFDcEYsc0dBQTRGO0FBQzVGLDhFQUFpRjtBQUNqRiw2SEFBZ0c7QUFDaEcsNkhBQWdHO0FBQ2hHLHlGQUF1RTtBQUN2RSxzR0FBZ0c7QUFDaEcsbUZBQTRFO0FBQzVFLDJDQUFzQztBQUV0QyxXQUFFLENBQUMsSUFBSSxDQUFDLHVCQUF1QixFQUFFLEtBQUssRUFBRSxjQUFjLEVBQUUsRUFBRTtJQUN4RCxNQUFNLE1BQU0sR0FBRyxNQUFNLGNBQWMsRUFBMEMsQ0FBQTtJQUM3RSxPQUFPO1FBQ0wsR0FBRyxNQUFNO1FBQ1QscUJBQXFCLEVBQUUsV0FBRSxDQUFDLEVBQUUsRUFBRTtRQUM5QixxQkFBcUIsRUFBRSxXQUFFLENBQUMsRUFBRSxFQUFFO1FBQzlCLGtDQUFrQyxFQUFFLFdBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQztZQUMvQyxLQUFLLEVBQUUsRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFO1lBQzlCLFlBQVksRUFBRSxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsSUFBSSxFQUFFO1lBQ2pFLElBQUksRUFBRTtnQkFDSixLQUFLLEVBQUUsRUFBRSxPQUFPLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDM0IsS0FBSyxFQUFFLEVBQUUsT0FBTyxFQUFFLENBQUMsS0FBSyxDQUFDLEVBQUU7YUFDNUI7U0FDRixDQUFDLENBQUM7S0FDSixDQUFBO0FBQ0gsQ0FBQyxDQUFDLENBQUE7QUFFRixXQUFFLENBQUMsSUFBSSxDQUFDLHFDQUFxQyxFQUFF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
|
|
@@ -7,19 +7,57 @@ exports.POST = void 0;
|
|
|
7
7
|
const utils_1 = require("@medusajs/framework/utils");
|
|
8
8
|
const otp_verification_1 = require("../../../../../modules/otp-verification/models/otp-verification");
|
|
9
9
|
const send_otp_workflow_1 = __importDefault(require("../../../../../workflows/send-otp-workflow"));
|
|
10
|
+
const handle_send_email_auth_otp_1 = require("../shared/handle-send-email-auth-otp");
|
|
11
|
+
const handle_send_phone_auth_otp_1 = require("../shared/handle-send-phone-auth-otp");
|
|
12
|
+
const VERIFICATION_TYPES = new Set([
|
|
13
|
+
otp_verification_1.OtpPurpose.EMAIL_VERIFICATION,
|
|
14
|
+
otp_verification_1.OtpPurpose.PHONE_VERIFICATION,
|
|
15
|
+
]);
|
|
16
|
+
const AUTH_TYPES = new Set([
|
|
17
|
+
otp_verification_1.OtpPurpose.EMAIL_AUTH,
|
|
18
|
+
otp_verification_1.OtpPurpose.PHONE_AUTH,
|
|
19
|
+
]);
|
|
10
20
|
const POST = async (req, res) => {
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "customer_id is required");
|
|
14
|
-
}
|
|
21
|
+
const body = (req.body ?? {});
|
|
22
|
+
const { customer_id, email, phone, type } = body;
|
|
15
23
|
if (!type || !Object.values(otp_verification_1.OtpPurpose).includes(type)) {
|
|
16
24
|
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Type must be one of: ${Object.values(otp_verification_1.OtpPurpose).join(", ")}`);
|
|
17
25
|
}
|
|
18
|
-
|
|
26
|
+
const purpose = type;
|
|
27
|
+
if (AUTH_TYPES.has(purpose)) {
|
|
28
|
+
if (customer_id) {
|
|
29
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "customer_id must not be provided for auth OTP types");
|
|
30
|
+
}
|
|
31
|
+
if (purpose === otp_verification_1.OtpPurpose.EMAIL_AUTH) {
|
|
32
|
+
if (!email || typeof email !== "string") {
|
|
33
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "email is required for email_auth");
|
|
34
|
+
}
|
|
35
|
+
if (phone) {
|
|
36
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "phone must not be provided for email_auth");
|
|
37
|
+
}
|
|
38
|
+
return (0, handle_send_email_auth_otp_1.handleSendEmailAuthOtp)(req, res, email);
|
|
39
|
+
}
|
|
40
|
+
if (!phone || typeof phone !== "string") {
|
|
41
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "phone is required for phone_auth");
|
|
42
|
+
}
|
|
43
|
+
if (email) {
|
|
44
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "email must not be provided for phone_auth");
|
|
45
|
+
}
|
|
46
|
+
return (0, handle_send_phone_auth_otp_1.handleSendPhoneAuthOtp)(req, res, phone);
|
|
47
|
+
}
|
|
48
|
+
if (!VERIFICATION_TYPES.has(purpose)) {
|
|
49
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, `Type ${type} is not supported for this endpoint`);
|
|
50
|
+
}
|
|
51
|
+
if (!customer_id) {
|
|
52
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "customer_id is required for verification OTP types");
|
|
53
|
+
}
|
|
54
|
+
if (email || phone) {
|
|
55
|
+
throw new utils_1.MedusaError(utils_1.MedusaError.Types.INVALID_DATA, "email and phone must not be provided for verification OTP types");
|
|
56
|
+
}
|
|
19
57
|
const { result } = await (0, send_otp_workflow_1.default)(req.scope).run({
|
|
20
58
|
input: {
|
|
21
59
|
customer_id,
|
|
22
|
-
type:
|
|
60
|
+
type: purpose,
|
|
23
61
|
},
|
|
24
62
|
});
|
|
25
63
|
return res.status(200).json({
|
|
@@ -28,4 +66,4 @@ const POST = async (req, res) => {
|
|
|
28
66
|
});
|
|
29
67
|
};
|
|
30
68
|
exports.POST = POST;
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL3N0b3JlL2N1c3RvbWVycy9vdHAvc2VuZC9yb3V0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSxxREFBdUQ7QUFDdkQsc0dBQTRGO0FBQzVGLG1HQUF3RTtBQUN4RSxxRkFBNkU7QUFDN0UscUZBQTZFO0FBRTdFLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxHQUFHLENBQWE7SUFDN0MsNkJBQVUsQ0FBQyxrQkFBa0I7SUFDN0IsNkJBQVUsQ0FBQyxrQkFBa0I7Q0FDOUIsQ0FBQyxDQUFBO0FBRUYsTUFBTSxVQUFVLEdBQUcsSUFBSSxHQUFHLENBQWE7SUFDckMsNkJBQVUsQ0FBQyxVQUFVO0lBQ3JCLDZCQUFVLENBQUMsVUFBVTtDQUN0QixDQUFDLENBQUE7QUFFSyxNQUFNLElBQUksR0FBRyxLQUFLLEVBQUUsR0FBa0IsRUFBRSxHQUFtQixFQUFFLEVBQUU7SUFDcEUsTUFBTSxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FLM0IsQ0FBQTtJQUVELE1BQU0sRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUE7SUFFaEQsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsNkJBQVUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFrQixDQUFDLEVBQUUsQ0FBQztRQUNyRSxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5Qix3QkFBd0IsTUFBTSxDQUFDLE1BQU0sQ0FBQyw2QkFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQy9ELENBQUE7SUFDSCxDQUFDO0lBRUQsTUFBTSxPQUFPLEdBQUcsSUFBa0IsQ0FBQTtJQUVsQyxJQUFJLFVBQVUsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUM1QixJQUFJLFdBQVcsRUFBRSxDQUFDO1lBQ2hCLE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQzlCLHFEQUFxRCxDQUN0RCxDQUFBO1FBQ0gsQ0FBQztRQUVELElBQUksT0FBTyxLQUFLLDZCQUFVLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDdEMsSUFBSSxDQUFDLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztnQkFDeEMsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLFlBQVksRUFDOUIsa0NBQWtDLENBQ25DLENBQUE7WUFDSCxDQUFDO1lBQ0QsSUFBSSxLQUFLLEVBQUUsQ0FBQztnQkFDVixNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5QiwyQ0FBMkMsQ0FDNUMsQ0FBQTtZQUNILENBQUM7WUFDRCxPQUFPLElBQUEsbURBQXNCLEVBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQTtRQUNoRCxDQUFDO1FBRUQsSUFBSSxDQUFDLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUN4QyxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5QixrQ0FBa0MsQ0FDbkMsQ0FBQTtRQUNILENBQUM7UUFDRCxJQUFJLEtBQUssRUFBRSxDQUFDO1lBQ1YsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLFlBQVksRUFDOUIsMkNBQTJDLENBQzVDLENBQUE7UUFDSCxDQUFDO1FBQ0QsT0FBTyxJQUFBLG1EQUFzQixFQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUE7SUFDaEQsQ0FBQztJQUVELElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUNyQyxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5QixRQUFRLElBQUkscUNBQXFDLENBQ2xELENBQUE7SUFDSCxDQUFDO0lBRUQsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ2pCLE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQzlCLG9EQUFvRCxDQUNyRCxDQUFBO0lBQ0gsQ0FBQztJQUVELElBQUksS0FBSyxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQ25CLE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQzlCLGlFQUFpRSxDQUNsRSxDQUFBO0lBQ0gsQ0FBQztJQUVELE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLElBQUEsMkJBQWUsRUFBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxDQUFDO1FBQ3RELEtBQUssRUFBRTtZQUNMLFdBQVc7WUFDWCxJQUFJLEVBQUUsT0FBTztTQUNkO0tBQ0YsQ0FBQyxDQUFBO0lBRUYsT0FBTyxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQztRQUMxQixLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUs7UUFDbkIsVUFBVSxFQUFFLE1BQU0sQ0FBQyxVQUFVO0tBQzlCLENBQUMsQ0FBQTtBQUNKLENBQUMsQ0FBQTtBQTFGWSxRQUFBLElBQUksUUEwRmhCIn0=
|