customer-registration 0.0.126 → 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.
Files changed (39) hide show
  1. package/.medusa/server/src/api/auth/customer/shared/complete-customer-login.js +11 -6
  2. package/.medusa/server/src/api/middlewares.js +6 -1
  3. package/.medusa/server/src/api/store/customers/otp/__tests__/send-route.test.js +240 -0
  4. package/.medusa/server/src/api/store/customers/otp/__tests__/verify-route.test.js +240 -0
  5. package/.medusa/server/src/api/store/customers/otp/send/route.js +45 -7
  6. package/.medusa/server/src/api/store/customers/otp/shared/email-auth-helpers.js +62 -0
  7. package/.medusa/server/src/api/store/customers/otp/shared/handle-send-email-auth-otp.js +45 -0
  8. package/.medusa/server/src/api/store/customers/otp/shared/handle-send-phone-auth-otp.js +45 -0
  9. package/.medusa/server/src/api/store/customers/otp/shared/handle-verify-email-auth-otp.js +54 -0
  10. package/.medusa/server/src/api/store/customers/otp/shared/handle-verify-phone-auth-otp.js +54 -0
  11. package/.medusa/server/src/api/store/customers/otp/shared/phone-auth-helpers.js +63 -0
  12. package/.medusa/server/src/api/store/customers/otp/shared/resolve-otp-token-purpose.js +27 -0
  13. package/.medusa/server/src/api/store/customers/otp/verify/route.js +22 -28
  14. package/.medusa/server/src/api/store/customers/route.js +6 -105
  15. package/.medusa/server/src/api/store/customers/shared/referral-code.js +91 -0
  16. package/.medusa/server/src/config/__tests__/email-auth-config.test.js +37 -0
  17. package/.medusa/server/src/config/__tests__/phone-auth-config.test.js +37 -0
  18. package/.medusa/server/src/config.js +25 -1
  19. package/.medusa/server/src/modules/otp-verification/migrations/Migration20250603000000AddEmailAuthOtp.js +67 -0
  20. package/.medusa/server/src/modules/otp-verification/migrations/Migration20250603100000AddPhoneAuthOtp.js +61 -0
  21. package/.medusa/server/src/modules/otp-verification/models/otp-verification.js +8 -2
  22. package/.medusa/server/src/modules/otp-verification/service.js +248 -1
  23. package/.medusa/server/src/providers/emailotp/index.js +9 -0
  24. package/.medusa/server/src/providers/emailotp/service.js +68 -0
  25. package/.medusa/server/src/providers/phoneotp/index.js +9 -0
  26. package/.medusa/server/src/providers/phoneotp/service.js +68 -0
  27. package/.medusa/server/src/providers/phonepass/service.js +5 -5
  28. package/.medusa/server/src/utils/phone-validation.js +26 -0
  29. package/.medusa/server/src/workflows/send-email-auth-otp-workflow.js +42 -0
  30. package/.medusa/server/src/workflows/send-phone-auth-otp-workflow.js +42 -0
  31. package/.medusa/server/src/workflows/steps/generate-email-auth-otp-step.js +25 -0
  32. package/.medusa/server/src/workflows/steps/generate-phone-auth-otp-step.js +25 -0
  33. package/.medusa/server/src/workflows/steps/index.js +10 -2
  34. package/.medusa/server/src/workflows/steps/resolve-or-create-email-auth-customer-step.js +125 -0
  35. package/.medusa/server/src/workflows/steps/resolve-or-create-phone-auth-customer-step.js +151 -0
  36. package/.medusa/server/src/workflows/verify-email-auth-otp-workflow.js +20 -0
  37. package/.medusa/server/src/workflows/verify-phone-auth-otp-workflow.js +20 -0
  38. package/README.md +109 -11
  39. package/package.json +1 -1
@@ -1,13 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.issueCustomerJwtToken = issueCustomerJwtToken;
3
4
  exports.completeCustomerLogin = completeCustomerLogin;
4
5
  const utils_1 = require("@medusajs/framework/utils");
