customer-registration 0.0.127 → 0.0.129

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 (31) hide show
  1. package/.medusa/server/src/api/middlewares.js +2 -7
  2. package/.medusa/server/src/api/store/customers/otp/__tests__/send-route.test.js +240 -0
  3. package/.medusa/server/src/api/store/customers/otp/__tests__/verify-route.test.js +240 -0
  4. package/.medusa/server/src/api/store/customers/otp/send/route.js +45 -7
  5. package/.medusa/server/src/api/store/customers/otp/shared/email-auth-helpers.js +62 -0
  6. package/.medusa/server/src/api/store/customers/otp/shared/handle-send-email-auth-otp.js +45 -0
  7. package/.medusa/server/src/api/store/customers/otp/shared/handle-send-phone-auth-otp.js +45 -0
  8. package/.medusa/server/src/api/store/customers/otp/shared/handle-verify-email-auth-otp.js +54 -0
  9. package/.medusa/server/src/api/store/customers/otp/shared/handle-verify-phone-auth-otp.js +54 -0
  10. package/.medusa/server/src/api/{auth/customer/phoneotp → store/customers/otp}/shared/phone-auth-helpers.js +1 -1
  11. package/.medusa/server/src/api/store/customers/otp/shared/resolve-otp-token-purpose.js +27 -0
  12. package/.medusa/server/src/api/store/customers/otp/verify/route.js +22 -28
  13. package/.medusa/server/src/api/store/customers/route.js +10 -14
  14. package/.medusa/server/src/api/store/customers/shared/__tests__/create-phone-only-customer.test.js +67 -0
  15. package/.medusa/server/src/api/store/customers/shared/create-phone-only-customer.js +43 -0
  16. package/.medusa/server/src/config.js +3 -3
  17. package/.medusa/server/src/providers/emailotp/service.js +2 -2
  18. package/.medusa/server/src/providers/phoneotp/service.js +2 -2
  19. package/.medusa/server/src/workflows/steps/resolve-or-create-email-auth-customer-step.js +2 -2
  20. package/.medusa/server/src/workflows/steps/resolve-or-create-phone-auth-customer-step.js +8 -47
  21. package/README.md +76 -114
  22. package/package.json +1 -1
  23. package/.medusa/server/src/api/auth/customer/emailotp/__tests__/send-route.test.js +0 -151
  24. package/.medusa/server/src/api/auth/customer/emailotp/__tests__/verify-route.test.js +0 -171
  25. package/.medusa/server/src/api/auth/customer/emailotp/send/route.js +0 -51
  26. package/.medusa/server/src/api/auth/customer/emailotp/shared/email-auth-helpers.js +0 -62
  27. package/.medusa/server/src/api/auth/customer/emailotp/verify/route.js +0 -54
  28. package/.medusa/server/src/api/auth/customer/phoneotp/__tests__/send-route.test.js +0 -153
  29. package/.medusa/server/src/api/auth/customer/phoneotp/__tests__/verify-route.test.js +0 -158
  30. package/.medusa/server/src/api/auth/customer/phoneotp/send/route.js +0 -51
  31. 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: "/auth/customer/emailotp/send",
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlkZGxld2FyZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBpL21pZGRsZXdhcmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsbURBQStEO0FBQy9ELG1EQUFzRjtBQUN0RixvRkFBZ0c7QUFDaEcsZ0ZBQXdGO0FBQ3hGLGlGQUEyRTtBQUMzRSxpR0FBMkY7QUFDM0YsK0RBQXlEO0FBQ3pELDZEQUE4RTtBQUU5RSxNQUFNLDZCQUE2QixHQUFHLElBQUEscUNBQXlCLEVBQzdELG1DQUFzQixFQUN0QiwyQ0FBNEIsQ0FDN0IsQ0FBQTtBQUVELGtCQUFlLElBQUEsd0JBQWlCLEVBQUM7SUFDL0IsTUFBTSxFQUFFO1FBQ047WUFDRSxPQUFPLEVBQUUsa0JBQWtCO1lBQzNCLFdBQVcsRUFBRSxDQUFDLDZDQUFvQixDQUFDO1NBQ3BDO1FBQ0Q7WUFDRSxPQUFPLEVBQUUsVUFBVTtZQUNuQixXQUFXLEVBQUUsQ0FBQyw2Q0FBb0IsQ0FBQztTQUNwQztRQUNEO1lBQ0UsT0FBTyxFQUFFLGtCQUFrQjtZQUMzQixNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDaEIsV0FBVyxFQUFFO2dCQUNYLElBQUEsK0JBQXdCLEVBQUMsNENBQStCLENBQUM7Z0JBQ3pELDZEQUE0QjthQUM3QjtTQUNGO1FBQ0Q7WUFDRSxPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxDQUFDLEtBQUssQ0FBQztZQUNmLFdBQVcsRUFBRSxDQUFDLDZCQUE2QixDQUFDO1NBQzdDO1FBQ0Q7WUFDRSxPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxDQUFDLE9BQU8sQ0FBQztZQUNqQixXQUFXLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztTQUM3QztRQUNEO1lBQ0UsbUVBQW1FO1lBQ25FLE9BQU8sRUFBRSxrREFBa0Q7WUFDM0QsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ2hCLFdBQVcsRUFBRSxDQUFDLElBQUEsMkJBQVcsRUFBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7U0FDekQ7UUFDRDtZQUNFLE9BQU8sRUFBRSw4QkFBOEI7WUFDdkMsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ2hCLFdBQVcsRUFBRSxDQUFDLElBQUEsMkJBQVcsRUFBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7U0FDekQ7UUFDRDtZQUNFLE9BQU8sRUFBRSw4QkFBOEI7WUFDdkMsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ2hCLFdBQVcsRUFBRSxDQUFDLElBQUEsMkJBQVcsRUFBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7U0FDekQ7S0FDRjtDQUNGLENBQUMsQ0FBQSJ9
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 { customer_id, type } = req.body;
12
- if (!customer_id) {
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
- // Execute workflow
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: 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL3N0b3JlL2N1c3RvbWVycy9vdHAvc2VuZC9yb3V0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSxxREFBdUQ7QUFDdkQsc0dBQTRGO0FBQzVGLG1HQUF3RTtBQUVqRSxNQUFNLElBQUksR0FBRyxLQUFLLEVBQUUsR0FBa0IsRUFBRSxHQUFtQixFQUFFLEVBQUU7SUFDcEUsTUFBTSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsR0FBRyxHQUFHLENBQUMsSUFHakMsQ0FBQTtJQUVELElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNqQixNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5Qix5QkFBeUIsQ0FDMUIsQ0FBQTtJQUNILENBQUM7SUFFRCxJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyw2QkFBVSxDQUFDLENBQUMsUUFBUSxDQUFDLElBQWtCLENBQUMsRUFBRSxDQUFDO1FBQ3JFLE1BQU0sSUFBSSxtQkFBVyxDQUNuQixtQkFBVyxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQzlCLHdCQUF3QixNQUFNLENBQUMsTUFBTSxDQUFDLDZCQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FDL0QsQ0FBQTtJQUNILENBQUM7SUFHRCxtQkFBbUI7SUFDbkIsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLE1BQU0sSUFBQSwyQkFBZSxFQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLENBQUM7UUFDdEQsS0FBSyxFQUFFO1lBQ0wsV0FBVztZQUNYLElBQUksRUFBRSxJQUFrQjtTQUN6QjtLQUNGLENBQUMsQ0FBQTtJQUVGLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFDMUIsS0FBSyxFQUFFLE1BQU0sQ0FBQyxLQUFLO1FBQ25CLFVBQVUsRUFBRSxNQUFNLENBQUMsVUFBVTtLQUM5QixDQUFDLENBQUE7QUFDSixDQUFDLENBQUE7QUFqQ1ksUUFBQSxJQUFJLFFBaUNoQiJ9
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL3N0b3JlL2N1c3RvbWVycy9vdHAvc2VuZC9yb3V0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSxxREFBdUQ7QUFDdkQsc0dBQTRGO0FBQzVGLG1HQUF3RTtBQUN4RSxxRkFBNkU7QUFDN0UscUZBQTZFO0FBRTdFLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxHQUFHLENBQWE7SUFDN0MsNkJBQVUsQ0FBQyxrQkFBa0I7SUFDN0IsNkJBQVUsQ0FBQyxrQkFBa0I7Q0FDOUIsQ0FBQyxDQUFBO0FBRUYsTUFBTSxVQUFVLEdBQUcsSUFBSSxHQUFHLENBQWE7SUFDckMsNkJBQVUsQ0FBQyxVQUFVO0lBQ3JCLDZCQUFVLENBQUMsVUFBVTtDQUN0QixDQUFDLENBQUE7QUFFSyxNQUFNLElBQUksR0FBRyxLQUFLLEVBQUUsR0FBa0IsRUFBRSxHQUFtQixFQUFFLEVBQUU7SUFDcEUsTUFBTSxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxJQUFJLEVBQUUsQ0FLM0IsQ0FBQTtJQUVELE1BQU0sRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUE7SUFFaEQsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsNkJBQVUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFrQixDQUFDLEVBQUUsQ0FBQztRQUNyRSxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5Qix3QkFBd0IsTUFBTSxDQUFDLE1BQU0sQ0FBQyw2QkFBVSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQy9ELENBQUE7SUFDSCxDQUFDO0lBRUQsTUFBTSxPQUFPLEdBQUcsSUFBa0IsQ0FBQTtJQUVsQyxJQUFJLFVBQVUs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