From b63bd81a20b1b2265fdd6f804c7379b671745aa5 Mon Sep 17 00:00:00 2001 From: Mihaly Lengyel Date: Mon, 19 Aug 2024 00:29:24 +0200 Subject: [PATCH 1/3] feat: add a route we can use to force refreshes --- .../for-tests/src/AppWithReactDomRouter.js | 7 +- examples/for-tests/src/OAuth2Page.js | 66 +- lib/build/arrowLeftIcon.js | 4 +- lib/build/authCompWrapper.js | 4 +- lib/build/authRecipe-shared.js | 6 +- lib/build/authRecipe-shared2.js | 20 +- lib/build/emailLargeIcon.js | 6 +- lib/build/emailpassword-shared.js | 4 +- lib/build/emailpassword-shared3.js | 135 +- lib/build/emailpassword-shared5.js | 94 +- lib/build/emailpassword.js | 53 +- lib/build/emailpasswordprebuiltui.js | 447 ++--- lib/build/emailverification-shared.js | 109 +- lib/build/emailverification-shared2.js | 41 +- lib/build/emailverification.js | 31 +- lib/build/emailverificationprebuiltui.js | 298 ++-- lib/build/genericComponentOverrideContext.js | 1449 +++++++++++++++- lib/build/index.js | 3 +- lib/build/index2.js | 453 ++--- lib/build/multifactorauth-shared.js | 155 +- lib/build/multifactorauth-shared2.js | 266 +-- lib/build/multifactorauth.js | 7 +- lib/build/multifactorauthprebuiltui.js | 127 +- lib/build/multitenancy.js | 9 +- lib/build/oauth2provider-shared.js | 94 +- lib/build/oauth2provider-shared2.js | 10 + lib/build/oauth2provider.js | 6 +- lib/build/oauth2providerprebuiltui.js | 261 +++ lib/build/passwordless-shared.js | 118 +- lib/build/passwordless.js | 81 +- lib/build/passwordlessprebuiltui.js | 991 ++++++----- .../componentOverrideContext.d.ts | 9 + .../features/tryRefreshPage/index.d.ts | 11 + .../components/themes/translations.d.ts | 3 + .../recipe/oauth2provider/constants.d.ts | 1 + .../oauth2provider/functionOverrides.d.ts | 6 + lib/build/recipe/oauth2provider/index.d.ts | 8 + .../recipe/oauth2provider/prebuiltui.d.ts | 42 + lib/build/recipe/oauth2provider/recipe.d.ts | 9 +- lib/build/recipe/oauth2provider/types.d.ts | 21 +- lib/build/recipeModule-shared.js | 35 +- lib/build/session.js | 91 +- lib/build/sessionprebuiltui.js | 59 +- lib/build/superTokens.js | 1450 ----------------- lib/build/thirdparty-shared.js | 279 ++-- lib/build/thirdparty.js | 35 +- lib/build/thirdpartyprebuiltui.js | 142 +- lib/build/totp-shared.js | 92 +- lib/build/totp.js | 23 +- lib/build/totpprebuiltui.js | 296 ++-- lib/build/translationContext.js | 12 +- lib/build/ui-entry.js | 3 +- .../componentOverrideContext.tsx | 7 + .../features/tryRefreshPage/index.tsx | 90 + .../components/themes/translations.ts | 3 + lib/ts/recipe/oauth2provider/constants.ts | 15 + .../oauth2provider/functionOverrides.ts | 19 + lib/ts/recipe/oauth2provider/index.ts | 4 + lib/ts/recipe/oauth2provider/prebuiltui.tsx | 108 ++ lib/ts/recipe/oauth2provider/recipe.ts | 20 +- lib/ts/recipe/oauth2provider/types.ts | 27 +- lib/ts/recipe/oauth2provider/utils.ts | 1 + package-lock.json | 16 +- recipe/oauth2provider/prebuiltui.d.ts | 17 + recipe/oauth2provider/prebuiltui.js | 20 + rollup.config.mjs | 1 + 66 files changed, 4764 insertions(+), 3566 deletions(-) create mode 100644 lib/build/oauth2provider-shared2.js create mode 100644 lib/build/oauth2providerprebuiltui.js create mode 100644 lib/build/recipe/oauth2provider/componentOverrideContext.d.ts create mode 100644 lib/build/recipe/oauth2provider/components/features/tryRefreshPage/index.d.ts create mode 100644 lib/build/recipe/oauth2provider/components/themes/translations.d.ts create mode 100644 lib/build/recipe/oauth2provider/constants.d.ts create mode 100644 lib/build/recipe/oauth2provider/functionOverrides.d.ts create mode 100644 lib/build/recipe/oauth2provider/prebuiltui.d.ts delete mode 100644 lib/build/superTokens.js create mode 100644 lib/ts/recipe/oauth2provider/componentOverrideContext.tsx create mode 100644 lib/ts/recipe/oauth2provider/components/features/tryRefreshPage/index.tsx create mode 100644 lib/ts/recipe/oauth2provider/components/themes/translations.ts create mode 100644 lib/ts/recipe/oauth2provider/constants.ts create mode 100644 lib/ts/recipe/oauth2provider/functionOverrides.ts create mode 100644 lib/ts/recipe/oauth2provider/prebuiltui.tsx create mode 100644 recipe/oauth2provider/prebuiltui.d.ts create mode 100644 recipe/oauth2provider/prebuiltui.js diff --git a/examples/for-tests/src/AppWithReactDomRouter.js b/examples/for-tests/src/AppWithReactDomRouter.js index f53ee0f30..9e1a664ec 100644 --- a/examples/for-tests/src/AppWithReactDomRouter.js +++ b/examples/for-tests/src/AppWithReactDomRouter.js @@ -7,6 +7,7 @@ import { EmailPasswordPreBuiltUI } from "supertokens-auth-react/recipe/emailpass import { PasswordlessPreBuiltUI } from "supertokens-auth-react/recipe/passwordless/prebuiltui"; import { EmailVerificationPreBuiltUI } from "supertokens-auth-react/recipe/emailverification/prebuiltui"; import { ThirdPartyPreBuiltUI, SignInAndUpCallback } from "supertokens-auth-react/recipe/thirdparty/prebuiltui"; +import { OAuth2ProviderPreBuiltUI } from "supertokens-auth-react/recipe/oauth2provider/prebuiltui"; import { AccessDeniedScreen } from "supertokens-auth-react/recipe/session/prebuiltui"; import { MultiFactorAuthPreBuiltUI } from "supertokens-auth-react/recipe/multifactorauth/prebuiltui"; import { TOTPPreBuiltUI } from "supertokens-auth-react/recipe/totp/prebuiltui"; @@ -31,7 +32,7 @@ function AppWithReactDomRouter(props) { const emailVerificationMode = window.localStorage.getItem("mode") || "OFF"; const websiteBasePath = window.localStorage.getItem("websiteBasePath") || undefined; - let recipePreBuiltUIList = [TOTPPreBuiltUI]; + let recipePreBuiltUIList = [TOTPPreBuiltUI, OAuth2ProviderPreBuiltUI]; if (enabledRecipes.some((r) => r.startsWith("thirdparty"))) { recipePreBuiltUIList.push(ThirdPartyPreBuiltUI); } @@ -174,8 +175,8 @@ function AppWithReactDomRouter(props) { /> )} - } /> - } /> + } /> + } /> diff --git a/examples/for-tests/src/OAuth2Page.js b/examples/for-tests/src/OAuth2Page.js index 76ab8b130..aa5b03839 100644 --- a/examples/for-tests/src/OAuth2Page.js +++ b/examples/for-tests/src/OAuth2Page.js @@ -4,12 +4,18 @@ import { getApiDomain, getWebsiteDomain } from "./config"; // NOTE: For convenience, the same page/component handles both login initiation and callback. // Separate pages for login and callback are not required. +const scopes = window.localStorage.getItem("oauth2-scopes") ?? "profile openid offline_access email"; +const extraConfig = JSON.parse(window.localStorage.getItem("oauth2-extra-config") ?? "{}"); +const extraSignInParams = JSON.parse(window.localStorage.getItem("oauth2-extra-sign-in-params") ?? "{}"); +const extraSignOutParams = JSON.parse(window.localStorage.getItem("oauth2-extra-sign-out-params") ?? "{}"); + const oidcConfig = { client_id: window.localStorage.getItem("oauth2-client-id"), authority: `${getApiDomain()}/auth`, response_type: "code", - redirect_uri: `${getWebsiteDomain()}/oauth2/callback`, - scope: "profile openid offline_access email", + redirect_uri: `${getWebsiteDomain()}/oauth/callback`, + scope: scopes ? scopes : "profile openid offline_access email", + ...extraConfig, onSigninCallback: async (user) => { // Clears the response code and other params from the callback url window.history.replaceState({}, document.title, window.location.pathname); @@ -17,27 +23,57 @@ const oidcConfig = { }; function AuthPage() { - const { signinRedirect, signoutSilent, user, error } = useAuth(); + const { signinRedirect, signinSilent, signoutSilent, user, error } = useAuth(); return (

OAuth2 Login Test

-
- {user ? ( -
+
+ {error &&

Error: {error.message}

} + {user && ( + <>
{JSON.stringify(user.profile, null, 2)}
- -
- ) : ( -
- {error &&

Error: {error.message}

} - -
+ )} + + + + +
); diff --git a/lib/build/arrowLeftIcon.js b/lib/build/arrowLeftIcon.js index 96e4ef41b..0c1efe594 100644 --- a/lib/build/arrowLeftIcon.js +++ b/lib/build/arrowLeftIcon.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); /* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. @@ -27,7 +27,7 @@ function ArrowLeftIcon(_a) { var color = _a.color; return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "11.272", diff --git a/lib/build/authCompWrapper.js b/lib/build/authCompWrapper.js index 7a112772e..ae3e8d5ec 100644 --- a/lib/build/authCompWrapper.js +++ b/lib/build/authCompWrapper.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var uiEntry = require("./index2.js"); @@ -9,7 +9,7 @@ function AuthComponentWrapper(_a) { recipeComponentOverrides = _a.recipeComponentOverrides; return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign({ value: recipeComponentOverrides }, { children: children }) + genericComponentOverrideContext.__assign({ value: recipeComponentOverrides }, { children: children }) ); } diff --git a/lib/build/authRecipe-shared.js b/lib/build/authRecipe-shared.js index a1f7e7efb..a49f45a02 100644 --- a/lib/build/authRecipe-shared.js +++ b/lib/build/authRecipe-shared.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); /* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. * @@ -17,7 +17,7 @@ var superTokens = require("./superTokens.js"); * under the License. */ function normaliseAuthRecipe(config) { - return superTokens.normaliseRecipeModuleConfig(config); + return genericComponentOverrideContext.normaliseRecipeModuleConfig(config); } function selectComponentsToCoverAllFirstFactors(comps, firstFactorIds) { if (firstFactorIds.length === 0) { @@ -45,7 +45,7 @@ function selectComponentsToCoverAllFirstFactors(comps, firstFactorIds) { if (componentsLeft.length !== 0) { var nextComps = selectComponentsToCoverAllFirstFactors(componentsLeft, factorIdsLeft); if (nextComps !== undefined) { - return { value: superTokens.__spreadArray([c], nextComps, true) }; + return { value: genericComponentOverrideContext.__spreadArray([c], nextComps, true) }; } } }; diff --git a/lib/build/authRecipe-shared2.js b/lib/build/authRecipe-shared2.js index 119ec2461..6ac9fc7cf 100644 --- a/lib/build/authRecipe-shared2.js +++ b/lib/build/authRecipe-shared2.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var index = require("./recipeModule-shared.js"); var types = require("./multifactorauth-shared.js"); @@ -19,26 +19,26 @@ var types = require("./multifactorauth-shared.js"); * under the License. */ var AuthRecipe = /** @class */ (function (_super) { - superTokens.__extends(AuthRecipe, _super); + genericComponentOverrideContext.__extends(AuthRecipe, _super); function AuthRecipe() { var _this = (_super !== null && _super.apply(this, arguments)) || this; // eslint-disable-next-line @typescript-eslint/no-unused-vars _this.getAuthRecipeDefaultRedirectionURL = function (_context) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { throw new Error("Should never come here"); }); }); }; _this.signOut = function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, types.Session.getInstanceOrThrow().signOut({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -50,14 +50,14 @@ var AuthRecipe = /** @class */ (function (_super) { }); }; _this.doesSessionExist = function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, types.Session.getInstanceOrThrow().doesSessionExist({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), diff --git a/lib/build/emailLargeIcon.js b/lib/build/emailLargeIcon.js index 54c0b4b70..3985ac948 100644 --- a/lib/build/emailLargeIcon.js +++ b/lib/build/emailLargeIcon.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); /* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. @@ -26,12 +26,12 @@ var jsxRuntime = require("react/jsx-runtime"); function EmailLargeIcon() { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "59.867", height: "40.34", viewBox: "0 0 59.867 40.34" }, { children: jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "email", transform: "translate(0 -83.5)" }, { children: [ diff --git a/lib/build/emailpassword-shared.js b/lib/build/emailpassword-shared.js index e0dae7dd3..2cf2045e7 100644 --- a/lib/build/emailpassword-shared.js +++ b/lib/build/emailpassword-shared.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); require("./index2.js"); var translationContext = require("./translationContext.js"); @@ -20,7 +20,7 @@ function Button(_a) { } return jsxRuntime.jsxs( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { type: type, disabled: disabled, onClick: onClick, "data-supertokens": "button" }, { children: [t(label), isLoading && "..."] } ) diff --git a/lib/build/emailpassword-shared3.js b/lib/build/emailpassword-shared3.js index 57b17541e..7382236e5 100644 --- a/lib/build/emailpassword-shared3.js +++ b/lib/build/emailpassword-shared3.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var EmailPasswordWebJS = require("supertokens-web-js/recipe/emailpassword"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); var index = require("./authRecipe-shared2.js"); @@ -17,19 +17,20 @@ var NormalisedURLPath__default = /*#__PURE__*/ _interopDefault(NormalisedURLPath var getFunctionOverrides = function (onHandleEvent) { return function (originalImp) { - return superTokens.__assign(superTokens.__assign({}, originalImp), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImp), { submitNewPassword: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, originalImp.submitNewPassword( - superTokens.__assign(superTokens.__assign({}, input), { - formFields: [input.formFields[0]], - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { formFields: [input.formFields[0]] } + ) ), ]; case 1: @@ -46,9 +47,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, sendPasswordResetEmail: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.sendPasswordResetEmail(input)]; @@ -70,9 +71,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, signUp: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var payloadBeforeCall, response, payloadAfterCall; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: _c.trys.push([0, 2, , 3]); @@ -132,9 +133,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, signIn: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var payloadBeforeCall, response, payloadAfterCall; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: _c.trys.push([0, 2, , 3]); @@ -215,9 +216,9 @@ var getFunctionOverrides = function (onHandleEvent) { * defaultEmailValidator. */ function defaultEmailValidator(value) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var defaultEmailValidatorRegexp; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { if (typeof value !== "string") { return [2 /*return*/, "ERROR_EMAIL_NON_STRING"]; } @@ -241,8 +242,8 @@ function defaultEmailValidator(value) { * Contains lowercase, uppercase, and numbers. */ function defaultPasswordValidator(value) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { if (typeof value !== "string") { return [2 /*return*/, "ERROR_PASSWORD_NON_STRING"]; } @@ -270,8 +271,8 @@ function defaultPasswordValidator(value) { * type string */ function defaultLoginPasswordValidator(value) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { if (typeof value !== "string") { return [2 /*return*/, "ERROR_PASSWORD_NON_STRING"]; } @@ -284,8 +285,8 @@ function defaultLoginPasswordValidator(value) { */ // eslint-disable-next-line @typescript-eslint/no-unused-vars function defaultValidate(_) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, undefined]; }); }); @@ -321,7 +322,7 @@ function normaliseEmailPasswordConfig(config) { signUpEmailField, config.resetPasswordUsingTokenFeature ); - var override = superTokens.__assign( + var override = genericComponentOverrideContext.__assign( { functions: function (originalImplementation) { return originalImplementation; @@ -329,11 +330,14 @@ function normaliseEmailPasswordConfig(config) { }, config.override ); - return superTokens.__assign(superTokens.__assign({}, utils.normaliseAuthRecipe(config)), { - signInAndUpFeature: signInAndUpFeature, - resetPasswordUsingTokenFeature: resetPasswordUsingTokenFeature, - override: override, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, utils.normaliseAuthRecipe(config)), + { + signInAndUpFeature: signInAndUpFeature, + resetPasswordUsingTokenFeature: resetPasswordUsingTokenFeature, + override: override, + } + ); } function normaliseSignInAndUpFeature(config) { if (config === undefined) { @@ -348,17 +352,17 @@ function normaliseSignInAndUpFeature(config) { */ var defaultSignInFields = signUpForm.formFields.reduce(function (signInFieldsAccumulator, field) { if (field.id === "email") { - return superTokens.__spreadArray( - superTokens.__spreadArray([], signInFieldsAccumulator, true), + return genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray([], signInFieldsAccumulator, true), [field], false ); } if (field.id === "password") { - return superTokens.__spreadArray( - superTokens.__spreadArray([], signInFieldsAccumulator, true), + return genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray([], signInFieldsAccumulator, true), [ - superTokens.__assign(superTokens.__assign({}, field), { + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, field), { autoComplete: "current-password", validate: defaultLoginPasswordValidator, }), @@ -403,7 +407,9 @@ function normaliseSignInFormFeatureConfig(defaultFormFields, config) { }) // Sign In fields are never optional. .map(function (field) { - return superTokens.__assign(superTokens.__assign({}, field), { optional: false }); + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, field), { + optional: false, + }); }); } var formFields = mergeFormFields(defaultFormFields, userFormFields); @@ -473,11 +479,10 @@ function normaliseResetPasswordUsingTokenFeature(signUpPasswordFieldValidate, si var enterEmailForm = { style: enterEmailFormStyle, formFields: [ - superTokens.__assign(superTokens.__assign({}, getDefaultEmailFormField()), { - validate: signUpEmailField.validate, - placeholder: "", - autofocus: true, - }), + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, getDefaultEmailFormField()), + { validate: signUpEmailField.validate, placeholder: "", autofocus: true } + ), ], }; return { @@ -512,8 +517,11 @@ function mergeFormFields(defaultFormFields, userFormFields) { optional = false; } // Merge. - mergedFormFields[j] = superTokens.__assign( - superTokens.__assign(superTokens.__assign({}, mergedFormFields[j]), userField), + mergedFormFields[j] = genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, mergedFormFields[j]), + userField + ), { optional: optional } ); isNewField = false; @@ -523,7 +531,7 @@ function mergeFormFields(defaultFormFields, userFormFields) { // If new field, push to mergeFormFields. if (isNewField) { mergedFormFields.push( - superTokens.__assign( + genericComponentOverrideContext.__assign( { optional: false, placeholder: userField.label, validate: defaultValidate }, userField ) @@ -540,10 +548,10 @@ function getFormattedFormField(field) { if (field.optional === false && field.nonOptionalErrorMsg === "") { throw new Error("nonOptionalErrorMsg for field ".concat(field.id, " cannot be an empty string")); } - return superTokens.__assign(superTokens.__assign({}, field), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, field), { validate: function (value) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: // Absent or not optional empty field @@ -581,7 +589,7 @@ function getFormattedFormField(field) { * Class. */ var EmailPassword = /** @class */ (function (_super) { - superTokens.__extends(EmailPassword, _super); + genericComponentOverrideContext.__extends(EmailPassword, _super); function EmailPassword(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = EmailPasswordWebJS__default.default; @@ -591,9 +599,9 @@ var EmailPassword = /** @class */ (function (_super) { _this.recipeID = EmailPassword.RECIPE_ID; _this.firstFactorIds = [types.FactorIds.EMAILPASSWORD]; _this.getDefaultRedirectionURL = function (context) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var resetPasswordPath; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { if (context.action === "RESET_PASSWORD") { resetPasswordPath = new NormalisedURLPath__default.default( constants.DEFAULT_RESET_PASSWORD_PATH @@ -625,24 +633,27 @@ var EmailPassword = /** @class */ (function (_super) { recipeID: EmailPassword.RECIPE_ID, authReact: function (appInfo) { EmailPassword.instance = new EmailPassword( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: EmailPassword.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: EmailPassword.RECIPE_ID } + ) ); return EmailPassword.instance; }, webJS: EmailPasswordWebJS__default.default.init( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - override: { - functions: function (originalImpl, builder) { - var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); - builder.override(functions); - builder.override(normalisedConfig.override.functions); - return originalImpl; + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + override: { + functions: function (originalImpl, builder) { + var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, }, - }, - }) + } + ) ), }; }; @@ -653,7 +664,7 @@ var EmailPassword = /** @class */ (function (_super) { "See https://supertokens.io/docs/emailpassword/quick-setup/frontend"; // eslint-disable-next-line supertokens-auth-react/no-direct-window-object if (typeof window === "undefined") { - error = error + superTokens.SSR_ERROR; + error = error + genericComponentOverrideContext.SSR_ERROR; } throw Error(error); } @@ -663,7 +674,7 @@ var EmailPassword = /** @class */ (function (_super) { * Tests methods. */ EmailPassword.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } EmailPassword.instance = undefined; diff --git a/lib/build/emailpassword-shared5.js b/lib/build/emailpassword-shared5.js index 60d3b9840..aa56ddb98 100644 --- a/lib/build/emailpassword-shared5.js +++ b/lib/build/emailpassword-shared5.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var React = require("react"); var STGeneralError = require("supertokens-web-js/utils/error"); @@ -24,7 +24,7 @@ function FormRow(_a) { hasError = _a.hasError; return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": ["formRow", hasError ? "hasError" : ""].join(" ") }, { children: children } ) @@ -54,7 +54,7 @@ function FormRow(_a) { function CheckedIcon() { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "14.862", @@ -96,7 +96,7 @@ function CheckedIcon() { function ErrorIcon() { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "17", @@ -109,7 +109,7 @@ function ErrorIcon() { children: [ jsxRuntime.jsx( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { className: "Asdf", fill: "rgb(var(--palette-error))" }, { children: jsxRuntime.jsx("path", { @@ -121,7 +121,7 @@ function ErrorIcon() { ), jsxRuntime.jsx( "text", - superTokens.__assign( + genericComponentOverrideContext.__assign( { fill: "#fff", fontSize: "10px", @@ -131,7 +131,7 @@ function ErrorIcon() { { children: jsxRuntime.jsx( "tspan", - superTokens.__assign({ x: "0", y: "0" }, { children: "!" }) + genericComponentOverrideContext.__assign({ x: "0", y: "0" }, { children: "!" }) ), } ) @@ -169,7 +169,7 @@ function ShowPasswordIcon(_a) { return jsxRuntime.jsx("div", { children: jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "18.391", @@ -194,7 +194,7 @@ function ShowPasswordIcon(_a) { }), jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { fill: "rgb(var(--palette-textPrimary))", stroke: "rgb(var(--palette-inputBackground))", @@ -243,7 +243,7 @@ function ShowPasswordIcon(_a) { return jsxRuntime.jsx("div", { children: jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "18.281", @@ -268,7 +268,7 @@ function ShowPasswordIcon(_a) { }), jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { fill: "rgb(var(--palette-textPrimary))", stroke: "rgb(var(--palette-inputBackground))", @@ -343,12 +343,12 @@ var Input = function (_a) { } return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "inputContainer" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": ["inputWrapper", hasError ? "inputError" : ""].join(" ") }, { children: [ @@ -368,7 +368,7 @@ var Input = function (_a) { hasError === true && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "inputAdornment inputAdornmentError" }, { children: jsxRuntime.jsx(ErrorIcon, {}) } ) @@ -377,7 +377,7 @@ var Input = function (_a) { hasError === false && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "inputAdornment inputAdornmentSuccess" }, { children: jsxRuntime.jsx(CheckedIcon, {}) } ) @@ -386,7 +386,7 @@ var Input = function (_a) { value.length > 0 && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return setShowPassword(showPassword === false); @@ -414,7 +414,7 @@ function InputError(_a) { var t = translationContext.useTranslation(); return jsxRuntime.jsx( "div", - superTokens.__assign({ "data-supertokens": "inputErrorMessage" }, { children: t(error) }) + genericComponentOverrideContext.__assign({ "data-supertokens": "inputErrorMessage" }, { children: t(error) }) ); } @@ -424,7 +424,7 @@ function Label(_a) { var t = translationContext.useTranslation(); return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "label" }, { children: [t(value), showIsRequired && value && value.trim() !== "" && " *"] } ) @@ -547,8 +547,8 @@ var FormBase = function (props) { }); // If there is a formfield missing from the states array, we fill with the default value if (fieldsWithoutState.length > 0) { - fs = superTokens.__spreadArray( - superTokens.__spreadArray([], fs, true), + fs = genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray([], fs, true), fieldsWithoutState.map(function (f) { return { id: f.id, value: fetchDefaultValue(f) }; }), @@ -584,8 +584,8 @@ var FormBase = function (props) { return f.id === id; }); if (field === undefined) { - return superTokens.__spreadArray( - superTokens.__spreadArray([], os, true), + return genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray([], os, true), [update({ id: id, value: "" })], false ); @@ -602,16 +602,18 @@ var FormBase = function (props) { var onInputFocus = React.useCallback( function (field) { updateFieldState(field.id, function (os) { - return superTokens.__assign(superTokens.__assign({}, os), { validated: false }); + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, os), { + validated: false, + }); }); }, [updateFieldState] ); var onInputBlur = React.useCallback( function (field) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var fieldConfig, error, _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if (!validateOnBlur) { @@ -631,10 +633,10 @@ var FormBase = function (props) { case 3: error = _a; updateFieldState(field.id, function (os) { - return superTokens.__assign(superTokens.__assign({}, os), { - error: error, - validated: error === undefined && field.value.length !== 0, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, os), + { error: error, validated: error === undefined && field.value.length !== 0 } + ); }); return [2 /*return*/]; } @@ -649,7 +651,10 @@ var FormBase = function (props) { throw new Error("".concat(field.id, " value must be a string")); } updateFieldState(field.id, function (os) { - return superTokens.__assign(superTokens.__assign({}, os), { value: field.value, error: undefined }); + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, os), { + value: field.value, + error: undefined, + }); }); props.clearError(); }, @@ -657,7 +662,7 @@ var FormBase = function (props) { ); var onFormSubmit = React.useCallback( function (e) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var apiFields, fieldUpdates, result, @@ -670,7 +675,7 @@ var FormBase = function (props) { field, errorFields_1, getErrorMessage_1; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: // Prevent default event propagation. @@ -679,7 +684,10 @@ var FormBase = function (props) { setIsLoading(true); setFieldStates(function (os) { return os.map(function (fs) { - return superTokens.__assign(superTokens.__assign({}, fs), { error: undefined }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, fs), + { error: undefined } + ); }); }); apiFields = formFields.map(function (field) { @@ -732,9 +740,10 @@ var FormBase = function (props) { if (update || field.clearOnSubmit === true) { // We can do these one by one, it's almost never more than one field updateFieldState(field.id, function (os) { - return superTokens.__assign(superTokens.__assign({}, os), { - value: update ? update.value : "", - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, os), + { value: update ? update.value : "" } + ); }); } }; @@ -793,9 +802,10 @@ var FormBase = function (props) { }; setFieldStates(function (os) { return os.map(function (fs) { - return superTokens.__assign(superTokens.__assign({}, fs), { - error: getErrorMessage_1(fs), - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, fs), + { error: getErrorMessage_1(fs) } + ); }); }); } @@ -818,12 +828,12 @@ var FormBase = function (props) { ); return jsxRuntime.jsx( FormStateContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: fieldStates }, { children: jsxRuntime.jsxs( "form", - superTokens.__assign( + genericComponentOverrideContext.__assign( { autoComplete: "on", noValidate: true, @@ -853,7 +863,7 @@ var FormBase = function (props) { }; return jsxRuntime.jsx( FormRow, - superTokens.__assign( + genericComponentOverrideContext.__assign( { hasError: fstate.error !== undefined }, { children: jsxRuntime.jsxs(React.Fragment, { diff --git a/lib/build/emailpassword.js b/lib/build/emailpassword.js index a16aef3ed..d297074f3 100644 --- a/lib/build/emailpassword.js +++ b/lib/build/emailpassword.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var componentOverrideContext = require("./emailpassword-shared2.js"); var recipe = require("./emailpassword-shared3.js"); require("supertokens-web-js"); @@ -14,7 +14,6 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); -require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("supertokens-web-js/recipe/emailpassword"); require("./authRecipe-shared2.js"); @@ -46,12 +45,12 @@ var Wrapper = /** @class */ (function () { return recipe.EmailPassword.init(config); }; Wrapper.signOut = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailPassword.getInstanceOrThrow().signOut({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -60,13 +59,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.submitNewPassword = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailPassword.getInstanceOrThrow().webJSRecipe.submitNewPassword( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -74,13 +73,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.sendPasswordResetEmail = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailPassword.getInstanceOrThrow().webJSRecipe.sendPasswordResetEmail( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -88,13 +87,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.signUp = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailPassword.getInstanceOrThrow().webJSRecipe.signUp( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -102,13 +101,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.signIn = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailPassword.getInstanceOrThrow().webJSRecipe.signIn( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -116,13 +115,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.doesEmailExist = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailPassword.getInstanceOrThrow().webJSRecipe.doesEmailExist( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -131,8 +130,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.getResetPasswordTokenFromURL = function (input) { return recipe.EmailPassword.getInstanceOrThrow().webJSRecipe.getResetPasswordTokenFromURL( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) diff --git a/lib/build/emailpasswordprebuiltui.js b/lib/build/emailpasswordprebuiltui.js index 6dd2da964..50ad9e111 100644 --- a/lib/build/emailpasswordprebuiltui.js +++ b/lib/build/emailpasswordprebuiltui.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); var uiEntry = require("./index2.js"); @@ -30,7 +30,6 @@ require("supertokens-web-js/utils"); require("supertokens-web-js/utils/normalisedURLDomain"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./multifactorauth-shared2.js"); require("supertokens-web-js/recipe/multifactorauth"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); @@ -89,7 +88,7 @@ function BackToSignInButton(_a) { var t = translationContext.useTranslation(); return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: onClick }, { children: [ @@ -126,25 +125,25 @@ var EmailPasswordResetPasswordEmail = function (props) { if (status === "SENT") { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "primaryText enterEmailSuccessMessage" }, { children: [ emailSuccessText, jsxRuntime.jsx( "span", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "link resendEmailLink", onClick: resend, @@ -168,18 +167,18 @@ var EmailPasswordResetPasswordEmail = function (props) { // Otherwise, return Form. return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container resetPasswordEmailForm" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle withBackButton" }, { children: [ @@ -196,7 +195,7 @@ var EmailPasswordResetPasswordEmail = function (props) { ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: t("EMAIL_PASSWORD_RESET_HEADER_SUBTITLE") } ) @@ -210,58 +209,65 @@ var EmailPasswordResetPasswordEmail = function (props) { buttonLabel: "EMAIL_PASSWORD_RESET_SEND_BTN", onSuccess: onSuccess, callAPI: function (formFields) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - var validationErrors, emailField, resp; - return superTokens.__generator(this, function (_a) { - switch (_a.label) { - case 0: - return [ - 4 /*yield*/, - superTokens.validateForm( - formFields, - props.config.resetPasswordUsingTokenFeature - .enterEmailForm.formFields - ), - ]; - case 1: - validationErrors = _a.sent(); - if (validationErrors.length > 0) { + return genericComponentOverrideContext.__awaiter( + void 0, + void 0, + void 0, + function () { + var validationErrors, emailField, resp; + return genericComponentOverrideContext.__generator(this, function (_a) { + switch (_a.label) { + case 0: return [ - 2 /*return*/, - { - status: "FIELD_ERROR", - formFields: validationErrors, - }, + 4 /*yield*/, + genericComponentOverrideContext.validateForm( + formFields, + props.config.resetPasswordUsingTokenFeature + .enterEmailForm.formFields + ), ]; - } - emailField = formFields.find(function (field) { - return field.id === "email"; - }); - if (emailField !== undefined) { - setEmailFieldValue(emailField.value); - } - return [ - 4 /*yield*/, - props.recipeImplementation.sendPasswordResetEmail({ - formFields: formFields, - userContext: userContext, - }), - ]; - case 2: - resp = _a.sent(); - if (resp.status === "PASSWORD_RESET_NOT_ALLOWED") { + case 1: + validationErrors = _a.sent(); + if (validationErrors.length > 0) { + return [ + 2 /*return*/, + { + status: "FIELD_ERROR", + formFields: validationErrors, + }, + ]; + } + emailField = formFields.find(function (field) { + return field.id === "email"; + }); + if (emailField !== undefined) { + setEmailFieldValue(emailField.value); + } return [ - 2 /*return*/, - { - status: "FIELD_ERROR", - formFields: [{ id: "email", error: resp.reason }], - }, + 4 /*yield*/, + props.recipeImplementation.sendPasswordResetEmail({ + formFields: formFields, + userContext: userContext, + }), ]; - } - return [2 /*return*/, resp]; - } - }); - }); + case 2: + resp = _a.sent(); + if (resp.status === "PASSWORD_RESET_NOT_ALLOWED") { + return [ + 2 /*return*/, + { + status: "FIELD_ERROR", + formFields: [ + { id: "email", error: resp.reason }, + ], + }, + ]; + } + return [2 /*return*/, resp]; + } + }); + } + ); }, showLabels: true, validateOnBlur: true, @@ -290,18 +296,18 @@ var EmailPasswordSubmitNewPassword = function (props) { if (status === "SUCCESS") { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle" }, { children: t("EMAIL_PASSWORD_RESET_SUBMIT_PW_SUCCESS_HEADER_TITLE") } ) @@ -313,7 +319,7 @@ var EmailPasswordSubmitNewPassword = function (props) { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "primaryText submitNewPasswordSuccessMessage", @@ -347,25 +353,25 @@ var EmailPasswordSubmitNewPassword = function (props) { } return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container resetPasswordPasswordForm" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle" }, { children: t("EMAIL_PASSWORD_RESET_SUBMIT_PW_HEADER_TITLE") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: t("EMAIL_PASSWORD_RESET_SUBMIT_PW_HEADER_SUBTITLE") } ) @@ -380,70 +386,77 @@ var EmailPasswordSubmitNewPassword = function (props) { onSuccess: onSuccess, validateOnBlur: true, callAPI: function (fields) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - var validationErrors, response; - return superTokens.__generator(this, function (_a) { - switch (_a.label) { - case 0: - return [ - 4 /*yield*/, - superTokens.validateForm( - fields, - props.config.resetPasswordUsingTokenFeature - .submitNewPasswordForm.formFields - ), - ]; - case 1: - validationErrors = _a.sent(); - if (validationErrors.length > 0) { + return genericComponentOverrideContext.__awaiter( + void 0, + void 0, + void 0, + function () { + var validationErrors, response; + return genericComponentOverrideContext.__generator(this, function (_a) { + switch (_a.label) { + case 0: return [ - 2 /*return*/, - { - status: "FIELD_ERROR", - formFields: validationErrors, - }, + 4 /*yield*/, + genericComponentOverrideContext.validateForm( + fields, + props.config.resetPasswordUsingTokenFeature + .submitNewPasswordForm.formFields + ), + ]; + case 1: + validationErrors = _a.sent(); + if (validationErrors.length > 0) { + return [ + 2 /*return*/, + { + status: "FIELD_ERROR", + formFields: validationErrors, + }, + ]; + } + // Verify that both passwords match. + if (fields[0].value !== fields[1].value) { + return [ + 2 /*return*/, + { + status: "FIELD_ERROR", + formFields: [ + { + id: fields[1].id, + error: "ERROR_CONFIRM_PASSWORD_NO_MATCH", + }, + ], + }, + ]; + } + return [ + 4 /*yield*/, + props.recipeImplementation.submitNewPassword({ + formFields: fields, + userContext: userContext, + }), ]; - } - // Verify that both passwords match. - if (fields[0].value !== fields[1].value) { + case 2: + response = _a.sent(); + if ( + response.status === "RESET_PASSWORD_INVALID_TOKEN_ERROR" + ) { + throw new STGeneralError__default.default( + "EMAIL_PASSWORD_RESET_PASSWORD_INVALID_TOKEN_ERROR" + ); + } return [ 2 /*return*/, - { - status: "FIELD_ERROR", - formFields: [ - { - id: fields[1].id, - error: "ERROR_CONFIRM_PASSWORD_NO_MATCH", - }, - ], - }, + response.status === "FIELD_ERROR" + ? response + : { + status: "OK", + }, ]; - } - return [ - 4 /*yield*/, - props.recipeImplementation.submitNewPassword({ - formFields: fields, - userContext: userContext, - }), - ]; - case 2: - response = _a.sent(); - if (response.status === "RESET_PASSWORD_INVALID_TOKEN_ERROR") { - throw new STGeneralError__default.default( - "EMAIL_PASSWORD_RESET_PASSWORD_INVALID_TOKEN_ERROR" - ); - } - return [ - 2 /*return*/, - response.status === "FIELD_ERROR" - ? response - : { - status: "OK", - }, - ]; - } - }); - }); + } + }); + } + ); }, showLabels: true, }), @@ -466,30 +479,38 @@ function ResetPasswordUsingTokenTheme(props) { */ // If no token, return SubmitNewPassword. if (props.submitNewPasswordForm !== undefined) { - return jsxRuntime.jsx(SubmitNewPassword, superTokens.__assign({}, props.submitNewPasswordForm)); + return jsxRuntime.jsx( + SubmitNewPassword, + genericComponentOverrideContext.__assign({}, props.submitNewPasswordForm) + ); } // Otherwise, return EnterEmail. - return jsxRuntime.jsx(ResetPasswordEmail, superTokens.__assign({}, props.enterEmailForm)); + return jsxRuntime.jsx(ResetPasswordEmail, genericComponentOverrideContext.__assign({}, props.enterEmailForm)); } function ResetPasswordUsingTokenThemeWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var userStyles = props.submitNewPasswordForm ? props.config.resetPasswordUsingTokenFeature.submitNewPasswordForm.style : props.config.resetPasswordUsingTokenFeature.enterEmailForm.style; return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( translations.ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, userStyles], }, - { children: jsxRuntime.jsx(ResetPasswordUsingTokenTheme, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + ResetPasswordUsingTokenTheme, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ), } @@ -498,9 +519,9 @@ function ResetPasswordUsingTokenThemeWrapper(props) { } var defaultTranslationsEmailPassword = { - en: superTokens.__assign( - superTokens.__assign( - superTokens.__assign({}, uiEntry.defaultTranslationsCommon.en), + en: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, uiEntry.defaultTranslationsCommon.en), translations.defaultTranslationsEmailVerification.en ), { @@ -572,7 +593,7 @@ var defaultTranslationsEmailPassword = { }; var ResetPasswordUsingToken$1 = function (props) { - var token = superTokens.getQueryParams("token"); + var token = genericComponentOverrideContext.getQueryParams("token"); var userContext = uiEntry.useUserContext(); if (props.userContext !== undefined) { userContext = props.userContext; @@ -598,7 +619,7 @@ var ResetPasswordUsingToken$1 = function (props) { recipeImplementation: props.recipe.webJSRecipe, config: props.recipe.config, onSignInClicked: function () { - void superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + void genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ show: "signin", navigate: props.navigate, redirectBack: false, @@ -609,7 +630,7 @@ var ResetPasswordUsingToken$1 = function (props) { }; var enterEmailForm = { onBackButtonClicked: function () { - return superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + return genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ show: "signin", navigate: props.navigate, redirectBack: false, @@ -636,14 +657,14 @@ var ResetPasswordUsingToken$1 = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { - useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, defaultStore: defaultTranslationsEmailPassword, }, { @@ -652,7 +673,7 @@ var ResetPasswordUsingToken$1 = function (props) { props.children === undefined && jsxRuntime.jsx( ResetPasswordUsingTokenThemeWrapper, - superTokens.__assign({}, childProps) + genericComponentOverrideContext.__assign({}, childProps) ), props.children && React__namespace.Children.map(props.children, function (child) { @@ -682,14 +703,14 @@ var SignInForm = uiEntry.withOverride("EmailPasswordSignInForm", function EmailP buttonLabel: "EMAIL_PASSWORD_SIGN_IN_SUBMIT_BTN", onSuccess: props.onSuccess, callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var validationErrors, response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, - superTokens.validateForm( + genericComponentOverrideContext.validateForm( formFields, props.config.signInAndUpFeature.signInForm.formFields ), @@ -734,22 +755,22 @@ var SignInForm = uiEntry.withOverride("EmailPasswordSignInForm", function EmailP }); }); function SignInTheme(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeStyle = props.config.signInAndUpFeature.signInForm.style; return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( translations.ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, activeStyle], }, - { children: jsxRuntime.jsx(SignInForm, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(SignInForm, genericComponentOverrideContext.__assign({}, props)) } ) ), } @@ -766,13 +787,13 @@ function useChildProps$1(recipe$2, onAuthSuccess, error, onError, clearError, us }, [recipe$2] ); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var t = translationContext.useTranslation(); var onSignInSuccess = React.useCallback( function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var payloadAfterCall; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: _b.trys.push([0, 2, , 3]); @@ -820,10 +841,10 @@ function useChildProps$1(recipe$2, onAuthSuccess, error, onError, clearError, us var formFields = signInFeature.formFields.map(function (f) { return f.id !== "password" ? f - : superTokens.__assign(superTokens.__assign({}, f), { + : genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, f), { labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ @@ -833,7 +854,7 @@ function useChildProps$1(recipe$2, onAuthSuccess, error, onError, clearError, us }), jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: onForgotPasswordClick, "data-supertokens": @@ -857,9 +878,9 @@ function useChildProps$1(recipe$2, onAuthSuccess, error, onError, clearError, us clearError: clearError, onError: onError, onFetchError: function (err) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -933,17 +954,20 @@ var SignInFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, { children: jsxRuntime.jsxs(React.Fragment, { children: [ props.children === undefined && - jsxRuntime.jsx(SignInTheme, superTokens.__assign({}, childProps)), + jsxRuntime.jsx(SignInTheme, genericComponentOverrideContext.__assign({}, childProps)), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { - return React__namespace.cloneElement(child, superTokens.__assign({}, childProps)); + return React__namespace.cloneElement( + child, + genericComponentOverrideContext.__assign({}, childProps) + ); } return child; }), @@ -954,19 +978,20 @@ var SignInFeature = function (props) { ); }; var getModifiedRecipeImplementation$1 = function (origImpl) { - return superTokens.__assign(superTokens.__assign({}, origImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, origImpl), { signIn: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, origImpl.signIn( - superTokens.__assign(superTokens.__assign({}, input), { - tryLinkingWithSessionUser: false, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { tryLinkingWithSessionUser: false } + ) ), ]; case 1: @@ -977,17 +1002,18 @@ var getModifiedRecipeImplementation$1 = function (origImpl) { }); }, signUp: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, origImpl.signUp( - superTokens.__assign(superTokens.__assign({}, input), { - tryLinkingWithSessionUser: false, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { tryLinkingWithSessionUser: false } + ) ), ]; case 1: @@ -1011,14 +1037,14 @@ var SignUpForm = uiEntry.withOverride("EmailPasswordSignUpForm", function EmailP buttonLabel: "EMAIL_PASSWORD_SIGN_UP_SUBMIT_BTN", onSuccess: props.onSuccess, callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var validationErrors, res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, - superTokens.validateForm( + genericComponentOverrideContext.validateForm( formFields, props.config.signInAndUpFeature.signUpForm.formFields ), @@ -1058,22 +1084,22 @@ var SignUpForm = uiEntry.withOverride("EmailPasswordSignUpForm", function EmailP }); }); function SignUpTheme(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeStyle = props.config.signInAndUpFeature.signUpForm.style; return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( translations.ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, activeStyle], }, - { children: jsxRuntime.jsx(SignUpForm, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(SignUpForm, genericComponentOverrideContext.__assign({}, props)) } ) ), } @@ -1090,12 +1116,12 @@ function useChildProps(recipe, onAuthSuccess, error, onError, clearError, userCo }, [recipe] ); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var onSignUpSuccess = React.useCallback( function (result) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var payloadAfterCall; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: _b.trys.push([0, 2, , 3]); @@ -1143,9 +1169,9 @@ function useChildProps(recipe, onAuthSuccess, error, onError, clearError, userCo styleFromInit: signUpFeature.style, formFields: getThemeSignUpFeatureFormFields(signUpFeature.formFields, recipe, userContext), onFetchError: function (err) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -1225,17 +1251,20 @@ var SignUpFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, { children: jsxRuntime.jsxs(React.Fragment, { children: [ props.children === undefined && - jsxRuntime.jsx(SignUpTheme, superTokens.__assign({}, childProps)), + jsxRuntime.jsx(SignUpTheme, genericComponentOverrideContext.__assign({}, childProps)), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { - return React__namespace.cloneElement(child, superTokens.__assign({}, childProps)); + return React__namespace.cloneElement( + child, + genericComponentOverrideContext.__assign({}, childProps) + ); } return child; }), @@ -1246,19 +1275,20 @@ var SignUpFeature = function (props) { ); }; var getModifiedRecipeImplementation = function (origImpl) { - return superTokens.__assign(superTokens.__assign({}, origImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, origImpl), { signIn: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, origImpl.signIn( - superTokens.__assign(superTokens.__assign({}, input), { - tryLinkingWithSessionUser: false, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { tryLinkingWithSessionUser: false } + ) ), ]; case 1: @@ -1269,17 +1299,18 @@ var getModifiedRecipeImplementation = function (origImpl) { }); }, signUp: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, origImpl.signUp( - superTokens.__assign(superTokens.__assign({}, input), { - tryLinkingWithSessionUser: false, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { tryLinkingWithSessionUser: false } + ) ), ]; case 1: @@ -1295,7 +1326,7 @@ function getThemeSignUpFeatureFormFields(formFields, recipe, userContext) { var _this = this; var emailPasswordOnly = formFields.length === 2; return formFields.map(function (field) { - return superTokens.__assign(superTokens.__assign({}, field), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, field), { showIsRequired: (function () { // If email and password only, do not show required indicator (*). if (emailPasswordOnly) { @@ -1311,9 +1342,9 @@ function getThemeSignUpFeatureFormFields(formFields, recipe, userContext) { } // Otherwise, if email, use syntax validate method and check if email exists. return function (value) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var error, emailExists, err_1; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, field.validate(value)]; @@ -1359,7 +1390,7 @@ function getThemeSignUpFeatureFormFields(formFields, recipe, userContext) { } var EmailPasswordPreBuiltUI = /** @class */ (function (_super) { - superTokens.__extends(EmailPasswordPreBuiltUI, _super); + genericComponentOverrideContext.__extends(EmailPasswordPreBuiltUI, _super); function EmailPasswordPreBuiltUI(recipeInstance) { var _this = _super.call(this) || this; _this.recipeInstance = recipeInstance; @@ -1375,7 +1406,9 @@ var EmailPasswordPreBuiltUI = /** @class */ (function (_super) { new NormalisedURLPath__default.default(constants.DEFAULT_RESET_PASSWORD_PATH) ); features[normalisedFullPath.getAsStringDangerous()] = { - matches: superTokens.matchRecipeIdUsingQueryParams(_this.recipeInstance.config.recipeId), + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), component: function (props) { return _this.getFeatureComponent("resetpassword", props, useComponentOverrides); }, @@ -1391,12 +1424,12 @@ var EmailPasswordPreBuiltUI = /** @class */ (function (_super) { if (componentName === "resetpassword") { return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ResetPasswordUsingToken$1, - superTokens.__assign({ recipe: _this.recipeInstance }, props, { + genericComponentOverrideContext.__assign({ recipe: _this.recipeInstance }, props, { useComponentOverrides: useComponentOverrides, }) ), @@ -1444,7 +1477,7 @@ var EmailPasswordPreBuiltUI = /** @class */ (function (_super) { component: function (props) { return jsxRuntime.jsx( SignUpFeature, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipe: _this.recipeInstance, useComponentOverrides: componentOverrideContext.useContext, @@ -1462,7 +1495,7 @@ var EmailPasswordPreBuiltUI = /** @class */ (function (_super) { component: function (props) { return jsxRuntime.jsx( SignInFeature, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipe: _this.recipeInstance, useComponentOverrides: componentOverrideContext.useContext, @@ -1477,7 +1510,7 @@ var EmailPasswordPreBuiltUI = /** @class */ (function (_super) { }; // For tests EmailPasswordPreBuiltUI.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } EmailPasswordPreBuiltUI.instance = undefined; diff --git a/lib/build/emailverification-shared.js b/lib/build/emailverification-shared.js index e63d777b0..e75d4a068 100644 --- a/lib/build/emailverification-shared.js +++ b/lib/build/emailverification-shared.js @@ -1,7 +1,6 @@ "use strict"; var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); -var superTokens = require("./superTokens.js"); var EmailVerificationWebJS = require("supertokens-web-js/recipe/emailverification"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); var postSuperTokensInitCallbacks = require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); @@ -36,10 +35,10 @@ var _a = genericComponentOverrideContext.createGenericComponentsOverrideContext( var DEFAULT_VERIFY_EMAIL_PATH = "/verify-email"; var EmailVerificationClaimClass = /** @class */ (function (_super) { - superTokens.__extends(EmailVerificationClaimClass, _super); + genericComponentOverrideContext.__extends(EmailVerificationClaimClass, _super); function EmailVerificationClaimClass(getRecipeImpl, onFailureRedirection) { var _this = _super.call(this, getRecipeImpl) || this; - var validatorsWithCallbacks = superTokens.__assign({}, _this.validators); + var validatorsWithCallbacks = genericComponentOverrideContext.__assign({}, _this.validators); var _loop_1 = function (key) { var validator = validatorsWithCallbacks[key]; validatorsWithCallbacks[key] = function () { @@ -47,19 +46,22 @@ var EmailVerificationClaimClass = /** @class */ (function (_super) { for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } - return superTokens.__assign(superTokens.__assign({}, validator.apply(void 0, args)), { - onFailureRedirection: function (args) { - if (onFailureRedirection !== undefined) { - return onFailureRedirection(args); - } - var recipe = EmailVerification.getInstanceOrThrow(); - if (recipe.config.mode === "REQUIRED") { - return recipe.getRedirectUrl({ action: "VERIFY_EMAIL" }, args.userContext); - } - return undefined; - }, - showAccessDeniedOnFailure: false, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, validator.apply(void 0, args)), + { + onFailureRedirection: function (args) { + if (onFailureRedirection !== undefined) { + return onFailureRedirection(args); + } + var recipe = EmailVerification.getInstanceOrThrow(); + if (recipe.config.mode === "REQUIRED") { + return recipe.getRedirectUrl({ action: "VERIFY_EMAIL" }, args.userContext); + } + return undefined; + }, + showAccessDeniedOnFailure: false, + } + ); }; }; for (var key in validatorsWithCallbacks) { @@ -73,11 +75,11 @@ var EmailVerificationClaimClass = /** @class */ (function (_super) { var getFunctionOverrides = function (onHandleEvent) { return function (originalImp) { - return superTokens.__assign(superTokens.__assign({}, originalImp), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImp), { verifyEmail: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.verifyEmail(input)]; @@ -95,9 +97,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, sendVerificationEmail: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.sendVerificationEmail(input)]; @@ -152,7 +154,7 @@ function normaliseEmailVerificationFeature(config) { var verifyEmailLinkClickedScreen = { style: verifyEmailLinkClickedScreenStyle, }; - var override = superTokens.__assign( + var override = genericComponentOverrideContext.__assign( { functions: function (originalImplementation) { return originalImplementation; @@ -160,13 +162,19 @@ function normaliseEmailVerificationFeature(config) { }, config.override ); - return superTokens.__assign(superTokens.__assign({}, superTokens.normaliseRecipeModuleConfig(config)), { - disableDefaultUI: disableDefaultUI, - mode: mode, - sendVerifyEmailScreen: sendVerifyEmailScreen, - verifyEmailLinkClickedScreen: verifyEmailLinkClickedScreen, - override: override, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + {}, + genericComponentOverrideContext.normaliseRecipeModuleConfig(config) + ), + { + disableDefaultUI: disableDefaultUI, + mode: mode, + sendVerifyEmailScreen: sendVerifyEmailScreen, + verifyEmailLinkClickedScreen: verifyEmailLinkClickedScreen, + override: override, + } + ); } /* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. @@ -184,7 +192,7 @@ function normaliseEmailVerificationFeature(config) { * under the License. */ var EmailVerification = /** @class */ (function (_super) { - superTokens.__extends(EmailVerification, _super); + genericComponentOverrideContext.__extends(EmailVerification, _super); function EmailVerification(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = EmailVerificationWebJS__default.default; @@ -193,9 +201,9 @@ var EmailVerification = /** @class */ (function (_super) { _this.webJSRecipe = webJSRecipe; _this.recipeID = EmailVerification.RECIPE_ID; _this.getDefaultRedirectionURL = function (context) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var verifyEmailPath; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { if (context.action === "VERIFY_EMAIL") { verifyEmailPath = new NormalisedURLPath__default.default(DEFAULT_VERIFY_EMAIL_PATH); return [ @@ -227,24 +235,27 @@ var EmailVerification = /** @class */ (function (_super) { recipeID: EmailVerification.RECIPE_ID, authReact: function (appInfo) { EmailVerification.instance = new EmailVerification( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: EmailVerification.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: EmailVerification.RECIPE_ID } + ) ); return EmailVerification.instance; }, webJS: EmailVerificationWebJS__default.default.init( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - override: { - functions: function (originalImpl, builder) { - var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); - builder.override(functions); - builder.override(normalisedConfig.override.functions); - return originalImpl; + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + override: { + functions: function (originalImpl, builder) { + var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, }, - }, - }) + } + ) ), }; }; @@ -253,15 +264,15 @@ var EmailVerification = /** @class */ (function (_super) { var error = "No instance of EmailVerification found. Make sure to call the EmailVerification.init method."; // eslint-disable-next-line supertokens-auth-react/no-direct-window-object if (typeof window === "undefined") { - error = error + superTokens.SSR_ERROR; + error = error + genericComponentOverrideContext.SSR_ERROR; } throw Error(error); } return EmailVerification.instance; }; EmailVerification.prototype.isEmailVerified = function (userContext) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -277,7 +288,7 @@ var EmailVerification = /** @class */ (function (_super) { }); }; EmailVerification.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } EmailVerification.instance = undefined; diff --git a/lib/build/emailverification-shared2.js b/lib/build/emailverification-shared2.js index 054d62c03..3ab790cf0 100644 --- a/lib/build/emailverification-shared2.js +++ b/lib/build/emailverification-shared2.js @@ -2,7 +2,7 @@ var jsxRuntime = require("react/jsx-runtime"); var React = require("react"); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var uiEntry = require("./index2.js"); var styles = @@ -27,24 +27,27 @@ var ThemeBase = function (_a) { }; var defaultTranslationsEmailVerification = { - en: superTokens.__assign(superTokens.__assign({}, uiEntry.defaultTranslationsCommon.en), { - EMAIL_VERIFICATION_RESEND_SUCCESS: "Email resent", - EMAIL_VERIFICATION_SEND_TITLE: "Verify your email address", - EMAIL_VERIFICATION_SEND_DESC_START: "", - EMAIL_VERIFICATION_SEND_DESC_STRONG: "Please click on the link", - EMAIL_VERIFICATION_SEND_DESC_END: " in the email we just sent you to confirm your email address.", - EMAIL_VERIFICATION_RESEND_BTN: "Resend Email", - EMAIL_VERIFICATION_LOGOUT: "Logout ", - EMAIL_VERIFICATION_SUCCESS: "Email verification successful!", - EMAIL_VERIFICATION_CONTINUE_BTN: "CONTINUE", - EMAIL_VERIFICATION_CONTINUE_LINK: "Continue", - EMAIL_VERIFICATION_EXPIRED: "The email verification link has expired", - EMAIL_VERIFICATION_ERROR_TITLE: "Something went wrong", - EMAIL_VERIFICATION_ERROR_DESC: "We encountered an unexpected error. Please contact support for assistance", - EMAIL_VERIFICATION_LINK_CLICKED_HEADER: "Verify your email address", - EMAIL_VERIFICATION_LINK_CLICKED_DESC: "Please click on the button below to verify your email address", - EMAIL_VERIFICATION_LINK_CLICKED_CONTINUE_BUTTON: "CONTINUE", - }), + en: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, uiEntry.defaultTranslationsCommon.en), + { + EMAIL_VERIFICATION_RESEND_SUCCESS: "Email resent", + EMAIL_VERIFICATION_SEND_TITLE: "Verify your email address", + EMAIL_VERIFICATION_SEND_DESC_START: "", + EMAIL_VERIFICATION_SEND_DESC_STRONG: "Please click on the link", + EMAIL_VERIFICATION_SEND_DESC_END: " in the email we just sent you to confirm your email address.", + EMAIL_VERIFICATION_RESEND_BTN: "Resend Email", + EMAIL_VERIFICATION_LOGOUT: "Logout ", + EMAIL_VERIFICATION_SUCCESS: "Email verification successful!", + EMAIL_VERIFICATION_CONTINUE_BTN: "CONTINUE", + EMAIL_VERIFICATION_CONTINUE_LINK: "Continue", + EMAIL_VERIFICATION_EXPIRED: "The email verification link has expired", + EMAIL_VERIFICATION_ERROR_TITLE: "Something went wrong", + EMAIL_VERIFICATION_ERROR_DESC: "We encountered an unexpected error. Please contact support for assistance", + EMAIL_VERIFICATION_LINK_CLICKED_HEADER: "Verify your email address", + EMAIL_VERIFICATION_LINK_CLICKED_DESC: "Please click on the button below to verify your email address", + EMAIL_VERIFICATION_LINK_CLICKED_CONTINUE_BUTTON: "CONTINUE", + } + ), }; exports.ThemeBase = ThemeBase; diff --git a/lib/build/emailverification.js b/lib/build/emailverification.js index 4c72c2735..57f8143f7 100644 --- a/lib/build/emailverification.js +++ b/lib/build/emailverification.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var recipe = require("./emailverification-shared.js"); require("supertokens-web-js"); require("supertokens-web-js/utils/cookieHandler"); @@ -13,7 +13,6 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); -require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("supertokens-web-js/recipe/emailverification"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); @@ -39,13 +38,13 @@ var Wrapper = /** @class */ (function () { return recipe.EmailVerification.init(config); }; Wrapper.isEmailVerified = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailVerification.getInstanceOrThrow().webJSRecipe.isEmailVerified( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -55,13 +54,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.verifyEmail = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailVerification.getInstanceOrThrow().webJSRecipe.verifyEmail( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -71,13 +70,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.sendVerificationEmail = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.EmailVerification.getInstanceOrThrow().webJSRecipe.sendVerificationEmail( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -88,8 +87,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.getEmailVerificationTokenFromURL = function (input) { return recipe.EmailVerification.getInstanceOrThrow().webJSRecipe.getEmailVerificationTokenFromURL( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) diff --git a/lib/build/emailverificationprebuiltui.js b/lib/build/emailverificationprebuiltui.js index 1262bec05..90aaa3ac0 100644 --- a/lib/build/emailverificationprebuiltui.js +++ b/lib/build/emailverificationprebuiltui.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); var uiEntry = require("./index2.js"); @@ -22,7 +22,6 @@ require("supertokens-web-js/utils"); require("supertokens-web-js/utils/normalisedURLDomain"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./multifactorauth-shared2.js"); require("supertokens-web-js/recipe/multifactorauth"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); @@ -93,7 +92,7 @@ function ArrowRightIcon(_a) { var color = _a.color; return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "11.272", @@ -124,9 +123,9 @@ var EmailVerificationSendVerifyEmail = function (props) { errorMessage = _b[0], setErrorMessage = _b[1]; var resendEmail = function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var response, e_1; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 5, , 6]); @@ -164,9 +163,9 @@ var EmailVerificationSendVerifyEmail = function (props) { }); }; var logout = function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var e_2; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 2, , 3]); @@ -197,8 +196,8 @@ var EmailVerificationSendVerifyEmail = function (props) { ); var checkSendResponse = React.useCallback( function (response) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: if (!(response.status === "EMAIL_ALREADY_VERIFIED_ERROR")) return [3 /*break*/, 2]; @@ -215,8 +214,8 @@ var EmailVerificationSendVerifyEmail = function (props) { [props.config, props.recipeImplementation, props.onEmailAlreadyVerified] ); var handleSendError = React.useCallback(function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -235,15 +234,15 @@ var EmailVerificationSendVerifyEmail = function (props) { }); }); }, []); - superTokens.useOnMountAPICall(sendVerificationEmail, checkSendResponse, handleSendError); + genericComponentOverrideContext.useOnMountAPICall(sendVerificationEmail, checkSendResponse, handleSendError); return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ @@ -254,28 +253,28 @@ var EmailVerificationSendVerifyEmail = function (props) { status === "EMAIL_RESENT" && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "generalSuccess" }, { children: t("EMAIL_VERIFICATION_RESEND_SUCCESS") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "sendVerifyEmailIcon" }, { children: jsxRuntime.jsx(emailLargeIcon.EmailLargeIcon, {}) } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle headerTinyTitle" }, { children: t("EMAIL_VERIFICATION_SEND_TITLE") } ) ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "primaryText sendVerifyEmailText" }, { children: [ @@ -291,14 +290,14 @@ var EmailVerificationSendVerifyEmail = function (props) { status !== "EMAIL_RESENT" && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "link sendVerifyEmailResend", onClick: resendEmail }, { children: t("EMAIL_VERIFICATION_RESEND_BTN") } ) ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithArrow", onClick: logout }, { children: [ @@ -343,7 +342,7 @@ var SendVerifyEmail = uiEntry.withOverride("EmailVerificationSendVerifyEmail", E function CheckedRoundIcon() { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "33", @@ -354,7 +353,7 @@ function CheckedRoundIcon() { { children: jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { fill: "rgb(var(--palette-success))", stroke: "rgb(var(--palette-success))" }, { children: [ @@ -399,7 +398,7 @@ function CheckedRoundIcon() { function ErrorLargeIcon() { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "33", @@ -412,7 +411,7 @@ function ErrorLargeIcon() { children: [ jsxRuntime.jsx( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { fill: "rgb(var(--palette-error))" }, { children: jsxRuntime.jsx("path", { @@ -424,7 +423,7 @@ function ErrorLargeIcon() { ), jsxRuntime.jsx( "text", - superTokens.__assign( + genericComponentOverrideContext.__assign( { fill: "#fff", "font-family": "Rubik-Bold, Rubik", @@ -435,7 +434,7 @@ function ErrorLargeIcon() { { children: jsxRuntime.jsx( "tspan", - superTokens.__assign({ x: "0", y: "0" }, { children: "!" }) + genericComponentOverrideContext.__assign({ x: "0", y: "0" }, { children: "!" }) ), } ) @@ -462,8 +461,8 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { setVerifyLoading = _c[1]; var verifyEmailOnMount = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { if (sessionContext.loading === true) { // This callback should only be called if the session is already loaded throw new Error("Should never come here"); @@ -487,8 +486,8 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { ); var handleVerifyResp = React.useCallback( function (response) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { if (response === "INTERACTION_REQUIRED") { setStatus("INTERACTION_REQUIRED"); } else if (response.status === "EMAIL_VERIFICATION_INVALID_TOKEN_ERROR") { @@ -511,23 +510,28 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { }, [setStatus, setErrorMessage] ); - superTokens.useOnMountAPICall(verifyEmailOnMount, handleVerifyResp, handleError, sessionContext.loading === false); + genericComponentOverrideContext.useOnMountAPICall( + verifyEmailOnMount, + handleVerifyResp, + handleError, + sessionContext.loading === false + ); var onTokenInvalidRedirect = props.onTokenInvalidRedirect, onSuccess = props.onSuccess; if (status === "LOADING") { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "spinner" }, { children: jsxRuntime.jsx(uiEntry.SpinnerIcon, {}) } ) @@ -542,25 +546,25 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { if (status === "INTERACTION_REQUIRED") { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row noFormRow" }, { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle" }, { children: t("EMAIL_VERIFICATION_LINK_CLICKED_HEADER") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: t("EMAIL_VERIFICATION_LINK_CLICKED_DESC") } ) @@ -568,36 +572,44 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { jsxRuntime.jsx(button.Button, { isLoading: verifyLoading, onClick: function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - var resp, err_1; - return superTokens.__generator(this, function (_a) { - switch (_a.label) { - case 0: - setVerifyLoading(true); - _a.label = 1; - case 1: - _a.trys.push([1, 4, , 5]); - return [ - 4 /*yield*/, - props.recipeImplementation.verifyEmail({ - userContext: userContext, - }), - ]; - case 2: - resp = _a.sent(); - return [4 /*yield*/, handleVerifyResp(resp)]; - case 3: - _a.sent(); - return [3 /*break*/, 5]; - case 4: - err_1 = _a.sent(); - void handleError(err_1); - return [3 /*break*/, 5]; - case 5: - return [2 /*return*/]; - } - }); - }); + return genericComponentOverrideContext.__awaiter( + void 0, + void 0, + void 0, + function () { + var resp, err_1; + return genericComponentOverrideContext.__generator( + this, + function (_a) { + switch (_a.label) { + case 0: + setVerifyLoading(true); + _a.label = 1; + case 1: + _a.trys.push([1, 4, , 5]); + return [ + 4 /*yield*/, + props.recipeImplementation.verifyEmail({ + userContext: userContext, + }), + ]; + case 2: + resp = _a.sent(); + return [4 /*yield*/, handleVerifyResp(resp)]; + case 3: + _a.sent(); + return [3 /*break*/, 5]; + case 4: + err_1 = _a.sent(); + void handleError(err_1); + return [3 /*break*/, 5]; + case 5: + return [2 /*return*/]; + } + } + ); + } + ); }, type: "button", label: "EMAIL_VERIFICATION_LINK_CLICKED_CONTINUE_BUTTON", @@ -613,26 +625,26 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { if (status === "SUCCESSFUL") { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row noFormRow" }, { children: [ jsxRuntime.jsx(CheckedRoundIcon, {}), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle headerTinyTitle" }, { children: t("EMAIL_VERIFICATION_SUCCESS") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "emailVerificationButtonWrapper" }, { children: jsxRuntime.jsx(button.Button, { @@ -655,25 +667,25 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { if (status === "INVALID") { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row noFormRow" }, { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle headerTinyTitle" }, { children: t("EMAIL_VERIFICATION_EXPIRED") } ) ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: onTokenInvalidRedirect, "data-supertokens": "secondaryText secondaryLinkWithArrow", @@ -698,18 +710,18 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { } return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row noFormRow" }, { children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle error" }, { children: [ @@ -721,7 +733,7 @@ var EmailVerificationVerifyEmailLinkClicked = function (props) { ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "primaryText" }, { children: t( @@ -749,26 +761,32 @@ function EmailVerificationTheme(props) { var sessionContext = session.useSessionContext(); // If we have a token, return VerifyEmailLinkClicked. if (props.verifyEmailLinkClickedScreen !== undefined) { - return jsxRuntime.jsx(VerifyEmailLinkClicked, superTokens.__assign({}, props.verifyEmailLinkClickedScreen)); + return jsxRuntime.jsx( + VerifyEmailLinkClicked, + genericComponentOverrideContext.__assign({}, props.verifyEmailLinkClickedScreen) + ); } // If we have an active session, we want to send the verification email if (sessionContext.loading === false && sessionContext.doesSessionExist === true) { - return jsxRuntime.jsx(SendVerifyEmail, superTokens.__assign({}, props.sendVerifyEmailScreen)); + return jsxRuntime.jsx( + SendVerifyEmail, + genericComponentOverrideContext.__assign({}, props.sendVerifyEmailScreen) + ); } // Otherwise, return an empty screen, waiting for the feature component to redirection to complete. return jsxRuntime.jsx(jsxRuntime.Fragment, {}); } function EmailVerificationThemeWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( translations.ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [ @@ -779,7 +797,12 @@ function EmailVerificationThemeWrapper(props) { : props.config.verifyEmailLinkClickedScreen.style, ], }, - { children: jsxRuntime.jsx(EmailVerificationTheme, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + EmailVerificationTheme, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ), } @@ -793,7 +816,7 @@ var EmailVerification$1 = function (props) { var _b = React.useState("LOADING"), status = _b[0], setStatus = _b[1]; - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var recipeComponentOverrides = props.useComponentOverrides(); var userContext = uiEntry.useUserContext(); if (props.userContext !== undefined) { @@ -801,8 +824,8 @@ var EmailVerification$1 = function (props) { } var redirectToAuthWithHistory = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -820,30 +843,33 @@ var EmailVerification$1 = function (props) { ); var modifiedRecipeImplementation = React.useMemo( function () { - return superTokens.__assign(superTokens.__assign({}, props.recipe.webJSRecipe), { - sendVerificationEmail: function (input) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - var response; - return superTokens.__generator(this, function (_a) { - switch (_a.label) { - case 0: - return [4 /*yield*/, props.recipe.webJSRecipe.sendVerificationEmail(input)]; - case 1: - response = _a.sent(); - superTokens.clearQueryParams(["token"]); - return [2 /*return*/, response]; - } + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, props.recipe.webJSRecipe), + { + sendVerificationEmail: function (input) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + var response; + return genericComponentOverrideContext.__generator(this, function (_a) { + switch (_a.label) { + case 0: + return [4 /*yield*/, props.recipe.webJSRecipe.sendVerificationEmail(input)]; + case 1: + response = _a.sent(); + genericComponentOverrideContext.clearQueryParams(["token"]); + return [2 /*return*/, response]; + } + }); }); - }); - }, - }); + }, + } + ); }, [props.recipe] ); var onSuccess = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, types.Session.getInstanceOrThrow() @@ -863,10 +889,10 @@ var EmailVerification$1 = function (props) { ); var fetchIsEmailVerified = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var token; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if (sessionContext.loading === true) { @@ -874,7 +900,9 @@ var EmailVerification$1 = function (props) { throw new Error("Should never come here"); } token = - (_a = superTokens.getQueryParams("token")) !== null && _a !== void 0 ? _a : undefined; + (_a = genericComponentOverrideContext.getQueryParams("token")) !== null && _a !== void 0 + ? _a + : undefined; if (!(token === undefined)) return [3 /*break*/, 4]; if (!!sessionContext.doesSessionExist) return [3 /*break*/, 2]; return [4 /*yield*/, redirectToAuthWithHistory()]; @@ -899,8 +927,8 @@ var EmailVerification$1 = function (props) { ); var checkIsEmailVerified = React.useCallback( function (isVerified) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { if (isVerified) { return [2 /*return*/, onSuccess()]; } @@ -913,8 +941,8 @@ var EmailVerification$1 = function (props) { ); var handleError = React.useCallback( function (err) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -937,7 +965,7 @@ var EmailVerification$1 = function (props) { }, [redirectToAuthWithHistory] ); - superTokens.useOnMountAPICall( + genericComponentOverrideContext.useOnMountAPICall( fetchIsEmailVerified, checkIsEmailVerified, handleError, @@ -945,9 +973,9 @@ var EmailVerification$1 = function (props) { ); var signOut = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var session; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: session = types.Session.getInstanceOrThrow(); @@ -974,7 +1002,8 @@ var EmailVerification$1 = function (props) { redirectToAuth: redirectToAuthWithHistory, }; var verifyEmailLinkClickedScreenFeature = props.recipe.config.verifyEmailLinkClickedScreen; - var token = (_a = superTokens.getQueryParams("token")) !== null && _a !== void 0 ? _a : undefined; + var token = + (_a = genericComponentOverrideContext.getQueryParams("token")) !== null && _a !== void 0 ? _a : undefined; var verifyEmailLinkClickedScreen = token === undefined ? undefined @@ -994,14 +1023,14 @@ var EmailVerification$1 = function (props) { }; return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { - useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, defaultStore: translations.defaultTranslationsEmailVerification, }, { @@ -1010,7 +1039,7 @@ var EmailVerification$1 = function (props) { props.children === undefined && jsxRuntime.jsx( EmailVerificationThemeWrapper, - superTokens.__assign({}, childProps) + genericComponentOverrideContext.__assign({}, childProps) ), props.children && React__namespace.Children.map(props.children, function (child) { @@ -1030,7 +1059,7 @@ var EmailVerification$1 = function (props) { }; var EmailVerificationPreBuiltUI = /** @class */ (function (_super) { - superTokens.__extends(EmailVerificationPreBuiltUI, _super); + genericComponentOverrideContext.__extends(EmailVerificationPreBuiltUI, _super); function EmailVerificationPreBuiltUI(recipeInstance) { var _this = _super.call(this) || this; _this.recipeInstance = recipeInstance; @@ -1046,7 +1075,9 @@ var EmailVerificationPreBuiltUI = /** @class */ (function (_super) { new NormalisedURLPath__default.default(recipe.DEFAULT_VERIFY_EMAIL_PATH) ); features[normalisedFullPath.getAsStringDangerous()] = { - matches: superTokens.matchRecipeIdUsingQueryParams(_this.recipeInstance.config.recipeId), + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), component: function (props) { return _this.getFeatureComponent("emailverification", props, useComponentOverrides); }, @@ -1066,12 +1097,12 @@ var EmailVerificationPreBuiltUI = /** @class */ (function (_super) { } return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( session.SessionAuth, - superTokens.__assign( + genericComponentOverrideContext.__assign( { requireAuth: false, overrideGlobalClaimValidators: function () { @@ -1083,15 +1114,18 @@ var EmailVerificationPreBuiltUI = /** @class */ (function (_super) { children: function (value) { return jsxRuntime.jsx( EmailVerification$1, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipe: _this.recipeInstance, useComponentOverrides: useComponentOverrides, }, - superTokens.__assign(superTokens.__assign({}, props), { - // We do this to make sure it does not add another provider - userContext: value, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, props), + { + // We do this to make sure it does not add another provider + userContext: value, + } + ) ) ); }, @@ -1134,7 +1168,7 @@ var EmailVerificationPreBuiltUI = /** @class */ (function (_super) { }; // For tests EmailVerificationPreBuiltUI.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } EmailVerificationPreBuiltUI.instance = undefined; diff --git a/lib/build/genericComponentOverrideContext.js b/lib/build/genericComponentOverrideContext.js index 4d5d3f5d7..8cb5d736f 100644 --- a/lib/build/genericComponentOverrideContext.js +++ b/lib/build/genericComponentOverrideContext.js @@ -1,14 +1,1421 @@ "use strict"; -var superTokens = require("./superTokens.js"); -var jsxRuntime = require("react/jsx-runtime"); +var SuperTokensWebJS = require("supertokens-web-js"); +var cookieHandler = require("supertokens-web-js/utils/cookieHandler"); +var postSuperTokensInitCallbacks = require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); +var windowHandler = require("supertokens-web-js/utils/windowHandler"); +var MultitenancyWebJS = require("supertokens-web-js/recipe/multitenancy"); +var utils = require("supertokens-web-js/utils"); var React = require("react"); +var NormalisedURLDomain = require("supertokens-web-js/utils/normalisedURLDomain"); +var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); +var jsxRuntime = require("react/jsx-runtime"); function _interopDefault(e) { return e && e.__esModule ? e : { default: e }; } +var SuperTokensWebJS__default = /*#__PURE__*/ _interopDefault(SuperTokensWebJS); +var MultitenancyWebJS__default = /*#__PURE__*/ _interopDefault(MultitenancyWebJS); var React__default = /*#__PURE__*/ _interopDefault(React); +var NormalisedURLDomain__default = /*#__PURE__*/ _interopDefault(NormalisedURLDomain); +var NormalisedURLPath__default = /*#__PURE__*/ _interopDefault(NormalisedURLPath); + +/****************************************************************************** +Copyright (c) Microsoft Corporation. + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH +REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY +AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, +INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM +LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR +OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR +PERFORMANCE OF THIS SOFTWARE. +***************************************************************************** */ +/* global Reflect, Promise, SuppressedError, Symbol */ + +var extendStatics = function (d, b) { + extendStatics = + Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && + function (d, b) { + d.__proto__ = b; + }) || + function (d, b) { + for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; + }; + return extendStatics(d, b); +}; + +function __extends(d, b) { + if (typeof b !== "function" && b !== null) + throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); + extendStatics(d, b); + function __() { + this.constructor = d; + } + d.prototype = b === null ? Object.create(b) : ((__.prototype = b.prototype), new __()); +} + +exports.__assign = function () { + exports.__assign = + Object.assign || + function __assign(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + }; + return exports.__assign.apply(this, arguments); +}; + +function __rest(s, e) { + var t = {}; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; + if (s != null && typeof Object.getOwnPropertySymbols === "function") + for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { + if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; + } + return t; +} + +function __awaiter(thisArg, _arguments, P, generator) { + function adopt(value) { + return value instanceof P + ? value + : new P(function (resolve) { + resolve(value); + }); + } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { + try { + step(generator.next(value)); + } catch (e) { + reject(e); + } + } + function rejected(value) { + try { + step(generator["throw"](value)); + } catch (e) { + reject(e); + } + } + function step(result) { + result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); + } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +} + +function __generator(thisArg, body) { + var _ = { + label: 0, + sent: function () { + if (t[0] & 1) throw t[1]; + return t[1]; + }, + trys: [], + ops: [], + }, + f, + y, + t, + g; + return ( + (g = { next: verb(0), throw: verb(1), return: verb(2) }), + typeof Symbol === "function" && + (g[Symbol.iterator] = function () { + return this; + }), + g + ); + function verb(n) { + return function (v) { + return step([n, v]); + }; + } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while ((g && ((g = 0), op[0] && (_ = 0)), _)) + try { + if ( + ((f = 1), + y && + (t = + op[0] & 2 + ? y["return"] + : op[0] + ? y["throw"] || ((t = y["return"]) && t.call(y), 0) + : y.next) && + !(t = t.call(y, op[1])).done) + ) + return t; + if (((y = 0), t)) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: + case 1: + t = op; + break; + case 4: + _.label++; + return { value: op[1], done: false }; + case 5: + _.label++; + y = op[1]; + op = [0]; + continue; + case 7: + op = _.ops.pop(); + _.trys.pop(); + continue; + default: + if (!((t = _.trys), (t = t.length > 0 && t[t.length - 1])) && (op[0] === 6 || op[0] === 2)) { + _ = 0; + continue; + } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { + _.label = op[1]; + break; + } + if (op[0] === 6 && _.label < t[1]) { + _.label = t[1]; + t = op; + break; + } + if (t && _.label < t[2]) { + _.label = t[2]; + _.ops.push(op); + break; + } + if (t[2]) _.ops.pop(); + _.trys.pop(); + continue; + } + op = body.call(thisArg, _); + } catch (e) { + op = [6, e]; + y = 0; + } finally { + f = t = 0; + } + if (op[0] & 5) throw op[1]; + return { value: op[0] ? op[1] : void 0, done: true }; + } +} + +function __spreadArray(to, from, pack) { + if (pack || arguments.length === 2) + for (var i = 0, l = from.length, ar; i < l; i++) { + if (ar || !(i in from)) { + if (!ar) ar = Array.prototype.slice.call(from, 0, i); + ar[i] = from[i]; + } + } + return to.concat(ar || Array.prototype.slice.call(from)); +} + +typeof SuppressedError === "function" + ? SuppressedError + : function (error, suppressed, message) { + var e = new Error(message); + return (e.name = "SuppressedError"), (e.error = error), (e.suppressed = suppressed), e; + }; + +/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +/* + * Consts. + */ +var RECIPE_ID_QUERY_PARAM = "rid"; +var DEFAULT_API_BASE_PATH = "/auth"; +var DEFAULT_WEBSITE_BASE_PATH = "/auth"; +var ST_ROOT_ID = "supertokens-root"; +var SSR_ERROR = + "\nIf you are trying to use this method doing server-side-rendering, please make sure you move this method inside a componentDidMount method or useEffect hook."; + +/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +var package_version = "0.42.2"; + +/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +var SUPERTOKENS_DEBUG_NAMESPACE = "com.supertokens.auth-react"; +var __debugLogsEnabled = false; +function enableLogging() { + __debugLogsEnabled = true; +} +function logDebugMessage(message) { + if (__debugLogsEnabled) { + // eslint-disable-next-line no-console + console.log( + "" + .concat(SUPERTOKENS_DEBUG_NAMESPACE, ' {t: "') + .concat(new Date().toISOString(), '", message: "') + .concat(message, '", supertokens-auth-react-ver: "') + .concat(package_version, '"}') + ); + } +} + +/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +/* + * getRecipeIdFromPath + * Input: + * Output: The "rid" query param if present, null otherwise. + */ +function getRecipeIdFromSearch(search) { + var urlParams = new URLSearchParams(search); + return urlParams.get(RECIPE_ID_QUERY_PARAM); +} +function clearQueryParams(paramNames) { + var newURL = new URL(windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHref()); + for (var _i = 0, paramNames_1 = paramNames; _i < paramNames_1.length; _i++) { + var param = paramNames_1[_i]; + newURL.searchParams.delete(param); + } + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.replaceState( + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.getState(), + "", + newURL.toString() + ); +} +function updateQueryParam(name, value) { + var newURL = new URL(windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHref()); + newURL.searchParams.set(name, value); + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.replaceState( + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.getState(), + "", + newURL.toString() + ); +} +function clearErrorQueryParam() { + clearQueryParams(["error", "message"]); +} +function getQueryParams(param) { + var urlParams = new URLSearchParams( + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getSearch() + ); + return urlParams.get(param); +} +function getURLHash() { + // By default it is returined with the "#" at the beginning, we cut that off here. + return windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHash().substr(1); +} +function getRedirectToPathFromURL() { + var redirectToPath = getQueryParams("redirectToPath"); + if (redirectToPath === null) { + return undefined; + } else { + try { + var url = void 0; + try { + url = new URL(redirectToPath); + } catch (error) { + var fakeDomain = redirectToPath.startsWith("/") ? "http://localhost" : "http://localhost/"; + url = new URL("".concat(fakeDomain).concat(redirectToPath)); + } + // Prevent Open redirects by normalising path. + var normalisedURLPath = new NormalisedURLPath__default.default(redirectToPath).getAsStringDangerous(); + var pathQueryParams = url.search || ""; // url.search contains the leading ? + var pathHash = url.hash || ""; // url.hash contains the leading # + var pathWithQueryParamsAndHash = normalisedURLPath + pathQueryParams + pathHash; + // Ensure a leading "/" if `normalisedUrlPath` is empty but `pathWithQueryParamsAndHash` is not to ensure proper redirection. + // Example: "?test=1" will not redirect the user to `/?test=1` if we don't add a leading "/". + if ( + normalisedURLPath.length === 0 && + pathWithQueryParamsAndHash.length > 0 && + !pathWithQueryParamsAndHash.startsWith("/") + ) { + return "/" + pathWithQueryParamsAndHash; + } + return pathWithQueryParamsAndHash; + } catch (_a) { + return undefined; + } + } +} +/* + * isTest + */ +function isTest() { + try { + return process.env.TEST_MODE === "testing" || process.env.REACT_APP_TEST_MODE === "testing"; + } catch (err) { + // can get Uncaught ReferenceError: process is not defined error + return false; + } +} +function normaliseInputAppInfoOrThrowError(appInfo) { + if (appInfo === undefined) { + throw new Error("Please provide the appInfo object when calling supertokens.init"); + } + if (appInfo.apiDomain === undefined) { + throw new Error("Please provide your apiDomain inside the appInfo object when calling supertokens.init"); + } + if (appInfo.appName === undefined) { + throw new Error("Please provide your appName inside the appInfo object when calling supertokens.init"); + } + if (appInfo.websiteDomain === undefined) { + throw new Error("Please provide your websiteDomain inside the appInfo object when calling supertokens.init"); + } + var apiGatewayPath = new NormalisedURLPath__default.default(""); + if (appInfo.apiGatewayPath !== undefined) { + apiGatewayPath = new NormalisedURLPath__default.default(appInfo.apiGatewayPath); + } + return { + appName: appInfo.appName, + apiDomain: new NormalisedURLDomain__default.default(appInfo.apiDomain), + websiteDomain: new NormalisedURLDomain__default.default(appInfo.websiteDomain), + apiBasePath: apiGatewayPath.appendPath( + getNormalisedURLPathOrDefault(DEFAULT_API_BASE_PATH, appInfo.apiBasePath) + ), + websiteBasePath: getNormalisedURLPathOrDefault(DEFAULT_WEBSITE_BASE_PATH, appInfo.websiteBasePath), + }; +} +function getNormalisedURLPathOrDefault(defaultPath, path) { + if (path !== undefined) { + return new NormalisedURLPath__default.default(path); + } else { + return new NormalisedURLPath__default.default(defaultPath); + } +} +/* + * validateForm + */ +// We check that the number of fields in input and config form field is the same. +// We check that each item in the config form field is also present in the input form field +function validateForm(inputs, configFormFields) { + return __awaiter(this, void 0, void 0, function () { + var validationErrors, _loop_1, i; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + validationErrors = []; + if (configFormFields.length !== inputs.length) { + throw Error("Are you sending too many / too few formFields?"); + } + _loop_1 = function (i) { + var field, input, value, error; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + field = configFormFields[i]; + input = inputs.find(function (i) { + return i.id === field.id; + }); + value = input.value; + if (input.id === "email") { + value = value.trim(); + } + return [4 /*yield*/, field.validate(value)]; + case 1: + error = _b.sent(); + // If error, add it. + if (error !== undefined) { + validationErrors.push({ + error: error, + id: field.id, + }); + } + return [2 /*return*/]; + } + }); + }; + i = 0; + _a.label = 1; + case 1: + if (!(i < configFormFields.length)) return [3 /*break*/, 4]; + return [5 /*yield**/, _loop_1(i)]; + case 2: + _a.sent(); + _a.label = 3; + case 3: + i++; + return [3 /*break*/, 1]; + case 4: + return [2 /*return*/, validationErrors]; + } + }); + }); +} +/* + * getCurrentNormalisedUrlPath + */ +function getCurrentNormalisedUrlPath() { + return new NormalisedURLPath__default.default( + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getPathName() + ); +} +function getCurrentNormalisedUrlPathWithQueryParamsAndFragments() { + var normalisedUrlPath = getCurrentNormalisedUrlPath().getAsStringDangerous(); + return ( + normalisedUrlPath + + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getSearch() + + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHash() + ); +} +function appendQueryParamsToURL(stringUrl, queryParams) { + if (queryParams === undefined) { + return stringUrl; + } + try { + var url_1 = new URL(stringUrl); + Object.entries(queryParams).forEach(function (_a) { + var key = _a[0], + value = _a[1]; + url_1.searchParams.set(key, value); + }); + return url_1.href; + } catch (e) { + var fakeDomain = stringUrl.startsWith("/") ? "http://localhost" : "http://localhost/"; + var url_2 = new URL("".concat(fakeDomain).concat(stringUrl)); + Object.entries(queryParams).forEach(function (_a) { + var key = _a[0], + value = _a[1]; + url_2.searchParams.set(key, value); + }); + return "".concat(url_2.pathname).concat(url_2.search).concat(url_2.hash); + } +} +function appendTrailingSlashToURL(stringUrl) { + return stringUrl.endsWith("/") ? stringUrl : stringUrl + "/"; +} +/* + * Default method for matching recipe route based on query params. + */ +function matchRecipeIdUsingQueryParams(recipeId) { + return function () { + var recipeIdFromSearch = getRecipeIdFromSearch( + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getSearch() + ); + return recipeIdFromSearch === recipeId; + }; +} +function redirectWithFullPageReload(to) { + if (to.trim() === "") { + to = "/"; + } + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.setHref(to); +} +function redirectWithNavigate(to, navigate) { + if (to.trim() === "") { + to = "/"; + } + if ("push" in navigate) { + // we are using react-router-dom that is before v6 + navigate.push(to); + } else { + // in react-router-dom v6, it is just navigate(to) + navigate(to); + } +} +function getOriginOfPage() { + return new NormalisedURLDomain__default.default( + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getOrigin() + ); +} +function getLocalStorage(key) { + return __awaiter(this, void 0, void 0, function () { + var res; + return __generator(this, function (_a) { + res = windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.localStorage.getItem(key); + if (res === null || res === undefined) { + return [2 /*return*/, null]; + } + return [2 /*return*/, res]; + }); + }); +} +function setLocalStorage(key, value) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + return [ + 4 /*yield*/, + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.localStorage.setItem( + key, + value + ), + ]; + case 1: + _a.sent(); + return [2 /*return*/]; + } + }); + }); +} +function removeFromLocalStorage(key) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + return [ + 4 /*yield*/, + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.localStorage.removeItem( + key + ), + ]; + case 1: + _a.sent(); + return [2 /*return*/]; + } + }); + }); +} +function mergeObjects(obj1, obj2) { + var res = exports.__assign({}, obj1); + for (var key in obj2) { + if (typeof res[key] === "object" && typeof obj2[key] === "object") { + res[key] = mergeObjects(res[key], obj2[key]); + } else { + res[key] = obj2[key]; + } + } + return res; +} +function normaliseCookieScopeOrThrowError(cookieScope) { + function helper(cookieScope) { + cookieScope = cookieScope.trim().toLowerCase(); + // first we convert it to a URL so that we can use the URL class + if (cookieScope.startsWith(".")) { + cookieScope = cookieScope.substr(1); + } + if (!cookieScope.startsWith("http://") && !cookieScope.startsWith("https://")) { + cookieScope = "http://" + cookieScope; + } + try { + var urlObj = new URL(cookieScope); + cookieScope = urlObj.hostname; + // remove leading dot + if (cookieScope.startsWith(".")) { + cookieScope = cookieScope.substr(1); + } + return cookieScope; + } catch (err) { + throw new Error("Please provide a valid cookie scope"); + } + } + function isAnIpAddress(ipaddress) { + return /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/.test( + ipaddress + ); + } + var noDotNormalised = helper(cookieScope); + if (noDotNormalised === "localhost" || isAnIpAddress(noDotNormalised)) { + return noDotNormalised; + } + if (cookieScope.startsWith(".")) { + return "." + noDotNormalised; + } + return noDotNormalised; +} +function getDefaultCookieScope() { + try { + return normaliseCookieScopeOrThrowError( + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHostName() + ); + } catch (_a) { + return undefined; + } +} +function getCookieValue(name) { + return __awaiter(this, void 0, void 0, function () { + var value, _a, parts, last, temp; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _a = "; "; + return [ + 4 /*yield*/, + cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.getCookie(), + ]; + case 1: + value = _a + _b.sent(); + parts = value.split("; " + name + "="); + if (parts.length >= 2) { + last = parts.pop(); + if (last !== undefined) { + temp = last.split(";").shift(); + if (temp === undefined) { + return [2 /*return*/, null]; + } + return [2 /*return*/, temp]; + } + } + return [2 /*return*/, null]; + } + }); + }); +} +// undefined value will remove the cookie +function setFrontendCookie(name, value, scope) { + return __awaiter(this, void 0, void 0, function () { + var expires, cookieVal; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + expires = "Thu, 01 Jan 1970 00:00:01 GMT"; + cookieVal = ""; + if (value !== undefined) { + cookieVal = value; + expires = undefined; // set cookie without expiry + } + if ( + !( + scope === "localhost" || + scope === + windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHostName() || + scope === undefined + ) + ) + return [3 /*break*/, 5]; + if (!(expires !== undefined)) return [3 /*break*/, 2]; + return [ + 4 /*yield*/, + cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( + "".concat(name, "=").concat(cookieVal, ";expires=").concat(expires, ";path=/;samesite=lax") + ), + ]; + case 1: + _a.sent(); + return [3 /*break*/, 4]; + case 2: + return [ + 4 /*yield*/, + cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( + "" + .concat(name, "=") + .concat(cookieVal, ";expires=Fri, 31 Dec 9999 23:59:59 GMT;path=/;samesite=lax") + ), + ]; + case 3: + _a.sent(); + _a.label = 4; + case 4: + return [3 /*break*/, 9]; + case 5: + if (!(expires !== undefined)) return [3 /*break*/, 7]; + return [ + 4 /*yield*/, + cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( + "" + .concat(name, "=") + .concat(cookieVal, ";expires=") + .concat(expires, ";domain=") + .concat(scope, ";path=/;samesite=lax") + ), + ]; + case 6: + _a.sent(); + return [3 /*break*/, 9]; + case 7: + return [ + 4 /*yield*/, + cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( + "" + .concat(name, "=") + .concat(cookieVal, ";domain=") + .concat(scope, ";expires=Fri, 31 Dec 9999 23:59:59 GMT;path=/;samesite=lax") + ), + ]; + case 8: + _a.sent(); + _a.label = 9; + case 9: + return [2 /*return*/]; + } + }); + }); +} +function getNormalisedUserContext(userContext) { + return userContext === undefined ? {} : userContext; +} +/** + * This function handles calling APIs that should only be called once during mount (mostly on mount of a route/feature component). + * It's split into multiple callbacks (fetch + handleResponse/handleError) because we expect fetch to take longer and + * and the component may be unmounted during the first fetch, in which case we want to avoid updating state/redirecting. + * This is especially relevant for development in strict mode with React 18 (and in the future for concurrent rendering). + * + * @param fetch This is a callback that is only called once on mount. Mostly it's for consuming tokens/doing one time only API calls + * @param handleResponse This is called with the result of the first (fetch) call if it succeeds. + * @param handleError This is called with the error of the first (fetch) call if it rejects. + * @param startLoading Will start the whole process if this is set to true (or omitted). Mostly used to wait for session loading. + */ +var useOnMountAPICall = function (fetch, handleResponse, handleError, startLoading) { + if (startLoading === void 0) { + startLoading = true; + } + var consumeReq = React.useRef(); + var _a = React.useState(undefined), + error = _a[0], + setError = _a[1]; + React.useEffect( + function () { + var effect = function (signal) { + return __awaiter(void 0, void 0, void 0, function () { + var resp, err_1, err_2; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + _a.trys.push([0, 2, , 9]); + if (consumeReq.current === undefined) { + consumeReq.current = fetch(); + } + return [4 /*yield*/, consumeReq.current]; + case 1: + resp = _a.sent(); + if (!signal.aborted) { + void handleResponse(resp); + } + return [3 /*break*/, 9]; + case 2: + err_1 = _a.sent(); + if (!!signal.aborted) return [3 /*break*/, 8]; + if (!(handleError !== undefined)) return [3 /*break*/, 7]; + _a.label = 3; + case 3: + _a.trys.push([3, 5, , 6]); + return [4 /*yield*/, handleError(err_1, resp)]; + case 4: + _a.sent(); + return [3 /*break*/, 6]; + case 5: + err_2 = _a.sent(); + setError(err_2); + return [3 /*break*/, 6]; + case 6: + return [3 /*break*/, 8]; + case 7: + setError(err_1); + _a.label = 8; + case 8: + return [3 /*break*/, 9]; + case 9: + return [2 /*return*/]; + } + }); + }); + }; + if (startLoading) { + var ctrl_1 = new AbortController(); + void effect(ctrl_1.signal); + return function () { + ctrl_1.abort(); + }; + } + return; + }, + [setError, consumeReq, fetch, handleResponse, handleError, startLoading] + ); + if (error) { + throw error; + } +}; +function useRethrowInRender() { + var _a = React.useState(undefined), + error = _a[0], + setError = _a[1]; + if (error) { + throw error; + } + return setError; +} + +var BaseRecipeModule = /** @class */ (function () { + /* + * Constructor. + */ + function BaseRecipeModule(config) { + this.config = config; + } + return BaseRecipeModule; +})(); + +function normaliseRecipeModuleConfig(config) { + var _this = this; + if (config === undefined) { + config = {}; + } + var onHandleEvent = config.onHandleEvent, + getRedirectionURL = config.getRedirectionURL, + preAPIHook = config.preAPIHook, + postAPIHook = config.postAPIHook; + if (onHandleEvent === undefined) { + // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function + onHandleEvent = function (_) {}; + } + if (getRedirectionURL === undefined) { + // eslint-disable-next-line @typescript-eslint/no-unused-vars + getRedirectionURL = function (_) { + return __awaiter(_this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2 /*return*/, undefined]; + }); + }); + }; + } + if (preAPIHook === undefined) { + // eslint-disable-next-line @typescript-eslint/no-unused-vars + preAPIHook = function (context) { + return __awaiter(_this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2 /*return*/, context]; + }); + }); + }; + } + if (postAPIHook === undefined) { + // eslint-disable-next-line @typescript-eslint/no-empty-function + postAPIHook = function () { + return __awaiter(_this, void 0, void 0, function () { + return __generator(this, function (_a) { + return [2 /*return*/]; + }); + }); + }; + } + var rootStyle = config.style === undefined ? "" : config.style; + return exports.__assign(exports.__assign({}, config), { + getRedirectionURL: getRedirectionURL, + onHandleEvent: onHandleEvent, + preAPIHook: preAPIHook, + postAPIHook: postAPIHook, + recipeRootStyle: rootStyle, + }); +} + +function normaliseMultitenancyConfig(config) { + return exports.__assign(exports.__assign({}, normaliseRecipeModuleConfig(config)), { + override: exports.__assign( + { + functions: function (originalImplementation) { + return originalImplementation; + }, + }, + config === null || config === void 0 ? void 0 : config.override + ), + }); +} +function hasIntersectingRecipes(tenantMethods, recipeList) { + return tenantMethods.firstFactors.some(function (factorId) { + return recipeList.some(function (r) { + return r.firstFactorIds.includes(factorId); + }); + }); +} + +/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +/* + * Class. + */ +var Multitenancy = /** @class */ (function (_super) { + __extends(Multitenancy, _super); + function Multitenancy(config, webJSRecipe) { + if (webJSRecipe === void 0) { + webJSRecipe = MultitenancyWebJS__default.default; + } + var _this = _super.call(this, config) || this; + _this.webJSRecipe = webJSRecipe; + _this.recipeID = Multitenancy.RECIPE_ID; + _this.dynamicLoginMethodsCache = {}; + return _this; + } + Multitenancy.prototype.getCurrentDynamicLoginMethods = function (input) { + var _a; + return __awaiter(this, void 0, void 0, function () { + var userContext, tenantId, tenantMethods; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (SuperTokens.usesDynamicLoginMethods === false) { + return [2 /*return*/, undefined]; + } + userContext = utils.getNormalisedUserContext(input.userContext); + return [4 /*yield*/, Multitenancy.getInstanceOrThrow().webJSRecipe.getTenantId()]; + case 1: + tenantId = (_a = _b.sent()) !== null && _a !== void 0 ? _a : "public"; + if (this.dynamicLoginMethodsCache[tenantId] === undefined) { + this.dynamicLoginMethodsCache[tenantId] = Multitenancy.getDynamicLoginMethods({ + tenantId: tenantId, + userContext: userContext, + }); + } + return [4 /*yield*/, this.dynamicLoginMethodsCache[tenantId]]; + case 2: + tenantMethods = _b.sent(); + if ( + !hasIntersectingRecipes( + tenantMethods, + SuperTokens.getInstanceOrThrow().recipeList.filter(function (recipe) { + return "firstFactorIds" in recipe; + }) + ) + ) { + throw new Error( + "Initialized recipes have no overlap with core recipes or could not load login methods" + ); + } + return [2 /*return*/, tenantMethods]; + } + }); + }); + }; + Multitenancy.getDynamicLoginMethods = function (input) { + return __awaiter(this, void 0, void 0, function () { + var _a, thirdParty, firstFactors; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + return [4 /*yield*/, MultitenancyWebJS__default.default.getLoginMethods(input)]; + case 1: + (_a = _b.sent()), (thirdParty = _a.thirdParty), (firstFactors = _a.firstFactors); + return [ + 2 /*return*/, + { + thirdparty: thirdParty, + firstFactors: firstFactors, + }, + ]; + } + }); + }); + }; + Multitenancy.init = function (config) { + var normalisedConfig = normaliseMultitenancyConfig(config); + return { + recipeID: Multitenancy.RECIPE_ID, + authReact: function (appInfo) { + Multitenancy.instance = new Multitenancy( + exports.__assign(exports.__assign({}, normalisedConfig), { + appInfo: appInfo, + recipeId: Multitenancy.RECIPE_ID, + }) + ); + return Multitenancy.instance; + }, + webJS: MultitenancyWebJS__default.default.init(exports.__assign({}, normalisedConfig)), + }; + }; + Multitenancy.getInstanceOrThrow = function () { + if (Multitenancy.instance === undefined) { + var error = + "No instance of Multitenancy found. Make sure to call the Multitenancy.init method." + + "See https://supertokens.io/docs/multitenancy/quick-setup/frontend"; + // eslint-disable-next-line supertokens-auth-react/no-direct-window-object + if (typeof window === "undefined") { + error = error + SSR_ERROR; + } + throw Error(error); + } + return Multitenancy.instance; + }; + /* + * Tests methods. + */ + Multitenancy.reset = function () { + if (!isTest()) { + return; + } + Multitenancy.instance = undefined; + return; + }; + Multitenancy.RECIPE_ID = "multitenancy"; + return Multitenancy; +})(BaseRecipeModule); + +var TranslationController = /** @class */ (function () { + function TranslationController() { + this.handlers = new Map(); + } + TranslationController.prototype.emit = function (event, detail) { + var handlerList = this.handlers.get(event) || []; + for (var _i = 0, handlerList_1 = handlerList; _i < handlerList_1.length; _i++) { + var h = handlerList_1[_i]; + h(event, detail); + } + }; + TranslationController.prototype.on = function (event, handler) { + var handlerList = this.handlers.get(event) || []; + this.handlers.set(event, handlerList.concat(handler)); + }; + TranslationController.prototype.off = function (event, handler) { + var handlerList = this.handlers.get(event) || []; + this.handlers.set( + event, + handlerList.filter(function (h) { + return h !== handler; + }) + ); + }; + return TranslationController; +})(); +var CURRENT_LANGUAGE_COOKIE_NAME = "sCurrLanguage"; +function saveCurrentLanguage(language, cookieDomain) { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _b.trys.push([0, 2, , 3]); + return [4 /*yield*/, setFrontendCookie(CURRENT_LANGUAGE_COOKIE_NAME, language, cookieDomain)]; + case 1: + _b.sent(); + return [3 /*break*/, 3]; + case 2: + _b.sent(); + return [3 /*break*/, 3]; + case 3: + return [2 /*return*/]; + } + }); + }); +} +function getCurrentLanguageFromCookie() { + return __awaiter(this, void 0, void 0, function () { + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + _b.trys.push([0, 2, , 3]); + return [4 /*yield*/, getCookieValue(CURRENT_LANGUAGE_COOKIE_NAME)]; + case 1: + return [2 /*return*/, _b.sent()]; + case 2: + _b.sent(); + // This can throw if we are not in a browser + // Since this is just loading a preference we can safely ignore the exception + return [2 /*return*/, null]; + case 3: + return [2 /*return*/]; + } + }); + }); +} + +/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +/* + * Class. + */ +var SuperTokens = /** @class */ (function () { + /* + * Constructor. + */ + function SuperTokens(config) { + var _this = this; + var _a, _b, _c, _d; + this.recipeList = []; + this.changeLanguage = function (lang) { + return __awaiter(_this, void 0, void 0, function () { + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + return [ + 4 /*yield*/, + saveCurrentLanguage(lang, this.languageTranslations.currentLanguageCookieScope), + ]; + case 1: + _a.sent(); + this.languageTranslations.translationEventSource.emit("LanguageChange", lang); + return [2 /*return*/]; + } + }); + }); + }; + this.redirectToAuth = function (options) { + return __awaiter(_this, void 0, void 0, function () { + var queryParams, redirectUrl; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + queryParams = options.queryParams === undefined ? {} : options.queryParams; + if (options.show !== undefined) { + queryParams.show = options.show; + } + if (options.redirectBack === true) { + queryParams.redirectToPath = getCurrentNormalisedUrlPathWithQueryParamsAndFragments(); + } + return [ + 4 /*yield*/, + this.getRedirectUrl( + { + action: "TO_AUTH", + showSignIn: options.show === "signin", + }, + options.userContext + ), + ]; + case 1: + redirectUrl = _a.sent(); + if (redirectUrl === null) { + logDebugMessage("Skipping redirection because the user override returned null"); + return [2 /*return*/]; + } + redirectUrl = appendQueryParamsToURL(redirectUrl, queryParams); + return [2 /*return*/, this.redirectToUrl(redirectUrl, options.navigate)]; + } + }); + }); + }; + this.redirectToUrl = function (redirectUrl, navigate) { + return __awaiter(_this, void 0, void 0, function () { + return __generator(this, function (_a) { + doRedirection(this.appInfo, redirectUrl, navigate); + return [2 /*return*/]; + }); + }); + }; + this.redirect = function (context, navigate, queryParams, userContext) { + return __awaiter(_this, void 0, void 0, function () { + var redirectUrl; + return __generator(this, function (_a) { + switch (_a.label) { + case 0: + return [4 /*yield*/, this.getRedirectUrl(context, getNormalisedUserContext(userContext))]; + case 1: + redirectUrl = _a.sent(); + if (redirectUrl === null) { + logDebugMessage( + "Skipping redirection because the user override returned null for context ".concat( + JSON.stringify(context, null, 2) + ) + ); + return [2 /*return*/]; + } + redirectUrl = appendQueryParamsToURL(redirectUrl, queryParams); + return [ + 2 /*return*/, + SuperTokens.getInstanceOrThrow().redirectToUrl(redirectUrl, navigate), + ]; + } + }); + }); + }; + this.appInfo = normaliseInputAppInfoOrThrowError(config.appInfo); + if (config.recipeList === undefined || config.recipeList.length === 0) { + throw new Error( + "Please provide at least one recipe to the supertokens.init function call. See https://supertokens.io/docs/emailpassword/quick-setup/frontend" + ); + } + var translationConfig = config.languageTranslations === undefined ? {} : config.languageTranslations; + this.languageTranslations = { + defaultLanguage: translationConfig.defaultLanguage === undefined ? "en" : translationConfig.defaultLanguage, + currentLanguageCookieScope: + translationConfig.currentLanguageCookieScope !== undefined + ? normaliseCookieScopeOrThrowError(translationConfig.currentLanguageCookieScope) + : getDefaultCookieScope(), + userTranslationStore: translationConfig.translations !== undefined ? translationConfig.translations : {}, + translationEventSource: new TranslationController(), + userTranslationFunc: translationConfig.translationFunc, + }; + var enableDebugLogs = Boolean(config === null || config === void 0 ? void 0 : config.enableDebugLogs); + if (enableDebugLogs) { + enableLogging(); + } + this.userGetRedirectionURL = config.getRedirectionURL; + this.recipeList = config.recipeList.map(function (_a) { + var authReact = _a.authReact; + return authReact(_this.appInfo, enableDebugLogs); + }); + this.rootStyle = (_a = config.style) !== null && _a !== void 0 ? _a : ""; + this.privacyPolicyLink = config.privacyPolicyLink; + this.termsOfServiceLink = config.termsOfServiceLink; + this.useShadowDom = (_b = config.useShadowDom) !== null && _b !== void 0 ? _b : true; + this.defaultToSignUp = (_c = config.defaultToSignUp) !== null && _c !== void 0 ? _c : false; + this.disableAuthRoute = (_d = config.disableAuthRoute) !== null && _d !== void 0 ? _d : false; + } + /* + * Static Methods. + */ + SuperTokens.init = function (config) { + var _a; + cookieHandler.CookieHandlerReference.init(config.cookieHandler); + windowHandler.WindowHandlerReference.init(config.windowHandler); + if (SuperTokens.instance !== undefined) { + console.warn("SuperTokens was already initialized"); + return; + } + SuperTokens.usesDynamicLoginMethods = + (_a = config.usesDynamicLoginMethods) !== null && _a !== void 0 ? _a : false; + var recipes = + config.recipeList.find(function (recipe) { + return recipe.recipeID === Multitenancy.RECIPE_ID; + }) !== undefined + ? config.recipeList + : config.recipeList.concat(Multitenancy.init({})); + SuperTokensWebJS__default.default.init( + exports.__assign(exports.__assign({}, config), { + recipeList: recipes.map(function (_a) { + var webJS = _a.webJS; + return webJS; + }), + }) + ); + SuperTokens.instance = new SuperTokens(exports.__assign(exports.__assign({}, config), { recipeList: recipes })); + postSuperTokensInitCallbacks.PostSuperTokensInitCallbacks.runPostInitCallbacks(); + }; + SuperTokens.getInstanceOrThrow = function () { + if (SuperTokens.instance === undefined) { + var error = "SuperTokens must be initialized before calling this method."; + // eslint-disable-next-line supertokens-auth-react/no-direct-window-object + if (typeof window === "undefined") { + error = error + SSR_ERROR; + } + throw new Error(error); + } + return SuperTokens.instance; + }; + SuperTokens.prototype.getRecipeOrThrow = function (recipeId) { + var recipe = this.recipeList.find(function (recipe) { + return recipe.config.recipeId === recipeId; + }); + if (recipe === undefined) { + throw new Error("Missing recipe: ".concat(recipeId)); + } + return recipe; + }; + SuperTokens.prototype.loadTranslation = function (store) { + this.languageTranslations.translationEventSource.emit("TranslationLoaded", store); + }; + SuperTokens.prototype.getRedirectUrl = function (context, userContext) { + var _a; + return __awaiter(this, void 0, void 0, function () { + var userRes, redirectUrl; + return __generator(this, function (_b) { + switch (_b.label) { + case 0: + if (!this.userGetRedirectionURL) return [3 /*break*/, 2]; + return [4 /*yield*/, this.userGetRedirectionURL(context, userContext)]; + case 1: + userRes = _b.sent(); + if (userRes !== undefined) { + return [2 /*return*/, userRes]; + } + _b.label = 2; + case 2: + if (context.action === "TO_AUTH") { + redirectUrl = this.appInfo.websiteBasePath.getAsStringDangerous(); + return [2 /*return*/, appendTrailingSlashToURL(redirectUrl)]; + } else if (context.action === "SUCCESS") { + return [2 /*return*/, (_a = context.redirectToPath) !== null && _a !== void 0 ? _a : "/"]; + } + throw new Error("Should never come here: unexpected redirection context"); + } + }); + }); + }; + /* + * Tests methods. + */ + SuperTokens.reset = function () { + if (!isTest()) { + return; + } + SuperTokens.instance = undefined; + return; + }; + SuperTokens.usesDynamicLoginMethods = false; + return SuperTokens; +})(); +function doRedirection(appInfo, redirectUrl, navigate) { + try { + new URL(redirectUrl); // If full URL, no error thrown, skip in app redirection. + } catch (e) { + // For multi tenancy, If mismatch between websiteDomain and current location, prepend URL relative path with websiteDomain. + var origin_1 = getOriginOfPage().getAsStringDangerous(); + if (origin_1 !== appInfo.websiteDomain.getAsStringDangerous()) { + redirectUrl = "".concat(appInfo.websiteDomain.getAsStringDangerous()).concat(redirectUrl); + redirectWithFullPageReload(redirectUrl); + return; + } + // If navigate was provided, use to redirect without reloading. + if (navigate !== undefined) { + redirectWithNavigate(redirectUrl, navigate); + return; + } + } + // Otherwise, redirect in app. + redirectWithFullPageReload(redirectUrl); +} var createGenericComponentsOverrideContext = function (v) { if (v === void 0) { @@ -21,12 +1428,42 @@ var createGenericComponentsOverrideContext = function (v) { var Provider = function (_a) { var children = _a.children, components = _a.components; - return jsxRuntime.jsx( - genericContext.Provider, - superTokens.__assign({ value: components }, { children: children }) - ); + return jsxRuntime.jsx(genericContext.Provider, exports.__assign({ value: components }, { children: children })); }; return [useComponentsOverrideContext, Provider, genericContext.Consumer]; }; +exports.BaseRecipeModule = BaseRecipeModule; +exports.Multitenancy = Multitenancy; +exports.SSR_ERROR = SSR_ERROR; +exports.ST_ROOT_ID = ST_ROOT_ID; +exports.SuperTokens = SuperTokens; +exports.__awaiter = __awaiter; +exports.__extends = __extends; +exports.__generator = __generator; +exports.__rest = __rest; +exports.__spreadArray = __spreadArray; +exports.appendQueryParamsToURL = appendQueryParamsToURL; +exports.clearErrorQueryParam = clearErrorQueryParam; +exports.clearQueryParams = clearQueryParams; exports.createGenericComponentsOverrideContext = createGenericComponentsOverrideContext; +exports.getCurrentLanguageFromCookie = getCurrentLanguageFromCookie; +exports.getCurrentNormalisedUrlPath = getCurrentNormalisedUrlPath; +exports.getCurrentNormalisedUrlPathWithQueryParamsAndFragments = getCurrentNormalisedUrlPathWithQueryParamsAndFragments; +exports.getLocalStorage = getLocalStorage; +exports.getNormalisedUserContext = getNormalisedUserContext; +exports.getQueryParams = getQueryParams; +exports.getRedirectToPathFromURL = getRedirectToPathFromURL; +exports.getURLHash = getURLHash; +exports.isTest = isTest; +exports.logDebugMessage = logDebugMessage; +exports.matchRecipeIdUsingQueryParams = matchRecipeIdUsingQueryParams; +exports.mergeObjects = mergeObjects; +exports.normaliseRecipeModuleConfig = normaliseRecipeModuleConfig; +exports.redirectWithFullPageReload = redirectWithFullPageReload; +exports.removeFromLocalStorage = removeFromLocalStorage; +exports.setLocalStorage = setLocalStorage; +exports.updateQueryParam = updateQueryParam; +exports.useOnMountAPICall = useOnMountAPICall; +exports.useRethrowInRender = useRethrowInRender; +exports.validateForm = validateForm; diff --git a/lib/build/index.js b/lib/build/index.js index 11217f2b2..b2a26c6c8 100644 --- a/lib/build/index.js +++ b/lib/build/index.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -require("./superTokens.js"); +require("./genericComponentOverrideContext.js"); var uiEntry = require("./index2.js"); var translationContext = require("./translationContext.js"); require("supertokens-web-js"); @@ -17,7 +17,6 @@ require("supertokens-web-js/utils/normalisedURLPath"); require("react/jsx-runtime"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./multifactorauth-shared2.js"); require("supertokens-web-js/recipe/multifactorauth"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); diff --git a/lib/build/index2.js b/lib/build/index2.js index 77de0cac3..afe235f69 100644 --- a/lib/build/index2.js +++ b/lib/build/index2.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var React = require("react"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); @@ -11,7 +11,6 @@ var componentOverrideContext = require("./multitenancy-shared.js"); var recipe$1 = require("./multifactorauth-shared2.js"); var types = require("./multifactorauth-shared.js"); var recipe = require("./oauth2provider-shared.js"); -var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var utils = require("./authRecipe-shared.js"); var NormalisedURLPath$1 = require("supertokens-web-js/lib/build/normalisedURLPath"); @@ -48,12 +47,12 @@ var ComponentOverrideContext = React__default.default.createContext("IS_DEFAULT" function SpinnerIcon() { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { version: "1.1", viewBox: "25 25 50 50", "data-supertokens": "spinnerIcon" }, { children: jsxRuntime.jsxs( "circle", - superTokens.__assign( + genericComponentOverrideContext.__assign( { cx: "50", cy: "50", @@ -114,10 +113,10 @@ var withOverride = function (overrideKey, DefaultComponent) { if (OverrideComponent !== null) { return jsxRuntime.jsx( OverrideComponent, - superTokens.__assign({ DefaultComponent: DefaultComponent }, props) + genericComponentOverrideContext.__assign({ DefaultComponent: DefaultComponent }, props) ); } - return jsxRuntime.jsx(DefaultComponent, superTokens.__assign({}, props)); + return jsxRuntime.jsx(DefaultComponent, genericComponentOverrideContext.__assign({}, props)); }; }; @@ -145,17 +144,17 @@ var ThemeBase$1 = function (_a) { var MultitenancyDynamicLoginMethodsSpinnerTheme = function () { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container delayedRender" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "spinner delayedRender" }, { children: jsxRuntime.jsx(SpinnerIcon, {}) } ) @@ -172,10 +171,10 @@ var DynamicLoginMethodsSpinnerThemeWithOverride = withOverride( MultitenancyDynamicLoginMethodsSpinnerTheme ); var DynamicLoginMethodsSpinnerTheme = function (props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; return jsxRuntime.jsx( ThemeBase$1, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: false, userStyles: [rootStyle, props.config.recipeRootStyle] }, { children: jsxRuntime.jsx(DynamicLoginMethodsSpinnerThemeWithOverride, {}) } ) @@ -187,17 +186,17 @@ var DynamicLoginMethodsSpinnerTheme = function (props) { // - it's used inside FeatureWrapper & RoutingComponent (meaning it can't use FeatureWrapper) // - it's not used in any specific route (multitenancy doesn't have a pre-built UI) var DynamicLoginMethodsSpinner = function () { - var recipe = superTokens.Multitenancy.getInstanceOrThrow(); + var recipe = genericComponentOverrideContext.Multitenancy.getInstanceOrThrow(); var recipeComponentOverrides = componentOverrideContext.useContext(); return jsxRuntime.jsx( ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( WithOrWithoutShadowDom, - superTokens.__assign( - { useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom }, + genericComponentOverrideContext.__assign( + { useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom }, { children: jsxRuntime.jsx(DynamicLoginMethodsSpinnerTheme, { config: recipe.config }) } ) ), @@ -220,7 +219,7 @@ var DynamicLoginMethodsProvider = function (_a) { var contextValue = value === undefined ? { loaded: false } : { loaded: true, loginMethods: value }; return jsxRuntime.jsx( dynamicLoginMethodsContext.Provider, - superTokens.__assign({ value: contextValue }, { children: children }) + genericComponentOverrideContext.__assign({ value: contextValue }, { children: children }) ); }; @@ -231,10 +230,10 @@ var useUserContext = function () { var UserContextProvider = function (_a) { var children = _a.children, userContext = _a.userContext; - var currentUserContext = React.useState(superTokens.getNormalisedUserContext(userContext))[0]; + var currentUserContext = React.useState(genericComponentOverrideContext.getNormalisedUserContext(userContext))[0]; return jsxRuntime.jsx( UserContextContext.Provider, - superTokens.__assign({ value: currentUserContext }, { children: children }) + genericComponentOverrideContext.__assign({ value: currentUserContext }, { children: children }) ); }; @@ -243,17 +242,17 @@ function FeatureWrapper(_a) { useShadowDom = _a.useShadowDom, defaultStore = _a.defaultStore; var userContext = useUserContext(); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var _b = React.useState(undefined), loadedDynamicLoginMethods = _b[0], setLoadedDynamicLoginMethods = _b[1]; - var st = superTokens.SuperTokens.getInstanceOrThrow(); + var st = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow(); React.useEffect( function () { if (loadedDynamicLoginMethods) { return; } - superTokens.Multitenancy.getInstanceOrThrow() + genericComponentOverrideContext.Multitenancy.getInstanceOrThrow() .getCurrentDynamicLoginMethods({ userContext: userContext }) .then( function (loginMethods) { @@ -266,20 +265,20 @@ function FeatureWrapper(_a) { }, [loadedDynamicLoginMethods, setLoadedDynamicLoginMethods] ); - if (superTokens.SuperTokens.usesDynamicLoginMethods && !loadedDynamicLoginMethods) { + if (genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods && !loadedDynamicLoginMethods) { return jsxRuntime.jsx(DynamicLoginMethodsSpinner, {}); } return jsxRuntime.jsx( DynamicLoginMethodsProvider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: loadedDynamicLoginMethods }, { children: jsxRuntime.jsx( translationContext.TranslationContextProvider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { defaultLanguage: st.languageTranslations.defaultLanguage, - defaultStore: superTokens.mergeObjects( + defaultStore: genericComponentOverrideContext.mergeObjects( defaultStore, st.languageTranslations.userTranslationStore ), @@ -289,7 +288,10 @@ function FeatureWrapper(_a) { { children: jsxRuntime.jsx( WithOrWithoutShadowDom, - superTokens.__assign({ useShadowDom: useShadowDom }, { children: children }) + genericComponentOverrideContext.__assign( + { useShadowDom: useShadowDom }, + { children: children } + ) ), } ) @@ -322,8 +324,8 @@ function WithShadowDom(_a) { // Otherwise, use shadow dom. return jsxRuntime.jsx( "div", - superTokens.__assign( - { id: superTokens.ST_ROOT_ID, ref: rootDiv }, + genericComponentOverrideContext.__assign( + { id: genericComponentOverrideContext.ST_ROOT_ID, ref: rootDiv }, { children: shadowRoot && reactDom.createPortal(children, shadowRoot) } ) ); @@ -335,8 +337,8 @@ function WithOrWithoutShadowDom(_a) { if (useShadowDom === false) { return jsxRuntime.jsxs( "div", - superTokens.__assign( - { id: superTokens.ST_ROOT_ID }, + genericComponentOverrideContext.__assign( + { id: genericComponentOverrideContext.ST_ROOT_ID }, { children: [children, jsxRuntime.jsx(DisableAutoFillInput, {})] } ) ); @@ -347,7 +349,7 @@ function DisableAutoFillInput() { /* eslint-disable react/jsx-no-literals */ return jsxRuntime.jsx( "style", - superTokens.__assign( + genericComponentOverrideContext.__assign( { type: "text/css" }, { children: @@ -404,7 +406,7 @@ function SuperTokensBranding() { var t = translationContext.useTranslation(); return jsxRuntime.jsxs( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "superTokensBranding", href: "https://supertokens.com?utm_campaign=poweredby", @@ -454,7 +456,7 @@ function UserContextWrapper(props) { if (props.userContext !== undefined) { return jsxRuntime.jsx( UserContextProvider, - superTokens.__assign({ userContext: props.userContext }, { children: props.children }) + genericComponentOverrideContext.__assign({ userContext: props.userContext }, { children: props.children }) ); } return jsxRuntime.jsx(UserContextContext.Consumer, { @@ -484,7 +486,10 @@ function UserContextWrapper(props) { function GeneralError(_a) { var error = _a.error; var t = translationContext.useTranslation(); - return jsxRuntime.jsx("div", superTokens.__assign({ "data-supertokens": "generalError" }, { children: t(error) })); + return jsxRuntime.jsx( + "div", + genericComponentOverrideContext.__assign({ "data-supertokens": "generalError" }, { children: t(error) }) + ); } var styles = @@ -515,14 +520,14 @@ var AuthPageComponentList = withOverride("AuthPageComponentList", function AuthP list.push(function () { return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "dividerWithOr" }, { children: [ jsxRuntime.jsx("div", { "data-supertokens": "divider" }), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "dividerText" }, { children: t("DIVIDER_OR") } ) @@ -541,11 +546,11 @@ var AuthPageComponentList = withOverride("AuthPageComponentList", function AuthP } return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "authComponentList" }, { children: list.map(function (i) { - return i(superTokens.__assign({}, props)); + return i(genericComponentOverrideContext.__assign({}, props)); }), } ) @@ -566,7 +571,7 @@ var AuthPageFooter = withOverride("AuthPageFooter", function AuthPageFooter(_a) } return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText privacyPolicyAndTermsAndConditions" }, { children: [ @@ -574,7 +579,7 @@ var AuthPageFooter = withOverride("AuthPageFooter", function AuthPageFooter(_a) termsOfServiceLink !== undefined && jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "link", href: termsOfServiceLink, @@ -588,7 +593,7 @@ var AuthPageFooter = withOverride("AuthPageFooter", function AuthPageFooter(_a) privacyPolicyLink !== undefined && jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "link", href: privacyPolicyLink, @@ -629,7 +634,7 @@ function HeavyArrowLeftIcon(_a) { var color = _a.color; return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "16", @@ -655,7 +660,7 @@ function BackButton(_a) { var onClick = _a.onClick; return jsxRuntime.jsx( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: onClick, "data-supertokens": "backButton backButtonCommon" }, { children: jsxRuntime.jsx(HeavyArrowLeftIcon, { color: "rgb(var(--palette-textTitle))" }) } ) @@ -680,7 +685,7 @@ var AuthPageHeader = withOverride("AuthPageHeader", function AuthPageHeader(_a) }), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle withBackButton" }, { children: [ @@ -702,7 +707,7 @@ var AuthPageHeader = withOverride("AuthPageHeader", function AuthPageHeader(_a) oauth2ClientInfo && jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "authPageTitleOAuthClient" }, { children: [ @@ -710,7 +715,7 @@ var AuthPageHeader = withOverride("AuthPageHeader", function AuthPageHeader(_a) oauth2ClientInfo.clientUri !== undefined ? jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "authPageTitleOAuthClientUrl link", href: oauth2ClientInfo.clientUri, @@ -720,7 +725,7 @@ var AuthPageHeader = withOverride("AuthPageHeader", function AuthPageHeader(_a) ) : jsxRuntime.jsx( "span", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "authPageTitleOAuthClientName" }, { children: oauth2ClientInfo.clientName } ) @@ -733,14 +738,14 @@ var AuthPageHeader = withOverride("AuthPageHeader", function AuthPageHeader(_a) (!isSignUp ? jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: [ t("AUTH_PAGE_HEADER_SUBTITLE_SIGN_IN_START"), jsxRuntime.jsx( "span", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "link", onClick: onSignInUpSwitcherClick }, { children: t("AUTH_PAGE_HEADER_SUBTITLE_SIGN_IN_SIGN_UP_LINK") } ) @@ -752,14 +757,14 @@ var AuthPageHeader = withOverride("AuthPageHeader", function AuthPageHeader(_a) ) : jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: [ t("AUTH_PAGE_HEADER_SUBTITLE_SIGN_UP_START"), jsxRuntime.jsx( "span", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "link", onClick: onSignInUpSwitcherClick }, { children: t("AUTH_PAGE_HEADER_SUBTITLE_SIGN_UP_SIGN_IN_LINK") } ) @@ -778,7 +783,7 @@ function AuthPageTheme(props) { if (props.fullPageCompWithPreloadedInfo) { return jsxRuntime.jsx(jsxRuntime.Fragment, { children: props.fullPageCompWithPreloadedInfo.component( - superTokens.__assign(superTokens.__assign({}, props), { + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, props), { preloadInfo: props.fullPageCompWithPreloadedInfo.preloadInfo, }) ), @@ -786,7 +791,7 @@ function AuthPageTheme(props) { } return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container authPage ".concat( props.factorIds.length > 1 ? "multiFactor" : "singleFactor" @@ -796,7 +801,7 @@ function AuthPageTheme(props) { children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ @@ -810,7 +815,10 @@ function AuthPageTheme(props) { oauth2ClientInfo: props.oauth2ClientInfo, }), props.error !== undefined && jsxRuntime.jsx(GeneralError, { error: props.error }), - jsxRuntime.jsx(AuthPageComponentList, superTokens.__assign({}, props)), + jsxRuntime.jsx( + AuthPageComponentList, + genericComponentOverrideContext.__assign({}, props) + ), jsxRuntime.jsx(AuthPageFooter, { factorIds: props.factorIds, isSignUp: props.isSignUp, @@ -829,18 +837,18 @@ function AuthPageTheme(props) { ); } function AuthPageThemeWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = hasFontDefined(rootStyle); return jsxRuntime.jsx( UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle] }, - { children: jsxRuntime.jsx(AuthPageTheme, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(AuthPageTheme, genericComponentOverrideContext.__assign({}, props)) } ) ), } @@ -857,19 +865,24 @@ var AuthPageWrapper = function (props) { var authRecipeComponentOverrides = useContext(); return jsxRuntime.jsx( UserContextProvider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( SessionAuthWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { requireAuth: false, doRedirection: false }, { children: jsxRuntime.jsx( ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: authRecipeComponentOverrides }, - { children: jsxRuntime.jsx(AuthPageInner, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + AuthPageInner, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ), } @@ -910,7 +923,7 @@ var AuthPageInner = function (props) { var forceFreshAuth = search.get("forceFreshAuth") === "true"; var sessionContext = useSessionContext(); var userContext = useUserContext(); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var _f = React.useState(undefined), loadedDynamicLoginMethods = _f[0], setLoadedDynamicLoginMethods = _f[1]; @@ -923,7 +936,7 @@ var AuthPageInner = function (props) { var _j = React.useState(false), sessionLoadedAndNotRedirecting = _j[0], setSessionLoadedAndNotRedirecting = _j[1]; - var st = superTokens.SuperTokens.getInstanceOrThrow(); + var st = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow(); var _k = React.useState(props.factors), factorList = _k[0], setFactorList = _k[1]; @@ -965,7 +978,7 @@ var AuthPageInner = function (props) { var onSignInUpSwitcherClick = React.useCallback( function () { if (props.useSignUpStateFromQueryString === true) { - superTokens.updateQueryParam("show", isSignUp ? "signin" : "signup"); + genericComponentOverrideContext.updateQueryParam("show", isSignUp ? "signin" : "signup"); } setError(undefined); setIsSignUp(!isSignUp); @@ -980,7 +993,7 @@ var AuthPageInner = function (props) { if (loadedDynamicLoginMethods) { return; } - superTokens.Multitenancy.getInstanceOrThrow() + genericComponentOverrideContext.Multitenancy.getInstanceOrThrow() .getCurrentDynamicLoginMethods({ userContext: userContext }) .then( function (loginMethods) { @@ -1038,7 +1051,7 @@ var AuthPageInner = function (props) { recipeId: types.Session.RECIPE_ID, }, types.Session.RECIPE_ID, - superTokens.getRedirectToPathFromURL(), + genericComponentOverrideContext.getRedirectToPathFromURL(), userContext, props.navigate ) @@ -1048,7 +1061,7 @@ var AuthPageInner = function (props) { .validateGlobalClaimsAndHandleSuccessRedirection( undefined, types.Session.RECIPE_ID, - superTokens.getRedirectToPathFromURL(), + genericComponentOverrideContext.getRedirectToPathFromURL(), userContext, props.navigate ) @@ -1073,7 +1086,7 @@ var AuthPageInner = function (props) { props.factors.some(function (id) { return !factorList.includes(id); })); - var stInstance = superTokens.SuperTokens.getInstanceOrThrow(); + var stInstance = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow(); var privacyPolicyLink = stInstance.privacyPolicyLink; var termsOfServiceLink = stInstance.termsOfServiceLink; React.useEffect( @@ -1084,7 +1097,8 @@ var AuthPageInner = function (props) { } if ( sessionLoadedAndNotRedirecting && - (loadedDynamicLoginMethods !== undefined || !superTokens.SuperTokens.usesDynamicLoginMethods) + (loadedDynamicLoginMethods !== undefined || + !genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods) ) { void buildAndSetChildProps( props.preBuiltUIList, @@ -1119,16 +1133,16 @@ var AuthPageInner = function (props) { function (ctx) { return types.Session.getInstanceOrThrow().validateGlobalClaimsAndHandleSuccessRedirection( loginChallenge !== null - ? superTokens.__assign(superTokens.__assign({}, ctx), { + ? genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, ctx), { action: "SUCCESS_OAUTH2", loginChallenge: loginChallenge, }) - : superTokens.__assign(superTokens.__assign({}, ctx), { + : genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, ctx), { action: "SUCCESS", - redirectToPath: superTokens.getRedirectToPathFromURL(), + redirectToPath: genericComponentOverrideContext.getRedirectToPathFromURL(), }), ctx.recipeId, - superTokens.getRedirectToPathFromURL(), + genericComponentOverrideContext.getRedirectToPathFromURL(), userContext, props.navigate ); @@ -1137,40 +1151,43 @@ var AuthPageInner = function (props) { ); var childProps = authComponentListInfo !== undefined && (loginChallenge === null || oauth2ClientInfo !== undefined) - ? superTokens.__assign(superTokens.__assign({}, authComponentListInfo), { - oauth2ClientInfo: oauth2ClientInfo, - onAuthSuccess: onAuthSuccess, - error: error, - onError: function (err) { - setError(err); - }, - clearError: function () { - return setError(undefined); - }, - navigate: props.navigate, - onSignInUpSwitcherClick: onSignInUpSwitcherClick, - privacyPolicyLink: privacyPolicyLink, - rebuildAuthPage: function () { - return setRebuildReqCount(function (v) { - return v + 1; - }); - }, - setFactorList: function (factorIds) { - setFactorList(factorIds); - setRebuildReqCount(function (v) { - return v + 1; - }); - }, - resetFactorList: function () { - setFactorList(props.factors); - setRebuildReqCount(function (v) { - return v + 1; - }); - }, - showBackButton: showUseAnotherLink, - termsOfServiceLink: termsOfServiceLink, - userContext: userContext, - }) + ? genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, authComponentListInfo), + { + oauth2ClientInfo: oauth2ClientInfo, + onAuthSuccess: onAuthSuccess, + error: error, + onError: function (err) { + setError(err); + }, + clearError: function () { + return setError(undefined); + }, + navigate: props.navigate, + onSignInUpSwitcherClick: onSignInUpSwitcherClick, + privacyPolicyLink: privacyPolicyLink, + rebuildAuthPage: function () { + return setRebuildReqCount(function (v) { + return v + 1; + }); + }, + setFactorList: function (factorIds) { + setFactorList(factorIds); + setRebuildReqCount(function (v) { + return v + 1; + }); + }, + resetFactorList: function () { + setFactorList(props.factors); + setRebuildReqCount(function (v) { + return v + 1; + }); + }, + showBackButton: showUseAnotherLink, + termsOfServiceLink: termsOfServiceLink, + userContext: userContext, + } + ) : undefined; var mergedTranslations = React.useMemo( function () { @@ -1178,10 +1195,10 @@ var AuthPageInner = function (props) { if (authComponentListInfo !== undefined) { for (var _i = 0, _a = props.preBuiltUIList; _i < _a.length; _i++) { var ui = _a[_i]; - res = superTokens.mergeObjects(res, ui.languageTranslations); + res = genericComponentOverrideContext.mergeObjects(res, ui.languageTranslations); } } - res = superTokens.mergeObjects(res, st.languageTranslations.userTranslationStore); + res = genericComponentOverrideContext.mergeObjects(res, st.languageTranslations.userTranslationStore); return res; }, [st.languageTranslations.userTranslationStore, authComponentListInfo] @@ -1191,12 +1208,12 @@ var AuthPageInner = function (props) { } else { return jsxRuntime.jsx( DynamicLoginMethodsProvider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: loadedDynamicLoginMethods }, { children: jsxRuntime.jsx( translationContext.TranslationContextProvider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { defaultLanguage: st.languageTranslations.defaultLanguage, defaultStore: mergedTranslations, @@ -1206,7 +1223,7 @@ var AuthPageInner = function (props) { { children: jsxRuntime.jsx( WithOrWithoutShadowDom, - superTokens.__assign( + genericComponentOverrideContext.__assign( { useShadowDom: st.useShadowDom }, { children: jsxRuntime.jsxs(React.Fragment, { @@ -1214,7 +1231,7 @@ var AuthPageInner = function (props) { props.children === undefined && jsxRuntime.jsx( AuthPageThemeWrapper, - superTokens.__assign({}, childProps) + genericComponentOverrideContext.__assign({}, childProps) ), props.children && React__default.default.Children.map( @@ -1252,7 +1269,7 @@ function buildAndSetChildProps( abort ) { var _a, _b, _c, _d; - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var authRecipesInited, firstFactors, missingPreBuiltUIs, @@ -1269,14 +1286,15 @@ function buildAndSetChildProps( preloadRes, partialAuthComps, selectedComponents; - return superTokens.__generator(this, function (_f) { + return genericComponentOverrideContext.__generator(this, function (_f) { switch (_f.label) { case 0: - authRecipesInited = superTokens.SuperTokens.getInstanceOrThrow().recipeList.filter(function ( - recipe - ) { - return "firstFactorIds" in recipe; - }); + authRecipesInited = + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().recipeList.filter(function ( + recipe + ) { + return "firstFactorIds" in recipe; + }); firstFactors = (_c = (_a = @@ -1291,8 +1309,8 @@ function buildAndSetChildProps( : _b.config.firstFactors) !== null && _c !== void 0 ? _c : authRecipesInited.reduce(function (acc, recipe) { - return superTokens.__spreadArray( - superTokens.__spreadArray([], acc, true), + return genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray([], acc, true), recipe.getFirstFactorsForAuthPage(), true ); @@ -1333,7 +1351,7 @@ function buildAndSetChildProps( // We have no provider defined for the tenant either if ( thirdPartyPreBuiltUI.recipeInstance.config.signInAndUpFeature.providers.length === 0 && - (!superTokens.SuperTokens.usesDynamicLoginMethods || + (!genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods || loadedDynamicLoginMethods.thirdparty.providers.length === 0) ) { firstFactors = firstFactors.filter(function (f) { @@ -1482,7 +1500,7 @@ function chooseComponentBasedOnFirstFactors(firstFactors, routeComponents) { fallbackRid = rid; fallbackComponent = matchingComp; if (firstFactors.length === factorsProvided.length) { - superTokens.logDebugMessage( + genericComponentOverrideContext.logDebugMessage( "Rendering ".concat(rid, " because it matches factors: ").concat(firstFactors, " exactly") ); return { value: matchingComp }; @@ -1524,7 +1542,7 @@ function chooseComponentBasedOnFirstFactors(firstFactors, routeComponents) { if (typeof state_1 === "object") return state_1.value; } if (fallbackComponent !== undefined) { - superTokens.logDebugMessage( + genericComponentOverrideContext.logDebugMessage( "Rendering ".concat(fallbackRid, " to cover ").concat(firstFactors, " as a fallback") ); return fallbackComponent; @@ -1555,7 +1573,7 @@ function chooseComponentBasedOnFirstFactors(firstFactors, routeComponents) { ) { enabledLoginMethods.push("passwordless"); } - superTokens.logDebugMessage( + genericComponentOverrideContext.logDebugMessage( "Choosing component using fallback logic w/ ".concat(enabledLoginMethods.join(", "), " enabled") ); var enabledRecipeCount = enabledLoginMethods.length; @@ -1640,7 +1658,8 @@ var RecipeRouter = /** @class */ (function () { var path = normalisedUrl.getAsStringDangerous(); // We check if we are on the auth page to later see if we should take first factors into account. var isAuthPage = - path === superTokens.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous(); + path === + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous(); // We get all components that can handle the current path var routeComponents = preBuiltUIList.reduce(function (components, c) { var routes = c.getPathsToFeatureComponentWithRecipeIdMap(); @@ -1688,7 +1707,7 @@ var RecipeRouter = /** @class */ (function () { return ( !ridlist.includes(comp.comp.recipeID) || comp.route !== - superTokens.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous() + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous() ); }); if (matchingNonAuthComponent) { @@ -1700,7 +1719,7 @@ var RecipeRouter = /** @class */ (function () { return defaultComp; } var mfaRecipe = recipe$1.MultiFactorAuth.getInstance(); - if (superTokens.SuperTokens.usesDynamicLoginMethods === false) { + if (genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods === false) { // If we are not using dynamic login methods, we can use the rid requested by the app if (componentMatchingRid) { return componentMatchingRid.comp; @@ -1762,7 +1781,7 @@ var RecipeRouter = /** @class */ (function () { function RoutingComponent(props) { var _a, _b; var userContext = useUserContext(); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var _c = React.useState(undefined), loadedDynamicLoginMethods = _c[0], setLoadedDynamicLoginMethods = _c[1]; @@ -1770,7 +1789,8 @@ function RoutingComponent(props) { (_a = props.getReactRouterDomWithCustomHistory()) === null || _a === void 0 ? void 0 : _a.useHistoryCustom(); var path = props.path; var isAuthPage = - path === superTokens.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous(); + path === + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous(); var location = (_b = props.getReactRouterDomWithCustomHistory()) === null || _b === void 0 ? void 0 : _b.useLocation(); var componentToRender = React__default.default.useMemo( @@ -1782,14 +1802,20 @@ function RoutingComponent(props) { // During development, this runs twice so as to warn devs of if there // are any side effects that happen here. So in tests, it will result in // the console log twice - if (loadedDynamicLoginMethods !== undefined || superTokens.SuperTokens.usesDynamicLoginMethods === false) { + if ( + loadedDynamicLoginMethods !== undefined || + genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods === false + ) { var result = RecipeRouter.getMatchingComponentForRouteAndRecipeIdFromPreBuiltUIList( normalizedPath, props.preBuiltUIList, false, loadedDynamicLoginMethods ); - if (result === undefined && superTokens.SuperTokens.usesDynamicLoginMethods === true) { + if ( + result === undefined && + genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods === true + ) { void redirectToAuth({ navigate: navigate, redirectBack: false }); } return result; @@ -1805,7 +1831,7 @@ function RoutingComponent(props) { if (loadedDynamicLoginMethods) { return; } - superTokens.Multitenancy.getInstanceOrThrow() + genericComponentOverrideContext.Multitenancy.getInstanceOrThrow() .getCurrentDynamicLoginMethods({ userContext: userContext }) .then( function (loginMethods) { @@ -1825,12 +1851,15 @@ function RoutingComponent(props) { useSignUpStateFromQueryString: true, }); } - if (superTokens.SuperTokens.usesDynamicLoginMethods && loadedDynamicLoginMethods === undefined) { + if ( + genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods && + loadedDynamicLoginMethods === undefined + ) { return jsxRuntime.jsx(DynamicLoginMethodsSpinner, {}); } if ( componentToRender === undefined || - (loadedDynamicLoginMethods === undefined && superTokens.SuperTokens.usesDynamicLoginMethods) + (loadedDynamicLoginMethods === undefined && genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods) ) { return null; } @@ -1858,7 +1887,7 @@ function getSuperTokensRoutesForReactRouterDom$1(_a) { if (!(path in routes)) { routes[path] = jsxRuntime.jsx( Route, - superTokens.__assign( + genericComponentOverrideContext.__assign( { exact: true, path: pathForRouter }, { children: jsxRuntime.jsx(RoutingComponent, { @@ -1876,18 +1905,18 @@ function getSuperTokensRoutesForReactRouterDom$1(_a) { }, {}) ); if ( - !superTokens.SuperTokens.getInstanceOrThrow().disableAuthRoute && + !genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().disableAuthRoute && recipeList.some(function (ui) { return ui.getAuthComponents().length !== 0; }) ) { - var path = superTokens.SuperTokens.getInstanceOrThrow() + var path = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow() .appInfo.websiteBasePath.appendPath(new NormalisedURLPath__default$1.default("/")) .getAsStringDangerous(); routes.push( jsxRuntime.jsx( Route, - superTokens.__assign( + genericComponentOverrideContext.__assign( { exact: true, path: getPathForRouter$1(basePath, path) }, { children: jsxRuntime.jsx(RoutingComponent, { @@ -1955,12 +1984,12 @@ function getSuperTokensRoutesForReactRouterDomV6(_a) { }, {}) ); if ( - !superTokens.SuperTokens.getInstanceOrThrow().disableAuthRoute && + !genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().disableAuthRoute && recipeList.some(function (ui) { return ui.getAuthComponents().length !== 0; }) ) { - var path = superTokens.SuperTokens.getInstanceOrThrow() + var path = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow() .appInfo.websiteBasePath.appendPath(new NormalisedURLPath__default$1.default("/")) .getAsStringDangerous(); routes.push( @@ -2065,15 +2094,16 @@ var UI = /** @class */ (function () { var recipeList = preBuiltUiClassList.map(function (r) { return r.getInstanceOrInitAndGetInstance(); }); - var path = superTokens.getCurrentNormalisedUrlPath().getAsStringDangerous(); + var path = genericComponentOverrideContext.getCurrentNormalisedUrlPath().getAsStringDangerous(); var isAuthPage = - path === superTokens.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous(); + path === + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().appInfo.websiteBasePath.getAsStringDangerous(); if (isAuthPage) { - return !superTokens.SuperTokens.getInstanceOrThrow().disableAuthRoute; + return !genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().disableAuthRoute; } return ( RecipeRouter.getMatchingComponentForRouteAndRecipeIdFromPreBuiltUIList( - superTokens.getCurrentNormalisedUrlPath(), + genericComponentOverrideContext.getCurrentNormalisedUrlPath(), recipeList, true ) !== undefined @@ -2085,7 +2115,7 @@ var UI = /** @class */ (function () { }); return jsxRuntime.jsx(RoutingComponent, { getReactRouterDomWithCustomHistory: UI.getReactRouterDomWithCustomHistory, - path: superTokens.getCurrentNormalisedUrlPath().getAsStringDangerous(), + path: genericComponentOverrideContext.getCurrentNormalisedUrlPath().getAsStringDangerous(), preBuiltUIList: recipeList, }); }; @@ -2095,7 +2125,7 @@ var UI = /** @class */ (function () { UI.AuthPage = function (props) { return jsxRuntime.jsx( AuthPageWrapper, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { preBuiltUIList: props.preBuiltUIList.map(function (r) { return r.getInstanceOrInitAndGetInstance(); }), @@ -2117,7 +2147,7 @@ var AuthPage = UI.AuthPage; var SessionAuth = function (_a) { var _b; var children = _a.children, - props = superTokens.__rest(_a, ["children"]); + props = genericComponentOverrideContext.__rest(_a, ["children"]); var requireAuth = React.useRef(props.requireAuth); if (props.requireAuth !== requireAuth.current) { throw new Error( @@ -2145,19 +2175,19 @@ var SessionAuth = function (_a) { // the app is using react-router-dom but added a session auth outside of the router. } var userContext = useUserContext(); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var redirectToLogin = React.useCallback(function () { - void superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + void genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: navigate, userContext: userContext, redirectBack: true, }); }, []); var buildContext = React.useCallback(function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var sessionExists, invalidClaims, err_1, err_2; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if (session.current === undefined) { @@ -2277,9 +2307,9 @@ var SessionAuth = function (_a) { }, []); var setInitialContextAndMaybeRedirect = React.useCallback( function (toSetContext) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var failureRedirectInfo, err_3; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: if (context.loading === false) { @@ -2317,7 +2347,7 @@ var SessionAuth = function (_a) { case 3: return [ 4 /*yield*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToUrl( + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToUrl( failureRedirectInfo.redirectPath, navigate ), @@ -2342,9 +2372,10 @@ var SessionAuth = function (_a) { return [ 2 /*return*/, setContext( - superTokens.__assign(superTokens.__assign({}, toSetContext), { - accessDeniedValidatorError: failureRedirectInfo.failedClaim, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, toSetContext), + { accessDeniedValidatorError: failureRedirectInfo.failedClaim } + ) ), ]; } @@ -2367,14 +2398,14 @@ var SessionAuth = function (_a) { navigate, ] ); - superTokens.useOnMountAPICall(buildContext, setInitialContextAndMaybeRedirect); + genericComponentOverrideContext.useOnMountAPICall(buildContext, setInitialContextAndMaybeRedirect); // subscribe to events on mount React.useEffect( function () { function onHandleEvent(event) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var _a, invalidClaims, failureRedirectInfo, err_4; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: _a = event.action; @@ -2426,16 +2457,16 @@ var SessionAuth = function (_a) { ) return [3 /*break*/, 5]; setContext( - superTokens.__assign(superTokens.__assign({}, event.sessionContext), { - loading: false, - invalidClaims: invalidClaims, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, event.sessionContext), + { loading: false, invalidClaims: invalidClaims } + ) ); return [3 /*break*/, 7]; case 5: return [ 4 /*yield*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToUrl( + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToUrl( failureRedirectInfo.redirectPath, navigate ), @@ -2460,37 +2491,40 @@ var SessionAuth = function (_a) { return [ 2 /*return*/, setContext( - superTokens.__assign(superTokens.__assign({}, event.sessionContext), { - loading: false, - invalidClaims: invalidClaims, - accessDeniedValidatorError: failureRedirectInfo.failedClaim, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, event.sessionContext), + { + loading: false, + invalidClaims: invalidClaims, + accessDeniedValidatorError: failureRedirectInfo.failedClaim, + } + ) ), ]; } _b.label = 10; case 10: setContext( - superTokens.__assign(superTokens.__assign({}, event.sessionContext), { - loading: false, - invalidClaims: invalidClaims, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, event.sessionContext), + { loading: false, invalidClaims: invalidClaims } + ) ); return [2 /*return*/]; case 11: setContext( - superTokens.__assign(superTokens.__assign({}, event.sessionContext), { - loading: false, - invalidClaims: [], - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, event.sessionContext), + { loading: false, invalidClaims: [] } + ) ); return [2 /*return*/]; case 12: setContext( - superTokens.__assign(superTokens.__assign({}, event.sessionContext), { - loading: false, - invalidClaims: [], - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, event.sessionContext), + { loading: false, invalidClaims: [] } + ) ); if (props.onSessionExpired !== undefined) { props.onSessionExpired(); @@ -2527,14 +2561,17 @@ var SessionAuth = function (_a) { validationError: context.accessDeniedValidatorError, }); } - return jsxRuntime.jsx(SessionContext.Provider, superTokens.__assign({ value: context }, { children: children })); + return jsxRuntime.jsx( + SessionContext.Provider, + genericComponentOverrideContext.__assign({ value: context }, { children: children }) + ); }; var SessionAuthWrapper = function (props) { return jsxRuntime.jsx( UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, - { children: jsxRuntime.jsx(SessionAuth, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(SessionAuth, genericComponentOverrideContext.__assign({}, props)) } ) ); }; @@ -2542,7 +2579,7 @@ var SessionAuthWrapper = function (props) { var SuperTokensWrapper = function (props) { return jsxRuntime.jsx( SessionAuthWrapper, - superTokens.__assign({}, props, { requireAuth: false, doRedirection: false }) + genericComponentOverrideContext.__assign({}, props, { requireAuth: false, doRedirection: false }) ); }; @@ -2566,34 +2603,37 @@ var SuperTokensWrapper = function (props) { var SuperTokensAPIWrapper = /** @class */ (function () { function SuperTokensAPIWrapper() {} SuperTokensAPIWrapper.init = function (config) { - superTokens.SuperTokens.init(config); + genericComponentOverrideContext.SuperTokens.init(config); }; SuperTokensAPIWrapper.changeLanguage = function (language) { - return superTokens.SuperTokens.getInstanceOrThrow().changeLanguage(language); + return genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().changeLanguage(language); }; SuperTokensAPIWrapper.loadTranslation = function (store) { - return superTokens.SuperTokens.getInstanceOrThrow().loadTranslation(store); + return genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().loadTranslation(store); }; var _a; _a = SuperTokensAPIWrapper; SuperTokensAPIWrapper.SuperTokensWrapper = SuperTokensWrapper; SuperTokensAPIWrapper.redirectToAuth = function (options) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var _b; - return superTokens.__generator(_a, function (_c) { + return genericComponentOverrideContext.__generator(_a, function (_c) { return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth( - superTokens.__assign(superTokens.__assign({}, options), { - redirectBack: - (_b = options === null || options === void 0 ? void 0 : options.redirectBack) !== - null && _b !== void 0 - ? _b - : true, - userContext: superTokens.getNormalisedUserContext( - options === null || options === void 0 ? void 0 : options.userContext - ), - }) + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth( + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, options), + { + redirectBack: + (_b = options === null || options === void 0 ? void 0 : options.redirectBack) !== + null && _b !== void 0 + ? _b + : true, + userContext: genericComponentOverrideContext.getNormalisedUserContext( + options === null || options === void 0 ? void 0 : options.userContext + ), + } + ) ), ]; }); @@ -2615,6 +2655,7 @@ exports.AuthPageHeader = AuthPageHeader; exports.AuthPageTheme = AuthPageTheme; exports.BackButton = BackButton; exports.ComponentOverrideContext = ComponentOverrideContext; +exports.DynamicLoginMethodsSpinner = DynamicLoginMethodsSpinner; exports.FeatureWrapper = FeatureWrapper; exports.GeneralError = GeneralError; exports.Provider = Provider; diff --git a/lib/build/multifactorauth-shared.js b/lib/build/multifactorauth-shared.js index a2ee8cc66..9da088995 100644 --- a/lib/build/multifactorauth-shared.js +++ b/lib/build/multifactorauth-shared.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var WebJSSessionRecipe = require("supertokens-web-js/recipe/session"); var recipe = require("./oauth2provider-shared.js"); var index = require("./recipeModule-shared.js"); @@ -39,7 +39,7 @@ function normaliseSessionConfig(config) { var accessDeniedScreen = { style: accessDeniedScreenStyle, }; - var override = superTokens.__assign( + var override = genericComponentOverrideContext.__assign( { functions: function (originalImplementation) { return originalImplementation; @@ -47,20 +47,26 @@ function normaliseSessionConfig(config) { }, config.override ); - return superTokens.__assign(superTokens.__assign({}, superTokens.normaliseRecipeModuleConfig(config)), { - // TODO: ideally we'd get the default (or normalized) value from supertokens-website - invalidClaimStatusCode: (_c = config.invalidClaimStatusCode) !== null && _c !== void 0 ? _c : 403, - accessDeniedScreen: accessDeniedScreen, - override: override, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + {}, + genericComponentOverrideContext.normaliseRecipeModuleConfig(config) + ), + { + // TODO: ideally we'd get the default (or normalized) value from supertokens-website + invalidClaimStatusCode: (_c = config.invalidClaimStatusCode) !== null && _c !== void 0 ? _c : 403, + accessDeniedScreen: accessDeniedScreen, + override: override, + } + ); } var getFailureRedirectionInfo = function (_a) { var invalidClaims = _a.invalidClaims, overrideGlobalClaimValidators = _a.overrideGlobalClaimValidators, userContext = _a.userContext; - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var globalValidators, failedClaim, _loop_1, _i, globalValidators_1, validator, state_1; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: globalValidators = utils.getGlobalClaimValidators({ @@ -70,7 +76,7 @@ var getFailureRedirectionInfo = function (_a) { failedClaim = undefined; _loop_1 = function (validator) { var claim, failureCallback, redirectPath; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: claim = invalidClaims.find(function (c) { @@ -143,7 +149,7 @@ function validateAndCompareOnFailureRedirectionURLToCurrent(redirectURL) { if (!redirectURL.startsWith("/")) { throw new Error("onFailureRedirectionURL returned a relative url: ".concat(redirectURL)); } - var appInfo = superTokens.SuperTokens.getInstanceOrThrow().appInfo; + var appInfo = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().appInfo; // otherwise we prepend the websiteDomain fullRedirectURL = "".concat(appInfo.websiteDomain.getAsStringDangerous()).concat(redirectURL); } @@ -165,7 +171,7 @@ function validateAndCompareOnFailureRedirectionURLToCurrent(redirectURL) { * under the License. */ var Session = /** @class */ (function (_super) { - superTokens.__extends(Session, _super); + genericComponentOverrideContext.__extends(Session, _super); function Session(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = WebJSSessionRecipe__default.default; @@ -184,8 +190,8 @@ var Session = /** @class */ (function (_super) { return _this.webJSRecipe.getClaimValue(input); }; _this.getAccessTokenPayloadSecurely = function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, this.webJSRecipe.getAccessTokenPayloadSecurely(input)]; }); }); @@ -197,8 +203,8 @@ var Session = /** @class */ (function (_super) { return _this.webJSRecipe.signOut(input); }; _this.attemptRefreshingSession = function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, this.webJSRecipe.attemptRefreshingSession()]; }); }); @@ -229,12 +235,12 @@ var Session = /** @class */ (function (_super) { userContext, navigate ) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, jsonContext, failureRedirectInfo, successContextStr, storedContext; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: - userContext = superTokens.getNormalisedUserContext(userContext); + userContext = genericComponentOverrideContext.getNormalisedUserContext(userContext); return [4 /*yield*/, this.doesSessionExist({ userContext: userContext })]; case 1: // First we check if there is an active session @@ -243,7 +249,7 @@ var Session = /** @class */ (function (_super) { // This can happen e.g.: if the user clicked on the email verification link in a browser without an active session return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: navigate, redirectBack: false, userContext: userContext, @@ -261,7 +267,10 @@ var Session = /** @class */ (function (_super) { }); return [ 4 /*yield*/, - superTokens.setLocalStorage("supertokens-success-redirection-context", jsonContext), + genericComponentOverrideContext.setLocalStorage( + "supertokens-success-redirection-context", + jsonContext + ), ]; case 3: _a.sent(); @@ -292,7 +301,7 @@ var Session = /** @class */ (function (_super) { } return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToUrl( + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToUrl( failureRedirectInfo.redirectPath, navigate ), @@ -303,7 +312,9 @@ var Session = /** @class */ (function (_super) { if (!(successRedirectContext === undefined)) return [3 /*break*/, 13]; return [ 4 /*yield*/, - superTokens.getLocalStorage("supertokens-success-redirection-context"), + genericComponentOverrideContext.getLocalStorage( + "supertokens-success-redirection-context" + ), ]; case 7: successContextStr = _a.sent(); @@ -321,7 +332,9 @@ var Session = /** @class */ (function (_super) { case 9: return [ 4 /*yield*/, - superTokens.removeFromLocalStorage("supertokens-success-redirection-context"), + genericComponentOverrideContext.removeFromLocalStorage( + "supertokens-success-redirection-context" + ), ]; case 10: _a.sent(); @@ -360,7 +373,7 @@ var Session = /** @class */ (function (_super) { } return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirect( + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirect( successRedirectContext, navigate, {}, @@ -376,16 +389,16 @@ var Session = /** @class */ (function (_super) { * @returns "/" */ _this.getDefaultRedirectionURL = function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, "/"]; }); }); }; _this.notifyListeners = function (event) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var sessionContext; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.getSessionContext(event)]; @@ -394,7 +407,9 @@ var Session = /** @class */ (function (_super) { // We copy this.eventListeners into a new array to "freeze" it for the loop // We do this to avoid an infinite loop in case one of the listeners causes a new listener to be added (e.g.: through re-rendering) Array.from(this.eventListeners).forEach(function (listener) { - return listener(superTokens.__assign({ sessionContext: sessionContext }, event)); + return listener( + genericComponentOverrideContext.__assign({ sessionContext: sessionContext }, event) + ); }); return [2 /*return*/]; } @@ -406,9 +421,9 @@ var Session = /** @class */ (function (_super) { Session.prototype.getSessionContext = function (_a) { var action = _a.action, userContext = _a.userContext; - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var _b, userId, accessTokenPayload; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: if ( @@ -468,42 +483,54 @@ var Session = /** @class */ (function (_super) { recipeID: Session.RECIPE_ID, authReact: function (appInfo) { Session.instance = new Session( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: Session.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: Session.RECIPE_ID } + ) ); return Session.instance; }, webJS: WebJSSessionRecipe__default.default.init( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - onHandleEvent: function (event) { - if (normalisedConfig.onHandleEvent !== undefined) { - normalisedConfig.onHandleEvent(event); - } - void Session.getInstanceOrThrow().notifyListeners(event); - }, - preAPIHook: function (context) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - var response; - return superTokens.__generator(this, function (_a) { - response = superTokens.__assign(superTokens.__assign({}, context), { - requestInit: superTokens.__assign(superTokens.__assign({}, context.requestInit), { - headers: superTokens.__assign( - superTokens.__assign({}, context.requestInit.headers), - { rid: Session.RECIPE_ID } - ), - }), + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + onHandleEvent: function (event) { + if (normalisedConfig.onHandleEvent !== undefined) { + normalisedConfig.onHandleEvent(event); + } + void Session.getInstanceOrThrow().notifyListeners(event); + }, + preAPIHook: function (context) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + var response; + return genericComponentOverrideContext.__generator(this, function (_a) { + response = genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, context), + { + requestInit: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, context.requestInit), + { + headers: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + {}, + context.requestInit.headers + ), + { rid: Session.RECIPE_ID } + ), + } + ), + } + ); + if (normalisedConfig.preAPIHook === undefined) { + return [2 /*return*/, response]; + } else { + return [2 /*return*/, normalisedConfig.preAPIHook(context)]; + } }); - if (normalisedConfig.preAPIHook === undefined) { - return [2 /*return*/, response]; - } else { - return [2 /*return*/, normalisedConfig.preAPIHook(context)]; - } }); - }); - }, - }) + }, + } + ) ), }; }; @@ -519,7 +546,7 @@ var Session = /** @class */ (function (_super) { return Session.instance; }; Session.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Session.instance = undefined; diff --git a/lib/build/multifactorauth-shared2.js b/lib/build/multifactorauth-shared2.js index c42157764..4eb51565b 100644 --- a/lib/build/multifactorauth-shared2.js +++ b/lib/build/multifactorauth-shared2.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var MultiFactorAuthWebJS = require("supertokens-web-js/recipe/multifactorauth"); var utils = require("supertokens-web-js/utils"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); @@ -42,11 +42,11 @@ var getFunctionOverrides = function ( _onHandleEvent ) { return function (originalImp) { - return superTokens.__assign(superTokens.__assign({}, originalImp), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImp), { resyncSessionAndFetchMFAInfo: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var stWindow, stored, parsed, unlock, stored_1, parsed, val; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: stWindow = windowHandler.WindowHandlerReference.getReferenceOrThrow(); @@ -63,11 +63,14 @@ var getFunctionOverrides = function ( if (parsed.t > Date.now() - 1000) { return [ 2 /*return*/, - superTokens.__assign(superTokens.__assign({}, parsed.v), { - // Adding a fake response is not great, but we do want to add something and this way it's detectable by the app - // so they could even add specific handling for it if they preferred. - fetchResponse: new Response(null, { status: 304 }), - }), + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, parsed.v), + { + // Adding a fake response is not great, but we do want to add something and this way it's detectable by the app + // so they could even add specific handling for it if they preferred. + fetchResponse: new Response(null, { status: 304 }), + } + ), ]; } } @@ -93,11 +96,14 @@ var getFunctionOverrides = function ( if (parsed.t > Date.now() - 1000) { return [ 2 /*return*/, - superTokens.__assign(superTokens.__assign({}, parsed.v), { - // Adding a fake response is not great, but we do want to add something and this way it's detectable by the app - // so they could even add specific handling for it if they preferred. - fetchResponse: new Response(null, { status: 304 }), - }), + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, parsed.v), + { + // Adding a fake response is not great, but we do want to add something and this way it's detectable by the app + // so they could even add specific handling for it if they preferred. + fetchResponse: new Response(null, { status: 304 }), + } + ), ]; } } @@ -155,9 +161,9 @@ var MultiFactorAuthClaimClass = /** @class */ (function () { var defaultOnFailureRedirection = function (_a) { var reason = _a.reason, userContext = _a.userContext; - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var recipe, nextFactorOptions, availableFactors, mfaInfo_1, availableFactors; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: recipe = getRecipe(); @@ -166,7 +172,7 @@ var MultiFactorAuthClaimClass = /** @class */ (function () { reason.allOfInAnyOrder || (reason.factorId !== undefined ? [reason.factorId] : undefined); if (!(nextFactorOptions !== undefined)) return [3 /*break*/, 1]; - superTokens.logDebugMessage( + genericComponentOverrideContext.logDebugMessage( "Redirecting to MFA on next array from validation failure: " + nextFactorOptions.join(", ") ); @@ -211,7 +217,7 @@ var MultiFactorAuthClaimClass = /** @class */ (function () { .map(function (v) { return v.id; }); - superTokens.logDebugMessage( + genericComponentOverrideContext.logDebugMessage( "Redirecting to MFA on next array from backend: " + availableFactors.join(", ") ); if (availableFactors.length === 1) { @@ -233,52 +239,67 @@ var MultiFactorAuthClaimClass = /** @class */ (function () { }); }); }; - this.validators = superTokens.__assign(superTokens.__assign({}, this.webJSClaim.validators), { - hasCompletedMFARequirementsForAuth: function (doRedirection, showAccessDeniedOnFailure) { - if (doRedirection === void 0) { - doRedirection = true; - } - if (showAccessDeniedOnFailure === void 0) { - showAccessDeniedOnFailure = true; - } - var orig = _this.webJSClaim.validators.hasCompletedMFARequirementsForAuth(); - return superTokens.__assign(superTokens.__assign({}, orig), { - showAccessDeniedOnFailure: showAccessDeniedOnFailure, - onFailureRedirection: - onFailureRedirection !== null && onFailureRedirection !== void 0 - ? onFailureRedirection - : function (_a) { - var reason = _a.reason, - userContext = _a.userContext; - return doRedirection - ? defaultOnFailureRedirection({ reason: reason, userContext: userContext }) - : undefined; - }, - }); - }, - hasCompletedFactors: function (requirements, doRedirection, showAccessDeniedOnFailure) { - if (doRedirection === void 0) { - doRedirection = true; - } - if (showAccessDeniedOnFailure === void 0) { - showAccessDeniedOnFailure = true; - } - var orig = _this.webJSClaim.validators.hasCompletedFactors(requirements); - return superTokens.__assign(superTokens.__assign({}, orig), { - showAccessDeniedOnFailure: showAccessDeniedOnFailure, - onFailureRedirection: - onFailureRedirection !== null && onFailureRedirection !== void 0 - ? onFailureRedirection - : function (_a) { - var reason = _a.reason, - userContext = _a.userContext; - return doRedirection - ? defaultOnFailureRedirection({ reason: reason, userContext: userContext }) - : undefined; - }, - }); - }, - }); + this.validators = genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, this.webJSClaim.validators), + { + hasCompletedMFARequirementsForAuth: function (doRedirection, showAccessDeniedOnFailure) { + if (doRedirection === void 0) { + doRedirection = true; + } + if (showAccessDeniedOnFailure === void 0) { + showAccessDeniedOnFailure = true; + } + var orig = _this.webJSClaim.validators.hasCompletedMFARequirementsForAuth(); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, orig), + { + showAccessDeniedOnFailure: showAccessDeniedOnFailure, + onFailureRedirection: + onFailureRedirection !== null && onFailureRedirection !== void 0 + ? onFailureRedirection + : function (_a) { + var reason = _a.reason, + userContext = _a.userContext; + return doRedirection + ? defaultOnFailureRedirection({ + reason: reason, + userContext: userContext, + }) + : undefined; + }, + } + ); + }, + hasCompletedFactors: function (requirements, doRedirection, showAccessDeniedOnFailure) { + if (doRedirection === void 0) { + doRedirection = true; + } + if (showAccessDeniedOnFailure === void 0) { + showAccessDeniedOnFailure = true; + } + var orig = _this.webJSClaim.validators.hasCompletedFactors(requirements); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, orig), + { + showAccessDeniedOnFailure: showAccessDeniedOnFailure, + onFailureRedirection: + onFailureRedirection !== null && onFailureRedirection !== void 0 + ? onFailureRedirection + : function (_a) { + var reason = _a.reason, + userContext = _a.userContext; + return doRedirection + ? defaultOnFailureRedirection({ + reason: reason, + userContext: userContext, + }) + : undefined; + }, + } + ); + }, + } + ); } return MultiFactorAuthClaimClass; })(); @@ -303,7 +324,7 @@ function normaliseMultiFactorAuthFeature(config) { config = {}; } var disableDefaultUI = config.disableDefaultUI === true; - var override = superTokens.__assign( + var override = genericComponentOverrideContext.__assign( { functions: function (originalImplementation) { return originalImplementation; @@ -311,15 +332,21 @@ function normaliseMultiFactorAuthFeature(config) { }, config.override ); - return superTokens.__assign(superTokens.__assign({}, superTokens.normaliseRecipeModuleConfig(config)), { - disableDefaultUI: disableDefaultUI, - firstFactors: config === null || config === void 0 ? void 0 : config.firstFactors, - getSecondaryFactorInfo: function (orig) { - return orig; - }, - factorChooserScreen: (_a = config.factorChooserScreen) !== null && _a !== void 0 ? _a : {}, - override: override, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + {}, + genericComponentOverrideContext.normaliseRecipeModuleConfig(config) + ), + { + disableDefaultUI: disableDefaultUI, + firstFactors: config === null || config === void 0 ? void 0 : config.firstFactors, + getSecondaryFactorInfo: function (orig) { + return orig; + }, + factorChooserScreen: (_a = config.factorChooserScreen) !== null && _a !== void 0 ? _a : {}, + override: override, + } + ); } function getAvailableFactors(factors, nextArrayQueryParam, recipe, userContext) { // There are 3 cases here: @@ -351,7 +378,7 @@ function getAvailableFactors(factors, nextArrayQueryParam, recipe, userContext) * under the License. */ var MultiFactorAuth = /** @class */ (function (_super) { - superTokens.__extends(MultiFactorAuth, _super); + genericComponentOverrideContext.__extends(MultiFactorAuth, _super); function MultiFactorAuth(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = MultiFactorAuthWebJS__default.default; @@ -361,9 +388,9 @@ var MultiFactorAuth = /** @class */ (function (_super) { _this.recipeID = MultiFactorAuth.RECIPE_ID; _this.secondaryFactors = []; _this.getDefaultRedirectionURL = function (context, userContext) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var chooserPath, url, redirectInfo, url; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { if (context.action === "FACTOR_CHOOSER") { chooserPath = new NormalisedURLPath__default.default(DEFAULT_FACTOR_CHOOSER_PATH); url = this.config.appInfo.websiteBasePath.appendPath(chooserPath).getAsStringDangerous(); @@ -411,24 +438,27 @@ var MultiFactorAuth = /** @class */ (function (_super) { recipeID: MultiFactorAuth.RECIPE_ID, authReact: function (appInfo) { MultiFactorAuth.instance = new MultiFactorAuth( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: MultiFactorAuth.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: MultiFactorAuth.RECIPE_ID } + ) ); return MultiFactorAuth.instance; }, webJS: MultiFactorAuthWebJS__default.default.init( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - override: { - functions: function (originalImpl, builder) { - var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); - builder.override(functions); - builder.override(normalisedConfig.override.functions); - return originalImpl; + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + override: { + functions: function (originalImpl, builder) { + var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, }, - }, - }) + } + ) ), }; }; @@ -440,15 +470,15 @@ var MultiFactorAuth = /** @class */ (function (_super) { var error = "No instance of MultiFactorAuth found. Make sure to call the MultiFactorAuth.init method."; // eslint-disable-next-line supertokens-auth-react/no-direct-window-object if (typeof window === "undefined") { - error = error + superTokens.SSR_ERROR; + error = error + genericComponentOverrideContext.SSR_ERROR; } throw Error(error); } return MultiFactorAuth.instance; }; MultiFactorAuth.prototype.addMFAFactors = function (secondaryFactors) { - this.secondaryFactors = superTokens.__spreadArray( - superTokens.__spreadArray( + this.secondaryFactors = genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray( [], this.secondaryFactors.filter(function (factor) { return secondaryFactors.every(function (newFactor) { @@ -474,9 +504,9 @@ var MultiFactorAuth = /** @class */ (function (_super) { if (redirectBack === void 0) { redirectBack = false; } - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var url, redirectUrl, redirectUrl; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: return [ @@ -503,17 +533,25 @@ var MultiFactorAuth = /** @class */ (function (_super) { // and is on a custom path that has a redirectToPath set to pathX when calling this function, // then we keep that in the query params if redirectBack is set to false. if (redirectBack) { - redirectUrl = superTokens.getCurrentNormalisedUrlPathWithQueryParamsAndFragments(); - url = superTokens.appendQueryParamsToURL(url, { redirectToPath: redirectUrl }); + redirectUrl = + genericComponentOverrideContext.getCurrentNormalisedUrlPathWithQueryParamsAndFragments(); + url = genericComponentOverrideContext.appendQueryParamsToURL(url, { + redirectToPath: redirectUrl, + }); } else { - redirectUrl = superTokens.getRedirectToPathFromURL(); + redirectUrl = genericComponentOverrideContext.getRedirectToPathFromURL(); if (redirectUrl) { - url = superTokens.appendQueryParamsToURL(url, { redirectToPath: redirectUrl }); + url = genericComponentOverrideContext.appendQueryParamsToURL(url, { + redirectToPath: redirectUrl, + }); } } return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToUrl(url, navigate), + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToUrl( + url, + navigate + ), ]; } }); @@ -531,9 +569,9 @@ var MultiFactorAuth = /** @class */ (function (_super) { if (nextFactorOptions === void 0) { nextFactorOptions = []; } - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var url, redirectUrl, redirectUrl; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: return [ @@ -549,17 +587,25 @@ var MultiFactorAuth = /** @class */ (function (_super) { return [2 /*return*/]; } if (redirectBack) { - redirectUrl = superTokens.getCurrentNormalisedUrlPathWithQueryParamsAndFragments(); - url = superTokens.appendQueryParamsToURL(url, { redirectToPath: redirectUrl }); + redirectUrl = + genericComponentOverrideContext.getCurrentNormalisedUrlPathWithQueryParamsAndFragments(); + url = genericComponentOverrideContext.appendQueryParamsToURL(url, { + redirectToPath: redirectUrl, + }); } else { - redirectUrl = superTokens.getRedirectToPathFromURL(); + redirectUrl = genericComponentOverrideContext.getRedirectToPathFromURL(); if (redirectUrl) { - url = superTokens.appendQueryParamsToURL(url, { redirectToPath: redirectUrl }); + url = genericComponentOverrideContext.appendQueryParamsToURL(url, { + redirectToPath: redirectUrl, + }); } } return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToUrl(url, navigate), + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToUrl( + url, + navigate + ), ]; } }); @@ -569,7 +615,7 @@ var MultiFactorAuth = /** @class */ (function (_super) { * Tests methods. */ MultiFactorAuth.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } MultiFactorAuth.instance = undefined; @@ -583,8 +629,8 @@ var MultiFactorAuth = /** @class */ (function (_super) { return MultiFactorAuth.getInstanceOrThrow(); }, function (context, userContext) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(_a, function (_b) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(_a, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, this.getInstanceOrThrow().getRedirectUrl(context, userContext)]; diff --git a/lib/build/multifactorauth.js b/lib/build/multifactorauth.js index d797015e1..e1fc17566 100644 --- a/lib/build/multifactorauth.js +++ b/lib/build/multifactorauth.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var componentOverrideContext = require("./multifactorauth-shared3.js"); var recipe = require("./multifactorauth-shared2.js"); var types = require("./multifactorauth-shared.js"); @@ -15,7 +15,6 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); -require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("supertokens-web-js/recipe/multifactorauth"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); @@ -45,8 +44,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.resyncSessionAndFetchMFAInfo = function (input) { return recipe.MultiFactorAuth.getInstanceOrThrow().webJSRecipe.resyncSessionAndFetchMFAInfo( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) diff --git a/lib/build/multifactorauthprebuiltui.js b/lib/build/multifactorauthprebuiltui.js index 3aa6244e1..fb11e2556 100644 --- a/lib/build/multifactorauthprebuiltui.js +++ b/lib/build/multifactorauthprebuiltui.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); var uiEntry = require("./index2.js"); @@ -21,7 +21,6 @@ require("supertokens-web-js/utils"); require("supertokens-web-js/utils/normalisedURLDomain"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./oauth2provider-shared.js"); require("supertokens-web-js/recipe/oauth2provider"); require("./recipeModule-shared.js"); @@ -91,12 +90,12 @@ var FactorChooserFooter = uiEntry.withOverride("MFAFactorChooserFooter", functio var t = translationContext.useTranslation(); return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row factorChooserFooter" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: logout }, { children: [ @@ -117,12 +116,12 @@ var FactorChooserHeader = uiEntry.withOverride("MFAFactorChooserHeader", functio var t = translationContext.useTranslation(); return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row factorChooserHeader" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle withBackButton" }, { children: [ @@ -153,30 +152,33 @@ var FactorOption = uiEntry.withOverride("MFAFactorOption", function MFAFactorOpt var t = translationContext.useTranslation(); return jsxRuntime.jsxs( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "factorChooserOption ".concat(id), onClick: onClick }, { children: [ jsxRuntime.jsxs( "div", - superTokens.__assign({ "data-supertokens": "factorLogo" }, { children: [" ", logo({})] }) + genericComponentOverrideContext.__assign( + { "data-supertokens": "factorLogo" }, + { children: [" ", logo({})] } + ) ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "factorOptionText" }, { children: [ jsxRuntime.jsx( "h6", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "factorName" }, { children: t(name) } ) ), jsxRuntime.jsx( "p", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "factorDescription" }, { children: t(description) } ) @@ -196,7 +198,7 @@ var FactorList = uiEntry.withOverride("MFAFactorList", function MFAFactorList(_a navigateToFactor = _a.navigateToFactor; return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row factorChooserList" }, { children: availableFactors.map(function (factor) { @@ -229,7 +231,7 @@ function FactorChooserTheme(props) { } return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container mfa" }, { children: [ @@ -249,16 +251,16 @@ function FactorChooserTheme(props) { ); } function FactorChooserThemeWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [ @@ -267,7 +269,12 @@ function FactorChooserThemeWrapper(props) { props.config.factorChooserScreen.style, ], }, - { children: jsxRuntime.jsx(FactorChooserTheme, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + FactorChooserTheme, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ), } @@ -276,20 +283,23 @@ function FactorChooserThemeWrapper(props) { } var defaultTranslationsMultiFactorAuth = { - en: superTokens.__assign(superTokens.__assign({}, uiEntry.defaultTranslationsCommon.en), { - MULTI_FACTOR_CHOOSER_HEADER_TITLE: "Please select a factor", - MULTI_FACTOR_AUTH_LOGOUT: "Log out", - PWLESS_MFA_OTP_PHONE_NAME: "SMS based OTP", - PWLESS_MFA_OTP_PHONE_DESCRIPTION: "Get an OTP code on your phone to complete the authentication request", - PWLESS_MFA_OTP_EMAIL_NAME: "Email based OTP", - PWLESS_MFA_OTP_EMAIL_DESCRIPTION: - "Get an OTP code on your email address to complete the authentication request", - TOTP_MFA_NAME: "TOTP", - TOTP_MFA_DESCRIPTION: "Use an authenticator app to complete the authentication request", - MFA_NO_AVAILABLE_OPTIONS: "You have no available secondary factors.", - MFA_NO_AVAILABLE_OPTIONS_LOGIN: - "You have no available secondary factors and cannot complete the sign-in process. Please contact support.", - }), + en: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, uiEntry.defaultTranslationsCommon.en), + { + MULTI_FACTOR_CHOOSER_HEADER_TITLE: "Please select a factor", + MULTI_FACTOR_AUTH_LOGOUT: "Log out", + PWLESS_MFA_OTP_PHONE_NAME: "SMS based OTP", + PWLESS_MFA_OTP_PHONE_DESCRIPTION: "Get an OTP code on your phone to complete the authentication request", + PWLESS_MFA_OTP_EMAIL_NAME: "Email based OTP", + PWLESS_MFA_OTP_EMAIL_DESCRIPTION: + "Get an OTP code on your email address to complete the authentication request", + TOTP_MFA_NAME: "TOTP", + TOTP_MFA_DESCRIPTION: "Use an authenticator app to complete the authentication request", + MFA_NO_AVAILABLE_OPTIONS: "You have no available secondary factors.", + MFA_NO_AVAILABLE_OPTIONS_LOGIN: + "You have no available secondary factors and cannot complete the sign-in process. Please contact support.", + } + ), }; var FactorChooser$1 = function (props) { @@ -303,11 +313,12 @@ var FactorChooser$1 = function (props) { userContext = props.userContext; } var recipeComponentOverrides = props.useComponentOverrides(); - var nextQueryParam = (_a = superTokens.getQueryParams("n")) !== null && _a !== void 0 ? _a : undefined; + var nextQueryParam = + (_a = genericComponentOverrideContext.getQueryParams("n")) !== null && _a !== void 0 ? _a : undefined; var redirectToAuthWithHistory = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -325,8 +336,8 @@ var FactorChooser$1 = function (props) { ); var fetchMFAInfo = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, props.recipe.webJSRecipe.resyncSessionAndFetchMFAInfo({ userContext: userContext }), @@ -338,8 +349,8 @@ var FactorChooser$1 = function (props) { ); var checkMFAInfo = React.useCallback( function (mfaInfo) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { setMFAInfo({ factors: mfaInfo.factors, phoneNumbers: mfaInfo.phoneNumbers, @@ -353,8 +364,8 @@ var FactorChooser$1 = function (props) { ); var handleError = React.useCallback( function (err) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -377,7 +388,12 @@ var FactorChooser$1 = function (props) { }, [redirectToAuthWithHistory] ); - superTokens.useOnMountAPICall(fetchMFAInfo, checkMFAInfo, handleError, sessionContext.loading === false); + genericComponentOverrideContext.useOnMountAPICall( + fetchMFAInfo, + checkMFAInfo, + handleError, + sessionContext.loading === false + ); var navigateToFactor = React.useCallback( function (factorId) { props.recipe.config.onHandleEvent({ @@ -390,9 +406,9 @@ var FactorChooser$1 = function (props) { ); var signOut = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var session; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: session = types.Session.getInstanceOrThrow(); @@ -441,21 +457,24 @@ var FactorChooser$1 = function (props) { }; return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { - useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, defaultStore: defaultTranslationsMultiFactorAuth, }, { children: jsxRuntime.jsxs(React.Fragment, { children: [ props.children === undefined && - jsxRuntime.jsx(FactorChooserThemeWrapper, superTokens.__assign({}, childProps)), + jsxRuntime.jsx( + FactorChooserThemeWrapper, + genericComponentOverrideContext.__assign({}, childProps) + ), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { @@ -474,7 +493,7 @@ var FactorChooser$1 = function (props) { }; var MultiFactorAuthPreBuiltUI = /** @class */ (function (_super) { - superTokens.__extends(MultiFactorAuthPreBuiltUI, _super); + genericComponentOverrideContext.__extends(MultiFactorAuthPreBuiltUI, _super); function MultiFactorAuthPreBuiltUI(recipeInstance) { var _this = _super.call(this) || this; _this.recipeInstance = recipeInstance; @@ -490,7 +509,9 @@ var MultiFactorAuthPreBuiltUI = /** @class */ (function (_super) { new NormalisedURLPath__default.default(recipe.DEFAULT_FACTOR_CHOOSER_PATH) ); features[normalisedFullPath.getAsStringDangerous()] = { - matches: superTokens.matchRecipeIdUsingQueryParams(_this.recipeInstance.config.recipeId), + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), component: function (props) { return _this.getFeatureComponent("factorchooser", props, useComponentOverrides); }, @@ -510,12 +531,12 @@ var MultiFactorAuthPreBuiltUI = /** @class */ (function (_super) { } return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( session.SessionAuth, - superTokens.__assign( + genericComponentOverrideContext.__assign( { overrideGlobalClaimValidators: function () { return []; @@ -524,7 +545,7 @@ var MultiFactorAuthPreBuiltUI = /** @class */ (function (_super) { { children: jsxRuntime.jsx( FactorChooser$1, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipe: _this.recipeInstance, useComponentOverrides: useComponentOverrides, @@ -570,7 +591,7 @@ var MultiFactorAuthPreBuiltUI = /** @class */ (function (_super) { }; // For tests MultiFactorAuthPreBuiltUI.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } MultiFactorAuthPreBuiltUI.instance = undefined; diff --git a/lib/build/multitenancy.js b/lib/build/multitenancy.js index 7c2f0e43d..05284f52e 100644 --- a/lib/build/multitenancy.js +++ b/lib/build/multitenancy.js @@ -4,17 +4,16 @@ Object.defineProperty(exports, "__esModule", { value: true }); var MultitenancyWebJS = require("supertokens-web-js/recipe/multitenancy"); var componentOverrideContext = require("./multitenancy-shared.js"); -var superTokens = require("./superTokens.js"); -require("./genericComponentOverrideContext.js"); -require("react/jsx-runtime"); -require("react"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); require("supertokens-web-js"); require("supertokens-web-js/utils/cookieHandler"); require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); require("supertokens-web-js/utils/windowHandler"); require("supertokens-web-js/utils"); +require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); +require("react/jsx-runtime"); /* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. * @@ -33,7 +32,7 @@ require("supertokens-web-js/utils/normalisedURLPath"); var Wrapper = /** @class */ (function () { function Wrapper() {} Wrapper.init = function (config) { - return superTokens.Multitenancy.init(config); + return genericComponentOverrideContext.Multitenancy.init(config); }; Wrapper.AllowedDomainsClaim = MultitenancyWebJS.AllowedDomainsClaim; Wrapper.ComponentsOverrideProvider = componentOverrideContext.Provider; diff --git a/lib/build/oauth2provider-shared.js b/lib/build/oauth2provider-shared.js index 03b573a62..ce379f3d3 100644 --- a/lib/build/oauth2provider-shared.js +++ b/lib/build/oauth2provider-shared.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var OAuth2WebJS = require("supertokens-web-js/recipe/oauth2provider"); var index = require("./recipeModule-shared.js"); @@ -10,17 +10,55 @@ function _interopDefault(e) { var OAuth2WebJS__default = /*#__PURE__*/ _interopDefault(OAuth2WebJS); -function normaliseOAuth2Config(config) { - return superTokens.__assign(superTokens.__assign({}, superTokens.normaliseRecipeModuleConfig(config)), { - override: superTokens.__assign( - { - functions: function (originalImplementation) { - return originalImplementation; - }, +var getFunctionOverrides = function (onHandleEvent) { + return function (originalImp) { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImp), { + getLoginChallengeInfo: function (input) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + var response; + return genericComponentOverrideContext.__generator(this, function (_a) { + switch (_a.label) { + case 0: + return [4 /*yield*/, originalImp.getLoginChallengeInfo(input)]; + case 1: + response = _a.sent(); + onHandleEvent({ + action: "LOADED_LOGIN_CHALLENGE", + loginChallenge: input.loginChallenge, + loginInfo: response.info, + userContext: input.userContext, + }); + return [2 /*return*/, response]; + } + }); + }); }, - config === null || config === void 0 ? void 0 : config.override + }); + }; +}; + +function normaliseOAuth2Config(config) { + var _a; + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + {}, + genericComponentOverrideContext.normaliseRecipeModuleConfig(config) ), - }); + { + disableDefaultUI: + (_a = config === null || config === void 0 ? void 0 : config.disableDefaultUI) !== null && _a !== void 0 + ? _a + : false, + override: genericComponentOverrideContext.__assign( + { + functions: function (originalImplementation) { + return originalImplementation; + }, + }, + config === null || config === void 0 ? void 0 : config.override + ), + } + ); } /* Copyright (c) 2024, VRAI Labs and/or its affiliates. All rights reserved. @@ -41,7 +79,7 @@ function normaliseOAuth2Config(config) { * Class. */ var OAuth2Provider = /** @class */ (function (_super) { - superTokens.__extends(OAuth2Provider, _super); + genericComponentOverrideContext.__extends(OAuth2Provider, _super); function OAuth2Provider(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = OAuth2WebJS__default.default; @@ -57,14 +95,28 @@ var OAuth2Provider = /** @class */ (function (_super) { recipeID: OAuth2Provider.RECIPE_ID, authReact: function (appInfo) { OAuth2Provider.instance = new OAuth2Provider( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: OAuth2Provider.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: OAuth2Provider.RECIPE_ID } + ) ); return OAuth2Provider.instance; }, - webJS: OAuth2WebJS__default.default.init(superTokens.__assign({}, normalisedConfig)), + webJS: OAuth2WebJS__default.default.init( + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + override: { + functions: function (originalImpl, builder) { + var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, + }, + } + ) + ), }; }; OAuth2Provider.getInstanceOrThrow = function () { @@ -74,7 +126,7 @@ var OAuth2Provider = /** @class */ (function (_super) { "See https://supertokens.io/docs/oauth2/quick-setup/frontend"; // eslint-disable-next-line supertokens-auth-react/no-direct-window-object if (typeof window === "undefined") { - error = error + superTokens.SSR_ERROR; + error = error + genericComponentOverrideContext.SSR_ERROR; } throw Error(error); } @@ -84,10 +136,10 @@ var OAuth2Provider = /** @class */ (function (_super) { return OAuth2Provider.instance; }; OAuth2Provider.prototype.getDefaultRedirectionURL = function (ctx) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var domain, basePath; - return superTokens.__generator(this, function (_a) { - if (ctx.action === "SUCCESS_OAUTH2") { + return genericComponentOverrideContext.__generator(this, function (_a) { + if (ctx.action === "SUCCESS_OAUTH2" || ctx.action === "CONTINUE_OAUTH2_AFTER_REFRESH") { domain = this.config.appInfo.apiDomain.getAsStringDangerous(); basePath = this.config.appInfo.apiBasePath.getAsStringDangerous(); return [ @@ -106,7 +158,7 @@ var OAuth2Provider = /** @class */ (function (_super) { * Tests methods. */ OAuth2Provider.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } OAuth2Provider.instance = undefined; diff --git a/lib/build/oauth2provider-shared2.js b/lib/build/oauth2provider-shared2.js new file mode 100644 index 000000000..bd3b554b5 --- /dev/null +++ b/lib/build/oauth2provider-shared2.js @@ -0,0 +1,10 @@ +"use strict"; + +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); + +var _a = genericComponentOverrideContext.createGenericComponentsOverrideContext(), + useContext = _a[0], + Provider = _a[1]; + +exports.Provider = Provider; +exports.useContext = useContext; diff --git a/lib/build/oauth2provider.js b/lib/build/oauth2provider.js index 7887de699..9be189f33 100644 --- a/lib/build/oauth2provider.js +++ b/lib/build/oauth2provider.js @@ -2,8 +2,9 @@ Object.defineProperty(exports, "__esModule", { value: true }); +var componentOverrideContext = require("./oauth2provider-shared2.js"); var recipe = require("./oauth2provider-shared.js"); -require("./superTokens.js"); +require("./genericComponentOverrideContext.js"); require("supertokens-web-js"); require("supertokens-web-js/utils/cookieHandler"); require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); @@ -13,6 +14,7 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); +require("react/jsx-runtime"); require("supertokens-web-js/recipe/oauth2provider"); require("./recipeModule-shared.js"); @@ -51,11 +53,13 @@ var Wrapper = /** @class */ (function () { Wrapper.getLoginChallengeInfo = function (input) { return recipe.OAuth2Provider.getInstanceOrThrow().webJSRecipe.getLoginChallengeInfo(input); }; + Wrapper.ComponentsOverrideProvider = componentOverrideContext.Provider; return Wrapper; })(); var init = Wrapper.init; var getLoginChallengeInfo = Wrapper.getLoginChallengeInfo; +exports.RecipeComponentsOverrideContextProvider = componentOverrideContext.Provider; exports.default = Wrapper; exports.getLoginChallengeInfo = getLoginChallengeInfo; exports.init = init; diff --git a/lib/build/oauth2providerprebuiltui.js b/lib/build/oauth2providerprebuiltui.js new file mode 100644 index 000000000..c81dbc606 --- /dev/null +++ b/lib/build/oauth2providerprebuiltui.js @@ -0,0 +1,261 @@ +"use strict"; + +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); +var jsxRuntime = require("react/jsx-runtime"); +var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); +var uiEntry = require("./index2.js"); +var session = require("./session.js"); +var componentOverrideContext = require("./oauth2provider-shared2.js"); +var React = require("react"); +var recipe = require("./oauth2provider-shared.js"); +require("supertokens-web-js"); +require("supertokens-web-js/utils/cookieHandler"); +require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); +require("supertokens-web-js/utils/windowHandler"); +require("supertokens-web-js/recipe/multitenancy"); +require("supertokens-web-js/utils"); +require("supertokens-web-js/utils/normalisedURLDomain"); +require("./translationContext.js"); +require("react-dom"); +require("./multitenancy-shared.js"); +require("./multifactorauth-shared2.js"); +require("supertokens-web-js/recipe/multifactorauth"); +require("supertokens-web-js/utils/sessionClaimValidatorStore"); +require("./recipeModule-shared.js"); +require("./multifactorauth-shared.js"); +require("supertokens-web-js/recipe/session"); +require("./authRecipe-shared.js"); +require("supertokens-web-js/lib/build/normalisedURLPath"); +require("./session-shared.js"); +require("supertokens-web-js/recipe/oauth2provider"); + +function _interopDefault(e) { + return e && e.__esModule ? e : { default: e }; +} + +function _interopNamespace(e) { + if (e && e.__esModule) return e; + var n = Object.create(null); + if (e) { + Object.keys(e).forEach(function (k) { + if (k !== "default") { + var d = Object.getOwnPropertyDescriptor(e, k); + Object.defineProperty( + n, + k, + d.get + ? d + : { + enumerable: true, + get: function () { + return e[k]; + }, + } + ); + } + }); + } + n.default = e; + return Object.freeze(n); +} + +var NormalisedURLPath__default = /*#__PURE__*/ _interopDefault(NormalisedURLPath); +var React__namespace = /*#__PURE__*/ _interopNamespace(React); + +var defaultTranslationsOAuth2Provider = { + en: {}, +}; + +var TryRefreshPage$1 = function (props) { + var _a; + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); + var sessionContext = React.useContext(uiEntry.SessionContext); + var loginChallenge = + (_a = genericComponentOverrideContext.getQueryParams("loginChallenge")) !== null && _a !== void 0 + ? _a + : undefined; + var userContext = uiEntry.useUserContext(); + if (props.userContext !== undefined) { + userContext = props.userContext; + } + React__namespace.useEffect( + function () { + if (sessionContext.loading === false) { + void props.recipe + .redirect( + { + action: "CONTINUE_OAUTH2_AFTER_REFRESH", + loginChallenge: loginChallenge !== null && loginChallenge !== void 0 ? loginChallenge : "", + recipeId: "oauth2provider", + }, + props.navigate, + {}, + userContext + ) + .catch(rethrowInRender); + } + }, + [loginChallenge, props.recipe, props.navigate, userContext, sessionContext] + ); + var childProps = { + config: props.recipe.config, + }; + return jsxRuntime.jsx( + uiEntry.FeatureWrapper, + genericComponentOverrideContext.__assign( + { + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, + defaultStore: defaultTranslationsOAuth2Provider, + }, + { + children: jsxRuntime.jsxs(React.Fragment, { + children: [ + props.children === undefined && jsxRuntime.jsx(uiEntry.DynamicLoginMethodsSpinner, {}), + props.children && + React__namespace.Children.map(props.children, function (child) { + if (React__namespace.isValidElement(child)) { + return React__namespace.cloneElement(child, childProps); + } + return child; + }), + ], + }), + } + ) + ); +}; + +/* Copyright (c) 2024, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +var DEFAULT_TRY_REFRESH_PATH = "/try-refresh"; + +var OAuth2ProviderPreBuiltUI = /** @class */ (function (_super) { + genericComponentOverrideContext.__extends(OAuth2ProviderPreBuiltUI, _super); + function OAuth2ProviderPreBuiltUI(recipeInstance) { + var _this = _super.call(this) || this; + _this.recipeInstance = recipeInstance; + _this.languageTranslations = defaultTranslationsOAuth2Provider; + // Instance methods + _this.getFeatures = function (useComponentOverrides) { + if (useComponentOverrides === void 0) { + useComponentOverrides = componentOverrideContext.useContext; + } + var features = {}; + if (_this.recipeInstance.config.disableDefaultUI !== true) { + var normalisedFullPath = _this.recipeInstance.config.appInfo.websiteBasePath.appendPath( + new NormalisedURLPath__default.default(DEFAULT_TRY_REFRESH_PATH) + ); + features[normalisedFullPath.getAsStringDangerous()] = { + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), + component: function (props) { + return _this.getFeatureComponent("try-refresh-page", props, useComponentOverrides); + }, + recipeID: recipe.OAuth2Provider.RECIPE_ID, + }; + } + return features; + }; + _this.getFeatureComponent = function ( + // eslint-disable-next-line @typescript-eslint/no-unused-vars + _, + props, + useComponentOverrides + ) { + if (useComponentOverrides === void 0) { + useComponentOverrides = componentOverrideContext.useContext; + } + return jsxRuntime.jsx( + uiEntry.UserContextWrapper, + genericComponentOverrideContext.__assign( + { userContext: props.userContext }, + { + children: jsxRuntime.jsx( + session.SessionAuth, + genericComponentOverrideContext.__assign( + { + requireAuth: false, + overrideGlobalClaimValidators: function () { + return []; + }, + }, + { + children: jsxRuntime.jsx( + TryRefreshPage$1, + genericComponentOverrideContext.__assign( + { + recipe: _this.recipeInstance, + useComponentOverrides: useComponentOverrides, + }, + props + ) + ), + } + ) + ), + } + ) + ); + }; + return _this; + } + // Static methods + OAuth2ProviderPreBuiltUI.getInstanceOrInitAndGetInstance = function () { + if (OAuth2ProviderPreBuiltUI.instance === undefined) { + var recipeInstance = recipe.OAuth2Provider.getInstanceOrThrow(); + OAuth2ProviderPreBuiltUI.instance = new OAuth2ProviderPreBuiltUI(recipeInstance); + } + return OAuth2ProviderPreBuiltUI.instance; + }; + OAuth2ProviderPreBuiltUI.getFeatures = function (useComponentOverrides) { + if (useComponentOverrides === void 0) { + useComponentOverrides = componentOverrideContext.useContext; + } + return OAuth2ProviderPreBuiltUI.getInstanceOrInitAndGetInstance().getFeatures(useComponentOverrides); + }; + OAuth2ProviderPreBuiltUI.getFeatureComponent = function (componentName, props, useComponentOverrides) { + if (useComponentOverrides === void 0) { + useComponentOverrides = componentOverrideContext.useContext; + } + return OAuth2ProviderPreBuiltUI.getInstanceOrInitAndGetInstance().getFeatureComponent( + componentName, + props, + useComponentOverrides + ); + }; + OAuth2ProviderPreBuiltUI.prototype.getAuthComponents = function () { + return []; + }; + // For tests + OAuth2ProviderPreBuiltUI.reset = function () { + if (!genericComponentOverrideContext.isTest()) { + return; + } + OAuth2ProviderPreBuiltUI.instance = undefined; + return; + }; + OAuth2ProviderPreBuiltUI.TryRefreshPage = function (props) { + return OAuth2ProviderPreBuiltUI.getInstanceOrInitAndGetInstance().getFeatureComponent( + "try-refresh-page", + props + ); + }; + return OAuth2ProviderPreBuiltUI; +})(uiEntry.RecipeRouter); +var TryRefreshPage = OAuth2ProviderPreBuiltUI.TryRefreshPage; + +exports.OAuth2ProviderPreBuiltUI = OAuth2ProviderPreBuiltUI; +exports.TryRefreshPage = TryRefreshPage; diff --git a/lib/build/passwordless-shared.js b/lib/build/passwordless-shared.js index 79b224e8b..9a5e31150 100644 --- a/lib/build/passwordless-shared.js +++ b/lib/build/passwordless-shared.js @@ -1,7 +1,6 @@ "use strict"; var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); -var superTokens = require("./superTokens.js"); var PasswordlessWebJS = require("supertokens-web-js/recipe/passwordless"); var postSuperTokensInitCallbacks = require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); var jsxRuntime = require("react/jsx-runtime"); @@ -23,7 +22,7 @@ var _a = genericComponentOverrideContext.createGenericComponentsOverrideContext( var OTPEmailIcon = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "17", height: "15", viewBox: "0 0 17 15", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, { children: [ @@ -37,7 +36,7 @@ var OTPEmailIcon = function () { jsxRuntime.jsx("defs", { children: jsxRuntime.jsxs( "linearGradient", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "paint0_linear_4445_310", x1: "8.5", @@ -64,7 +63,7 @@ var OTPEmailIcon = function () { var OTPSMSIcon = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "17", height: "15", viewBox: "0 0 17 15", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, { children: [ @@ -78,7 +77,7 @@ var OTPSMSIcon = function () { jsxRuntime.jsx("defs", { children: jsxRuntime.jsxs( "linearGradient", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "paint0_linear_4445_316", x1: "8.5", @@ -104,11 +103,11 @@ var OTPSMSIcon = function () { var getFunctionOverrides = function (onHandleEvent) { return function (originalImp) { - return superTokens.__assign(superTokens.__assign({}, originalImp), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImp), { createCode: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.createCode(input)]; @@ -126,9 +125,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, resendCode: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.resendCode(input)]; @@ -150,9 +149,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, consumeCode: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var payloadBeforeCall, response, payloadAfterCall; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: _c.trys.push([0, 2, , 3]); @@ -217,17 +216,20 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, setLoginAttemptInfo: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, originalImp.setLoginAttemptInfo( - superTokens.__assign(superTokens.__assign({}, input), { - attemptInfo: superTokens.__assign( - superTokens.__assign({}, input.attemptInfo), - input.userContext.additionalAttemptInfo - ), - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { + attemptInfo: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input.attemptInfo), + input.userContext.additionalAttemptInfo + ), + } + ) ), ]; }); @@ -268,8 +270,8 @@ function defaultEmailValidator(value) { return undefined; } function userInputCodeValidate(value) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { if (typeof value !== "string") { return [2 /*return*/, "GENERAL_ERROR_OTP_NON_STRING"]; } @@ -285,8 +287,8 @@ function userInputCodeValidate(value) { */ // eslint-disable-next-line @typescript-eslint/no-unused-vars function defaultValidate(_) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, undefined]; }); }); @@ -314,7 +316,7 @@ function normalisePasswordlessConfig(config) { throw new Error("Please pass one of 'PHONE', 'EMAIL' or 'EMAIL_OR_PHONE' as the contactMethod"); } var signInUpFeature = normalizeSignInUpFeatureConfig(config.signInUpFeature, config); - var override = superTokens.__assign( + var override = genericComponentOverrideContext.__assign( { functions: function (originalImplementation) { return originalImplementation; @@ -336,15 +338,18 @@ function normalisePasswordlessConfig(config) { ) { validatePhoneNumber = config.validatePhoneNumber; } - return superTokens.__assign(superTokens.__assign({}, utils.normaliseAuthRecipe(config)), { - validateEmailAddress: validateEmailAddress, - validatePhoneNumber: validatePhoneNumber, - signInUpFeature: signInUpFeature, - linkClickedScreenFeature: normalisePasswordlessBaseConfig(config.linkClickedScreenFeature), - mfaFeature: normalisePasswordlessBaseConfig(config.mfaFeature), - contactMethod: config.contactMethod, - override: override, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, utils.normaliseAuthRecipe(config)), + { + validateEmailAddress: validateEmailAddress, + validatePhoneNumber: validatePhoneNumber, + signInUpFeature: signInUpFeature, + linkClickedScreenFeature: normalisePasswordlessBaseConfig(config.linkClickedScreenFeature), + mfaFeature: normalisePasswordlessBaseConfig(config.mfaFeature), + contactMethod: config.contactMethod, + override: override, + } + ); } function normalizeSignInUpFeatureConfig(signInUpInput, config) { if ( @@ -354,7 +359,7 @@ function normalizeSignInUpFeatureConfig(signInUpInput, config) { ) { throw new Error("Please pass a positive number as resendEmailOrSMSGapInSeconds"); } - return superTokens.__assign(superTokens.__assign({}, signInUpInput), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, signInUpInput), { resendEmailOrSMSGapInSeconds: (signInUpInput === null || signInUpInput === void 0 ? void 0 @@ -392,7 +397,9 @@ function normalizeSignInUpFeatureConfig(signInUpInput, config) { } function normalisePasswordlessBaseConfig(config) { var style = config && config.style !== undefined ? config.style : ""; - return superTokens.__assign(superTokens.__assign({}, config), { style: style }); + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, config), { + style: style, + }); } /* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. @@ -427,7 +434,7 @@ var otpEmailFactor = { * Class. */ var Passwordless = /** @class */ (function (_super) { - superTokens.__extends(Passwordless, _super); + genericComponentOverrideContext.__extends(Passwordless, _super); function Passwordless(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = PasswordlessWebJS__default.default; @@ -442,8 +449,8 @@ var Passwordless = /** @class */ (function (_super) { types.FactorIds.LINK_PHONE, ]; _this.getDefaultRedirectionURL = function (context) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, this.getAuthRecipeDefaultRedirectionURL(context)]; }); }); @@ -472,24 +479,27 @@ var Passwordless = /** @class */ (function (_super) { recipeID: Passwordless.RECIPE_ID, authReact: function (appInfo) { Passwordless.instance = new Passwordless( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: Passwordless.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: Passwordless.RECIPE_ID } + ) ); return Passwordless.instance; }, webJS: PasswordlessWebJS__default.default.init( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - override: { - functions: function (originalImpl, builder) { - var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); - builder.override(functions); - builder.override(normalisedConfig.override.functions); - return originalImpl; + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + override: { + functions: function (originalImpl, builder) { + var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, }, - }, - }) + } + ) ), }; }; @@ -500,7 +510,7 @@ var Passwordless = /** @class */ (function (_super) { "See https://supertokens.io/docs/passwordless/quick-setup/frontend"; // eslint-disable-next-line supertokens-auth-react/no-direct-window-object if (typeof window === "undefined") { - error = error + superTokens.SSR_ERROR; + error = error + genericComponentOverrideContext.SSR_ERROR; } throw Error(error); } @@ -510,7 +520,7 @@ var Passwordless = /** @class */ (function (_super) { * Tests methods. */ Passwordless.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Passwordless.instance = undefined; diff --git a/lib/build/passwordless.js b/lib/build/passwordless.js index 0892e826d..1b2c514be 100644 --- a/lib/build/passwordless.js +++ b/lib/build/passwordless.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var recipe = require("./passwordless-shared.js"); require("supertokens-web-js"); require("supertokens-web-js/utils/cookieHandler"); @@ -13,7 +13,6 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); -require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("supertokens-web-js/recipe/passwordless"); require("./authRecipe-shared2.js"); @@ -47,12 +46,12 @@ var Wrapper = /** @class */ (function () { return recipe.Passwordless.init(config); }; Wrapper.signOut = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().signOut({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -61,13 +60,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.createCode = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.createCode( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -77,13 +76,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.resendCode = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.resendCode( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -93,13 +92,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.consumeCode = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.consumeCode( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -110,8 +109,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.getLinkCodeFromURL = function (input) { return recipe.Passwordless.getInstanceOrThrow().webJSRecipe.getLinkCodeFromURL( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -119,21 +118,21 @@ var Wrapper = /** @class */ (function () { }; Wrapper.getPreAuthSessionIdFromURL = function (input) { return recipe.Passwordless.getInstanceOrThrow().webJSRecipe.getPreAuthSessionIdFromURL( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) ); }; Wrapper.doesEmailExist = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.doesEmailExist( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -141,13 +140,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.doesPhoneNumberExist = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.doesPhoneNumberExist( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -155,13 +154,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.getLoginAttemptInfo = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.getLoginAttemptInfo( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -171,13 +170,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.setLoginAttemptInfo = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.setLoginAttemptInfo( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -185,13 +184,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.clearLoginAttemptInfo = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.Passwordless.getInstanceOrThrow().webJSRecipe.clearLoginAttemptInfo( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) diff --git a/lib/build/passwordlessprebuiltui.js b/lib/build/passwordlessprebuiltui.js index b58501178..615fa049d 100644 --- a/lib/build/passwordlessprebuiltui.js +++ b/lib/build/passwordlessprebuiltui.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var React = require("react"); var jsxRuntime = require("react/jsx-runtime"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); @@ -31,7 +31,6 @@ require("supertokens-web-js/utils"); require("supertokens-web-js/utils/normalisedURLDomain"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./oauth2provider-shared.js"); require("supertokens-web-js/recipe/oauth2provider"); require("./recipeModule-shared.js"); @@ -107,7 +106,7 @@ var ThemeBase = function (_a) { var ContinueWithPasswordless = function (props) { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "continueWithPasswordlessButtonWrapper" }, { children: jsxRuntime.jsx(button.Button, { @@ -127,13 +126,18 @@ var ContinueWithPasswordlessWithOverride = uiEntry.withOverride( ContinueWithPasswordless ); var ContinueWithPasswordlessTheme = function (props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); return jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle] }, - { children: jsxRuntime.jsx(ContinueWithPasswordlessWithOverride, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + ContinueWithPasswordlessWithOverride, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ); }; @@ -142,12 +146,12 @@ var ContinueWithPasswordlessFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, { children: jsxRuntime.jsx( ContinueWithPasswordlessTheme, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { continueWithPasswordlessClicked: function () { return props.setFactorList(props.factorIds); }, @@ -166,12 +170,12 @@ var PasswordlessLinkClickedScreen = function (props) { setLoading = _a[1]; return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: @@ -180,21 +184,21 @@ var PasswordlessLinkClickedScreen = function (props) { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle" }, { children: t("PWLESS_LINK_CLICKED_CONTINUE_HEADER") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: t("PWLESS_LINK_CLICKED_CONTINUE_DESC") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "continueButtonWrapper" }, { children: jsxRuntime.jsx(button.Button, { @@ -213,7 +217,7 @@ var PasswordlessLinkClickedScreen = function (props) { }) : jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "spinner" }, { children: jsxRuntime.jsx(uiEntry.SpinnerIcon, {}) } ) @@ -230,89 +234,97 @@ var LinkClickedScreenWithOverride = uiEntry.withOverride( PasswordlessLinkClickedScreen ); var LinkClickedScreen$1 = function (props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); return jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, props.config.linkClickedScreenFeature.style], }, - { children: jsxRuntime.jsx(LinkClickedScreenWithOverride, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + LinkClickedScreenWithOverride, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ); }; var defaultTranslationsPasswordless = { - en: superTokens.__assign(superTokens.__assign({}, uiEntry.defaultTranslationsCommon.en), { - GENERAL_ERROR_EMAIL_UNDEFINED: "Please set your email", - GENERAL_ERROR_EMAIL_NON_STRING: "Email must be of type string", - GENERAL_ERROR_EMAIL_INVALID: "Email is invalid", - GENERAL_ERROR_PHONE_UNDEFINED: "Please set your phone number", - GENERAL_ERROR_PHONE_NON_STRING: "Phone number must be of type string", - GENERAL_ERROR_PHONE_INVALID: "Phone number is invalid", - GENERAL_ERROR_OTP_UNDEFINED: "Please fill your OTP", - GENERAL_ERROR_OTP_INVALID: "Invalid OTP", - GENERAL_ERROR_OTP_EXPIRED: "Expired OTP.", - GENERAL_ERROR_OTP_NON_STRING: "OTP must be of type string", - GENERAL_ERROR_OTP_EMPTY: "OTP cannot be empty", - ERROR_SIGN_IN_UP_LINK: "Invalid magic link. Please try again.", - ERROR_SIGN_IN_UP_RESEND_RESTART_FLOW: "Login timed out. Please try again.", - ERROR_SIGN_IN_UP_CODE_CONSUME_RESTART_FLOW: "Login unsuccessful. Please try again.", - PWLESS_SIGN_IN_UP_EMAIL_LABEL: "Email", - PWLESS_SIGN_IN_UP_PHONE_LABEL: "Phone Number", - PWLESS_SIGN_IN_UP_SWITCH_TO_PHONE: "Use a Phone number", - PWLESS_SIGN_IN_UP_SWITCH_TO_EMAIL: "Use an Email", - PWLESS_SIGN_IN_UP_CONTINUE_BUTTON: "CONTINUE", - PWLESS_COMBO_CONTINUE_WITH_PASSWORDLESS_LINK: "Continue with passwordless", - PWLESS_COMBO_CONTINUE_WITH_PASSWORDLESS_BUTTON: "CONTINUE WITH PASSWORDLESS", - PWLESS_COMBO_PASSWORD_LABEL: "Password", - PWLESS_COMBO_FORGOT_PW_LINK: "Forgot password?", - PWLESS_LINK_SENT_RESEND_SUCCESS: "Link resent", - PWLESS_LINK_SENT_RESEND_TITLE: "Link sent!", - PWLESS_LINK_SENT_RESEND_DESC_START_EMAIL: "We sent a link to ", - PWLESS_LINK_SENT_RESEND_DESC_START_PHONE: "We sent a link to your phone number ", - PWLESS_LINK_SENT_RESEND_DESC_END_EMAIL: " Click the link to login or sign up", - PWLESS_LINK_SENT_RESEND_DESC_END_PHONE: "", - PWLESS_SIGN_IN_UP_CHANGE_CONTACT_INFO_EMAIL: "Change email", - PWLESS_SIGN_IN_UP_CHANGE_CONTACT_INFO_PHONE: "Change phone number", - PWLESS_LINK_CLICKED_CONTINUE_HEADER: "Sign Up or Log In", - PWLESS_LINK_CLICKED_CONTINUE_DESC: "Click the button below to log in on this device", - PWLESS_LINK_CLICKED_CONTINUE_BUTTON: "CONTINUE", - PWLESS_RESEND_SUCCESS_EMAIL: "Email resent", - PWLESS_RESEND_SUCCESS_PHONE: "SMS resent", - PWLESS_RESEND_BTN_DISABLED_START: "Resend in ", - PWLESS_RESEND_BTN_DISABLED_END: "", - PWLESS_RESEND_BTN_EMAIL: "Resend Email", - PWLESS_RESEND_BTN_PHONE: "Resend SMS", - PWLESS_USER_INPUT_CODE_HEADER_TITLE: "Enter OTP", - PWLESS_USER_INPUT_CODE_HEADER_SUBTITLE: "An OTP was sent to you at", - PWLESS_USER_INPUT_CODE_HEADER_SUBTITLE_LINK: "An OTP and a magic link was sent to you at", - PWLESS_USER_INPUT_CODE_INPUT_LABEL: "OTP", - PWLESS_MFA_HEADER_TITLE_PHONE: "SMS based OTP", - PWLESS_MFA_HEADER_TITLE_EMAIL: "Email based OTP", - PWLESS_MFA_FOOTER_LOGOUT: "Logout", - /* - * The following are error messages from our backend SDK. - * These are returned as full messages to preserver compatibilty, but they work just like the keys above. - * They are shown as is by default (setting the value to undefined will display the raw translation key) - */ - "Failed to generate a one time code. Please try again": undefined, - "Phone number is invalid": undefined, - "Email is invalid": undefined, - "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_002)": - undefined, - "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_003)": - undefined, - "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_017)": undefined, - "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_018)": undefined, - "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_019)": undefined, - }), + en: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, uiEntry.defaultTranslationsCommon.en), + { + GENERAL_ERROR_EMAIL_UNDEFINED: "Please set your email", + GENERAL_ERROR_EMAIL_NON_STRING: "Email must be of type string", + GENERAL_ERROR_EMAIL_INVALID: "Email is invalid", + GENERAL_ERROR_PHONE_UNDEFINED: "Please set your phone number", + GENERAL_ERROR_PHONE_NON_STRING: "Phone number must be of type string", + GENERAL_ERROR_PHONE_INVALID: "Phone number is invalid", + GENERAL_ERROR_OTP_UNDEFINED: "Please fill your OTP", + GENERAL_ERROR_OTP_INVALID: "Invalid OTP", + GENERAL_ERROR_OTP_EXPIRED: "Expired OTP.", + GENERAL_ERROR_OTP_NON_STRING: "OTP must be of type string", + GENERAL_ERROR_OTP_EMPTY: "OTP cannot be empty", + ERROR_SIGN_IN_UP_LINK: "Invalid magic link. Please try again.", + ERROR_SIGN_IN_UP_RESEND_RESTART_FLOW: "Login timed out. Please try again.", + ERROR_SIGN_IN_UP_CODE_CONSUME_RESTART_FLOW: "Login unsuccessful. Please try again.", + PWLESS_SIGN_IN_UP_EMAIL_LABEL: "Email", + PWLESS_SIGN_IN_UP_PHONE_LABEL: "Phone Number", + PWLESS_SIGN_IN_UP_SWITCH_TO_PHONE: "Use a Phone number", + PWLESS_SIGN_IN_UP_SWITCH_TO_EMAIL: "Use an Email", + PWLESS_SIGN_IN_UP_CONTINUE_BUTTON: "CONTINUE", + PWLESS_COMBO_CONTINUE_WITH_PASSWORDLESS_LINK: "Continue with passwordless", + PWLESS_COMBO_CONTINUE_WITH_PASSWORDLESS_BUTTON: "CONTINUE WITH PASSWORDLESS", + PWLESS_COMBO_PASSWORD_LABEL: "Password", + PWLESS_COMBO_FORGOT_PW_LINK: "Forgot password?", + PWLESS_LINK_SENT_RESEND_SUCCESS: "Link resent", + PWLESS_LINK_SENT_RESEND_TITLE: "Link sent!", + PWLESS_LINK_SENT_RESEND_DESC_START_EMAIL: "We sent a link to ", + PWLESS_LINK_SENT_RESEND_DESC_START_PHONE: "We sent a link to your phone number ", + PWLESS_LINK_SENT_RESEND_DESC_END_EMAIL: " Click the link to login or sign up", + PWLESS_LINK_SENT_RESEND_DESC_END_PHONE: "", + PWLESS_SIGN_IN_UP_CHANGE_CONTACT_INFO_EMAIL: "Change email", + PWLESS_SIGN_IN_UP_CHANGE_CONTACT_INFO_PHONE: "Change phone number", + PWLESS_LINK_CLICKED_CONTINUE_HEADER: "Sign Up or Log In", + PWLESS_LINK_CLICKED_CONTINUE_DESC: "Click the button below to log in on this device", + PWLESS_LINK_CLICKED_CONTINUE_BUTTON: "CONTINUE", + PWLESS_RESEND_SUCCESS_EMAIL: "Email resent", + PWLESS_RESEND_SUCCESS_PHONE: "SMS resent", + PWLESS_RESEND_BTN_DISABLED_START: "Resend in ", + PWLESS_RESEND_BTN_DISABLED_END: "", + PWLESS_RESEND_BTN_EMAIL: "Resend Email", + PWLESS_RESEND_BTN_PHONE: "Resend SMS", + PWLESS_USER_INPUT_CODE_HEADER_TITLE: "Enter OTP", + PWLESS_USER_INPUT_CODE_HEADER_SUBTITLE: "An OTP was sent to you at", + PWLESS_USER_INPUT_CODE_HEADER_SUBTITLE_LINK: "An OTP and a magic link was sent to you at", + PWLESS_USER_INPUT_CODE_INPUT_LABEL: "OTP", + PWLESS_MFA_HEADER_TITLE_PHONE: "SMS based OTP", + PWLESS_MFA_HEADER_TITLE_EMAIL: "Email based OTP", + PWLESS_MFA_FOOTER_LOGOUT: "Logout", + /* + * The following are error messages from our backend SDK. + * These are returned as full messages to preserver compatibilty, but they work just like the keys above. + * They are shown as is by default (setting the value to undefined will display the raw translation key) + */ + "Failed to generate a one time code. Please try again": undefined, + "Phone number is invalid": undefined, + "Email is invalid": undefined, + "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_002)": + undefined, + "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_003)": + undefined, + "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_017)": undefined, + "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_018)": undefined, + "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_019)": undefined, + } + ), }; var LinkClickedScreen = function (props) { - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var userContext = uiEntry.useUserContext(); if (props.userContext !== undefined) { userContext = props.userContext; @@ -322,19 +334,19 @@ var LinkClickedScreen = function (props) { setRequireUserInteraction = _a[1]; var consumeCodeAtMount = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var preAuthSessionId, linkCode, loginAttemptInfo, payloadBeforeCall; var _b; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: - preAuthSessionId = superTokens.getQueryParams("preAuthSessionId"); - linkCode = superTokens.getURLHash(); + preAuthSessionId = genericComponentOverrideContext.getQueryParams("preAuthSessionId"); + linkCode = genericComponentOverrideContext.getURLHash(); if (!(preAuthSessionId === null || preAuthSessionId.length === 0 || linkCode.length === 0)) return [3 /*break*/, 2]; return [ 4 /*yield*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: "signin", @@ -397,9 +409,9 @@ var LinkClickedScreen = function (props) { ); var handleConsumeResp = React.useCallback( function (consumeRes) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var response, payloadBeforeCall, payloadAfterCall, loginAttemptInfo; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if (consumeRes === "REQUIRES_INTERACTION") { @@ -414,7 +426,7 @@ var LinkClickedScreen = function (props) { if (response.status === "RESTART_FLOW_ERROR") { return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: "restart_link", @@ -427,7 +439,7 @@ var LinkClickedScreen = function (props) { if (response.status === "SIGN_IN_UP_NOT_ALLOWED") { return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: response.reason, @@ -508,7 +520,7 @@ var LinkClickedScreen = function (props) { var handleConsumeError = React.useCallback( function (err) { if (STGeneralError__default.default.isThisError(err)) { - return superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + return genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: "custom", @@ -518,7 +530,7 @@ var LinkClickedScreen = function (props) { userContext: userContext, }); } else { - return superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + return genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: "signin", @@ -530,16 +542,16 @@ var LinkClickedScreen = function (props) { }, [props.navigate, userContext] ); - superTokens.useOnMountAPICall(consumeCodeAtMount, handleConsumeResp, handleConsumeError); + genericComponentOverrideContext.useOnMountAPICall(consumeCodeAtMount, handleConsumeResp, handleConsumeError); var recipeComponentOverrides = props.useComponentOverrides(); var childProps = { recipeImplementation: props.recipe.webJSRecipe, config: props.recipe.config, requireUserInteraction: requireUserInteraction, consumeCode: function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var payloadBeforeCall, consumeResp, err_1; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: _b.trys.push([0, 7, , 8]); @@ -590,21 +602,24 @@ var LinkClickedScreen = function (props) { }; return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { - useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, defaultStore: defaultTranslationsPasswordless, }, { children: jsxRuntime.jsxs(React.Fragment, { children: [ props.children === undefined && - jsxRuntime.jsx(LinkClickedScreen$1, superTokens.__assign({}, childProps)), + jsxRuntime.jsx( + LinkClickedScreen$1, + genericComponentOverrideContext.__assign({}, childProps) + ), props.children && React__namespace.default.Children.map(props.children, function (child) { if (React__namespace.default.isValidElement(child)) { @@ -645,29 +660,29 @@ var LinkClickedScreen = function (props) { function SMSLargeIcon() { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "52.013", height: "41.889", viewBox: "0 0 52.013 41.889" }, { children: jsxRuntime.jsx( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "Group_10400", "data-name": "Group 10400", transform: "translate(-724.625 -241.125)" }, { children: jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "Group_10399", "data-name": "Group 10399" }, { children: [ jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "Group_10398", "data-name": "Group 10398" }, { children: [ jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "_2639922_sms_icon", "data-name": "2639922_sms_icon", @@ -717,7 +732,7 @@ function SMSLargeIcon() { ), jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "_2639922_sms_icon-2", "data-name": "2639922_sms_icon", @@ -749,7 +764,7 @@ function SMSLargeIcon() { ), jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "Group_10397", "data-name": "Group 10397" }, { children: [ @@ -779,7 +794,7 @@ function SMSLargeIcon() { ), jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "Group_10396", "data-name": "Group 10396" }, { children: [ @@ -816,7 +831,7 @@ function SMSLargeIcon() { }), jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "Group_10395", "data-name": "Group 10395" }, { children: [ @@ -890,7 +905,7 @@ var ResendButton = uiEntry.withOverride("PasswordlessResendButton", function Pas ); return jsxRuntime.jsx( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { type: "button", disabled: secsUntilResend !== undefined, @@ -941,9 +956,9 @@ var PasswordlessLinkSent = function (props) { }, []); var resendEmail = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var response, generalError, e_1; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 5, , 6]); @@ -1001,12 +1016,12 @@ var PasswordlessLinkSent = function (props) { var resendActive = status === "LINK_RESENT"; return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ @@ -1017,14 +1032,14 @@ var PasswordlessLinkSent = function (props) { resendActive && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "generalSuccess" }, { children: t("PWLESS_LINK_SENT_RESEND_SUCCESS") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "sendCodeIcon" }, { children: @@ -1036,14 +1051,14 @@ var PasswordlessLinkSent = function (props) { ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle headerTinyTitle" }, { children: t("PWLESS_LINK_SENT_RESEND_TITLE") } ) ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "primaryText sendCodeText" }, { children: [ @@ -1068,7 +1083,7 @@ var PasswordlessLinkSent = function (props) { }), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: function () { @@ -1099,22 +1114,22 @@ var PasswordlessLinkSent = function (props) { }; var LinkSent = uiEntry.withOverride("PasswordlessLinkSent", PasswordlessLinkSent); function LinkSentWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeStyle = props.config.signInUpFeature.linkSentScreenStyle; return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, activeStyle], }, - { children: jsxRuntime.jsx(LinkSent, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(LinkSent, genericComponentOverrideContext.__assign({}, props)) } ) ), } @@ -1140,15 +1155,15 @@ function useChildProps$4( }, [recipe$1, onError, rebuildAuthPage] ); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); return React.useMemo( function () { return { userContext: userContext, onSuccess: function (result) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var payloadAfterCall; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: _b.trys.push([0, 2, , 3]); @@ -1185,7 +1200,7 @@ function useChildProps$4( recipeId: recipe$1.recipeID, }, recipe$1.recipeID, - superTokens.getRedirectToPathFromURL(), + genericComponentOverrideContext.getRedirectToPathFromURL(), userContext, navigate ) @@ -1196,9 +1211,9 @@ function useChildProps$4( }); }, onFetchError: function (err) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -1278,12 +1293,15 @@ var LinkSentFeatureInner = function (props) { props.children === undefined && jsxRuntime.jsx( LinkSentWrapper, - superTokens.__assign({}, childProps, { userContext: props.userContext }) + genericComponentOverrideContext.__assign({}, childProps, { userContext: props.userContext }) ), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { - return React__namespace.cloneElement(child, superTokens.__assign({}, childProps)); + return React__namespace.cloneElement( + child, + genericComponentOverrideContext.__assign({}, childProps) + ); } return child; }), @@ -1294,20 +1312,20 @@ var LinkSentFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, - { children: jsxRuntime.jsx(LinkSentFeatureInner, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(LinkSentFeatureInner, genericComponentOverrideContext.__assign({}, props)) } ) ); }; function getModifiedRecipeImplementation$4(originalImpl, setError, rebuildAuthPage) { var _this = this; - return superTokens.__assign(superTokens.__assign({}, originalImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImpl), { resendCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res, loginAttemptInfo, timestamp; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, originalImpl.resendCode(input)]; @@ -1328,13 +1346,17 @@ function getModifiedRecipeImplementation$4(originalImpl, setError, rebuildAuthPa 4 /*yield*/, originalImpl.setLoginAttemptInfo({ userContext: input.userContext, - attemptInfo: superTokens.__assign(superTokens.__assign({}, loginAttemptInfo), { - tryLinkingWithSessionUser: - (_a = loginAttemptInfo.tryLinkingWithSessionUser) !== null && _a !== void 0 - ? _a - : false, - lastResend: timestamp, - }), + attemptInfo: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, loginAttemptInfo), + { + tryLinkingWithSessionUser: + (_a = loginAttemptInfo.tryLinkingWithSessionUser) !== null && + _a !== void 0 + ? _a + : false, + lastResend: timestamp, + } + ), }), ]; case 3: @@ -1362,9 +1384,9 @@ function getModifiedRecipeImplementation$4(originalImpl, setError, rebuildAuthPa }); }, consumeCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImpl.consumeCode(input)]; @@ -1413,8 +1435,8 @@ function getModifiedRecipeImplementation$4(originalImpl, setError, rebuildAuthPa }); }, clearLoginAttemptInfo: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -1425,7 +1447,7 @@ function getModifiedRecipeImplementation$4(originalImpl, setError, rebuildAuthPa ]; case 1: _a.sent(); - superTokens.clearErrorQueryParam(); + genericComponentOverrideContext.clearErrorQueryParam(); rebuildAuthPage(); return [2 /*return*/]; } @@ -1437,9 +1459,9 @@ function getModifiedRecipeImplementation$4(originalImpl, setError, rebuildAuthPa var phoneNumberUtilsImport; function getPhoneNumberUtils() { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var global; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, preloadPhoneNumberUtils()]; @@ -1466,9 +1488,9 @@ function preloadPhoneNumberUtils() { // This was moved to a separate file to make tree-shaking more effective, since we do not want to include the phoneNumberUtils // in the base pwless recipe because it increases the bundle size by a lot function defaultPhoneNumberValidator(value) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var intlTelInputUtils; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: if (typeof value !== "string") { @@ -1509,10 +1531,10 @@ var EmailForm = uiEntry.withOverride("PasswordlessEmailForm", function Passwordl buttonLabel: "PWLESS_SIGN_IN_UP_CONTINUE_BUTTON", onSuccess: props.onSuccess, callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var email, validationRes, response; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: email = @@ -3542,7 +3564,7 @@ function PhoneNumberInput(_a) { // if it detects a mobile environment, but this doesn't work with our styling if we use shadow dom var anyIti = itiRef; if (anyIti.isMobile) { - var root = document.getElementById(superTokens.ST_ROOT_ID); + var root = document.getElementById(genericComponentOverrideContext.ST_ROOT_ID); // We only have to do this if we are using shadowDom and we need access to the dom element anyway // so passing the shadowroot element here would be both impractical and not too useful if (root === null || root === void 0 ? void 0 : root.shadowRoot) { @@ -3564,13 +3586,13 @@ function PhoneNumberInput(_a) { */ return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "inputContainer" }, { children: [ jsxRuntime.jsxs( "style", - superTokens.__assign( + genericComponentOverrideContext.__assign( { type: "text/css" }, { children: [ @@ -3582,7 +3604,7 @@ function PhoneNumberInput(_a) { ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "phoneInputWrapper inputWrapper ".concat( hasError ? "inputError" : "" @@ -3614,7 +3636,7 @@ function PhoneNumberInput(_a) { hasError === true && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "inputAdornment inputAdornmentError" }, { children: jsxRuntime.jsx(formBase.ErrorIcon, {}) } ) @@ -3632,7 +3654,7 @@ function PhoneNumberInput(_a) { // TODO: type props var phoneNumberInputWithInjectedProps = function (injectedProps) { return function (props) { - return jsxRuntime.jsx(PhoneNumberInput, superTokens.__assign({}, injectedProps, props)); + return jsxRuntime.jsx(PhoneNumberInput, genericComponentOverrideContext.__assign({}, injectedProps, props)); }; }; @@ -3670,10 +3692,10 @@ var PhoneForm = uiEntry.withOverride("PasswordlessPhoneForm", function Passwordl buttonLabel: "PWLESS_SIGN_IN_UP_CONTINUE_BUTTON", onSuccess: props.onSuccess, callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var phoneNumber, validationRes, response; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: phoneNumber = @@ -3725,7 +3747,7 @@ var UserInputCodeFormFooter = uiEntry.withOverride( return jsxRuntime.jsx(React.Fragment, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: function () { @@ -3757,14 +3779,14 @@ var UserInputCodeFormHeader = uiEntry.withOverride( children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle" }, { children: t("PWLESS_USER_INPUT_CODE_HEADER_TITLE") } ) ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: [ @@ -3786,20 +3808,26 @@ var UserInputCodeFormHeader = uiEntry.withOverride( var UserInputCodeFormScreen = function (props) { return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ - jsxRuntime.jsx(UserInputCodeFormHeader, superTokens.__assign({}, props)), + jsxRuntime.jsx( + UserInputCodeFormHeader, + genericComponentOverrideContext.__assign({}, props) + ), props.error !== undefined && jsxRuntime.jsx(uiEntry.GeneralError, { error: props.error }), - jsxRuntime.jsx(UserInputCodeForm, superTokens.__assign({}, props)), + jsxRuntime.jsx( + UserInputCodeForm, + genericComponentOverrideContext.__assign({}, props) + ), ], } ) @@ -3829,9 +3857,9 @@ var UserInputCodeForm = uiEntry.withOverride("PasswordlessUserInputCodeForm", fu ); var resend = React.useCallback( function resend() { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response, generalError, e_1; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 5, , 6]); @@ -3890,7 +3918,7 @@ var UserInputCodeForm = uiEntry.withOverride("PasswordlessUserInputCodeForm", fu clearResendNotifTimeout !== undefined && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "generalSuccess" }, { children: @@ -3910,7 +3938,7 @@ var UserInputCodeForm = uiEntry.withOverride("PasswordlessUserInputCodeForm", fu label: "", labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ @@ -3939,10 +3967,10 @@ var UserInputCodeForm = uiEntry.withOverride("PasswordlessUserInputCodeForm", fu onSuccess: props.onSuccess, buttonLabel: "PWLESS_SIGN_IN_UP_CONTINUE_BUTTON", callAPI: function (formFields) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var userInputCode, response; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: userInputCode = @@ -3990,29 +4018,36 @@ var UserInputCodeForm = uiEntry.withOverride("PasswordlessUserInputCodeForm", fu ? _a : jsxRuntime.jsx( UserInputCodeFormFooter, - superTokens.__assign({}, props, { loginAttemptInfo: props.loginAttemptInfo }) + genericComponentOverrideContext.__assign({}, props, { + loginAttemptInfo: props.loginAttemptInfo, + }) ), }), ], }); }); function UserInputCodeFormScreenWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeStyle = props.config.signInUpFeature.userInputCodeFormStyle; return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, activeStyle], }, - { children: jsxRuntime.jsx(UserInputCodeFormScreen, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + UserInputCodeFormScreen, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ), } @@ -4023,17 +4058,17 @@ function UserInputCodeFormScreenWrapper(props) { var OTPLoadingScreen = function () { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container delayedRender pwless-mfa loadingScreen" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "spinner delayedRender" }, { children: jsxRuntime.jsx(uiEntry.SpinnerIcon, {}) } ) @@ -4051,12 +4086,12 @@ var MFAFooter = uiEntry.withOverride("PasswordlessMFAFooter", function Passwordl var t = translationContext.useTranslation(); return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "footerLinkGroupVert pwless-mfa footer" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: props.onSignOutClicked, @@ -4082,7 +4117,7 @@ var MFAHeader = uiEntry.withOverride("PasswordlessMFAHeader", function Passwordl children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle withBackButton pwless-mfa header" }, { children: [ @@ -4113,14 +4148,14 @@ var MFAOTPFooter = uiEntry.withOverride("PasswordlessMFAOTPFooter", function Pas var userContext = uiEntry.useUserContext(); return jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "footerLinkGroupVert pwless-mfa otpFooter" }, { children: [ canChangeEmail && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText", onClick: function () { @@ -4139,7 +4174,7 @@ var MFAOTPFooter = uiEntry.withOverride("PasswordlessMFAOTPFooter", function Pas ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: onSignOutClicked, @@ -4170,7 +4205,7 @@ var MFAOTPHeader = uiEntry.withOverride("PasswordlessMFAOTPHeader", function Pas children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle withBackButton pwless-mfa otpHeader" }, { children: [ @@ -4187,7 +4222,7 @@ var MFAOTPHeader = uiEntry.withOverride("PasswordlessMFAOTPHeader", function Pas ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: [ @@ -4217,7 +4252,7 @@ var MFATheme = function (_a) { var activeScreen = _a.activeScreen, featureState = _a.featureState, onBackButtonClicked = _a.onBackButtonClicked, - props = superTokens.__rest(_a, ["activeScreen", "featureState", "onBackButtonClicked"]); + props = genericComponentOverrideContext.__rest(_a, ["activeScreen", "featureState", "onBackButtonClicked"]); var t = translationContext.useTranslation(); var commonProps = { recipeImplementation: props.recipeImplementation, @@ -4242,13 +4277,13 @@ var MFATheme = function (_a) { }) : jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container pwless-mfa" }, { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: jsxRuntime.jsxs(React__namespace.default.Fragment, { @@ -4256,7 +4291,7 @@ var MFATheme = function (_a) { activeScreen === MFAScreens.UserInputCodeForm ? jsxRuntime.jsx( MFAOTPHeader, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { showBackButton: featureState.showBackButton, loginAttemptInfo: featureState.loginAttemptInfo, canChangeEmail: featureState.canChangeEmail, @@ -4265,7 +4300,7 @@ var MFATheme = function (_a) { ) : jsxRuntime.jsx( MFAHeader, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { showBackButton: featureState.showBackButton, onBackButtonClicked: onBackButtonClicked, contactMethod: @@ -4279,42 +4314,54 @@ var MFATheme = function (_a) { activeScreen === MFAScreens.EmailForm ? jsxRuntime.jsx( EmailForm, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { footer: jsxRuntime.jsx( MFAFooter, - superTokens.__assign({}, commonProps, { - onSignOutClicked: props.onSignOutClicked, - canChangeEmail: featureState.canChangeEmail, - }) + genericComponentOverrideContext.__assign( + {}, + commonProps, + { + onSignOutClicked: props.onSignOutClicked, + canChangeEmail: featureState.canChangeEmail, + } + ) ), }) ) : activeScreen === MFAScreens.PhoneForm ? jsxRuntime.jsx( PhoneForm, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { footer: jsxRuntime.jsx( MFAFooter, - superTokens.__assign({}, commonProps, { - onSignOutClicked: props.onSignOutClicked, - canChangeEmail: featureState.canChangeEmail, - }) + genericComponentOverrideContext.__assign( + {}, + commonProps, + { + onSignOutClicked: props.onSignOutClicked, + canChangeEmail: featureState.canChangeEmail, + } + ) ), }) ) : activeScreen === MFAScreens.UserInputCodeForm ? jsxRuntime.jsx( UserInputCodeForm, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { loginAttemptInfo: featureState.loginAttemptInfo, onSuccess: props.onSuccess, footer: jsxRuntime.jsx( MFAOTPFooter, - superTokens.__assign({}, commonProps, { - onSignOutClicked: props.onSignOutClicked, - canChangeEmail: featureState.canChangeEmail, - loginAttemptInfo: featureState.loginAttemptInfo, - }) + genericComponentOverrideContext.__assign( + {}, + commonProps, + { + onSignOutClicked: props.onSignOutClicked, + canChangeEmail: featureState.canChangeEmail, + loginAttemptInfo: featureState.loginAttemptInfo, + } + ) ), }) ) @@ -4331,7 +4378,7 @@ var MFATheme = function (_a) { ); }; function MFAThemeWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeScreen = getActiveScreen$2(props); var activeStyle; @@ -4346,12 +4393,12 @@ function MFAThemeWrapper(props) { } return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [ @@ -4364,7 +4411,7 @@ function MFAThemeWrapper(props) { { children: jsxRuntime.jsx( MFATheme, - superTokens.__assign({}, props, { activeScreen: activeScreen }) + genericComponentOverrideContext.__assign({}, props, { activeScreen: activeScreen }) ), } ) @@ -4404,30 +4451,31 @@ var useFeatureReducer = function () { if (!oldState.loginAttemptInfo) { return oldState; } - return superTokens.__assign(superTokens.__assign({}, oldState), { - error: undefined, - loginAttemptInfo: superTokens.__assign(superTokens.__assign({}, oldState.loginAttemptInfo), { - lastResend: action.timestamp, - }), - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { + error: undefined, + loginAttemptInfo: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState.loginAttemptInfo), + { lastResend: action.timestamp } + ), + } + ); case "restartFlow": - return superTokens.__assign(superTokens.__assign({}, oldState), { - error: action.error, - loginAttemptInfo: undefined, - showAccessDenied: !oldState.canChangeEmail, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { error: action.error, loginAttemptInfo: undefined, showAccessDenied: !oldState.canChangeEmail } + ); case "setError": - return superTokens.__assign(superTokens.__assign({}, oldState), { - loaded: true, - error: action.error, - showAccessDenied: action.showAccessDenied, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { loaded: true, error: action.error, showAccessDenied: action.showAccessDenied } + ); case "startVerify": - return superTokens.__assign(superTokens.__assign({}, oldState), { - loaded: true, - loginAttemptInfo: action.loginAttemptInfo, - error: undefined, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { loaded: true, loginAttemptInfo: action.loginAttemptInfo, error: undefined } + ); default: return oldState; } @@ -4442,23 +4490,25 @@ var useFeatureReducer = function () { }, function (initArg) { var error = undefined; - var errorQueryParam = superTokens.getQueryParams("error"); + var errorQueryParam = genericComponentOverrideContext.getQueryParams("error"); if (errorQueryParam !== null) { error = "SOMETHING_WENT_WRONG_ERROR"; } - return superTokens.__assign(superTokens.__assign({}, initArg), { error: error }); + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, initArg), { + error: error, + }); } ); }; function useChildProps$3(recipe$1, recipeImplementation, state, contactMethod, dispatch, userContext, navigate) { var _this = this; - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); return React.useMemo( function () { var _a; return { onSuccess: function () { - var redirectToPath = superTokens.getRedirectToPathFromURL(); + var redirectToPath = genericComponentOverrideContext.getRedirectToPathFromURL(); return types.Session.getInstanceOrThrow() .validateGlobalClaimsAndHandleSuccessRedirection( undefined, @@ -4470,8 +4520,8 @@ function useChildProps$3(recipe$1, recipeImplementation, state, contactMethod, d .catch(rethrowInRender); }, onSignOutClicked: function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -4498,8 +4548,8 @@ function useChildProps$3(recipe$1, recipeImplementation, state, contactMethod, d }); }, onBackButtonClicked: function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: if (!state.loginAttemptInfo) return [3 /*break*/, 2]; @@ -4531,9 +4581,9 @@ function useChildProps$3(recipe$1, recipeImplementation, state, contactMethod, d }); }, onFetchError: function (err) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -4631,17 +4681,20 @@ var MFAFeatureInner = function (props) { props.children === undefined && jsxRuntime.jsx( MFAThemeWrapper, - superTokens.__assign({}, childProps, { featureState: state, dispatch: dispatch }) + genericComponentOverrideContext.__assign({}, childProps, { + featureState: state, + dispatch: dispatch, + }) ), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { return React__namespace.cloneElement( child, - superTokens.__assign(superTokens.__assign({}, childProps), { - featureState: state, - dispatch: dispatch, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, childProps), + { featureState: state, dispatch: dispatch } + ) ); } return child; @@ -4653,17 +4706,22 @@ var MFAFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { - useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, defaultStore: defaultTranslationsPasswordless, }, - { children: jsxRuntime.jsx(MFAFeatureInner, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + MFAFeatureInner, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ), } @@ -4674,8 +4732,8 @@ function useOnLoad(props, recipeImplementation, dispatch, userContext) { var _this = this; var fetchMFAInfo = React__namespace.useCallback( function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe$3.MultiFactorAuth.getInstanceOrThrow().webJSRecipe.resyncSessionAndFetchMFAInfo({ @@ -4695,7 +4753,7 @@ function useOnLoad(props, recipeImplementation, dispatch, userContext) { ); var onLoad = React__namespace.useCallback( function (mfaInfo) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var error, errorQueryParam, doSetup, @@ -4708,12 +4766,12 @@ function useOnLoad(props, recipeImplementation, dispatch, userContext) { err_1, invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: error = undefined; - errorQueryParam = superTokens.getQueryParams("error"); - doSetup = superTokens.getQueryParams("setup"); + errorQueryParam = genericComponentOverrideContext.getQueryParams("error"); + doSetup = genericComponentOverrideContext.getQueryParams("setup"); if (errorQueryParam !== null) { error = "SOMETHING_WENT_WRONG_ERROR"; } @@ -4774,10 +4832,10 @@ function useOnLoad(props, recipeImplementation, dispatch, userContext) { return [ 4 /*yield*/, recipeImplementation.createCode( - superTokens.__assign(superTokens.__assign({}, createCodeInfo), { - tryLinkingWithSessionUser: true, - userContext: userContext, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, createCodeInfo), + { tryLinkingWithSessionUser: true, userContext: userContext } + ) ), ]; case 5: @@ -4880,15 +4938,15 @@ function useOnLoad(props, recipeImplementation, dispatch, userContext) { }, [dispatch, recipeImplementation, props.contactMethod, userContext] ); - superTokens.useOnMountAPICall(fetchMFAInfo, onLoad, handleLoadError); + genericComponentOverrideContext.useOnMountAPICall(fetchMFAInfo, onLoad, handleLoadError); } function getModifiedRecipeImplementation$3(originalImpl, config, dispatch) { var _this = this; - return superTokens.__assign(superTokens.__assign({}, originalImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImpl), { createCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var contactInfo, phoneNumberUtils, contactMethod, additionalAttemptInfo, res, loginAttemptInfo; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, getPhoneNumberUtils()]; @@ -4908,17 +4966,21 @@ function getModifiedRecipeImplementation$3(originalImpl, config, dispatch) { lastResend: Date.now(), contactMethod: contactMethod, contactInfo: contactInfo, - redirectToPath: superTokens.getRedirectToPathFromURL(), + redirectToPath: genericComponentOverrideContext.getRedirectToPathFromURL(), }; return [ 4 /*yield*/, originalImpl.createCode( - superTokens.__assign(superTokens.__assign({}, input), { - tryLinkingWithSessionUser: true, - userContext: superTokens.__assign(superTokens.__assign({}, input.userContext), { - additionalAttemptInfo: additionalAttemptInfo, - }), - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { + tryLinkingWithSessionUser: true, + userContext: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input.userContext), + { additionalAttemptInfo: additionalAttemptInfo } + ), + } + ) ), ]; case 2: @@ -4941,10 +5003,10 @@ function getModifiedRecipeImplementation$3(originalImpl, config, dispatch) { }); }, resendCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res, loginAttemptInfo, timestamp; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, originalImpl.resendCode(input)]; @@ -4965,13 +5027,17 @@ function getModifiedRecipeImplementation$3(originalImpl, config, dispatch) { 4 /*yield*/, originalImpl.setLoginAttemptInfo({ userContext: input.userContext, - attemptInfo: superTokens.__assign(superTokens.__assign({}, loginAttemptInfo), { - tryLinkingWithSessionUser: - (_a = loginAttemptInfo.tryLinkingWithSessionUser) !== null && _a !== void 0 - ? _a - : true, - lastResend: timestamp, - }), + attemptInfo: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, loginAttemptInfo), + { + tryLinkingWithSessionUser: + (_a = loginAttemptInfo.tryLinkingWithSessionUser) !== null && + _a !== void 0 + ? _a + : true, + lastResend: timestamp, + } + ), }), ]; case 3: @@ -4999,9 +5065,9 @@ function getModifiedRecipeImplementation$3(originalImpl, config, dispatch) { }); }, consumeCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImpl.consumeCode(input)]; @@ -5052,8 +5118,8 @@ function getModifiedRecipeImplementation$3(originalImpl, config, dispatch) { }); }, clearLoginAttemptInfo: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -5064,7 +5130,7 @@ function getModifiedRecipeImplementation$3(originalImpl, config, dispatch) { ]; case 1: _a.sent(); - superTokens.clearErrorQueryParam(); + genericComponentOverrideContext.clearErrorQueryParam(); dispatch({ type: "restartFlow", error: undefined }); return [2 /*return*/]; } @@ -5106,14 +5172,14 @@ var EmailOrPhoneForm = uiEntry.withOverride( label: "", labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ jsxRuntime.jsx(formBase.Label, { value: "PWLESS_SIGN_IN_UP_PHONE_LABEL" }), jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return setIsPhoneNumber(false); @@ -5142,7 +5208,7 @@ var EmailOrPhoneForm = uiEntry.withOverride( label: "", labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ @@ -5152,7 +5218,7 @@ var EmailOrPhoneForm = uiEntry.withOverride( }), jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return setIsPhoneNumber(function (v) { @@ -5180,10 +5246,10 @@ var EmailOrPhoneForm = uiEntry.withOverride( buttonLabel: "PWLESS_SIGN_IN_UP_CONTINUE_BUTTON", onSuccess: props.onSuccess, callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var contactInfo, phoneNumber, validationRes, email, validationRes, response; var _a, _b; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: if (!isPhoneNumber) return [3 /*break*/, 2]; @@ -5226,10 +5292,13 @@ var EmailOrPhoneForm = uiEntry.withOverride( return [ 4 /*yield*/, props.recipeImplementation.createCode( - superTokens.__assign(superTokens.__assign({}, contactInfo), { - // tryLinkingWithSessionUser is set by the fn override - userContext: userContext, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, contactInfo), + { + // tryLinkingWithSessionUser is set by the fn override + userContext: userContext, + } + ) ), ]; case 5: @@ -5260,7 +5329,7 @@ var SignInUpScreens; */ var SignInUpTheme$1 = function (_a) { var activeScreen = _a.activeScreen, - props = superTokens.__rest(_a, ["activeScreen"]); + props = genericComponentOverrideContext.__rest(_a, ["activeScreen"]); var commonProps = { recipeImplementation: props.recipeImplementation, config: props.config, @@ -5271,15 +5340,15 @@ var SignInUpTheme$1 = function (_a) { validatePhoneNumber: props.validatePhoneNumber, }; return activeScreen === SignInUpScreens.EmailForm - ? jsxRuntime.jsx(EmailForm, superTokens.__assign({}, commonProps)) + ? jsxRuntime.jsx(EmailForm, genericComponentOverrideContext.__assign({}, commonProps)) : activeScreen === SignInUpScreens.PhoneForm - ? jsxRuntime.jsx(PhoneForm, superTokens.__assign({}, commonProps)) + ? jsxRuntime.jsx(PhoneForm, genericComponentOverrideContext.__assign({}, commonProps)) : activeScreen === SignInUpScreens.EmailOrPhoneForm - ? jsxRuntime.jsx(EmailOrPhoneForm, superTokens.__assign({}, commonProps)) + ? jsxRuntime.jsx(EmailOrPhoneForm, genericComponentOverrideContext.__assign({}, commonProps)) : null; }; function SignInUpThemeWrapper$1(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeScreen = getActiveScreen$1(props.factorIds); var activeStyle; @@ -5292,12 +5361,12 @@ function SignInUpThemeWrapper$1(props) { } return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, activeStyle], @@ -5305,7 +5374,7 @@ function SignInUpThemeWrapper$1(props) { { children: jsxRuntime.jsx( SignInUpTheme$1, - superTokens.__assign({}, props, { activeScreen: activeScreen }) + genericComponentOverrideContext.__assign({}, props, { activeScreen: activeScreen }) ), } ) @@ -5347,16 +5416,16 @@ function useChildProps$2( }, [recipe$1] ); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); return React.useMemo( function () { var _a; return { userContext: userContext, onSuccess: function (result) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var payloadAfterCall; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: _b.trys.push([0, 2, , 3]); @@ -5397,9 +5466,9 @@ function useChildProps$2( onError: onError, clearError: clearError, onFetchError: function (err) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -5483,11 +5552,14 @@ var SignInUpFeatureInner = function (props) { return jsxRuntime.jsxs(React.Fragment, { children: [ props.children === undefined && - jsxRuntime.jsx(SignInUpThemeWrapper$1, superTokens.__assign({}, childProps)), + jsxRuntime.jsx(SignInUpThemeWrapper$1, genericComponentOverrideContext.__assign({}, childProps)), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { - return React__namespace.cloneElement(child, superTokens.__assign({}, childProps)); + return React__namespace.cloneElement( + child, + genericComponentOverrideContext.__assign({}, childProps) + ); } return child; }), @@ -5498,19 +5570,19 @@ var SignInUpFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, - { children: jsxRuntime.jsx(SignInUpFeatureInner, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(SignInUpFeatureInner, genericComponentOverrideContext.__assign({}, props)) } ) ); }; function getModifiedRecipeImplementation$2(originalImpl, config, rebuildAuthPage) { var _this = this; - return superTokens.__assign(superTokens.__assign({}, originalImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImpl), { createCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var contactInfo, phoneNumberUtils, contactMethod, additionalAttemptInfo, res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, getPhoneNumberUtils()]; @@ -5530,17 +5602,21 @@ function getModifiedRecipeImplementation$2(originalImpl, config, rebuildAuthPage lastResend: Date.now(), contactMethod: contactMethod, contactInfo: contactInfo, - redirectToPath: superTokens.getRedirectToPathFromURL(), + redirectToPath: genericComponentOverrideContext.getRedirectToPathFromURL(), }; return [ 4 /*yield*/, originalImpl.createCode( - superTokens.__assign(superTokens.__assign({}, input), { - tryLinkingWithSessionUser: false, - userContext: superTokens.__assign(superTokens.__assign({}, input.userContext), { - additionalAttemptInfo: additionalAttemptInfo, - }), - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { + tryLinkingWithSessionUser: false, + userContext: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input.userContext), + { additionalAttemptInfo: additionalAttemptInfo } + ), + } + ) ), ]; case 2: @@ -5571,14 +5647,14 @@ var ContinueWithPasswordlessFooter = function (_a) { } return jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "link linkButton continueWithPasswordlessLink", onClick: function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var phoneNumber, validationRes, email, validationRes; var _a, _b; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: if (!isPhoneNumber) return [3 /*break*/, 2]; @@ -5656,7 +5732,7 @@ var EPComboEmailForm = uiEntry.withOverride( validate: recipe$2.defaultValidate, labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ @@ -5666,7 +5742,7 @@ var EPComboEmailForm = uiEntry.withOverride( }), jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return recipe$1.EmailPassword.getInstanceOrThrow().redirect({ @@ -5692,10 +5768,10 @@ var EPComboEmailForm = uiEntry.withOverride( buttonLabel: "PWLESS_SIGN_IN_UP_CONTINUE_BUTTON", onSuccess: props.onSuccess, callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var email, validationRes; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: email = @@ -5761,14 +5837,14 @@ var EPComboEmailOrPhoneForm = uiEntry.withOverride( label: "", labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ jsxRuntime.jsx(formBase.Label, { value: "PWLESS_SIGN_IN_UP_PHONE_LABEL" }), jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return props.setIsPhoneNumber(false); @@ -5797,14 +5873,14 @@ var EPComboEmailOrPhoneForm = uiEntry.withOverride( label: "", labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ jsxRuntime.jsx(formBase.Label, { value: "PWLESS_SIGN_IN_UP_EMAIL_LABEL" }), jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return props.setIsPhoneNumber(true); @@ -5837,7 +5913,7 @@ var EPComboEmailOrPhoneForm = uiEntry.withOverride( validate: recipe$2.defaultValidate, labelComponent: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "formLabelWithLinkWrapper" }, { children: [ @@ -5847,7 +5923,7 @@ var EPComboEmailOrPhoneForm = uiEntry.withOverride( }), jsxRuntime.jsx( "a", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return recipe$1.EmailPassword.getInstanceOrThrow().redirect({ @@ -5872,10 +5948,10 @@ var EPComboEmailOrPhoneForm = uiEntry.withOverride( formFields: formFields, buttonLabel: "PWLESS_SIGN_IN_UP_CONTINUE_BUTTON", callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var phoneNumber, validationRes, email, validationRes; var _a, _b; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: if (!props.isPhoneNumber) return [3 /*break*/, 2]; @@ -5948,27 +6024,27 @@ var SignInUpEPComboScreens; */ var SignInUpTheme = function (_a) { var activeScreen = _a.activeScreen, - props = superTokens.__rest(_a, ["activeScreen"]); - var commonProps = superTokens.__assign({}, props); + props = genericComponentOverrideContext.__rest(_a, ["activeScreen"]); + var commonProps = genericComponentOverrideContext.__assign({}, props); return activeScreen === SignInUpEPComboScreens.EmailForm - ? jsxRuntime.jsx(EPComboEmailForm, superTokens.__assign({}, commonProps)) + ? jsxRuntime.jsx(EPComboEmailForm, genericComponentOverrideContext.__assign({}, commonProps)) : activeScreen === SignInUpEPComboScreens.EmailOrPhoneForm - ? jsxRuntime.jsx(EPComboEmailOrPhoneForm, superTokens.__assign({}, commonProps)) + ? jsxRuntime.jsx(EPComboEmailOrPhoneForm, genericComponentOverrideContext.__assign({}, commonProps)) : null; }; function SignInUpThemeWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeScreen = getActiveScreen(props.factorIds); var activeStyle = props.config.signInUpFeature.emailOrPhoneFormStyle; return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, activeStyle], @@ -5976,7 +6052,7 @@ function SignInUpThemeWrapper(props) { { children: jsxRuntime.jsx( SignInUpTheme, - superTokens.__assign({}, props, { activeScreen: activeScreen }) + genericComponentOverrideContext.__assign({}, props, { activeScreen: activeScreen }) ), } ) @@ -6023,7 +6099,7 @@ function useChildProps$1( var _c = React__namespace.useState(false), showContinueWithPasswordlessLink = _c[0], setShowContinueWithPasswordlessLink = _c[1]; - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); return React.useMemo( function () { var _a; @@ -6040,9 +6116,9 @@ function useChildProps$1( showPasswordField: showPasswordField, showContinueWithPasswordlessLink: showContinueWithPasswordlessLink, onContactInfoSubmit: function (contactInfo) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var createRes, email, _a, epExists, pwlessExists, createRes; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if (!isPhoneNumber) return [3 /*break*/, 2]; @@ -6120,14 +6196,14 @@ function useChildProps$1( }); }, onPasswordSubmit: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var validationErrors, response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, - superTokens.validateForm( + genericComponentOverrideContext.validateForm( formFields, recipe$1.EmailPassword.getInstanceOrThrow().config.signInAndUpFeature .signInForm.formFields @@ -6163,9 +6239,10 @@ function useChildProps$1( } else { return [ 2 /*return*/, - superTokens.__assign(superTokens.__assign({}, response), { - isEmailPassword: true, - }), + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, response), + { isEmailPassword: true } + ), ]; } } @@ -6173,19 +6250,19 @@ function useChildProps$1( }); }, onContinueWithPasswordlessClick: function (contactInfo) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var createInfo, createRes; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: createInfo = isPhoneNumber ? { phoneNumber: contactInfo } : { email: contactInfo }; return [ 4 /*yield*/, recipeImplementation.createCode( - superTokens.__assign(superTokens.__assign({}, createInfo), { - tryLinkingWithSessionUser: false, - userContext: userContext, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, createInfo), + { tryLinkingWithSessionUser: false, userContext: userContext } + ) ), ]; case 1: @@ -6201,9 +6278,9 @@ function useChildProps$1( }); }, onSuccess: function (result) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var payloadAfterCall; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if (!result.isEmailPassword) { @@ -6251,9 +6328,9 @@ function useChildProps$1( onError: onError, clearError: clearError, onFetchError: function (err) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -6344,11 +6421,15 @@ var SignInUpEPComboFeatureInner = function (props) { ); return jsxRuntime.jsxs(React.Fragment, { children: [ - props.children === undefined && jsxRuntime.jsx(SignInUpThemeWrapper, superTokens.__assign({}, childProps)), + props.children === undefined && + jsxRuntime.jsx(SignInUpThemeWrapper, genericComponentOverrideContext.__assign({}, childProps)), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { - return React__namespace.cloneElement(child, superTokens.__assign({}, childProps)); + return React__namespace.cloneElement( + child, + genericComponentOverrideContext.__assign({}, childProps) + ); } return child; }), @@ -6359,19 +6440,24 @@ var SignInUpEPComboFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, - { children: jsxRuntime.jsx(SignInUpEPComboFeatureInner, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + SignInUpEPComboFeatureInner, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ); }; function getModifiedRecipeImplementation$1(originalImpl, config, rebuildAuthPage) { var _this = this; - return superTokens.__assign(superTokens.__assign({}, originalImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImpl), { createCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var contactInfo, phoneNumberUtils, contactMethod, additionalAttemptInfo, res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, getPhoneNumberUtils()]; @@ -6391,17 +6477,21 @@ function getModifiedRecipeImplementation$1(originalImpl, config, rebuildAuthPage lastResend: Date.now(), contactMethod: contactMethod, contactInfo: contactInfo, - redirectToPath: superTokens.getRedirectToPathFromURL(), + redirectToPath: genericComponentOverrideContext.getRedirectToPathFromURL(), }; return [ 4 /*yield*/, originalImpl.createCode( - superTokens.__assign(superTokens.__assign({}, input), { - tryLinkingWithSessionUser: false, - userContext: superTokens.__assign(superTokens.__assign({}, input.userContext), { - additionalAttemptInfo: additionalAttemptInfo, - }), - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input), + { + tryLinkingWithSessionUser: false, + userContext: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input.userContext), + { additionalAttemptInfo: additionalAttemptInfo } + ), + } + ) ), ]; case 2: @@ -6436,15 +6526,15 @@ function useChildProps( }, [recipe$1, onError, rebuildAuthPage] ); - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); return React.useMemo( function () { return { userContext: userContext, onSuccess: function (result) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var payloadAfterCall; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: _b.trys.push([0, 2, , 3]); @@ -6482,9 +6572,9 @@ function useChildProps( }); }, onFetchError: function (err) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -6565,12 +6655,15 @@ var UserInputCodeFeatureInner = function (props) { props.children === undefined && jsxRuntime.jsx( UserInputCodeFormScreenWrapper, - superTokens.__assign({}, childProps, { userContext: props.userContext }) + genericComponentOverrideContext.__assign({}, childProps, { userContext: props.userContext }) ), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { - return React__namespace.cloneElement(child, superTokens.__assign({}, childProps)); + return React__namespace.cloneElement( + child, + genericComponentOverrideContext.__assign({}, childProps) + ); } return child; }), @@ -6581,20 +6674,20 @@ var UserInputCodeFeature = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, - { children: jsxRuntime.jsx(UserInputCodeFeatureInner, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(UserInputCodeFeatureInner, genericComponentOverrideContext.__assign({}, props)) } ) ); }; function getModifiedRecipeImplementation(originalImpl, setError, rebuildAuthPage) { var _this = this; - return superTokens.__assign(superTokens.__assign({}, originalImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImpl), { resendCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res, loginAttemptInfo, timestamp; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, originalImpl.resendCode(input)]; @@ -6615,13 +6708,17 @@ function getModifiedRecipeImplementation(originalImpl, setError, rebuildAuthPage 4 /*yield*/, originalImpl.setLoginAttemptInfo({ userContext: input.userContext, - attemptInfo: superTokens.__assign(superTokens.__assign({}, loginAttemptInfo), { - tryLinkingWithSessionUser: - (_a = loginAttemptInfo.tryLinkingWithSessionUser) !== null && _a !== void 0 - ? _a - : false, - lastResend: timestamp, - }), + attemptInfo: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, loginAttemptInfo), + { + tryLinkingWithSessionUser: + (_a = loginAttemptInfo.tryLinkingWithSessionUser) !== null && + _a !== void 0 + ? _a + : false, + lastResend: timestamp, + } + ), }), ]; case 3: @@ -6649,9 +6746,9 @@ function getModifiedRecipeImplementation(originalImpl, setError, rebuildAuthPage }); }, consumeCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImpl.consumeCode(input)]; @@ -6700,8 +6797,8 @@ function getModifiedRecipeImplementation(originalImpl, setError, rebuildAuthPage }); }, clearLoginAttemptInfo: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ @@ -6712,7 +6809,7 @@ function getModifiedRecipeImplementation(originalImpl, setError, rebuildAuthPage ]; case 1: _a.sent(); - superTokens.clearErrorQueryParam(); + genericComponentOverrideContext.clearErrorQueryParam(); rebuildAuthPage(); return [2 /*return*/]; } @@ -6723,7 +6820,7 @@ function getModifiedRecipeImplementation(originalImpl, setError, rebuildAuthPage } var PasswordlessPreBuiltUI = /** @class */ (function (_super) { - superTokens.__extends(PasswordlessPreBuiltUI, _super); + genericComponentOverrideContext.__extends(PasswordlessPreBuiltUI, _super); function PasswordlessPreBuiltUI(recipeInstance) { var _this = _super.call(this) || this; _this.recipeInstance = recipeInstance; @@ -6739,7 +6836,9 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { new NormalisedURLPath__default.default("/verify") ); features[normalisedFullPath.getAsStringDangerous()] = { - matches: superTokens.matchRecipeIdUsingQueryParams(_this.recipeInstance.config.recipeId), + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), component: function (props) { return _this.getFeatureComponent("linkClickedScreen", props, useComponentOverrides); }, @@ -6751,7 +6850,9 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { new NormalisedURLPath__default.default("/mfa/otp-phone") ); features[normalisedFullPathPhone.getAsStringDangerous()] = { - matches: superTokens.matchRecipeIdUsingQueryParams(_this.recipeInstance.config.recipeId), + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), component: function (props) { return _this.getFeatureComponent("otp-phone", props, useComponentOverrides); }, @@ -6761,7 +6862,9 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { new NormalisedURLPath__default.default("/mfa/otp-email") ); features[normalisedFullPathEmail.getAsStringDangerous()] = { - matches: superTokens.matchRecipeIdUsingQueryParams(_this.recipeInstance.config.recipeId), + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), component: function (props) { return _this.getFeatureComponent("otp-email", props, useComponentOverrides); }, @@ -6777,19 +6880,21 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { if (componentName === "linkClickedScreen") { return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( session.SessionAuth, - superTokens.__assign( + genericComponentOverrideContext.__assign( { requireAuth: false, doRedirection: false }, { children: jsxRuntime.jsx( LinkClickedScreen, - superTokens.__assign({ recipe: _this.recipeInstance }, props, { - useComponentOverrides: useComponentOverrides, - }) + genericComponentOverrideContext.__assign( + { recipe: _this.recipeInstance }, + props, + { useComponentOverrides: useComponentOverrides } + ) ), } ) @@ -6801,12 +6906,12 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { if (componentName === "otp-email") { return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( session.SessionAuth, - superTokens.__assign( + genericComponentOverrideContext.__assign( { overrideGlobalClaimValidators: function () { return []; @@ -6815,7 +6920,7 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { { children: jsxRuntime.jsx( MFAFeature, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipe: _this.recipeInstance, useComponentOverrides: useComponentOverrides, @@ -6835,12 +6940,12 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { if (componentName === "otp-phone") { return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( session.SessionAuth, - superTokens.__assign( + genericComponentOverrideContext.__assign( { overrideGlobalClaimValidators: function () { return []; @@ -6849,7 +6954,7 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { { children: jsxRuntime.jsx( MFAFeature, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipe: _this.recipeInstance, useComponentOverrides: useComponentOverrides, @@ -6902,16 +7007,16 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { types.FactorIds.OTP_EMAIL, types.FactorIds.OTP_PHONE, ]); - var res = superTokens.__spreadArray( - superTokens.__spreadArray( + var res = genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray( [ { type: "FULL_PAGE", preloadInfoAndRunChecks: function (firstFactors, userContext) { var _b, _c; - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var loginAttemptInfo; - return superTokens.__generator(this, function (_d) { + return genericComponentOverrideContext.__generator(this, function (_d) { switch (_d.label) { case 0: return [ @@ -6989,10 +7094,10 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { }, component: function (_b) { var preloadInfo = _b.preloadInfo, - props = superTokens.__rest(_b, ["preloadInfo"]); + props = genericComponentOverrideContext.__rest(_b, ["preloadInfo"]); return jsxRuntime.jsx( LinkSentFeature, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { recipe: _this.recipeInstance, useComponentOverrides: recipe$2.useContext, loginAttemptInfo: preloadInfo, @@ -7005,9 +7110,9 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { type: "FULL_PAGE", preloadInfoAndRunChecks: function (firstFactors, userContext) { var _b, _c; - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var loginAttemptInfo; - return superTokens.__generator(this, function (_d) { + return genericComponentOverrideContext.__generator(this, function (_d) { switch (_d.label) { case 0: return [ @@ -7085,10 +7190,10 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { }, component: function (_b) { var preloadInfo = _b.preloadInfo, - props = superTokens.__rest(_b, ["preloadInfo"]); + props = genericComponentOverrideContext.__rest(_b, ["preloadInfo"]); return jsxRuntime.jsx( UserInputCodeFeature, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { recipe: _this.recipeInstance, useComponentOverrides: recipe$2.useContext, loginAttemptInfo: preloadInfo, @@ -7106,7 +7211,7 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { component: function (props) { return React.createElement( SignInUpFeature, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { key: factors.join("|"), recipe: _this.recipeInstance, useComponentOverrides: recipe$2.useContext, @@ -7126,7 +7231,7 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { component: function (props) { return jsxRuntime.jsx( ContinueWithPasswordlessFeature, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { recipe: _this.recipeInstance, factorIds: factors, useComponentOverrides: recipe$2.useContext, @@ -7146,7 +7251,11 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { res, factorCombos .map(function (combo) { - return superTokens.__spreadArray([types.FactorIds.EMAILPASSWORD], combo, true); + return genericComponentOverrideContext.__spreadArray( + [types.FactorIds.EMAILPASSWORD], + combo, + true + ); }) .map(function (factors) { return { @@ -7156,7 +7265,7 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { component: function (props) { return React.createElement( SignInUpEPComboFeature, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { key: factors.join("|"), recipe: _this.recipeInstance, useComponentOverrides: recipe$2.useContext, @@ -7174,7 +7283,7 @@ var PasswordlessPreBuiltUI = /** @class */ (function (_super) { }; // For tests PasswordlessPreBuiltUI.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } PasswordlessPreBuiltUI.instance = undefined; @@ -7202,10 +7311,10 @@ function getAllChoices(choices) { return [[]]; } var subChoices = getAllChoices(choices.slice(1)); - return superTokens.__spreadArray( - superTokens.__spreadArray([], subChoices, true), + return genericComponentOverrideContext.__spreadArray( + genericComponentOverrideContext.__spreadArray([], subChoices, true), subChoices.map(function (a) { - return superTokens.__spreadArray([choices[0]], a, true); + return genericComponentOverrideContext.__spreadArray([choices[0]], a, true); }), true ); diff --git a/lib/build/recipe/oauth2provider/componentOverrideContext.d.ts b/lib/build/recipe/oauth2provider/componentOverrideContext.d.ts new file mode 100644 index 000000000..288fc18e7 --- /dev/null +++ b/lib/build/recipe/oauth2provider/componentOverrideContext.d.ts @@ -0,0 +1,9 @@ +/// +import type { ComponentOverrideMap } from "./types"; +declare const useContext: () => ComponentOverrideMap, + Provider: import("react").FC< + import("react").PropsWithChildren<{ + components: ComponentOverrideMap; + }> + >; +export { useContext as useRecipeComponentOverrideContext, Provider as RecipeComponentsOverrideContextProvider }; diff --git a/lib/build/recipe/oauth2provider/components/features/tryRefreshPage/index.d.ts b/lib/build/recipe/oauth2provider/components/features/tryRefreshPage/index.d.ts new file mode 100644 index 000000000..dfde96e31 --- /dev/null +++ b/lib/build/recipe/oauth2provider/components/features/tryRefreshPage/index.d.ts @@ -0,0 +1,11 @@ +import * as React from "react"; +import type { FeatureBaseProps, UserContext } from "../../../../../types"; +import type Recipe from "../../../recipe"; +import type { ComponentOverrideMap } from "../../../types"; +declare type Prop = FeatureBaseProps<{ + recipe: Recipe; + userContext?: UserContext; + useComponentOverrides: () => ComponentOverrideMap; +}>; +export declare const TryRefreshPage: React.FC; +export default TryRefreshPage; diff --git a/lib/build/recipe/oauth2provider/components/themes/translations.d.ts b/lib/build/recipe/oauth2provider/components/themes/translations.d.ts new file mode 100644 index 000000000..d361acb41 --- /dev/null +++ b/lib/build/recipe/oauth2provider/components/themes/translations.d.ts @@ -0,0 +1,3 @@ +export declare const defaultTranslationsOAuth2Provider: { + en: {}; +}; diff --git a/lib/build/recipe/oauth2provider/constants.d.ts b/lib/build/recipe/oauth2provider/constants.d.ts new file mode 100644 index 000000000..73ebf72dc --- /dev/null +++ b/lib/build/recipe/oauth2provider/constants.d.ts @@ -0,0 +1 @@ +export declare const DEFAULT_TRY_REFRESH_PATH = "/try-refresh"; diff --git a/lib/build/recipe/oauth2provider/functionOverrides.d.ts b/lib/build/recipe/oauth2provider/functionOverrides.d.ts new file mode 100644 index 000000000..f6163a931 --- /dev/null +++ b/lib/build/recipe/oauth2provider/functionOverrides.d.ts @@ -0,0 +1,6 @@ +import type { OnHandleEventContext } from "./types"; +import type { RecipeOnHandleEventFunction } from "../recipeModule/types"; +import type { RecipeInterface } from "supertokens-web-js/recipe/oauth2provider"; +export declare const getFunctionOverrides: ( + onHandleEvent: RecipeOnHandleEventFunction +) => (originalImp: RecipeInterface) => RecipeInterface; diff --git a/lib/build/recipe/oauth2provider/index.d.ts b/lib/build/recipe/oauth2provider/index.d.ts index 77cd9b408..b37e1525a 100644 --- a/lib/build/recipe/oauth2provider/index.d.ts +++ b/lib/build/recipe/oauth2provider/index.d.ts @@ -1,3 +1,5 @@ +/// +import { RecipeComponentsOverrideContextProvider } from "./componentOverrideContext"; import { UserInput, GetRedirectionURLContext, PreAPIHookContext, OnHandleEventContext } from "./types"; import type { RecipeFunctionOptions, LoginInfo } from "supertokens-web-js/recipe/oauth2provider"; import type { RecipeInterface } from "supertokens-web-js/recipe/oauth2provider"; @@ -25,6 +27,11 @@ export default class Wrapper { info: LoginInfo; fetchResponse: Response; }>; + static ComponentsOverrideProvider: import("react").FC< + import("react").PropsWithChildren<{ + components: import("./types").ComponentOverrideMap; + }> + >; } declare const init: typeof Wrapper.init; declare const getLoginChallengeInfo: typeof Wrapper.getLoginChallengeInfo; @@ -36,4 +43,5 @@ export { OnHandleEventContext, UserInput, RecipeInterface, + RecipeComponentsOverrideContextProvider, }; diff --git a/lib/build/recipe/oauth2provider/prebuiltui.d.ts b/lib/build/recipe/oauth2provider/prebuiltui.d.ts new file mode 100644 index 000000000..51f22d8ff --- /dev/null +++ b/lib/build/recipe/oauth2provider/prebuiltui.d.ts @@ -0,0 +1,42 @@ +/// +import { RecipeRouter } from "../recipeRouter"; +import OAuth2ProviderRecipe from "./recipe"; +import type { GenericComponentOverrideMap } from "../../components/componentOverride/componentOverrideContext"; +import type { FeatureBaseProps, RecipeFeatureComponentMap, UserContext } from "../../types"; +import type { AuthComponent } from "../../types"; +export declare class OAuth2ProviderPreBuiltUI extends RecipeRouter { + readonly recipeInstance: OAuth2ProviderRecipe; + static instance?: OAuth2ProviderPreBuiltUI; + languageTranslations: { + en: {}; + }; + constructor(recipeInstance: OAuth2ProviderRecipe); + static getInstanceOrInitAndGetInstance(): OAuth2ProviderPreBuiltUI; + static getFeatures(useComponentOverrides?: () => GenericComponentOverrideMap): RecipeFeatureComponentMap; + static getFeatureComponent( + componentName: "try-refresh-page", + props: any, + useComponentOverrides?: () => GenericComponentOverrideMap + ): JSX.Element; + getFeatures: (useComponentOverrides?: () => GenericComponentOverrideMap) => RecipeFeatureComponentMap; + getFeatureComponent: ( + _: "try-refresh-page", + props: FeatureBaseProps<{ + userContext?: UserContext; + }>, + useComponentOverrides?: () => GenericComponentOverrideMap + ) => JSX.Element; + getAuthComponents(): AuthComponent[]; + static reset(): void; + static TryRefreshPage: ( + props: FeatureBaseProps<{ + userContext?: UserContext; + }> + ) => JSX.Element; +} +declare const TryRefreshPage: ( + props: FeatureBaseProps<{ + userContext?: UserContext; + }> +) => JSX.Element; +export { TryRefreshPage }; diff --git a/lib/build/recipe/oauth2provider/recipe.d.ts b/lib/build/recipe/oauth2provider/recipe.d.ts index 3911833f7..88f243b82 100644 --- a/lib/build/recipe/oauth2provider/recipe.d.ts +++ b/lib/build/recipe/oauth2provider/recipe.d.ts @@ -7,12 +7,7 @@ import type { PreAndPostAPIHookAction, UserInput, } from "./types"; -import type { - RecipeInitResult, - NormalisedConfigWithAppInfoAndRecipeID, - WebJSRecipeInterface, - SuccessRedirectContextOAuth2, -} from "../../types"; +import type { RecipeInitResult, NormalisedConfigWithAppInfoAndRecipeID, WebJSRecipeInterface } from "../../types"; export default class OAuth2Provider extends RecipeModule< GetRedirectionURLContext, PreAndPostAPIHookAction, @@ -30,6 +25,6 @@ export default class OAuth2Provider extends RecipeModule< static init(config?: UserInput): RecipeInitResult; static getInstanceOrThrow(): OAuth2Provider; static getInstance(): OAuth2Provider | undefined; - getDefaultRedirectionURL(ctx: SuccessRedirectContextOAuth2): Promise; + getDefaultRedirectionURL(ctx: GetRedirectionURLContext): Promise; static reset(): void; } diff --git a/lib/build/recipe/oauth2provider/types.d.ts b/lib/build/recipe/oauth2provider/types.d.ts index 0221c29c1..874e3fcd5 100644 --- a/lib/build/recipe/oauth2provider/types.d.ts +++ b/lib/build/recipe/oauth2provider/types.d.ts @@ -4,7 +4,7 @@ import type { NormalisedConfig as NormalisedRecipeModuleConfig, } from "../recipeModule/types"; import type OverrideableBuilder from "supertokens-js-override"; -import type { RecipeInterface } from "supertokens-web-js/recipe/oauth2provider/types"; +import type { LoginInfo, RecipeInterface } from "supertokens-web-js/recipe/oauth2provider/types"; export declare type PreAndPostAPIHookAction = "GET_LOGIN_CHALLENGE_INFO"; export declare type PreAPIHookContext = { action: PreAndPostAPIHookAction; @@ -13,6 +13,7 @@ export declare type PreAPIHookContext = { userContext: UserContext; }; export declare type UserInput = { + disableDefaultUI?: boolean; override?: { functions?: ( originalImplementation: RecipeInterface, @@ -25,12 +26,24 @@ export declare type NormalisedConfig = NormalisedRecipeModuleConfig< PreAndPostAPIHookAction, OnHandleEventContext > & { + disableDefaultUI: boolean; override: { - functions?: ( + functions: ( originalImplementation: RecipeInterface, builder: OverrideableBuilder ) => RecipeInterface; }; }; -export declare type GetRedirectionURLContext = SuccessRedirectContextOAuth2; -export declare type OnHandleEventContext = any; +export declare type ContinueOAuth2AfterRefreshRedirectContext = { + recipeId: "oauth2provider"; + action: "CONTINUE_OAUTH2_AFTER_REFRESH"; + loginChallenge: string; +}; +export declare type GetRedirectionURLContext = SuccessRedirectContextOAuth2 | ContinueOAuth2AfterRefreshRedirectContext; +export declare type OnHandleEventContext = { + action: "LOADED_LOGIN_CHALLENGE"; + loginChallenge: string; + loginInfo: LoginInfo; + userContext: UserContext; +}; +export declare type ComponentOverrideMap = any; diff --git a/lib/build/recipeModule-shared.js b/lib/build/recipeModule-shared.js index 096e6ddb4..709d6a3fe 100644 --- a/lib/build/recipeModule-shared.js +++ b/lib/build/recipeModule-shared.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); /* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. * @@ -17,33 +17,42 @@ var superTokens = require("./superTokens.js"); * under the License. */ var RecipeModule = /** @class */ (function (_super) { - superTokens.__extends(RecipeModule, _super); + genericComponentOverrideContext.__extends(RecipeModule, _super); function RecipeModule() { var _this = (_super !== null && _super.apply(this, arguments)) || this; _this.redirect = function (context, navigate, queryParams, userContext) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var redirectUrl; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, - this.getRedirectUrl(context, superTokens.getNormalisedUserContext(userContext)), + this.getRedirectUrl( + context, + genericComponentOverrideContext.getNormalisedUserContext(userContext) + ), ]; case 1: redirectUrl = _a.sent(); if (redirectUrl === null) { - superTokens.logDebugMessage( + genericComponentOverrideContext.logDebugMessage( "Skipping redirection because the user override returned null for context ".concat( JSON.stringify(context, null, 2) ) ); return [2 /*return*/]; } - redirectUrl = superTokens.appendQueryParamsToURL(redirectUrl, queryParams); + redirectUrl = genericComponentOverrideContext.appendQueryParamsToURL( + redirectUrl, + queryParams + ); return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToUrl(redirectUrl, navigate), + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToUrl( + redirectUrl, + navigate + ), ]; } }); @@ -51,9 +60,9 @@ var RecipeModule = /** @class */ (function (_super) { }; // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types _this.getRedirectUrl = function (context, userContext) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var redirectUrl; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, this.config.getRedirectionURL(context, userContext)]; @@ -74,13 +83,13 @@ var RecipeModule = /** @class */ (function (_super) { } // eslint-disable-next-line @typescript-eslint/no-unused-vars RecipeModule.prototype.getDefaultRedirectionURL = function (_, _userContext) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { throw new Error("getDefaultRedirectionURL is not implemented."); }); }); }; return RecipeModule; -})(superTokens.BaseRecipeModule); +})(genericComponentOverrideContext.BaseRecipeModule); exports.RecipeModule = RecipeModule; diff --git a/lib/build/session.js b/lib/build/session.js index b805d24cc..9fb87e239 100644 --- a/lib/build/session.js +++ b/lib/build/session.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var WebJSSessionRecipe = require("supertokens-web-js/recipe/session"); var componentOverrideContext = require("./session-shared.js"); var types = require("./multifactorauth-shared.js"); @@ -16,7 +16,6 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); -require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("./oauth2provider-shared.js"); require("supertokens-web-js/recipe/oauth2provider"); @@ -31,10 +30,10 @@ require("./authRecipe-shared.js"); require("supertokens-web-js/lib/build/normalisedURLPath"); var BooleanClaim = /** @class */ (function (_super) { - superTokens.__extends(BooleanClaim, _super); + genericComponentOverrideContext.__extends(BooleanClaim, _super); function BooleanClaim(config) { var _this = _super.call(this, config) || this; - var validatorsWithCallbacks = superTokens.__assign({}, _this.validators); + var validatorsWithCallbacks = genericComponentOverrideContext.__assign({}, _this.validators); var _loop_1 = function (key) { var validator = validatorsWithCallbacks[key]; validatorsWithCallbacks[key] = function () { @@ -42,10 +41,13 @@ var BooleanClaim = /** @class */ (function (_super) { for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } - return superTokens.__assign(superTokens.__assign({}, validator.apply(void 0, args)), { - onFailureRedirection: config.onFailureRedirection, - showAccessDeniedOnFailure: config.showAccessDeniedOnFailure, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, validator.apply(void 0, args)), + { + onFailureRedirection: config.onFailureRedirection, + showAccessDeniedOnFailure: config.showAccessDeniedOnFailure, + } + ); }; }; for (var key in validatorsWithCallbacks) { @@ -58,10 +60,10 @@ var BooleanClaim = /** @class */ (function (_super) { })(WebJSSessionRecipe.BooleanClaim); var PrimitiveArrayClaim = /** @class */ (function (_super) { - superTokens.__extends(PrimitiveArrayClaim, _super); + genericComponentOverrideContext.__extends(PrimitiveArrayClaim, _super); function PrimitiveArrayClaim(config) { var _this = _super.call(this, config) || this; - var validatorsWithCallbacks = superTokens.__assign({}, _this.validators); + var validatorsWithCallbacks = genericComponentOverrideContext.__assign({}, _this.validators); var _loop_1 = function (key) { var validator = validatorsWithCallbacks[key]; validatorsWithCallbacks[key] = function () { @@ -69,10 +71,13 @@ var PrimitiveArrayClaim = /** @class */ (function (_super) { for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } - return superTokens.__assign(superTokens.__assign({}, validator.apply(void 0, args)), { - onFailureRedirection: config.onFailureRedirection, - showAccessDeniedOnFailure: config.showAccessDeniedOnFailure, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, validator.apply(void 0, args)), + { + onFailureRedirection: config.onFailureRedirection, + showAccessDeniedOnFailure: config.showAccessDeniedOnFailure, + } + ); }; }; for (var key in validatorsWithCallbacks) { @@ -85,10 +90,10 @@ var PrimitiveArrayClaim = /** @class */ (function (_super) { })(WebJSSessionRecipe.PrimitiveArrayClaim); var PrimitiveClaim = /** @class */ (function (_super) { - superTokens.__extends(PrimitiveClaim, _super); + genericComponentOverrideContext.__extends(PrimitiveClaim, _super); function PrimitiveClaim(config) { var _this = _super.call(this, config) || this; - var validatorsWithCallbacks = superTokens.__assign({}, _this.validators); + var validatorsWithCallbacks = genericComponentOverrideContext.__assign({}, _this.validators); var _loop_1 = function (key) { var validator = validatorsWithCallbacks[key]; validatorsWithCallbacks[key] = function () { @@ -96,10 +101,13 @@ var PrimitiveClaim = /** @class */ (function (_super) { for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } - return superTokens.__assign(superTokens.__assign({}, validator.apply(void 0, args)), { - onFailureRedirection: config.onFailureRedirection, - showAccessDeniedOnFailure: config.showAccessDeniedOnFailure, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, validator.apply(void 0, args)), + { + onFailureRedirection: config.onFailureRedirection, + showAccessDeniedOnFailure: config.showAccessDeniedOnFailure, + } + ); }; }; for (var key in validatorsWithCallbacks) { @@ -152,12 +160,12 @@ var SessionAPIWrapper = /** @class */ (function () { return types.Session.init(config); }; SessionAPIWrapper.getUserId = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, types.Session.getInstanceOrThrow().getUserId({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -166,12 +174,12 @@ var SessionAPIWrapper = /** @class */ (function () { }); }; SessionAPIWrapper.getAccessToken = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, types.Session.getInstanceOrThrow().getAccessToken({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -180,12 +188,12 @@ var SessionAPIWrapper = /** @class */ (function () { }); }; SessionAPIWrapper.getAccessTokenPayloadSecurely = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, types.Session.getInstanceOrThrow().getAccessTokenPayloadSecurely({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -194,19 +202,19 @@ var SessionAPIWrapper = /** @class */ (function () { }); }; SessionAPIWrapper.attemptRefreshingSession = function () { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, types.Session.getInstanceOrThrow().attemptRefreshingSession()]; }); }); }; SessionAPIWrapper.doesSessionExist = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, types.Session.getInstanceOrThrow().doesSessionExist({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -218,15 +226,18 @@ var SessionAPIWrapper = /** @class */ (function () { * @deprecated */ SessionAPIWrapper.addAxiosInterceptors = function (axiosInstance, userContext) { - return types.Session.addAxiosInterceptors(axiosInstance, superTokens.getNormalisedUserContext(userContext)); + return types.Session.addAxiosInterceptors( + axiosInstance, + genericComponentOverrideContext.getNormalisedUserContext(userContext) + ); }; SessionAPIWrapper.signOut = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, types.Session.getInstanceOrThrow().signOut({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -238,7 +249,7 @@ var SessionAPIWrapper = /** @class */ (function () { return types.Session.getInstanceOrThrow().validateClaims({ overrideGlobalClaimValidators: input === null || input === void 0 ? void 0 : input.overrideGlobalClaimValidators, - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }); @@ -249,7 +260,7 @@ var SessionAPIWrapper = /** @class */ (function () { SessionAPIWrapper.getClaimValue = function (input) { return types.Session.getInstanceOrThrow().getClaimValue({ claim: input.claim, - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }); diff --git a/lib/build/sessionprebuiltui.js b/lib/build/sessionprebuiltui.js index 965c551fb..0541541a0 100644 --- a/lib/build/sessionprebuiltui.js +++ b/lib/build/sessionprebuiltui.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var uiEntry = require("./index2.js"); var componentOverrideContext = require("./session-shared.js"); @@ -18,7 +18,6 @@ require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./multifactorauth-shared2.js"); require("supertokens-web-js/recipe/multifactorauth"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); @@ -32,7 +31,7 @@ require("supertokens-web-js/recipe/session"); function ErrorRoundIcon() { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "32", height: "32", viewBox: "0 0 32 32", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, { children: [ @@ -58,7 +57,7 @@ function BackButton(_a) { var t = translationContext.useTranslation(); return jsxRuntime.jsx( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: onClick, "data-supertokens": "buttonBase backButton" }, { children: t("GO_BACK") } ) @@ -73,7 +72,7 @@ function LogoutButton(_a) { var t = translationContext.useTranslation(); return jsxRuntime.jsxs( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: onClick, "data-supertokens": "buttonBase logoutButton" }, { children: [ @@ -110,8 +109,8 @@ var AccessDeniedScreen$2 = function (props) { var userContext = uiEntry.useUserContext(); var t = translationContext.useTranslation(); var onLogout = function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, props.recipe.signOut({ userContext: userContext })]; @@ -119,7 +118,7 @@ var AccessDeniedScreen$2 = function (props) { _a.sent(); return [ 4 /*yield*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ show: "signin", redirectBack: false, userContext: userContext, @@ -148,24 +147,24 @@ var AccessDeniedScreen$2 = function (props) { }; return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "center accessDenied" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: [ jsxRuntime.jsx(ErrorRoundIcon, {}), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle" }, { children: t("ACCESS_DENIED") } ) @@ -174,14 +173,14 @@ var AccessDeniedScreen$2 = function (props) { props.error && jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "primaryText accessDeniedError" }, { children: [" ", props.error] } ) ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "buttonsGroup" }, { children: [ @@ -206,26 +205,30 @@ var AccessDeniedScreen$2 = function (props) { }; var AccessDeniedThemeWithOverride = uiEntry.withOverride("SessionAccessDenied", AccessDeniedScreen$2); var AccessDeniedScreenTheme = function (props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); return jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, props.config.accessDeniedScreen.style], }, - { children: jsxRuntime.jsx(AccessDeniedThemeWithOverride, superTokens.__assign({}, props)) } + { + children: jsxRuntime.jsx( + AccessDeniedThemeWithOverride, + genericComponentOverrideContext.__assign({}, props) + ), + } ) ); }; var defaultTranslationsSession = { - en: superTokens.__assign(superTokens.__assign({}, uiEntry.defaultTranslationsCommon.en), { - ACCESS_DENIED: "Access denied", - GO_BACK: "Go back", - LOGOUT: "Log out", - }), + en: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, uiEntry.defaultTranslationsCommon.en), + { ACCESS_DENIED: "Access denied", GO_BACK: "Go back", LOGOUT: "Log out" } + ), }; var AccessDeniedScreen$1 = function (props) { @@ -239,18 +242,18 @@ var AccessDeniedScreen$1 = function (props) { : _b.useHistoryCustom(); return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { defaultStore: defaultTranslationsSession, useShadowDom: (_c = props.useShadowDom) !== null && _c !== void 0 ? _c - : superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + : genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, }, { children: jsxRuntime.jsx(AccessDeniedScreenTheme, { @@ -268,7 +271,7 @@ var AccessDeniedScreen$1 = function (props) { }; var SessionPreBuiltUI = /** @class */ (function (_super) { - superTokens.__extends(SessionPreBuiltUI, _super); + genericComponentOverrideContext.__extends(SessionPreBuiltUI, _super); function SessionPreBuiltUI(recipeInstance) { var _this = _super.call(this) || this; _this.recipeInstance = recipeInstance; @@ -287,7 +290,7 @@ var SessionPreBuiltUI = /** @class */ (function (_super) { if (componentName === "accessDenied") { return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx(AccessDeniedScreen$1, { @@ -333,7 +336,7 @@ var SessionPreBuiltUI = /** @class */ (function (_super) { }; // For tests SessionPreBuiltUI.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } SessionPreBuiltUI.instance = undefined; diff --git a/lib/build/superTokens.js b/lib/build/superTokens.js deleted file mode 100644 index 6f3e33976..000000000 --- a/lib/build/superTokens.js +++ /dev/null @@ -1,1450 +0,0 @@ -"use strict"; - -var SuperTokensWebJS = require("supertokens-web-js"); -var cookieHandler = require("supertokens-web-js/utils/cookieHandler"); -var postSuperTokensInitCallbacks = require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); -var windowHandler = require("supertokens-web-js/utils/windowHandler"); -var MultitenancyWebJS = require("supertokens-web-js/recipe/multitenancy"); -var utils = require("supertokens-web-js/utils"); -var React = require("react"); -var NormalisedURLDomain = require("supertokens-web-js/utils/normalisedURLDomain"); -var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); - -function _interopDefault(e) { - return e && e.__esModule ? e : { default: e }; -} - -var SuperTokensWebJS__default = /*#__PURE__*/ _interopDefault(SuperTokensWebJS); -var MultitenancyWebJS__default = /*#__PURE__*/ _interopDefault(MultitenancyWebJS); -var NormalisedURLDomain__default = /*#__PURE__*/ _interopDefault(NormalisedURLDomain); -var NormalisedURLPath__default = /*#__PURE__*/ _interopDefault(NormalisedURLPath); - -/****************************************************************************** -Copyright (c) Microsoft Corporation. - -Permission to use, copy, modify, and/or distribute this software for any -purpose with or without fee is hereby granted. - -THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH -REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, -INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR -OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR -PERFORMANCE OF THIS SOFTWARE. -***************************************************************************** */ -/* global Reflect, Promise, SuppressedError, Symbol */ - -var extendStatics = function (d, b) { - extendStatics = - Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && - function (d, b) { - d.__proto__ = b; - }) || - function (d, b) { - for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; - }; - return extendStatics(d, b); -}; - -function __extends(d, b) { - if (typeof b !== "function" && b !== null) - throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); - extendStatics(d, b); - function __() { - this.constructor = d; - } - d.prototype = b === null ? Object.create(b) : ((__.prototype = b.prototype), new __()); -} - -exports.__assign = function () { - exports.__assign = - Object.assign || - function __assign(t) { - for (var s, i = 1, n = arguments.length; i < n; i++) { - s = arguments[i]; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; - } - return t; - }; - return exports.__assign.apply(this, arguments); -}; - -function __rest(s, e) { - var t = {}; - for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; - if (s != null && typeof Object.getOwnPropertySymbols === "function") - for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { - if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; - } - return t; -} - -function __awaiter(thisArg, _arguments, P, generator) { - function adopt(value) { - return value instanceof P - ? value - : new P(function (resolve) { - resolve(value); - }); - } - return new (P || (P = Promise))(function (resolve, reject) { - function fulfilled(value) { - try { - step(generator.next(value)); - } catch (e) { - reject(e); - } - } - function rejected(value) { - try { - step(generator["throw"](value)); - } catch (e) { - reject(e); - } - } - function step(result) { - result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); - } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); -} - -function __generator(thisArg, body) { - var _ = { - label: 0, - sent: function () { - if (t[0] & 1) throw t[1]; - return t[1]; - }, - trys: [], - ops: [], - }, - f, - y, - t, - g; - return ( - (g = { next: verb(0), throw: verb(1), return: verb(2) }), - typeof Symbol === "function" && - (g[Symbol.iterator] = function () { - return this; - }), - g - ); - function verb(n) { - return function (v) { - return step([n, v]); - }; - } - function step(op) { - if (f) throw new TypeError("Generator is already executing."); - while ((g && ((g = 0), op[0] && (_ = 0)), _)) - try { - if ( - ((f = 1), - y && - (t = - op[0] & 2 - ? y["return"] - : op[0] - ? y["throw"] || ((t = y["return"]) && t.call(y), 0) - : y.next) && - !(t = t.call(y, op[1])).done) - ) - return t; - if (((y = 0), t)) op = [op[0] & 2, t.value]; - switch (op[0]) { - case 0: - case 1: - t = op; - break; - case 4: - _.label++; - return { value: op[1], done: false }; - case 5: - _.label++; - y = op[1]; - op = [0]; - continue; - case 7: - op = _.ops.pop(); - _.trys.pop(); - continue; - default: - if (!((t = _.trys), (t = t.length > 0 && t[t.length - 1])) && (op[0] === 6 || op[0] === 2)) { - _ = 0; - continue; - } - if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { - _.label = op[1]; - break; - } - if (op[0] === 6 && _.label < t[1]) { - _.label = t[1]; - t = op; - break; - } - if (t && _.label < t[2]) { - _.label = t[2]; - _.ops.push(op); - break; - } - if (t[2]) _.ops.pop(); - _.trys.pop(); - continue; - } - op = body.call(thisArg, _); - } catch (e) { - op = [6, e]; - y = 0; - } finally { - f = t = 0; - } - if (op[0] & 5) throw op[1]; - return { value: op[0] ? op[1] : void 0, done: true }; - } -} - -function __spreadArray(to, from, pack) { - if (pack || arguments.length === 2) - for (var i = 0, l = from.length, ar; i < l; i++) { - if (ar || !(i in from)) { - if (!ar) ar = Array.prototype.slice.call(from, 0, i); - ar[i] = from[i]; - } - } - return to.concat(ar || Array.prototype.slice.call(from)); -} - -typeof SuppressedError === "function" - ? SuppressedError - : function (error, suppressed, message) { - var e = new Error(message); - return (e.name = "SuppressedError"), (e.error = error), (e.suppressed = suppressed), e; - }; - -/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. - * - * This software is licensed under the Apache License, Version 2.0 (the - * "License") as published by the Apache Software Foundation. - * - * You may not use this file except in compliance with the License. You may - * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - */ -/* - * Consts. - */ -var RECIPE_ID_QUERY_PARAM = "rid"; -var DEFAULT_API_BASE_PATH = "/auth"; -var DEFAULT_WEBSITE_BASE_PATH = "/auth"; -var ST_ROOT_ID = "supertokens-root"; -var SSR_ERROR = - "\nIf you are trying to use this method doing server-side-rendering, please make sure you move this method inside a componentDidMount method or useEffect hook."; - -/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. - * - * This software is licensed under the Apache License, Version 2.0 (the - * "License") as published by the Apache Software Foundation. - * - * You may not use this file except in compliance with the License. You may - * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - */ -var package_version = "0.42.2"; - -/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. - * - * This software is licensed under the Apache License, Version 2.0 (the - * "License") as published by the Apache Software Foundation. - * - * You may not use this file except in compliance with the License. You may - * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - */ -var SUPERTOKENS_DEBUG_NAMESPACE = "com.supertokens.auth-react"; -var __debugLogsEnabled = false; -function enableLogging() { - __debugLogsEnabled = true; -} -function logDebugMessage(message) { - if (__debugLogsEnabled) { - // eslint-disable-next-line no-console - console.log( - "" - .concat(SUPERTOKENS_DEBUG_NAMESPACE, ' {t: "') - .concat(new Date().toISOString(), '", message: "') - .concat(message, '", supertokens-auth-react-ver: "') - .concat(package_version, '"}') - ); - } -} - -/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. - * - * This software is licensed under the Apache License, Version 2.0 (the - * "License") as published by the Apache Software Foundation. - * - * You may not use this file except in compliance with the License. You may - * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - */ -/* - * getRecipeIdFromPath - * Input: - * Output: The "rid" query param if present, null otherwise. - */ -function getRecipeIdFromSearch(search) { - var urlParams = new URLSearchParams(search); - return urlParams.get(RECIPE_ID_QUERY_PARAM); -} -function clearQueryParams(paramNames) { - var newURL = new URL(windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHref()); - for (var _i = 0, paramNames_1 = paramNames; _i < paramNames_1.length; _i++) { - var param = paramNames_1[_i]; - newURL.searchParams.delete(param); - } - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.replaceState( - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.getState(), - "", - newURL.toString() - ); -} -function updateQueryParam(name, value) { - var newURL = new URL(windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHref()); - newURL.searchParams.set(name, value); - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.replaceState( - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.history.getState(), - "", - newURL.toString() - ); -} -function clearErrorQueryParam() { - clearQueryParams(["error", "message"]); -} -function getQueryParams(param) { - var urlParams = new URLSearchParams( - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getSearch() - ); - return urlParams.get(param); -} -function getURLHash() { - // By default it is returined with the "#" at the beginning, we cut that off here. - return windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHash().substr(1); -} -function getRedirectToPathFromURL() { - var redirectToPath = getQueryParams("redirectToPath"); - if (redirectToPath === null) { - return undefined; - } else { - try { - var url = void 0; - try { - url = new URL(redirectToPath); - } catch (error) { - var fakeDomain = redirectToPath.startsWith("/") ? "http://localhost" : "http://localhost/"; - url = new URL("".concat(fakeDomain).concat(redirectToPath)); - } - // Prevent Open redirects by normalising path. - var normalisedURLPath = new NormalisedURLPath__default.default(redirectToPath).getAsStringDangerous(); - var pathQueryParams = url.search || ""; // url.search contains the leading ? - var pathHash = url.hash || ""; // url.hash contains the leading # - var pathWithQueryParamsAndHash = normalisedURLPath + pathQueryParams + pathHash; - // Ensure a leading "/" if `normalisedUrlPath` is empty but `pathWithQueryParamsAndHash` is not to ensure proper redirection. - // Example: "?test=1" will not redirect the user to `/?test=1` if we don't add a leading "/". - if ( - normalisedURLPath.length === 0 && - pathWithQueryParamsAndHash.length > 0 && - !pathWithQueryParamsAndHash.startsWith("/") - ) { - return "/" + pathWithQueryParamsAndHash; - } - return pathWithQueryParamsAndHash; - } catch (_a) { - return undefined; - } - } -} -/* - * isTest - */ -function isTest() { - try { - return process.env.TEST_MODE === "testing" || process.env.REACT_APP_TEST_MODE === "testing"; - } catch (err) { - // can get Uncaught ReferenceError: process is not defined error - return false; - } -} -function normaliseInputAppInfoOrThrowError(appInfo) { - if (appInfo === undefined) { - throw new Error("Please provide the appInfo object when calling supertokens.init"); - } - if (appInfo.apiDomain === undefined) { - throw new Error("Please provide your apiDomain inside the appInfo object when calling supertokens.init"); - } - if (appInfo.appName === undefined) { - throw new Error("Please provide your appName inside the appInfo object when calling supertokens.init"); - } - if (appInfo.websiteDomain === undefined) { - throw new Error("Please provide your websiteDomain inside the appInfo object when calling supertokens.init"); - } - var apiGatewayPath = new NormalisedURLPath__default.default(""); - if (appInfo.apiGatewayPath !== undefined) { - apiGatewayPath = new NormalisedURLPath__default.default(appInfo.apiGatewayPath); - } - return { - appName: appInfo.appName, - apiDomain: new NormalisedURLDomain__default.default(appInfo.apiDomain), - websiteDomain: new NormalisedURLDomain__default.default(appInfo.websiteDomain), - apiBasePath: apiGatewayPath.appendPath( - getNormalisedURLPathOrDefault(DEFAULT_API_BASE_PATH, appInfo.apiBasePath) - ), - websiteBasePath: getNormalisedURLPathOrDefault(DEFAULT_WEBSITE_BASE_PATH, appInfo.websiteBasePath), - }; -} -function getNormalisedURLPathOrDefault(defaultPath, path) { - if (path !== undefined) { - return new NormalisedURLPath__default.default(path); - } else { - return new NormalisedURLPath__default.default(defaultPath); - } -} -/* - * validateForm - */ -// We check that the number of fields in input and config form field is the same. -// We check that each item in the config form field is also present in the input form field -function validateForm(inputs, configFormFields) { - return __awaiter(this, void 0, void 0, function () { - var validationErrors, _loop_1, i; - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - validationErrors = []; - if (configFormFields.length !== inputs.length) { - throw Error("Are you sending too many / too few formFields?"); - } - _loop_1 = function (i) { - var field, input, value, error; - return __generator(this, function (_b) { - switch (_b.label) { - case 0: - field = configFormFields[i]; - input = inputs.find(function (i) { - return i.id === field.id; - }); - value = input.value; - if (input.id === "email") { - value = value.trim(); - } - return [4 /*yield*/, field.validate(value)]; - case 1: - error = _b.sent(); - // If error, add it. - if (error !== undefined) { - validationErrors.push({ - error: error, - id: field.id, - }); - } - return [2 /*return*/]; - } - }); - }; - i = 0; - _a.label = 1; - case 1: - if (!(i < configFormFields.length)) return [3 /*break*/, 4]; - return [5 /*yield**/, _loop_1(i)]; - case 2: - _a.sent(); - _a.label = 3; - case 3: - i++; - return [3 /*break*/, 1]; - case 4: - return [2 /*return*/, validationErrors]; - } - }); - }); -} -/* - * getCurrentNormalisedUrlPath - */ -function getCurrentNormalisedUrlPath() { - return new NormalisedURLPath__default.default( - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getPathName() - ); -} -function getCurrentNormalisedUrlPathWithQueryParamsAndFragments() { - var normalisedUrlPath = getCurrentNormalisedUrlPath().getAsStringDangerous(); - return ( - normalisedUrlPath + - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getSearch() + - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHash() - ); -} -function appendQueryParamsToURL(stringUrl, queryParams) { - if (queryParams === undefined) { - return stringUrl; - } - try { - var url_1 = new URL(stringUrl); - Object.entries(queryParams).forEach(function (_a) { - var key = _a[0], - value = _a[1]; - url_1.searchParams.set(key, value); - }); - return url_1.href; - } catch (e) { - var fakeDomain = stringUrl.startsWith("/") ? "http://localhost" : "http://localhost/"; - var url_2 = new URL("".concat(fakeDomain).concat(stringUrl)); - Object.entries(queryParams).forEach(function (_a) { - var key = _a[0], - value = _a[1]; - url_2.searchParams.set(key, value); - }); - return "".concat(url_2.pathname).concat(url_2.search).concat(url_2.hash); - } -} -function appendTrailingSlashToURL(stringUrl) { - return stringUrl.endsWith("/") ? stringUrl : stringUrl + "/"; -} -/* - * Default method for matching recipe route based on query params. - */ -function matchRecipeIdUsingQueryParams(recipeId) { - return function () { - var recipeIdFromSearch = getRecipeIdFromSearch( - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getSearch() - ); - return recipeIdFromSearch === recipeId; - }; -} -function redirectWithFullPageReload(to) { - if (to.trim() === "") { - to = "/"; - } - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.setHref(to); -} -function redirectWithNavigate(to, navigate) { - if (to.trim() === "") { - to = "/"; - } - if ("push" in navigate) { - // we are using react-router-dom that is before v6 - navigate.push(to); - } else { - // in react-router-dom v6, it is just navigate(to) - navigate(to); - } -} -function getOriginOfPage() { - return new NormalisedURLDomain__default.default( - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getOrigin() - ); -} -function getLocalStorage(key) { - return __awaiter(this, void 0, void 0, function () { - var res; - return __generator(this, function (_a) { - res = windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.localStorage.getItem(key); - if (res === null || res === undefined) { - return [2 /*return*/, null]; - } - return [2 /*return*/, res]; - }); - }); -} -function setLocalStorage(key, value) { - return __awaiter(this, void 0, void 0, function () { - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - return [ - 4 /*yield*/, - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.localStorage.setItem( - key, - value - ), - ]; - case 1: - _a.sent(); - return [2 /*return*/]; - } - }); - }); -} -function removeFromLocalStorage(key) { - return __awaiter(this, void 0, void 0, function () { - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - return [ - 4 /*yield*/, - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.localStorage.removeItem( - key - ), - ]; - case 1: - _a.sent(); - return [2 /*return*/]; - } - }); - }); -} -function mergeObjects(obj1, obj2) { - var res = exports.__assign({}, obj1); - for (var key in obj2) { - if (typeof res[key] === "object" && typeof obj2[key] === "object") { - res[key] = mergeObjects(res[key], obj2[key]); - } else { - res[key] = obj2[key]; - } - } - return res; -} -function normaliseCookieScopeOrThrowError(cookieScope) { - function helper(cookieScope) { - cookieScope = cookieScope.trim().toLowerCase(); - // first we convert it to a URL so that we can use the URL class - if (cookieScope.startsWith(".")) { - cookieScope = cookieScope.substr(1); - } - if (!cookieScope.startsWith("http://") && !cookieScope.startsWith("https://")) { - cookieScope = "http://" + cookieScope; - } - try { - var urlObj = new URL(cookieScope); - cookieScope = urlObj.hostname; - // remove leading dot - if (cookieScope.startsWith(".")) { - cookieScope = cookieScope.substr(1); - } - return cookieScope; - } catch (err) { - throw new Error("Please provide a valid cookie scope"); - } - } - function isAnIpAddress(ipaddress) { - return /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/.test( - ipaddress - ); - } - var noDotNormalised = helper(cookieScope); - if (noDotNormalised === "localhost" || isAnIpAddress(noDotNormalised)) { - return noDotNormalised; - } - if (cookieScope.startsWith(".")) { - return "." + noDotNormalised; - } - return noDotNormalised; -} -function getDefaultCookieScope() { - try { - return normaliseCookieScopeOrThrowError( - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHostName() - ); - } catch (_a) { - return undefined; - } -} -function getCookieValue(name) { - return __awaiter(this, void 0, void 0, function () { - var value, _a, parts, last, temp; - return __generator(this, function (_b) { - switch (_b.label) { - case 0: - _a = "; "; - return [ - 4 /*yield*/, - cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.getCookie(), - ]; - case 1: - value = _a + _b.sent(); - parts = value.split("; " + name + "="); - if (parts.length >= 2) { - last = parts.pop(); - if (last !== undefined) { - temp = last.split(";").shift(); - if (temp === undefined) { - return [2 /*return*/, null]; - } - return [2 /*return*/, temp]; - } - } - return [2 /*return*/, null]; - } - }); - }); -} -// undefined value will remove the cookie -function setFrontendCookie(name, value, scope) { - return __awaiter(this, void 0, void 0, function () { - var expires, cookieVal; - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - expires = "Thu, 01 Jan 1970 00:00:01 GMT"; - cookieVal = ""; - if (value !== undefined) { - cookieVal = value; - expires = undefined; // set cookie without expiry - } - if ( - !( - scope === "localhost" || - scope === - windowHandler.WindowHandlerReference.getReferenceOrThrow().windowHandler.location.getHostName() || - scope === undefined - ) - ) - return [3 /*break*/, 5]; - if (!(expires !== undefined)) return [3 /*break*/, 2]; - return [ - 4 /*yield*/, - cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( - "".concat(name, "=").concat(cookieVal, ";expires=").concat(expires, ";path=/;samesite=lax") - ), - ]; - case 1: - _a.sent(); - return [3 /*break*/, 4]; - case 2: - return [ - 4 /*yield*/, - cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( - "" - .concat(name, "=") - .concat(cookieVal, ";expires=Fri, 31 Dec 9999 23:59:59 GMT;path=/;samesite=lax") - ), - ]; - case 3: - _a.sent(); - _a.label = 4; - case 4: - return [3 /*break*/, 9]; - case 5: - if (!(expires !== undefined)) return [3 /*break*/, 7]; - return [ - 4 /*yield*/, - cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( - "" - .concat(name, "=") - .concat(cookieVal, ";expires=") - .concat(expires, ";domain=") - .concat(scope, ";path=/;samesite=lax") - ), - ]; - case 6: - _a.sent(); - return [3 /*break*/, 9]; - case 7: - return [ - 4 /*yield*/, - cookieHandler.CookieHandlerReference.getReferenceOrThrow().cookieHandler.setCookie( - "" - .concat(name, "=") - .concat(cookieVal, ";domain=") - .concat(scope, ";expires=Fri, 31 Dec 9999 23:59:59 GMT;path=/;samesite=lax") - ), - ]; - case 8: - _a.sent(); - _a.label = 9; - case 9: - return [2 /*return*/]; - } - }); - }); -} -function getNormalisedUserContext(userContext) { - return userContext === undefined ? {} : userContext; -} -/** - * This function handles calling APIs that should only be called once during mount (mostly on mount of a route/feature component). - * It's split into multiple callbacks (fetch + handleResponse/handleError) because we expect fetch to take longer and - * and the component may be unmounted during the first fetch, in which case we want to avoid updating state/redirecting. - * This is especially relevant for development in strict mode with React 18 (and in the future for concurrent rendering). - * - * @param fetch This is a callback that is only called once on mount. Mostly it's for consuming tokens/doing one time only API calls - * @param handleResponse This is called with the result of the first (fetch) call if it succeeds. - * @param handleError This is called with the error of the first (fetch) call if it rejects. - * @param startLoading Will start the whole process if this is set to true (or omitted). Mostly used to wait for session loading. - */ -var useOnMountAPICall = function (fetch, handleResponse, handleError, startLoading) { - if (startLoading === void 0) { - startLoading = true; - } - var consumeReq = React.useRef(); - var _a = React.useState(undefined), - error = _a[0], - setError = _a[1]; - React.useEffect( - function () { - var effect = function (signal) { - return __awaiter(void 0, void 0, void 0, function () { - var resp, err_1, err_2; - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - _a.trys.push([0, 2, , 9]); - if (consumeReq.current === undefined) { - consumeReq.current = fetch(); - } - return [4 /*yield*/, consumeReq.current]; - case 1: - resp = _a.sent(); - if (!signal.aborted) { - void handleResponse(resp); - } - return [3 /*break*/, 9]; - case 2: - err_1 = _a.sent(); - if (!!signal.aborted) return [3 /*break*/, 8]; - if (!(handleError !== undefined)) return [3 /*break*/, 7]; - _a.label = 3; - case 3: - _a.trys.push([3, 5, , 6]); - return [4 /*yield*/, handleError(err_1, resp)]; - case 4: - _a.sent(); - return [3 /*break*/, 6]; - case 5: - err_2 = _a.sent(); - setError(err_2); - return [3 /*break*/, 6]; - case 6: - return [3 /*break*/, 8]; - case 7: - setError(err_1); - _a.label = 8; - case 8: - return [3 /*break*/, 9]; - case 9: - return [2 /*return*/]; - } - }); - }); - }; - if (startLoading) { - var ctrl_1 = new AbortController(); - void effect(ctrl_1.signal); - return function () { - ctrl_1.abort(); - }; - } - return; - }, - [setError, consumeReq, fetch, handleResponse, handleError, startLoading] - ); - if (error) { - throw error; - } -}; -function useRethrowInRender() { - var _a = React.useState(undefined), - error = _a[0], - setError = _a[1]; - if (error) { - throw error; - } - return setError; -} - -var BaseRecipeModule = /** @class */ (function () { - /* - * Constructor. - */ - function BaseRecipeModule(config) { - this.config = config; - } - return BaseRecipeModule; -})(); - -function normaliseRecipeModuleConfig(config) { - var _this = this; - if (config === undefined) { - config = {}; - } - var onHandleEvent = config.onHandleEvent, - getRedirectionURL = config.getRedirectionURL, - preAPIHook = config.preAPIHook, - postAPIHook = config.postAPIHook; - if (onHandleEvent === undefined) { - // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function - onHandleEvent = function (_) {}; - } - if (getRedirectionURL === undefined) { - // eslint-disable-next-line @typescript-eslint/no-unused-vars - getRedirectionURL = function (_) { - return __awaiter(_this, void 0, void 0, function () { - return __generator(this, function (_a) { - return [2 /*return*/, undefined]; - }); - }); - }; - } - if (preAPIHook === undefined) { - // eslint-disable-next-line @typescript-eslint/no-unused-vars - preAPIHook = function (context) { - return __awaiter(_this, void 0, void 0, function () { - return __generator(this, function (_a) { - return [2 /*return*/, context]; - }); - }); - }; - } - if (postAPIHook === undefined) { - // eslint-disable-next-line @typescript-eslint/no-empty-function - postAPIHook = function () { - return __awaiter(_this, void 0, void 0, function () { - return __generator(this, function (_a) { - return [2 /*return*/]; - }); - }); - }; - } - var rootStyle = config.style === undefined ? "" : config.style; - return exports.__assign(exports.__assign({}, config), { - getRedirectionURL: getRedirectionURL, - onHandleEvent: onHandleEvent, - preAPIHook: preAPIHook, - postAPIHook: postAPIHook, - recipeRootStyle: rootStyle, - }); -} - -function normaliseMultitenancyConfig(config) { - return exports.__assign(exports.__assign({}, normaliseRecipeModuleConfig(config)), { - override: exports.__assign( - { - functions: function (originalImplementation) { - return originalImplementation; - }, - }, - config === null || config === void 0 ? void 0 : config.override - ), - }); -} -function hasIntersectingRecipes(tenantMethods, recipeList) { - return tenantMethods.firstFactors.some(function (factorId) { - return recipeList.some(function (r) { - return r.firstFactorIds.includes(factorId); - }); - }); -} - -/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. - * - * This software is licensed under the Apache License, Version 2.0 (the - * "License") as published by the Apache Software Foundation. - * - * You may not use this file except in compliance with the License. You may - * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - */ -/* - * Class. - */ -var Multitenancy = /** @class */ (function (_super) { - __extends(Multitenancy, _super); - function Multitenancy(config, webJSRecipe) { - if (webJSRecipe === void 0) { - webJSRecipe = MultitenancyWebJS__default.default; - } - var _this = _super.call(this, config) || this; - _this.webJSRecipe = webJSRecipe; - _this.recipeID = Multitenancy.RECIPE_ID; - _this.dynamicLoginMethodsCache = {}; - return _this; - } - Multitenancy.prototype.getCurrentDynamicLoginMethods = function (input) { - var _a; - return __awaiter(this, void 0, void 0, function () { - var userContext, tenantId, tenantMethods; - return __generator(this, function (_b) { - switch (_b.label) { - case 0: - if (SuperTokens.usesDynamicLoginMethods === false) { - return [2 /*return*/, undefined]; - } - userContext = utils.getNormalisedUserContext(input.userContext); - return [4 /*yield*/, Multitenancy.getInstanceOrThrow().webJSRecipe.getTenantId()]; - case 1: - tenantId = (_a = _b.sent()) !== null && _a !== void 0 ? _a : "public"; - if (this.dynamicLoginMethodsCache[tenantId] === undefined) { - this.dynamicLoginMethodsCache[tenantId] = Multitenancy.getDynamicLoginMethods({ - tenantId: tenantId, - userContext: userContext, - }); - } - return [4 /*yield*/, this.dynamicLoginMethodsCache[tenantId]]; - case 2: - tenantMethods = _b.sent(); - if ( - !hasIntersectingRecipes( - tenantMethods, - SuperTokens.getInstanceOrThrow().recipeList.filter(function (recipe) { - return "firstFactorIds" in recipe; - }) - ) - ) { - throw new Error( - "Initialized recipes have no overlap with core recipes or could not load login methods" - ); - } - return [2 /*return*/, tenantMethods]; - } - }); - }); - }; - Multitenancy.getDynamicLoginMethods = function (input) { - return __awaiter(this, void 0, void 0, function () { - var _a, thirdParty, firstFactors; - return __generator(this, function (_b) { - switch (_b.label) { - case 0: - return [4 /*yield*/, MultitenancyWebJS__default.default.getLoginMethods(input)]; - case 1: - (_a = _b.sent()), (thirdParty = _a.thirdParty), (firstFactors = _a.firstFactors); - return [ - 2 /*return*/, - { - thirdparty: thirdParty, - firstFactors: firstFactors, - }, - ]; - } - }); - }); - }; - Multitenancy.init = function (config) { - var normalisedConfig = normaliseMultitenancyConfig(config); - return { - recipeID: Multitenancy.RECIPE_ID, - authReact: function (appInfo) { - Multitenancy.instance = new Multitenancy( - exports.__assign(exports.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: Multitenancy.RECIPE_ID, - }) - ); - return Multitenancy.instance; - }, - webJS: MultitenancyWebJS__default.default.init(exports.__assign({}, normalisedConfig)), - }; - }; - Multitenancy.getInstanceOrThrow = function () { - if (Multitenancy.instance === undefined) { - var error = - "No instance of Multitenancy found. Make sure to call the Multitenancy.init method." + - "See https://supertokens.io/docs/multitenancy/quick-setup/frontend"; - // eslint-disable-next-line supertokens-auth-react/no-direct-window-object - if (typeof window === "undefined") { - error = error + SSR_ERROR; - } - throw Error(error); - } - return Multitenancy.instance; - }; - /* - * Tests methods. - */ - Multitenancy.reset = function () { - if (!isTest()) { - return; - } - Multitenancy.instance = undefined; - return; - }; - Multitenancy.RECIPE_ID = "multitenancy"; - return Multitenancy; -})(BaseRecipeModule); - -var TranslationController = /** @class */ (function () { - function TranslationController() { - this.handlers = new Map(); - } - TranslationController.prototype.emit = function (event, detail) { - var handlerList = this.handlers.get(event) || []; - for (var _i = 0, handlerList_1 = handlerList; _i < handlerList_1.length; _i++) { - var h = handlerList_1[_i]; - h(event, detail); - } - }; - TranslationController.prototype.on = function (event, handler) { - var handlerList = this.handlers.get(event) || []; - this.handlers.set(event, handlerList.concat(handler)); - }; - TranslationController.prototype.off = function (event, handler) { - var handlerList = this.handlers.get(event) || []; - this.handlers.set( - event, - handlerList.filter(function (h) { - return h !== handler; - }) - ); - }; - return TranslationController; -})(); -var CURRENT_LANGUAGE_COOKIE_NAME = "sCurrLanguage"; -function saveCurrentLanguage(language, cookieDomain) { - return __awaiter(this, void 0, void 0, function () { - return __generator(this, function (_b) { - switch (_b.label) { - case 0: - _b.trys.push([0, 2, , 3]); - return [4 /*yield*/, setFrontendCookie(CURRENT_LANGUAGE_COOKIE_NAME, language, cookieDomain)]; - case 1: - _b.sent(); - return [3 /*break*/, 3]; - case 2: - _b.sent(); - return [3 /*break*/, 3]; - case 3: - return [2 /*return*/]; - } - }); - }); -} -function getCurrentLanguageFromCookie() { - return __awaiter(this, void 0, void 0, function () { - return __generator(this, function (_b) { - switch (_b.label) { - case 0: - _b.trys.push([0, 2, , 3]); - return [4 /*yield*/, getCookieValue(CURRENT_LANGUAGE_COOKIE_NAME)]; - case 1: - return [2 /*return*/, _b.sent()]; - case 2: - _b.sent(); - // This can throw if we are not in a browser - // Since this is just loading a preference we can safely ignore the exception - return [2 /*return*/, null]; - case 3: - return [2 /*return*/]; - } - }); - }); -} - -/* Copyright (c) 2021, VRAI Labs and/or its affiliates. All rights reserved. - * - * This software is licensed under the Apache License, Version 2.0 (the - * "License") as published by the Apache Software Foundation. - * - * You may not use this file except in compliance with the License. You may - * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - */ -/* - * Class. - */ -var SuperTokens = /** @class */ (function () { - /* - * Constructor. - */ - function SuperTokens(config) { - var _this = this; - var _a, _b, _c, _d; - this.recipeList = []; - this.changeLanguage = function (lang) { - return __awaiter(_this, void 0, void 0, function () { - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - return [ - 4 /*yield*/, - saveCurrentLanguage(lang, this.languageTranslations.currentLanguageCookieScope), - ]; - case 1: - _a.sent(); - this.languageTranslations.translationEventSource.emit("LanguageChange", lang); - return [2 /*return*/]; - } - }); - }); - }; - this.redirectToAuth = function (options) { - return __awaiter(_this, void 0, void 0, function () { - var queryParams, redirectUrl; - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - queryParams = options.queryParams === undefined ? {} : options.queryParams; - if (options.show !== undefined) { - queryParams.show = options.show; - } - if (options.redirectBack === true) { - queryParams.redirectToPath = getCurrentNormalisedUrlPathWithQueryParamsAndFragments(); - } - return [ - 4 /*yield*/, - this.getRedirectUrl( - { - action: "TO_AUTH", - showSignIn: options.show === "signin", - }, - options.userContext - ), - ]; - case 1: - redirectUrl = _a.sent(); - if (redirectUrl === null) { - logDebugMessage("Skipping redirection because the user override returned null"); - return [2 /*return*/]; - } - redirectUrl = appendQueryParamsToURL(redirectUrl, queryParams); - return [2 /*return*/, this.redirectToUrl(redirectUrl, options.navigate)]; - } - }); - }); - }; - this.redirectToUrl = function (redirectUrl, navigate) { - return __awaiter(_this, void 0, void 0, function () { - return __generator(this, function (_a) { - doRedirection(this.appInfo, redirectUrl, navigate); - return [2 /*return*/]; - }); - }); - }; - this.redirect = function (context, navigate, queryParams, userContext) { - return __awaiter(_this, void 0, void 0, function () { - var redirectUrl; - return __generator(this, function (_a) { - switch (_a.label) { - case 0: - return [4 /*yield*/, this.getRedirectUrl(context, getNormalisedUserContext(userContext))]; - case 1: - redirectUrl = _a.sent(); - if (redirectUrl === null) { - logDebugMessage( - "Skipping redirection because the user override returned null for context ".concat( - JSON.stringify(context, null, 2) - ) - ); - return [2 /*return*/]; - } - redirectUrl = appendQueryParamsToURL(redirectUrl, queryParams); - return [ - 2 /*return*/, - SuperTokens.getInstanceOrThrow().redirectToUrl(redirectUrl, navigate), - ]; - } - }); - }); - }; - this.appInfo = normaliseInputAppInfoOrThrowError(config.appInfo); - if (config.recipeList === undefined || config.recipeList.length === 0) { - throw new Error( - "Please provide at least one recipe to the supertokens.init function call. See https://supertokens.io/docs/emailpassword/quick-setup/frontend" - ); - } - var translationConfig = config.languageTranslations === undefined ? {} : config.languageTranslations; - this.languageTranslations = { - defaultLanguage: translationConfig.defaultLanguage === undefined ? "en" : translationConfig.defaultLanguage, - currentLanguageCookieScope: - translationConfig.currentLanguageCookieScope !== undefined - ? normaliseCookieScopeOrThrowError(translationConfig.currentLanguageCookieScope) - : getDefaultCookieScope(), - userTranslationStore: translationConfig.translations !== undefined ? translationConfig.translations : {}, - translationEventSource: new TranslationController(), - userTranslationFunc: translationConfig.translationFunc, - }; - var enableDebugLogs = Boolean(config === null || config === void 0 ? void 0 : config.enableDebugLogs); - if (enableDebugLogs) { - enableLogging(); - } - this.userGetRedirectionURL = config.getRedirectionURL; - this.recipeList = config.recipeList.map(function (_a) { - var authReact = _a.authReact; - return authReact(_this.appInfo, enableDebugLogs); - }); - this.rootStyle = (_a = config.style) !== null && _a !== void 0 ? _a : ""; - this.privacyPolicyLink = config.privacyPolicyLink; - this.termsOfServiceLink = config.termsOfServiceLink; - this.useShadowDom = (_b = config.useShadowDom) !== null && _b !== void 0 ? _b : true; - this.defaultToSignUp = (_c = config.defaultToSignUp) !== null && _c !== void 0 ? _c : false; - this.disableAuthRoute = (_d = config.disableAuthRoute) !== null && _d !== void 0 ? _d : false; - } - /* - * Static Methods. - */ - SuperTokens.init = function (config) { - var _a; - cookieHandler.CookieHandlerReference.init(config.cookieHandler); - windowHandler.WindowHandlerReference.init(config.windowHandler); - if (SuperTokens.instance !== undefined) { - console.warn("SuperTokens was already initialized"); - return; - } - SuperTokens.usesDynamicLoginMethods = - (_a = config.usesDynamicLoginMethods) !== null && _a !== void 0 ? _a : false; - var recipes = - config.recipeList.find(function (recipe) { - return recipe.recipeID === Multitenancy.RECIPE_ID; - }) !== undefined - ? config.recipeList - : config.recipeList.concat(Multitenancy.init({})); - SuperTokensWebJS__default.default.init( - exports.__assign(exports.__assign({}, config), { - recipeList: recipes.map(function (_a) { - var webJS = _a.webJS; - return webJS; - }), - }) - ); - SuperTokens.instance = new SuperTokens(exports.__assign(exports.__assign({}, config), { recipeList: recipes })); - postSuperTokensInitCallbacks.PostSuperTokensInitCallbacks.runPostInitCallbacks(); - }; - SuperTokens.getInstanceOrThrow = function () { - if (SuperTokens.instance === undefined) { - var error = "SuperTokens must be initialized before calling this method."; - // eslint-disable-next-line supertokens-auth-react/no-direct-window-object - if (typeof window === "undefined") { - error = error + SSR_ERROR; - } - throw new Error(error); - } - return SuperTokens.instance; - }; - SuperTokens.prototype.getRecipeOrThrow = function (recipeId) { - var recipe = this.recipeList.find(function (recipe) { - return recipe.config.recipeId === recipeId; - }); - if (recipe === undefined) { - throw new Error("Missing recipe: ".concat(recipeId)); - } - return recipe; - }; - SuperTokens.prototype.loadTranslation = function (store) { - this.languageTranslations.translationEventSource.emit("TranslationLoaded", store); - }; - SuperTokens.prototype.getRedirectUrl = function (context, userContext) { - var _a; - return __awaiter(this, void 0, void 0, function () { - var userRes, redirectUrl; - return __generator(this, function (_b) { - switch (_b.label) { - case 0: - if (!this.userGetRedirectionURL) return [3 /*break*/, 2]; - return [4 /*yield*/, this.userGetRedirectionURL(context, userContext)]; - case 1: - userRes = _b.sent(); - if (userRes !== undefined) { - return [2 /*return*/, userRes]; - } - _b.label = 2; - case 2: - if (context.action === "TO_AUTH") { - redirectUrl = this.appInfo.websiteBasePath.getAsStringDangerous(); - return [2 /*return*/, appendTrailingSlashToURL(redirectUrl)]; - } else if (context.action === "SUCCESS") { - return [2 /*return*/, (_a = context.redirectToPath) !== null && _a !== void 0 ? _a : "/"]; - } - throw new Error("Should never come here: unexpected redirection context"); - } - }); - }); - }; - /* - * Tests methods. - */ - SuperTokens.reset = function () { - if (!isTest()) { - return; - } - SuperTokens.instance = undefined; - return; - }; - SuperTokens.usesDynamicLoginMethods = false; - return SuperTokens; -})(); -function doRedirection(appInfo, redirectUrl, navigate) { - try { - new URL(redirectUrl); // If full URL, no error thrown, skip in app redirection. - } catch (e) { - // For multi tenancy, If mismatch between websiteDomain and current location, prepend URL relative path with websiteDomain. - var origin_1 = getOriginOfPage().getAsStringDangerous(); - if (origin_1 !== appInfo.websiteDomain.getAsStringDangerous()) { - redirectUrl = "".concat(appInfo.websiteDomain.getAsStringDangerous()).concat(redirectUrl); - redirectWithFullPageReload(redirectUrl); - return; - } - // If navigate was provided, use to redirect without reloading. - if (navigate !== undefined) { - redirectWithNavigate(redirectUrl, navigate); - return; - } - } - // Otherwise, redirect in app. - redirectWithFullPageReload(redirectUrl); -} - -exports.BaseRecipeModule = BaseRecipeModule; -exports.Multitenancy = Multitenancy; -exports.SSR_ERROR = SSR_ERROR; -exports.ST_ROOT_ID = ST_ROOT_ID; -exports.SuperTokens = SuperTokens; -exports.__awaiter = __awaiter; -exports.__extends = __extends; -exports.__generator = __generator; -exports.__rest = __rest; -exports.__spreadArray = __spreadArray; -exports.appendQueryParamsToURL = appendQueryParamsToURL; -exports.clearErrorQueryParam = clearErrorQueryParam; -exports.clearQueryParams = clearQueryParams; -exports.getCurrentLanguageFromCookie = getCurrentLanguageFromCookie; -exports.getCurrentNormalisedUrlPath = getCurrentNormalisedUrlPath; -exports.getCurrentNormalisedUrlPathWithQueryParamsAndFragments = getCurrentNormalisedUrlPathWithQueryParamsAndFragments; -exports.getLocalStorage = getLocalStorage; -exports.getNormalisedUserContext = getNormalisedUserContext; -exports.getQueryParams = getQueryParams; -exports.getRedirectToPathFromURL = getRedirectToPathFromURL; -exports.getURLHash = getURLHash; -exports.isTest = isTest; -exports.logDebugMessage = logDebugMessage; -exports.matchRecipeIdUsingQueryParams = matchRecipeIdUsingQueryParams; -exports.mergeObjects = mergeObjects; -exports.normaliseRecipeModuleConfig = normaliseRecipeModuleConfig; -exports.redirectWithFullPageReload = redirectWithFullPageReload; -exports.removeFromLocalStorage = removeFromLocalStorage; -exports.setLocalStorage = setLocalStorage; -exports.updateQueryParam = updateQueryParam; -exports.useOnMountAPICall = useOnMountAPICall; -exports.useRethrowInRender = useRethrowInRender; -exports.validateForm = validateForm; diff --git a/lib/build/thirdparty-shared.js b/lib/build/thirdparty-shared.js index 626dfd0fe..c34e7f232 100644 --- a/lib/build/thirdparty-shared.js +++ b/lib/build/thirdparty-shared.js @@ -1,7 +1,6 @@ "use strict"; var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); -var superTokens = require("./superTokens.js"); var ThirdpartyWebJS = require("supertokens-web-js/recipe/thirdparty"); var index = require("./authRecipe-shared2.js"); var types = require("./multifactorauth-shared.js"); @@ -31,24 +30,24 @@ function ProviderButton(_a) { var providerStyleName = "provider".concat(providerName); return jsxRuntime.jsxs( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "button providerButton ".concat(providerStyleName) }, { children: [ logo !== undefined && jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "providerButtonLeft" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "providerButtonLogo" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "providerButtonLogoCenter" }, { children: logo } ) @@ -61,7 +60,7 @@ function ProviderButton(_a) { ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "providerButtonText" }, { children: [ @@ -120,9 +119,10 @@ var Provider = /** @class */ (function () { if (this.config.getRedirectURL) { return this.config.getRedirectURL(this.config.id); } - var domain = superTokens.SuperTokens.getInstanceOrThrow().appInfo.websiteDomain.getAsStringDangerous(); + var domain = + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().appInfo.websiteDomain.getAsStringDangerous(); var callbackPath = new NormalisedURLPath__default.default("/callback/".concat(this.config.id)); - var path = superTokens.SuperTokens.getInstanceOrThrow() + var path = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow() .appInfo.websiteBasePath.appendPath(callbackPath) .getAsStringDangerous(); return "".concat(domain).concat(path); @@ -137,18 +137,20 @@ var Provider = /** @class */ (function () { * Class. */ var ActiveDirectory = /** @class */ (function (_super) { - superTokens.__extends(ActiveDirectory, _super); + genericComponentOverrideContext.__extends(ActiveDirectory, _super); /* * Constructor. */ function ActiveDirectory(config) { var _this = - _super.call(this, superTokens.__assign({ id: "active-directory", name: "Active Directory" }, config)) || - this; + _super.call( + this, + genericComponentOverrideContext.__assign({ id: "active-directory", name: "Active Directory" }, config) + ) || this; _this.getLogo = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "18", height: "16", @@ -160,7 +162,7 @@ var ActiveDirectory = /** @class */ (function (_super) { children: [ jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { clipPath: "url(#clip0_402_84)" }, { children: [ @@ -187,7 +189,7 @@ var ActiveDirectory = /** @class */ (function (_super) { jsxRuntime.jsx("defs", { children: jsxRuntime.jsx( "clipPath", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "clip0_402_84" }, { children: jsxRuntime.jsx("rect", { @@ -221,7 +223,7 @@ var ActiveDirectory = /** @class */ (function (_super) { * Tests methods. */ ActiveDirectory.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } ActiveDirectory.instance = undefined; @@ -234,16 +236,17 @@ var ActiveDirectory = /** @class */ (function (_super) { * Class. */ var Apple = /** @class */ (function (_super) { - superTokens.__extends(Apple, _super); + genericComponentOverrideContext.__extends(Apple, _super); /* * Constructor. */ function Apple(config) { - var _this = _super.call(this, superTokens.__assign({ id: "apple", name: "Apple" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "apple", name: "Apple" }, config)) || this; _this.getLogo = function () { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "15.614", @@ -253,7 +256,7 @@ var Apple = /** @class */ (function (_super) { { children: jsxRuntime.jsxs( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "iconfinder_logo_brand_brands_logos_apple_ios_2993701", transform: "translate(-2)", @@ -312,9 +315,10 @@ var Apple = /** @class */ (function (_super) { return _this; } Apple.prototype.getRedirectURIOnProviderDashboard = function () { - var domain = superTokens.SuperTokens.getInstanceOrThrow().appInfo.apiDomain.getAsStringDangerous(); + var domain = + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().appInfo.apiDomain.getAsStringDangerous(); var callbackPath = new NormalisedURLPath__default$1.default("/callback/".concat(this.id)); - var path = superTokens.SuperTokens.getInstanceOrThrow() + var path = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow() .appInfo.apiBasePath.appendPath(callbackPath) .getAsStringDangerous(); return "".concat(domain).concat(path); @@ -334,7 +338,7 @@ var Apple = /** @class */ (function (_super) { * Tests methods. */ Apple.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Apple.instance = undefined; @@ -347,16 +351,20 @@ var Apple = /** @class */ (function (_super) { * Class. */ var Bitbucket = /** @class */ (function (_super) { - superTokens.__extends(Bitbucket, _super); + genericComponentOverrideContext.__extends(Bitbucket, _super); /* * Constructor. */ function Bitbucket(config) { - var _this = _super.call(this, superTokens.__assign({ id: "bitbucket", name: "Bitbucket" }, config)) || this; + var _this = + _super.call( + this, + genericComponentOverrideContext.__assign({ id: "bitbucket", name: "Bitbucket" }, config) + ) || this; _this.getLogo = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "19", height: "17", @@ -377,7 +385,7 @@ var Bitbucket = /** @class */ (function (_super) { jsxRuntime.jsx("defs", { children: jsxRuntime.jsxs( "linearGradient", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "paint0_linear_4108_67124", x1: "19.2748", @@ -417,7 +425,7 @@ var Bitbucket = /** @class */ (function (_super) { * Tests methods. */ Bitbucket.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Bitbucket.instance = undefined; @@ -430,16 +438,20 @@ var Bitbucket = /** @class */ (function (_super) { * Class. */ var BoxySAML = /** @class */ (function (_super) { - superTokens.__extends(BoxySAML, _super); + genericComponentOverrideContext.__extends(BoxySAML, _super); /* * Constructor. */ function BoxySAML(config) { - var _this = _super.call(this, superTokens.__assign({ id: "boxy-saml", name: "BoxySAML" }, config)) || this; + var _this = + _super.call( + this, + genericComponentOverrideContext.__assign({ id: "boxy-saml", name: "BoxySAML" }, config) + ) || this; _this.getLogo = function () { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "18", height: "18", @@ -475,7 +487,7 @@ var BoxySAML = /** @class */ (function (_super) { * Tests methods. */ BoxySAML.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } BoxySAML.instance = undefined; @@ -488,16 +500,18 @@ var BoxySAML = /** @class */ (function (_super) { * Class. */ var Discord = /** @class */ (function (_super) { - superTokens.__extends(Discord, _super); + genericComponentOverrideContext.__extends(Discord, _super); /* * Constructor. */ function Discord(config) { - var _this = _super.call(this, superTokens.__assign({ id: "discord", name: "Discord" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "discord", name: "Discord" }, config)) || + this; _this.getLogo = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "18", height: "14", @@ -509,7 +523,7 @@ var Discord = /** @class */ (function (_super) { children: [ jsxRuntime.jsx( "g", - superTokens.__assign( + genericComponentOverrideContext.__assign( { clipPath: "url(#clip0_4108_67056)" }, { children: jsxRuntime.jsx("path", { @@ -522,7 +536,7 @@ var Discord = /** @class */ (function (_super) { jsxRuntime.jsx("defs", { children: jsxRuntime.jsx( "clipPath", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "clip0_4108_67056" }, { children: jsxRuntime.jsx("rect", { @@ -556,7 +570,7 @@ var Discord = /** @class */ (function (_super) { * Tests methods. */ Discord.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Discord.instance = undefined; @@ -569,16 +583,18 @@ var Discord = /** @class */ (function (_super) { * Class. */ var Facebook = /** @class */ (function (_super) { - superTokens.__extends(Facebook, _super); + genericComponentOverrideContext.__extends(Facebook, _super); /* * Constructor. */ function Facebook(config) { - var _this = _super.call(this, superTokens.__assign({ id: "facebook", name: "Facebook" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "facebook", name: "Facebook" }, config)) || + this; _this.getLogo = function () { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { fill: "#1777F2", xmlns: "http://www.w3.org/2000/svg", @@ -611,7 +627,7 @@ var Facebook = /** @class */ (function (_super) { * Tests methods. */ Facebook.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Facebook.instance = undefined; @@ -624,16 +640,18 @@ var Facebook = /** @class */ (function (_super) { * Class. */ var Github = /** @class */ (function (_super) { - superTokens.__extends(Github, _super); + genericComponentOverrideContext.__extends(Github, _super); /* * Constructor. */ function Github(config) { - var _this = _super.call(this, superTokens.__assign({ id: "github", name: "GitHub" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "github", name: "GitHub" }, config)) || + this; _this.getLogo = function () { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "18", height: "17.556", viewBox: "0 0 18 17.556" }, { children: jsxRuntime.jsx("path", { @@ -663,7 +681,7 @@ var Github = /** @class */ (function (_super) { * Tests methods. */ Github.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Github.instance = undefined; @@ -676,16 +694,18 @@ var Github = /** @class */ (function (_super) { * Class. */ var Gitlab = /** @class */ (function (_super) { - superTokens.__extends(Gitlab, _super); + genericComponentOverrideContext.__extends(Gitlab, _super); /* * Constructor. */ function Gitlab(config) { - var _this = _super.call(this, superTokens.__assign({ id: "gitlab", name: "Gitlab" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "gitlab", name: "Gitlab" }, config)) || + this; _this.getLogo = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "18", height: "18", @@ -733,7 +753,7 @@ var Gitlab = /** @class */ (function (_super) { * Tests methods. */ Gitlab.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Gitlab.instance = undefined; @@ -746,16 +766,18 @@ var Gitlab = /** @class */ (function (_super) { * Class. */ var Google = /** @class */ (function (_super) { - superTokens.__extends(Google, _super); + genericComponentOverrideContext.__extends(Google, _super); /* * Constructor. */ function Google(config) { - var _this = _super.call(this, superTokens.__assign({ id: "google", name: "Google" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "google", name: "Google" }, config)) || + this; _this.getLogo = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 48 48", width: "18px", height: "18px" }, { children: [ @@ -797,7 +819,7 @@ var Google = /** @class */ (function (_super) { * Tests methods. */ Google.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Google.instance = undefined; @@ -807,15 +829,17 @@ var Google = /** @class */ (function (_super) { })(Provider); var GoogleWorkspaces = /** @class */ (function (_super) { - superTokens.__extends(GoogleWorkspaces, _super); + genericComponentOverrideContext.__extends(GoogleWorkspaces, _super); function GoogleWorkspaces(config) { var _this = - _super.call(this, superTokens.__assign({ id: "google-workspaces", name: "Google Workspaces" }, config)) || - this; + _super.call( + this, + genericComponentOverrideContext.__assign({ id: "google-workspaces", name: "Google Workspaces" }, config) + ) || this; _this.getLogo = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 48 48", width: "18px", height: "18px" }, { children: [ @@ -857,7 +881,7 @@ var GoogleWorkspaces = /** @class */ (function (_super) { * Tests methods. */ GoogleWorkspaces.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } GoogleWorkspaces.instance = undefined; @@ -870,16 +894,18 @@ var GoogleWorkspaces = /** @class */ (function (_super) { * Class. */ var LinkedIn = /** @class */ (function (_super) { - superTokens.__extends(LinkedIn, _super); + genericComponentOverrideContext.__extends(LinkedIn, _super); /* * Constructor. */ function LinkedIn(config) { - var _this = _super.call(this, superTokens.__assign({ id: "linkedin", name: "LinkedIn" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "linkedin", name: "LinkedIn" }, config)) || + this; _this.getLogo = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 48 48", width: "20", height: "20" }, { children: [ @@ -913,7 +939,7 @@ var LinkedIn = /** @class */ (function (_super) { * Tests methods. */ LinkedIn.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } LinkedIn.instance = undefined; @@ -926,16 +952,17 @@ var LinkedIn = /** @class */ (function (_super) { * Class. */ var Okta = /** @class */ (function (_super) { - superTokens.__extends(Okta, _super); + genericComponentOverrideContext.__extends(Okta, _super); /* * Constructor. */ function Okta(config) { - var _this = _super.call(this, superTokens.__assign({ id: "okta", name: "Okta" }, config)) || this; + var _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "okta", name: "Okta" }, config)) || this; _this.getLogo = function () { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "18", height: "18", @@ -971,7 +998,7 @@ var Okta = /** @class */ (function (_super) { * Tests methods. */ Okta.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Okta.instance = undefined; @@ -984,7 +1011,7 @@ var Okta = /** @class */ (function (_super) { * Class. */ var Twitter = /** @class */ (function (_super) { - superTokens.__extends(Twitter, _super); + genericComponentOverrideContext.__extends(Twitter, _super); /* * Constructor. */ @@ -996,13 +1023,14 @@ var Twitter = /** @class */ (function (_super) { if (normalisedUseLegacyTwitterLogo) { name = "Twitter"; } - _this = _super.call(this, superTokens.__assign({ id: "twitter", name: name }, config)) || this; + _this = + _super.call(this, genericComponentOverrideContext.__assign({ id: "twitter", name: name }, config)) || this; _this.useLegacyTwitterLogo = false; _this.getLogo = function () { if (_this.useLegacyTwitterLogo === true) { return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "20.129", @@ -1026,7 +1054,7 @@ var Twitter = /** @class */ (function (_super) { } return jsxRuntime.jsx( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "16", height: "16", viewBox: "0 0 1200 1227" }, { children: jsxRuntime.jsx("path", { @@ -1055,7 +1083,7 @@ var Twitter = /** @class */ (function (_super) { * Tests methods. */ Twitter.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } Twitter.instance = undefined; @@ -1066,11 +1094,11 @@ var Twitter = /** @class */ (function (_super) { var getFunctionOverrides = function (recipeId, onHandleEvent) { return function (originalImp) { - return superTokens.__assign(superTokens.__assign({}, originalImp), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImp), { signInAndUp: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var payloadBeforeCall, response, payloadAfterCall; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: _c.trys.push([0, 2, , 3]); @@ -1132,13 +1160,18 @@ var getFunctionOverrides = function (recipeId, onHandleEvent) { setStateAndOtherInfoToStorage: function (input) { var _a; var loginChallenge = - (_a = superTokens.getQueryParams("loginChallenge")) !== null && _a !== void 0 ? _a : undefined; + (_a = genericComponentOverrideContext.getQueryParams("loginChallenge")) !== null && _a !== void 0 + ? _a + : undefined; return originalImp.setStateAndOtherInfoToStorage({ - state: superTokens.__assign(superTokens.__assign({}, input.state), { - rid: recipeId, - oauth2LoginChallenge: loginChallenge, - redirectToPath: superTokens.getRedirectToPathFromURL(), - }), + state: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, input.state), + { + rid: recipeId, + oauth2LoginChallenge: loginChallenge, + redirectToPath: genericComponentOverrideContext.getRedirectToPathFromURL(), + } + ), userContext: input.userContext, }); }, @@ -1150,7 +1183,7 @@ var getFunctionOverrides = function (recipeId, onHandleEvent) { * Class. */ var Custom = /** @class */ (function (_super) { - superTokens.__extends(Custom, _super); + genericComponentOverrideContext.__extends(Custom, _super); /* * Constructor. */ @@ -1198,7 +1231,7 @@ function normaliseThirdPartyConfig(config) { var signInAndUpFeature = normaliseSignInAndUpFeature(config.signInAndUpFeature); var oAuthCallbackScreen = config.oAuthCallbackScreen === undefined ? {} : { style: config.oAuthCallbackScreen.style }; - var override = superTokens.__assign( + var override = genericComponentOverrideContext.__assign( { functions: function (originalImplementation) { return originalImplementation; @@ -1206,11 +1239,10 @@ function normaliseThirdPartyConfig(config) { }, config.override ); - return superTokens.__assign(superTokens.__assign({}, utils.normaliseAuthRecipe(config)), { - signInAndUpFeature: signInAndUpFeature, - oAuthCallbackScreen: oAuthCallbackScreen, - override: override, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, utils.normaliseAuthRecipe(config)), + { signInAndUpFeature: signInAndUpFeature, oAuthCallbackScreen: oAuthCallbackScreen, override: override } + ); } function normaliseSignInAndUpFeature(config) { if (config === undefined) { @@ -1263,16 +1295,18 @@ function matchRecipeIdUsingState(recipe, userContext) { return false; } function redirectToThirdPartyLogin(input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var loginMethods, tenantProviders, providers, provider, response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [ 4 /*yield*/, - superTokens.Multitenancy.getInstanceOrThrow().getCurrentDynamicLoginMethods({ - userContext: input.userContext, - }), + genericComponentOverrideContext.Multitenancy.getInstanceOrThrow().getCurrentDynamicLoginMethods( + { + userContext: input.userContext, + } + ), ]; case 1: loginMethods = _a.sent(); @@ -1305,7 +1339,7 @@ function redirectToThirdPartyLogin(input) { ]; case 2: response = _a.sent(); - superTokens.redirectWithFullPageReload(response); + genericComponentOverrideContext.redirectWithFullPageReload(response); return [2 /*return*/, { status: "OK" }]; } }); @@ -1331,7 +1365,7 @@ var mergeProviders = function (_a) { twitter: Twitter, facebook: Facebook, }; - var usesDynamicLoginMethods = superTokens.SuperTokens.usesDynamicLoginMethods === true; + var usesDynamicLoginMethods = genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods === true; if ( usesDynamicLoginMethods === false && (clientProviders === null || clientProviders === void 0 ? void 0 : clientProviders.length) === 0 @@ -1361,11 +1395,14 @@ var mergeProviders = function (_a) { if (provider !== undefined) { providers.push( Custom.init( - superTokens.__assign(superTokens.__assign({}, provider.config), { - id: tenantProvider.id, - name: tenantProvider.name, - buttonComponent: provider.getButton(tenantProvider.name), - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, provider.config), + { + id: tenantProvider.id, + name: tenantProvider.name, + buttonComponent: provider.getButton(tenantProvider.name), + } + ) ) ); } else { @@ -1409,14 +1446,14 @@ var mergeProviders = function (_a) { * Class. */ var ThirdParty = /** @class */ (function (_super) { - superTokens.__extends(ThirdParty, _super); + genericComponentOverrideContext.__extends(ThirdParty, _super); function ThirdParty(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = ThirdpartyWebJS__default.default; } var _this = this; if ( - superTokens.SuperTokens.usesDynamicLoginMethods === false && + genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods === false && config.signInAndUpFeature.providers.length === 0 ) { throw new Error("ThirdParty signInAndUpFeature providers array cannot be empty."); @@ -1429,8 +1466,8 @@ var ThirdParty = /** @class */ (function (_super) { * Instance methods. */ _this.getDefaultRedirectionURL = function (context) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [2 /*return*/, this.getAuthRecipeDefaultRedirectionURL(context)]; }); }); @@ -1447,24 +1484,30 @@ var ThirdParty = /** @class */ (function (_super) { recipeID: ThirdParty.RECIPE_ID, authReact: function (appInfo) { ThirdParty.instance = new ThirdParty( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: ThirdParty.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: ThirdParty.RECIPE_ID } + ) ); return ThirdParty.instance; }, webJS: ThirdpartyWebJS__default.default.init( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - override: { - functions: function (originalImpl, builder) { - var functions = getFunctionOverrides(ThirdParty.RECIPE_ID, normalisedConfig.onHandleEvent); - builder.override(functions); - builder.override(normalisedConfig.override.functions); - return originalImpl; + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + override: { + functions: function (originalImpl, builder) { + var functions = getFunctionOverrides( + ThirdParty.RECIPE_ID, + normalisedConfig.onHandleEvent + ); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, }, - }, - }) + } + ) ), }; }; @@ -1475,7 +1518,7 @@ var ThirdParty = /** @class */ (function (_super) { "See https://supertokens.io/docs/thirdparty/quick-setup/frontend"; // eslint-disable-next-line supertokens-auth-react/no-direct-window-object if (typeof window === "undefined") { - error = error + superTokens.SSR_ERROR; + error = error + genericComponentOverrideContext.SSR_ERROR; } throw Error(error); } @@ -1485,7 +1528,7 @@ var ThirdParty = /** @class */ (function (_super) { * Tests methods. */ ThirdParty.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } ThirdParty.instance = undefined; diff --git a/lib/build/thirdparty.js b/lib/build/thirdparty.js index 679cc22d8..cfbb03296 100644 --- a/lib/build/thirdparty.js +++ b/lib/build/thirdparty.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var recipe = require("./thirdparty-shared.js"); require("supertokens-web-js"); require("supertokens-web-js/utils/cookieHandler"); @@ -13,7 +13,6 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); -require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("supertokens-web-js/recipe/thirdparty"); require("./authRecipe-shared2.js"); @@ -49,12 +48,12 @@ var Wrapper = /** @class */ (function () { return recipe.ThirdParty.init(config); }; Wrapper.signOut = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.ThirdParty.getInstanceOrThrow().signOut({ - userContext: superTokens.getNormalisedUserContext( + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }), @@ -63,16 +62,16 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.redirectToThirdPartyLogin = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var recipeInstance; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { recipeInstance = recipe.ThirdParty.getInstanceOrThrow(); return [ 2 /*return*/, recipe.redirectToThirdPartyLogin({ thirdPartyId: input.thirdPartyId, config: recipeInstance.config, - userContext: superTokens.getNormalisedUserContext(input.userContext), + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), recipeImplementation: recipeInstance.webJSRecipe, }), ]; @@ -81,21 +80,21 @@ var Wrapper = /** @class */ (function () { }; Wrapper.getStateAndOtherInfoFromStorage = function (input) { return recipe.ThirdParty.getInstanceOrThrow().webJSRecipe.getStateAndOtherInfoFromStorage( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) ); }; Wrapper.getAuthorisationURLWithQueryParamsAndSetState = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.ThirdParty.getInstanceOrThrow().webJSRecipe.getAuthorisationURLWithQueryParamsAndSetState( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext(input.userContext), + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext(input.userContext), }) ), ]; @@ -103,13 +102,13 @@ var Wrapper = /** @class */ (function () { }); }; Wrapper.signInAndUp = function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe.ThirdParty.getInstanceOrThrow().webJSRecipe.signInAndUp( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) diff --git a/lib/build/thirdpartyprebuiltui.js b/lib/build/thirdpartyprebuiltui.js index d2c6f67b9..de2b8a93e 100644 --- a/lib/build/thirdpartyprebuiltui.js +++ b/lib/build/thirdpartyprebuiltui.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); var uiEntry = require("./index2.js"); @@ -23,7 +23,6 @@ require("supertokens-web-js/utils/normalisedURLDomain"); require("./translationContext.js"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./multifactorauth-shared2.js"); require("supertokens-web-js/recipe/multifactorauth"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); @@ -97,9 +96,9 @@ var ThemeBase = function (_a) { var ThirdPartySignInAndUpProvidersForm = function (props) { var userContext = uiEntry.useUserContext(); var signInClick = function (providerId) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var response, generalError, e_1; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 5, , 6]); @@ -154,12 +153,12 @@ var ThirdPartySignInAndUpProvidersForm = function (props) { children: props.providers.map(function (provider) { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "providerContainer" }, { children: jsxRuntime.jsx( "span", - superTokens.__assign( + genericComponentOverrideContext.__assign( { onClick: function () { return signInClick(provider.id); @@ -178,16 +177,16 @@ var ThirdPartySignInAndUpProvidersForm = function (props) { var ProvidersForm = uiEntry.withOverride("ThirdPartySignInAndUpProvidersForm", ThirdPartySignInAndUpProvidersForm); var SignInAndUpThemeWrapper = function (props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [ @@ -196,7 +195,7 @@ var SignInAndUpThemeWrapper = function (props) { props.config.signInAndUpFeature.style, ], }, - { children: jsxRuntime.jsx(ProvidersForm, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(ProvidersForm, genericComponentOverrideContext.__assign({}, props)) } ) ), } @@ -225,7 +224,7 @@ function useChildProps( return React.useMemo( function () { var tenantProviders; - if (superTokens.SuperTokens.usesDynamicLoginMethods) { + if (genericComponentOverrideContext.SuperTokens.usesDynamicLoginMethods) { if (dynamicLoginMethods.loaded === false) { throw new Error("Component requiring dynamicLoginMethods rendered without FeatureWrapper."); } else { @@ -267,15 +266,21 @@ var SignInAndUpFeature = function (props) { props.navigate, props.userContext ); - var themeProps = superTokens.__assign(superTokens.__assign({}, childProps), { providers: childProps.providers }); + var themeProps = genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, childProps), + { providers: childProps.providers } + ); return jsxRuntime.jsxs(React.Fragment, { children: [ props.children === undefined && - jsxRuntime.jsx(SignInAndUpThemeWrapper, superTokens.__assign({}, themeProps)), + jsxRuntime.jsx(SignInAndUpThemeWrapper, genericComponentOverrideContext.__assign({}, themeProps)), props.children && React__namespace.Children.map(props.children, function (child) { if (React__namespace.isValidElement(child)) { - return React__namespace.cloneElement(child, superTokens.__assign({}, childProps)); + return React__namespace.cloneElement( + child, + genericComponentOverrideContext.__assign({}, childProps) + ); } return child; }), @@ -286,21 +291,21 @@ var SignInAndUpFeatureWrapper = function (props) { var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( authCompWrapper.AuthComponentWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipeComponentOverrides: recipeComponentOverrides }, - { children: jsxRuntime.jsx(SignInAndUpFeature, superTokens.__assign({}, props)) } + { children: jsxRuntime.jsx(SignInAndUpFeature, genericComponentOverrideContext.__assign({}, props)) } ) ); }; var getModifiedRecipeImplementation = function (origImpl) { - return superTokens.__assign({}, origImpl); + return genericComponentOverrideContext.__assign({}, origImpl); }; /* * Component. */ var ThirdPartySignInAndUpCallbackTheme = /** @class */ (function (_super) { - superTokens.__extends(ThirdPartySignInAndUpCallbackTheme, _super); + genericComponentOverrideContext.__extends(ThirdPartySignInAndUpCallbackTheme, _super); function ThirdPartySignInAndUpCallbackTheme() { /* * Methods. @@ -309,17 +314,17 @@ var ThirdPartySignInAndUpCallbackTheme = /** @class */ (function (_super) { _this.render = function () { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "spinner" }, { children: jsxRuntime.jsx(uiEntry.SpinnerIcon, {}) } ) @@ -340,11 +345,11 @@ var SignInAndUpCallbackThemeWithOverride = uiEntry.withOverride( ThirdPartySignInAndUpCallbackTheme ); var SignInAndUpCallbackTheme = function (props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); return jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, props.config.signInAndUpFeature.style], @@ -355,26 +360,29 @@ var SignInAndUpCallbackTheme = function (props) { }; var defaultTranslationsThirdParty = { - en: superTokens.__assign(superTokens.__assign({}, uiEntry.defaultTranslationsCommon.en), { - THIRD_PARTY_PROVIDER_DEFAULT_BTN_START: "Continue with ", - THIRD_PARTY_PROVIDER_DEFAULT_BTN_END: "", - THIRD_PARTY_ERROR_NO_EMAIL: "Could not retrieve email. Please try a different method.", - /* - * The following are error messages from our backend SDK. - * These are returned as full messages to preserver compatibilty, but they work just like the keys above. - * They are shown as is by default (setting the value to undefined will display the raw translation key) - */ - "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_004)": - undefined, - "Cannot sign in / up because new email cannot be applied to existing account. Please contact support. (ERR_CODE_005)": - undefined, - "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_006)": - undefined, - "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_020)": undefined, - "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_021)": undefined, - "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_022)": undefined, - "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_023)": undefined, - }), + en: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, uiEntry.defaultTranslationsCommon.en), + { + THIRD_PARTY_PROVIDER_DEFAULT_BTN_START: "Continue with ", + THIRD_PARTY_PROVIDER_DEFAULT_BTN_END: "", + THIRD_PARTY_ERROR_NO_EMAIL: "Could not retrieve email. Please try a different method.", + /* + * The following are error messages from our backend SDK. + * These are returned as full messages to preserver compatibilty, but they work just like the keys above. + * They are shown as is by default (setting the value to undefined will display the raw translation key) + */ + "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_004)": + undefined, + "Cannot sign in / up because new email cannot be applied to existing account. Please contact support. (ERR_CODE_005)": + undefined, + "Cannot sign in / up due to security reasons. Please try a different login method or contact support. (ERR_CODE_006)": + undefined, + "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_020)": undefined, + "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_021)": undefined, + "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_022)": undefined, + "Cannot sign in / up due to security reasons. Please contact support. (ERR_CODE_023)": undefined, + } + ), }; var SignInAndUpCallback$1 = function (props) { @@ -382,13 +390,13 @@ var SignInAndUpCallback$1 = function (props) { if (props.userContext !== undefined) { userContext = props.userContext; } - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); var verifyCode = React.useCallback( function () { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var payloadBeforeCall; var _b; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: _c.trys.push([0, 2, , 3]); @@ -428,15 +436,15 @@ var SignInAndUpCallback$1 = function (props) { function (_a) { var response = _a.response, payloadBeforeCall = _a.payloadBeforeCall; - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var payloadAfterCall, stateResponse, redirectToPath, loginChallenge; - return superTokens.__generator(this, function (_c) { + return genericComponentOverrideContext.__generator(this, function (_c) { switch (_c.label) { case 0: if (response.status === "NO_EMAIL_GIVEN_BY_PROVIDER") { return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: "no_email_present", @@ -449,7 +457,7 @@ var SignInAndUpCallback$1 = function (props) { if (response.status === "SIGN_IN_UP_NOT_ALLOWED") { return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: response.status, @@ -536,9 +544,9 @@ var SignInAndUpCallback$1 = function (props) { ); var handleError = React.useCallback( function (err) { - return superTokens.__awaiter(void 0, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(void 0, void 0, void 0, function () { var invalidClaims, evInstance; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: if ( @@ -585,7 +593,7 @@ var SignInAndUpCallback$1 = function (props) { if (STGeneralError__default.default.isThisError(err)) { return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: "custom", @@ -598,7 +606,7 @@ var SignInAndUpCallback$1 = function (props) { } return [ 2 /*return*/, - superTokens.SuperTokens.getInstanceOrThrow().redirectToAuth({ + genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().redirectToAuth({ navigate: props.navigate, queryParams: { error: "signin", @@ -613,18 +621,18 @@ var SignInAndUpCallback$1 = function (props) { }, [props.navigate, userContext] ); - superTokens.useOnMountAPICall(verifyCode, handleVerifyResponse, handleError); + genericComponentOverrideContext.useOnMountAPICall(verifyCode, handleVerifyResponse, handleError); var recipeComponentOverrides = props.useComponentOverrides(); return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { - useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, defaultStore: defaultTranslationsThirdParty, }, { @@ -644,7 +652,7 @@ var SignInAndUpCallback$1 = function (props) { }; var ThirdPartyPreBuiltUI = /** @class */ (function (_super) { - superTokens.__extends(ThirdPartyPreBuiltUI, _super); + genericComponentOverrideContext.__extends(ThirdPartyPreBuiltUI, _super); function ThirdPartyPreBuiltUI(recipeInstance) { var _this = _super.call(this) || this; _this.recipeInstance = recipeInstance; @@ -677,19 +685,21 @@ var ThirdPartyPreBuiltUI = /** @class */ (function (_super) { if (componentName === "signinupcallback") { return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( session.SessionAuth, - superTokens.__assign( + genericComponentOverrideContext.__assign( { requireAuth: false, doRedirection: false }, { children: jsxRuntime.jsx( SignInAndUpCallback$1, - superTokens.__assign({ recipe: _this.recipeInstance }, props, { - useComponentOverrides: useComponentOverrides, - }) + genericComponentOverrideContext.__assign( + { recipe: _this.recipeInstance }, + props, + { useComponentOverrides: useComponentOverrides } + ) ), } ) @@ -734,7 +744,7 @@ var ThirdPartyPreBuiltUI = /** @class */ (function (_super) { component: function (props) { return jsxRuntime.jsx( SignInAndUpFeatureWrapper, - superTokens.__assign({}, props, { + genericComponentOverrideContext.__assign({}, props, { recipe: _this.recipeInstance, useComponentOverrides: recipe.useContext, }), @@ -749,7 +759,7 @@ var ThirdPartyPreBuiltUI = /** @class */ (function (_super) { }; // For tests ThirdPartyPreBuiltUI.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } ThirdPartyPreBuiltUI.instance = undefined; diff --git a/lib/build/totp-shared.js b/lib/build/totp-shared.js index 19bcbbaf7..ce1ea7bc5 100644 --- a/lib/build/totp-shared.js +++ b/lib/build/totp-shared.js @@ -1,7 +1,6 @@ "use strict"; var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); -var superTokens = require("./superTokens.js"); var TOTPWebJS = require("supertokens-web-js/recipe/totp"); var postSuperTokensInitCallbacks = require("supertokens-web-js/utils/postSuperTokensInitCallbacks"); var jsxRuntime = require("react/jsx-runtime"); @@ -22,7 +21,7 @@ var _a = genericComponentOverrideContext.createGenericComponentsOverrideContext( var TOTPIcon = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { width: "20", height: "19", viewBox: "0 0 20 19", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, { children: [ @@ -35,7 +34,7 @@ var TOTPIcon = function () { jsxRuntime.jsx("defs", { children: jsxRuntime.jsxs( "linearGradient", - superTokens.__assign( + genericComponentOverrideContext.__assign( { id: "paint0_linear_4901_3396", x1: "10", @@ -61,11 +60,11 @@ var TOTPIcon = function () { var getFunctionOverrides = function (onHandleEvent) { return function (originalImp) { - return superTokens.__assign(superTokens.__assign({}, originalImp), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImp), { createDevice: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.createDevice(input)]; @@ -84,9 +83,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, verifyDevice: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.verifyDevice(input)]; @@ -106,9 +105,9 @@ var getFunctionOverrides = function (onHandleEvent) { }); }, verifyCode: function (input) { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var response; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImp.verifyCode(input)]; @@ -147,7 +146,7 @@ function normaliseMultiFactorAuthFeature(config) { if (config === undefined) { config = {}; } - var override = superTokens.__assign( + var override = genericComponentOverrideContext.__assign( { functions: function (originalImplementation) { return originalImplementation; @@ -155,23 +154,29 @@ function normaliseMultiFactorAuthFeature(config) { }, config.override ); - return superTokens.__assign(superTokens.__assign({}, superTokens.normaliseRecipeModuleConfig(config)), { - totpMFAScreen: superTokens.__assign( - { - disableDefaultUI: false, - blockedScreenStyle: "", - setupScreenStyle: "", - verificationScreenStyle: "", - loadingScreenStyle: "", - }, - config.totpMFAScreen + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign( + {}, + genericComponentOverrideContext.normaliseRecipeModuleConfig(config) ), - override: override, - }); + { + totpMFAScreen: genericComponentOverrideContext.__assign( + { + disableDefaultUI: false, + blockedScreenStyle: "", + setupScreenStyle: "", + verificationScreenStyle: "", + loadingScreenStyle: "", + }, + config.totpMFAScreen + ), + override: override, + } + ); } function totpCodeValidate(value) { - return superTokens.__awaiter(this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { if (typeof value !== "string") { return [2 /*return*/, "GENERAL_ERROR_TOTP_NON_STRING"]; } @@ -205,7 +210,7 @@ var totpFactor = { logo: TOTPIcon, }; var TOTP = /** @class */ (function (_super) { - superTokens.__extends(TOTP, _super); + genericComponentOverrideContext.__extends(TOTP, _super); function TOTP(config, webJSRecipe) { if (webJSRecipe === void 0) { webJSRecipe = TOTPWebJS__default.default; @@ -215,8 +220,8 @@ var TOTP = /** @class */ (function (_super) { _this.recipeID = TOTP.RECIPE_ID; // eslint-disable-next-line @typescript-eslint/no-unused-vars _this.getDefaultRedirectionURL = function (_context) { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { throw new Error("Should never come here"); }); }); @@ -235,24 +240,27 @@ var TOTP = /** @class */ (function (_super) { recipeID: TOTP.RECIPE_ID, authReact: function (appInfo) { TOTP.instance = new TOTP( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - appInfo: appInfo, - recipeId: TOTP.RECIPE_ID, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { appInfo: appInfo, recipeId: TOTP.RECIPE_ID } + ) ); return TOTP.instance; }, webJS: TOTPWebJS__default.default.init( - superTokens.__assign(superTokens.__assign({}, normalisedConfig), { - override: { - functions: function (originalImpl, builder) { - var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); - builder.override(functions); - builder.override(normalisedConfig.override.functions); - return originalImpl; + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, normalisedConfig), + { + override: { + functions: function (originalImpl, builder) { + var functions = getFunctionOverrides(normalisedConfig.onHandleEvent); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, }, - }, - }) + } + ) ), }; }; @@ -264,7 +272,7 @@ var TOTP = /** @class */ (function (_super) { var error = "No instance of TOTP found. Make sure to call the TOTP.init method."; // eslint-disable-next-line supertokens-auth-react/no-direct-window-object if (typeof window === "undefined") { - error = error + superTokens.SSR_ERROR; + error = error + genericComponentOverrideContext.SSR_ERROR; } throw Error(error); } diff --git a/lib/build/totp.js b/lib/build/totp.js index 61a7a7d57..05a5da4c6 100644 --- a/lib/build/totp.js +++ b/lib/build/totp.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var recipe = require("./totp-shared.js"); require("supertokens-web-js"); require("supertokens-web-js/utils/cookieHandler"); @@ -13,7 +13,6 @@ require("supertokens-web-js/utils"); require("react"); require("supertokens-web-js/utils/normalisedURLDomain"); require("supertokens-web-js/utils/normalisedURLPath"); -require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("supertokens-web-js/recipe/totp"); require("./multifactorauth-shared2.js"); @@ -46,8 +45,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.createDevice = function (input) { return recipe.TOTP.getInstanceOrThrow().webJSRecipe.createDevice( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -55,8 +54,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.verifyCode = function (input) { return recipe.TOTP.getInstanceOrThrow().webJSRecipe.verifyCode( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -64,8 +63,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.verifyDevice = function (input) { return recipe.TOTP.getInstanceOrThrow().webJSRecipe.verifyDevice( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -73,8 +72,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.removeDevice = function (input) { return recipe.TOTP.getInstanceOrThrow().webJSRecipe.removeDevice( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) @@ -82,8 +81,8 @@ var Wrapper = /** @class */ (function () { }; Wrapper.listDevices = function (input) { return recipe.TOTP.getInstanceOrThrow().webJSRecipe.listDevices( - superTokens.__assign(superTokens.__assign({}, input), { - userContext: superTokens.getNormalisedUserContext( + genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, input), { + userContext: genericComponentOverrideContext.getNormalisedUserContext( input === null || input === void 0 ? void 0 : input.userContext ), }) diff --git a/lib/build/totpprebuiltui.js b/lib/build/totpprebuiltui.js index 72c1c7604..3b1125a98 100644 --- a/lib/build/totpprebuiltui.js +++ b/lib/build/totpprebuiltui.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var NormalisedURLPath = require("supertokens-web-js/utils/normalisedURLPath"); var uiEntry = require("./index2.js"); @@ -23,7 +23,6 @@ require("supertokens-web-js/utils"); require("supertokens-web-js/utils/normalisedURLDomain"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./oauth2provider-shared.js"); require("supertokens-web-js/recipe/oauth2provider"); require("./recipeModule-shared.js"); @@ -95,7 +94,7 @@ var ThemeBase = function (_a) { var BlockedIcon = function () { return jsxRuntime.jsxs( "svg", - superTokens.__assign( + genericComponentOverrideContext.__assign( { xmlns: "http://www.w3.org/2000/svg", width: "65", height: "65", viewBox: "0 0 65 65", fill: "none" }, { children: [ @@ -147,7 +146,7 @@ var RetryButton = function (_a) { ); return jsxRuntime.jsx( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { type: "button", disabled: secsUntilRetry !== undefined, @@ -182,26 +181,26 @@ var TOTPBlockedScreen = function (props) { var t = translationContext.useTranslation(); return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container totp-mfa blockedScreen" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row noFormRow" }, { children: [ jsxRuntime.jsx(BlockedIcon, {}), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle" }, { children: t("TOTP_BLOCKED_TITLE") } ) ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: t("TOTP_BLOCKED_SUBTITLE") } ) @@ -219,7 +218,7 @@ var TOTPBlockedScreen = function (props) { ), jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: props.onSignOutClicked, @@ -247,17 +246,17 @@ var BlockedScreen = uiEntry.withOverride("TOTPBlockedScreen", TOTPBlockedScreen) var TOTPLoadingScreen = function () { return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container delayedRender totp-mfa loadingScreen" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "spinner delayedRender" }, { children: jsxRuntime.jsx(uiEntry.SpinnerIcon, {}) } ) @@ -294,10 +293,10 @@ var CodeForm = uiEntry.withOverride("TOTPCodeForm", function TOTPCodeForm(props) onSuccess: props.onSuccess, buttonLabel: "TOTP_CODE_CONTINUE_BUTTON", callAPI: function (formFields) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var totp, response; var _a; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: totp = @@ -362,12 +361,12 @@ var CodeVerificationFooter = uiEntry.withOverride( var t = translationContext.useTranslation(); return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "footerLinkGroupVert totp-mfa codeVerificationFooter" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: onSignOutClicked, @@ -396,7 +395,7 @@ var CodeVerificationHeader = uiEntry.withOverride( children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle withBackButton totp-mfa codeVerificationHeader" }, { children: [ @@ -415,7 +414,7 @@ var CodeVerificationHeader = uiEntry.withOverride( ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: t("TOTP_CODE_VERIFICATION_HEADER_SUBTITLE") } ) @@ -3356,7 +3355,7 @@ var DeviceInfoSection = uiEntry.withOverride("TOTPDeviceInfoSection", function T children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "totpDeviceInfoWithQR totp-mfa deviceInfoSection" }, { children: [ @@ -3367,14 +3366,14 @@ var DeviceInfoSection = uiEntry.withOverride("TOTPDeviceInfoSection", function T }), jsxRuntime.jsxs( "span", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "showTOTPSecret" }, { children: [ t("TOTP_SHOW_SECRET_START"), jsxRuntime.jsx( "button", - superTokens.__assign( + genericComponentOverrideContext.__assign( { type: "button", onClick: props.onShowSecretClicked, @@ -3391,7 +3390,7 @@ var DeviceInfoSection = uiEntry.withOverride("TOTPDeviceInfoSection", function T props.showSecret && jsxRuntime.jsx( "span", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "totpSecret" }, { children: props.deviceInfo.secret } ) @@ -3410,12 +3409,12 @@ var DeviceSetupFooter = uiEntry.withOverride("TOTPDeviceSetupFooter", function T var t = translationContext.useTranslation(); return jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "footerLinkGroupVert totp-mfa deviceSetupFooter" }, { children: jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "secondaryText secondaryLinkWithLeftArrow", onClick: onSignOutClicked }, { children: [ @@ -3438,7 +3437,7 @@ var DeviceSetupHeader = uiEntry.withOverride("TOTPDeviceSetupHeader", function T children: [ jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerTitle withBackButton totp-mfa deviceSetupHeader" }, { children: [ @@ -3455,7 +3454,7 @@ var DeviceSetupHeader = uiEntry.withOverride("TOTPDeviceSetupHeader", function T ), jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "headerSubtitle secondaryText" }, { children: t("TOTP_DEVICE_SETUP_HEADER_SUBTITLE") } ) @@ -3476,7 +3475,7 @@ var TOTPMFAScreens; var TOTPMFATheme = function (_a) { var activeScreen = _a.activeScreen, featureState = _a.featureState, - props = superTokens.__rest(_a, ["activeScreen", "featureState"]); + props = genericComponentOverrideContext.__rest(_a, ["activeScreen", "featureState"]); var t = translationContext.useTranslation(); var commonProps = { featureState: featureState, @@ -3504,13 +3503,13 @@ var TOTPMFATheme = function (_a) { ? jsxRuntime.jsx(LoadingScreen, {}) : jsxRuntime.jsxs( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "container totp-mfa" }, { children: [ jsxRuntime.jsx( "div", - superTokens.__assign( + genericComponentOverrideContext.__assign( { "data-supertokens": "row" }, { children: @@ -3520,14 +3519,14 @@ var TOTPMFATheme = function (_a) { activeScreen === TOTPMFAScreens.DeviceSetup ? jsxRuntime.jsx( DeviceSetupHeader, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { showBackButton: featureState.showBackButton, onBackButtonClicked: props.onBackButtonClicked, }) ) : jsxRuntime.jsx( CodeVerificationHeader, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { showBackButton: featureState.showBackButton, onBackButtonClicked: props.onBackButtonClicked, }) @@ -3535,7 +3534,7 @@ var TOTPMFATheme = function (_a) { activeScreen === TOTPMFAScreens.DeviceSetup && jsxRuntime.jsx( DeviceInfoSection, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { deviceInfo: featureState.deviceInfo, showSecret: featureState.showSecret, onShowSecretClicked: props.onShowSecretClicked, @@ -3547,21 +3546,25 @@ var TOTPMFATheme = function (_a) { }), jsxRuntime.jsx( CodeForm, - superTokens.__assign({}, commonProps, { + genericComponentOverrideContext.__assign({}, commonProps, { onSuccess: props.onSuccess, footer: activeScreen === TOTPMFAScreens.DeviceSetup ? jsxRuntime.jsx( DeviceSetupFooter, - superTokens.__assign({}, commonProps, { - onSignOutClicked: props.onSignOutClicked, - }) + genericComponentOverrideContext.__assign( + {}, + commonProps, + { onSignOutClicked: props.onSignOutClicked } + ) ) : jsxRuntime.jsx( CodeVerificationFooter, - superTokens.__assign({}, commonProps, { - onSignOutClicked: props.onSignOutClicked, - }) + genericComponentOverrideContext.__assign( + {}, + commonProps, + { onSignOutClicked: props.onSignOutClicked } + ) ), }) ), @@ -3577,7 +3580,7 @@ var TOTPMFATheme = function (_a) { ); }; function TOTPMFAThemeWrapper(props) { - var rootStyle = superTokens.SuperTokens.getInstanceOrThrow().rootStyle; + var rootStyle = genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().rootStyle; var hasFont = uiEntry.hasFontDefined(rootStyle) || uiEntry.hasFontDefined(props.config.recipeRootStyle); var activeScreen = getActiveScreen(props); var activeStyle; @@ -3592,12 +3595,12 @@ function TOTPMFAThemeWrapper(props) { } return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( ThemeBase, - superTokens.__assign( + genericComponentOverrideContext.__assign( { loadDefaultFont: !hasFont, userStyles: [rootStyle, props.config.recipeRootStyle, activeStyle], @@ -3605,7 +3608,7 @@ function TOTPMFAThemeWrapper(props) { { children: jsxRuntime.jsx( TOTPMFATheme, - superTokens.__assign({}, props, { activeScreen: activeScreen }) + genericComponentOverrideContext.__assign({}, props, { activeScreen: activeScreen }) ), } ) @@ -3641,33 +3644,38 @@ function getErrorString(error, state, t) { } var defaultTranslationsTOTP = { - en: superTokens.__assign(superTokens.__assign({}, uiEntry.defaultTranslationsCommon.en), { - TOTP_SHOW_SECRET_START: "Unable to scan? Use a", - TOTP_SHOW_SECRET_LINK: "secret key", - TOTP_SHOW_SECRET_END: "", - TOTP_CODE_VERIFICATION_HEADER_TITLE: "Enter TOTP", - TOTP_CODE_VERIFICATION_HEADER_SUBTITLE: - "Open the two-factor authenticator (TOTP) app on your mobile device to view your authentication code", - TOTP_DEVICE_SETUP_HEADER_TITLE: "Add a TOTP device", - TOTP_DEVICE_SETUP_HEADER_SUBTITLE: "Please scan the given QR code from a phone app like Google Authenticator.", - TOTP_CODE_INPUT_LABEL: "Please enter TOTP", - TOTP_CODE_CONTINUE_BUTTON: "Continue", - TOTP_BLOCKED_TITLE: "Account locked", - TOTP_BLOCKED_SUBTITLE: "Account locked due to multiple failed login attempts.", - TOTP_MFA_BLOCKED_TIMER_START: "", - TOTP_MFA_BLOCKED_TIMER_END: "", - TOTP_MFA_BLOCKED_RETRY: "Try again", - TOTP_MFA_LOGOUT: "Logout", - ERROR_TOTP_INVALID_CODE: "Invalid TOTP. Please try again.", - ERROR_TOTP_INVALID_CODE_RETRY_START: "", - // \xA0 is non breaking space. - // We add it to make sure there is no line break between the number and the rest of the sentence - ERROR_TOTP_INVALID_CODE_RETRY_END: "\xA0attempt(s) remaining before account is temporarily locked.", - ERROR_TOTP_UNKNOWN_DEVICE: "The device was deleted before verification. Please refresh the page to try again.", - GENERAL_ERROR_TOTP_NON_STRING: "TOTP code must be of type string", - GENERAL_ERROR_TOTP_EMPTY: "TOTP code cannot be empty", - GENERAL_ERROR_TOTP_UNDEFINED: "Please fill your TOTP code", - }), + en: genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, uiEntry.defaultTranslationsCommon.en), + { + TOTP_SHOW_SECRET_START: "Unable to scan? Use a", + TOTP_SHOW_SECRET_LINK: "secret key", + TOTP_SHOW_SECRET_END: "", + TOTP_CODE_VERIFICATION_HEADER_TITLE: "Enter TOTP", + TOTP_CODE_VERIFICATION_HEADER_SUBTITLE: + "Open the two-factor authenticator (TOTP) app on your mobile device to view your authentication code", + TOTP_DEVICE_SETUP_HEADER_TITLE: "Add a TOTP device", + TOTP_DEVICE_SETUP_HEADER_SUBTITLE: + "Please scan the given QR code from a phone app like Google Authenticator.", + TOTP_CODE_INPUT_LABEL: "Please enter TOTP", + TOTP_CODE_CONTINUE_BUTTON: "Continue", + TOTP_BLOCKED_TITLE: "Account locked", + TOTP_BLOCKED_SUBTITLE: "Account locked due to multiple failed login attempts.", + TOTP_MFA_BLOCKED_TIMER_START: "", + TOTP_MFA_BLOCKED_TIMER_END: "", + TOTP_MFA_BLOCKED_RETRY: "Try again", + TOTP_MFA_LOGOUT: "Logout", + ERROR_TOTP_INVALID_CODE: "Invalid TOTP. Please try again.", + ERROR_TOTP_INVALID_CODE_RETRY_START: "", + // \xA0 is non breaking space. + // We add it to make sure there is no line break between the number and the rest of the sentence + ERROR_TOTP_INVALID_CODE_RETRY_END: "\xA0attempt(s) remaining before account is temporarily locked.", + ERROR_TOTP_UNKNOWN_DEVICE: + "The device was deleted before verification. Please refresh the page to try again.", + GENERAL_ERROR_TOTP_NON_STRING: "TOTP code must be of type string", + GENERAL_ERROR_TOTP_EMPTY: "TOTP code cannot be empty", + GENERAL_ERROR_TOTP_UNDEFINED: "Please fill your TOTP code", + } + ), }; var useFeatureReducer = function () { @@ -3687,38 +3695,46 @@ var useFeatureReducer = function () { showSecret: false, }; case "setBlocked": - return superTokens.__assign(superTokens.__assign({}, oldState), { - isBlocked: true, - nextRetryAt: action.nextRetryAt, - error: action.error, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { isBlocked: true, nextRetryAt: action.nextRetryAt, error: action.error } + ); case "setError": - return superTokens.__assign(superTokens.__assign({}, oldState), { - loaded: true, - maxAttemptCount: - (_a = action.maxAttemptCount) !== null && _a !== void 0 ? _a : oldState.maxAttemptCount, - currAttemptCount: - (_b = action.currAttemptCount) !== null && _b !== void 0 ? _b : oldState.currAttemptCount, - showAccessDenied: action.showAccessDenied, - error: action.error, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { + loaded: true, + maxAttemptCount: + (_a = action.maxAttemptCount) !== null && _a !== void 0 ? _a : oldState.maxAttemptCount, + currAttemptCount: + (_b = action.currAttemptCount) !== null && _b !== void 0 + ? _b + : oldState.currAttemptCount, + showAccessDenied: action.showAccessDenied, + error: action.error, + } + ); case "createDevice": - return superTokens.__assign(superTokens.__assign({}, oldState), { - deviceInfo: action.deviceInfo, - isBlocked: false, - showSecret: false, - nextRetryAt: undefined, - error: undefined, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { + deviceInfo: action.deviceInfo, + isBlocked: false, + showSecret: false, + nextRetryAt: undefined, + error: undefined, + } + ); case "showSecret": - return superTokens.__assign(superTokens.__assign({}, oldState), { showSecret: true }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { showSecret: true } + ); case "restartFlow": - return superTokens.__assign(superTokens.__assign({}, oldState), { - isBlocked: false, - showSecret: false, - nextRetryAt: undefined, - error: action.error, - }); + return genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, oldState), + { isBlocked: false, showSecret: false, nextRetryAt: undefined, error: action.error } + ); default: return oldState; } @@ -3734,11 +3750,13 @@ var useFeatureReducer = function () { }, function (initArg) { var error = undefined; - var errorQueryParam = superTokens.getQueryParams("error"); + var errorQueryParam = genericComponentOverrideContext.getQueryParams("error"); if (errorQueryParam !== null) { error = "SOMETHING_WENT_WRONG_ERROR"; } - return superTokens.__assign(superTokens.__assign({}, initArg), { error: error }); + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, initArg), { + error: error, + }); } ); }; @@ -3746,8 +3764,8 @@ function useOnLoad(recipeImpl, dispatch, userContext) { var _this = this; var fetchMFAInfo = React__namespace.useCallback( function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { return [ 2 /*return*/, recipe$1.MultiFactorAuth.getInstanceOrThrow().webJSRecipe.resyncSessionAndFetchMFAInfo({ @@ -3767,14 +3785,14 @@ function useOnLoad(recipeImpl, dispatch, userContext) { ); var onLoad = React__namespace.useCallback( function (mfaInfo) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var error, errorQueryParam, doSetup, alreadySetup, showBackButton, deviceInfo, createResp; - return superTokens.__generator(this, function (_b) { + return genericComponentOverrideContext.__generator(this, function (_b) { switch (_b.label) { case 0: error = undefined; - errorQueryParam = superTokens.getQueryParams("error"); - doSetup = superTokens.getQueryParams("setup"); + errorQueryParam = genericComponentOverrideContext.getQueryParams("error"); + doSetup = genericComponentOverrideContext.getQueryParams("setup"); if (errorQueryParam !== null) { error = "SOMETHING_WENT_WRONG_ERROR"; } @@ -3821,7 +3839,7 @@ function useOnLoad(recipeImpl, dispatch, userContext) { }); return [2 /*return*/]; } - deviceInfo = superTokens.__assign({}, createResp); + deviceInfo = genericComponentOverrideContext.__assign({}, createResp); delete deviceInfo.status; _b.label = 5; case 5: @@ -3841,11 +3859,11 @@ function useOnLoad(recipeImpl, dispatch, userContext) { }, [dispatch, recipeImpl, userContext] ); - superTokens.useOnMountAPICall(fetchMFAInfo, onLoad, handleLoadError); + genericComponentOverrideContext.useOnMountAPICall(fetchMFAInfo, onLoad, handleLoadError); } function useChildProps(recipe, recipeImplementation, state, dispatch, userContext, navigate) { var _this = this; - var rethrowInRender = superTokens.useRethrowInRender(); + var rethrowInRender = genericComponentOverrideContext.useRethrowInRender(); return React.useMemo( function () { return { @@ -3853,8 +3871,8 @@ function useChildProps(recipe, recipeImplementation, state, dispatch, userContex dispatch({ type: "showSecret" }); }, onBackButtonClicked: function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: if (!state.deviceInfo) return [3 /*break*/, 2]; @@ -3892,8 +3910,8 @@ function useChildProps(recipe, recipeImplementation, state, dispatch, userContex dispatch({ type: "restartFlow", error: undefined }); }, onSignOutClicked: function () { - return superTokens.__awaiter(_this, void 0, void 0, function () { - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: if (!state.deviceInfo) return [3 /*break*/, 2]; @@ -3926,7 +3944,7 @@ function useChildProps(recipe, recipeImplementation, state, dispatch, userContex }); }, onSuccess: function () { - var redirectToPath = superTokens.getRedirectToPathFromURL(); + var redirectToPath = genericComponentOverrideContext.getRedirectToPathFromURL(); return types.Session.getInstanceOrThrow() .validateGlobalClaimsAndHandleSuccessRedirection( undefined, @@ -3960,14 +3978,14 @@ var SignInUpFeature = function (props) { useOnLoad(recipeImplementation, dispatch, userContext); return jsxRuntime.jsx( uiEntry.ComponentOverrideContext.Provider, - superTokens.__assign( + genericComponentOverrideContext.__assign( { value: recipeComponentOverrides }, { children: jsxRuntime.jsx( uiEntry.FeatureWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { - useShadowDom: superTokens.SuperTokens.getInstanceOrThrow().useShadowDom, + useShadowDom: genericComponentOverrideContext.SuperTokens.getInstanceOrThrow().useShadowDom, defaultStore: defaultTranslationsTOTP, }, { @@ -3976,7 +3994,7 @@ var SignInUpFeature = function (props) { props.children === undefined && jsxRuntime.jsx( TOTPMFAThemeWrapper, - superTokens.__assign({}, childProps, { + genericComponentOverrideContext.__assign({}, childProps, { featureState: state, dispatch: dispatch, }) @@ -3986,10 +4004,10 @@ var SignInUpFeature = function (props) { if (React__namespace.isValidElement(child)) { return React__namespace.cloneElement( child, - superTokens.__assign(superTokens.__assign({}, childProps), { - featureState: state, - dispatch: dispatch, - }) + genericComponentOverrideContext.__assign( + genericComponentOverrideContext.__assign({}, childProps), + { featureState: state, dispatch: dispatch } + ) ); } return child; @@ -4005,18 +4023,18 @@ var SignInUpFeature = function (props) { }; function getModifiedRecipeImplementation(originalImpl, dispatch) { var _this = this; - return superTokens.__assign(superTokens.__assign({}, originalImpl), { + return genericComponentOverrideContext.__assign(genericComponentOverrideContext.__assign({}, originalImpl), { createDevice: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res, deviceInfo; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImpl.createDevice(input)]; case 1: res = _a.sent(); if (res.status === "OK") { - deviceInfo = superTokens.__assign({}, res); + deviceInfo = genericComponentOverrideContext.__assign({}, res); delete deviceInfo.status; dispatch({ type: "createDevice", deviceInfo: deviceInfo }); } @@ -4026,9 +4044,9 @@ function getModifiedRecipeImplementation(originalImpl, dispatch) { }); }, verifyCode: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImpl.verifyCode(input)]; @@ -4055,9 +4073,9 @@ function getModifiedRecipeImplementation(originalImpl, dispatch) { }); }, verifyDevice: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImpl.verifyDevice(input)]; @@ -4090,9 +4108,9 @@ function getModifiedRecipeImplementation(originalImpl, dispatch) { }); }, removeDevice: function (input) { - return superTokens.__awaiter(_this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(_this, void 0, void 0, function () { var res; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, originalImpl.removeDevice(input)]; @@ -4124,7 +4142,7 @@ function getModifiedRecipeImplementation(originalImpl, dispatch) { var DEFAULT_TOTP_PATH = "/mfa/totp"; var TOTPPreBuiltUI = /** @class */ (function (_super) { - superTokens.__extends(TOTPPreBuiltUI, _super); + genericComponentOverrideContext.__extends(TOTPPreBuiltUI, _super); function TOTPPreBuiltUI(recipeInstance) { var _this = _super.call(this) || this; _this.recipeInstance = recipeInstance; @@ -4140,7 +4158,9 @@ var TOTPPreBuiltUI = /** @class */ (function (_super) { new NormalisedURLPath__default.default(DEFAULT_TOTP_PATH) ); features[normalisedFullPath.getAsStringDangerous()] = { - matches: superTokens.matchRecipeIdUsingQueryParams(_this.recipeInstance.config.recipeId), + matches: genericComponentOverrideContext.matchRecipeIdUsingQueryParams( + _this.recipeInstance.config.recipeId + ), component: function (props) { return _this.getFeatureComponent("mfaTOTP", props, useComponentOverrides); }, @@ -4160,12 +4180,12 @@ var TOTPPreBuiltUI = /** @class */ (function (_super) { } return jsxRuntime.jsx( uiEntry.UserContextWrapper, - superTokens.__assign( + genericComponentOverrideContext.__assign( { userContext: props.userContext }, { children: jsxRuntime.jsx( session.SessionAuth, - superTokens.__assign( + genericComponentOverrideContext.__assign( { overrideGlobalClaimValidators: function () { return []; @@ -4174,7 +4194,7 @@ var TOTPPreBuiltUI = /** @class */ (function (_super) { { children: jsxRuntime.jsx( SignInUpFeature, - superTokens.__assign( + genericComponentOverrideContext.__assign( { recipe: _this.recipeInstance, useComponentOverrides: useComponentOverrides, @@ -4220,7 +4240,7 @@ var TOTPPreBuiltUI = /** @class */ (function (_super) { }; // For tests TOTPPreBuiltUI.reset = function () { - if (!superTokens.isTest()) { + if (!genericComponentOverrideContext.isTest()) { return; } TOTPPreBuiltUI.instance = undefined; diff --git a/lib/build/translationContext.js b/lib/build/translationContext.js index 01ccda532..f74c9f995 100644 --- a/lib/build/translationContext.js +++ b/lib/build/translationContext.js @@ -1,6 +1,6 @@ "use strict"; -var superTokens = require("./superTokens.js"); +var genericComponentOverrideContext = require("./genericComponentOverrideContext.js"); var jsxRuntime = require("react/jsx-runtime"); var React = require("react"); @@ -34,12 +34,12 @@ var TranslationContextProvider = function (_a) { React.useEffect( function () { function loadLanguageFromCookies() { - return superTokens.__awaiter(this, void 0, void 0, function () { + return genericComponentOverrideContext.__awaiter(this, void 0, void 0, function () { var cookieLang, cookieLangTemp; - return superTokens.__generator(this, function (_a) { + return genericComponentOverrideContext.__generator(this, function (_a) { switch (_a.label) { case 0: - return [4 /*yield*/, superTokens.getCurrentLanguageFromCookie()]; + return [4 /*yield*/, genericComponentOverrideContext.getCurrentLanguageFromCookie()]; case 1: cookieLang = _a.sent(); cookieLangTemp = cookieLang === null ? defaultLanguage : cookieLang; @@ -70,7 +70,7 @@ var TranslationContextProvider = function (_a) { // eslint-disable-next-line @typescript-eslint/no-unused-vars var loadHandler = function (_eventName, detail) { setTranslationStore(function (os) { - return superTokens.mergeObjects(os, detail); + return genericComponentOverrideContext.mergeObjects(os, detail); }); }; translationControlEventSource.on("LanguageChange", changeHandler); @@ -105,7 +105,7 @@ var TranslationContextProvider = function (_a) { } return jsxRuntime.jsx( TranslationContext.Provider, - superTokens.__assign({ value: { translate: translateFunc } }, { children: children }) + genericComponentOverrideContext.__assign({ value: { translate: translateFunc } }, { children: children }) ); }; diff --git a/lib/build/ui-entry.js b/lib/build/ui-entry.js index 941fd497d..c91525c6e 100644 --- a/lib/build/ui-entry.js +++ b/lib/build/ui-entry.js @@ -2,7 +2,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); -require("./superTokens.js"); +require("./genericComponentOverrideContext.js"); require("react/jsx-runtime"); require("react"); var uiEntry = require("./index2.js"); @@ -17,7 +17,6 @@ require("supertokens-web-js/utils/normalisedURLPath"); require("./translationContext.js"); require("react-dom"); require("./multitenancy-shared.js"); -require("./genericComponentOverrideContext.js"); require("./multifactorauth-shared2.js"); require("supertokens-web-js/recipe/multifactorauth"); require("supertokens-web-js/utils/sessionClaimValidatorStore"); diff --git a/lib/ts/recipe/oauth2provider/componentOverrideContext.tsx b/lib/ts/recipe/oauth2provider/componentOverrideContext.tsx new file mode 100644 index 000000000..467bd5485 --- /dev/null +++ b/lib/ts/recipe/oauth2provider/componentOverrideContext.tsx @@ -0,0 +1,7 @@ +import { createGenericComponentsOverrideContext } from "../../components/componentOverride/genericComponentOverrideContext"; + +import type { ComponentOverrideMap } from "./types"; + +const [useContext, Provider] = createGenericComponentsOverrideContext(); + +export { useContext as useRecipeComponentOverrideContext, Provider as RecipeComponentsOverrideContextProvider }; diff --git a/lib/ts/recipe/oauth2provider/components/features/tryRefreshPage/index.tsx b/lib/ts/recipe/oauth2provider/components/features/tryRefreshPage/index.tsx new file mode 100644 index 000000000..9392157f1 --- /dev/null +++ b/lib/ts/recipe/oauth2provider/components/features/tryRefreshPage/index.tsx @@ -0,0 +1,90 @@ +/* Copyright (c) 2024, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ + +/* + * Imports. + */ +import * as React from "react"; +import { useContext, Fragment } from "react"; + +import FeatureWrapper from "../../../../../components/featureWrapper"; +import SuperTokens from "../../../../../superTokens"; +import { useUserContext } from "../../../../../usercontext"; +import { getQueryParams, useRethrowInRender } from "../../../../../utils"; +import DynamicLoginMethodsSpinner from "../../../../multitenancy/components/features/dynamicLoginMethodsSpinner"; +import { SessionContext } from "../../../../session"; +import { defaultTranslationsOAuth2Provider } from "../../themes/translations"; + +import type { FeatureBaseProps, UserContext } from "../../../../../types"; +import type Recipe from "../../../recipe"; +import type { ComponentOverrideMap } from "../../../types"; + +type Prop = FeatureBaseProps<{ + recipe: Recipe; + userContext?: UserContext; + useComponentOverrides: () => ComponentOverrideMap; +}>; + +export const TryRefreshPage: React.FC = (props) => { + const rethrowInRender = useRethrowInRender(); + const sessionContext = useContext(SessionContext); + const loginChallenge = getQueryParams("loginChallenge") ?? undefined; + let userContext = useUserContext(); + if (props.userContext !== undefined) { + userContext = props.userContext; + } + + React.useEffect(() => { + if (sessionContext.loading === false) { + void props.recipe + .redirect( + { + action: "CONTINUE_OAUTH2_AFTER_REFRESH", + loginChallenge: loginChallenge ?? "", + recipeId: "oauth2provider", + }, + props.navigate, + {}, + userContext + ) + .catch(rethrowInRender); + } + }, [loginChallenge, props.recipe, props.navigate, userContext, sessionContext]); + + const childProps = { + config: props.recipe.config, + }; + return ( + + + {/* No custom theme, use default. */} + {props.children === undefined && } + {/* Otherwise, custom theme is provided, propagate props. */} + {props.children && + React.Children.map(props.children, (child) => { + if (React.isValidElement(child)) { + return React.cloneElement(child, childProps); + } + + return child; + })} + + + ); +}; + +export default TryRefreshPage; diff --git a/lib/ts/recipe/oauth2provider/components/themes/translations.ts b/lib/ts/recipe/oauth2provider/components/themes/translations.ts new file mode 100644 index 000000000..46e47ec58 --- /dev/null +++ b/lib/ts/recipe/oauth2provider/components/themes/translations.ts @@ -0,0 +1,3 @@ +export const defaultTranslationsOAuth2Provider = { + en: {}, +}; diff --git a/lib/ts/recipe/oauth2provider/constants.ts b/lib/ts/recipe/oauth2provider/constants.ts new file mode 100644 index 000000000..13c4c4e90 --- /dev/null +++ b/lib/ts/recipe/oauth2provider/constants.ts @@ -0,0 +1,15 @@ +/* Copyright (c) 2024, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +export const DEFAULT_TRY_REFRESH_PATH = "/try-refresh"; diff --git a/lib/ts/recipe/oauth2provider/functionOverrides.ts b/lib/ts/recipe/oauth2provider/functionOverrides.ts new file mode 100644 index 000000000..7e0fc33d5 --- /dev/null +++ b/lib/ts/recipe/oauth2provider/functionOverrides.ts @@ -0,0 +1,19 @@ +import type { OnHandleEventContext } from "./types"; +import type { RecipeOnHandleEventFunction } from "../recipeModule/types"; +import type { RecipeInterface } from "supertokens-web-js/recipe/oauth2provider"; + +export const getFunctionOverrides = + (onHandleEvent: RecipeOnHandleEventFunction) => + (originalImp: RecipeInterface): RecipeInterface => ({ + ...originalImp, + async getLoginChallengeInfo(input) { + const response = await originalImp.getLoginChallengeInfo(input); + onHandleEvent({ + action: "LOADED_LOGIN_CHALLENGE", + loginChallenge: input.loginChallenge, + loginInfo: response.info, + userContext: input.userContext, + }); + return response; + }, + }); diff --git a/lib/ts/recipe/oauth2provider/index.ts b/lib/ts/recipe/oauth2provider/index.ts index 980b8efe8..43f9a1146 100644 --- a/lib/ts/recipe/oauth2provider/index.ts +++ b/lib/ts/recipe/oauth2provider/index.ts @@ -13,6 +13,7 @@ * under the License. */ +import { RecipeComponentsOverrideContextProvider } from "./componentOverrideContext"; import OAuth2Provider from "./recipe"; import { UserInput, GetRedirectionURLContext, PreAPIHookContext, OnHandleEventContext } from "./types"; @@ -47,6 +48,8 @@ export default class Wrapper { }> { return OAuth2Provider.getInstanceOrThrow().webJSRecipe.getLoginChallengeInfo(input); } + + static ComponentsOverrideProvider = RecipeComponentsOverrideContextProvider; } const init = Wrapper.init; @@ -60,4 +63,5 @@ export { OnHandleEventContext, UserInput, RecipeInterface, + RecipeComponentsOverrideContextProvider, }; diff --git a/lib/ts/recipe/oauth2provider/prebuiltui.tsx b/lib/ts/recipe/oauth2provider/prebuiltui.tsx new file mode 100644 index 000000000..0e3c511a3 --- /dev/null +++ b/lib/ts/recipe/oauth2provider/prebuiltui.tsx @@ -0,0 +1,108 @@ +import NormalisedURLPath from "supertokens-web-js/utils/normalisedURLPath"; + +import UserContextWrapper from "../../usercontext/userContextWrapper"; +import { isTest, matchRecipeIdUsingQueryParams } from "../../utils"; +import { RecipeRouter } from "../recipeRouter"; +import { SessionAuth } from "../session"; + +import { useRecipeComponentOverrideContext } from "./componentOverrideContext"; +import { default as TryRefreshPageFeature } from "./components/features/tryRefreshPage"; +import { defaultTranslationsOAuth2Provider } from "./components/themes/translations"; +import { DEFAULT_TRY_REFRESH_PATH } from "./constants"; +import OAuth2ProviderRecipe from "./recipe"; + +import type { GenericComponentOverrideMap } from "../../components/componentOverride/componentOverrideContext"; +import type { FeatureBaseProps, RecipeFeatureComponentMap, UserContext } from "../../types"; +import type { AuthComponent } from "../../types"; + +export class OAuth2ProviderPreBuiltUI extends RecipeRouter { + static instance?: OAuth2ProviderPreBuiltUI; + languageTranslations = defaultTranslationsOAuth2Provider; + + constructor(public readonly recipeInstance: OAuth2ProviderRecipe) { + super(); + } + + // Static methods + static getInstanceOrInitAndGetInstance(): OAuth2ProviderPreBuiltUI { + if (OAuth2ProviderPreBuiltUI.instance === undefined) { + const recipeInstance = OAuth2ProviderRecipe.getInstanceOrThrow(); + OAuth2ProviderPreBuiltUI.instance = new OAuth2ProviderPreBuiltUI(recipeInstance); + } + + return OAuth2ProviderPreBuiltUI.instance; + } + static getFeatures( + useComponentOverrides: () => GenericComponentOverrideMap = useRecipeComponentOverrideContext + ): RecipeFeatureComponentMap { + return OAuth2ProviderPreBuiltUI.getInstanceOrInitAndGetInstance().getFeatures(useComponentOverrides); + } + static getFeatureComponent( + componentName: "try-refresh-page", + props: any, + useComponentOverrides: () => GenericComponentOverrideMap = useRecipeComponentOverrideContext + ): JSX.Element { + return OAuth2ProviderPreBuiltUI.getInstanceOrInitAndGetInstance().getFeatureComponent( + componentName, + props, + useComponentOverrides + ); + } + + // Instance methods + getFeatures = ( + useComponentOverrides: () => GenericComponentOverrideMap = useRecipeComponentOverrideContext + ): RecipeFeatureComponentMap => { + const features: RecipeFeatureComponentMap = {}; + if (this.recipeInstance.config.disableDefaultUI !== true) { + const normalisedFullPath = this.recipeInstance.config.appInfo.websiteBasePath.appendPath( + new NormalisedURLPath(DEFAULT_TRY_REFRESH_PATH) + ); + features[normalisedFullPath.getAsStringDangerous()] = { + matches: matchRecipeIdUsingQueryParams(this.recipeInstance.config.recipeId), + component: (props: any) => this.getFeatureComponent("try-refresh-page", props, useComponentOverrides), + recipeID: OAuth2ProviderRecipe.RECIPE_ID, + }; + } + return features; + }; + getFeatureComponent = ( + // eslint-disable-next-line @typescript-eslint/no-unused-vars + _: "try-refresh-page", + props: FeatureBaseProps<{ userContext?: UserContext }>, + useComponentOverrides: () => GenericComponentOverrideMap = useRecipeComponentOverrideContext + ): JSX.Element => { + return ( + + []}> + + + + ); + }; + + getAuthComponents(): AuthComponent[] { + return []; + } + + // For tests + static reset(): void { + if (!isTest()) { + return; + } + + OAuth2ProviderPreBuiltUI.instance = undefined; + return; + } + + static TryRefreshPage = (props: FeatureBaseProps<{ userContext?: UserContext }>) => + OAuth2ProviderPreBuiltUI.getInstanceOrInitAndGetInstance().getFeatureComponent("try-refresh-page", props); +} + +const TryRefreshPage = OAuth2ProviderPreBuiltUI.TryRefreshPage; + +export { TryRefreshPage }; diff --git a/lib/ts/recipe/oauth2provider/recipe.ts b/lib/ts/recipe/oauth2provider/recipe.ts index d88503db1..9018d4413 100644 --- a/lib/ts/recipe/oauth2provider/recipe.ts +++ b/lib/ts/recipe/oauth2provider/recipe.ts @@ -23,6 +23,7 @@ import { SSR_ERROR } from "../../constants"; import { isTest } from "../../utils"; import RecipeModule from "../recipeModule"; +import { getFunctionOverrides } from "./functionOverrides"; import { normaliseOAuth2Config } from "./utils"; import type { @@ -32,12 +33,7 @@ import type { PreAndPostAPIHookAction, UserInput, } from "./types"; -import type { - RecipeInitResult, - NormalisedConfigWithAppInfoAndRecipeID, - WebJSRecipeInterface, - SuccessRedirectContextOAuth2, -} from "../../types"; +import type { RecipeInitResult, NormalisedConfigWithAppInfoAndRecipeID, WebJSRecipeInterface } from "../../types"; import type { NormalisedAppInfo } from "../../types"; /* @@ -82,6 +78,14 @@ export default class OAuth2Provider extends RecipeModule< }, webJS: OAuth2WebJS.init({ ...normalisedConfig, + override: { + functions: (originalImpl, builder) => { + const functions = getFunctionOverrides(normalisedConfig.onHandleEvent); + builder.override(functions); + builder.override(normalisedConfig.override.functions); + return originalImpl; + }, + }, }), }; } @@ -106,8 +110,8 @@ export default class OAuth2Provider extends RecipeModule< return OAuth2Provider.instance; } - async getDefaultRedirectionURL(ctx: SuccessRedirectContextOAuth2): Promise { - if (ctx.action === "SUCCESS_OAUTH2") { + async getDefaultRedirectionURL(ctx: GetRedirectionURLContext): Promise { + if (ctx.action === "SUCCESS_OAUTH2" || ctx.action === "CONTINUE_OAUTH2_AFTER_REFRESH") { const domain = this.config.appInfo.apiDomain.getAsStringDangerous(); const basePath = this.config.appInfo.apiBasePath.getAsStringDangerous(); diff --git a/lib/ts/recipe/oauth2provider/types.ts b/lib/ts/recipe/oauth2provider/types.ts index 0a43695f2..36511eb27 100644 --- a/lib/ts/recipe/oauth2provider/types.ts +++ b/lib/ts/recipe/oauth2provider/types.ts @@ -4,7 +4,7 @@ import type { NormalisedConfig as NormalisedRecipeModuleConfig, } from "../recipeModule/types"; import type OverrideableBuilder from "supertokens-js-override"; -import type { RecipeInterface } from "supertokens-web-js/recipe/oauth2provider/types"; +import type { LoginInfo, RecipeInterface } from "supertokens-web-js/recipe/oauth2provider/types"; export type PreAndPostAPIHookAction = "GET_LOGIN_CHALLENGE_INFO"; @@ -16,6 +16,7 @@ export type PreAPIHookContext = { }; export type UserInput = { + disableDefaultUI?: boolean; override?: { functions?: ( originalImplementation: RecipeInterface, @@ -29,14 +30,32 @@ export type NormalisedConfig = NormalisedRecipeModuleConfig< PreAndPostAPIHookAction, OnHandleEventContext > & { + disableDefaultUI: boolean; override: { - functions?: ( + functions: ( originalImplementation: RecipeInterface, builder: OverrideableBuilder ) => RecipeInterface; }; }; -export type GetRedirectionURLContext = SuccessRedirectContextOAuth2; +export type ContinueOAuth2AfterRefreshRedirectContext = { + recipeId: "oauth2provider"; + action: "CONTINUE_OAUTH2_AFTER_REFRESH"; + loginChallenge: string; +}; + +export type GetRedirectionURLContext = SuccessRedirectContextOAuth2 | ContinueOAuth2AfterRefreshRedirectContext; + +export type OnHandleEventContext = { + /* + * On Handle Event actions + */ + action: "LOADED_LOGIN_CHALLENGE"; + loginChallenge: string; + loginInfo: LoginInfo; + userContext: UserContext; +}; -export type OnHandleEventContext = any; +// TODO: update this whenever we add components +export type ComponentOverrideMap = any; diff --git a/lib/ts/recipe/oauth2provider/utils.ts b/lib/ts/recipe/oauth2provider/utils.ts index 5302c9c4b..8402f7ba8 100644 --- a/lib/ts/recipe/oauth2provider/utils.ts +++ b/lib/ts/recipe/oauth2provider/utils.ts @@ -5,6 +5,7 @@ import type { UserInput, NormalisedConfig } from "./types"; export function normaliseOAuth2Config(config?: UserInput): NormalisedConfig { return { ...normaliseRecipeModuleConfig(config), + disableDefaultUI: config?.disableDefaultUI ?? false, override: { functions: (originalImplementation) => originalImplementation, ...config?.override, diff --git a/package-lock.json b/package-lock.json index f34f9a2ad..fba0274e9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -23890,8 +23890,7 @@ }, "node_modules/supertokens-web-js": { "version": "0.12.0", - "resolved": "git+ssh://git@github.com/supertokens/supertokens-web-js.git#d7cc0fe8b4736f083216546ac66a0a23b2eff964", - "license": "Apache-2.0", + "resolved": "git+ssh://git@github.com/supertokens/supertokens-web-js.git#b450dfedd971c8d8d0b13c372a735fea7c5187b6", "peer": true, "dependencies": { "supertokens-js-override": "0.0.4", @@ -23899,9 +23898,9 @@ } }, "node_modules/supertokens-website": { - "version": "20.0.2", - "resolved": "git+ssh://git@github.com/supertokens/supertokens-website.git#e8b03b341a9098d0b5119a978a1174c92d5060ae", - "license": "Apache-2.0", + "version": "20.1.4", + "resolved": "https://registry.npmjs.org/supertokens-website/-/supertokens-website-20.1.4.tgz", + "integrity": "sha512-2hbB/MWJew4W8bq5q0M75tjUnniahLzXVOnu+535j3HB4wworwMJ1ZGfg25OL9q1fm4g+ITNKVjJeJgJqEDlmA==", "peer": true, "dependencies": { "browser-tabs-lock": "^1.3.0", @@ -43370,7 +43369,7 @@ "integrity": "sha512-r0JFBjkMIdep3Lbk3JA+MpnpuOtw4RSyrlRAbrzMcxwiYco3GFWl/daimQZ5b1forOiUODpOlXbSOljP/oyurg==" }, "supertokens-web-js": { - "version": "git+ssh://git@github.com/supertokens/supertokens-web-js.git#d7cc0fe8b4736f083216546ac66a0a23b2eff964", + "version": "git+ssh://git@github.com/supertokens/supertokens-web-js.git#b450dfedd971c8d8d0b13c372a735fea7c5187b6", "from": "supertokens-web-js@github:supertokens/supertokens-web-js#feat/oauth2/base", "peer": true, "requires": { @@ -43379,8 +43378,9 @@ } }, "supertokens-website": { - "version": "git+ssh://git@github.com/supertokens/supertokens-website.git#e8b03b341a9098d0b5119a978a1174c92d5060ae", - "from": "supertokens-website@^20.0.1", + "version": "20.1.4", + "resolved": "https://registry.npmjs.org/supertokens-website/-/supertokens-website-20.1.4.tgz", + "integrity": "sha512-2hbB/MWJew4W8bq5q0M75tjUnniahLzXVOnu+535j3HB4wworwMJ1ZGfg25OL9q1fm4g+ITNKVjJeJgJqEDlmA==", "peer": true, "requires": { "browser-tabs-lock": "^1.3.0", diff --git a/recipe/oauth2provider/prebuiltui.d.ts b/recipe/oauth2provider/prebuiltui.d.ts new file mode 100644 index 000000000..c983a1551 --- /dev/null +++ b/recipe/oauth2provider/prebuiltui.d.ts @@ -0,0 +1,17 @@ +/* Copyright (c) 2024, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +export * from "../../lib/build/recipe/oauth2provider/prebuiltui"; +import * as _default from "../../lib/build/recipe/oauth2provider/prebuiltui"; +export default _default; diff --git a/recipe/oauth2provider/prebuiltui.js b/recipe/oauth2provider/prebuiltui.js new file mode 100644 index 000000000..c5380476f --- /dev/null +++ b/recipe/oauth2provider/prebuiltui.js @@ -0,0 +1,20 @@ +/* Copyright (c) 2024, VRAI Labs and/or its affiliates. All rights reserved. + * + * This software is licensed under the Apache License, Version 2.0 (the + * "License") as published by the Apache Software Foundation. + * + * You may not use this file except in compliance with the License. You may + * obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + */ +"use strict"; +function __export(m) { + for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; +} +exports.__esModule = true; +__export(require("../../lib/build/oauth2providerprebuiltui")); diff --git a/rollup.config.mjs b/rollup.config.mjs index 75f56e115..8314eab99 100644 --- a/rollup.config.mjs +++ b/rollup.config.mjs @@ -26,6 +26,7 @@ export default [ passwordless: "lib/ts/recipe/passwordless/index.ts", passwordlessprebuiltui: "lib/ts/recipe/passwordless/prebuiltui.tsx", oauth2provider: "lib/ts/recipe/oauth2provider/index.ts", + oauth2providerprebuiltui: "lib/ts/recipe/oauth2provider/prebuiltui.tsx", thirdparty: "lib/ts/recipe/thirdparty/index.ts", thirdpartyprebuiltui: "lib/ts/recipe/thirdparty/prebuiltui.tsx", multitenancy: "lib/ts/recipe/multitenancy/index.ts", From 458c80796fd6ba12cbea2d5cb6e56eb9d10f85fd Mon Sep 17 00:00:00 2001 From: Mihaly Lengyel Date: Mon, 19 Aug 2024 00:33:30 +0200 Subject: [PATCH 2/3] test: extend/stabilize tests --- test/end-to-end/oauth2provider.test.js | 440 ++++++++++++++++++++++++- test/end-to-end/signin.test.js | 19 +- test/helpers.js | 37 ++- test/server/package-lock.json | 24 +- test/server/package.json | 2 +- test/with-typescript/src/App.tsx | 3 + 6 files changed, 483 insertions(+), 42 deletions(-) diff --git a/test/end-to-end/oauth2provider.test.js b/test/end-to-end/oauth2provider.test.js index 0165ce80b..2c3585b94 100644 --- a/test/end-to-end/oauth2provider.test.js +++ b/test/end-to-end/oauth2provider.test.js @@ -26,8 +26,8 @@ import { backendBeforeEach, waitForUrl, createOAuth2Client, - setOAuth2ClientIdInStorage, - removeOAuth2ClientIdFromStorage, + setOAuth2ClientInfo, + removeOAuth2ClientInfo, getOAuth2LoginButton, getOAuth2LogoutButton, getOAuth2TokenData, @@ -36,10 +36,16 @@ import { signUp, getDefaultSignUpFieldValues, getTestEmail, + getOAuth2Error, } from "../helpers"; import fetch from "isomorphic-fetch"; -import { TEST_CLIENT_BASE_URL, TEST_SERVER_BASE_URL, SIGN_OUT_API } from "../constants"; +import { + TEST_CLIENT_BASE_URL, + TEST_SERVER_BASE_URL, + SIGN_OUT_API, + TEST_APPLICATION_SERVER_BASE_URL, +} from "../constants"; // We do no thave to use a separate domain for the oauth2 client, since the way we are testing // the lib doesn't interact with the supertokens session handling. @@ -65,6 +71,12 @@ describe("SuperTokens OAuth2Provider", function () { await fetch(`${TEST_SERVER_BASE_URL}/startst`, { method: "POST", + headers: { "content-type": "application/json" }, + body: JSON.stringify({ + coreConfig: { + access_token_validity: 5, // 5 seconds + }, + }), }).catch(console.error); browser = await puppeteer.launch({ @@ -105,13 +117,13 @@ describe("SuperTokens OAuth2Provider", function () { describe("Generic OAuth2 Client Library", function () { afterEach(async function () { - await removeOAuth2ClientIdFromStorage(page); + await removeOAuth2ClientInfo(page); }); it("should successfully complete the OAuth2 flow", async function () { const { client } = await createOAuth2Client({ scope: "offline_access profile openid email", - redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth2/callback`], + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], accessTokenStrategy: "jwt", tokenEndpointAuthMethod: "none", grantTypes: ["authorization_code", "refresh_token"], @@ -119,9 +131,12 @@ describe("SuperTokens OAuth2Provider", function () { skipConsent: true, }); - await setOAuth2ClientIdInStorage(page, client.clientId); + await setOAuth2ClientInfo(page, client.clientId); - await page.goto(`${TEST_CLIENT_BASE_URL}/oauth2/login`); + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); let loginButton = await getOAuth2LoginButton(page); await loginButton.click(); @@ -132,7 +147,7 @@ describe("SuperTokens OAuth2Provider", function () { const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); await signUp(page, fieldValues, postValues, "emailpassword"); - await waitForUrl(page, "/oauth2/callback"); + await waitForUrl(page, "/oauth/callback"); // Validate token data const tokenData = await getOAuth2TokenData(page); @@ -142,15 +157,320 @@ describe("SuperTokens OAuth2Provider", function () { const logoutButton = await getOAuth2LogoutButton(page); await logoutButton.click(); + await waitFor(1000); + + await page.waitForSelector("#oauth2-token-data", { hidden: true }); + // Ensure the Login Button is visible after logout is clicked loginButton = await getOAuth2LoginButton(page); - assert.ok(loginButton !== null); + await loginButton.click(); + await waitForUrl(page, "/oauth/callback"); + }); + + it("should login without interaction if the user already has a session", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid email", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + }); + + await setOAuth2ClientInfo(page, client.clientId); + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/auth`), + ]); + await toggleSignInSignUp(page); + const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); + await signUp(page, fieldValues, postValues, "emailpassword"); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page); + await loginButton.click(); + + await waitForUrl(page, "/oauth/callback"); + + // Validate token data + const tokenData = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenData.aud, [client.clientId]); + }); + + it("should require logging in again with prompt=login", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid email", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + }); + + await setOAuth2ClientInfo(page, client.clientId); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page, "prompt-login"); + await loginButton.click(); + + await waitForUrl(page, "/auth"); + + await toggleSignInSignUp(page); + const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); + await signUp(page, fieldValues, postValues, "emailpassword"); + + await waitForUrl(page, "/oauth/callback"); + + // Validate token data + const tokenData = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenData.aud, [client.clientId]); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + loginButton = await getOAuth2LoginButton(page, "prompt-login"); + await loginButton.click(); + await waitForUrl(page, "/auth"); + }); + + it("should require logging in again with max_age=3 after 3 seconds", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid email", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + }); + + await setOAuth2ClientInfo(page, client.clientId); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page, "max-age-3"); + await loginButton.click(); + + await waitForUrl(page, "/auth"); + + await toggleSignInSignUp(page); + const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); + await signUp(page, fieldValues, postValues, "emailpassword"); + + await waitForUrl(page, "/oauth/callback"); + + // Validate token data + const tokenData = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenData.aud, [client.clientId]); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + loginButton = await getOAuth2LoginButton(page, "max-age-3"); + await loginButton.click(); + await waitForUrl(page, "/oauth/callback"); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + await waitFor(3000); + loginButton = await getOAuth2LoginButton(page, "max-age-3"); + await loginButton.click(); + await waitForUrl(page, "/auth"); }); it("should successfully refresh the tokens after expiry", async function () { const { client } = await createOAuth2Client({ scope: "offline_access profile openid email", - redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth2/callback`], + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + // The library refreshes the token 60 seconds before it expires. + // We set the token lifespan to 63 seconds to force a refresh in 3 seconds. + authorizationCodeGrantAccessTokenLifespan: "63s", + }); + + await setOAuth2ClientInfo(page, client.clientId); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page); + await loginButton.click(); + + await waitForUrl(page, "/auth"); + + await toggleSignInSignUp(page); + const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); + await signUp(page, fieldValues, postValues, "emailpassword"); + + await waitForUrl(page, "/oauth/callback"); + + // Validate token data + const tokenDataAfterLogin = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterLogin.aud, [client.clientId]); + + // Although the react-oidc-context library automatically refreshes the + // token, we wait for 4 seconds and reload the page to ensure a refresh. + await waitFor(4000); + await Promise.all([page.reload(), page.waitForNavigation({ waitUntil: "networkidle0" })]); + + const tokenDataAfterRefresh = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterRefresh.aud, [client.clientId]); + + // Validate the token was refreshed + assert(tokenDataAfterLogin.iat !== tokenDataAfterRefresh.iat); + assert(tokenDataAfterLogin.exp < tokenDataAfterRefresh.exp); + }); + + it("should have roles in the id_token if the scopes is requested", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid email roles permissions", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + }); + + await setOAuth2ClientInfo(page, client.clientId, "offline_access profile openid email roles permissions"); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page); + await loginButton.click(); + + await waitForUrl(page, "/auth"); + + await toggleSignInSignUp(page); + const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); + await signUp(page, fieldValues, postValues, "emailpassword"); + + await waitForUrl(page, "/oauth/callback"); + + // Validate token data + const tokenDataAfterLogin = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterLogin.aud, [client.clientId]); + + await page.evaluate( + (url) => + window.fetch(url, { + method: "POST", + headers: [["content-type", "application/json"]], + body: JSON.stringify({ + role: "testRole", + permissions: ["testPerm"], + }), + }), + `${TEST_APPLICATION_SERVER_BASE_URL}/setRole` + ); + + await waitFor(2000); + loginButton = await getOAuth2LoginButton(page, "silent"); + await loginButton.click(); + + await waitFor(1000); + + const tokenDataAfterRefresh = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterRefresh.aud, [client.clientId]); + + // Validate the token was refreshed + assert(tokenDataAfterLogin.iat !== tokenDataAfterRefresh.iat); + assert(tokenDataAfterLogin.exp < tokenDataAfterRefresh.exp); + + assert.deepStrictEqual(tokenDataAfterLogin.roles, []); + assert.deepStrictEqual(tokenDataAfterLogin.permissions, []); + + assert.deepStrictEqual(tokenDataAfterRefresh.roles, ["testRole"]); + assert.deepStrictEqual(tokenDataAfterRefresh.permissions, ["testPerm"]); + }); + + it("should not include email info if the scope is not requested", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid roles permissions", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + // The library refreshes the token 60 seconds before it expires. + // We set the token lifespan to 63 seconds to force a refresh in 3 seconds. + authorizationCodeGrantAccessTokenLifespan: "63s", + }); + + await setOAuth2ClientInfo(page, client.clientId, "offline_access profile openid roles permissions"); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page); + await loginButton.click(); + + await waitForUrl(page, "/auth"); + + await toggleSignInSignUp(page); + const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); + await signUp(page, fieldValues, postValues, "emailpassword"); + + await waitForUrl(page, "/oauth/callback"); + + // Validate token data + const tokenDataAfterLogin = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterLogin.aud, [client.clientId]); + + // Although the react-oidc-context library automatically refreshes the + // token, we wait for 4 seconds and reload the page to ensure a refresh. + await waitFor(4000); + await Promise.all([page.reload(), page.waitForNavigation({ waitUntil: "networkidle0" })]); + + const tokenDataAfterRefresh = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterRefresh.aud, [client.clientId]); + + // Validate the token was refreshed + assert(tokenDataAfterLogin.iat !== tokenDataAfterRefresh.iat); + assert(tokenDataAfterLogin.exp < tokenDataAfterRefresh.exp); + + assert.strictEqual(tokenDataAfterLogin.email, undefined); + assert.strictEqual(tokenDataAfterLogin.email_verified, undefined); + assert.strictEqual(tokenDataAfterRefresh.email, undefined); + assert.strictEqual(tokenDataAfterRefresh.email_verified, undefined); + }); + + it("should work if the scope phoneNumber is requested for emailpassword user", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid phoneNumber", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], accessTokenStrategy: "jwt", tokenEndpointAuthMethod: "none", grantTypes: ["authorization_code", "refresh_token"], @@ -161,9 +481,12 @@ describe("SuperTokens OAuth2Provider", function () { authorizationCodeGrantAccessTokenLifespan: "63s", }); - await setOAuth2ClientIdInStorage(page, client.clientId); + await setOAuth2ClientInfo(page, client.clientId, "offline_access profile openid phoneNumber"); - await page.goto(`${TEST_CLIENT_BASE_URL}/oauth2/login`); + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); let loginButton = await getOAuth2LoginButton(page); await loginButton.click(); @@ -174,7 +497,7 @@ describe("SuperTokens OAuth2Provider", function () { const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); await signUp(page, fieldValues, postValues, "emailpassword"); - await waitForUrl(page, "/oauth2/callback"); + await waitForUrl(page, "/oauth/callback"); // Validate token data const tokenDataAfterLogin = await getOAuth2TokenData(page); @@ -183,8 +506,95 @@ describe("SuperTokens OAuth2Provider", function () { // Although the react-oidc-context library automatically refreshes the // token, we wait for 4 seconds and reload the page to ensure a refresh. await waitFor(4000); - await page.reload(); - await page.waitForNavigation({ waitUntil: "networkidle0" }); + await Promise.all([page.reload(), page.waitForNavigation({ waitUntil: "networkidle0" })]); + + const tokenDataAfterRefresh = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterRefresh.aud, [client.clientId]); + + // Validate the token was refreshed + assert(tokenDataAfterLogin.iat !== tokenDataAfterRefresh.iat); + assert(tokenDataAfterLogin.exp < tokenDataAfterRefresh.exp); + + assert.strictEqual(tokenDataAfterLogin.email, undefined); + assert.strictEqual(tokenDataAfterLogin.email_verified, undefined); + assert.strictEqual(tokenDataAfterRefresh.email, undefined); + assert.strictEqual(tokenDataAfterRefresh.email_verified, undefined); + assert.strictEqual(tokenDataAfterLogin.phoneNumber, undefined); + assert.notStrictEqual(tokenDataAfterLogin.phoneNumber_verified, undefined); + assert.strictEqual(tokenDataAfterRefresh.phoneNumber, undefined); + assert.notStrictEqual(tokenDataAfterRefresh.phoneNumber_verified, undefined); + }); + + it("should reject the login if the wrong scope is requested", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + // The library refreshes the token 60 seconds before it expires. + // We set the token lifespan to 63 seconds to force a refresh in 3 seconds. + authorizationCodeGrantAccessTokenLifespan: "63s", + }); + + await setOAuth2ClientInfo(page, client.clientId, "offline_access profile openid roles permissions"); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page); + await loginButton.click(); + + assert.strictEqual( + await getOAuth2Error(page), + `Error: The requested scope is invalid, unknown, or malformed. The OAuth 2.0 Client is not allowed to request scope 'roles'.` + ); + }); + + it("should work even if the supertokens session is expired", async function () { + const { client } = await createOAuth2Client({ + scope: "offline_access profile openid email", + redirectUris: [`${TEST_CLIENT_BASE_URL}/oauth/callback`], + accessTokenStrategy: "jwt", + tokenEndpointAuthMethod: "none", + grantTypes: ["authorization_code", "refresh_token"], + responseTypes: ["code", "id_token"], + skipConsent: true, + // The library refreshes the token 60 seconds before it expires. + // We set the token lifespan to 63 seconds to force a refresh in 3 seconds. + authorizationCodeGrantAccessTokenLifespan: "63s", + }); + + await setOAuth2ClientInfo(page, client.clientId); + + await toggleSignInSignUp(page); + const { fieldValues, postValues } = getDefaultSignUpFieldValues({ email: getTestEmail() }); + await signUp(page, fieldValues, postValues, "emailpassword"); + + await waitFor(6000); + + await Promise.all([ + page.waitForNavigation({ waitUntil: "networkidle0" }), + page.goto(`${TEST_CLIENT_BASE_URL}/oauth/login`), + ]); + + let loginButton = await getOAuth2LoginButton(page); + await loginButton.click(); + + await waitForUrl(page, "/oauth/callback"); + + // Validate token data + const tokenDataAfterLogin = await getOAuth2TokenData(page); + assert.deepStrictEqual(tokenDataAfterLogin.aud, [client.clientId]); + + // Although the react-oidc-context library automatically refreshes the + // token, we wait for 6 seconds and reload the page to ensure a refresh. + await waitFor(6000); + await Promise.all([page.reload(), page.waitForNavigation({ waitUntil: "networkidle0" })]); const tokenDataAfterRefresh = await getOAuth2TokenData(page); assert.deepStrictEqual(tokenDataAfterRefresh.aud, [client.clientId]); diff --git a/test/end-to-end/signin.test.js b/test/end-to-end/signin.test.js index 876fd83bd..883218ea3 100644 --- a/test/end-to-end/signin.test.js +++ b/test/end-to-end/signin.test.js @@ -482,7 +482,7 @@ describe("SuperTokens SignIn", function () { await assertSignInRedirectTo( page, `${TEST_CLIENT_BASE_URL}/auth?rid=emailpassword&redirectToPath=%2Fredirect-here`, - `${TEST_CLIENT_BASE_URL}/redirect-here` + `/redirect-here` ); // test that if we visit auth again, we end up in redirect-heree again with query params kept @@ -492,15 +492,14 @@ describe("SuperTokens SignIn", function () { ), page.waitForNavigation({ waitUntil: "networkidle0" }), ]); - const { pathname, search } = await page.evaluate(() => window.location); - assert.deepStrictEqual(pathname + search, "/redirect-heree?foo=bar"); + await waitForUrl(page, "/redirect-heree?foo=bar", false); }); it("Successful Sign In with redirect to, redirectToPath directly without trailing slash", async function () { await assertSignInRedirectTo( page, `${TEST_CLIENT_BASE_URL}/auth?rid=emailpassword&redirectToPath=redirect-here`, - `${TEST_CLIENT_BASE_URL}/redirect-here` + `/redirect-here` ); }); @@ -531,7 +530,7 @@ describe("SuperTokens SignIn", function () { await assertSignInRedirectTo( page, `${TEST_CLIENT_BASE_URL}/auth?rid=emailpassword&redirectToPath=https://attacker.com/path`, - `${TEST_CLIENT_BASE_URL}/path` + `/path` ); }); @@ -540,7 +539,7 @@ describe("SuperTokens SignIn", function () { await assertSignInRedirectTo( page, `${TEST_CLIENT_BASE_URL}/auth?rid=emailpassword&redirectToPath=javascript:alert(1)`, - `${TEST_CLIENT_BASE_URL}/javascript:alert(1)` + `/javascript:alert(1)` ); }); @@ -1054,11 +1053,5 @@ async function assertSignInRedirectTo(page, startUrl, finalUrl) { ]); // Submit. - await Promise.all([ - submitFormReturnRequestAndResponse(page, SIGN_IN_API), - page.waitForNavigation({ waitUntil: "networkidle0" }), - ]); - - let href = await page.evaluate(() => window.location.href); - assert.deepStrictEqual(href, finalUrl); + await Promise.all([submitFormReturnRequestAndResponse(page, SIGN_IN_API), waitForUrl(page, finalUrl, false)]); } diff --git a/test/helpers.js b/test/helpers.js index efe97ed4d..672718e9b 100644 --- a/test/helpers.js +++ b/test/helpers.js @@ -1117,16 +1117,41 @@ export async function createOAuth2Client(input) { // For the OAuth2 end-to-end test, we need to provide the created clientId to both the OAuth2 login and callback pages. // We use localStorage to store the clientId instead of query params, as it must be available on the callback page as well. -export async function setOAuth2ClientIdInStorage(page, clientId) { - return page.evaluate((clientId) => localStorage.setItem("oauth2-client-id", clientId), clientId); +export async function setOAuth2ClientInfo(page, clientId, scopes, extraConfig, extraSignInParams, extraSignOutParams) { + await page.evaluate((clientId) => localStorage.setItem("oauth2-client-id", clientId), clientId); + if (scopes) { + await page.evaluate((scopes) => localStorage.setItem("oauth2-scopes", scopes), scopes); + } + if (extraConfig) { + await page.evaluate((extraConfig) => localStorage.setItem("oauth2-extra-config", extraConfig), extraConfig); + } + if (extraSignInParams) { + await page.evaluate( + (extraSignInParams) => localStorage.setItem("oauth2-extra-sign-in-params", extraSignInParams), + extraSignInParams + ); + } + if (extraSignOutParams) { + await page.evaluate( + (extraSignOutParams) => localStorage.setItem("oauth2-extra-sign-out-params", extraSignOutParams), + extraSignOutParams + ); + } +} + +export async function removeOAuth2ClientInfo(page) { + await page.evaluate(() => localStorage.removeItem("oauth2-client-id")); + await page.evaluate(() => localStorage.removeItem("oauth2-scopes")); } -export async function removeOAuth2ClientIdFromStorage(page) { - return page.evaluate(() => localStorage.removeItem("oauth2-client-id")); +export async function getOAuth2LoginButton(page, type = "default") { + const id = type === "default" ? "#oauth2-login-button" : `#oauth2-login-button-${type}`; + return page.waitForSelector(id); } -export async function getOAuth2LoginButton(page) { - return page.waitForSelector("#oauth2-login-button"); +export async function getOAuth2Error(page) { + const ele = await page.waitForSelector("#oauth2-error-message"); + return await ele.evaluate((el) => el.textContent); } export async function getOAuth2LogoutButton(page) { diff --git a/test/server/package-lock.json b/test/server/package-lock.json index 80f265cec..6cf95278b 100644 --- a/test/server/package-lock.json +++ b/test/server/package-lock.json @@ -16,7 +16,7 @@ "express": "4.17.1", "morgan": "^1.10.0", "otpauth": "^9.2.0", - "supertokens-node": "18.0" + "supertokens-node": "github:supertokens/supertokens-node#feat/oauth2/base" } }, "node_modules/accepts": { @@ -995,6 +995,11 @@ "node": ">= 0.8.0" } }, + "node_modules/set-cookie-parser": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.7.0.tgz", + "integrity": "sha512-lXLOiqpkUumhRdFF3k1osNXCy9akgx/dyPZ5p8qAg9seJzXr5ZrlqZuWIMuY6ejOsVLE6flJ5/h3lsn57fQ/PQ==" + }, "node_modules/set-function-length": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.1.1.tgz", @@ -1041,9 +1046,8 @@ "integrity": "sha512-r0JFBjkMIdep3Lbk3JA+MpnpuOtw4RSyrlRAbrzMcxwiYco3GFWl/daimQZ5b1forOiUODpOlXbSOljP/oyurg==" }, "node_modules/supertokens-node": { - "version": "18.0.0", - "resolved": "https://registry.npmjs.org/supertokens-node/-/supertokens-node-18.0.0.tgz", - "integrity": "sha512-NPFPShZu44EI3jJK0qW8Wm8GfNhM4xUOWFJ/1EvNW1pzVN0EmJkIzqlmzeBExg5oc03fZXKS4YnUTt6PAnlD1w==", + "version": "20.0.2", + "resolved": "git+ssh://git@github.com/supertokens/supertokens-node.git#905b5cd6e9babe50488318e32295a353523b8069", "dependencies": { "content-type": "^1.0.5", "cookie": "0.4.0", @@ -1055,6 +1059,7 @@ "nodemailer": "^6.7.2", "pkce-challenge": "^3.0.0", "psl": "1.8.0", + "set-cookie-parser": "^2.6.0", "supertokens-js-override": "^0.0.4", "twilio": "^4.19.3" } @@ -1976,6 +1981,11 @@ "send": "0.17.1" } }, + "set-cookie-parser": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.7.0.tgz", + "integrity": "sha512-lXLOiqpkUumhRdFF3k1osNXCy9akgx/dyPZ5p8qAg9seJzXr5ZrlqZuWIMuY6ejOsVLE6flJ5/h3lsn57fQ/PQ==" + }, "set-function-length": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.1.1.tgz", @@ -2013,9 +2023,8 @@ "integrity": "sha512-r0JFBjkMIdep3Lbk3JA+MpnpuOtw4RSyrlRAbrzMcxwiYco3GFWl/daimQZ5b1forOiUODpOlXbSOljP/oyurg==" }, "supertokens-node": { - "version": "18.0.0", - "resolved": "https://registry.npmjs.org/supertokens-node/-/supertokens-node-18.0.0.tgz", - "integrity": "sha512-NPFPShZu44EI3jJK0qW8Wm8GfNhM4xUOWFJ/1EvNW1pzVN0EmJkIzqlmzeBExg5oc03fZXKS4YnUTt6PAnlD1w==", + "version": "git+ssh://git@github.com/supertokens/supertokens-node.git#905b5cd6e9babe50488318e32295a353523b8069", + "from": "supertokens-node@github:supertokens/supertokens-node#feat/oauth2/base", "requires": { "content-type": "^1.0.5", "cookie": "0.4.0", @@ -2027,6 +2036,7 @@ "nodemailer": "^6.7.2", "pkce-challenge": "^3.0.0", "psl": "1.8.0", + "set-cookie-parser": "^2.6.0", "supertokens-js-override": "^0.0.4", "twilio": "^4.19.3" }, diff --git a/test/server/package.json b/test/server/package.json index 0fdaf93f1..a36e4efd1 100644 --- a/test/server/package.json +++ b/test/server/package.json @@ -16,6 +16,6 @@ "express": "4.17.1", "morgan": "^1.10.0", "otpauth": "^9.2.0", - "supertokens-node": "18.0" + "supertokens-node": "github:supertokens/supertokens-node#feat/oauth2/base" } } diff --git a/test/with-typescript/src/App.tsx b/test/with-typescript/src/App.tsx index 64ae7db8e..6cfc6b85d 100644 --- a/test/with-typescript/src/App.tsx +++ b/test/with-typescript/src/App.tsx @@ -281,6 +281,9 @@ function getRecipeList() { } return context; }, + postAPIHook: async (context) => { + context.userContext; + }, override: { functions: (oI) => { return { From dac170ec6e534643c61c3b034d2e175f6f243db4 Mon Sep 17 00:00:00 2001 From: Ankit Tiwari Date: Tue, 27 Aug 2024 21:20:04 +0530 Subject: [PATCH 3/3] feat: Add functions and prebuiltUI for oauth2 logout (#850) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat: Add functions and prebuiltUI for oauth2 logout * Update lib/ts/recipe/oauth2provider/components/themes/themeBase.tsx Co-authored-by: Mihály Lengyel * fix: PR changes * fix: PR changes --------- Co-authored-by: Mihály Lengyel --- examples/for-tests/src/OAuth2Page.js | 5 +- lib/build/components/assets/logoutIcon.d.ts | 2 + lib/build/oauth2provider-shared.js | 25 ++ lib/build/oauth2provider.js | 18 + lib/build/oauth2providerprebuiltui.js | 379 ++++++++++++++++-- .../features/oauth2LogoutScreen/index.d.ts | 11 + .../OAuth2LogoutScreenInner.d.ts | 5 + .../themes/oauth2LogoutScreen/index.d.ts | 3 + .../components/themes/themeBase.d.ts | 7 + .../components/themes/translations.d.ts | 26 +- .../recipe/oauth2provider/constants.d.ts | 1 + lib/build/recipe/oauth2provider/index.d.ts | 20 + .../recipe/oauth2provider/prebuiltui.d.ts | 35 +- lib/build/recipe/oauth2provider/types.d.ts | 47 ++- lib/ts/components/assets/logoutIcon.tsx | 27 ++ .../features/oauth2LogoutScreen/index.tsx | 130 ++++++ .../OAuth2LogoutScreenInner.tsx | 41 ++ .../themes/oauth2LogoutScreen/index.tsx | 36 ++ .../components/themes/styles.css | 31 ++ .../components/themes/themeBase.tsx | 36 ++ .../components/themes/translations.ts | 9 +- lib/ts/recipe/oauth2provider/constants.ts | 1 + .../oauth2provider/functionOverrides.ts | 9 + lib/ts/recipe/oauth2provider/index.ts | 23 ++ lib/ts/recipe/oauth2provider/prebuiltui.tsx | 57 ++- lib/ts/recipe/oauth2provider/recipe.ts | 2 + lib/ts/recipe/oauth2provider/types.ts | 57 ++- lib/ts/recipe/oauth2provider/utils.ts | 5 + stories/oauth2provider.stories.tsx | 81 ++++ test/end-to-end/oauth2provider.test.js | 63 +++ test/helpers.js | 8 +- test/unit/componentOverrides.test.tsx | 7 +- 32 files changed, 1129 insertions(+), 78 deletions(-) create mode 100644 lib/build/components/assets/logoutIcon.d.ts create mode 100644 lib/build/recipe/oauth2provider/components/features/oauth2LogoutScreen/index.d.ts create mode 100644 lib/build/recipe/oauth2provider/components/themes/oauth2LogoutScreen/OAuth2LogoutScreenInner.d.ts create mode 100644 lib/build/recipe/oauth2provider/components/themes/oauth2LogoutScreen/index.d.ts create mode 100644 lib/build/recipe/oauth2provider/components/themes/themeBase.d.ts create mode 100644 lib/ts/components/assets/logoutIcon.tsx create mode 100644 lib/ts/recipe/oauth2provider/components/features/oauth2LogoutScreen/index.tsx create mode 100644 lib/ts/recipe/oauth2provider/components/themes/oauth2LogoutScreen/OAuth2LogoutScreenInner.tsx create mode 100644 lib/ts/recipe/oauth2provider/components/themes/oauth2LogoutScreen/index.tsx create mode 100644 lib/ts/recipe/oauth2provider/components/themes/styles.css create mode 100644 lib/ts/recipe/oauth2provider/components/themes/themeBase.tsx create mode 100644 stories/oauth2provider.stories.tsx diff --git a/examples/for-tests/src/OAuth2Page.js b/examples/for-tests/src/OAuth2Page.js index aa5b03839..3db24f8b8 100644 --- a/examples/for-tests/src/OAuth2Page.js +++ b/examples/for-tests/src/OAuth2Page.js @@ -23,7 +23,7 @@ const oidcConfig = { }; function AuthPage() { - const { signinRedirect, signinSilent, signoutSilent, user, error } = useAuth(); + const { signinRedirect, signinSilent, signoutSilent, signoutRedirect, user, error } = useAuth(); return (
@@ -36,6 +36,9 @@ function AuthPage() { + )}