5
6
  const generate_jwt_token_1 = require("@medusajs/medusa/api/auth/utils/generate-jwt-token");
6
7
  const account_deletion_request_1 = require("../../../../modules/account-deletion-request");
7
8
  /**
8
- * Pending deletion check, merge customer_id into app_metadata, issue JWT, respond 200 `{ token }`.
9
+ * Pending deletion check, merge customer_id into app_metadata, issue customer JWT.
9
10
  */
10
- async function completeCustomerLogin(req, res, config, authIdentity, customerId, logContext) {
11
+ async function issueCustomerJwtToken(req, config, authIdentity, customerId) {
11
12
  const accountDeletionService = req.scope.resolve(account_deletion_request_1.ACCOUNT_DELETION_REQUEST_MODULE);
12
13
  if (await accountDeletionService.hasPendingRequest(customerId)) {
13
14
  throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNAUTHORIZED, "Customer has an active account deletion request");
@@ -37,11 +38,15 @@ async function completeCustomerLogin(req, res, config, authIdentity, customerId,
37
38
  throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNEXPECTED_STATE, `JWT generation failed: ${jwtError instanceof Error ? jwtError.message : "Unknown error"}`);
38
39
  }
39
40
  if (!token || typeof token !== "string") {
40
- if (logContext.kind === "email") {
41
- throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNEXPECTED_STATE, `Failed to generate authentication token for customer ${customerId}. Token type: ${typeof token}, Token value: ${token}`);
42
- }
43
41
  throw new utils_1.MedusaError(utils_1.MedusaError.Types.UNEXPECTED_STATE, "Failed to generate authentication token");
44
42
  }
43
+ return token;
44
+ }
45
+ /**
46
+ * Pending deletion check, merge customer_id into app_metadata, issue JWT, respond 200 `{ token }`.
47
+ */
48
+ async function completeCustomerLogin(req, res, config, authIdentity, customerId, logContext) {
49
+ const token = await issueCustomerJwtToken(req, config, authIdentity, customerId);
45
50
  res.status(200).json({ token });
46
51
  }
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGxldGUtY3VzdG9tZXItbG9naW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL2F1dGgvY3VzdG9tZXIvc2hhcmVkL2NvbXBsZXRlLWN1c3RvbWVyLWxvZ2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBcUJBLHNEQXFFQztBQXhGRCxxREFBdUQ7QUFDdkQsMkZBQW9HO0FBQ3BHLDJGQUE4RjtBQWM5Rjs7R0FFRztBQUNJLEtBQUssVUFBVSxxQkFBcUIsQ0FDekMsR0FBa0IsRUFDbEIsR0FBbUIsRUFDbkIsTUFBMEIsRUFDMUIsWUFBK0IsRUFDL0IsVUFBa0IsRUFDbEIsVUFBK0U7SUFFL0UsTUFBTSxzQkFBc0IsR0FDMUIsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQ2YsMERBQStCLENBQ2hDLENBQUE7SUFDSCxJQUFJLE1BQU0sc0JBQXNCLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztRQUMvRCxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5QixpREFBaUQsQ0FDbEQsQ0FBQTtJQUNILENBQUM7SUFFRCxNQUFNLDBCQUEwQixHQUFHO1FBQ2pDLEdBQUcsWUFBWTtRQUNmLFlBQVksRUFBRTtZQUNaLEdBQUcsWUFBWSxDQUFDLFlBQVk7WUFDNUIsV0FBVyxFQUFFLFVBQVU7U0FDeEI7S0FDRixDQUFBO0lBRUQsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLE1BQU0sQ0FBQyxhQUFhLElBQUksRUFBRSxDQUFBO0lBRTNDLElBQUksQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7UUFDckIsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLFlBQVksRUFDOUIsOEJBQThCLENBQy9CLENBQUE7SUFDSCxDQUFDO0lBRUQsSUFBSSxLQUF5QixDQUFBO0lBQzdCLElBQUksQ0FBQztRQUNILEtBQUssR0FBRyxNQUFNLElBQUEsb0RBQStCLEVBQzNDO1lBQ0UsWUFBWSxFQUFFLDBCQUF3RDtZQUN0RSxTQUFTLEVBQUUsVUFBVTtTQUN0QixFQUNEO1lBQ0UsTUFBTSxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3RCLFNBQVMsRUFBRSxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUk7U0FDckMsQ0FDRixDQUFBO0lBQ0gsQ0FBQztJQUFDLE9BQU8sUUFBUSxFQUFFLENBQUM7UUFDbEIsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUNsQywwQkFBMEIsUUFBUSxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsZUFBZSxFQUFFLENBQzNGLENBQUE7SUFDSCxDQUFDO0lBRUQsSUFBSSxDQUFDLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztRQUN4QyxJQUFJLFVBQVUsQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFFLENBQUM7WUFDaEMsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUNsQyx3REFBd0QsVUFBVSxpQkFBaUIsT0FBTyxLQUFLLGtCQUFrQixLQUFLLEVBQUUsQ0FDekgsQ0FBQTtRQUNILENBQUM7UUFDRCxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQ2xDLHlDQUF5QyxDQUMxQyxDQUFBO0lBQ0gsQ0FBQztJQUVELEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQTtBQUNqQyxDQUFDIn0=
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGxldGUtY3VzdG9tZXItbG9naW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBpL2F1dGgvY3VzdG9tZXIvc2hhcmVkL2NvbXBsZXRlLWN1c3RvbWVyLWxvZ2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBcUJBLHNEQTZEQztBQUtELHNEQWdCQztBQXJHRCxxREFBdUQ7QUFDdkQsMkZBQW9HO0FBQ3BHLDJGQUE4RjtBQWM5Rjs7R0FFRztBQUNJLEtBQUssVUFBVSxxQkFBcUIsQ0FDekMsR0FBa0IsRUFDbEIsTUFBMEIsRUFDMUIsWUFBK0IsRUFDL0IsVUFBa0I7SUFFbEIsTUFBTSxzQkFBc0IsR0FDMUIsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQ2YsMERBQStCLENBQ2hDLENBQUE7SUFDSCxJQUFJLE1BQU0sc0JBQXNCLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztRQUMvRCxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUM5QixpREFBaUQsQ0FDbEQsQ0FBQTtJQUNILENBQUM7SUFFRCxNQUFNLDBCQUEwQixHQUFHO1FBQ2pDLEdBQUcsWUFBWTtRQUNmLFlBQVksRUFBRTtZQUNaLEdBQUcsWUFBWSxDQUFDLFlBQVk7WUFDNUIsV0FBVyxFQUFFLFVBQVU7U0FDeEI7S0FDRixDQUFBO0lBRUQsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLE1BQU0sQ0FBQyxhQUFhLElBQUksRUFBRSxDQUFBO0lBRTNDLElBQUksQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLENBQUM7UUFDckIsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLFlBQVksRUFDOUIsOEJBQThCLENBQy9CLENBQUE7SUFDSCxDQUFDO0lBRUQsSUFBSSxLQUF5QixDQUFBO0lBQzdCLElBQUksQ0FBQztRQUNILEtBQUssR0FBRyxNQUFNLElBQUEsb0RBQStCLEVBQzNDO1lBQ0UsWUFBWSxFQUFFLDBCQUF3RDtZQUN0RSxTQUFTLEVBQUUsVUFBVTtTQUN0QixFQUNEO1lBQ0UsTUFBTSxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3RCLFNBQVMsRUFBRSxJQUFJLENBQUMsWUFBWSxJQUFJLElBQUk7U0FDckMsQ0FDRixDQUFBO0lBQ0gsQ0FBQztJQUFDLE9BQU8sUUFBUSxFQUFFLENBQUM7UUFDbEIsTUFBTSxJQUFJLG1CQUFXLENBQ25CLG1CQUFXLENBQUMsS0FBSyxDQUFDLGdCQUFnQixFQUNsQywwQkFBMEIsUUFBUSxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsZUFBZSxFQUFFLENBQzNGLENBQUE7SUFDSCxDQUFDO0lBRUQsSUFBSSxDQUFDLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztRQUN4QyxNQUFNLElBQUksbUJBQVcsQ0FDbkIsbUJBQVcsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLEVBQ2xDLHlDQUF5QyxDQUMxQyxDQUFBO0lBQ0gsQ0FBQztJQUVELE9BQU8sS0FBSyxDQUFBO0FBQ2QsQ0FBQztBQUVEOztHQUVHO0FBQ0ksS0FBSyxVQUFVLHFCQUFxQixDQUN6QyxHQUFrQixFQUNsQixHQUFtQixFQUNuQixNQUEwQixFQUMxQixZQUErQixFQUMvQixVQUFrQixFQUNsQixVQUErRTtJQUUvRSxNQUFNLEtBQUssR0FBRyxNQUFNLHFCQUFxQixDQUN2QyxHQUFHLEVBQ0gsTUFBTSxFQUNOLFlBQVksRUFDWixVQUFVLENBQ1gsQ0FBQTtJQUVELEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQTtBQUNqQyxDQUFDIn0=
@@ -43,6 +43,11 @@ exports.default = (0, http_1.defineMiddlewares)({
43
43
  method: ["POST"],
44
44
  middlewares: [(0, ip_rate_limit_1.ipRateLimit)({ max: 5, windowMs: 60_000 })],
45
45
  },
46
+ {
47
+ matcher: "/store/customers/otp/send",
48
+ method: ["POST"],
49
+ middlewares: [(0, ip_rate_limit_1.ipRateLimit)({ max: 5, windowMs: 60_000 })],
50
+ },
46
51
  ],
47
52
  });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlkZGxld2FyZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBpL21pZGRsZXdhcmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsbURBQStEO0FBQy9ELG1EQUFzRjtBQUN0RixvRkFBZ0c7QUFDaEcsZ0ZBQXdGO0FBQ3hGLGlGQUEyRTtBQUMzRSxpR0FBMkY7QUFDM0YsK0RBQXlEO0FBQ3pELDZEQUE4RTtBQUU5RSxNQUFNLDZCQUE2QixHQUFHLElBQUEscUNBQXlCLEVBQzdELG1DQUFzQixFQUN0QiwyQ0FBNEIsQ0FDN0IsQ0FBQTtBQUVELGtCQUFlLElBQUEsd0JBQWlCLEVBQUM7SUFDL0IsTUFBTSxFQUFFO1FBQ047WUFDRSxPQUFPLEVBQUUsa0JBQWtCO1lBQzNCLFdBQVcsRUFBRSxDQUFDLDZDQUFvQixDQUFDO1NBQ3BDO1FBQ0Q7WUFDRSxPQUFPLEVBQUUsVUFBVTtZQUNuQixXQUFXLEVBQUUsQ0FBQyw2Q0FBb0IsQ0FBQztTQUNwQztRQUNEO1lBQ0UsT0FBTyxFQUFFLGtCQUFrQjtZQUMzQixNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDaEIsV0FBVyxFQUFFO2dCQUNYLElBQUEsK0JBQXdCLEVBQUMsNENBQStCLENBQUM7Z0JBQ3pELDZEQUE0QjthQUM3QjtTQUNGO1FBQ0Q7WUFDRSxPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxDQUFDLEtBQUssQ0FBQztZQUNmLFdBQVcsRUFBRSxDQUFDLDZCQUE2QixDQUFDO1NBQzdDO1FBQ0Q7WUFDRSxPQUFPLEVBQUUscUJBQXFCO1lBQzlCLE1BQU0sRUFBRSxDQUFDLE9BQU8sQ0FBQztZQUNqQixXQUFXLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztTQUM3QztRQUNEO1lBQ0UsbUVBQW1FO1lBQ25FLE9BQU8sRUFBRSxrREFBa0Q7WUFDM0QsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ2hCLFdBQVcsRUFBRSxDQUFDLElBQUEsMkJBQVcsRUFBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7U0FDekQ7S0FDRjtDQUNGLENBQUMsQ0FBQSJ9
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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