{"version":3,"file":"aws-amplify-Dc6ymh5k.js","sources":["../../../node_modules/@aws-amplify/core/dist/esm/constants.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Logger/types.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Logger/ConsoleLogger.mjs","../../../node_modules/@aws-amplify/core/dist/esm/errors/AmplifyError.mjs","../../../node_modules/@aws-amplify/core/dist/esm/types/errors.mjs","../../../node_modules/@aws-amplify/core/dist/esm/errors/createAssertionFunction.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Hub/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/globalHelpers/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/convert/base64/base64Decoder.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/Auth/utils/errorHelpers.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/Auth/utils/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/deepFreeze.mjs","../../../node_modules/@aws-amplify/core/dist/esm/parseAWSExports.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/constants.mjs","../../../node_modules/uuid/dist/esm-browser/rng.js","../../../node_modules/uuid/dist/esm-browser/stringify.js","../../../node_modules/uuid/dist/esm-browser/native.js","../../../node_modules/uuid/dist/esm-browser/v4.js","../../../node_modules/@aws-amplify/core/dist/esm/parseAmplifyOutputs.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/parseAmplifyConfig.mjs","../../../node_modules/@aws-crypto/sha256-js/build/module/constants.js","../../../node_modules/@aws-crypto/sha256-js/build/module/RawSha256.js","../../../node_modules/@aws-crypto/util/node_modules/@smithy/util-utf8/dist-es/fromUtf8.browser.js","../../../node_modules/@aws-crypto/util/build/module/convertToBuffer.js","../../../node_modules/@aws-crypto/util/build/module/isEmptyData.js","../../../node_modules/@aws-crypto/sha256-js/build/module/jsSha256.js","../../../node_modules/@aws-amplify/core/node_modules/@smithy/util-hex-encoding/dist-es/index.js","../../../node_modules/@aws-amplify/core/dist/esm/Platform/types.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/version.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/helpers.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/React.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/Vue.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/Svelte.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/Next.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/Nuxt.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/Angular.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/ReactNative.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/Expo.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/Web.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detection/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/detectFramework.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/customUserAgent.mjs","../../../node_modules/@aws-amplify/core/dist/esm/Platform/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/isBrowser.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/Auth/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/Amplify.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/apis/internal/fetchAuthSession.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/apis/fetchAuthSession.mjs","../../../node_modules/@aws-amplify/core/dist/esm/singleton/apis/clearCredentials.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/serde/responseInfo.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/serde/json.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/internal/composeServiceApi.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/endpoints/partitions.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/endpoints/getDnsSuffix.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/retry/constants.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/retry/retryMiddleware.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/amplifyUuid/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/retry/amzSdkInvocationIdHeaderMiddleware.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/retry/amzSdkRequestHeaderMiddleware.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/userAgent/middleware.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/internal/composeTransferHandler.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/utils/memoization.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/handlers/fetch.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/handlers/aws/unauthenticated.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/retry/constants.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/retry/jitteredBackoff.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/retry/jitteredBackoff.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/retry/isClockSkewError.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/retry/defaultRetryDecider.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/amplifyUrl/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/awsClients/cognitoIdentity/base.mjs","../../../node_modules/@aws-amplify/core/dist/esm/awsClients/cognitoIdentity/getId.mjs","../../../node_modules/@aws-amplify/core/dist/esm/awsClients/cognitoIdentity/getCredentialsForIdentity.mjs","../../../node_modules/@aws-amplify/core/dist/esm/errors/PlatformNotSupportedError.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/KeyValueStorage.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/InMemoryStorage.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/utils.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/DefaultStorage.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/SessionStorage.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/SyncKeyValueStorage.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/SyncSessionStorage.mjs","../../../node_modules/@aws-amplify/core/node_modules/js-cookie/dist/js.cookie.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/CookieStorage.mjs","../../../node_modules/@aws-amplify/core/dist/esm/storage/index.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getSignedHeaders.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/constants.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getCredentialScope.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getFormattedDates.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getSigningValues.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/dataHashHelpers.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getCanonicalHeaders.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getCanonicalQueryString.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getCanonicalUri.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getHashedPayload.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getCanonicalRequest.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getSigningKey.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getStringToSign.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/utils/getSignature.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/signer/signatureV4/signRequest.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/utils/getSkewCorrectedDate.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/utils/isClockSkewed.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/utils/getUpdatedSystemClockOffset.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/middleware.mjs","../../../node_modules/@aws-amplify/core/dist/esm/clients/middleware/signing/utils/extendedEncodeURIComponent.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/deDupeAsyncFunction.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/isTokenExpired.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/deviceName/getDeviceName.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/convert/base64/bytesToString.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/convert/base64/base64Encoder.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/cryptoSecureRandomInt.mjs","../../../node_modules/@aws-amplify/core/dist/esm/utils/WordArray.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/errors/types/validation.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/common/AuthErrorStrings.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/errors/AuthError.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/errors/utils/assertValidationError.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/parsers/regionParsers.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/apiHelpers.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/types/errors.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/errors/constants.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/types.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/internal/getCurrentUser.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/getCurrentUser.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/utils/getAuthUserAgentValue.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/shared/serde/createUserPoolSerializer.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/errors/utils/assertServiceError.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/shared/serde/createUserPoolDeserializer.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/constants.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createInitiateAuthClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createRespondToAuthChallengeClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createAssociateSoftwareTokenClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/cognitoUserPoolEndpointResolver.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/factories/createCognitoUserPoolEndpointResolver.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/userContextData.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/refreshAuthTokens.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/types.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/errorHelpers.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/constants.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/TokenStore.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/signInWithRedirectStore.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/oauth/oAuthStore.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/TokenOrchestrator.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/CognitoUserPoolsTokenProvider.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/tokenProvider.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/tokenProvider/cacheTokens.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/dispatchSignedInHubEvent.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/utils/store/autoSignInStore.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/utils/store/signInStore.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/utils/passkey/errors.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/utils/passkey/getIsPasskeySupported.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/convert/base64url/convertArrayBufferToBase64Url.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/convert/base64url/convertBase64UrlToArrayBuffer.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/utils/passkey/serde.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/utils/passkey/types/index.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/utils/passkey/getPasskey.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createConfirmDeviceClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/textEncoder/index.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/BigInteger/BigInteger.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/calculate/calculateS.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/constants.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getBytesFromHex.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getHexFromBytes.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getHashFromData.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getHashFromHex.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getPaddedHex.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/calculate/calculateU.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getHkdfKey.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getRandomBytes.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getRandomString.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/AuthenticationHelper/AuthenticationHelper.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/calculate/calculateA.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getAuthenticationHelper.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/getNewDeviceMetadata.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/flows/userAuth/handleWebAuthnSignInResult.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getNowString.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/srp/getSignatureString.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/handleDeviceSRPAuth.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/handlePasswordVerifierChallenge.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/retryOnResourceNotFoundException.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/setActiveSignInUsername.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/flows/shared/handlePasswordSRP.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/signInHelpers.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signInWithCustomAuth.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signInWithCustomSRPAuth.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/autoSignIn.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signInWithSRP.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signInWithUserPassword.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/client/flows/userAuth/handleUserAuthFlow.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signInWithUserAuth.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signIn.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/signUpHelpers.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createSignUpClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signUp.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createForgotPasswordClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/resetPassword.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createConfirmForgotPasswordClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/confirmResetPassword.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createConfirmSignUpClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/confirmSignUp.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/oauth/getRedirectUrl.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/utils/openAuthSession.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/oauth/completeOAuthSignOut.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/oauth/oAuthSignOutRedirect.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/utils/oauth/handleOAuthSignOut.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/foundation/factories/serviceClients/cognitoIdentityProvider/createRevokeTokenClient.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/apis/signOut.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/credentialsProvider/types.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/credentialsProvider/IdentityIdStore.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/credentialsProvider/utils.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/credentialsProvider/IdentityIdProvider.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/credentialsProvider/credentialsProvider.mjs","../../../node_modules/@aws-amplify/auth/dist/esm/providers/cognito/credentialsProvider/index.mjs","../../../node_modules/aws-amplify/dist/esm/initSingleton.mjs"],"sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Logging constants\nconst AWS_CLOUDWATCH_CATEGORY = 'Logging';\nconst USER_AGENT_HEADER = 'x-amz-user-agent';\n// Error exception code constants\nconst NO_HUBCALLBACK_PROVIDED_EXCEPTION = 'NoHubcallbackProvidedException';\n\nexport { AWS_CLOUDWATCH_CATEGORY, NO_HUBCALLBACK_PROVIDED_EXCEPTION, USER_AGENT_HEADER };\n//# sourceMappingURL=constants.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nvar LogType;\n(function (LogType) {\n LogType[\"DEBUG\"] = \"DEBUG\";\n LogType[\"ERROR\"] = \"ERROR\";\n LogType[\"INFO\"] = \"INFO\";\n LogType[\"WARN\"] = \"WARN\";\n LogType[\"VERBOSE\"] = \"VERBOSE\";\n LogType[\"NONE\"] = \"NONE\";\n})(LogType || (LogType = {}));\n\nexport { LogType };\n//# sourceMappingURL=types.mjs.map\n","import { AWS_CLOUDWATCH_CATEGORY } from '../constants.mjs';\nimport { LogType } from './types.mjs';\n\n/* eslint-disable no-console */\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst LOG_LEVELS = {\n VERBOSE: 1,\n DEBUG: 2,\n INFO: 3,\n WARN: 4,\n ERROR: 5,\n NONE: 6,\n};\n/**\n * Write logs\n * @class Logger\n */\nclass ConsoleLogger {\n /**\n * @constructor\n * @param {string} name - Name of the logger\n */\n constructor(name, level = LogType.WARN) {\n this.name = name;\n this.level = level;\n this._pluggables = [];\n }\n _padding(n) {\n return n < 10 ? '0' + n : '' + n;\n }\n _ts() {\n const dt = new Date();\n return ([this._padding(dt.getMinutes()), this._padding(dt.getSeconds())].join(':') +\n '.' +\n dt.getMilliseconds());\n }\n configure(config) {\n if (!config)\n return this._config;\n this._config = config;\n return this._config;\n }\n /**\n * Write log\n * @method\n * @memeberof Logger\n * @param {LogType|string} type - log type, default INFO\n * @param {string|object} msg - Logging message or object\n */\n _log(type, ...msg) {\n let loggerLevelName = this.level;\n if (ConsoleLogger.LOG_LEVEL) {\n loggerLevelName = ConsoleLogger.LOG_LEVEL;\n }\n if (typeof window !== 'undefined' && window.LOG_LEVEL) {\n loggerLevelName = window.LOG_LEVEL;\n }\n const loggerLevel = LOG_LEVELS[loggerLevelName];\n const typeLevel = LOG_LEVELS[type];\n if (!(typeLevel >= loggerLevel)) {\n // Do nothing if type is not greater than or equal to logger level (handle undefined)\n return;\n }\n let log = console.log.bind(console);\n if (type === LogType.ERROR && console.error) {\n log = console.error.bind(console);\n }\n if (type === LogType.WARN && console.warn) {\n log = console.warn.bind(console);\n }\n if (ConsoleLogger.BIND_ALL_LOG_LEVELS) {\n if (type === LogType.INFO && console.info) {\n log = console.info.bind(console);\n }\n if (type === LogType.DEBUG && console.debug) {\n log = console.debug.bind(console);\n }\n }\n const prefix = `[${type}] ${this._ts()} ${this.name}`;\n let message = '';\n if (msg.length === 1 && typeof msg[0] === 'string') {\n message = `${prefix} - ${msg[0]}`;\n log(message);\n }\n else if (msg.length === 1) {\n message = `${prefix} ${msg[0]}`;\n log(prefix, msg[0]);\n }\n else if (typeof msg[0] === 'string') {\n let obj = msg.slice(1);\n if (obj.length === 1) {\n obj = obj[0];\n }\n message = `${prefix} - ${msg[0]} ${obj}`;\n log(`${prefix} - ${msg[0]}`, obj);\n }\n else {\n message = `${prefix} ${msg}`;\n log(prefix, msg);\n }\n for (const plugin of this._pluggables) {\n const logEvent = { message, timestamp: Date.now() };\n plugin.pushLogs([logEvent]);\n }\n }\n /**\n * Write General log. Default to INFO\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n log(...msg) {\n this._log(LogType.INFO, ...msg);\n }\n /**\n * Write INFO log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n info(...msg) {\n this._log(LogType.INFO, ...msg);\n }\n /**\n * Write WARN log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n warn(...msg) {\n this._log(LogType.WARN, ...msg);\n }\n /**\n * Write ERROR log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n error(...msg) {\n this._log(LogType.ERROR, ...msg);\n }\n /**\n * Write DEBUG log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n debug(...msg) {\n this._log(LogType.DEBUG, ...msg);\n }\n /**\n * Write VERBOSE log\n * @method\n * @memeberof Logger\n * @param {string|object} msg - Logging message or object\n */\n verbose(...msg) {\n this._log(LogType.VERBOSE, ...msg);\n }\n addPluggable(pluggable) {\n if (pluggable && pluggable.getCategoryName() === AWS_CLOUDWATCH_CATEGORY) {\n this._pluggables.push(pluggable);\n pluggable.configure(this._config);\n }\n }\n listPluggables() {\n return this._pluggables;\n }\n}\nConsoleLogger.LOG_LEVEL = null;\nConsoleLogger.BIND_ALL_LOG_LEVELS = false;\n\nexport { ConsoleLogger };\n//# sourceMappingURL=ConsoleLogger.mjs.map\n","class AmplifyError extends Error {\n /**\n * Constructs an AmplifyError.\n *\n * @param message text that describes the main problem.\n * @param underlyingError the underlying cause of the error.\n * @param recoverySuggestion suggestion to recover from the error.\n *\n */\n constructor({ message, name, recoverySuggestion, underlyingError, metadata, }) {\n super(message);\n this.name = name;\n this.underlyingError = underlyingError;\n this.recoverySuggestion = recoverySuggestion;\n if (metadata) {\n // If metadata exists, explicitly only record the following properties.\n const { extendedRequestId, httpStatusCode, requestId } = metadata;\n this.metadata = { extendedRequestId, httpStatusCode, requestId };\n }\n // Hack for making the custom error class work when transpiled to es5\n // TODO: Delete the following 2 lines after we change the build target to >= es2015\n this.constructor = AmplifyError;\n Object.setPrototypeOf(this, AmplifyError.prototype);\n }\n}\n\nexport { AmplifyError };\n//# sourceMappingURL=AmplifyError.mjs.map\n","var AmplifyErrorCode;\n(function (AmplifyErrorCode) {\n AmplifyErrorCode[\"NoEndpointId\"] = \"NoEndpointId\";\n AmplifyErrorCode[\"PlatformNotSupported\"] = \"PlatformNotSupported\";\n AmplifyErrorCode[\"Unknown\"] = \"Unknown\";\n AmplifyErrorCode[\"NetworkError\"] = \"NetworkError\";\n})(AmplifyErrorCode || (AmplifyErrorCode = {}));\n\nexport { AmplifyErrorCode };\n//# sourceMappingURL=errors.mjs.map\n","import { AmplifyError } from './AmplifyError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createAssertionFunction = (errorMap, AssertionError = AmplifyError) => (assertion, name, additionalContext) => {\n const { message, recoverySuggestion } = errorMap[name];\n if (!assertion) {\n throw new AssertionError({\n name,\n message: additionalContext\n ? `${message} ${additionalContext}`\n : message,\n recoverySuggestion,\n });\n }\n};\n\nexport { createAssertionFunction };\n//# sourceMappingURL=createAssertionFunction.mjs.map\n","import { ConsoleLogger } from '../Logger/ConsoleLogger.mjs';\nimport { NO_HUBCALLBACK_PROVIDED_EXCEPTION } from '../constants.mjs';\nimport { AmplifyError } from '../errors/AmplifyError.mjs';\nimport '../types/errors.mjs';\nimport '../errors/errorHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst AMPLIFY_SYMBOL = (typeof Symbol !== 'undefined'\n ? Symbol('amplify_default')\n : '@@amplify_default');\nconst logger = new ConsoleLogger('Hub');\nclass HubClass {\n constructor(name) {\n this.listeners = new Map();\n this.protectedChannels = [\n 'core',\n 'auth',\n 'api',\n 'analytics',\n 'interactions',\n 'pubsub',\n 'storage',\n 'ui',\n 'xr',\n ];\n this.name = name;\n }\n /**\n * Used internally to remove a Hub listener.\n *\n * @remarks\n * This private method is for internal use only. Instead of calling Hub.remove, call the result of Hub.listen.\n */\n _remove(channel, listener) {\n const holder = this.listeners.get(channel);\n if (!holder) {\n logger.warn(`No listeners for ${channel}`);\n return;\n }\n this.listeners.set(channel, [\n ...holder.filter(({ callback }) => callback !== listener),\n ]);\n }\n dispatch(channel, payload, source, ampSymbol) {\n if (typeof channel === 'string' &&\n this.protectedChannels.indexOf(channel) > -1) {\n const hasAccess = ampSymbol === AMPLIFY_SYMBOL;\n if (!hasAccess) {\n logger.warn(`WARNING: ${channel} is protected and dispatching on it can have unintended consequences`);\n }\n }\n const capsule = {\n channel,\n payload: { ...payload },\n source,\n patternInfo: [],\n };\n try {\n this._toListeners(capsule);\n }\n catch (e) {\n logger.error(e);\n }\n }\n listen(channel, callback, listenerName = 'noname') {\n let cb;\n if (typeof callback !== 'function') {\n throw new AmplifyError({\n name: NO_HUBCALLBACK_PROVIDED_EXCEPTION,\n message: 'No callback supplied to Hub',\n });\n }\n else {\n // Needs to be casted as a more generic type\n cb = callback;\n }\n let holder = this.listeners.get(channel);\n if (!holder) {\n holder = [];\n this.listeners.set(channel, holder);\n }\n holder.push({\n name: listenerName,\n callback: cb,\n });\n return () => {\n this._remove(channel, cb);\n };\n }\n _toListeners(capsule) {\n const { channel, payload } = capsule;\n const holder = this.listeners.get(channel);\n if (holder) {\n holder.forEach(listener => {\n logger.debug(`Dispatching to ${channel} with `, payload);\n try {\n listener.callback(capsule);\n }\n catch (e) {\n logger.error(e);\n }\n });\n }\n }\n}\n/* We export a __default__ instance of HubClass to use it as a\npseudo Singleton for the main messaging bus, however you can still create\nyour own instance of HubClass() for a separate \"private bus\" of events. */\nconst Hub = new HubClass('__default__');\n/**\n * @internal\n *\n * Internal hub used for core Amplify functionality. Not intended for use outside of Amplify.\n *\n */\nconst HubInternal = new HubClass('internal-hub');\n\nexport { AMPLIFY_SYMBOL, Hub, HubClass, HubInternal };\n//# sourceMappingURL=index.mjs.map\n","import { AmplifyError } from '../../errors/AmplifyError.mjs';\nimport '../../types/errors.mjs';\nimport '../../errors/errorHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst getCrypto = () => {\n if (typeof window === 'object' && typeof window.crypto === 'object') {\n return window.crypto;\n }\n // Next.js global polyfill\n if (typeof crypto === 'object') {\n return crypto;\n }\n throw new AmplifyError({\n name: 'MissingPolyfill',\n message: 'Cannot resolve the `crypto` function from the environment.',\n });\n};\nconst getBtoa = () => {\n // browser\n if (typeof window !== 'undefined' && typeof window.btoa === 'function') {\n return window.btoa;\n }\n // Next.js global polyfill\n if (typeof btoa === 'function') {\n return btoa;\n }\n throw new AmplifyError({\n name: 'Base64EncoderError',\n message: 'Cannot resolve the `btoa` function from the environment.',\n });\n};\nconst getAtob = () => {\n // browser\n if (typeof window !== 'undefined' && typeof window.atob === 'function') {\n return window.atob;\n }\n // Next.js global polyfill\n if (typeof atob === 'function') {\n return atob;\n }\n throw new AmplifyError({\n name: 'Base64EncoderError',\n message: 'Cannot resolve the `atob` function from the environment.',\n });\n};\n\nexport { getAtob, getBtoa, getCrypto };\n//# sourceMappingURL=index.mjs.map\n","import { getAtob } from '../../globalHelpers/index.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst base64Decoder = {\n convert(input, options) {\n let inputStr = input;\n // urlSafe character replacement options conform to the base64 url spec\n // https://datatracker.ietf.org/doc/html/rfc4648#page-7\n if (options?.urlSafe) {\n inputStr = inputStr.replace(/-/g, '+').replace(/_/g, '/');\n }\n return getAtob()(inputStr);\n },\n};\n\nexport { base64Decoder };\n//# sourceMappingURL=base64Decoder.mjs.map\n","import { createAssertionFunction } from '../../../errors/createAssertionFunction.mjs';\nimport '../../../types/errors.mjs';\nimport '../../../errors/errorHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nvar AuthConfigurationErrorCode;\n(function (AuthConfigurationErrorCode) {\n AuthConfigurationErrorCode[\"AuthTokenConfigException\"] = \"AuthTokenConfigException\";\n AuthConfigurationErrorCode[\"AuthUserPoolAndIdentityPoolException\"] = \"AuthUserPoolAndIdentityPoolException\";\n AuthConfigurationErrorCode[\"AuthUserPoolException\"] = \"AuthUserPoolException\";\n AuthConfigurationErrorCode[\"InvalidIdentityPoolIdException\"] = \"InvalidIdentityPoolIdException\";\n AuthConfigurationErrorCode[\"OAuthNotConfigureException\"] = \"OAuthNotConfigureException\";\n})(AuthConfigurationErrorCode || (AuthConfigurationErrorCode = {}));\nconst authConfigurationErrorMap = {\n [AuthConfigurationErrorCode.AuthTokenConfigException]: {\n message: 'Auth Token Provider not configured.',\n recoverySuggestion: 'Make sure to call Amplify.configure in your app.',\n },\n [AuthConfigurationErrorCode.AuthUserPoolAndIdentityPoolException]: {\n message: 'Auth UserPool or IdentityPool not configured.',\n recoverySuggestion: 'Make sure to call Amplify.configure in your app with UserPoolId and IdentityPoolId.',\n },\n [AuthConfigurationErrorCode.AuthUserPoolException]: {\n message: 'Auth UserPool not configured.',\n recoverySuggestion: 'Make sure to call Amplify.configure in your app with userPoolId and userPoolClientId.',\n },\n [AuthConfigurationErrorCode.InvalidIdentityPoolIdException]: {\n message: 'Invalid identity pool id provided.',\n recoverySuggestion: 'Make sure a valid identityPoolId is given in the config.',\n },\n [AuthConfigurationErrorCode.OAuthNotConfigureException]: {\n message: 'oauth param not configured.',\n recoverySuggestion: 'Make sure to call Amplify.configure with oauth parameter in your app.',\n },\n};\nconst assert = createAssertionFunction(authConfigurationErrorMap);\n\nexport { AuthConfigurationErrorCode, assert };\n//# sourceMappingURL=errorHelpers.mjs.map\n","import { base64Decoder } from '../../../utils/convert/base64/base64Decoder.mjs';\nimport '../../../types/errors.mjs';\nimport '../../../errors/errorHelpers.mjs';\nimport { assert, AuthConfigurationErrorCode } from './errorHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction assertTokenProviderConfig(cognitoConfig) {\n let assertionValid = true; // assume valid until otherwise proveed\n if (!cognitoConfig) {\n assertionValid = false;\n }\n else {\n assertionValid =\n !!cognitoConfig.userPoolId && !!cognitoConfig.userPoolClientId;\n }\n assert(assertionValid, AuthConfigurationErrorCode.AuthUserPoolException);\n}\nfunction assertOAuthConfig(cognitoConfig) {\n const validOAuthConfig = !!cognitoConfig?.loginWith?.oauth?.domain &&\n !!cognitoConfig?.loginWith?.oauth?.redirectSignOut &&\n !!cognitoConfig?.loginWith?.oauth?.redirectSignIn &&\n !!cognitoConfig?.loginWith?.oauth?.responseType;\n assert(validOAuthConfig, AuthConfigurationErrorCode.OAuthNotConfigureException);\n}\nfunction assertIdentityPoolIdConfig(cognitoConfig) {\n const validConfig = !!cognitoConfig?.identityPoolId;\n assert(validConfig, AuthConfigurationErrorCode.InvalidIdentityPoolIdException);\n}\n/**\n * Decodes payload of JWT token\n *\n * @param {String} token A string representing a token to be decoded\n * @throws {@link Error} - Throws error when token is invalid or payload malformed.\n */\nfunction decodeJWT(token) {\n const tokenParts = token.split('.');\n if (tokenParts.length !== 3) {\n throw new Error('Invalid token');\n }\n try {\n const base64WithUrlSafe = tokenParts[1];\n const base64 = base64WithUrlSafe.replace(/-/g, '+').replace(/_/g, '/');\n const jsonStr = decodeURIComponent(base64Decoder\n .convert(base64)\n .split('')\n .map(char => `%${`00${char.charCodeAt(0).toString(16)}`.slice(-2)}`)\n .join(''));\n const payload = JSON.parse(jsonStr);\n return {\n toString: () => token,\n payload,\n };\n }\n catch (err) {\n throw new Error('Invalid token payload');\n }\n}\n\nexport { assertIdentityPoolIdConfig, assertOAuthConfig, assertTokenProviderConfig, decodeJWT };\n//# sourceMappingURL=index.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst deepFreeze = (object) => {\n const propNames = Reflect.ownKeys(object);\n for (const name of propNames) {\n const value = object[name];\n if ((value && typeof value === 'object') || typeof value === 'function') {\n deepFreeze(value);\n }\n }\n return Object.freeze(object);\n};\n\nexport { deepFreeze };\n//# sourceMappingURL=deepFreeze.mjs.map\n","import { ConsoleLogger } from './Logger/ConsoleLogger.mjs';\nimport { AmplifyError } from './errors/AmplifyError.mjs';\nimport './types/errors.mjs';\nimport './errors/errorHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst logger = new ConsoleLogger('parseAWSExports');\nconst authTypeMapping = {\n API_KEY: 'apiKey',\n AWS_IAM: 'iam',\n AMAZON_COGNITO_USER_POOLS: 'userPool',\n OPENID_CONNECT: 'oidc',\n NONE: 'none',\n AWS_LAMBDA: 'lambda',\n // `LAMBDA` is an incorrect value that was added during the v6 rewrite.\n // Keeping it as a valid value until v7 to prevent breaking customers who might\n // be relying on it as a workaround.\n // ref: https://github.com/aws-amplify/amplify-js/pull/12922\n // TODO: @v7 remove next line\n LAMBDA: 'lambda',\n};\n/**\n * Converts the object imported from `aws-exports.js` or `amplifyconfiguration.json` files generated by\n * the Amplify CLI into an object that conforms to the {@link ResourcesConfig}.\n *\n * @param config A configuration object imported from `aws-exports.js` or `amplifyconfiguration.json`.\n *\n * @returns An object that conforms to the {@link ResourcesConfig} .\n */\nconst parseAWSExports = (config = {}) => {\n if (!Object.prototype.hasOwnProperty.call(config, 'aws_project_region')) {\n throw new AmplifyError({\n name: 'InvalidParameterException',\n message: 'Invalid config parameter.',\n recoverySuggestion: 'Ensure passing the config object imported from `amplifyconfiguration.json`.',\n });\n }\n const { aws_appsync_apiKey, aws_appsync_authenticationType, aws_appsync_graphqlEndpoint, aws_appsync_region, aws_bots_config, aws_cognito_identity_pool_id, aws_cognito_sign_up_verification_method, aws_cognito_mfa_configuration, aws_cognito_mfa_types, aws_cognito_password_protection_settings, aws_cognito_verification_mechanisms, aws_cognito_signup_attributes, aws_cognito_social_providers, aws_cognito_username_attributes, aws_mandatory_sign_in, aws_mobile_analytics_app_id, aws_mobile_analytics_app_region, aws_user_files_s3_bucket, aws_user_files_s3_bucket_region, aws_user_files_s3_dangerously_connect_to_http_endpoint_for_testing, aws_user_pools_id, aws_user_pools_web_client_id, geo, oauth, predictions, aws_cloud_logic_custom, Notifications, modelIntrospection, } = config;\n const amplifyConfig = {};\n // Analytics\n if (aws_mobile_analytics_app_id) {\n amplifyConfig.Analytics = {\n Pinpoint: {\n appId: aws_mobile_analytics_app_id,\n region: aws_mobile_analytics_app_region,\n },\n };\n }\n // Notifications\n const { InAppMessaging, Push } = Notifications ?? {};\n if (InAppMessaging?.AWSPinpoint || Push?.AWSPinpoint) {\n if (InAppMessaging?.AWSPinpoint) {\n const { appId, region } = InAppMessaging.AWSPinpoint;\n amplifyConfig.Notifications = {\n InAppMessaging: {\n Pinpoint: {\n appId,\n region,\n },\n },\n };\n }\n if (Push?.AWSPinpoint) {\n const { appId, region } = Push.AWSPinpoint;\n amplifyConfig.Notifications = {\n ...amplifyConfig.Notifications,\n PushNotification: {\n Pinpoint: {\n appId,\n region,\n },\n },\n };\n }\n }\n // Interactions\n if (Array.isArray(aws_bots_config)) {\n amplifyConfig.Interactions = {\n LexV1: Object.fromEntries(aws_bots_config.map(bot => [bot.name, bot])),\n };\n }\n // API\n if (aws_appsync_graphqlEndpoint) {\n const defaultAuthMode = authTypeMapping[aws_appsync_authenticationType];\n if (!defaultAuthMode) {\n logger.debug(`Invalid authentication type ${aws_appsync_authenticationType}. Falling back to IAM.`);\n }\n amplifyConfig.API = {\n GraphQL: {\n endpoint: aws_appsync_graphqlEndpoint,\n apiKey: aws_appsync_apiKey,\n region: aws_appsync_region,\n defaultAuthMode: defaultAuthMode ?? 'iam',\n },\n };\n if (modelIntrospection) {\n amplifyConfig.API.GraphQL.modelIntrospection = modelIntrospection;\n }\n }\n // Auth\n const mfaConfig = aws_cognito_mfa_configuration\n ? {\n status: aws_cognito_mfa_configuration &&\n aws_cognito_mfa_configuration.toLowerCase(),\n totpEnabled: aws_cognito_mfa_types?.includes('TOTP') ?? false,\n smsEnabled: aws_cognito_mfa_types?.includes('SMS') ?? false,\n }\n : undefined;\n const passwordFormatConfig = aws_cognito_password_protection_settings\n ? {\n minLength: aws_cognito_password_protection_settings.passwordPolicyMinLength,\n requireLowercase: aws_cognito_password_protection_settings.passwordPolicyCharacters?.includes('REQUIRES_LOWERCASE') ?? false,\n requireUppercase: aws_cognito_password_protection_settings.passwordPolicyCharacters?.includes('REQUIRES_UPPERCASE') ?? false,\n requireNumbers: aws_cognito_password_protection_settings.passwordPolicyCharacters?.includes('REQUIRES_NUMBERS') ?? false,\n requireSpecialCharacters: aws_cognito_password_protection_settings.passwordPolicyCharacters?.includes('REQUIRES_SYMBOLS') ?? false,\n }\n : undefined;\n const mergedUserAttributes = Array.from(new Set([\n ...(aws_cognito_verification_mechanisms ?? []),\n ...(aws_cognito_signup_attributes ?? []),\n ]));\n const userAttributes = mergedUserAttributes.reduce((attributes, key) => ({\n ...attributes,\n // All user attributes generated by the CLI are required\n [key.toLowerCase()]: { required: true },\n }), {});\n const loginWithEmailEnabled = aws_cognito_username_attributes?.includes('EMAIL') ?? false;\n const loginWithPhoneEnabled = aws_cognito_username_attributes?.includes('PHONE_NUMBER') ?? false;\n if (aws_cognito_identity_pool_id || aws_user_pools_id) {\n amplifyConfig.Auth = {\n Cognito: {\n identityPoolId: aws_cognito_identity_pool_id,\n allowGuestAccess: aws_mandatory_sign_in !== 'enable',\n signUpVerificationMethod: aws_cognito_sign_up_verification_method,\n userAttributes,\n userPoolClientId: aws_user_pools_web_client_id,\n userPoolId: aws_user_pools_id,\n mfa: mfaConfig,\n passwordFormat: passwordFormatConfig,\n loginWith: {\n username: !(loginWithEmailEnabled || loginWithPhoneEnabled),\n email: loginWithEmailEnabled,\n phone: loginWithPhoneEnabled,\n },\n },\n };\n }\n const hasOAuthConfig = oauth ? Object.keys(oauth).length > 0 : false;\n const hasSocialProviderConfig = aws_cognito_social_providers\n ? aws_cognito_social_providers.length > 0\n : false;\n if (amplifyConfig.Auth && hasOAuthConfig) {\n amplifyConfig.Auth.Cognito.loginWith = {\n ...amplifyConfig.Auth.Cognito.loginWith,\n oauth: {\n ...getOAuthConfig(oauth),\n ...(hasSocialProviderConfig && {\n providers: parseSocialProviders(aws_cognito_social_providers),\n }),\n },\n };\n }\n // Storage\n if (aws_user_files_s3_bucket) {\n amplifyConfig.Storage = {\n S3: {\n bucket: aws_user_files_s3_bucket,\n region: aws_user_files_s3_bucket_region,\n dangerouslyConnectToHttpEndpointForTesting: aws_user_files_s3_dangerously_connect_to_http_endpoint_for_testing,\n },\n };\n }\n // Geo\n if (geo) {\n const { amazon_location_service } = geo;\n amplifyConfig.Geo = {\n LocationService: {\n maps: amazon_location_service.maps,\n geofenceCollections: amazon_location_service.geofenceCollections,\n searchIndices: amazon_location_service.search_indices,\n region: amazon_location_service.region,\n },\n };\n }\n // REST API\n if (aws_cloud_logic_custom) {\n amplifyConfig.API = {\n ...amplifyConfig.API,\n REST: aws_cloud_logic_custom.reduce((acc, api) => {\n const { name, endpoint, region, service } = api;\n return {\n ...acc,\n [name]: {\n endpoint,\n ...(service ? { service } : undefined),\n ...(region ? { region } : undefined),\n },\n };\n }, {}),\n };\n }\n // Predictions\n if (predictions) {\n // map VoiceId from speechGenerator defaults to voiceId\n const { VoiceId: voiceId } = predictions?.convert?.speechGenerator?.defaults ?? {};\n amplifyConfig.Predictions = voiceId\n ? {\n ...predictions,\n convert: {\n ...predictions.convert,\n speechGenerator: {\n ...predictions.convert.speechGenerator,\n defaults: { voiceId },\n },\n },\n }\n : predictions;\n }\n return amplifyConfig;\n};\nconst getRedirectUrl = (redirectStr) => redirectStr?.split(',') ?? [];\nconst getOAuthConfig = ({ domain, scope, redirectSignIn, redirectSignOut, responseType, }) => ({\n domain,\n scopes: scope,\n redirectSignIn: getRedirectUrl(redirectSignIn),\n redirectSignOut: getRedirectUrl(redirectSignOut),\n responseType,\n});\nconst parseSocialProviders = (aws_cognito_social_providers) => {\n return aws_cognito_social_providers.map((provider) => {\n const updatedProvider = provider.toLowerCase();\n return updatedProvider.charAt(0).toUpperCase() + updatedProvider.slice(1);\n });\n};\n\nexport { parseAWSExports };\n//# sourceMappingURL=parseAWSExports.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst ADD_OAUTH_LISTENER = Symbol('oauth-listener');\n\nexport { ADD_OAUTH_LISTENER };\n//# sourceMappingURL=constants.mjs.map\n","// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\nlet getRandomValues;\nconst rnds8 = new Uint8Array(16);\nexport default function rng() {\n // lazy load so that environments that need to polyfill have a chance to do so\n if (!getRandomValues) {\n // getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation.\n getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto);\n\n if (!getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n }\n\n return getRandomValues(rnds8);\n}","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);\nexport default {\n randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction isAmplifyOutputs(config) {\n // version format initially will be '1' but is expected to be something like x.y where x is major and y minor version\n const { version } = config;\n if (!version) {\n return false;\n }\n return version.startsWith('1');\n}\nfunction parseStorage(amplifyOutputsStorageProperties) {\n if (!amplifyOutputsStorageProperties) {\n return undefined;\n }\n const { bucket_name, aws_region, buckets } = amplifyOutputsStorageProperties;\n return {\n S3: {\n bucket: bucket_name,\n region: aws_region,\n buckets: buckets && createBucketInfoMap(buckets),\n },\n };\n}\nfunction parseAuth(amplifyOutputsAuthProperties) {\n if (!amplifyOutputsAuthProperties) {\n return undefined;\n }\n const { user_pool_id, user_pool_client_id, identity_pool_id, password_policy, mfa_configuration, mfa_methods, unauthenticated_identities_enabled, oauth, username_attributes, standard_required_attributes, groups, } = amplifyOutputsAuthProperties;\n const authConfig = {\n Cognito: {\n userPoolId: user_pool_id,\n userPoolClientId: user_pool_client_id,\n groups,\n },\n };\n if (identity_pool_id) {\n authConfig.Cognito = {\n ...authConfig.Cognito,\n identityPoolId: identity_pool_id,\n };\n }\n if (password_policy) {\n authConfig.Cognito.passwordFormat = {\n requireLowercase: password_policy.require_lowercase,\n requireNumbers: password_policy.require_numbers,\n requireUppercase: password_policy.require_uppercase,\n requireSpecialCharacters: password_policy.require_symbols,\n minLength: password_policy.min_length ?? 6,\n };\n }\n if (mfa_configuration) {\n authConfig.Cognito.mfa = {\n status: getMfaStatus(mfa_configuration),\n smsEnabled: mfa_methods?.includes('SMS'),\n totpEnabled: mfa_methods?.includes('TOTP'),\n };\n }\n if (unauthenticated_identities_enabled) {\n authConfig.Cognito.allowGuestAccess = unauthenticated_identities_enabled;\n }\n if (oauth) {\n authConfig.Cognito.loginWith = {\n oauth: {\n domain: oauth.domain,\n redirectSignIn: oauth.redirect_sign_in_uri,\n redirectSignOut: oauth.redirect_sign_out_uri,\n responseType: oauth.response_type === 'token' ? 'token' : 'code',\n scopes: oauth.scopes,\n providers: getOAuthProviders(oauth.identity_providers),\n },\n };\n }\n if (username_attributes) {\n authConfig.Cognito.loginWith = {\n ...authConfig.Cognito.loginWith,\n email: username_attributes.includes('email'),\n phone: username_attributes.includes('phone_number'),\n // Signing in with a username is not currently supported in Gen2, this should always evaluate to false\n username: username_attributes.includes('username'),\n };\n }\n if (standard_required_attributes) {\n authConfig.Cognito.userAttributes = standard_required_attributes.reduce((acc, curr) => ({ ...acc, [curr]: { required: true } }), {});\n }\n return authConfig;\n}\nfunction parseAnalytics(amplifyOutputsAnalyticsProperties) {\n if (!amplifyOutputsAnalyticsProperties?.amazon_pinpoint) {\n return undefined;\n }\n const { amazon_pinpoint } = amplifyOutputsAnalyticsProperties;\n return {\n Pinpoint: {\n appId: amazon_pinpoint.app_id,\n region: amazon_pinpoint.aws_region,\n },\n };\n}\nfunction parseGeo(amplifyOutputsAnalyticsProperties) {\n if (!amplifyOutputsAnalyticsProperties) {\n return undefined;\n }\n const { aws_region, geofence_collections, maps, search_indices } = amplifyOutputsAnalyticsProperties;\n return {\n LocationService: {\n region: aws_region,\n searchIndices: search_indices,\n geofenceCollections: geofence_collections,\n maps,\n },\n };\n}\nfunction parseData(amplifyOutputsDataProperties) {\n if (!amplifyOutputsDataProperties) {\n return undefined;\n }\n const { aws_region, default_authorization_type, url, api_key, model_introspection, } = amplifyOutputsDataProperties;\n const GraphQL = {\n endpoint: url,\n defaultAuthMode: getGraphQLAuthMode(default_authorization_type),\n region: aws_region,\n apiKey: api_key,\n modelIntrospection: model_introspection,\n };\n return {\n GraphQL,\n };\n}\nfunction parseCustom(amplifyOutputsCustomProperties) {\n if (!amplifyOutputsCustomProperties?.events) {\n return undefined;\n }\n const { url, aws_region, api_key, default_authorization_type } = amplifyOutputsCustomProperties.events;\n const Events = {\n endpoint: url,\n defaultAuthMode: getGraphQLAuthMode(default_authorization_type),\n region: aws_region,\n apiKey: api_key,\n };\n return {\n Events,\n };\n}\nfunction parseNotifications(amplifyOutputsNotificationsProperties) {\n if (!amplifyOutputsNotificationsProperties) {\n return undefined;\n }\n const { aws_region, channels, amazon_pinpoint_app_id } = amplifyOutputsNotificationsProperties;\n const hasInAppMessaging = channels.includes('IN_APP_MESSAGING');\n const hasPushNotification = channels.includes('APNS') || channels.includes('FCM');\n if (!(hasInAppMessaging || hasPushNotification)) {\n return undefined;\n }\n // At this point, we know the Amplify outputs contains at least one supported channel\n const notificationsConfig = {};\n if (hasInAppMessaging) {\n notificationsConfig.InAppMessaging = {\n Pinpoint: {\n appId: amazon_pinpoint_app_id,\n region: aws_region,\n },\n };\n }\n if (hasPushNotification) {\n notificationsConfig.PushNotification = {\n Pinpoint: {\n appId: amazon_pinpoint_app_id,\n region: aws_region,\n },\n };\n }\n return notificationsConfig;\n}\nfunction parseAmplifyOutputs(amplifyOutputs) {\n const resourcesConfig = {};\n if (amplifyOutputs.storage) {\n resourcesConfig.Storage = parseStorage(amplifyOutputs.storage);\n }\n if (amplifyOutputs.auth) {\n resourcesConfig.Auth = parseAuth(amplifyOutputs.auth);\n }\n if (amplifyOutputs.analytics) {\n resourcesConfig.Analytics = parseAnalytics(amplifyOutputs.analytics);\n }\n if (amplifyOutputs.geo) {\n resourcesConfig.Geo = parseGeo(amplifyOutputs.geo);\n }\n if (amplifyOutputs.data) {\n resourcesConfig.API = parseData(amplifyOutputs.data);\n }\n if (amplifyOutputs.custom) {\n const customConfig = parseCustom(amplifyOutputs.custom);\n if (customConfig && 'Events' in customConfig) {\n resourcesConfig.API = { ...resourcesConfig.API, ...customConfig };\n }\n }\n if (amplifyOutputs.notifications) {\n resourcesConfig.Notifications = parseNotifications(amplifyOutputs.notifications);\n }\n return resourcesConfig;\n}\nconst authModeNames = {\n AMAZON_COGNITO_USER_POOLS: 'userPool',\n API_KEY: 'apiKey',\n AWS_IAM: 'iam',\n AWS_LAMBDA: 'lambda',\n OPENID_CONNECT: 'oidc',\n};\nfunction getGraphQLAuthMode(authType) {\n return authModeNames[authType];\n}\nconst providerNames = {\n GOOGLE: 'Google',\n LOGIN_WITH_AMAZON: 'Amazon',\n FACEBOOK: 'Facebook',\n SIGN_IN_WITH_APPLE: 'Apple',\n};\nfunction getOAuthProviders(providers = []) {\n return providers.reduce((oAuthProviders, provider) => {\n if (providerNames[provider] !== undefined) {\n oAuthProviders.push(providerNames[provider]);\n }\n return oAuthProviders;\n }, []);\n}\nfunction getMfaStatus(mfaConfiguration) {\n if (mfaConfiguration === 'OPTIONAL')\n return 'optional';\n if (mfaConfiguration === 'REQUIRED')\n return 'on';\n return 'off';\n}\nfunction createBucketInfoMap(buckets) {\n const mappedBuckets = {};\n buckets.forEach(({ name, bucket_name: bucketName, aws_region: region, paths }) => {\n if (name in mappedBuckets) {\n throw new Error(`Duplicate friendly name found: ${name}. Name must be unique.`);\n }\n const sanitizedPaths = paths\n ? Object.entries(paths).reduce((acc, [key, value]) => {\n if (value !== undefined) {\n acc[key] = value;\n }\n return acc;\n }, {})\n : undefined;\n mappedBuckets[name] = {\n bucketName,\n region,\n paths: sanitizedPaths,\n };\n });\n return mappedBuckets;\n}\n\nexport { isAmplifyOutputs, parseAmplifyOutputs, parseAnalytics };\n//# sourceMappingURL=parseAmplifyOutputs.mjs.map\n","import { parseAWSExports } from '../parseAWSExports.mjs';\nimport { isAmplifyOutputs, parseAmplifyOutputs } from '../parseAmplifyOutputs.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Parses the variety of configuration shapes that Amplify can accept into a ResourcesConfig.\n *\n * @param amplifyConfig An Amplify configuration object conforming to one of the supported schemas.\n * @return A ResourcesConfig for the provided configuration object.\n */\nconst parseAmplifyConfig = (amplifyConfig) => {\n if (Object.keys(amplifyConfig).some(key => key.startsWith('aws_'))) {\n return parseAWSExports(amplifyConfig);\n }\n else if (isAmplifyOutputs(amplifyConfig)) {\n return parseAmplifyOutputs(amplifyConfig);\n }\n else {\n return amplifyConfig;\n }\n};\n\nexport { parseAmplifyConfig };\n//# sourceMappingURL=parseAmplifyConfig.mjs.map\n","/**\n * @internal\n */\nexport var BLOCK_SIZE = 64;\n/**\n * @internal\n */\nexport var DIGEST_LENGTH = 32;\n/**\n * @internal\n */\nexport var KEY = new Uint32Array([\n 0x428a2f98,\n 0x71374491,\n 0xb5c0fbcf,\n 0xe9b5dba5,\n 0x3956c25b,\n 0x59f111f1,\n 0x923f82a4,\n 0xab1c5ed5,\n 0xd807aa98,\n 0x12835b01,\n 0x243185be,\n 0x550c7dc3,\n 0x72be5d74,\n 0x80deb1fe,\n 0x9bdc06a7,\n 0xc19bf174,\n 0xe49b69c1,\n 0xefbe4786,\n 0x0fc19dc6,\n 0x240ca1cc,\n 0x2de92c6f,\n 0x4a7484aa,\n 0x5cb0a9dc,\n 0x76f988da,\n 0x983e5152,\n 0xa831c66d,\n 0xb00327c8,\n 0xbf597fc7,\n 0xc6e00bf3,\n 0xd5a79147,\n 0x06ca6351,\n 0x14292967,\n 0x27b70a85,\n 0x2e1b2138,\n 0x4d2c6dfc,\n 0x53380d13,\n 0x650a7354,\n 0x766a0abb,\n 0x81c2c92e,\n 0x92722c85,\n 0xa2bfe8a1,\n 0xa81a664b,\n 0xc24b8b70,\n 0xc76c51a3,\n 0xd192e819,\n 0xd6990624,\n 0xf40e3585,\n 0x106aa070,\n 0x19a4c116,\n 0x1e376c08,\n 0x2748774c,\n 0x34b0bcb5,\n 0x391c0cb3,\n 0x4ed8aa4a,\n 0x5b9cca4f,\n 0x682e6ff3,\n 0x748f82ee,\n 0x78a5636f,\n 0x84c87814,\n 0x8cc70208,\n 0x90befffa,\n 0xa4506ceb,\n 0xbef9a3f7,\n 0xc67178f2\n]);\n/**\n * @internal\n */\nexport var INIT = [\n 0x6a09e667,\n 0xbb67ae85,\n 0x3c6ef372,\n 0xa54ff53a,\n 0x510e527f,\n 0x9b05688c,\n 0x1f83d9ab,\n 0x5be0cd19\n];\n/**\n * @internal\n */\nexport var MAX_HASHABLE_LENGTH = Math.pow(2, 53) - 1;\n//# sourceMappingURL=constants.js.map","import { BLOCK_SIZE, DIGEST_LENGTH, INIT, KEY, MAX_HASHABLE_LENGTH } from \"./constants\";\n/**\n * @internal\n */\nvar RawSha256 = /** @class */ (function () {\n function RawSha256() {\n this.state = Int32Array.from(INIT);\n this.temp = new Int32Array(64);\n this.buffer = new Uint8Array(64);\n this.bufferLength = 0;\n this.bytesHashed = 0;\n /**\n * @internal\n */\n this.finished = false;\n }\n RawSha256.prototype.update = function (data) {\n if (this.finished) {\n throw new Error(\"Attempted to update an already finished hash.\");\n }\n var position = 0;\n var byteLength = data.byteLength;\n this.bytesHashed += byteLength;\n if (this.bytesHashed * 8 > MAX_HASHABLE_LENGTH) {\n throw new Error(\"Cannot hash more than 2^53 - 1 bits\");\n }\n while (byteLength > 0) {\n this.buffer[this.bufferLength++] = data[position++];\n byteLength--;\n if (this.bufferLength === BLOCK_SIZE) {\n this.hashBuffer();\n this.bufferLength = 0;\n }\n }\n };\n RawSha256.prototype.digest = function () {\n if (!this.finished) {\n var bitsHashed = this.bytesHashed * 8;\n var bufferView = new DataView(this.buffer.buffer, this.buffer.byteOffset, this.buffer.byteLength);\n var undecoratedLength = this.bufferLength;\n bufferView.setUint8(this.bufferLength++, 0x80);\n // Ensure the final block has enough room for the hashed length\n if (undecoratedLength % BLOCK_SIZE >= BLOCK_SIZE - 8) {\n for (var i = this.bufferLength; i < BLOCK_SIZE; i++) {\n bufferView.setUint8(i, 0);\n }\n this.hashBuffer();\n this.bufferLength = 0;\n }\n for (var i = this.bufferLength; i < BLOCK_SIZE - 8; i++) {\n bufferView.setUint8(i, 0);\n }\n bufferView.setUint32(BLOCK_SIZE - 8, Math.floor(bitsHashed / 0x100000000), true);\n bufferView.setUint32(BLOCK_SIZE - 4, bitsHashed);\n this.hashBuffer();\n this.finished = true;\n }\n // The value in state is little-endian rather than big-endian, so flip\n // each word into a new Uint8Array\n var out = new Uint8Array(DIGEST_LENGTH);\n for (var i = 0; i < 8; i++) {\n out[i * 4] = (this.state[i] >>> 24) & 0xff;\n out[i * 4 + 1] = (this.state[i] >>> 16) & 0xff;\n out[i * 4 + 2] = (this.state[i] >>> 8) & 0xff;\n out[i * 4 + 3] = (this.state[i] >>> 0) & 0xff;\n }\n return out;\n };\n RawSha256.prototype.hashBuffer = function () {\n var _a = this, buffer = _a.buffer, state = _a.state;\n var state0 = state[0], state1 = state[1], state2 = state[2], state3 = state[3], state4 = state[4], state5 = state[5], state6 = state[6], state7 = state[7];\n for (var i = 0; i < BLOCK_SIZE; i++) {\n if (i < 16) {\n this.temp[i] =\n ((buffer[i * 4] & 0xff) << 24) |\n ((buffer[i * 4 + 1] & 0xff) << 16) |\n ((buffer[i * 4 + 2] & 0xff) << 8) |\n (buffer[i * 4 + 3] & 0xff);\n }\n else {\n var u = this.temp[i - 2];\n var t1_1 = ((u >>> 17) | (u << 15)) ^ ((u >>> 19) | (u << 13)) ^ (u >>> 10);\n u = this.temp[i - 15];\n var t2_1 = ((u >>> 7) | (u << 25)) ^ ((u >>> 18) | (u << 14)) ^ (u >>> 3);\n this.temp[i] =\n ((t1_1 + this.temp[i - 7]) | 0) + ((t2_1 + this.temp[i - 16]) | 0);\n }\n var t1 = ((((((state4 >>> 6) | (state4 << 26)) ^\n ((state4 >>> 11) | (state4 << 21)) ^\n ((state4 >>> 25) | (state4 << 7))) +\n ((state4 & state5) ^ (~state4 & state6))) |\n 0) +\n ((state7 + ((KEY[i] + this.temp[i]) | 0)) | 0)) |\n 0;\n var t2 = ((((state0 >>> 2) | (state0 << 30)) ^\n ((state0 >>> 13) | (state0 << 19)) ^\n ((state0 >>> 22) | (state0 << 10))) +\n ((state0 & state1) ^ (state0 & state2) ^ (state1 & state2))) |\n 0;\n state7 = state6;\n state6 = state5;\n state5 = state4;\n state4 = (state3 + t1) | 0;\n state3 = state2;\n state2 = state1;\n state1 = state0;\n state0 = (t1 + t2) | 0;\n }\n state[0] += state0;\n state[1] += state1;\n state[2] += state2;\n state[3] += state3;\n state[4] += state4;\n state[5] += state5;\n state[6] += state6;\n state[7] += state7;\n };\n return RawSha256;\n}());\nexport { RawSha256 };\n//# sourceMappingURL=RawSha256.js.map","export const fromUtf8 = (input) => new TextEncoder().encode(input);\n","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { fromUtf8 as fromUtf8Browser } from \"@smithy/util-utf8\";\n// Quick polyfill\nvar fromUtf8 = typeof Buffer !== \"undefined\" && Buffer.from\n ? function (input) { return Buffer.from(input, \"utf8\"); }\n : fromUtf8Browser;\nexport function convertToBuffer(data) {\n // Already a Uint8, do nothing\n if (data instanceof Uint8Array)\n return data;\n if (typeof data === \"string\") {\n return fromUtf8(data);\n }\n if (ArrayBuffer.isView(data)) {\n return new Uint8Array(data.buffer, data.byteOffset, data.byteLength / Uint8Array.BYTES_PER_ELEMENT);\n }\n return new Uint8Array(data);\n}\n//# sourceMappingURL=convertToBuffer.js.map","// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nexport function isEmptyData(data) {\n if (typeof data === \"string\") {\n return data.length === 0;\n }\n return data.byteLength === 0;\n}\n//# sourceMappingURL=isEmptyData.js.map","import { __awaiter, __generator } from \"tslib\";\nimport { BLOCK_SIZE } from \"./constants\";\nimport { RawSha256 } from \"./RawSha256\";\nimport { isEmptyData, convertToBuffer } from \"@aws-crypto/util\";\nvar Sha256 = /** @class */ (function () {\n function Sha256(secret) {\n this.secret = secret;\n this.hash = new RawSha256();\n this.reset();\n }\n Sha256.prototype.update = function (toHash) {\n if (isEmptyData(toHash) || this.error) {\n return;\n }\n try {\n this.hash.update(convertToBuffer(toHash));\n }\n catch (e) {\n this.error = e;\n }\n };\n /* This synchronous method keeps compatibility\n * with the v2 aws-sdk.\n */\n Sha256.prototype.digestSync = function () {\n if (this.error) {\n throw this.error;\n }\n if (this.outer) {\n if (!this.outer.finished) {\n this.outer.update(this.hash.digest());\n }\n return this.outer.digest();\n }\n return this.hash.digest();\n };\n /* The underlying digest method here is synchronous.\n * To keep the same interface with the other hash functions\n * the default is to expose this as an async method.\n * However, it can sometimes be useful to have a sync method.\n */\n Sha256.prototype.digest = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n return [2 /*return*/, this.digestSync()];\n });\n });\n };\n Sha256.prototype.reset = function () {\n this.hash = new RawSha256();\n if (this.secret) {\n this.outer = new RawSha256();\n var inner = bufferFromSecret(this.secret);\n var outer = new Uint8Array(BLOCK_SIZE);\n outer.set(inner);\n for (var i = 0; i < BLOCK_SIZE; i++) {\n inner[i] ^= 0x36;\n outer[i] ^= 0x5c;\n }\n this.hash.update(inner);\n this.outer.update(outer);\n // overwrite the copied key in memory\n for (var i = 0; i < inner.byteLength; i++) {\n inner[i] = 0;\n }\n }\n };\n return Sha256;\n}());\nexport { Sha256 };\nfunction bufferFromSecret(secret) {\n var input = convertToBuffer(secret);\n if (input.byteLength > BLOCK_SIZE) {\n var bufferHash = new RawSha256();\n bufferHash.update(input);\n input = bufferHash.digest();\n }\n var buffer = new Uint8Array(BLOCK_SIZE);\n buffer.set(input);\n return buffer;\n}\n//# sourceMappingURL=jsSha256.js.map","const SHORT_TO_HEX = {};\nconst HEX_TO_SHORT = {};\nfor (let i = 0; i < 256; i++) {\n let encodedByte = i.toString(16).toLowerCase();\n if (encodedByte.length === 1) {\n encodedByte = `0${encodedByte}`;\n }\n SHORT_TO_HEX[i] = encodedByte;\n HEX_TO_SHORT[encodedByte] = i;\n}\nexport function fromHex(encoded) {\n if (encoded.length % 2 !== 0) {\n throw new Error(\"Hex encoded strings must have an even number length\");\n }\n const out = new Uint8Array(encoded.length / 2);\n for (let i = 0; i < encoded.length; i += 2) {\n const encodedByte = encoded.slice(i, i + 2).toLowerCase();\n if (encodedByte in HEX_TO_SHORT) {\n out[i / 2] = HEX_TO_SHORT[encodedByte];\n }\n else {\n throw new Error(`Cannot decode unrecognized sequence ${encodedByte} as hexadecimal`);\n }\n }\n return out;\n}\nexport function toHex(bytes) {\n let out = \"\";\n for (let i = 0; i < bytes.byteLength; i++) {\n out += SHORT_TO_HEX[bytes[i]];\n }\n return out;\n}\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nvar Framework;\n(function (Framework) {\n // < 100 - Web frameworks\n Framework[\"WebUnknown\"] = \"0\";\n Framework[\"React\"] = \"1\";\n Framework[\"NextJs\"] = \"2\";\n Framework[\"Angular\"] = \"3\";\n Framework[\"VueJs\"] = \"4\";\n Framework[\"Nuxt\"] = \"5\";\n Framework[\"Svelte\"] = \"6\";\n // 100s - Server side frameworks\n Framework[\"ServerSideUnknown\"] = \"100\";\n Framework[\"ReactSSR\"] = \"101\";\n Framework[\"NextJsSSR\"] = \"102\";\n Framework[\"AngularSSR\"] = \"103\";\n Framework[\"VueJsSSR\"] = \"104\";\n Framework[\"NuxtSSR\"] = \"105\";\n Framework[\"SvelteSSR\"] = \"106\";\n // 200s - Mobile framework\n Framework[\"ReactNative\"] = \"201\";\n Framework[\"Expo\"] = \"202\";\n})(Framework || (Framework = {}));\nvar Category;\n(function (Category) {\n Category[\"AI\"] = \"ai\";\n Category[\"API\"] = \"api\";\n Category[\"Auth\"] = \"auth\";\n Category[\"Analytics\"] = \"analytics\";\n Category[\"DataStore\"] = \"datastore\";\n Category[\"Geo\"] = \"geo\";\n Category[\"InAppMessaging\"] = \"inappmessaging\";\n Category[\"Interactions\"] = \"interactions\";\n Category[\"Predictions\"] = \"predictions\";\n Category[\"PubSub\"] = \"pubsub\";\n Category[\"PushNotification\"] = \"pushnotification\";\n Category[\"Storage\"] = \"storage\";\n})(Category || (Category = {}));\nvar AiAction;\n(function (AiAction) {\n AiAction[\"CreateConversation\"] = \"1\";\n AiAction[\"GetConversation\"] = \"2\";\n AiAction[\"ListConversations\"] = \"3\";\n AiAction[\"DeleteConversation\"] = \"4\";\n AiAction[\"SendMessage\"] = \"5\";\n AiAction[\"ListMessages\"] = \"6\";\n AiAction[\"OnMessage\"] = \"7\";\n AiAction[\"Generation\"] = \"8\";\n AiAction[\"UpdateConversation\"] = \"9\";\n})(AiAction || (AiAction = {}));\nvar AnalyticsAction;\n(function (AnalyticsAction) {\n AnalyticsAction[\"Record\"] = \"1\";\n AnalyticsAction[\"IdentifyUser\"] = \"2\";\n})(AnalyticsAction || (AnalyticsAction = {}));\nvar ApiAction;\n(function (ApiAction) {\n ApiAction[\"GraphQl\"] = \"1\";\n ApiAction[\"Get\"] = \"2\";\n ApiAction[\"Post\"] = \"3\";\n ApiAction[\"Put\"] = \"4\";\n ApiAction[\"Patch\"] = \"5\";\n ApiAction[\"Del\"] = \"6\";\n ApiAction[\"Head\"] = \"7\";\n})(ApiAction || (ApiAction = {}));\nvar AuthAction;\n(function (AuthAction) {\n AuthAction[\"SignUp\"] = \"1\";\n AuthAction[\"ConfirmSignUp\"] = \"2\";\n AuthAction[\"ResendSignUpCode\"] = \"3\";\n AuthAction[\"SignIn\"] = \"4\";\n AuthAction[\"FetchMFAPreference\"] = \"6\";\n AuthAction[\"UpdateMFAPreference\"] = \"7\";\n AuthAction[\"SetUpTOTP\"] = \"10\";\n AuthAction[\"VerifyTOTPSetup\"] = \"11\";\n AuthAction[\"ConfirmSignIn\"] = \"12\";\n AuthAction[\"DeleteUserAttributes\"] = \"15\";\n AuthAction[\"DeleteUser\"] = \"16\";\n AuthAction[\"UpdateUserAttributes\"] = \"17\";\n AuthAction[\"FetchUserAttributes\"] = \"18\";\n AuthAction[\"ConfirmUserAttribute\"] = \"22\";\n AuthAction[\"SignOut\"] = \"26\";\n AuthAction[\"UpdatePassword\"] = \"27\";\n AuthAction[\"ResetPassword\"] = \"28\";\n AuthAction[\"ConfirmResetPassword\"] = \"29\";\n AuthAction[\"FederatedSignIn\"] = \"30\";\n AuthAction[\"RememberDevice\"] = \"32\";\n AuthAction[\"ForgetDevice\"] = \"33\";\n AuthAction[\"FetchDevices\"] = \"34\";\n AuthAction[\"SendUserAttributeVerificationCode\"] = \"35\";\n AuthAction[\"SignInWithRedirect\"] = \"36\";\n AuthAction[\"StartWebAuthnRegistration\"] = \"37\";\n AuthAction[\"CompleteWebAuthnRegistration\"] = \"38\";\n AuthAction[\"ListWebAuthnCredentials\"] = \"39\";\n AuthAction[\"DeleteWebAuthnCredential\"] = \"40\";\n})(AuthAction || (AuthAction = {}));\nvar DataStoreAction;\n(function (DataStoreAction) {\n DataStoreAction[\"Subscribe\"] = \"1\";\n DataStoreAction[\"GraphQl\"] = \"2\";\n})(DataStoreAction || (DataStoreAction = {}));\nvar GeoAction;\n(function (GeoAction) {\n GeoAction[\"SearchByText\"] = \"0\";\n GeoAction[\"SearchByCoordinates\"] = \"1\";\n GeoAction[\"SearchForSuggestions\"] = \"2\";\n GeoAction[\"SearchByPlaceId\"] = \"3\";\n GeoAction[\"SaveGeofences\"] = \"4\";\n GeoAction[\"GetGeofence\"] = \"5\";\n GeoAction[\"ListGeofences\"] = \"6\";\n GeoAction[\"DeleteGeofences\"] = \"7\";\n})(GeoAction || (GeoAction = {}));\nvar InAppMessagingAction;\n(function (InAppMessagingAction) {\n InAppMessagingAction[\"SyncMessages\"] = \"1\";\n InAppMessagingAction[\"IdentifyUser\"] = \"2\";\n InAppMessagingAction[\"NotifyMessageInteraction\"] = \"3\";\n})(InAppMessagingAction || (InAppMessagingAction = {}));\nvar InteractionsAction;\n(function (InteractionsAction) {\n InteractionsAction[\"None\"] = \"0\";\n})(InteractionsAction || (InteractionsAction = {}));\nvar PredictionsAction;\n(function (PredictionsAction) {\n PredictionsAction[\"Convert\"] = \"1\";\n PredictionsAction[\"Identify\"] = \"2\";\n PredictionsAction[\"Interpret\"] = \"3\";\n})(PredictionsAction || (PredictionsAction = {}));\nvar PubSubAction;\n(function (PubSubAction) {\n PubSubAction[\"Subscribe\"] = \"1\";\n})(PubSubAction || (PubSubAction = {}));\nvar PushNotificationAction;\n(function (PushNotificationAction) {\n PushNotificationAction[\"InitializePushNotifications\"] = \"1\";\n PushNotificationAction[\"IdentifyUser\"] = \"2\";\n})(PushNotificationAction || (PushNotificationAction = {}));\nvar StorageAction;\n(function (StorageAction) {\n StorageAction[\"UploadData\"] = \"1\";\n StorageAction[\"DownloadData\"] = \"2\";\n StorageAction[\"List\"] = \"3\";\n StorageAction[\"Copy\"] = \"4\";\n StorageAction[\"Remove\"] = \"5\";\n StorageAction[\"GetProperties\"] = \"6\";\n StorageAction[\"GetUrl\"] = \"7\";\n StorageAction[\"GetDataAccess\"] = \"8\";\n StorageAction[\"ListCallerAccessGrants\"] = \"9\";\n})(StorageAction || (StorageAction = {}));\n\nexport { AiAction, AnalyticsAction, ApiAction, AuthAction, Category, DataStoreAction, Framework, GeoAction, InAppMessagingAction, InteractionsAction, PredictionsAction, PubSubAction, PushNotificationAction, StorageAction };\n//# sourceMappingURL=types.mjs.map\n","// generated by genversion\nconst version = '6.14.0';\n\nexport { version };\n//# sourceMappingURL=version.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst globalExists = () => {\n return typeof global !== 'undefined';\n};\nconst globalThisExists = () => {\n return typeof globalThis !== 'undefined';\n};\nconst windowExists = () => {\n return typeof window !== 'undefined';\n};\nconst documentExists = () => {\n return typeof document !== 'undefined';\n};\nconst processExists = () => {\n return typeof process !== 'undefined';\n};\nconst keyPrefixMatch = (object, prefix) => {\n return !!Object.keys(object).find(key => key.startsWith(prefix));\n};\n\nexport { documentExists, globalExists, globalThisExists, keyPrefixMatch, processExists, windowExists };\n//# sourceMappingURL=helpers.mjs.map\n","import { documentExists, processExists } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with react 18.2 - built using Vite\nfunction reactWebDetect() {\n const elementKeyPrefixedWithReact = (key) => {\n return key.startsWith('_react') || key.startsWith('__react');\n };\n const elementIsReactEnabled = (element) => {\n return Object.keys(element).find(elementKeyPrefixedWithReact);\n };\n const allElementsWithId = () => Array.from(document.querySelectorAll('[id]'));\n return documentExists() && allElementsWithId().some(elementIsReactEnabled);\n}\nfunction reactSSRDetect() {\n return (processExists() &&\n typeof process.env !== 'undefined' &&\n !!Object.keys(process.env).find(key => key.includes('react')));\n}\n// use the some\n\nexport { reactSSRDetect, reactWebDetect };\n//# sourceMappingURL=React.mjs.map\n","import { windowExists, keyPrefixMatch, globalExists } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with vue 3.3.2\nfunction vueWebDetect() {\n return windowExists() && keyPrefixMatch(window, '__VUE');\n}\nfunction vueSSRDetect() {\n return globalExists() && keyPrefixMatch(global, '__VUE');\n}\n\nexport { vueSSRDetect, vueWebDetect };\n//# sourceMappingURL=Vue.mjs.map\n","import { windowExists, keyPrefixMatch, processExists } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with svelte 3.59\nfunction svelteWebDetect() {\n return windowExists() && keyPrefixMatch(window, '__SVELTE');\n}\nfunction svelteSSRDetect() {\n return (processExists() &&\n typeof process.env !== 'undefined' &&\n !!Object.keys(process.env).find(key => key.includes('svelte')));\n}\n\nexport { svelteSSRDetect, svelteWebDetect };\n//# sourceMappingURL=Svelte.mjs.map\n","import { windowExists, globalExists, keyPrefixMatch } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with next 13.4 / react 18.2\nfunction nextWebDetect() {\n return (windowExists() &&\n window.next &&\n typeof window.next === 'object');\n}\nfunction nextSSRDetect() {\n return (globalExists() &&\n (keyPrefixMatch(global, '__next') || keyPrefixMatch(global, '__NEXT')));\n}\n\nexport { nextSSRDetect, nextWebDetect };\n//# sourceMappingURL=Next.mjs.map\n","import { windowExists, globalExists } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with nuxt 2.15 / vue 2.7\nfunction nuxtWebDetect() {\n return (windowExists() &&\n (window.__NUXT__ !== undefined ||\n window.$nuxt !== undefined));\n}\nfunction nuxtSSRDetect() {\n return (globalExists() && typeof global.__NUXT_PATHS__ !== 'undefined');\n}\n\nexport { nuxtSSRDetect, nuxtWebDetect };\n//# sourceMappingURL=Nuxt.mjs.map\n","import { documentExists, processExists, windowExists } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with @angular/core 16.0.0\nfunction angularWebDetect() {\n const angularVersionSetInDocument = Boolean(documentExists() && document.querySelector('[ng-version]'));\n const angularContentSetInWindow = Boolean(windowExists() && typeof window.ng !== 'undefined');\n return angularVersionSetInDocument || angularContentSetInWindow;\n}\nfunction angularSSRDetect() {\n return ((processExists() &&\n typeof process.env === 'object' &&\n process.env.npm_lifecycle_script?.startsWith('ng ')) ||\n false);\n}\n\nexport { angularSSRDetect, angularWebDetect };\n//# sourceMappingURL=Angular.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with react-native 0.17.7\nfunction reactNativeDetect() {\n return (typeof navigator !== 'undefined' &&\n typeof navigator.product !== 'undefined' &&\n navigator.product === 'ReactNative');\n}\n\nexport { reactNativeDetect };\n//# sourceMappingURL=ReactNative.mjs.map\n","import { globalExists } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Tested with expo 48 / react-native 0.71.3\nfunction expoDetect() {\n return globalExists() && typeof global.expo !== 'undefined';\n}\n\nexport { expoDetect };\n//# sourceMappingURL=Expo.mjs.map\n","import { windowExists } from './helpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction webDetect() {\n return windowExists();\n}\n\nexport { webDetect };\n//# sourceMappingURL=Web.mjs.map\n","import { Framework } from '../types.mjs';\nimport { reactWebDetect, reactSSRDetect } from './React.mjs';\nimport { vueWebDetect, vueSSRDetect } from './Vue.mjs';\nimport { svelteWebDetect, svelteSSRDetect } from './Svelte.mjs';\nimport { nextWebDetect, nextSSRDetect } from './Next.mjs';\nimport { nuxtWebDetect, nuxtSSRDetect } from './Nuxt.mjs';\nimport { angularWebDetect, angularSSRDetect } from './Angular.mjs';\nimport { reactNativeDetect } from './ReactNative.mjs';\nimport { expoDetect } from './Expo.mjs';\nimport { webDetect } from './Web.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// These are in the order of detection where when both are detectable, the early Framework will be reported\nconst detectionMap = [\n // First, detect mobile\n { platform: Framework.Expo, detectionMethod: expoDetect },\n { platform: Framework.ReactNative, detectionMethod: reactNativeDetect },\n // Next, detect web frameworks\n { platform: Framework.NextJs, detectionMethod: nextWebDetect },\n { platform: Framework.Nuxt, detectionMethod: nuxtWebDetect },\n { platform: Framework.Angular, detectionMethod: angularWebDetect },\n { platform: Framework.React, detectionMethod: reactWebDetect },\n { platform: Framework.VueJs, detectionMethod: vueWebDetect },\n { platform: Framework.Svelte, detectionMethod: svelteWebDetect },\n { platform: Framework.WebUnknown, detectionMethod: webDetect },\n // Last, detect ssr frameworks\n { platform: Framework.NextJsSSR, detectionMethod: nextSSRDetect },\n { platform: Framework.NuxtSSR, detectionMethod: nuxtSSRDetect },\n { platform: Framework.ReactSSR, detectionMethod: reactSSRDetect },\n { platform: Framework.VueJsSSR, detectionMethod: vueSSRDetect },\n { platform: Framework.AngularSSR, detectionMethod: angularSSRDetect },\n { platform: Framework.SvelteSSR, detectionMethod: svelteSSRDetect },\n];\nfunction detect() {\n return (detectionMap.find(detectionEntry => detectionEntry.detectionMethod())\n ?.platform || Framework.ServerSideUnknown);\n}\n\nexport { detect };\n//# sourceMappingURL=index.mjs.map\n","import { Framework } from './types.mjs';\nimport { detect } from './detection/index.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// We want to cache detection since the framework won't change\nlet frameworkCache;\nconst frameworkChangeObservers = [];\n// Setup the detection reset tracking / timeout delays\nlet resetTriggered = false;\nconst SSR_RESET_TIMEOUT = 10; // ms\nconst WEB_RESET_TIMEOUT = 10; // ms\nconst PRIME_FRAMEWORK_DELAY = 1000; // ms\nconst detectFramework = () => {\n if (!frameworkCache) {\n frameworkCache = detect();\n if (resetTriggered) {\n // The final run of detectFramework:\n // Starting from this point, the `frameworkCache` becomes \"final\".\n // So we don't need to notify the observers again so the observer\n // can be removed after the final notice.\n while (frameworkChangeObservers.length) {\n frameworkChangeObservers.pop()?.();\n }\n }\n else {\n // The first run of detectFramework:\n // Every time we update the cache, call each observer function\n frameworkChangeObservers.forEach(fcn => {\n fcn();\n });\n }\n // Retry once for either Unknown type after a delay (explained below)\n resetTimeout(Framework.ServerSideUnknown, SSR_RESET_TIMEOUT);\n resetTimeout(Framework.WebUnknown, WEB_RESET_TIMEOUT);\n }\n return frameworkCache;\n};\n/**\n * @internal Setup observer callback that will be called everytime the framework changes\n */\nconst observeFrameworkChanges = (fcn) => {\n // When the `frameworkCache` won't be updated again, we ignore all incoming\n // observers.\n if (resetTriggered) {\n return;\n }\n frameworkChangeObservers.push(fcn);\n};\nfunction clearCache() {\n frameworkCache = undefined;\n}\n// For a framework type and a delay amount, setup the event to re-detect\n// During the runtime boot, it is possible that framework detection will\n// be triggered before the framework has made modifications to the\n// global/window/etc needed for detection. When no framework is detected\n// we will reset and try again to ensure we don't use a cached\n// non-framework detection result for all requests.\nfunction resetTimeout(framework, delay) {\n if (frameworkCache === framework && !resetTriggered) {\n setTimeout(() => {\n clearCache();\n resetTriggered = true;\n setTimeout(detectFramework, PRIME_FRAMEWORK_DELAY);\n }, delay);\n }\n}\n\nexport { clearCache, detectFramework, frameworkChangeObservers, observeFrameworkChanges };\n//# sourceMappingURL=detectFramework.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Maintains custom user-agent state set by external consumers.\nconst customUserAgentState = {};\n/**\n * Sets custom user agent state which will be appended to applicable requests. Returns a function that can be used to\n * clean up any custom state set with this API.\n *\n * @note\n * This API operates globally. Calling this API multiple times will result in the most recently set values for a\n * particular API being used.\n *\n * @note\n * This utility IS NOT compatible with SSR.\n *\n * @param input - SetCustomUserAgentInput that defines custom state to apply to the specified APIs.\n */\nconst setCustomUserAgent = (input) => {\n // Save custom user-agent state & increment reference counter\n // TODO Remove `any` when we upgrade to TypeScript 5.2, see: https://github.com/microsoft/TypeScript/issues/44373\n customUserAgentState[input.category] = input.apis.reduce((acc, api) => ({\n ...acc,\n [api]: {\n refCount: acc[api]?.refCount ? acc[api].refCount + 1 : 1,\n additionalDetails: input.additionalDetails,\n },\n }), customUserAgentState[input.category] ?? {});\n // Callback that cleans up state for APIs recorded by this call\n let cleanUpCallbackCalled = false;\n const cleanUpCallback = () => {\n // Only allow the cleanup callback to be called once\n if (cleanUpCallbackCalled) {\n return;\n }\n cleanUpCallbackCalled = true;\n input.apis.forEach(api => {\n const apiRefCount = customUserAgentState[input.category][api].refCount;\n if (apiRefCount > 1) {\n customUserAgentState[input.category][api].refCount = apiRefCount - 1;\n }\n else {\n delete customUserAgentState[input.category][api];\n // Clean up category if no more APIs set\n if (!Object.keys(customUserAgentState[input.category]).length) {\n delete customUserAgentState[input.category];\n }\n }\n });\n };\n return cleanUpCallback;\n};\nconst getCustomUserAgent = (category, api) => customUserAgentState[category]?.[api]?.additionalDetails;\n\nexport { getCustomUserAgent, setCustomUserAgent };\n//# sourceMappingURL=customUserAgent.mjs.map\n","import { Framework } from './types.mjs';\nimport { version } from './version.mjs';\nimport { detectFramework, observeFrameworkChanges } from './detectFramework.mjs';\nimport { getCustomUserAgent } from './customUserAgent.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst BASE_USER_AGENT = `aws-amplify`;\n/** Sanitize Amplify version string be removing special character + and character post the special character */\nconst sanitizeAmplifyVersion = (amplifyVersion) => amplifyVersion.replace(/\\+.*/, '');\nclass PlatformBuilder {\n constructor() {\n this.userAgent = `${BASE_USER_AGENT}/${sanitizeAmplifyVersion(version)}`;\n }\n get framework() {\n return detectFramework();\n }\n get isReactNative() {\n return (this.framework === Framework.ReactNative ||\n this.framework === Framework.Expo);\n }\n observeFrameworkChanges(fcn) {\n observeFrameworkChanges(fcn);\n }\n}\nconst Platform = new PlatformBuilder();\nconst getAmplifyUserAgentObject = ({ category, action, } = {}) => {\n const userAgent = [\n [BASE_USER_AGENT, sanitizeAmplifyVersion(version)],\n ];\n if (category) {\n userAgent.push([category, action]);\n }\n userAgent.push(['framework', detectFramework()]);\n if (category && action) {\n const customState = getCustomUserAgent(category, action);\n if (customState) {\n customState.forEach(state => {\n userAgent.push(state);\n });\n }\n }\n return userAgent;\n};\nconst getAmplifyUserAgent = (customUserAgentDetails) => {\n const userAgent = getAmplifyUserAgentObject(customUserAgentDetails);\n const userAgentString = userAgent\n .map(([agentKey, agentValue]) => agentKey && agentValue ? `${agentKey}/${agentValue}` : agentKey)\n .join(' ');\n return userAgentString;\n};\n\nexport { Platform, getAmplifyUserAgent, getAmplifyUserAgentObject, sanitizeAmplifyVersion };\n//# sourceMappingURL=index.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst isBrowser = () => typeof window !== 'undefined' && typeof window.document !== 'undefined';\n\nexport { isBrowser };\n//# sourceMappingURL=isBrowser.mjs.map\n","class AuthClass {\n /**\n * Configure Auth category\n *\n * @internal\n *\n * @param authResourcesConfig - Resources configurations required by Auth providers.\n * @param authOptions - Client options used by library\n *\n * @returns void\n */\n configure(authResourcesConfig, authOptions) {\n this.authConfig = authResourcesConfig;\n this.authOptions = authOptions;\n }\n /**\n * Fetch the auth tokens, and the temporary AWS credentials and identity if they are configured. By default it\n * does not refresh the auth tokens or credentials if they are loaded in storage already. You can force a refresh\n * with `{ forceRefresh: true }` input.\n *\n * @param options - Options configuring the fetch behavior.\n *\n * @returns Promise of current auth session {@link AuthSession}.\n */\n async fetchAuthSession(options = {}) {\n let credentialsAndIdentityId;\n let userSub;\n // Get tokens will throw if session cannot be refreshed (network or service error) or return null if not available\n const tokens = await this.getTokens(options);\n if (tokens) {\n userSub = tokens.accessToken?.payload?.sub;\n // getCredentialsAndIdentityId will throw if cannot get credentials (network or service error)\n credentialsAndIdentityId =\n await this.authOptions?.credentialsProvider?.getCredentialsAndIdentityId({\n authConfig: this.authConfig,\n tokens,\n authenticated: true,\n forceRefresh: options.forceRefresh,\n });\n }\n else {\n // getCredentialsAndIdentityId will throw if cannot get credentials (network or service error)\n credentialsAndIdentityId =\n await this.authOptions?.credentialsProvider?.getCredentialsAndIdentityId({\n authConfig: this.authConfig,\n authenticated: false,\n forceRefresh: options.forceRefresh,\n });\n }\n return {\n tokens,\n credentials: credentialsAndIdentityId?.credentials,\n identityId: credentialsAndIdentityId?.identityId,\n userSub,\n };\n }\n async clearCredentials() {\n await this.authOptions?.credentialsProvider?.clearCredentialsAndIdentityId();\n }\n async getTokens(options) {\n return ((await this.authOptions?.tokenProvider?.getTokens(options)) ?? undefined);\n }\n}\n\nexport { AuthClass };\n//# sourceMappingURL=index.mjs.map\n","import { Hub, AMPLIFY_SYMBOL } from '../Hub/index.mjs';\nimport '../types/errors.mjs';\nimport '../errors/errorHelpers.mjs';\nimport '../utils/getClientInfo/getClientInfo.mjs';\nimport '../utils/retry/retry.mjs';\nimport { deepFreeze } from '../utils/deepFreeze.mjs';\nimport '../parseAWSExports.mjs';\nimport { ADD_OAUTH_LISTENER } from './constants.mjs';\nimport 'uuid';\nimport { parseAmplifyConfig } from '../utils/parseAmplifyConfig.mjs';\nimport './Auth/utils/errorHelpers.mjs';\nimport '@aws-crypto/sha256-js';\nimport '@smithy/util-hex-encoding';\nimport '../Platform/index.mjs';\nimport '../Platform/types.mjs';\nimport '../BackgroundProcessManager/types.mjs';\nimport '../Reachability/Reachability.mjs';\nimport '../utils/sessionListener/index.mjs';\nimport { AuthClass } from './Auth/index.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nclass AmplifyClass {\n constructor() {\n this.oAuthListener = undefined;\n this.resourcesConfig = {};\n this.libraryOptions = {};\n this.Auth = new AuthClass();\n }\n /**\n * Configures Amplify for use with your back-end resources.\n *\n * @remarks\n * This API does not perform any merging of either `resourcesConfig` or `libraryOptions`. The most recently\n * provided values will be used after configuration.\n *\n * @remarks\n * `configure` can be used to specify additional library options where available for supported categories.\n *\n * @param resourceConfig - Back-end resource configuration. Typically provided via the `aws-exports.js` file.\n * @param libraryOptions - Additional options for customizing the behavior of the library.\n */\n configure(resourcesConfig, libraryOptions) {\n const resolvedResourceConfig = parseAmplifyConfig(resourcesConfig);\n this.resourcesConfig = resolvedResourceConfig;\n if (libraryOptions) {\n this.libraryOptions = libraryOptions;\n }\n // Make resource config immutable\n this.resourcesConfig = deepFreeze(this.resourcesConfig);\n this.Auth.configure(this.resourcesConfig.Auth, this.libraryOptions.Auth);\n Hub.dispatch('core', {\n event: 'configure',\n data: this.resourcesConfig,\n }, 'Configure', AMPLIFY_SYMBOL);\n this.notifyOAuthListener();\n }\n /**\n * Provides access to the current back-end resource configuration for the Library.\n *\n * @returns Returns the immutable back-end resource configuration.\n */\n getConfig() {\n return this.resourcesConfig;\n }\n /** @internal */\n [ADD_OAUTH_LISTENER](listener) {\n if (this.resourcesConfig.Auth?.Cognito.loginWith?.oauth) {\n // when Amplify has been configured with a valid OAuth config while adding the listener, run it directly\n listener(this.resourcesConfig.Auth?.Cognito);\n }\n else {\n // otherwise register the listener and run it later when Amplify gets configured with a valid oauth config\n this.oAuthListener = listener;\n }\n }\n notifyOAuthListener() {\n if (!this.resourcesConfig.Auth?.Cognito.loginWith?.oauth ||\n !this.oAuthListener) {\n return;\n }\n this.oAuthListener(this.resourcesConfig.Auth?.Cognito);\n // the listener should only be notified once with a valid oauth config\n this.oAuthListener = undefined;\n }\n}\n/**\n * The `Amplify` utility is used to configure the library.\n *\n * @remarks\n * `Amplify` orchestrates cross-category communication within the library.\n */\nconst Amplify = new AmplifyClass();\n\nexport { Amplify, AmplifyClass };\n//# sourceMappingURL=Amplify.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst fetchAuthSession = (amplify, options) => {\n return amplify.Auth.fetchAuthSession(options);\n};\n\nexport { fetchAuthSession };\n//# sourceMappingURL=fetchAuthSession.mjs.map\n","import { Amplify } from '../Amplify.mjs';\nimport { fetchAuthSession as fetchAuthSession$1 } from './internal/fetchAuthSession.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Fetch the auth session including the tokens and credentials if they are available. By default it\n * does not refresh the auth tokens or credentials if they are loaded in storage already. You can force a refresh\n * with `{ forceRefresh: true }` input.\n *\n * @param options - Options configuring the fetch behavior.\n * @throws {@link AuthError} - Throws error when session information cannot be refreshed.\n * @returns Promise\n */\nconst fetchAuthSession = (options) => {\n return fetchAuthSession$1(Amplify, options);\n};\n\nexport { fetchAuthSession };\n//# sourceMappingURL=fetchAuthSession.mjs.map\n","import { Amplify } from '../Amplify.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction clearCredentials() {\n return Amplify.Auth.clearCredentials();\n}\n\nexport { clearCredentials };\n//# sourceMappingURL=clearCredentials.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst parseMetadata = (response) => {\n const { headers, statusCode } = response;\n return {\n ...(isMetadataBearer(response) ? response.$metadata : {}),\n httpStatusCode: statusCode,\n requestId: headers['x-amzn-requestid'] ??\n headers['x-amzn-request-id'] ??\n headers['x-amz-request-id'],\n extendedRequestId: headers['x-amz-id-2'],\n cfId: headers['x-amz-cf-id'],\n };\n};\nconst isMetadataBearer = (response) => typeof response?.$metadata === 'object';\n\nexport { parseMetadata };\n//# sourceMappingURL=responseInfo.mjs.map\n","import { parseMetadata } from './responseInfo.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Utility functions for serializing and deserializing of JSON protocol in general(including: REST-JSON, JSON-RPC, etc.)\n */\n/**\n * Error parser for AWS JSON protocol.\n */\nconst parseJsonError = async (response) => {\n if (!response || response.statusCode < 300) {\n return;\n }\n const body = await parseJsonBody(response);\n const sanitizeErrorCode = (rawValue) => {\n const [cleanValue] = rawValue.toString().split(/[,:]+/);\n if (cleanValue.includes('#')) {\n return cleanValue.split('#')[1];\n }\n return cleanValue;\n };\n const code = sanitizeErrorCode(response.headers['x-amzn-errortype'] ??\n body.code ??\n body.__type ??\n 'UnknownError');\n const message = body.message ?? body.Message ?? 'Unknown error';\n const error = new Error(message);\n return Object.assign(error, {\n name: code,\n $metadata: parseMetadata(response),\n });\n};\n/**\n * Parse JSON response body to JavaScript object.\n */\nconst parseJsonBody = async (response) => {\n if (!response.body) {\n throw new Error('Missing response payload');\n }\n const output = await response.body.json();\n return Object.assign(output, {\n $metadata: parseMetadata(response),\n });\n};\n\nexport { parseJsonBody, parseJsonError };\n//# sourceMappingURL=json.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Compose a service API handler that accepts input as defined shape and responds conforming to defined output shape.\n * A service API handler is composed with:\n * * A transfer handler\n * * A serializer function\n * * A deserializer function\n * * A default config object\n *\n * The returned service API handler, when called, will trigger the following workflow:\n * 1. When calling the service API handler function, the default config object is merged into the input config\n * object to assign the default values of some omitted configs, resulting to a resolved config object.\n * 2. The `endpointResolver` function from the default config object will be invoked with the resolved config object and\n * API input object resulting to an endpoint instance.\n * 3. The serializer function is invoked with API input object and the endpoint instance resulting to an HTTP request\n * instance.\n * 4. The HTTP request instance and the resolved config object is passed to the transfer handler function.\n * 5. The transfer handler function resolves to an HTTP response instance(can be either successful or failed status code).\n * 6. The deserializer function is invoked with the HTTP response instance resulting to the API output object, and\n * return to the caller.\n *\n *\n * @param transferHandler Async function for dispatching HTTP requests and returning HTTP response.\n * @param serializer Async function for converting object in defined input shape into HTTP request targeting a given\n * \tendpoint.\n * @param deserializer Async function for converting HTTP response into output object in defined output shape, or error\n * \tshape.\n * @param defaultConfig object containing default options to be consumed by transfer handler, serializer and\n * deserializer.\n * @returns a async service API handler function that accepts a config object and input object in defined shape, returns\n * \tan output object in defined shape. It may also throw error instance in defined shape in deserializer. The config\n * object type is composed with options type of transferHandler, endpointResolver function as well as endpointResolver\n * function's input options type, region string. The config object property will be marked as optional if it's also\n * \tdefined in defaultConfig.\n *\n * @internal\n */\nconst composeServiceApi = (transferHandler, serializer, deserializer, defaultConfig) => {\n return async (config, input) => {\n const resolvedConfig = {\n ...defaultConfig,\n ...config,\n };\n // We need to allow different endpoints based on both given config(other than region) and input.\n // However for most of non-S3 services, region is the only input for endpoint resolver.\n const endpoint = await resolvedConfig.endpointResolver(resolvedConfig, input);\n // Unlike AWS SDK clients, a serializer should NOT populate the `host` or `content-length` headers.\n // Both of these headers are prohibited per Spec(https://developer.mozilla.org/en-US/docs/Glossary/Forbidden_header_name).\n // They will be populated automatically by browser, or node-fetch polyfill.\n const request = await serializer(input, endpoint);\n const response = await transferHandler(request, {\n ...resolvedConfig,\n });\n return deserializer(response);\n };\n};\n\nexport { composeServiceApi };\n//# sourceMappingURL=composeServiceApi.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Default partition for AWS services. This is used when the region is not provided or the region is not recognized.\n *\n * @internal\n */\nconst defaultPartition = {\n id: 'aws',\n outputs: {\n dnsSuffix: 'amazonaws.com',\n },\n regionRegex: '^(us|eu|ap|sa|ca|me|af)\\\\-\\\\w+\\\\-\\\\d+$',\n regions: ['aws-global'],\n};\n/**\n * This data is adapted from the partition file from AWS SDK shared utilities but remove some contents for bundle size\n * concern. Information removed are `dualStackDnsSuffix`, `supportDualStack`, `supportFIPS`, restricted partitions, and\n * list of regions for each partition other than global regions.\n *\n * * Ref: https://docs.aws.amazon.com/general/latest/gr/rande.html#regional-endpoints\n * * Ref: https://github.com/aws/aws-sdk-js-v3/blob/0201baef03c2379f1f6f7150b9d401d4b230d488/packages/util-endpoints/src/lib/aws/partitions.json#L1\n *\n * @internal\n */\nconst partitionsInfo = {\n partitions: [\n defaultPartition,\n {\n id: 'aws-cn',\n outputs: {\n dnsSuffix: 'amazonaws.com.cn',\n },\n regionRegex: '^cn\\\\-\\\\w+\\\\-\\\\d+$',\n regions: ['aws-cn-global'],\n },\n ],\n};\n\nexport { defaultPartition, partitionsInfo };\n//# sourceMappingURL=partitions.mjs.map\n","import { partitionsInfo, defaultPartition } from './partitions.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Get the AWS Services endpoint URL's DNS suffix for a given region. A typical AWS regional service endpoint URL will\n * follow this pattern: {endpointPrefix}.{region}.{dnsSuffix}. For example, the endpoint URL for Cognito Identity in\n * us-east-1 will be cognito-identity.us-east-1.amazonaws.com. Here the DnsSuffix is `amazonaws.com`.\n *\n * @param region\n * @returns The DNS suffix\n *\n * @internal\n */\nconst getDnsSuffix = (region) => {\n const { partitions } = partitionsInfo;\n for (const { regions, outputs, regionRegex } of partitions) {\n const regex = new RegExp(regionRegex);\n if (regions.includes(region) || regex.test(region)) {\n return outputs.dnsSuffix;\n }\n }\n return defaultPartition.outputs.dnsSuffix;\n};\n\nexport { getDnsSuffix };\n//# sourceMappingURL=getDnsSuffix.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst DEFAULT_RETRY_ATTEMPTS = 3;\nconst AMZ_SDK_INVOCATION_ID_HEADER = 'amz-sdk-invocation-id';\nconst AMZ_SDK_REQUEST_HEADER = 'amz-sdk-request';\nconst DEFAULT_MAX_DELAY_MS = 5 * 60 * 1000;\n\nexport { AMZ_SDK_INVOCATION_ID_HEADER, AMZ_SDK_REQUEST_HEADER, DEFAULT_MAX_DELAY_MS, DEFAULT_RETRY_ATTEMPTS };\n//# sourceMappingURL=constants.mjs.map\n","import { DEFAULT_RETRY_ATTEMPTS } from './constants.mjs';\n\n/**\n * Middleware that executes the retry logic.\n */\nconst retryMiddlewareFactory = ({ maxAttempts = DEFAULT_RETRY_ATTEMPTS, retryDecider, computeDelay, abortSignal, }) => {\n if (maxAttempts < 1) {\n throw new Error('maxAttempts must be greater than 0');\n }\n return (next, context) => async function retryMiddleware(request) {\n let error;\n let attemptsCount = context.attemptsCount ?? 0;\n let response;\n // When retry is not needed or max attempts is reached, either error or response will be set. This function handles either cases.\n const handleTerminalErrorOrResponse = () => {\n if (response) {\n addOrIncrementMetadataAttempts(response, attemptsCount);\n return response;\n }\n else {\n addOrIncrementMetadataAttempts(error, attemptsCount);\n throw error;\n }\n };\n while (!abortSignal?.aborted && attemptsCount < maxAttempts) {\n try {\n response = await next(request);\n error = undefined;\n }\n catch (e) {\n error = e;\n response = undefined;\n }\n // context.attemptsCount may be updated after calling next handler which may retry the request by itself.\n attemptsCount =\n (context.attemptsCount ?? 0) > attemptsCount\n ? (context.attemptsCount ?? 0)\n : attemptsCount + 1;\n context.attemptsCount = attemptsCount;\n const { isCredentialsExpiredError, retryable } = await retryDecider(response, error, context);\n if (retryable) {\n // Setting isCredentialsInvalid flag to notify signing middleware to forceRefresh credentials provider.\n context.isCredentialsExpired = !!isCredentialsExpiredError;\n if (!abortSignal?.aborted && attemptsCount < maxAttempts) {\n // prevent sleep for last attempt or cancelled request;\n const delay = computeDelay(attemptsCount);\n await cancellableSleep(delay, abortSignal);\n }\n continue;\n }\n else {\n return handleTerminalErrorOrResponse();\n }\n }\n if (abortSignal?.aborted) {\n throw new Error('Request aborted.');\n }\n else {\n return handleTerminalErrorOrResponse();\n }\n };\n};\nconst cancellableSleep = (timeoutMs, abortSignal) => {\n if (abortSignal?.aborted) {\n return Promise.resolve();\n }\n let timeoutId;\n let sleepPromiseResolveFn;\n const sleepPromise = new Promise(resolve => {\n sleepPromiseResolveFn = resolve;\n timeoutId = setTimeout(resolve, timeoutMs);\n });\n abortSignal?.addEventListener('abort', function cancelSleep(_) {\n clearTimeout(timeoutId);\n abortSignal?.removeEventListener('abort', cancelSleep);\n sleepPromiseResolveFn();\n });\n return sleepPromise;\n};\nconst addOrIncrementMetadataAttempts = (nextHandlerOutput, attempts) => {\n if (Object.prototype.toString.call(nextHandlerOutput) !== '[object Object]') {\n return;\n }\n nextHandlerOutput.$metadata = {\n ...(nextHandlerOutput.$metadata ?? {}),\n attempts,\n };\n};\n\nexport { retryMiddlewareFactory };\n//# sourceMappingURL=retryMiddleware.mjs.map\n","import { v4 } from 'uuid';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst amplifyUuid = v4;\n\nexport { amplifyUuid };\n//# sourceMappingURL=index.mjs.map\n","import '../../../types/errors.mjs';\nimport '../../../errors/errorHelpers.mjs';\nimport '../../../utils/getClientInfo/getClientInfo.mjs';\nimport '../../../utils/retry/retry.mjs';\nimport '../../../parseAWSExports.mjs';\nimport { amplifyUuid } from '../../../utils/amplifyUuid/index.mjs';\nimport '../../../singleton/Auth/utils/errorHelpers.mjs';\nimport '@aws-crypto/sha256-js';\nimport '@smithy/util-hex-encoding';\nimport '../../../Platform/index.mjs';\nimport '../../../Platform/types.mjs';\nimport '../../../BackgroundProcessManager/types.mjs';\nimport '../../../Reachability/Reachability.mjs';\nimport '../../../Hub/index.mjs';\nimport '../../../utils/sessionListener/index.mjs';\nimport { AMZ_SDK_INVOCATION_ID_HEADER } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Middleware injects a UUID string to `amz-sdk-invocation-id` header.\n * if the header is not set already. This header is helpful to provide\n * observability to group the requests caused by automatic retry.\n *\n * This middleware is standalone because of extra UUID dependency, we will\n * NOT use this middleware for API categories.\n *\n * Ref: https://sdk.amazonaws.com/kotlin/api/smithy-kotlin/api/1.0.9/http-client/aws.smithy.kotlin.runtime.http.operation/-http-operation-context/-sdk-invocation-id.html\n */\nconst amzSdkInvocationIdHeaderMiddlewareFactory = () => next => {\n return async function amzSdkInvocationIdHeaderMiddleware(request) {\n if (!request.headers[AMZ_SDK_INVOCATION_ID_HEADER]) {\n request.headers[AMZ_SDK_INVOCATION_ID_HEADER] = amplifyUuid();\n }\n return next(request);\n };\n};\n\nexport { amzSdkInvocationIdHeaderMiddlewareFactory };\n//# sourceMappingURL=amzSdkInvocationIdHeaderMiddleware.mjs.map\n","import { DEFAULT_RETRY_ATTEMPTS, AMZ_SDK_REQUEST_HEADER } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Middleware injects `amz-sdk-request` header to indicate the retry state at the time an HTTP request is made.\n * This middleware should co-exist with retryMiddleware as it relies on the retryAttempts value in middleware context\n * set by the retry middleware.\n *\n * Example header: `amz-sdk-request: attempt=1; max=3`.\n *\n * This middleware is standalone because of extra headers may conflict with custom endpoint settings(e.g. CORS), we will\n * NOT use this middleware for API categories.\n */\nconst amzSdkRequestHeaderMiddlewareFactory = ({ maxAttempts = DEFAULT_RETRY_ATTEMPTS }) => (next, context) => {\n return async function amzSdkRequestHeaderMiddleware(request) {\n const attemptsCount = context.attemptsCount ?? 0;\n request.headers[AMZ_SDK_REQUEST_HEADER] =\n `attempt=${attemptsCount + 1}; max=${maxAttempts}`;\n return next(request);\n };\n};\n\nexport { amzSdkRequestHeaderMiddlewareFactory };\n//# sourceMappingURL=amzSdkRequestHeaderMiddleware.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Middleware injects user agent string to specified header(default to 'x-amz-user-agent'),\n * if the header is not set already.\n *\n * TODO: incorporate new user agent design\n */\nconst userAgentMiddlewareFactory = ({ userAgentHeader = 'x-amz-user-agent', userAgentValue = '', }) => next => {\n return async function userAgentMiddleware(request) {\n if (userAgentValue.trim().length === 0) {\n const result = await next(request);\n return result;\n }\n else {\n const headerName = userAgentHeader.toLowerCase();\n request.headers[headerName] = request.headers[headerName]\n ? `${request.headers[headerName]} ${userAgentValue}`\n : userAgentValue;\n const response = await next(request);\n return response;\n }\n };\n};\n\nexport { userAgentMiddlewareFactory };\n//# sourceMappingURL=middleware.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Compose a transfer handler with a core transfer handler and a list of middleware.\n * @param coreHandler Core transfer handler\n * @param middleware\tList of middleware\n * @returns A transfer handler whose option type is the union of the core\n * \ttransfer handler's option type and the middleware's option type.\n * @internal\n */\nconst composeTransferHandler = (coreHandler, middleware) => (request, options) => {\n const context = {};\n let composedHandler = (composeHandlerRequest) => coreHandler(composeHandlerRequest, options);\n for (let i = middleware.length - 1; i >= 0; i--) {\n const m = middleware[i];\n const resolvedMiddleware = m(options);\n composedHandler = resolvedMiddleware(composedHandler, context);\n }\n return composedHandler(request);\n};\n\nexport { composeTransferHandler };\n//# sourceMappingURL=composeTransferHandler.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Cache the payload of a response body. It allows multiple calls to the body,\n * for example, when reading the body in both retry decider and error deserializer.\n * Caching body is allowed here because we call the body accessor(blob(), json(),\n * etc.) when body is small or streaming implementation is not available(RN).\n *\n * @internal\n */\nconst withMemoization = (payloadAccessor) => {\n let cached;\n return () => {\n if (!cached) {\n // Explicitly not awaiting. Intermediate await would add overhead and\n // introduce a possible race in the event that this wrapper is called\n // again before the first `payloadAccessor` call resolves.\n cached = payloadAccessor();\n }\n return cached;\n };\n};\n\nexport { withMemoization };\n//# sourceMappingURL=memoization.mjs.map\n","import { AmplifyError } from '../../errors/AmplifyError.mjs';\nimport { AmplifyErrorCode } from '../../types/errors.mjs';\nimport '../../errors/errorHelpers.mjs';\nimport { withMemoization } from '../utils/memoization.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst shouldSendBody = (method) => !['HEAD', 'GET', 'DELETE'].includes(method.toUpperCase());\n// TODO[AllanZhengYP]: we need to provide isCanceledError utility\nconst fetchTransferHandler = async ({ url, method, headers, body }, { abortSignal, cache, withCrossDomainCredentials }) => {\n let resp;\n try {\n resp = await fetch(url, {\n method,\n headers,\n body: shouldSendBody(method) ? body : undefined,\n signal: abortSignal,\n cache,\n credentials: withCrossDomainCredentials ? 'include' : 'same-origin',\n });\n }\n catch (e) {\n if (e instanceof TypeError) {\n throw new AmplifyError({\n name: AmplifyErrorCode.NetworkError,\n message: 'A network error has occurred.',\n underlyingError: e,\n });\n }\n throw e;\n }\n const responseHeaders = {};\n resp.headers?.forEach((value, key) => {\n responseHeaders[key.toLowerCase()] = value;\n });\n const httpResponse = {\n statusCode: resp.status,\n headers: responseHeaders,\n body: null,\n };\n // resp.body is a ReadableStream according to Fetch API spec, but React Native\n // does not implement it.\n const bodyWithMixin = Object.assign(resp.body ?? {}, {\n text: withMemoization(() => resp.text()),\n blob: withMemoization(() => resp.blob()),\n json: withMemoization(() => resp.json()),\n });\n return {\n ...httpResponse,\n body: bodyWithMixin,\n };\n};\n\nexport { fetchTransferHandler };\n//# sourceMappingURL=fetch.mjs.map\n","import { retryMiddlewareFactory } from '../../middleware/retry/retryMiddleware.mjs';\nimport '../../../types/errors.mjs';\nimport '../../../errors/errorHelpers.mjs';\nimport '../../../utils/getClientInfo/getClientInfo.mjs';\nimport '../../../utils/retry/retry.mjs';\nimport { amzSdkInvocationIdHeaderMiddlewareFactory } from '../../middleware/retry/amzSdkInvocationIdHeaderMiddleware.mjs';\nimport { amzSdkRequestHeaderMiddlewareFactory } from '../../middleware/retry/amzSdkRequestHeaderMiddleware.mjs';\nimport { userAgentMiddlewareFactory } from '../../middleware/userAgent/middleware.mjs';\nimport { composeTransferHandler } from '../../internal/composeTransferHandler.mjs';\nimport { fetchTransferHandler } from '../fetch.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst unauthenticatedHandler = composeTransferHandler(fetchTransferHandler, [\n userAgentMiddlewareFactory,\n amzSdkInvocationIdHeaderMiddlewareFactory,\n retryMiddlewareFactory,\n amzSdkRequestHeaderMiddlewareFactory,\n]);\n\nexport { unauthenticatedHandler };\n//# sourceMappingURL=unauthenticated.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst MAX_DELAY_MS = 5 * 60 * 1000;\n\nexport { MAX_DELAY_MS };\n//# sourceMappingURL=constants.mjs.map\n","import { MAX_DELAY_MS } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @private\n * Internal use of Amplify only\n */\nfunction jitteredBackoff(maxDelayMs = MAX_DELAY_MS) {\n const BASE_TIME_MS = 100;\n const JITTER_FACTOR = 100;\n return attempt => {\n const delay = 2 ** attempt * BASE_TIME_MS + JITTER_FACTOR * Math.random();\n return delay > maxDelayMs ? false : delay;\n };\n}\n\nexport { jitteredBackoff };\n//# sourceMappingURL=jitteredBackoff.mjs.map\n","import '../../../types/errors.mjs';\nimport '../../../errors/errorHelpers.mjs';\nimport '../../../utils/getClientInfo/getClientInfo.mjs';\nimport { jitteredBackoff as jitteredBackoff$1 } from '../../../utils/retry/jitteredBackoff.mjs';\nimport '../../../utils/retry/retry.mjs';\nimport { DEFAULT_MAX_DELAY_MS } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// TODO: [v6] The separate retry utility is used by Data packages now and will replaced by retry middleware.\nconst jitteredBackoff = attempt => {\n const delayFunction = jitteredBackoff$1(DEFAULT_MAX_DELAY_MS);\n const delay = delayFunction(attempt);\n // The delayFunction returns false when the delay is greater than the max delay(5 mins).\n // In this case, the retry middleware will delay 5 mins instead, as a ceiling of the delay.\n return delay === false ? DEFAULT_MAX_DELAY_MS : delay;\n};\n\nexport { jitteredBackoff };\n//# sourceMappingURL=jitteredBackoff.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// via https://github.com/aws/aws-sdk-js-v3/blob/ab0e7be36e7e7f8a0c04834357aaad643c7912c3/packages/service-error-classification/src/constants.ts#L8\nconst CLOCK_SKEW_ERROR_CODES = [\n 'AuthFailure',\n 'InvalidSignatureException',\n 'RequestExpired',\n 'RequestInTheFuture',\n 'RequestTimeTooSkewed',\n 'SignatureDoesNotMatch',\n 'BadRequestException', // API Gateway\n];\n/**\n * Given an error code, returns true if it is related to a clock skew error.\n *\n * @param errorCode String representation of some error.\n * @returns True if given error is present in `CLOCK_SKEW_ERROR_CODES`, false otherwise.\n *\n * @internal\n */\nconst isClockSkewError = (errorCode) => !!errorCode && CLOCK_SKEW_ERROR_CODES.includes(errorCode);\n\nexport { isClockSkewError };\n//# sourceMappingURL=isClockSkewError.mjs.map\n","import { AmplifyErrorCode } from '../../../types/errors.mjs';\nimport { isClockSkewError } from './isClockSkewError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Get retry decider function\n * @param errorParser Function to load JavaScript error from HTTP response\n */\nconst getRetryDecider = (errorParser) => async (response, error) => {\n const parsedError = error ??\n (await errorParser(response)) ??\n undefined;\n const errorCode = parsedError?.code || parsedError?.name;\n const statusCode = response?.statusCode;\n const isRetryable = isConnectionError(error) ||\n isThrottlingError(statusCode, errorCode) ||\n isClockSkewError(errorCode) ||\n isServerSideError(statusCode, errorCode);\n return {\n retryable: isRetryable,\n };\n};\n// reference: https://github.com/aws/aws-sdk-js-v3/blob/ab0e7be36e7e7f8a0c04834357aaad643c7912c3/packages/service-error-classification/src/constants.ts#L22-L37\nconst THROTTLING_ERROR_CODES = [\n 'BandwidthLimitExceeded',\n 'EC2ThrottledException',\n 'LimitExceededException',\n 'PriorRequestNotComplete',\n 'ProvisionedThroughputExceededException',\n 'RequestLimitExceeded',\n 'RequestThrottled',\n 'RequestThrottledException',\n 'SlowDown',\n 'ThrottledException',\n 'Throttling',\n 'ThrottlingException',\n 'TooManyRequestsException',\n];\nconst TIMEOUT_ERROR_CODES = [\n 'TimeoutError',\n 'RequestTimeout',\n 'RequestTimeoutException',\n];\nconst isThrottlingError = (statusCode, errorCode) => statusCode === 429 ||\n (!!errorCode && THROTTLING_ERROR_CODES.includes(errorCode));\nconst isConnectionError = (error) => [\n AmplifyErrorCode.NetworkError,\n // TODO(vNext): unify the error code `ERR_NETWORK` used by the Storage XHR handler\n 'ERR_NETWORK',\n].includes(error?.name);\nconst isServerSideError = (statusCode, errorCode) => (!!statusCode && [500, 502, 503, 504].includes(statusCode)) ||\n (!!errorCode && TIMEOUT_ERROR_CODES.includes(errorCode));\n\nexport { getRetryDecider };\n//# sourceMappingURL=defaultRetryDecider.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst AmplifyUrl = URL;\nconst AmplifyUrlSearchParams = URLSearchParams;\n\nexport { AmplifyUrl, AmplifyUrlSearchParams };\n//# sourceMappingURL=index.mjs.map\n","import { getDnsSuffix } from '../../clients/endpoints/getDnsSuffix.mjs';\nimport '../../types/errors.mjs';\nimport '../../errors/errorHelpers.mjs';\nimport { unauthenticatedHandler } from '../../clients/handlers/aws/unauthenticated.mjs';\nimport { jitteredBackoff } from '../../clients/middleware/retry/jitteredBackoff.mjs';\nimport { getRetryDecider } from '../../clients/middleware/retry/defaultRetryDecider.mjs';\nimport '../../utils/getClientInfo/getClientInfo.mjs';\nimport '../../utils/retry/retry.mjs';\nimport '../../parseAWSExports.mjs';\nimport 'uuid';\nimport { AmplifyUrl } from '../../utils/amplifyUrl/index.mjs';\nimport '../../singleton/Auth/utils/errorHelpers.mjs';\nimport '@aws-crypto/sha256-js';\nimport '@smithy/util-hex-encoding';\nimport { getAmplifyUserAgent } from '../../Platform/index.mjs';\nimport '../../Platform/types.mjs';\nimport '../../BackgroundProcessManager/types.mjs';\nimport '../../Reachability/Reachability.mjs';\nimport '../../Hub/index.mjs';\nimport '../../utils/sessionListener/index.mjs';\nimport { composeTransferHandler } from '../../clients/internal/composeTransferHandler.mjs';\nimport { parseJsonError } from '../../clients/serde/json.mjs';\nimport { observeFrameworkChanges } from '../../Platform/detectFramework.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * The service name used to sign requests if the API requires authentication.\n */\nconst SERVICE_NAME = 'cognito-identity';\n/**\n * The endpoint resolver function that returns the endpoint URL for a given region.\n */\nconst endpointResolver = ({ region }) => ({\n url: new AmplifyUrl(`https://cognito-identity.${region}.${getDnsSuffix(region)}`),\n});\n/**\n * A Cognito Identity-specific middleware that disables caching for all requests.\n */\nconst disableCacheMiddlewareFactory = () => next => async function disableCacheMiddleware(request) {\n request.headers['cache-control'] = 'no-store';\n return next(request);\n};\n/**\n * A Cognito Identity-specific transfer handler that does NOT sign requests, and\n * disables caching.\n *\n * @internal\n */\nconst cognitoIdentityTransferHandler = composeTransferHandler(unauthenticatedHandler, [disableCacheMiddlewareFactory]);\n/**\n * @internal\n */\nconst defaultConfig = {\n service: SERVICE_NAME,\n endpointResolver,\n retryDecider: getRetryDecider(parseJsonError),\n computeDelay: jitteredBackoff,\n userAgentValue: getAmplifyUserAgent(),\n cache: 'no-store',\n};\nobserveFrameworkChanges(() => {\n defaultConfig.userAgentValue = getAmplifyUserAgent();\n});\n/**\n * @internal\n */\nconst getSharedHeaders = (operation) => ({\n 'content-type': 'application/x-amz-json-1.1',\n 'x-amz-target': `AWSCognitoIdentityService.${operation}`,\n});\n/**\n * @internal\n */\nconst buildHttpRpcRequest = ({ url }, headers, body) => ({\n headers,\n url,\n body,\n method: 'POST',\n});\n\nexport { buildHttpRpcRequest, cognitoIdentityTransferHandler, defaultConfig, getSharedHeaders };\n//# sourceMappingURL=base.mjs.map\n","import '../../types/errors.mjs';\nimport '../../errors/errorHelpers.mjs';\nimport '../../utils/getClientInfo/getClientInfo.mjs';\nimport '../../utils/retry/retry.mjs';\nimport '../../parseAWSExports.mjs';\nimport 'uuid';\nimport '../../singleton/Auth/utils/errorHelpers.mjs';\nimport '@aws-crypto/sha256-js';\nimport '@smithy/util-hex-encoding';\nimport '../../Platform/index.mjs';\nimport '../../Platform/types.mjs';\nimport '../../BackgroundProcessManager/types.mjs';\nimport '../../Reachability/Reachability.mjs';\nimport '../../Hub/index.mjs';\nimport '../../utils/sessionListener/index.mjs';\nimport { parseMetadata } from '../../clients/serde/responseInfo.mjs';\nimport { parseJsonError, parseJsonBody } from '../../clients/serde/json.mjs';\nimport { composeServiceApi } from '../../clients/internal/composeServiceApi.mjs';\nimport { defaultConfig, cognitoIdentityTransferHandler, buildHttpRpcRequest, getSharedHeaders } from './base.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst getIdSerializer = (input, endpoint) => {\n const headers = getSharedHeaders('GetId');\n const body = JSON.stringify(input);\n return buildHttpRpcRequest(endpoint, headers, body);\n};\nconst getIdDeserializer = async (response) => {\n if (response.statusCode >= 300) {\n const error = await parseJsonError(response);\n throw error;\n }\n else {\n const body = await parseJsonBody(response);\n return {\n IdentityId: body.IdentityId,\n $metadata: parseMetadata(response),\n };\n }\n};\n/**\n * @internal\n */\nconst getId = composeServiceApi(cognitoIdentityTransferHandler, getIdSerializer, getIdDeserializer, defaultConfig);\n\nexport { getId };\n//# sourceMappingURL=getId.mjs.map\n","import '../../types/errors.mjs';\nimport '../../errors/errorHelpers.mjs';\nimport '../../utils/getClientInfo/getClientInfo.mjs';\nimport '../../utils/retry/retry.mjs';\nimport '../../parseAWSExports.mjs';\nimport 'uuid';\nimport '../../singleton/Auth/utils/errorHelpers.mjs';\nimport '@aws-crypto/sha256-js';\nimport '@smithy/util-hex-encoding';\nimport '../../Platform/index.mjs';\nimport '../../Platform/types.mjs';\nimport '../../BackgroundProcessManager/types.mjs';\nimport '../../Reachability/Reachability.mjs';\nimport '../../Hub/index.mjs';\nimport '../../utils/sessionListener/index.mjs';\nimport { parseMetadata } from '../../clients/serde/responseInfo.mjs';\nimport { parseJsonError, parseJsonBody } from '../../clients/serde/json.mjs';\nimport { composeServiceApi } from '../../clients/internal/composeServiceApi.mjs';\nimport { defaultConfig, cognitoIdentityTransferHandler, buildHttpRpcRequest, getSharedHeaders } from './base.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst getCredentialsForIdentitySerializer = (input, endpoint) => {\n const headers = getSharedHeaders('GetCredentialsForIdentity');\n const body = JSON.stringify(input);\n return buildHttpRpcRequest(endpoint, headers, body);\n};\nconst getCredentialsForIdentityDeserializer = async (response) => {\n if (response.statusCode >= 300) {\n const error = await parseJsonError(response);\n throw error;\n }\n else {\n const body = await parseJsonBody(response);\n return {\n IdentityId: body.IdentityId,\n Credentials: deserializeCredentials(body.Credentials),\n $metadata: parseMetadata(response),\n };\n }\n};\nconst deserializeCredentials = ({ AccessKeyId, SecretKey, SessionToken, Expiration, } = {}) => {\n return {\n AccessKeyId,\n SecretKey,\n SessionToken,\n Expiration: Expiration && new Date(Expiration * 1000),\n };\n};\n/**\n * @internal\n */\nconst getCredentialsForIdentity = composeServiceApi(cognitoIdentityTransferHandler, getCredentialsForIdentitySerializer, getCredentialsForIdentityDeserializer, defaultConfig);\n\nexport { getCredentialsForIdentity };\n//# sourceMappingURL=getCredentialsForIdentity.mjs.map\n","import { AmplifyErrorCode } from '../types/errors.mjs';\nimport { AmplifyError } from './AmplifyError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nclass PlatformNotSupportedError extends AmplifyError {\n constructor() {\n super({\n name: AmplifyErrorCode.PlatformNotSupported,\n message: 'Function not supported on current platform',\n });\n }\n}\n\nexport { PlatformNotSupportedError };\n//# sourceMappingURL=PlatformNotSupportedError.mjs.map\n","import { PlatformNotSupportedError } from '../errors/PlatformNotSupportedError.mjs';\nimport '../errors/errorHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nclass KeyValueStorage {\n constructor(storage) {\n this.storage = storage;\n }\n /**\n * This is used to set a specific item in storage\n * @param {string} key - the key for the item\n * @param {object} value - the value\n * @returns {string} value that was set\n */\n async setItem(key, value) {\n if (!this.storage)\n throw new PlatformNotSupportedError();\n this.storage.setItem(key, value);\n }\n /**\n * This is used to get a specific key from storage\n * @param {string} key - the key for the item\n * This is used to clear the storage\n * @returns {string} the data item\n */\n async getItem(key) {\n if (!this.storage)\n throw new PlatformNotSupportedError();\n return this.storage.getItem(key);\n }\n /**\n * This is used to remove an item from storage\n * @param {string} key - the key being set\n * @returns {string} value - value that was deleted\n */\n async removeItem(key) {\n if (!this.storage)\n throw new PlatformNotSupportedError();\n this.storage.removeItem(key);\n }\n /**\n * This is used to clear the storage\n * @returns {string} nothing\n */\n async clear() {\n if (!this.storage)\n throw new PlatformNotSupportedError();\n this.storage.clear();\n }\n}\n\nexport { KeyValueStorage };\n//# sourceMappingURL=KeyValueStorage.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nclass InMemoryStorage {\n constructor() {\n this.storage = new Map();\n }\n get length() {\n return this.storage.size;\n }\n key(index) {\n if (index > this.length - 1) {\n return null;\n }\n return Array.from(this.storage.keys())[index];\n }\n setItem(key, value) {\n this.storage.set(key, value);\n }\n getItem(key) {\n return this.storage.get(key) ?? null;\n }\n removeItem(key) {\n this.storage.delete(key);\n }\n clear() {\n this.storage.clear();\n }\n}\n\nexport { InMemoryStorage };\n//# sourceMappingURL=InMemoryStorage.mjs.map\n","import { ConsoleLogger } from '../Logger/ConsoleLogger.mjs';\nimport { InMemoryStorage } from './InMemoryStorage.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n * @returns Either a reference to window.localStorage or an in-memory storage as fallback\n */\nconst logger = new ConsoleLogger('CoreStorageUtils');\nconst getLocalStorageWithFallback = () => {\n try {\n // Attempt to use localStorage directly\n if (typeof window !== 'undefined' && window.localStorage) {\n return window.localStorage;\n }\n }\n catch (e) {\n // Handle any errors related to localStorage access\n logger.info('localStorage not found. InMemoryStorage is used as a fallback.');\n }\n // Return in-memory storage as a fallback if localStorage is not accessible\n return new InMemoryStorage();\n};\n/**\n * @internal\n * @returns Either a reference to window.sessionStorage or an in-memory storage as fallback\n */\nconst getSessionStorageWithFallback = () => {\n try {\n // Attempt to use sessionStorage directly\n if (typeof window !== 'undefined' && window.sessionStorage) {\n // Verify we can actually use it by testing access\n window.sessionStorage.getItem('test');\n return window.sessionStorage;\n }\n throw new Error('sessionStorage is not defined');\n }\n catch (e) {\n // Handle any errors related to sessionStorage access\n logger.info('sessionStorage not found. InMemoryStorage is used as a fallback.');\n return new InMemoryStorage();\n }\n};\n\nexport { getLocalStorageWithFallback, getSessionStorageWithFallback };\n//# sourceMappingURL=utils.mjs.map\n","import { KeyValueStorage } from './KeyValueStorage.mjs';\nimport { getLocalStorageWithFallback } from './utils.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nclass DefaultStorage extends KeyValueStorage {\n constructor() {\n super(getLocalStorageWithFallback());\n }\n}\n\nexport { DefaultStorage };\n//# sourceMappingURL=DefaultStorage.mjs.map\n","import { KeyValueStorage } from './KeyValueStorage.mjs';\nimport { getSessionStorageWithFallback } from './utils.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nclass SessionStorage extends KeyValueStorage {\n constructor() {\n super(getSessionStorageWithFallback());\n }\n}\n\nexport { SessionStorage };\n//# sourceMappingURL=SessionStorage.mjs.map\n","import { PlatformNotSupportedError } from '../errors/PlatformNotSupportedError.mjs';\nimport '../errors/errorHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nclass SyncKeyValueStorage {\n constructor(storage) {\n this._storage = storage;\n }\n get storage() {\n if (!this._storage)\n throw new PlatformNotSupportedError();\n return this._storage;\n }\n /**\n * This is used to set a specific item in storage\n * @param {string} key - the key for the item\n * @param {object} value - the value\n * @returns {string} value that was set\n */\n setItem(key, value) {\n this.storage.setItem(key, value);\n }\n /**\n * This is used to get a specific key from storage\n * @param {string} key - the key for the item\n * This is used to clear the storage\n * @returns {string} the data item\n */\n getItem(key) {\n return this.storage.getItem(key);\n }\n /**\n * This is used to remove an item from storage\n * @param {string} key - the key being set\n * @returns {string} value - value that was deleted\n */\n removeItem(key) {\n this.storage.removeItem(key);\n }\n /**\n * This is used to clear the storage\n * @returns {string} nothing\n */\n clear() {\n this.storage.clear();\n }\n}\n\nexport { SyncKeyValueStorage };\n//# sourceMappingURL=SyncKeyValueStorage.mjs.map\n","import { SyncKeyValueStorage } from './SyncKeyValueStorage.mjs';\nimport { getSessionStorageWithFallback } from './utils.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nclass SyncSessionStorage extends SyncKeyValueStorage {\n constructor() {\n super(getSessionStorageWithFallback());\n }\n}\n\nexport { SyncSessionStorage };\n//# sourceMappingURL=SyncSessionStorage.mjs.map\n","/*! js-cookie v3.0.5 | MIT */\n/* eslint-disable no-var */\nfunction assign (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n target[key] = source[key];\n }\n }\n return target\n}\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\nvar defaultConverter = {\n read: function (value) {\n if (value[0] === '\"') {\n value = value.slice(1, -1);\n }\n return value.replace(/(%[\\dA-F]{2})+/gi, decodeURIComponent)\n },\n write: function (value) {\n return encodeURIComponent(value).replace(\n /%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,\n decodeURIComponent\n )\n }\n};\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\n\nfunction init (converter, defaultAttributes) {\n function set (name, value, attributes) {\n if (typeof document === 'undefined') {\n return\n }\n\n attributes = assign({}, defaultAttributes, attributes);\n\n if (typeof attributes.expires === 'number') {\n attributes.expires = new Date(Date.now() + attributes.expires * 864e5);\n }\n if (attributes.expires) {\n attributes.expires = attributes.expires.toUTCString();\n }\n\n name = encodeURIComponent(name)\n .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\n .replace(/[()]/g, escape);\n\n var stringifiedAttributes = '';\n for (var attributeName in attributes) {\n if (!attributes[attributeName]) {\n continue\n }\n\n stringifiedAttributes += '; ' + attributeName;\n\n if (attributes[attributeName] === true) {\n continue\n }\n\n // Considers RFC 6265 section 5.2:\n // ...\n // 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n // character:\n // Consume the characters of the unparsed-attributes up to,\n // not including, the first %x3B (\";\") character.\n // ...\n stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n }\n\n return (document.cookie =\n name + '=' + converter.write(value, name) + stringifiedAttributes)\n }\n\n function get (name) {\n if (typeof document === 'undefined' || (arguments.length && !name)) {\n return\n }\n\n // To prevent the for loop in the first place assign an empty array\n // in case there are no cookies at all.\n var cookies = document.cookie ? document.cookie.split('; ') : [];\n var jar = {};\n for (var i = 0; i < cookies.length; i++) {\n var parts = cookies[i].split('=');\n var value = parts.slice(1).join('=');\n\n try {\n var found = decodeURIComponent(parts[0]);\n jar[found] = converter.read(value, found);\n\n if (name === found) {\n break\n }\n } catch (e) {}\n }\n\n return name ? jar[name] : jar\n }\n\n return Object.create(\n {\n set,\n get,\n remove: function (name, attributes) {\n set(\n name,\n '',\n assign({}, attributes, {\n expires: -1\n })\n );\n },\n withAttributes: function (attributes) {\n return init(this.converter, assign({}, this.attributes, attributes))\n },\n withConverter: function (converter) {\n return init(assign({}, this.converter, converter), this.attributes)\n }\n },\n {\n attributes: { value: Object.freeze(defaultAttributes) },\n converter: { value: Object.freeze(converter) }\n }\n )\n}\n\nvar api = init(defaultConverter, { path: '/' });\n/* eslint-enable no-var */\n\nexport { api as default };\n","import JsCookie from 'js-cookie';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nclass CookieStorage {\n constructor(data = {}) {\n const { path, domain, expires, sameSite, secure } = data;\n this.domain = domain;\n this.path = path || '/';\n this.expires = Object.prototype.hasOwnProperty.call(data, 'expires')\n ? expires\n : 365;\n this.secure = Object.prototype.hasOwnProperty.call(data, 'secure')\n ? secure\n : true;\n if (Object.prototype.hasOwnProperty.call(data, 'sameSite')) {\n if (!sameSite || !['strict', 'lax', 'none'].includes(sameSite)) {\n throw new Error('The sameSite value of cookieStorage must be \"lax\", \"strict\" or \"none\".');\n }\n if (sameSite === 'none' && !this.secure) {\n throw new Error('sameSite = None requires the Secure attribute in latest browser versions.');\n }\n this.sameSite = sameSite;\n }\n }\n async setItem(key, value) {\n JsCookie.set(key, value, this.getData());\n }\n async getItem(key) {\n const item = JsCookie.get(key);\n return item ?? null;\n }\n async removeItem(key) {\n JsCookie.remove(key, this.getData());\n }\n async clear() {\n const cookie = JsCookie.get();\n const promises = Object.keys(cookie).map(key => this.removeItem(key));\n await Promise.all(promises);\n }\n getData() {\n return {\n path: this.path,\n expires: this.expires,\n domain: this.domain,\n secure: this.secure,\n ...(this.sameSite && { sameSite: this.sameSite }),\n };\n }\n}\n\nexport { CookieStorage };\n//# sourceMappingURL=CookieStorage.mjs.map\n","import { DefaultStorage } from './DefaultStorage.mjs';\nimport { InMemoryStorage } from './InMemoryStorage.mjs';\nimport { KeyValueStorage } from './KeyValueStorage.mjs';\nimport { SessionStorage } from './SessionStorage.mjs';\nimport { SyncSessionStorage } from './SyncSessionStorage.mjs';\nexport { CookieStorage } from './CookieStorage.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst defaultStorage = new DefaultStorage();\nconst sessionStorage = new SessionStorage();\nconst syncSessionStorage = new SyncSessionStorage();\nconst sharedInMemoryStorage = new KeyValueStorage(new InMemoryStorage());\n\nexport { defaultStorage, sessionStorage, sharedInMemoryStorage, syncSessionStorage };\n//# sourceMappingURL=index.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns signed headers.\n *\n * @param headers `headers` from the request.\n * @returns List of headers included in canonical headers, separated by semicolons (;). This indicates which headers\n * are part of the signing process. Header names must use lowercase characters and must appear in alphabetical order.\n *\n * @internal\n */\nconst getSignedHeaders = (headers) => Object.keys(headers)\n .map(key => key.toLowerCase())\n .sort()\n .join(';');\n\nexport { getSignedHeaders };\n//# sourceMappingURL=getSignedHeaders.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// query params\nconst ALGORITHM_QUERY_PARAM = 'X-Amz-Algorithm';\nconst AMZ_DATE_QUERY_PARAM = 'X-Amz-Date';\nconst CREDENTIAL_QUERY_PARAM = 'X-Amz-Credential';\nconst EXPIRES_QUERY_PARAM = 'X-Amz-Expires';\nconst REGION_SET_PARAM = 'X-Amz-Region-Set';\nconst SIGNATURE_QUERY_PARAM = 'X-Amz-Signature';\nconst SIGNED_HEADERS_QUERY_PARAM = 'X-Amz-SignedHeaders';\nconst TOKEN_QUERY_PARAM = 'X-Amz-Security-Token';\n// headers\nconst AUTH_HEADER = 'authorization';\nconst HOST_HEADER = 'host';\nconst AMZ_DATE_HEADER = AMZ_DATE_QUERY_PARAM.toLowerCase();\nconst TOKEN_HEADER = TOKEN_QUERY_PARAM.toLowerCase();\n// identifiers\nconst KEY_TYPE_IDENTIFIER = 'aws4_request';\nconst SHA256_ALGORITHM_IDENTIFIER = 'AWS4-HMAC-SHA256';\nconst SIGNATURE_IDENTIFIER = 'AWS4';\n// preset values\nconst EMPTY_HASH = 'e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855';\nconst UNSIGNED_PAYLOAD = 'UNSIGNED-PAYLOAD';\n\nexport { ALGORITHM_QUERY_PARAM, AMZ_DATE_HEADER, AMZ_DATE_QUERY_PARAM, AUTH_HEADER, CREDENTIAL_QUERY_PARAM, EMPTY_HASH, EXPIRES_QUERY_PARAM, HOST_HEADER, KEY_TYPE_IDENTIFIER, REGION_SET_PARAM, SHA256_ALGORITHM_IDENTIFIER, SIGNATURE_IDENTIFIER, SIGNATURE_QUERY_PARAM, SIGNED_HEADERS_QUERY_PARAM, TOKEN_HEADER, TOKEN_QUERY_PARAM, UNSIGNED_PAYLOAD };\n//# sourceMappingURL=constants.mjs.map\n","import { KEY_TYPE_IDENTIFIER } from '../constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns the credential scope which restricts the resulting signature to the specified region and service.\n *\n * @param date Current date in the format 'YYYYMMDD'.\n * @param region AWS region in which the service resides.\n * @param service Service to which the signed request is being sent.\n *\n * @returns A string representing the credential scope with format 'YYYYMMDD/region/service/aws4_request'.\n *\n * @internal\n */\nconst getCredentialScope = (date, region, service) => `${date}/${region}/${service}/${KEY_TYPE_IDENTIFIER}`;\n\nexport { getCredentialScope };\n//# sourceMappingURL=getCredentialScope.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns expected date strings to be used in signing.\n *\n * @param date JavaScript `Date` object.\n * @returns `FormattedDates` object containing the following:\n * - longDate: A date string in 'YYYYMMDDThhmmssZ' format\n * - shortDate: A date string in 'YYYYMMDD' format\n *\n * @internal\n */\nconst getFormattedDates = (date) => {\n const longDate = date.toISOString().replace(/[:-]|\\.\\d{3}/g, '');\n return {\n longDate,\n shortDate: longDate.slice(0, 8),\n };\n};\n\nexport { getFormattedDates };\n//# sourceMappingURL=getFormattedDates.mjs.map\n","import { getCredentialScope } from './getCredentialScope.mjs';\nimport { getFormattedDates } from './getFormattedDates.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Extracts common values used for signing both requests and urls.\n *\n * @param options `SignRequestOptions` object containing values used to construct the signature.\n * @returns Common `SigningValues` used for signing.\n *\n * @internal\n */\nconst getSigningValues = ({ credentials, signingDate = new Date(), signingRegion, signingService, uriEscapePath = true, }) => {\n // get properties from credentials\n const { accessKeyId, secretAccessKey, sessionToken } = credentials;\n // get formatted dates for signing\n const { longDate, shortDate } = getFormattedDates(signingDate);\n // copy header and set signing properties\n const credentialScope = getCredentialScope(shortDate, signingRegion, signingService);\n return {\n accessKeyId,\n credentialScope,\n longDate,\n secretAccessKey,\n sessionToken,\n shortDate,\n signingRegion,\n signingService,\n uriEscapePath,\n };\n};\n\nexport { getSigningValues };\n//# sourceMappingURL=getSigningValues.mjs.map\n","import { Sha256 } from '@aws-crypto/sha256-js';\nimport { toHex } from '@smithy/util-hex-encoding';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// TODO: V6 update to different crypto dependency?\n/**\n * Returns the hashed data a `Uint8Array`.\n *\n * @param key `SourceData` to be used as hashing key.\n * @param data Hashable `SourceData`.\n * @returns `Uint8Array` created from the data as input to a hash function.\n */\nconst getHashedData = (key, data) => {\n const sha256 = new Sha256(key ?? undefined);\n sha256.update(data);\n // TODO: V6 flip to async digest\n const hashedData = sha256.digestSync();\n return hashedData;\n};\n/**\n * Returns the hashed data as a hex string.\n *\n * @param key `SourceData` to be used as hashing key.\n * @param data Hashable `SourceData`.\n * @returns String using lowercase hexadecimal characters created from the data as input to a hash function.\n *\n * @internal\n */\nconst getHashedDataAsHex = (key, data) => {\n const hashedData = getHashedData(key, data);\n return toHex(hashedData);\n};\n\nexport { getHashedData, getHashedDataAsHex };\n//# sourceMappingURL=dataHashHelpers.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns canonical headers.\n *\n * @param headers Headers from the request.\n * @returns Request headers that will be signed, and their values, separated by newline characters. Header names must\n * use lowercase characters, must appear in alphabetical order, and must be followed by a colon (:). For the values,\n * trim any leading or trailing spaces, convert sequential spaces to a single space, and separate the values\n * for a multi-value header using commas.\n *\n * @internal\n */\nconst getCanonicalHeaders = (headers) => Object.entries(headers)\n .map(([key, value]) => ({\n key: key.toLowerCase(),\n value: value?.trim().replace(/\\s+/g, ' ') ?? '',\n}))\n .sort((a, b) => (a.key < b.key ? -1 : 1))\n .map(entry => `${entry.key}:${entry.value}\\n`)\n .join('');\n\nexport { getCanonicalHeaders };\n//# sourceMappingURL=getCanonicalHeaders.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a canonical query string.\n *\n * @param searchParams `searchParams` from the request url.\n * @returns URL-encoded query string parameters, separated by ampersands (&). Percent-encode reserved characters,\n * including the space character. Encode names and values separately. If there are empty parameters, append the equals\n * sign to the parameter name before encoding. After encoding, sort the parameters alphabetically by key name. If there\n * is no query string, use an empty string (\"\").\n *\n * @internal\n */\nconst getCanonicalQueryString = (searchParams) => Array.from(searchParams)\n .sort(([keyA, valA], [keyB, valB]) => {\n if (keyA === keyB) {\n return valA < valB ? -1 : 1;\n }\n return keyA < keyB ? -1 : 1;\n})\n .map(([key, val]) => `${escapeUri(key)}=${escapeUri(val)}`)\n .join('&');\nconst escapeUri = (uri) => encodeURIComponent(uri).replace(/[!'()*]/g, hexEncode);\nconst hexEncode = (c) => `%${c.charCodeAt(0).toString(16).toUpperCase()}`;\n\nexport { getCanonicalQueryString };\n//# sourceMappingURL=getCanonicalQueryString.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a canonical uri.\n *\n * @param pathname `pathname` from request url.\n * @param uriEscapePath Whether to uri encode the path as part of canonical uri. It's used for S3 only where the\n * pathname is already uri encoded, and the signing process is not expected to uri encode it again. Defaults to true.\n * @returns URI-encoded version of the absolute path component URL (everything between the host and the question mark\n * character (?) that starts the query string parameters). If the absolute path is empty, a forward slash character (/).\n *\n * @internal\n */\nconst getCanonicalUri = (pathname, uriEscapePath = true) => pathname\n ? uriEscapePath\n ? encodeURIComponent(pathname).replace(/%2F/g, '/')\n : pathname\n : '/';\n\nexport { getCanonicalUri };\n//# sourceMappingURL=getCanonicalUri.mjs.map\n","import { EMPTY_HASH, UNSIGNED_PAYLOAD } from '../constants.mjs';\nimport { getHashedDataAsHex } from './dataHashHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns the hashed payload.\n *\n * @param body `body` (payload) from the request.\n * @returns String created using the payload in the body of the HTTP request as input to a hash function. This string\n * uses lowercase hexadecimal characters. If the payload is empty, return precalculated result of an empty hash.\n *\n * @internal\n */\nconst getHashedPayload = (body) => {\n // return precalculated empty hash if body is undefined or null\n if (body == null) {\n return EMPTY_HASH;\n }\n if (isSourceData(body)) {\n const hashedData = getHashedDataAsHex(null, body);\n return hashedData;\n }\n // Defined body is not signable. Return unsigned payload which may or may not be accepted by the service.\n return UNSIGNED_PAYLOAD;\n};\nconst isSourceData = (body) => typeof body === 'string' || ArrayBuffer.isView(body) || isArrayBuffer(body);\nconst isArrayBuffer = (arg) => (typeof ArrayBuffer === 'function' && arg instanceof ArrayBuffer) ||\n Object.prototype.toString.call(arg) === '[object ArrayBuffer]';\n\nexport { getHashedPayload };\n//# sourceMappingURL=getHashedPayload.mjs.map\n","import { getCanonicalHeaders } from './getCanonicalHeaders.mjs';\nimport { getCanonicalQueryString } from './getCanonicalQueryString.mjs';\nimport { getCanonicalUri } from './getCanonicalUri.mjs';\nimport { getHashedPayload } from './getHashedPayload.mjs';\nimport { getSignedHeaders } from './getSignedHeaders.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a canonical request.\n *\n * @param request `HttpRequest` from which to create the canonical request from.\n * @param uriEscapePath Whether to uri encode the path as part of canonical uri. It's used for S3 only where the\n * pathname is already uri encoded, and the signing process is not expected to uri encode it again. Defaults to true.\n * @returns String created by by concatenating the following strings, separated by newline characters:\n * - HTTPMethod\n * - CanonicalUri\n * - CanonicalQueryString\n * - CanonicalHeaders\n * - SignedHeaders\n * - HashedPayload\n *\n * @internal\n */\nconst getCanonicalRequest = ({ body, headers, method, url }, uriEscapePath = true) => [\n method,\n getCanonicalUri(url.pathname, uriEscapePath),\n getCanonicalQueryString(url.searchParams),\n getCanonicalHeaders(headers),\n getSignedHeaders(headers),\n getHashedPayload(body),\n].join('\\n');\n\nexport { getCanonicalRequest };\n//# sourceMappingURL=getCanonicalRequest.mjs.map\n","import { KEY_TYPE_IDENTIFIER, SIGNATURE_IDENTIFIER } from '../constants.mjs';\nimport { getHashedData } from './dataHashHelpers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a signing key to be used for signing requests.\n *\n * @param secretAccessKey AWS secret access key from credentials.\n * @param date Current date in the format 'YYYYMMDD'.\n * @param region AWS region in which the service resides.\n * @param service Service to which the signed request is being sent.\n *\n * @returns `Uint8Array` calculated from its composite parts.\n *\n * @internal\n */\nconst getSigningKey = (secretAccessKey, date, region, service) => {\n const key = `${SIGNATURE_IDENTIFIER}${secretAccessKey}`;\n const dateKey = getHashedData(key, date);\n const regionKey = getHashedData(dateKey, region);\n const serviceKey = getHashedData(regionKey, service);\n const signingKey = getHashedData(serviceKey, KEY_TYPE_IDENTIFIER);\n return signingKey;\n};\n\nexport { getSigningKey };\n//# sourceMappingURL=getSigningKey.mjs.map\n","import { SHA256_ALGORITHM_IDENTIFIER } from '../constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a string to be signed.\n *\n * @param date Current date in the format 'YYYYMMDDThhmmssZ'.\n * @param credentialScope String representing the credential scope with format 'YYYYMMDD/region/service/aws4_request'.\n * @param hashedRequest Hashed canonical request.\n *\n * @returns A string created by by concatenating the following strings, separated by newline characters:\n * - Algorithm\n * - RequestDateTime\n * - CredentialScope\n * - HashedCanonicalRequest\n *\n * @internal\n */\nconst getStringToSign = (date, credentialScope, hashedRequest) => [SHA256_ALGORITHM_IDENTIFIER, date, credentialScope, hashedRequest].join('\\n');\n\nexport { getStringToSign };\n//# sourceMappingURL=getStringToSign.mjs.map\n","import { getHashedDataAsHex } from './dataHashHelpers.mjs';\nimport { getCanonicalRequest } from './getCanonicalRequest.mjs';\nimport { getSigningKey } from './getSigningKey.mjs';\nimport { getStringToSign } from './getStringToSign.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Calculates and returns an AWS API Signature.\n * https://docs.aws.amazon.com/IAM/latest/UserGuide/create-signed-request.html\n *\n * @param request `HttpRequest` to be signed.\n * @param signRequestOptions `SignRequestOptions` object containing values used to construct the signature.\n * @returns AWS API Signature to sign a request or url with.\n *\n * @internal\n */\nconst getSignature = (request, { credentialScope, longDate, secretAccessKey, shortDate, signingRegion, signingService, uriEscapePath, }) => {\n // step 1: create a canonical request\n const canonicalRequest = getCanonicalRequest(request, uriEscapePath);\n // step 2: create a hash of the canonical request\n const hashedRequest = getHashedDataAsHex(null, canonicalRequest);\n // step 3: create a string to sign\n const stringToSign = getStringToSign(longDate, credentialScope, hashedRequest);\n // step 4: calculate the signature\n const signature = getHashedDataAsHex(getSigningKey(secretAccessKey, shortDate, signingRegion, signingService), stringToSign);\n return signature;\n};\n\nexport { getSignature };\n//# sourceMappingURL=getSignature.mjs.map\n","import { getSignedHeaders } from './utils/getSignedHeaders.mjs';\nimport { getSigningValues } from './utils/getSigningValues.mjs';\nimport { HOST_HEADER, AMZ_DATE_HEADER, TOKEN_HEADER, SHA256_ALGORITHM_IDENTIFIER, AUTH_HEADER } from './constants.mjs';\nimport { getSignature } from './utils/getSignature.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Given a `HttpRequest`, returns a Signature Version 4 signed `HttpRequest`.\n *\n * @param request `HttpRequest` to be signed.\n * @param signRequestOptions `SignRequestOptions` object containing values used to construct the signature.\n * @returns A `HttpRequest` with authentication headers which can grant temporary access to AWS resources.\n */\nconst signRequest = (request, options) => {\n const signingValues = getSigningValues(options);\n const { accessKeyId, credentialScope, longDate, sessionToken } = signingValues;\n // create the request to sign\n const headers = { ...request.headers };\n headers[HOST_HEADER] = request.url.host;\n headers[AMZ_DATE_HEADER] = longDate;\n if (sessionToken) {\n headers[TOKEN_HEADER] = sessionToken;\n }\n const requestToSign = { ...request, headers };\n // calculate and add the signature to the request\n const signature = getSignature(requestToSign, signingValues);\n const credentialEntry = `Credential=${accessKeyId}/${credentialScope}`;\n const signedHeadersEntry = `SignedHeaders=${getSignedHeaders(headers)}`;\n const signatureEntry = `Signature=${signature}`;\n headers[AUTH_HEADER] =\n `${SHA256_ALGORITHM_IDENTIFIER} ${credentialEntry}, ${signedHeadersEntry}, ${signatureEntry}`;\n return requestToSign;\n};\n\nexport { signRequest };\n//# sourceMappingURL=signRequest.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a `Date` that is corrected for clock skew.\n *\n * @param systemClockOffset The offset of the system clock in milliseconds.\n *\n * @returns `Date` representing the current time adjusted by the system clock offset.\n *\n * @internal\n */\nconst getSkewCorrectedDate = (systemClockOffset) => new Date(Date.now() + systemClockOffset);\n\nexport { getSkewCorrectedDate };\n//# sourceMappingURL=getSkewCorrectedDate.mjs.map\n","import { getSkewCorrectedDate } from './getSkewCorrectedDate.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// 5 mins in milliseconds. Ref: https://github.com/aws/aws-sdk-js-v3/blob/6c0f44fab30a1bb2134af47362a31332abc3666b/packages/middleware-signing/src/utils/isClockSkewed.ts#L10\nconst SKEW_WINDOW = 5 * 60 * 1000;\n/**\n * Checks if the provided date is within the skew window of 5 minutes.\n *\n * @param clockTimeInMilliseconds Time to check for skew in milliseconds.\n * @param clockOffsetInMilliseconds Offset to check clock against in milliseconds.\n *\n * @returns True if skewed. False otherwise.\n *\n * @internal\n */\nconst isClockSkewed = (clockTimeInMilliseconds, clockOffsetInMilliseconds) => Math.abs(getSkewCorrectedDate(clockOffsetInMilliseconds).getTime() -\n clockTimeInMilliseconds) >= SKEW_WINDOW;\n\nexport { isClockSkewed };\n//# sourceMappingURL=isClockSkewed.mjs.map\n","import { isClockSkewed } from './isClockSkewed.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns the difference between clock time and the current system time if clock is skewed.\n *\n * @param clockTimeInMilliseconds Clock time in milliseconds.\n * @param currentSystemClockOffset Current system clock offset in milliseconds.\n *\n * @internal\n */\nconst getUpdatedSystemClockOffset = (clockTimeInMilliseconds, currentSystemClockOffset) => {\n if (isClockSkewed(clockTimeInMilliseconds, currentSystemClockOffset)) {\n return clockTimeInMilliseconds - Date.now();\n }\n return currentSystemClockOffset;\n};\n\nexport { getUpdatedSystemClockOffset };\n//# sourceMappingURL=getUpdatedSystemClockOffset.mjs.map\n","import { signRequest } from './signer/signatureV4/signRequest.mjs';\nimport '@aws-crypto/sha256-js';\nimport '@smithy/util-hex-encoding';\nimport { getSkewCorrectedDate } from './utils/getSkewCorrectedDate.mjs';\nimport { getUpdatedSystemClockOffset } from './utils/getUpdatedSystemClockOffset.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Middleware that SigV4 signs request with AWS credentials, and correct system clock offset.\n * This middleware is expected to be placed after retry middleware.\n */\nconst signingMiddlewareFactory = ({ credentials, region, service, uriEscapePath = true, }) => {\n let currentSystemClockOffset;\n return (next, context) => async function signingMiddleware(request) {\n currentSystemClockOffset = currentSystemClockOffset ?? 0;\n const signRequestOptions = {\n credentials: typeof credentials === 'function'\n ? await credentials({\n forceRefresh: !!context?.isCredentialsExpired,\n })\n : credentials,\n signingDate: getSkewCorrectedDate(currentSystemClockOffset),\n signingRegion: region,\n signingService: service,\n uriEscapePath,\n };\n const signedRequest = await signRequest(request, signRequestOptions);\n const response = await next(signedRequest);\n // Update system clock offset if response contains date header, regardless of the status code.\n // non-2xx response will still be returned from next handler instead of thrown, because it's\n // only thrown by the retry middleware.\n const dateString = getDateHeader(response);\n if (dateString) {\n currentSystemClockOffset = getUpdatedSystemClockOffset(Date.parse(dateString), currentSystemClockOffset);\n }\n return response;\n };\n};\nconst getDateHeader = ({ headers } = {}) => headers?.date ?? headers?.Date ?? headers?.['x-amz-date'];\n\nexport { signingMiddlewareFactory };\n//# sourceMappingURL=middleware.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Wraps encodeURIComponent to encode additional characters to fully adhere to RFC 3986.\n * @see https://github.com/aws/aws-sdk-js-v3/blob/86b432c464150069678b25ff88d57c2ca26e75a2/packages/smithy-client/src/extended-encode-uri-component.ts#L7\n *\n * @param uri URI string to encode\n * @returns RFC 3986 encoded string\n *\n * @internal\n */\nconst extendedEncodeURIComponent = (uri) => {\n // Match characters normally not encoded by `encodeURIComponent`\n const extendedCharacters = /[!'()*]/g;\n return encodeURIComponent(uri).replace(extendedCharacters, hexEncode);\n};\nconst hexEncode = (c) => `%${c.charCodeAt(0).toString(16).toUpperCase()}`;\n\nexport { extendedEncodeURIComponent };\n//# sourceMappingURL=extendedEncodeURIComponent.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * returns in-flight promise if there is one\n *\n * @param asyncFunction - asyncFunction to be deduped.\n * @returns - the return type of the callback\n */\nconst deDupeAsyncFunction = (asyncFunction) => {\n let inflightPromise;\n return async (...args) => {\n if (inflightPromise)\n return inflightPromise;\n inflightPromise = new Promise((resolve, reject) => {\n asyncFunction(...args)\n .then(result => {\n resolve(result);\n })\n .catch(error => {\n reject(error);\n })\n .finally(() => {\n inflightPromise = undefined;\n });\n });\n return inflightPromise;\n };\n};\n\nexport { deDupeAsyncFunction };\n//# sourceMappingURL=deDupeAsyncFunction.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction isTokenExpired({ expiresAt, clockDrift, tolerance = 5000, }) {\n const currentTime = Date.now();\n return currentTime + clockDrift + tolerance > expiresAt;\n}\n\nexport { isTokenExpired };\n//# sourceMappingURL=isTokenExpired.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Retrieves the device name using the User-Agent Client Hints API if available,\n * falling back to the traditional userAgent string if not.\n *\n * @returns {Promise} A promise that resolves with a string representing the device name.\n *\n * Example Output:\n * navigator.userAgentData:\n * 'macOS 14.2.1 arm macOS Not A(Brand/99.0.0.0;Google Chrome/121.0.6167.160;Chromium/121.0.6167.160'\n * navigator.userAgent:\n * 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:109.0) Gecko/20100101 Firefox/115.0'\n */\nconst getDeviceName = async () => {\n const { userAgentData } = navigator;\n if (!userAgentData)\n return navigator.userAgent;\n const { platform = '', platformVersion = '', model = '', architecture = '', fullVersionList = [], } = await userAgentData.getHighEntropyValues([\n 'platform',\n 'platformVersion',\n 'architecture',\n 'model',\n 'fullVersionList',\n ]);\n const versionList = fullVersionList\n .map((v) => `${v.brand}/${v.version}`)\n .join(';');\n const deviceName = [\n platform,\n platformVersion,\n architecture,\n model,\n platform,\n versionList,\n ]\n .filter(value => value)\n .join(' ');\n return deviceName || navigator.userAgent;\n};\n\nexport { getDeviceName };\n//# sourceMappingURL=getDeviceName.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction bytesToString(input) {\n return Array.from(input, byte => String.fromCodePoint(byte)).join('');\n}\n\nexport { bytesToString };\n//# sourceMappingURL=bytesToString.mjs.map\n","import { getBtoa } from '../../globalHelpers/index.mjs';\nimport { bytesToString } from './bytesToString.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst base64Encoder = {\n /**\n * Convert input to base64-encoded string\n * @param input - string to convert to base64\n * @param options - encoding options that can optionally produce a base64url string\n * @returns base64-encoded string\n */\n convert(input, options = {\n urlSafe: false,\n skipPadding: false,\n }) {\n const inputStr = typeof input === 'string' ? input : bytesToString(input);\n let encodedStr = getBtoa()(inputStr);\n // urlSafe char replacement and skipPadding options conform to the base64url spec\n // https://datatracker.ietf.org/doc/html/rfc4648#section-5\n if (options.urlSafe) {\n encodedStr = encodedStr.replace(/\\+/g, '-').replace(/\\//g, '_');\n }\n if (options.skipPadding) {\n encodedStr = encodedStr.replace(/=/g, '');\n }\n return encodedStr;\n },\n};\n\nexport { base64Encoder };\n//# sourceMappingURL=base64Encoder.mjs.map\n","import { getCrypto } from './globalHelpers/index.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/*\n * Cryptographically secure pseudorandom number generator\n * As Math.random() is cryptographically not safe to use\n */\nfunction cryptoSecureRandomInt() {\n const crypto = getCrypto();\n const randomResult = crypto.getRandomValues(new Uint32Array(1))[0];\n return randomResult;\n}\n\nexport { cryptoSecureRandomInt };\n//# sourceMappingURL=cryptoSecureRandomInt.mjs.map\n","import { cryptoSecureRandomInt } from './cryptoSecureRandomInt.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Hex encoding strategy.\n * Converts a word array to a hex string.\n * @param {WordArray} wordArray The word array.\n * @return {string} The hex string.\n * @static\n */\nfunction hexStringify(wordArray) {\n // Shortcuts\n const { words } = wordArray;\n const { sigBytes } = wordArray;\n // Convert\n const hexChars = [];\n for (let i = 0; i < sigBytes; i++) {\n const bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n hexChars.push((bite >>> 4).toString(16));\n hexChars.push((bite & 0x0f).toString(16));\n }\n return hexChars.join('');\n}\nclass WordArray {\n constructor(words, sigBytes) {\n this.words = [];\n let Words = words;\n Words = this.words = Words || [];\n if (sigBytes !== undefined) {\n this.sigBytes = sigBytes;\n }\n else {\n this.sigBytes = Words.length * 4;\n }\n }\n random(nBytes) {\n const words = [];\n for (let i = 0; i < nBytes; i += 4) {\n words.push(cryptoSecureRandomInt());\n }\n return new WordArray(words, nBytes);\n }\n toString() {\n return hexStringify(this);\n }\n}\n\nexport { WordArray };\n//# sourceMappingURL=WordArray.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nvar AuthValidationErrorCode;\n(function (AuthValidationErrorCode) {\n AuthValidationErrorCode[\"EmptySignInUsername\"] = \"EmptySignInUsername\";\n AuthValidationErrorCode[\"EmptySignInPassword\"] = \"EmptySignInPassword\";\n AuthValidationErrorCode[\"CustomAuthSignInPassword\"] = \"CustomAuthSignInPassword\";\n AuthValidationErrorCode[\"EmptySignUpUsername\"] = \"EmptySignUpUsername\";\n AuthValidationErrorCode[\"EmptySignUpPassword\"] = \"EmptySignUpPassword\";\n AuthValidationErrorCode[\"EmptyConfirmSignUpUsername\"] = \"EmptyConfirmSignUpUsername\";\n AuthValidationErrorCode[\"EmptyConfirmSignUpCode\"] = \"EmptyConfirmSignUpCode\";\n AuthValidationErrorCode[\"EmptyResendSignUpCodeUsername\"] = \"EmptyresendSignUpCodeUsername\";\n AuthValidationErrorCode[\"EmptyChallengeResponse\"] = \"EmptyChallengeResponse\";\n AuthValidationErrorCode[\"EmptyConfirmResetPasswordUsername\"] = \"EmptyConfirmResetPasswordUsername\";\n AuthValidationErrorCode[\"EmptyConfirmResetPasswordNewPassword\"] = \"EmptyConfirmResetPasswordNewPassword\";\n AuthValidationErrorCode[\"EmptyConfirmResetPasswordConfirmationCode\"] = \"EmptyConfirmResetPasswordConfirmationCode\";\n AuthValidationErrorCode[\"EmptyResetPasswordUsername\"] = \"EmptyResetPasswordUsername\";\n AuthValidationErrorCode[\"EmptyVerifyTOTPSetupCode\"] = \"EmptyVerifyTOTPSetupCode\";\n AuthValidationErrorCode[\"EmptyConfirmUserAttributeCode\"] = \"EmptyConfirmUserAttributeCode\";\n AuthValidationErrorCode[\"IncorrectMFAMethod\"] = \"IncorrectMFAMethod\";\n AuthValidationErrorCode[\"EmptyUpdatePassword\"] = \"EmptyUpdatePassword\";\n})(AuthValidationErrorCode || (AuthValidationErrorCode = {}));\n\nexport { AuthValidationErrorCode };\n//# sourceMappingURL=validation.mjs.map\n","import { AuthValidationErrorCode } from '../errors/types/validation.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst validationErrorMap = {\n [AuthValidationErrorCode.EmptyChallengeResponse]: {\n message: 'challengeResponse is required to confirmSignIn',\n },\n [AuthValidationErrorCode.EmptyConfirmResetPasswordUsername]: {\n message: 'username is required to confirmResetPassword',\n },\n [AuthValidationErrorCode.EmptyConfirmSignUpCode]: {\n message: 'code is required to confirmSignUp',\n },\n [AuthValidationErrorCode.EmptyConfirmSignUpUsername]: {\n message: 'username is required to confirmSignUp',\n },\n [AuthValidationErrorCode.EmptyConfirmResetPasswordConfirmationCode]: {\n message: 'confirmationCode is required to confirmResetPassword',\n },\n [AuthValidationErrorCode.EmptyConfirmResetPasswordNewPassword]: {\n message: 'newPassword is required to confirmResetPassword',\n },\n [AuthValidationErrorCode.EmptyResendSignUpCodeUsername]: {\n message: 'username is required to confirmSignUp',\n },\n [AuthValidationErrorCode.EmptyResetPasswordUsername]: {\n message: 'username is required to resetPassword',\n },\n [AuthValidationErrorCode.EmptySignInPassword]: {\n message: 'password is required to signIn',\n },\n [AuthValidationErrorCode.EmptySignInUsername]: {\n message: 'username is required to signIn',\n },\n [AuthValidationErrorCode.EmptySignUpPassword]: {\n message: 'password is required to signUp',\n },\n [AuthValidationErrorCode.EmptySignUpUsername]: {\n message: 'username is required to signUp',\n },\n [AuthValidationErrorCode.CustomAuthSignInPassword]: {\n message: 'A password is not needed when signing in with CUSTOM_WITHOUT_SRP',\n recoverySuggestion: 'Do not include a password in your signIn call.',\n },\n [AuthValidationErrorCode.IncorrectMFAMethod]: {\n message: 'Incorrect MFA method was chosen. It should be either SMS, TOTP, or EMAIL',\n recoverySuggestion: 'Try to pass SMS, TOTP, or EMAIL as the challengeResponse',\n },\n [AuthValidationErrorCode.EmptyVerifyTOTPSetupCode]: {\n message: 'code is required to verifyTotpSetup',\n },\n [AuthValidationErrorCode.EmptyUpdatePassword]: {\n message: 'oldPassword and newPassword are required to changePassword',\n },\n [AuthValidationErrorCode.EmptyConfirmUserAttributeCode]: {\n message: 'confirmation code is required to confirmUserAttribute',\n },\n};\n// TODO: delete this code when the Auth class is removed.\nvar AuthErrorStrings;\n(function (AuthErrorStrings) {\n AuthErrorStrings[\"DEFAULT_MSG\"] = \"Authentication Error\";\n AuthErrorStrings[\"EMPTY_EMAIL\"] = \"Email cannot be empty\";\n AuthErrorStrings[\"EMPTY_PHONE\"] = \"Phone number cannot be empty\";\n AuthErrorStrings[\"EMPTY_USERNAME\"] = \"Username cannot be empty\";\n AuthErrorStrings[\"INVALID_USERNAME\"] = \"The username should either be a string or one of the sign in types\";\n AuthErrorStrings[\"EMPTY_PASSWORD\"] = \"Password cannot be empty\";\n AuthErrorStrings[\"EMPTY_CODE\"] = \"Confirmation code cannot be empty\";\n AuthErrorStrings[\"SIGN_UP_ERROR\"] = \"Error creating account\";\n AuthErrorStrings[\"NO_MFA\"] = \"No valid MFA method provided\";\n AuthErrorStrings[\"INVALID_MFA\"] = \"Invalid MFA type\";\n AuthErrorStrings[\"EMPTY_CHALLENGE\"] = \"Challenge response cannot be empty\";\n AuthErrorStrings[\"NO_USER_SESSION\"] = \"Failed to get the session because the user is empty\";\n AuthErrorStrings[\"NETWORK_ERROR\"] = \"Network Error\";\n AuthErrorStrings[\"DEVICE_CONFIG\"] = \"Device tracking has not been configured in this User Pool\";\n AuthErrorStrings[\"AUTOSIGNIN_ERROR\"] = \"Please use your credentials to sign in\";\n AuthErrorStrings[\"OAUTH_ERROR\"] = \"Couldn't finish OAuth flow, check your User Pool HostedUI settings\";\n})(AuthErrorStrings || (AuthErrorStrings = {}));\nvar AuthErrorCodes;\n(function (AuthErrorCodes) {\n AuthErrorCodes[\"SignInException\"] = \"SignInException\";\n AuthErrorCodes[\"OAuthSignInError\"] = \"OAuthSignInException\";\n})(AuthErrorCodes || (AuthErrorCodes = {}));\n\nexport { AuthErrorCodes, AuthErrorStrings, validationErrorMap };\n//# sourceMappingURL=AuthErrorStrings.mjs.map\n","import { AmplifyError } from '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nclass AuthError extends AmplifyError {\n constructor(params) {\n super(params);\n // Hack for making the custom error class work when transpiled to es5\n // TODO: Delete the following 2 lines after we change the build target to >= es2015\n this.constructor = AuthError;\n Object.setPrototypeOf(this, AuthError.prototype);\n }\n}\n\nexport { AuthError };\n//# sourceMappingURL=AuthError.mjs.map\n","import { validationErrorMap } from '../../common/AuthErrorStrings.mjs';\nimport { AuthError } from '../AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction assertValidationError(assertion, name) {\n const { message, recoverySuggestion } = validationErrorMap[name];\n if (!assertion) {\n throw new AuthError({ name, message, recoverySuggestion });\n }\n}\n\nexport { assertValidationError };\n//# sourceMappingURL=assertValidationError.mjs.map\n","import { AuthError } from '../../errors/AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction getRegionFromUserPoolId(userPoolId) {\n const region = userPoolId?.split('_')[0];\n if (!userPoolId ||\n userPoolId.indexOf('_') < 0 ||\n !region ||\n typeof region !== 'string')\n throw new AuthError({\n name: 'InvalidUserPoolId',\n message: 'Invalid user pool id provided.',\n });\n return region;\n}\nfunction getRegionFromIdentityPoolId(identityPoolId) {\n if (!identityPoolId || !identityPoolId.includes(':')) {\n throw new AuthError({\n name: 'InvalidIdentityPoolIdException',\n message: 'Invalid identity pool id provided.',\n recoverySuggestion: 'Make sure a valid identityPoolId is given in the config.',\n });\n }\n return identityPoolId.split(':')[0];\n}\n\nexport { getRegionFromIdentityPoolId, getRegionFromUserPoolId };\n//# sourceMappingURL=regionParsers.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Transforms a user attributes object into an array of AttributeType objects.\n * @param attributes user attributes to be mapped to AttributeType objects.\n * @returns an array of AttributeType objects.\n */\nfunction toAttributeType(attributes) {\n return Object.entries(attributes).map(([key, value]) => ({\n Name: key,\n Value: value,\n }));\n}\n/**\n * Transforms an array of AttributeType objects into a user attributes object.\n *\n * @param attributes - an array of AttributeType objects.\n * @returns AuthUserAttributes object.\n */\nfunction toAuthUserAttribute(attributes) {\n const userAttributes = {};\n attributes?.forEach(attribute => {\n if (attribute.Name)\n userAttributes[attribute.Name] = attribute.Value;\n });\n return userAttributes;\n}\n\nexport { toAttributeType, toAuthUserAttribute };\n//# sourceMappingURL=apiHelpers.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nvar AssociateSoftwareTokenException;\n(function (AssociateSoftwareTokenException) {\n AssociateSoftwareTokenException[\"ConcurrentModificationException\"] = \"ConcurrentModificationException\";\n AssociateSoftwareTokenException[\"ForbiddenException\"] = \"ForbiddenException\";\n AssociateSoftwareTokenException[\"InternalErrorException\"] = \"InternalErrorException\";\n AssociateSoftwareTokenException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n AssociateSoftwareTokenException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n AssociateSoftwareTokenException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n AssociateSoftwareTokenException[\"SoftwareTokenMFANotFoundException\"] = \"SoftwareTokenMFANotFoundException\";\n})(AssociateSoftwareTokenException || (AssociateSoftwareTokenException = {}));\nvar ChangePasswordException;\n(function (ChangePasswordException) {\n ChangePasswordException[\"ForbiddenException\"] = \"ForbiddenException\";\n ChangePasswordException[\"InternalErrorException\"] = \"InternalErrorException\";\n ChangePasswordException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ChangePasswordException[\"InvalidPasswordException\"] = \"InvalidPasswordException\";\n ChangePasswordException[\"LimitExceededException\"] = \"LimitExceededException\";\n ChangePasswordException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ChangePasswordException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n ChangePasswordException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ChangePasswordException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ChangePasswordException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n ChangePasswordException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ChangePasswordException || (ChangePasswordException = {}));\nvar ConfirmDeviceException;\n(function (ConfirmDeviceException) {\n ConfirmDeviceException[\"ForbiddenException\"] = \"ForbiddenException\";\n ConfirmDeviceException[\"InternalErrorException\"] = \"InternalErrorException\";\n ConfirmDeviceException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n ConfirmDeviceException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ConfirmDeviceException[\"InvalidPasswordException\"] = \"InvalidPasswordException\";\n ConfirmDeviceException[\"InvalidUserPoolConfigurationException\"] = \"InvalidUserPoolConfigurationException\";\n ConfirmDeviceException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ConfirmDeviceException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n ConfirmDeviceException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ConfirmDeviceException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ConfirmDeviceException[\"UsernameExistsException\"] = \"UsernameExistsException\";\n ConfirmDeviceException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n ConfirmDeviceException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ConfirmDeviceException || (ConfirmDeviceException = {}));\nvar ConfirmForgotPasswordException;\n(function (ConfirmForgotPasswordException) {\n ConfirmForgotPasswordException[\"CodeMismatchException\"] = \"CodeMismatchException\";\n ConfirmForgotPasswordException[\"ExpiredCodeException\"] = \"ExpiredCodeException\";\n ConfirmForgotPasswordException[\"ForbiddenException\"] = \"ForbiddenException\";\n ConfirmForgotPasswordException[\"InternalErrorException\"] = \"InternalErrorException\";\n ConfirmForgotPasswordException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n ConfirmForgotPasswordException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ConfirmForgotPasswordException[\"InvalidPasswordException\"] = \"InvalidPasswordException\";\n ConfirmForgotPasswordException[\"LimitExceededException\"] = \"LimitExceededException\";\n ConfirmForgotPasswordException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ConfirmForgotPasswordException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ConfirmForgotPasswordException[\"TooManyFailedAttemptsException\"] = \"TooManyFailedAttemptsException\";\n ConfirmForgotPasswordException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ConfirmForgotPasswordException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n ConfirmForgotPasswordException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n ConfirmForgotPasswordException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n ConfirmForgotPasswordException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ConfirmForgotPasswordException || (ConfirmForgotPasswordException = {}));\nvar ConfirmSignUpException;\n(function (ConfirmSignUpException) {\n ConfirmSignUpException[\"AliasExistsException\"] = \"AliasExistsException\";\n ConfirmSignUpException[\"CodeMismatchException\"] = \"CodeMismatchException\";\n ConfirmSignUpException[\"ExpiredCodeException\"] = \"ExpiredCodeException\";\n ConfirmSignUpException[\"ForbiddenException\"] = \"ForbiddenException\";\n ConfirmSignUpException[\"InternalErrorException\"] = \"InternalErrorException\";\n ConfirmSignUpException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n ConfirmSignUpException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ConfirmSignUpException[\"LimitExceededException\"] = \"LimitExceededException\";\n ConfirmSignUpException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ConfirmSignUpException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ConfirmSignUpException[\"TooManyFailedAttemptsException\"] = \"TooManyFailedAttemptsException\";\n ConfirmSignUpException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ConfirmSignUpException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n ConfirmSignUpException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n ConfirmSignUpException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ConfirmSignUpException || (ConfirmSignUpException = {}));\nvar DeleteUserAttributesException;\n(function (DeleteUserAttributesException) {\n DeleteUserAttributesException[\"ForbiddenException\"] = \"ForbiddenException\";\n DeleteUserAttributesException[\"InternalErrorException\"] = \"InternalErrorException\";\n DeleteUserAttributesException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n DeleteUserAttributesException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n DeleteUserAttributesException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n DeleteUserAttributesException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n DeleteUserAttributesException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n DeleteUserAttributesException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n DeleteUserAttributesException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(DeleteUserAttributesException || (DeleteUserAttributesException = {}));\nvar DeleteUserException;\n(function (DeleteUserException) {\n DeleteUserException[\"ForbiddenException\"] = \"ForbiddenException\";\n DeleteUserException[\"InternalErrorException\"] = \"InternalErrorException\";\n DeleteUserException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n DeleteUserException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n DeleteUserException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n DeleteUserException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n DeleteUserException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n DeleteUserException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n DeleteUserException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(DeleteUserException || (DeleteUserException = {}));\nvar ForgetDeviceException;\n(function (ForgetDeviceException) {\n ForgetDeviceException[\"ForbiddenException\"] = \"ForbiddenException\";\n ForgetDeviceException[\"InternalErrorException\"] = \"InternalErrorException\";\n ForgetDeviceException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ForgetDeviceException[\"InvalidUserPoolConfigurationException\"] = \"InvalidUserPoolConfigurationException\";\n ForgetDeviceException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ForgetDeviceException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n ForgetDeviceException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ForgetDeviceException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ForgetDeviceException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n ForgetDeviceException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ForgetDeviceException || (ForgetDeviceException = {}));\nvar ForgotPasswordException;\n(function (ForgotPasswordException) {\n ForgotPasswordException[\"CodeDeliveryFailureException\"] = \"CodeDeliveryFailureException\";\n ForgotPasswordException[\"ForbiddenException\"] = \"ForbiddenException\";\n ForgotPasswordException[\"InternalErrorException\"] = \"InternalErrorException\";\n ForgotPasswordException[\"InvalidEmailRoleAccessPolicyException\"] = \"InvalidEmailRoleAccessPolicyException\";\n ForgotPasswordException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n ForgotPasswordException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ForgotPasswordException[\"InvalidSmsRoleAccessPolicyException\"] = \"InvalidSmsRoleAccessPolicyException\";\n ForgotPasswordException[\"InvalidSmsRoleTrustRelationshipException\"] = \"InvalidSmsRoleTrustRelationshipException\";\n ForgotPasswordException[\"LimitExceededException\"] = \"LimitExceededException\";\n ForgotPasswordException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ForgotPasswordException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ForgotPasswordException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ForgotPasswordException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n ForgotPasswordException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n ForgotPasswordException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ForgotPasswordException || (ForgotPasswordException = {}));\nvar GetUserException;\n(function (GetUserException) {\n GetUserException[\"ForbiddenException\"] = \"ForbiddenException\";\n GetUserException[\"InternalErrorException\"] = \"InternalErrorException\";\n GetUserException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n GetUserException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n GetUserException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n GetUserException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n GetUserException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n GetUserException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n GetUserException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(GetUserException || (GetUserException = {}));\nvar GetIdException;\n(function (GetIdException) {\n GetIdException[\"ExternalServiceException\"] = \"ExternalServiceException\";\n GetIdException[\"InternalErrorException\"] = \"InternalErrorException\";\n GetIdException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n GetIdException[\"LimitExceededException\"] = \"LimitExceededException\";\n GetIdException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n GetIdException[\"ResourceConflictException\"] = \"ResourceConflictException\";\n GetIdException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n GetIdException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n})(GetIdException || (GetIdException = {}));\nvar GetCredentialsForIdentityException;\n(function (GetCredentialsForIdentityException) {\n GetCredentialsForIdentityException[\"ExternalServiceException\"] = \"ExternalServiceException\";\n GetCredentialsForIdentityException[\"InternalErrorException\"] = \"InternalErrorException\";\n GetCredentialsForIdentityException[\"InvalidIdentityPoolConfigurationException\"] = \"InvalidIdentityPoolConfigurationException\";\n GetCredentialsForIdentityException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n GetCredentialsForIdentityException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n GetCredentialsForIdentityException[\"ResourceConflictException\"] = \"ResourceConflictException\";\n GetCredentialsForIdentityException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n GetCredentialsForIdentityException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n})(GetCredentialsForIdentityException || (GetCredentialsForIdentityException = {}));\nvar GetUserAttributeVerificationException;\n(function (GetUserAttributeVerificationException) {\n GetUserAttributeVerificationException[\"CodeDeliveryFailureException\"] = \"CodeDeliveryFailureException\";\n GetUserAttributeVerificationException[\"ForbiddenException\"] = \"ForbiddenException\";\n GetUserAttributeVerificationException[\"InternalErrorException\"] = \"InternalErrorException\";\n GetUserAttributeVerificationException[\"InvalidEmailRoleAccessPolicyException\"] = \"InvalidEmailRoleAccessPolicyException\";\n GetUserAttributeVerificationException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n GetUserAttributeVerificationException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n GetUserAttributeVerificationException[\"InvalidSmsRoleAccessPolicyException\"] = \"InvalidSmsRoleAccessPolicyException\";\n GetUserAttributeVerificationException[\"InvalidSmsRoleTrustRelationshipException\"] = \"InvalidSmsRoleTrustRelationshipException\";\n GetUserAttributeVerificationException[\"LimitExceededException\"] = \"LimitExceededException\";\n GetUserAttributeVerificationException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n GetUserAttributeVerificationException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n GetUserAttributeVerificationException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n GetUserAttributeVerificationException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n GetUserAttributeVerificationException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n GetUserAttributeVerificationException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n GetUserAttributeVerificationException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n GetUserAttributeVerificationException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(GetUserAttributeVerificationException || (GetUserAttributeVerificationException = {}));\nvar GlobalSignOutException;\n(function (GlobalSignOutException) {\n GlobalSignOutException[\"ForbiddenException\"] = \"ForbiddenException\";\n GlobalSignOutException[\"InternalErrorException\"] = \"InternalErrorException\";\n GlobalSignOutException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n GlobalSignOutException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n GlobalSignOutException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n GlobalSignOutException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n GlobalSignOutException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n GlobalSignOutException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n})(GlobalSignOutException || (GlobalSignOutException = {}));\nvar InitiateAuthException;\n(function (InitiateAuthException) {\n InitiateAuthException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n InitiateAuthException[\"ForbiddenException\"] = \"ForbiddenException\";\n InitiateAuthException[\"InternalErrorException\"] = \"InternalErrorException\";\n InitiateAuthException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n InitiateAuthException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n InitiateAuthException[\"InvalidSmsRoleAccessPolicyException\"] = \"InvalidSmsRoleAccessPolicyException\";\n InitiateAuthException[\"InvalidSmsRoleTrustRelationshipException\"] = \"InvalidSmsRoleTrustRelationshipException\";\n InitiateAuthException[\"InvalidUserPoolConfigurationException\"] = \"InvalidUserPoolConfigurationException\";\n InitiateAuthException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n InitiateAuthException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n InitiateAuthException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n InitiateAuthException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n InitiateAuthException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n InitiateAuthException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n InitiateAuthException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(InitiateAuthException || (InitiateAuthException = {}));\nvar ResendConfirmationException;\n(function (ResendConfirmationException) {\n ResendConfirmationException[\"CodeDeliveryFailureException\"] = \"CodeDeliveryFailureException\";\n ResendConfirmationException[\"ForbiddenException\"] = \"ForbiddenException\";\n ResendConfirmationException[\"InternalErrorException\"] = \"InternalErrorException\";\n ResendConfirmationException[\"InvalidEmailRoleAccessPolicyException\"] = \"InvalidEmailRoleAccessPolicyException\";\n ResendConfirmationException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n ResendConfirmationException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ResendConfirmationException[\"InvalidSmsRoleAccessPolicyException\"] = \"InvalidSmsRoleAccessPolicyException\";\n ResendConfirmationException[\"InvalidSmsRoleTrustRelationshipException\"] = \"InvalidSmsRoleTrustRelationshipException\";\n ResendConfirmationException[\"LimitExceededException\"] = \"LimitExceededException\";\n ResendConfirmationException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ResendConfirmationException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ResendConfirmationException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ResendConfirmationException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n ResendConfirmationException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n ResendConfirmationException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ResendConfirmationException || (ResendConfirmationException = {}));\nvar RespondToAuthChallengeException;\n(function (RespondToAuthChallengeException) {\n RespondToAuthChallengeException[\"AliasExistsException\"] = \"AliasExistsException\";\n RespondToAuthChallengeException[\"CodeMismatchException\"] = \"CodeMismatchException\";\n RespondToAuthChallengeException[\"ExpiredCodeException\"] = \"ExpiredCodeException\";\n RespondToAuthChallengeException[\"ForbiddenException\"] = \"ForbiddenException\";\n RespondToAuthChallengeException[\"InternalErrorException\"] = \"InternalErrorException\";\n RespondToAuthChallengeException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n RespondToAuthChallengeException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n RespondToAuthChallengeException[\"InvalidPasswordException\"] = \"InvalidPasswordException\";\n RespondToAuthChallengeException[\"InvalidSmsRoleAccessPolicyException\"] = \"InvalidSmsRoleAccessPolicyException\";\n RespondToAuthChallengeException[\"InvalidSmsRoleTrustRelationshipException\"] = \"InvalidSmsRoleTrustRelationshipException\";\n RespondToAuthChallengeException[\"InvalidUserPoolConfigurationException\"] = \"InvalidUserPoolConfigurationException\";\n RespondToAuthChallengeException[\"MFAMethodNotFoundException\"] = \"MFAMethodNotFoundException\";\n RespondToAuthChallengeException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n RespondToAuthChallengeException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n RespondToAuthChallengeException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n RespondToAuthChallengeException[\"SoftwareTokenMFANotFoundException\"] = \"SoftwareTokenMFANotFoundException\";\n RespondToAuthChallengeException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n RespondToAuthChallengeException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n RespondToAuthChallengeException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n RespondToAuthChallengeException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n RespondToAuthChallengeException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(RespondToAuthChallengeException || (RespondToAuthChallengeException = {}));\nvar SetUserMFAPreferenceException;\n(function (SetUserMFAPreferenceException) {\n SetUserMFAPreferenceException[\"ForbiddenException\"] = \"ForbiddenException\";\n SetUserMFAPreferenceException[\"InternalErrorException\"] = \"InternalErrorException\";\n SetUserMFAPreferenceException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n SetUserMFAPreferenceException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n SetUserMFAPreferenceException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n SetUserMFAPreferenceException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n SetUserMFAPreferenceException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n SetUserMFAPreferenceException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(SetUserMFAPreferenceException || (SetUserMFAPreferenceException = {}));\nvar SignUpException;\n(function (SignUpException) {\n SignUpException[\"CodeDeliveryFailureException\"] = \"CodeDeliveryFailureException\";\n SignUpException[\"InternalErrorException\"] = \"InternalErrorException\";\n SignUpException[\"InvalidEmailRoleAccessPolicyException\"] = \"InvalidEmailRoleAccessPolicyException\";\n SignUpException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n SignUpException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n SignUpException[\"InvalidPasswordException\"] = \"InvalidPasswordException\";\n SignUpException[\"InvalidSmsRoleAccessPolicyException\"] = \"InvalidSmsRoleAccessPolicyException\";\n SignUpException[\"InvalidSmsRoleTrustRelationshipException\"] = \"InvalidSmsRoleTrustRelationshipException\";\n SignUpException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n SignUpException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n SignUpException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n SignUpException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n SignUpException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n SignUpException[\"UsernameExistsException\"] = \"UsernameExistsException\";\n})(SignUpException || (SignUpException = {}));\nvar UpdateUserAttributesException;\n(function (UpdateUserAttributesException) {\n UpdateUserAttributesException[\"AliasExistsException\"] = \"AliasExistsException\";\n UpdateUserAttributesException[\"CodeDeliveryFailureException\"] = \"CodeDeliveryFailureException\";\n UpdateUserAttributesException[\"CodeMismatchException\"] = \"CodeMismatchException\";\n UpdateUserAttributesException[\"ExpiredCodeException\"] = \"ExpiredCodeException\";\n UpdateUserAttributesException[\"ForbiddenException\"] = \"ForbiddenException\";\n UpdateUserAttributesException[\"InternalErrorException\"] = \"InternalErrorException\";\n UpdateUserAttributesException[\"InvalidEmailRoleAccessPolicyException\"] = \"InvalidEmailRoleAccessPolicyException\";\n UpdateUserAttributesException[\"InvalidLambdaResponseException\"] = \"InvalidLambdaResponseException\";\n UpdateUserAttributesException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n UpdateUserAttributesException[\"InvalidSmsRoleAccessPolicyException\"] = \"InvalidSmsRoleAccessPolicyException\";\n UpdateUserAttributesException[\"InvalidSmsRoleTrustRelationshipException\"] = \"InvalidSmsRoleTrustRelationshipException\";\n UpdateUserAttributesException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n UpdateUserAttributesException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n UpdateUserAttributesException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n UpdateUserAttributesException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n UpdateUserAttributesException[\"UnexpectedLambdaException\"] = \"UnexpectedLambdaException\";\n UpdateUserAttributesException[\"UserLambdaValidationException\"] = \"UserLambdaValidationException\";\n UpdateUserAttributesException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n UpdateUserAttributesException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(UpdateUserAttributesException || (UpdateUserAttributesException = {}));\nvar VerifySoftwareTokenException;\n(function (VerifySoftwareTokenException) {\n VerifySoftwareTokenException[\"CodeMismatchException\"] = \"CodeMismatchException\";\n VerifySoftwareTokenException[\"EnableSoftwareTokenMFAException\"] = \"EnableSoftwareTokenMFAException\";\n VerifySoftwareTokenException[\"ForbiddenException\"] = \"ForbiddenException\";\n VerifySoftwareTokenException[\"InternalErrorException\"] = \"InternalErrorException\";\n VerifySoftwareTokenException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n VerifySoftwareTokenException[\"InvalidUserPoolConfigurationException\"] = \"InvalidUserPoolConfigurationException\";\n VerifySoftwareTokenException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n VerifySoftwareTokenException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n VerifySoftwareTokenException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n VerifySoftwareTokenException[\"SoftwareTokenMFANotFoundException\"] = \"SoftwareTokenMFANotFoundException\";\n VerifySoftwareTokenException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n VerifySoftwareTokenException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n VerifySoftwareTokenException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(VerifySoftwareTokenException || (VerifySoftwareTokenException = {}));\nvar VerifyUserAttributeException;\n(function (VerifyUserAttributeException) {\n VerifyUserAttributeException[\"AliasExistsException\"] = \"AliasExistsException\";\n VerifyUserAttributeException[\"CodeMismatchException\"] = \"CodeMismatchException\";\n VerifyUserAttributeException[\"ExpiredCodeException\"] = \"ExpiredCodeException\";\n VerifyUserAttributeException[\"ForbiddenException\"] = \"ForbiddenException\";\n VerifyUserAttributeException[\"InternalErrorException\"] = \"InternalErrorException\";\n VerifyUserAttributeException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n VerifyUserAttributeException[\"LimitExceededException\"] = \"LimitExceededException\";\n VerifyUserAttributeException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n VerifyUserAttributeException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n VerifyUserAttributeException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n VerifyUserAttributeException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n VerifyUserAttributeException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n VerifyUserAttributeException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(VerifyUserAttributeException || (VerifyUserAttributeException = {}));\nvar UpdateDeviceStatusException;\n(function (UpdateDeviceStatusException) {\n UpdateDeviceStatusException[\"ForbiddenException\"] = \"ForbiddenException\";\n UpdateDeviceStatusException[\"InternalErrorException\"] = \"InternalErrorException\";\n UpdateDeviceStatusException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n UpdateDeviceStatusException[\"InvalidUserPoolConfigurationException\"] = \"InvalidUserPoolConfigurationException\";\n UpdateDeviceStatusException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n UpdateDeviceStatusException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n UpdateDeviceStatusException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n UpdateDeviceStatusException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n UpdateDeviceStatusException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n UpdateDeviceStatusException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(UpdateDeviceStatusException || (UpdateDeviceStatusException = {}));\nvar ListDevicesException;\n(function (ListDevicesException) {\n ListDevicesException[\"ForbiddenException\"] = \"ForbiddenException\";\n ListDevicesException[\"InternalErrorException\"] = \"InternalErrorException\";\n ListDevicesException[\"InvalidParameterException\"] = \"InvalidParameterException\";\n ListDevicesException[\"InvalidUserPoolConfigurationException\"] = \"InvalidUserPoolConfigurationException\";\n ListDevicesException[\"NotAuthorizedException\"] = \"NotAuthorizedException\";\n ListDevicesException[\"PasswordResetRequiredException\"] = \"PasswordResetRequiredException\";\n ListDevicesException[\"ResourceNotFoundException\"] = \"ResourceNotFoundException\";\n ListDevicesException[\"TooManyRequestsException\"] = \"TooManyRequestsException\";\n ListDevicesException[\"UserNotConfirmedException\"] = \"UserNotConfirmedException\";\n ListDevicesException[\"UserNotFoundException\"] = \"UserNotFoundException\";\n})(ListDevicesException || (ListDevicesException = {}));\nconst SETUP_TOTP_EXCEPTION = 'SetUpTOTPException';\n\nexport { AssociateSoftwareTokenException, ChangePasswordException, ConfirmDeviceException, ConfirmForgotPasswordException, ConfirmSignUpException, DeleteUserAttributesException, DeleteUserException, ForgetDeviceException, ForgotPasswordException, GetCredentialsForIdentityException, GetIdException, GetUserAttributeVerificationException, GetUserException, GlobalSignOutException, InitiateAuthException, ListDevicesException, ResendConfirmationException, RespondToAuthChallengeException, SETUP_TOTP_EXCEPTION, SetUserMFAPreferenceException, SignUpException, UpdateDeviceStatusException, UpdateUserAttributesException, VerifySoftwareTokenException, VerifyUserAttributeException };\n//# sourceMappingURL=errors.mjs.map\n","import { AuthError } from './AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst USER_UNAUTHENTICATED_EXCEPTION = 'UserUnAuthenticatedException';\nconst USER_ALREADY_AUTHENTICATED_EXCEPTION = 'UserAlreadyAuthenticatedException';\nconst DEVICE_METADATA_NOT_FOUND_EXCEPTION = 'DeviceMetadataNotFoundException';\nconst AUTO_SIGN_IN_EXCEPTION = 'AutoSignInException';\nconst INVALID_REDIRECT_EXCEPTION = 'InvalidRedirectException';\nconst INVALID_APP_SCHEME_EXCEPTION = 'InvalidAppSchemeException';\nconst INVALID_PREFERRED_REDIRECT_EXCEPTION = 'InvalidPreferredRedirectUrlException';\nconst invalidRedirectException = new AuthError({\n name: INVALID_REDIRECT_EXCEPTION,\n message: 'signInRedirect or signOutRedirect had an invalid format or was not found.',\n recoverySuggestion: 'Please make sure the signIn/Out redirect in your oauth config is valid.',\n});\nconst invalidAppSchemeException = new AuthError({\n name: INVALID_APP_SCHEME_EXCEPTION,\n message: 'A valid non-http app scheme was not found in the config.',\n recoverySuggestion: 'Please make sure a valid custom app scheme is present in the config.',\n});\nconst invalidPreferredRedirectUrlException = new AuthError({\n name: INVALID_PREFERRED_REDIRECT_EXCEPTION,\n message: 'The given preferredRedirectUrl does not match any items in the redirectSignOutUrls array from the config.',\n recoverySuggestion: 'Please make sure a matching preferredRedirectUrl is provided.',\n});\nconst INVALID_ORIGIN_EXCEPTION = 'InvalidOriginException';\nconst invalidOriginException = new AuthError({\n name: INVALID_ORIGIN_EXCEPTION,\n message: 'redirect is coming from a different origin. The oauth flow needs to be initiated from the same origin',\n recoverySuggestion: 'Please call signInWithRedirect from the same origin.',\n});\nconst OAUTH_SIGNOUT_EXCEPTION = 'OAuthSignOutException';\nconst TOKEN_REFRESH_EXCEPTION = 'TokenRefreshException';\nconst UNEXPECTED_SIGN_IN_INTERRUPTION_EXCEPTION = 'UnexpectedSignInInterruptionException';\n\nexport { AUTO_SIGN_IN_EXCEPTION, DEVICE_METADATA_NOT_FOUND_EXCEPTION, INVALID_APP_SCHEME_EXCEPTION, INVALID_ORIGIN_EXCEPTION, INVALID_PREFERRED_REDIRECT_EXCEPTION, INVALID_REDIRECT_EXCEPTION, OAUTH_SIGNOUT_EXCEPTION, TOKEN_REFRESH_EXCEPTION, UNEXPECTED_SIGN_IN_INTERRUPTION_EXCEPTION, USER_ALREADY_AUTHENTICATED_EXCEPTION, USER_UNAUTHENTICATED_EXCEPTION, invalidAppSchemeException, invalidOriginException, invalidPreferredRedirectUrlException, invalidRedirectException };\n//# sourceMappingURL=constants.mjs.map\n","import { AuthError } from '../../../errors/AuthError.mjs';\nimport { TOKEN_REFRESH_EXCEPTION, USER_UNAUTHENTICATED_EXCEPTION, DEVICE_METADATA_NOT_FOUND_EXCEPTION } from '../../../errors/constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction isTypeUserPoolConfig(authConfig) {\n if (authConfig &&\n authConfig.Cognito.userPoolId &&\n authConfig.Cognito.userPoolClientId) {\n return true;\n }\n return false;\n}\nfunction assertAuthTokens(tokens) {\n if (!tokens || !tokens.accessToken) {\n throw new AuthError({\n name: USER_UNAUTHENTICATED_EXCEPTION,\n message: 'User needs to be authenticated to call this API.',\n recoverySuggestion: 'Sign in before calling this API again.',\n });\n }\n}\nfunction assertIdTokenInAuthTokens(tokens) {\n if (!tokens || !tokens.idToken) {\n throw new AuthError({\n name: USER_UNAUTHENTICATED_EXCEPTION,\n message: 'User needs to be authenticated to call this API.',\n recoverySuggestion: 'Sign in before calling this API again.',\n });\n }\n}\nconst oAuthTokenRefreshException = new AuthError({\n name: TOKEN_REFRESH_EXCEPTION,\n message: `Token refresh is not supported when authenticated with the 'implicit grant' (token) oauth flow. \n\tPlease change your oauth configuration to use 'code grant' flow.`,\n recoverySuggestion: `Please logout and change your Amplify configuration to use \"code grant\" flow. \n\tE.g { responseType: 'code' }`,\n});\nconst tokenRefreshException = new AuthError({\n name: USER_UNAUTHENTICATED_EXCEPTION,\n message: 'User needs to be authenticated to call this API.',\n recoverySuggestion: 'Sign in before calling this API again.',\n});\nfunction assertAuthTokensWithRefreshToken(tokens) {\n if (isAuthenticatedWithImplicitOauthFlow(tokens)) {\n throw oAuthTokenRefreshException;\n }\n if (!isAuthenticatedWithRefreshToken(tokens)) {\n throw tokenRefreshException;\n }\n}\nfunction assertDeviceMetadata(deviceMetadata) {\n if (!deviceMetadata ||\n !deviceMetadata.deviceKey ||\n !deviceMetadata.deviceGroupKey ||\n !deviceMetadata.randomPassword) {\n throw new AuthError({\n name: DEVICE_METADATA_NOT_FOUND_EXCEPTION,\n message: 'Either deviceKey, deviceGroupKey or secretPassword were not found during the sign-in process.',\n recoverySuggestion: 'Make sure to not clear storage after calling the signIn API.',\n });\n }\n}\nconst OAuthStorageKeys = {\n inflightOAuth: 'inflightOAuth',\n oauthSignIn: 'oauthSignIn',\n oauthPKCE: 'oauthPKCE',\n oauthState: 'oauthState',\n};\nfunction isAuthenticated(tokens) {\n return tokens?.accessToken || tokens?.idToken;\n}\nfunction isAuthenticatedWithRefreshToken(tokens) {\n return isAuthenticated(tokens) && tokens?.refreshToken;\n}\nfunction isAuthenticatedWithImplicitOauthFlow(tokens) {\n return isAuthenticated(tokens) && !tokens?.refreshToken;\n}\n\nexport { OAuthStorageKeys, assertAuthTokens, assertAuthTokensWithRefreshToken, assertDeviceMetadata, assertIdTokenInAuthTokens, isTypeUserPoolConfig, oAuthTokenRefreshException, tokenRefreshException };\n//# sourceMappingURL=types.mjs.map\n","import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { assertAuthTokens } from '../../utils/types.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst getCurrentUser = async (amplify) => {\n const authConfig = amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n const tokens = await amplify.Auth.getTokens({ forceRefresh: false });\n assertAuthTokens(tokens);\n const { 'cognito:username': username, sub } = tokens.idToken?.payload ?? {};\n const authUser = {\n username: username,\n userId: sub,\n };\n const signInDetails = getSignInDetailsFromTokens(tokens);\n if (signInDetails) {\n authUser.signInDetails = signInDetails;\n }\n return authUser;\n};\nfunction getSignInDetailsFromTokens(tokens) {\n return tokens?.signInDetails;\n}\n\nexport { getCurrentUser };\n//# sourceMappingURL=getCurrentUser.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { getCurrentUser as getCurrentUser$1 } from './internal/getCurrentUser.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Gets the current user from the idToken.\n *\n * @param input - The GetCurrentUserInput object.\n * @returns GetCurrentUserOutput\n * @throws - {@link InitiateAuthException} - Thrown when the service fails to refresh the tokens.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nconst getCurrentUser = async () => {\n return getCurrentUser$1(Amplify);\n};\n\nexport { getCurrentUser };\n//# sourceMappingURL=getCurrentUser.mjs.map\n","import { getAmplifyUserAgent, Category } from '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst getAuthUserAgentValue = (action, customUserAgentDetails) => getAmplifyUserAgent({\n category: Category.Auth,\n action,\n ...customUserAgentDetails,\n});\n\nexport { getAuthUserAgentValue };\n//# sourceMappingURL=getAuthUserAgentValue.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createUserPoolSerializer = (operation) => (input, endpoint) => {\n const headers = getSharedHeaders(operation);\n const body = JSON.stringify(input);\n return buildHttpRpcRequest(endpoint, headers, body);\n};\nconst getSharedHeaders = (operation) => ({\n 'content-type': 'application/x-amz-json-1.1',\n 'x-amz-target': `AWSCognitoIdentityProviderService.${operation}`,\n});\nconst buildHttpRpcRequest = ({ url }, headers, body) => ({\n headers,\n url,\n body,\n method: 'POST',\n});\n\nexport { createUserPoolSerializer };\n//# sourceMappingURL=createUserPoolSerializer.mjs.map\n","import { AmplifyErrorCode } from '@aws-amplify/core/internals/utils';\nimport { AuthError } from '../AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction assertServiceError(error) {\n if (!error ||\n error.name === 'Error' ||\n error instanceof TypeError) {\n throw new AuthError({\n name: AmplifyErrorCode.Unknown,\n message: 'An unknown error has occurred.',\n underlyingError: error,\n });\n }\n}\n\nexport { assertServiceError };\n//# sourceMappingURL=assertServiceError.mjs.map\n","import { parseJsonError, parseJsonBody } from '@aws-amplify/core/internals/aws-client-utils';\nimport { assertServiceError } from '../../../../../../errors/utils/assertServiceError.mjs';\nimport { AuthError } from '../../../../../../errors/AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createUserPoolDeserializer = () => async (response) => {\n if (response.statusCode >= 300) {\n const error = await parseJsonError(response);\n assertServiceError(error);\n throw new AuthError({\n name: error.name,\n message: error.message,\n metadata: error.$metadata,\n });\n }\n return parseJsonBody(response);\n};\n\nexport { createUserPoolDeserializer };\n//# sourceMappingURL=createUserPoolDeserializer.mjs.map\n","import { composeTransferHandler } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { unauthenticatedHandler } from '@aws-amplify/core/internals/aws-client-utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * A Cognito Identity-specific middleware that disables caching for all requests.\n */\nconst disableCacheMiddlewareFactory = () => (next, _) => async function disableCacheMiddleware(request) {\n request.headers['cache-control'] = 'no-store';\n return next(request);\n};\n/**\n * A Cognito Identity-specific transfer handler that does NOT sign requests, and\n * disables caching.\n *\n * @internal\n */\nconst cognitoUserPoolTransferHandler = composeTransferHandler(unauthenticatedHandler, [disableCacheMiddlewareFactory]);\n\nexport { cognitoUserPoolTransferHandler };\n//# sourceMappingURL=cognitoUserPoolTransferHandler.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * The service name used to sign requests if the API requires authentication.\n */\nconst COGNITO_IDP_SERVICE_NAME = 'cognito-idp';\n\nexport { COGNITO_IDP_SERVICE_NAME };\n//# sourceMappingURL=constants.mjs.map\n","import { getRetryDecider, parseJsonError, jitteredBackoff } from '@aws-amplify/core/internals/aws-client-utils';\nimport { getAmplifyUserAgent } from '@aws-amplify/core/internals/utils';\nimport { COGNITO_IDP_SERVICE_NAME } from '../../../constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst DEFAULT_SERVICE_CLIENT_API_CONFIG = {\n service: COGNITO_IDP_SERVICE_NAME,\n retryDecider: getRetryDecider(parseJsonError),\n computeDelay: jitteredBackoff,\n userAgentValue: getAmplifyUserAgent(),\n cache: 'no-store',\n};\n\nexport { DEFAULT_SERVICE_CLIENT_API_CONFIG };\n//# sourceMappingURL=constants.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createInitiateAuthClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('InitiateAuth'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createInitiateAuthClient };\n//# sourceMappingURL=createInitiateAuthClient.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createRespondToAuthChallengeClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('RespondToAuthChallenge'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createRespondToAuthChallengeClient };\n//# sourceMappingURL=createRespondToAuthChallengeClient.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createAssociateSoftwareTokenClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('AssociateSoftwareToken'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createAssociateSoftwareTokenClient };\n//# sourceMappingURL=createAssociateSoftwareTokenClient.mjs.map\n","import { getDnsSuffix } from '@aws-amplify/core/internals/aws-client-utils';\nimport { AmplifyUrl } from '@aws-amplify/core/internals/utils';\nimport { COGNITO_IDP_SERVICE_NAME } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst cognitoUserPoolEndpointResolver = ({ region, }) => ({\n url: new AmplifyUrl(`https://${COGNITO_IDP_SERVICE_NAME}.${region}.${getDnsSuffix(region)}`),\n});\n\nexport { cognitoUserPoolEndpointResolver };\n//# sourceMappingURL=cognitoUserPoolEndpointResolver.mjs.map\n","import { AmplifyUrl } from '@aws-amplify/core/internals/utils';\nimport { cognitoUserPoolEndpointResolver } from '../../../foundation/cognitoUserPoolEndpointResolver.mjs';\n\nconst createCognitoUserPoolEndpointResolver = ({ endpointOverride }) => (input) => {\n if (endpointOverride) {\n return { url: new AmplifyUrl(endpointOverride) };\n }\n return cognitoUserPoolEndpointResolver(input);\n};\n\nexport { createCognitoUserPoolEndpointResolver };\n//# sourceMappingURL=createCognitoUserPoolEndpointResolver.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction getUserContextData({ username, userPoolId, userPoolClientId, }) {\n if (typeof window === 'undefined') {\n return undefined;\n }\n const amazonCognitoAdvancedSecurityData = window\n .AmazonCognitoAdvancedSecurityData;\n if (typeof amazonCognitoAdvancedSecurityData === 'undefined') {\n return undefined;\n }\n const advancedSecurityData = amazonCognitoAdvancedSecurityData.getData(username, userPoolId, userPoolClientId);\n if (advancedSecurityData) {\n const userContextData = {\n EncodedData: advancedSecurityData,\n };\n return userContextData;\n }\n return {};\n}\n\nexport { getUserContextData };\n//# sourceMappingURL=userContextData.mjs.map\n","import { deDupeAsyncFunction, assertTokenProviderConfig, decodeJWT } from '@aws-amplify/core/internals/utils';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { assertAuthTokensWithRefreshToken } from './types.mjs';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { createInitiateAuthClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createInitiateAuthClient.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../../../errors/types/validation.mjs';\nimport '../types/errors.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getUserContextData } from './userContextData.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst refreshAuthTokensFunction = async ({ tokens, authConfig, username, }) => {\n assertTokenProviderConfig(authConfig?.Cognito);\n const { userPoolId, userPoolClientId, userPoolEndpoint } = authConfig.Cognito;\n const region = getRegionFromUserPoolId(userPoolId);\n assertAuthTokensWithRefreshToken(tokens);\n const refreshTokenString = tokens.refreshToken;\n const AuthParameters = {\n REFRESH_TOKEN: refreshTokenString,\n };\n if (tokens.deviceMetadata?.deviceKey) {\n AuthParameters.DEVICE_KEY = tokens.deviceMetadata.deviceKey;\n }\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const initiateAuth = createInitiateAuthClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const { AuthenticationResult } = await initiateAuth({ region }, {\n ClientId: userPoolClientId,\n AuthFlow: 'REFRESH_TOKEN_AUTH',\n AuthParameters,\n UserContextData,\n });\n const accessToken = decodeJWT(AuthenticationResult?.AccessToken ?? '');\n const idToken = AuthenticationResult?.IdToken\n ? decodeJWT(AuthenticationResult.IdToken)\n : undefined;\n const { iat } = accessToken.payload;\n // This should never happen. If it does, it's a bug from the service.\n if (!iat) {\n throw new AuthError({\n name: 'iatNotFoundException',\n message: 'iat not found in access token',\n });\n }\n const clockDrift = iat * 1000 - new Date().getTime();\n return {\n accessToken,\n idToken,\n clockDrift,\n refreshToken: refreshTokenString,\n username,\n };\n};\nconst refreshAuthTokens = deDupeAsyncFunction(refreshAuthTokensFunction);\nconst refreshAuthTokensWithoutDedupe = refreshAuthTokensFunction;\n\nexport { refreshAuthTokens, refreshAuthTokensWithoutDedupe };\n//# sourceMappingURL=refreshAuthTokens.mjs.map\n","const AuthTokenStorageKeys = {\n accessToken: 'accessToken',\n idToken: 'idToken',\n oidcProvider: 'oidcProvider',\n clockDrift: 'clockDrift',\n refreshToken: 'refreshToken',\n deviceKey: 'deviceKey',\n randomPasswordKey: 'randomPasswordKey',\n deviceGroupKey: 'deviceGroupKey',\n signInDetails: 'signInDetails',\n oauthMetadata: 'oauthMetadata',\n};\n\nexport { AuthTokenStorageKeys };\n//# sourceMappingURL=types.mjs.map\n","import { createAssertionFunction } from '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nvar TokenProviderErrorCode;\n(function (TokenProviderErrorCode) {\n TokenProviderErrorCode[\"InvalidAuthTokens\"] = \"InvalidAuthTokens\";\n})(TokenProviderErrorCode || (TokenProviderErrorCode = {}));\nconst tokenValidationErrorMap = {\n [TokenProviderErrorCode.InvalidAuthTokens]: {\n message: 'Invalid tokens.',\n recoverySuggestion: 'Make sure the tokens are valid.',\n },\n};\nconst assert = createAssertionFunction(tokenValidationErrorMap);\n\nexport { TokenProviderErrorCode, assert };\n//# sourceMappingURL=errorHelpers.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst AUTH_KEY_PREFIX = 'CognitoIdentityServiceProvider';\n\nexport { AUTH_KEY_PREFIX };\n//# sourceMappingURL=constants.mjs.map\n","import { decodeJWT, assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { AuthTokenStorageKeys } from './types.mjs';\nimport { assert, TokenProviderErrorCode } from './errorHelpers.mjs';\nimport { AUTH_KEY_PREFIX } from './constants.mjs';\n\nclass DefaultTokenStore {\n getKeyValueStorage() {\n if (!this.keyValueStorage) {\n throw new AuthError({\n name: 'KeyValueStorageNotFoundException',\n message: 'KeyValueStorage was not found in TokenStore',\n });\n }\n return this.keyValueStorage;\n }\n setKeyValueStorage(keyValueStorage) {\n this.keyValueStorage = keyValueStorage;\n }\n setAuthConfig(authConfig) {\n this.authConfig = authConfig;\n }\n async loadTokens() {\n // TODO(v6): migration logic should be here\n // Reading V5 tokens old format\n try {\n const authKeys = await this.getAuthKeys();\n const accessTokenString = await this.getKeyValueStorage().getItem(authKeys.accessToken);\n if (!accessTokenString) {\n throw new AuthError({\n name: 'NoSessionFoundException',\n message: 'Auth session was not found. Make sure to call signIn.',\n });\n }\n const accessToken = decodeJWT(accessTokenString);\n const itString = await this.getKeyValueStorage().getItem(authKeys.idToken);\n const idToken = itString ? decodeJWT(itString) : undefined;\n const refreshToken = (await this.getKeyValueStorage().getItem(authKeys.refreshToken)) ??\n undefined;\n const clockDriftString = (await this.getKeyValueStorage().getItem(authKeys.clockDrift)) ?? '0';\n const clockDrift = Number.parseInt(clockDriftString);\n const signInDetails = await this.getKeyValueStorage().getItem(authKeys.signInDetails);\n const tokens = {\n accessToken,\n idToken,\n refreshToken,\n deviceMetadata: (await this.getDeviceMetadata()) ?? undefined,\n clockDrift,\n username: await this.getLastAuthUser(),\n };\n if (signInDetails) {\n tokens.signInDetails = JSON.parse(signInDetails);\n }\n return tokens;\n }\n catch (err) {\n return null;\n }\n }\n async storeTokens(tokens) {\n assert(tokens !== undefined, TokenProviderErrorCode.InvalidAuthTokens);\n const lastAuthUser = tokens.username;\n await this.getKeyValueStorage().setItem(this.getLastAuthUserKey(), lastAuthUser);\n const authKeys = await this.getAuthKeys();\n await this.getKeyValueStorage().setItem(authKeys.accessToken, tokens.accessToken.toString());\n if (tokens.idToken) {\n await this.getKeyValueStorage().setItem(authKeys.idToken, tokens.idToken.toString());\n }\n else {\n await this.getKeyValueStorage().removeItem(authKeys.idToken);\n }\n if (tokens.refreshToken) {\n await this.getKeyValueStorage().setItem(authKeys.refreshToken, tokens.refreshToken);\n }\n else {\n await this.getKeyValueStorage().removeItem(authKeys.refreshToken);\n }\n if (tokens.deviceMetadata) {\n if (tokens.deviceMetadata.deviceKey) {\n await this.getKeyValueStorage().setItem(authKeys.deviceKey, tokens.deviceMetadata.deviceKey);\n }\n if (tokens.deviceMetadata.deviceGroupKey) {\n await this.getKeyValueStorage().setItem(authKeys.deviceGroupKey, tokens.deviceMetadata.deviceGroupKey);\n }\n await this.getKeyValueStorage().setItem(authKeys.randomPasswordKey, tokens.deviceMetadata.randomPassword);\n }\n if (tokens.signInDetails) {\n await this.getKeyValueStorage().setItem(authKeys.signInDetails, JSON.stringify(tokens.signInDetails));\n }\n else {\n await this.getKeyValueStorage().removeItem(authKeys.signInDetails);\n }\n await this.getKeyValueStorage().setItem(authKeys.clockDrift, `${tokens.clockDrift}`);\n }\n async clearTokens() {\n const authKeys = await this.getAuthKeys();\n // Not calling clear because it can remove data that is not managed by AuthTokenStore\n await Promise.all([\n this.getKeyValueStorage().removeItem(authKeys.accessToken),\n this.getKeyValueStorage().removeItem(authKeys.idToken),\n this.getKeyValueStorage().removeItem(authKeys.clockDrift),\n this.getKeyValueStorage().removeItem(authKeys.refreshToken),\n this.getKeyValueStorage().removeItem(authKeys.signInDetails),\n this.getKeyValueStorage().removeItem(this.getLastAuthUserKey()),\n this.getKeyValueStorage().removeItem(authKeys.oauthMetadata),\n ]);\n }\n async getDeviceMetadata(username) {\n const authKeys = await this.getAuthKeys(username);\n const deviceKey = await this.getKeyValueStorage().getItem(authKeys.deviceKey);\n const deviceGroupKey = await this.getKeyValueStorage().getItem(authKeys.deviceGroupKey);\n const randomPassword = await this.getKeyValueStorage().getItem(authKeys.randomPasswordKey);\n return randomPassword && deviceGroupKey && deviceKey\n ? {\n deviceKey,\n deviceGroupKey,\n randomPassword,\n }\n : null;\n }\n async clearDeviceMetadata(username) {\n const authKeys = await this.getAuthKeys(username);\n await Promise.all([\n this.getKeyValueStorage().removeItem(authKeys.deviceKey),\n this.getKeyValueStorage().removeItem(authKeys.deviceGroupKey),\n this.getKeyValueStorage().removeItem(authKeys.randomPasswordKey),\n ]);\n }\n async getAuthKeys(username) {\n assertTokenProviderConfig(this.authConfig?.Cognito);\n const lastAuthUser = username ?? (await this.getLastAuthUser());\n return createKeysForAuthStorage(AUTH_KEY_PREFIX, `${this.authConfig.Cognito.userPoolClientId}.${lastAuthUser}`);\n }\n getLastAuthUserKey() {\n assertTokenProviderConfig(this.authConfig?.Cognito);\n const identifier = this.authConfig.Cognito.userPoolClientId;\n return `${AUTH_KEY_PREFIX}.${identifier}.LastAuthUser`;\n }\n async getLastAuthUser() {\n const lastAuthUser = (await this.getKeyValueStorage().getItem(this.getLastAuthUserKey())) ??\n 'username';\n return lastAuthUser;\n }\n async setOAuthMetadata(metadata) {\n const { oauthMetadata: oauthMetadataKey } = await this.getAuthKeys();\n await this.getKeyValueStorage().setItem(oauthMetadataKey, JSON.stringify(metadata));\n }\n async getOAuthMetadata() {\n const { oauthMetadata: oauthMetadataKey } = await this.getAuthKeys();\n const oauthMetadata = await this.getKeyValueStorage().getItem(oauthMetadataKey);\n return oauthMetadata && JSON.parse(oauthMetadata);\n }\n}\nconst createKeysForAuthStorage = (provider, identifier) => {\n return getAuthStorageKeys(AuthTokenStorageKeys)(`${provider}`, identifier);\n};\nfunction getAuthStorageKeys(authKeys) {\n const keys = Object.values({ ...authKeys });\n return (prefix, identifier) => keys.reduce((acc, authKey) => ({\n ...acc,\n [authKey]: `${prefix}.${identifier}.${authKey}`,\n }), {});\n}\n\nexport { DefaultTokenStore, createKeysForAuthStorage, getAuthStorageKeys };\n//# sourceMappingURL=TokenStore.mjs.map\n","import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { getAuthStorageKeys } from '../tokenProvider/TokenStore.mjs';\nimport { OAuthStorageKeys } from './types.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst V5_HOSTED_UI_KEY = 'amplify-signin-with-hostedUI';\nconst name = 'CognitoIdentityServiceProvider';\nclass DefaultOAuthStore {\n constructor(keyValueStorage) {\n this.keyValueStorage = keyValueStorage;\n }\n async clearOAuthInflightData() {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n await Promise.all([\n this.keyValueStorage.removeItem(authKeys.inflightOAuth),\n this.keyValueStorage.removeItem(authKeys.oauthPKCE),\n this.keyValueStorage.removeItem(authKeys.oauthState),\n ]);\n }\n async clearOAuthData() {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n await this.clearOAuthInflightData();\n await this.keyValueStorage.removeItem(V5_HOSTED_UI_KEY); // remove in case a customer migrated an App from v5 to v6\n return this.keyValueStorage.removeItem(authKeys.oauthSignIn);\n }\n loadOAuthState() {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n return this.keyValueStorage.getItem(authKeys.oauthState);\n }\n storeOAuthState(state) {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n return this.keyValueStorage.setItem(authKeys.oauthState, state);\n }\n loadPKCE() {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n return this.keyValueStorage.getItem(authKeys.oauthPKCE);\n }\n storePKCE(pkce) {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n return this.keyValueStorage.setItem(authKeys.oauthPKCE, pkce);\n }\n setAuthConfig(authConfigParam) {\n this.cognitoConfig = authConfigParam;\n }\n async loadOAuthInFlight() {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n return ((await this.keyValueStorage.getItem(authKeys.inflightOAuth)) === 'true');\n }\n async storeOAuthInFlight(inflight) {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n await this.keyValueStorage.setItem(authKeys.inflightOAuth, `${inflight}`);\n }\n async loadOAuthSignIn() {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n const isLegacyHostedUISignIn = await this.keyValueStorage.getItem(V5_HOSTED_UI_KEY);\n const [isOAuthSignIn, preferPrivateSession] = (await this.keyValueStorage.getItem(authKeys.oauthSignIn))?.split(',') ??\n [];\n return {\n isOAuthSignIn: isOAuthSignIn === 'true' || isLegacyHostedUISignIn === 'true',\n preferPrivateSession: preferPrivateSession === 'true',\n };\n }\n async storeOAuthSignIn(oauthSignIn, preferPrivateSession = false) {\n assertTokenProviderConfig(this.cognitoConfig);\n const authKeys = createKeysForAuthStorage(name, this.cognitoConfig.userPoolClientId);\n await this.keyValueStorage.setItem(authKeys.oauthSignIn, `${oauthSignIn},${preferPrivateSession}`);\n }\n}\nconst createKeysForAuthStorage = (provider, identifier) => {\n return getAuthStorageKeys(OAuthStorageKeys)(provider, identifier);\n};\n\nexport { DefaultOAuthStore };\n//# sourceMappingURL=signInWithRedirectStore.mjs.map\n","import { defaultStorage } from '@aws-amplify/core';\nimport { DefaultOAuthStore } from '../signInWithRedirectStore.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst oAuthStore = new DefaultOAuthStore(defaultStorage);\n\nexport { oAuthStore };\n//# sourceMappingURL=oAuthStore.mjs.map\n","import { Hub } from '@aws-amplify/core';\nimport { isBrowser, assertTokenProviderConfig, isTokenExpired, AMPLIFY_SYMBOL, AmplifyErrorCode } from '@aws-amplify/core/internals/utils';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { oAuthStore } from '../utils/oauth/oAuthStore.mjs';\nimport { addInflightPromise } from '../utils/oauth/inflightPromise.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nclass TokenOrchestrator {\n constructor() {\n this.waitForInflightOAuth = isBrowser()\n ? async () => {\n if (!(await oAuthStore.loadOAuthInFlight())) {\n return;\n }\n if (this.inflightPromise) {\n return this.inflightPromise;\n }\n // when there is valid oauth config and there is an inflight oauth flow, try\n // to block async calls that require fetching tokens before the oauth flow completes\n // e.g. getCurrentUser, fetchAuthSession etc.\n this.inflightPromise = new Promise((resolve, _reject) => {\n addInflightPromise(resolve);\n });\n return this.inflightPromise;\n }\n : async () => {\n // no-op for non-browser environments\n };\n }\n setAuthConfig(authConfig) {\n oAuthStore.setAuthConfig(authConfig.Cognito);\n this.authConfig = authConfig;\n }\n setTokenRefresher(tokenRefresher) {\n this.tokenRefresher = tokenRefresher;\n }\n setAuthTokenStore(tokenStore) {\n this.tokenStore = tokenStore;\n }\n getTokenStore() {\n if (!this.tokenStore) {\n throw new AuthError({\n name: 'EmptyTokenStoreException',\n message: 'TokenStore not set',\n });\n }\n return this.tokenStore;\n }\n getTokenRefresher() {\n if (!this.tokenRefresher) {\n throw new AuthError({\n name: 'EmptyTokenRefresherException',\n message: 'TokenRefresher not set',\n });\n }\n return this.tokenRefresher;\n }\n async getTokens(options) {\n let tokens;\n try {\n assertTokenProviderConfig(this.authConfig?.Cognito);\n }\n catch (_err) {\n // Token provider not configured\n return null;\n }\n await this.waitForInflightOAuth();\n this.inflightPromise = undefined;\n tokens = await this.getTokenStore().loadTokens();\n const username = await this.getTokenStore().getLastAuthUser();\n if (tokens === null) {\n return null;\n }\n const idTokenExpired = !!tokens?.idToken &&\n isTokenExpired({\n expiresAt: (tokens.idToken?.payload?.exp ?? 0) * 1000,\n clockDrift: tokens.clockDrift ?? 0,\n });\n const accessTokenExpired = isTokenExpired({\n expiresAt: (tokens.accessToken?.payload?.exp ?? 0) * 1000,\n clockDrift: tokens.clockDrift ?? 0,\n });\n if (options?.forceRefresh || idTokenExpired || accessTokenExpired) {\n tokens = await this.refreshTokens({\n tokens,\n username,\n });\n if (tokens === null) {\n return null;\n }\n }\n return {\n accessToken: tokens?.accessToken,\n idToken: tokens?.idToken,\n signInDetails: tokens?.signInDetails,\n };\n }\n async refreshTokens({ tokens, username, }) {\n try {\n const { signInDetails } = tokens;\n const newTokens = await this.getTokenRefresher()({\n tokens,\n authConfig: this.authConfig,\n username,\n });\n newTokens.signInDetails = signInDetails;\n await this.setTokens({ tokens: newTokens });\n Hub.dispatch('auth', { event: 'tokenRefresh' }, 'Auth', AMPLIFY_SYMBOL);\n return newTokens;\n }\n catch (err) {\n return this.handleErrors(err);\n }\n }\n handleErrors(err) {\n assertServiceError(err);\n if (err.name !== AmplifyErrorCode.NetworkError) {\n // TODO(v6): Check errors on client\n this.clearTokens();\n }\n Hub.dispatch('auth', {\n event: 'tokenRefresh_failure',\n data: { error: err },\n }, 'Auth', AMPLIFY_SYMBOL);\n if (err.name.startsWith('NotAuthorizedException')) {\n return null;\n }\n throw err;\n }\n async setTokens({ tokens }) {\n return this.getTokenStore().storeTokens(tokens);\n }\n async clearTokens() {\n return this.getTokenStore().clearTokens();\n }\n getDeviceMetadata(username) {\n return this.getTokenStore().getDeviceMetadata(username);\n }\n clearDeviceMetadata(username) {\n return this.getTokenStore().clearDeviceMetadata(username);\n }\n setOAuthMetadata(metadata) {\n return this.getTokenStore().setOAuthMetadata(metadata);\n }\n getOAuthMetadata() {\n return this.getTokenStore().getOAuthMetadata();\n }\n}\n\nexport { TokenOrchestrator };\n//# sourceMappingURL=TokenOrchestrator.mjs.map\n","import { defaultStorage } from '@aws-amplify/core';\nimport { refreshAuthTokens } from '../utils/refreshAuthTokens.mjs';\nimport { DefaultTokenStore } from './TokenStore.mjs';\nimport { TokenOrchestrator } from './TokenOrchestrator.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nclass CognitoUserPoolsTokenProvider {\n constructor() {\n this.authTokenStore = new DefaultTokenStore();\n this.authTokenStore.setKeyValueStorage(defaultStorage);\n this.tokenOrchestrator = new TokenOrchestrator();\n this.tokenOrchestrator.setAuthTokenStore(this.authTokenStore);\n this.tokenOrchestrator.setTokenRefresher(refreshAuthTokens);\n }\n getTokens({ forceRefresh } = { forceRefresh: false }) {\n return this.tokenOrchestrator.getTokens({ forceRefresh });\n }\n setKeyValueStorage(keyValueStorage) {\n this.authTokenStore.setKeyValueStorage(keyValueStorage);\n }\n setAuthConfig(authConfig) {\n this.authTokenStore.setAuthConfig(authConfig);\n this.tokenOrchestrator.setAuthConfig(authConfig);\n }\n}\n\nexport { CognitoUserPoolsTokenProvider };\n//# sourceMappingURL=CognitoUserPoolsTokenProvider.mjs.map\n","import { CognitoUserPoolsTokenProvider } from './CognitoUserPoolsTokenProvider.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * The default provider for the JWT access token and ID token issued from the configured Cognito user pool. It manages\n * the refresh and storage of the tokens. It stores the tokens in `window.localStorage` if available, and falls back to\n * in-memory storage if not.\n */\nconst cognitoUserPoolsTokenProvider = new CognitoUserPoolsTokenProvider();\nconst { tokenOrchestrator } = cognitoUserPoolsTokenProvider;\n\nexport { cognitoUserPoolsTokenProvider, tokenOrchestrator };\n//# sourceMappingURL=tokenProvider.mjs.map\n","import { decodeJWT, AmplifyError } from '@aws-amplify/core/internals/utils';\nimport { tokenOrchestrator } from './tokenProvider.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nasync function cacheCognitoTokens(AuthenticationResult) {\n if (AuthenticationResult.AccessToken) {\n const accessToken = decodeJWT(AuthenticationResult.AccessToken);\n const accessTokenIssuedAtInMillis = (accessToken.payload.iat || 0) * 1000;\n const currentTime = new Date().getTime();\n const clockDrift = accessTokenIssuedAtInMillis > 0\n ? accessTokenIssuedAtInMillis - currentTime\n : 0;\n let idToken;\n let refreshToken;\n let deviceMetadata;\n if (AuthenticationResult.RefreshToken) {\n refreshToken = AuthenticationResult.RefreshToken;\n }\n if (AuthenticationResult.IdToken) {\n idToken = decodeJWT(AuthenticationResult.IdToken);\n }\n if (AuthenticationResult?.NewDeviceMetadata) {\n deviceMetadata = AuthenticationResult.NewDeviceMetadata;\n }\n const tokens = {\n accessToken,\n idToken,\n refreshToken,\n clockDrift,\n deviceMetadata,\n username: AuthenticationResult.username,\n };\n if (AuthenticationResult?.signInDetails) {\n tokens.signInDetails = AuthenticationResult.signInDetails;\n }\n await tokenOrchestrator.setTokens({\n tokens,\n });\n }\n else {\n // This would be a service error\n throw new AmplifyError({\n message: 'Invalid tokens',\n name: 'InvalidTokens',\n recoverySuggestion: 'Check Cognito UserPool settings',\n });\n }\n}\n\nexport { cacheCognitoTokens };\n//# sourceMappingURL=cacheTokens.mjs.map\n","import { Hub } from '@aws-amplify/core';\nimport { AMPLIFY_SYMBOL } from '@aws-amplify/core/internals/utils';\nimport { getCurrentUser } from '../apis/getCurrentUser.mjs';\nimport { USER_UNAUTHENTICATED_EXCEPTION, UNEXPECTED_SIGN_IN_INTERRUPTION_EXCEPTION } from '../../../errors/constants.mjs';\nimport { AuthError } from '../../../errors/AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst ERROR_MESSAGE = 'Unable to get user session following successful sign-in.';\nconst dispatchSignedInHubEvent = async () => {\n try {\n Hub.dispatch('auth', {\n event: 'signedIn',\n data: await getCurrentUser(),\n }, 'Auth', AMPLIFY_SYMBOL);\n }\n catch (error) {\n if (error.name === USER_UNAUTHENTICATED_EXCEPTION) {\n throw new AuthError({\n name: UNEXPECTED_SIGN_IN_INTERRUPTION_EXCEPTION,\n message: ERROR_MESSAGE,\n recoverySuggestion: 'This most likely is due to auth tokens not being persisted. If you are using cookie store, please ensure cookies can be correctly set from your server.',\n });\n }\n throw error;\n }\n};\n\nexport { ERROR_MESSAGE, dispatchSignedInHubEvent };\n//# sourceMappingURL=dispatchSignedInHubEvent.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction defaultState() {\n return {\n active: false,\n };\n}\nconst autoSignInReducer = (state, action) => {\n switch (action.type) {\n case 'SET_USERNAME':\n return {\n ...state,\n username: action.value,\n };\n case 'SET_SESSION':\n return {\n ...state,\n session: action.value,\n };\n case 'START':\n return {\n ...state,\n active: true,\n };\n case 'RESET':\n return defaultState();\n default:\n return state;\n }\n};\nconst createAutoSignInStore = (reducer) => {\n let currentState = reducer(defaultState(), { type: 'RESET' });\n return {\n getState: () => currentState,\n dispatch: action => {\n currentState = reducer(currentState, action);\n },\n };\n};\nconst autoSignInStore = createAutoSignInStore(autoSignInReducer);\n\nexport { autoSignInStore };\n//# sourceMappingURL=autoSignInStore.mjs.map\n","import { syncSessionStorage } from '@aws-amplify/core';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// Minutes until stored session invalidates is defaulted to 3 minutes\n// to maintain parity with Amazon Cognito user pools API behavior\nconst MS_TO_EXPIRY = 3 * 60 * 1000;\nconst TGT_STATE = 'CognitoSignInState';\nconst SIGN_IN_STATE_KEYS = {\n username: `${TGT_STATE}.username`,\n challengeName: `${TGT_STATE}.challengeName`,\n signInSession: `${TGT_STATE}.signInSession`,\n expiry: `${TGT_STATE}.expiry`,\n};\nconst signInReducer = (state, action) => {\n switch (action.type) {\n case 'SET_SIGN_IN_SESSION':\n persistSignInState({ signInSession: action.value });\n return {\n ...state,\n signInSession: action.value,\n };\n case 'SET_SIGN_IN_STATE':\n persistSignInState(action.value);\n return {\n ...action.value,\n };\n case 'SET_CHALLENGE_NAME':\n persistSignInState({ challengeName: action.value });\n return {\n ...state,\n challengeName: action.value,\n };\n case 'SET_USERNAME':\n persistSignInState({ username: action.value });\n return {\n ...state,\n username: action.value,\n };\n case 'SET_INITIAL_STATE':\n return getInitialState();\n case 'RESET_STATE':\n clearPersistedSignInState();\n return getDefaultState();\n // this state is never reachable\n default:\n return state;\n }\n};\nconst isExpired = (expiryDate) => {\n const expiryTimestamp = Number(expiryDate);\n const currentTimestamp = Date.now();\n return expiryTimestamp <= currentTimestamp;\n};\nconst resetActiveSignInState = () => {\n signInStore.dispatch({ type: 'RESET_STATE' });\n};\nconst clearPersistedSignInState = () => {\n for (const stateKey of Object.values(SIGN_IN_STATE_KEYS)) {\n syncSessionStorage.removeItem(stateKey);\n }\n};\nconst getDefaultState = () => ({\n username: undefined,\n challengeName: undefined,\n signInSession: undefined,\n});\n// Hydrate signInStore from syncSessionStorage if the session has not expired\nconst getInitialState = () => {\n const expiry = syncSessionStorage.getItem(SIGN_IN_STATE_KEYS.expiry);\n if (!expiry || isExpired(expiry)) {\n clearPersistedSignInState();\n return getDefaultState();\n }\n const username = syncSessionStorage.getItem(SIGN_IN_STATE_KEYS.username) ?? undefined;\n const challengeName = (syncSessionStorage.getItem(SIGN_IN_STATE_KEYS.challengeName) ?? undefined);\n const signInSession = syncSessionStorage.getItem(SIGN_IN_STATE_KEYS.signInSession) ?? undefined;\n return {\n username,\n challengeName,\n signInSession,\n };\n};\nconst createStore = reducer => {\n let currentState = reducer(getDefaultState(), { type: 'SET_INITIAL_STATE' });\n return {\n getState: () => currentState,\n dispatch: action => {\n currentState = reducer(currentState, action);\n },\n };\n};\nconst signInStore = createStore(signInReducer);\nfunction setActiveSignInState(state) {\n signInStore.dispatch({\n type: 'SET_SIGN_IN_STATE',\n value: state,\n });\n}\n// Save local state into Session Storage\nconst persistSignInState = ({ challengeName, signInSession, username, }) => {\n username && syncSessionStorage.setItem(SIGN_IN_STATE_KEYS.username, username);\n challengeName &&\n syncSessionStorage.setItem(SIGN_IN_STATE_KEYS.challengeName, challengeName);\n if (signInSession) {\n syncSessionStorage.setItem(SIGN_IN_STATE_KEYS.signInSession, signInSession);\n // Updates expiry when session is passed\n syncSessionStorage.setItem(SIGN_IN_STATE_KEYS.expiry, String(Date.now() + MS_TO_EXPIRY));\n }\n};\n\nexport { persistSignInState, resetActiveSignInState, setActiveSignInState, signInStore };\n//# sourceMappingURL=signInStore.mjs.map\n","import { createAssertionFunction, AmplifyError, AmplifyErrorCode } from '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nclass PasskeyError extends AmplifyError {\n constructor(params) {\n super(params);\n // Hack for making the custom error class work when transpiled to es5\n // TODO: Delete the following 2 lines after we change the build target to >= es2015\n this.constructor = PasskeyError;\n Object.setPrototypeOf(this, PasskeyError.prototype);\n }\n}\nvar PasskeyErrorCode;\n(function (PasskeyErrorCode) {\n // not supported\n PasskeyErrorCode[\"PasskeyNotSupported\"] = \"PasskeyNotSupported\";\n // duplicate passkey\n PasskeyErrorCode[\"PasskeyAlreadyExists\"] = \"PasskeyAlreadyExists\";\n // misconfigurations\n PasskeyErrorCode[\"InvalidPasskeyRegistrationOptions\"] = \"InvalidPasskeyRegistrationOptions\";\n PasskeyErrorCode[\"InvalidPasskeyAuthenticationOptions\"] = \"InvalidPasskeyAuthenticationOptions\";\n PasskeyErrorCode[\"RelyingPartyMismatch\"] = \"RelyingPartyMismatch\";\n // failed credential creation / retrieval\n PasskeyErrorCode[\"PasskeyRegistrationFailed\"] = \"PasskeyRegistrationFailed\";\n PasskeyErrorCode[\"PasskeyRetrievalFailed\"] = \"PasskeyRetrievalFailed\";\n // cancel / aborts\n PasskeyErrorCode[\"PasskeyRegistrationCanceled\"] = \"PasskeyRegistrationCanceled\";\n PasskeyErrorCode[\"PasskeyAuthenticationCanceled\"] = \"PasskeyAuthenticationCanceled\";\n PasskeyErrorCode[\"PasskeyOperationAborted\"] = \"PasskeyOperationAborted\";\n})(PasskeyErrorCode || (PasskeyErrorCode = {}));\nconst notSupportedRecoverySuggestion = 'Passkeys may not be supported on this device. Ensure your application is running in a secure context (HTTPS) and Web Authentication API is supported.';\nconst abortOrCancelRecoverySuggestion = 'User may have canceled the ceremony or another interruption has occurred. Check underlying error for details.';\nconst misconfigurationRecoverySuggestion = 'Ensure your user pool is configured to support the WEB_AUTHN as an authentication factor.';\nconst passkeyErrorMap = {\n [PasskeyErrorCode.PasskeyNotSupported]: {\n message: 'Passkeys may not be supported on this device.',\n recoverySuggestion: notSupportedRecoverySuggestion,\n },\n [PasskeyErrorCode.InvalidPasskeyRegistrationOptions]: {\n message: 'Invalid passkey registration options.',\n recoverySuggestion: misconfigurationRecoverySuggestion,\n },\n [PasskeyErrorCode.InvalidPasskeyAuthenticationOptions]: {\n message: 'Invalid passkey authentication options.',\n recoverySuggestion: misconfigurationRecoverySuggestion,\n },\n [PasskeyErrorCode.PasskeyRegistrationFailed]: {\n message: 'Device failed to create passkey.',\n recoverySuggestion: notSupportedRecoverySuggestion,\n },\n [PasskeyErrorCode.PasskeyRetrievalFailed]: {\n message: 'Device failed to retrieve passkey.',\n recoverySuggestion: 'Passkeys may not be available on this device. Try an alternative authentication factor like PASSWORD, EMAIL_OTP, or SMS_OTP.',\n },\n [PasskeyErrorCode.PasskeyAlreadyExists]: {\n message: 'Passkey already exists in authenticator.',\n recoverySuggestion: 'Proceed with existing passkey or try again after deleting the credential.',\n },\n [PasskeyErrorCode.PasskeyRegistrationCanceled]: {\n message: 'Passkey registration ceremony has been canceled.',\n recoverySuggestion: abortOrCancelRecoverySuggestion,\n },\n [PasskeyErrorCode.PasskeyAuthenticationCanceled]: {\n message: 'Passkey authentication ceremony has been canceled.',\n recoverySuggestion: abortOrCancelRecoverySuggestion,\n },\n [PasskeyErrorCode.PasskeyOperationAborted]: {\n message: 'Passkey operation has been aborted.',\n recoverySuggestion: abortOrCancelRecoverySuggestion,\n },\n [PasskeyErrorCode.RelyingPartyMismatch]: {\n message: 'Relying party does not match current domain.',\n recoverySuggestion: 'Ensure relying party identifier matches current domain.',\n },\n};\nconst assertPasskeyError = createAssertionFunction(passkeyErrorMap, PasskeyError);\n/**\n * Handle Passkey Authentication Errors\n * https://w3c.github.io/webauthn/#sctn-get-request-exceptions\n *\n * @param err unknown\n * @returns PasskeyError\n */\nconst handlePasskeyAuthenticationError = (err) => {\n if (err instanceof PasskeyError) {\n return err;\n }\n if (err instanceof Error) {\n if (err.name === 'NotAllowedError') {\n const { message, recoverySuggestion } = passkeyErrorMap[PasskeyErrorCode.PasskeyAuthenticationCanceled];\n return new PasskeyError({\n name: PasskeyErrorCode.PasskeyAuthenticationCanceled,\n message,\n recoverySuggestion,\n underlyingError: err,\n });\n }\n }\n return handlePasskeyError(err);\n};\n/**\n * Handle Passkey Registration Errors\n * https://w3c.github.io/webauthn/#sctn-create-request-exceptions\n *\n * @param err unknown\n * @returns PasskeyError\n */\nconst handlePasskeyRegistrationError = (err) => {\n if (err instanceof PasskeyError) {\n return err;\n }\n if (err instanceof Error) {\n // Duplicate Passkey\n if (err.name === 'InvalidStateError') {\n const { message, recoverySuggestion } = passkeyErrorMap[PasskeyErrorCode.PasskeyAlreadyExists];\n return new PasskeyError({\n name: PasskeyErrorCode.PasskeyAlreadyExists,\n message,\n recoverySuggestion,\n underlyingError: err,\n });\n }\n // User Cancels Ceremony / Generic Catch All\n if (err.name === 'NotAllowedError') {\n const { message, recoverySuggestion } = passkeyErrorMap[PasskeyErrorCode.PasskeyRegistrationCanceled];\n return new PasskeyError({\n name: PasskeyErrorCode.PasskeyRegistrationCanceled,\n message,\n recoverySuggestion,\n underlyingError: err,\n });\n }\n }\n return handlePasskeyError(err);\n};\n/**\n * Handles Overlapping Passkey Errors Between Registration & Authentication\n * https://w3c.github.io/webauthn/#sctn-create-request-exceptions\n * https://w3c.github.io/webauthn/#sctn-get-request-exceptions\n *\n * @param err unknown\n * @returns PasskeyError\n */\nconst handlePasskeyError = (err) => {\n if (err instanceof Error) {\n // Passkey Operation Aborted\n if (err.name === 'AbortError') {\n const { message, recoverySuggestion } = passkeyErrorMap[PasskeyErrorCode.PasskeyOperationAborted];\n return new PasskeyError({\n name: PasskeyErrorCode.PasskeyOperationAborted,\n message,\n recoverySuggestion,\n underlyingError: err,\n });\n }\n // Relying Party / Domain Mismatch\n if (err.name === 'SecurityError') {\n const { message, recoverySuggestion } = passkeyErrorMap[PasskeyErrorCode.RelyingPartyMismatch];\n return new PasskeyError({\n name: PasskeyErrorCode.RelyingPartyMismatch,\n message,\n recoverySuggestion,\n underlyingError: err,\n });\n }\n }\n return new PasskeyError({\n name: AmplifyErrorCode.Unknown,\n message: 'An unknown error has occurred.',\n underlyingError: err,\n });\n};\n\nexport { PasskeyError, PasskeyErrorCode, assertPasskeyError, handlePasskeyAuthenticationError, handlePasskeyRegistrationError };\n//# sourceMappingURL=errors.mjs.map\n","import { isBrowser } from '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Determines if passkey is supported in current context\n * Will return false if executed in non-secure context\n * @returns boolean\n */\nconst getIsPasskeySupported = () => {\n return (isBrowser() &&\n window.isSecureContext &&\n 'credentials' in navigator &&\n typeof window.PublicKeyCredential === 'function');\n};\n\nexport { getIsPasskeySupported };\n//# sourceMappingURL=getIsPasskeySupported.mjs.map\n","import { base64Encoder } from '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n// https://datatracker.ietf.org/doc/html/rfc4648#page-7\n/**\n * Converts an ArrayBuffer to a base64url encoded string\n * @param buffer - the ArrayBuffer instance of a Uint8Array\n * @returns string - a base64url encoded string\n */\nconst convertArrayBufferToBase64Url = (buffer) => {\n return base64Encoder.convert(new Uint8Array(buffer), {\n urlSafe: true,\n skipPadding: true,\n });\n};\n\nexport { convertArrayBufferToBase64Url };\n//# sourceMappingURL=convertArrayBufferToBase64Url.mjs.map\n","import { base64Decoder } from '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Converts a base64url encoded string to an ArrayBuffer\n * @param base64url - a base64url encoded string\n * @returns ArrayBuffer\n */\nconst convertBase64UrlToArrayBuffer = (base64url) => {\n return Uint8Array.from(base64Decoder.convert(base64url, { urlSafe: true }), x => x.charCodeAt(0)).buffer;\n};\n\nexport { convertBase64UrlToArrayBuffer };\n//# sourceMappingURL=convertBase64UrlToArrayBuffer.mjs.map\n","import { convertArrayBufferToBase64Url } from '../../../foundation/convert/base64url/convertArrayBufferToBase64Url.mjs';\nimport { convertBase64UrlToArrayBuffer } from '../../../foundation/convert/base64url/convertBase64UrlToArrayBuffer.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Deserializes Public Key Credential Creation Options JSON\n * @param input PasskeyCreateOptionsJson\n * @returns PublicKeyCredentialCreationOptions\n */\nconst deserializeJsonToPkcCreationOptions = (input) => {\n const userIdBuffer = convertBase64UrlToArrayBuffer(input.user.id);\n const challengeBuffer = convertBase64UrlToArrayBuffer(input.challenge);\n const excludeCredentialsWithBuffer = (input.excludeCredentials || []).map(excludeCred => ({\n ...excludeCred,\n id: convertBase64UrlToArrayBuffer(excludeCred.id),\n }));\n return {\n ...input,\n excludeCredentials: excludeCredentialsWithBuffer,\n challenge: challengeBuffer,\n user: {\n ...input.user,\n id: userIdBuffer,\n },\n };\n};\n/**\n * Serializes a Public Key Credential With Attestation to JSON\n * @param input PasskeyCreateResult\n * @returns PasskeyCreateResultJson\n */\nconst serializePkcWithAttestationToJson = (input) => {\n const response = {\n clientDataJSON: convertArrayBufferToBase64Url(input.response.clientDataJSON),\n attestationObject: convertArrayBufferToBase64Url(input.response.attestationObject),\n transports: input.response.getTransports(),\n publicKeyAlgorithm: input.response.getPublicKeyAlgorithm(),\n authenticatorData: convertArrayBufferToBase64Url(input.response.getAuthenticatorData()),\n };\n const publicKey = input.response.getPublicKey();\n if (publicKey) {\n response.publicKey = convertArrayBufferToBase64Url(publicKey);\n }\n const resultJson = {\n type: input.type,\n id: input.id,\n rawId: convertArrayBufferToBase64Url(input.rawId),\n clientExtensionResults: input.getClientExtensionResults(),\n response,\n };\n if (input.authenticatorAttachment) {\n resultJson.authenticatorAttachment = input.authenticatorAttachment;\n }\n return resultJson;\n};\n/**\n * Deserializes Public Key Credential Get Options JSON\n * @param input PasskeyGetOptionsJson\n * @returns PublicKeyCredentialRequestOptions\n */\nconst deserializeJsonToPkcGetOptions = (input) => {\n const challengeBuffer = convertBase64UrlToArrayBuffer(input.challenge);\n const allowedCredentialsWithBuffer = (input.allowCredentials || []).map(allowedCred => ({\n ...allowedCred,\n id: convertBase64UrlToArrayBuffer(allowedCred.id),\n }));\n return {\n ...input,\n challenge: challengeBuffer,\n allowCredentials: allowedCredentialsWithBuffer,\n };\n};\n/**\n * Serializes a Public Key Credential With Attestation to JSON\n * @param input PasskeyGetResult\n * @returns PasskeyGetResultJson\n */\nconst serializePkcWithAssertionToJson = (input) => {\n const response = {\n clientDataJSON: convertArrayBufferToBase64Url(input.response.clientDataJSON),\n authenticatorData: convertArrayBufferToBase64Url(input.response.authenticatorData),\n signature: convertArrayBufferToBase64Url(input.response.signature),\n };\n if (input.response.userHandle) {\n response.userHandle = convertArrayBufferToBase64Url(input.response.userHandle);\n }\n const resultJson = {\n id: input.id,\n rawId: convertArrayBufferToBase64Url(input.rawId),\n type: input.type,\n clientExtensionResults: input.getClientExtensionResults(),\n response,\n };\n if (input.authenticatorAttachment) {\n resultJson.authenticatorAttachment = input.authenticatorAttachment;\n }\n return resultJson;\n};\n\nexport { deserializeJsonToPkcCreationOptions, deserializeJsonToPkcGetOptions, serializePkcWithAssertionToJson, serializePkcWithAttestationToJson };\n//# sourceMappingURL=serde.mjs.map\n","import { assertPasskeyError, PasskeyErrorCode } from '../errors.mjs';\nexport { assertValidCredentialCreationOptions } from './shared.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction assertCredentialIsPkcWithAuthenticatorAttestationResponse(credential) {\n assertPasskeyError(credential &&\n credential instanceof PublicKeyCredential &&\n credential.response instanceof AuthenticatorAttestationResponse, PasskeyErrorCode.PasskeyRegistrationFailed);\n}\nfunction assertCredentialIsPkcWithAuthenticatorAssertionResponse(credential) {\n assertPasskeyError(credential &&\n credential instanceof PublicKeyCredential &&\n credential.response instanceof AuthenticatorAssertionResponse, PasskeyErrorCode.PasskeyRetrievalFailed);\n}\n\nexport { assertCredentialIsPkcWithAuthenticatorAssertionResponse, assertCredentialIsPkcWithAuthenticatorAttestationResponse };\n//# sourceMappingURL=index.mjs.map\n","import { assertPasskeyError, PasskeyErrorCode, handlePasskeyAuthenticationError } from './errors.mjs';\nimport { getIsPasskeySupported } from './getIsPasskeySupported.mjs';\nimport { deserializeJsonToPkcGetOptions, serializePkcWithAssertionToJson } from './serde.mjs';\nimport { assertCredentialIsPkcWithAuthenticatorAssertionResponse } from './types/index.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst getPasskey = async (input) => {\n try {\n const isPasskeySupported = getIsPasskeySupported();\n assertPasskeyError(isPasskeySupported, PasskeyErrorCode.PasskeyNotSupported);\n const passkeyGetOptions = deserializeJsonToPkcGetOptions(input);\n const credential = await navigator.credentials.get({\n publicKey: passkeyGetOptions,\n });\n assertCredentialIsPkcWithAuthenticatorAssertionResponse(credential);\n return serializePkcWithAssertionToJson(credential);\n }\n catch (err) {\n throw handlePasskeyAuthenticationError(err);\n }\n};\n\nexport { getPasskey };\n//# sourceMappingURL=getPasskey.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createConfirmDeviceClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('ConfirmDevice'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createConfirmDeviceClient };\n//# sourceMappingURL=createConfirmDeviceClient.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst textEncoder = {\n convert(input) {\n return new TextEncoder().encode(input);\n },\n};\n\nexport { textEncoder };\n//# sourceMappingURL=index.mjs.map\n","/* eslint-disable */\n// @ts-nocheck -> BigInteger is already a vended utility\n// A small implementation of BigInteger based on http://www-cs-students.stanford.edu/~tjw/jsbn/\n//\n// All public methods have been removed except the following:\n// new BigInteger(a, b) (only radix 2, 4, 8, 16 and 32 supported)\n// toString (only radix 2, 4, 8, 16 and 32 supported)\n// negate\n// abs\n// compareTo\n// bitLength\n// mod\n// equals\n// add\n// subtract\n// multiply\n// divide\n// modPow\n/*\n * Copyright (c) 2003-2005 Tom Wu\n * All Rights Reserved.\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * \"Software\"), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS-IS\" AND WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY\n * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.\n *\n * IN NO EVENT SHALL TOM WU BE LIABLE FOR ANY SPECIAL, INCIDENTAL,\n * INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, OR ANY DAMAGES WHATSOEVER\n * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER OR NOT ADVISED OF\n * THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF LIABILITY, ARISING OUT\n * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n *\n * In addition, the following condition applies:\n *\n * All redistributions must retain an intact copy of this copyright notice\n * and disclaimer.\n */\n// (public) Constructor\nfunction BigInteger(a, b) {\n if (a != null)\n this.fromString(a, b);\n}\n// return new, unset BigInteger\nfunction nbi() {\n return new BigInteger(null, null);\n}\n// Bits per digit\nlet dbits;\n// JavaScript engine analysis\nconst canary = 0xdeadbeefcafe;\nconst j_lm = (canary & 0xffffff) === 0xefcafe;\n// am: Compute w_j += (x*this_i), propagate carries,\n// c is initial carry, returns final carry.\n// c < 3*dvalue, x < 2*dvalue, this_i < dvalue\n// We need to select the fastest one that works in this environment.\n// am1: use a single mult and divide to get the high bits,\n// max digit bits should be 26 because\n// max internal value = 2*dvalue^2-2*dvalue (< 2^53)\nfunction am1(i, x, w, j, c, n) {\n while (--n >= 0) {\n const v = x * this[i++] + w[j] + c;\n c = Math.floor(v / 0x4000000);\n w[j++] = v & 0x3ffffff;\n }\n return c;\n}\n// am2 avoids a big mult-and-extract completely.\n// Max digit bits should be <= 30 because we do bitwise ops\n// on values up to 2*hdvalue^2-hdvalue-1 (< 2^31)\nfunction am2(i, x, w, j, c, n) {\n const xl = x & 0x7fff;\n const xh = x >> 15;\n while (--n >= 0) {\n let l = this[i] & 0x7fff;\n const h = this[i++] >> 15;\n const m = xh * l + h * xl;\n l = xl * l + ((m & 0x7fff) << 15) + w[j] + (c & 0x3fffffff);\n c = (l >>> 30) + (m >>> 15) + xh * h + (c >>> 30);\n w[j++] = l & 0x3fffffff;\n }\n return c;\n}\n// Alternately, set max digit bits to 28 since some\n// browsers slow down when dealing with 32-bit numbers.\nfunction am3(i, x, w, j, c, n) {\n const xl = x & 0x3fff;\n const xh = x >> 14;\n while (--n >= 0) {\n let l = this[i] & 0x3fff;\n const h = this[i++] >> 14;\n const m = xh * l + h * xl;\n l = xl * l + ((m & 0x3fff) << 14) + w[j] + c;\n c = (l >> 28) + (m >> 14) + xh * h;\n w[j++] = l & 0xfffffff;\n }\n return c;\n}\nconst inBrowser = typeof navigator !== 'undefined';\nif (inBrowser && j_lm && navigator.appName === 'Microsoft Internet Explorer') {\n BigInteger.prototype.am = am2;\n dbits = 30;\n}\nelse if (inBrowser && j_lm && navigator.appName !== 'Netscape') {\n BigInteger.prototype.am = am1;\n dbits = 26;\n}\nelse {\n // Mozilla/Netscape seems to prefer am3\n BigInteger.prototype.am = am3;\n dbits = 28;\n}\nBigInteger.prototype.DB = dbits;\nBigInteger.prototype.DM = (1 << dbits) - 1;\nBigInteger.prototype.DV = 1 << dbits;\nconst BI_FP = 52;\nBigInteger.prototype.FV = Math.pow(2, BI_FP);\nBigInteger.prototype.F1 = BI_FP - dbits;\nBigInteger.prototype.F2 = 2 * dbits - BI_FP;\n// Digit conversions\nconst BI_RM = '0123456789abcdefghijklmnopqrstuvwxyz';\nconst BI_RC = [];\nlet rr, vv;\nrr = '0'.charCodeAt(0);\nfor (vv = 0; vv <= 9; ++vv)\n BI_RC[rr++] = vv;\nrr = 'a'.charCodeAt(0);\nfor (vv = 10; vv < 36; ++vv)\n BI_RC[rr++] = vv;\nrr = 'A'.charCodeAt(0);\nfor (vv = 10; vv < 36; ++vv)\n BI_RC[rr++] = vv;\nfunction int2char(n) {\n return BI_RM.charAt(n);\n}\nfunction intAt(s, i) {\n const c = BI_RC[s.charCodeAt(i)];\n return c == null ? -1 : c;\n}\n// (protected) copy this to r\nfunction bnpCopyTo(r) {\n for (let i = this.t - 1; i >= 0; --i)\n r[i] = this[i];\n r.t = this.t;\n r.s = this.s;\n}\n// (protected) set from integer value x, -DV <= x < DV\nfunction bnpFromInt(x) {\n this.t = 1;\n this.s = x < 0 ? -1 : 0;\n if (x > 0)\n this[0] = x;\n else if (x < -1)\n this[0] = x + this.DV;\n else\n this.t = 0;\n}\n// return bigint initialized to value\nfunction nbv(i) {\n const r = nbi();\n r.fromInt(i);\n return r;\n}\n// (protected) set from string and radix\nfunction bnpFromString(s, b) {\n let k;\n if (b === 16)\n k = 4;\n else if (b === 8)\n k = 3;\n else if (b === 2)\n k = 1;\n else if (b === 32)\n k = 5;\n else if (b === 4)\n k = 2;\n else\n throw new Error('Only radix 2, 4, 8, 16, 32 are supported');\n this.t = 0;\n this.s = 0;\n let i = s.length;\n let mi = false;\n let sh = 0;\n while (--i >= 0) {\n const x = intAt(s, i);\n if (x < 0) {\n if (s.charAt(i) === '-')\n mi = true;\n continue;\n }\n mi = false;\n if (sh === 0)\n this[this.t++] = x;\n else if (sh + k > this.DB) {\n this[this.t - 1] |= (x & ((1 << (this.DB - sh)) - 1)) << sh;\n this[this.t++] = x >> (this.DB - sh);\n }\n else\n this[this.t - 1] |= x << sh;\n sh += k;\n if (sh >= this.DB)\n sh -= this.DB;\n }\n this.clamp();\n if (mi)\n BigInteger.ZERO.subTo(this, this);\n}\n// (protected) clamp off excess high words\nfunction bnpClamp() {\n const c = this.s & this.DM;\n while (this.t > 0 && this[this.t - 1] == c)\n --this.t;\n}\n// (public) return string representation in given radix\nfunction bnToString(b) {\n if (this.s < 0)\n return '-' + this.negate().toString(b);\n let k;\n if (b == 16)\n k = 4;\n else if (b === 8)\n k = 3;\n else if (b === 2)\n k = 1;\n else if (b === 32)\n k = 5;\n else if (b === 4)\n k = 2;\n else\n throw new Error('Only radix 2, 4, 8, 16, 32 are supported');\n const km = (1 << k) - 1;\n let d;\n let m = false;\n let r = '';\n let i = this.t;\n let p = this.DB - ((i * this.DB) % k);\n if (i-- > 0) {\n if (p < this.DB && (d = this[i] >> p) > 0) {\n m = true;\n r = int2char(d);\n }\n while (i >= 0) {\n if (p < k) {\n d = (this[i] & ((1 << p) - 1)) << (k - p);\n d |= this[--i] >> (p += this.DB - k);\n }\n else {\n d = (this[i] >> (p -= k)) & km;\n if (p <= 0) {\n p += this.DB;\n --i;\n }\n }\n if (d > 0)\n m = true;\n if (m)\n r += int2char(d);\n }\n }\n return m ? r : '0';\n}\n// (public) -this\nfunction bnNegate() {\n const r = nbi();\n BigInteger.ZERO.subTo(this, r);\n return r;\n}\n// (public) |this|\nfunction bnAbs() {\n return this.s < 0 ? this.negate() : this;\n}\n// (public) return + if this > a, - if this < a, 0 if equal\nfunction bnCompareTo(a) {\n let r = this.s - a.s;\n if (r != 0)\n return r;\n let i = this.t;\n r = i - a.t;\n if (r != 0)\n return this.s < 0 ? -r : r;\n while (--i >= 0)\n if ((r = this[i] - a[i]) != 0)\n return r;\n return 0;\n}\n// returns bit length of the integer x\nfunction nbits(x) {\n let r = 1;\n let t;\n if ((t = x >>> 16) !== 0) {\n x = t;\n r += 16;\n }\n if ((t = x >> 8) !== 0) {\n x = t;\n r += 8;\n }\n if ((t = x >> 4) !== 0) {\n x = t;\n r += 4;\n }\n if ((t = x >> 2) !== 0) {\n x = t;\n r += 2;\n }\n if ((t = x >> 1) !== 0) {\n x = t;\n r += 1;\n }\n return r;\n}\n// (public) return the number of bits in \"this\"\nfunction bnBitLength() {\n if (this.t <= 0)\n return 0;\n return this.DB * (this.t - 1) + nbits(this[this.t - 1] ^ (this.s & this.DM));\n}\n// (protected) r = this << n*DB\nfunction bnpDLShiftTo(n, r) {\n let i;\n for (i = this.t - 1; i >= 0; --i)\n r[i + n] = this[i];\n for (i = n - 1; i >= 0; --i)\n r[i] = 0;\n r.t = this.t + n;\n r.s = this.s;\n}\n// (protected) r = this >> n*DB\nfunction bnpDRShiftTo(n, r) {\n for (let i = n; i < this.t; ++i)\n r[i - n] = this[i];\n r.t = Math.max(this.t - n, 0);\n r.s = this.s;\n}\n// (protected) r = this << n\nfunction bnpLShiftTo(n, r) {\n const bs = n % this.DB;\n const cbs = this.DB - bs;\n const bm = (1 << cbs) - 1;\n const ds = Math.floor(n / this.DB);\n let c = (this.s << bs) & this.DM;\n let i;\n for (i = this.t - 1; i >= 0; --i) {\n r[i + ds + 1] = (this[i] >> cbs) | c;\n c = (this[i] & bm) << bs;\n }\n for (i = ds - 1; i >= 0; --i)\n r[i] = 0;\n r[ds] = c;\n r.t = this.t + ds + 1;\n r.s = this.s;\n r.clamp();\n}\n// (protected) r = this >> n\nfunction bnpRShiftTo(n, r) {\n r.s = this.s;\n const ds = Math.floor(n / this.DB);\n if (ds >= this.t) {\n r.t = 0;\n return;\n }\n const bs = n % this.DB;\n const cbs = this.DB - bs;\n const bm = (1 << bs) - 1;\n r[0] = this[ds] >> bs;\n for (let i = ds + 1; i < this.t; ++i) {\n r[i - ds - 1] |= (this[i] & bm) << cbs;\n r[i - ds] = this[i] >> bs;\n }\n if (bs > 0)\n r[this.t - ds - 1] |= (this.s & bm) << cbs;\n r.t = this.t - ds;\n r.clamp();\n}\n// (protected) r = this - a\nfunction bnpSubTo(a, r) {\n let i = 0;\n let c = 0;\n const m = Math.min(a.t, this.t);\n while (i < m) {\n c += this[i] - a[i];\n r[i++] = c & this.DM;\n c >>= this.DB;\n }\n if (a.t < this.t) {\n c -= a.s;\n while (i < this.t) {\n c += this[i];\n r[i++] = c & this.DM;\n c >>= this.DB;\n }\n c += this.s;\n }\n else {\n c += this.s;\n while (i < a.t) {\n c -= a[i];\n r[i++] = c & this.DM;\n c >>= this.DB;\n }\n c -= a.s;\n }\n r.s = c < 0 ? -1 : 0;\n if (c < -1)\n r[i++] = this.DV + c;\n else if (c > 0)\n r[i++] = c;\n r.t = i;\n r.clamp();\n}\n// (protected) r = this * a, r != this,a (HAC 14.12)\n// \"this\" should be the larger one if appropriate.\nfunction bnpMultiplyTo(a, r) {\n const x = this.abs();\n const y = a.abs();\n let i = x.t;\n r.t = i + y.t;\n while (--i >= 0)\n r[i] = 0;\n for (i = 0; i < y.t; ++i)\n r[i + x.t] = x.am(0, y[i], r, i, 0, x.t);\n r.s = 0;\n r.clamp();\n if (this.s !== a.s)\n BigInteger.ZERO.subTo(r, r);\n}\n// (protected) r = this^2, r != this (HAC 14.16)\nfunction bnpSquareTo(r) {\n const x = this.abs();\n let i = (r.t = 2 * x.t);\n while (--i >= 0)\n r[i] = 0;\n for (i = 0; i < x.t - 1; ++i) {\n const c = x.am(i, x[i], r, 2 * i, 0, 1);\n if ((r[i + x.t] += x.am(i + 1, 2 * x[i], r, 2 * i + 1, c, x.t - i - 1)) >=\n x.DV) {\n r[i + x.t] -= x.DV;\n r[i + x.t + 1] = 1;\n }\n }\n if (r.t > 0)\n r[r.t - 1] += x.am(i, x[i], r, 2 * i, 0, 1);\n r.s = 0;\n r.clamp();\n}\n// (protected) divide this by m, quotient and remainder to q, r (HAC 14.20)\n// r != q, this != m. q or r may be null.\nfunction bnpDivRemTo(m, q, r) {\n const pm = m.abs();\n if (pm.t <= 0)\n return;\n const pt = this.abs();\n if (pt.t < pm.t) {\n if (q != null)\n q.fromInt(0);\n if (r != null)\n this.copyTo(r);\n return;\n }\n if (r === null)\n r = nbi();\n const y = nbi();\n const ts = this.s;\n const ms = m.s;\n const nsh = this.DB - nbits(pm[pm.t - 1]);\n // normalize modulus\n if (nsh > 0) {\n pm.lShiftTo(nsh, y);\n pt.lShiftTo(nsh, r);\n }\n else {\n pm.copyTo(y);\n pt.copyTo(r);\n }\n const ys = y.t;\n const y0 = y[ys - 1];\n if (y0 === 0)\n return;\n const yt = y0 * (1 << this.F1) + (ys > 1 ? y[ys - 2] >> this.F2 : 0);\n const d1 = this.FV / yt;\n const d2 = (1 << this.F1) / yt;\n const e = 1 << this.F2;\n let i = r.t;\n let j = i - ys;\n const t = q === null ? nbi() : q;\n y.dlShiftTo(j, t);\n if (r.compareTo(t) >= 0) {\n r[r.t++] = 1;\n r.subTo(t, r);\n }\n BigInteger.ONE.dlShiftTo(ys, t);\n t.subTo(y, y);\n // \"negative\" y so we can replace sub with am later\n while (y.t < ys)\n y[y.t++] = 0;\n while (--j >= 0) {\n // Estimate quotient digit\n let qd = r[--i] === y0 ? this.DM : Math.floor(r[i] * d1 + (r[i - 1] + e) * d2);\n if ((r[i] += y.am(0, qd, r, j, 0, ys)) < qd) {\n // Try it out\n y.dlShiftTo(j, t);\n r.subTo(t, r);\n while (r[i] < --qd)\n r.subTo(t, r);\n }\n }\n if (q !== null) {\n r.drShiftTo(ys, q);\n if (ts !== ms)\n BigInteger.ZERO.subTo(q, q);\n }\n r.t = ys;\n r.clamp();\n if (nsh > 0)\n r.rShiftTo(nsh, r);\n // Denormalize remainder\n if (ts < 0)\n BigInteger.ZERO.subTo(r, r);\n}\n// (public) this mod a\nfunction bnMod(a) {\n const r = nbi();\n this.abs().divRemTo(a, null, r);\n if (this.s < 0 && r.compareTo(BigInteger.ZERO) > 0)\n a.subTo(r, r);\n return r;\n}\n// (protected) return \"-1/this % 2^DB\"; useful for Mont. reduction\n// justification:\n// xy == 1 (mod m)\n// xy = 1+km\n// xy(2-xy) = (1+km)(1-km)\n// x[y(2-xy)] = 1-k^2m^2\n// x[y(2-xy)] == 1 (mod m^2)\n// if y is 1/x mod m, then y(2-xy) is 1/x mod m^2\n// should reduce x and y(2-xy) by m^2 at each step to keep size bounded.\n// JS multiply \"overflows\" differently from C/C++, so care is needed here.\nfunction bnpInvDigit() {\n if (this.t < 1)\n return 0;\n const x = this[0];\n if ((x & 1) === 0)\n return 0;\n let y = x & 3;\n // y == 1/x mod 2^2\n y = (y * (2 - (x & 0xf) * y)) & 0xf;\n // y == 1/x mod 2^4\n y = (y * (2 - (x & 0xff) * y)) & 0xff;\n // y == 1/x mod 2^8\n y = (y * (2 - (((x & 0xffff) * y) & 0xffff))) & 0xffff;\n // y == 1/x mod 2^16\n // last step - calculate inverse mod DV directly;\n // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints\n y = (y * (2 - ((x * y) % this.DV))) % this.DV;\n // y == 1/x mod 2^dbits\n // we really want the negative inverse, and -DV < y < DV\n return y > 0 ? this.DV - y : -y;\n}\nfunction bnEquals(a) {\n return this.compareTo(a) === 0;\n}\n// (protected) r = this + a\nfunction bnpAddTo(a, r) {\n let i = 0;\n let c = 0;\n const m = Math.min(a.t, this.t);\n while (i < m) {\n c += this[i] + a[i];\n r[i++] = c & this.DM;\n c >>= this.DB;\n }\n if (a.t < this.t) {\n c += a.s;\n while (i < this.t) {\n c += this[i];\n r[i++] = c & this.DM;\n c >>= this.DB;\n }\n c += this.s;\n }\n else {\n c += this.s;\n while (i < a.t) {\n c += a[i];\n r[i++] = c & this.DM;\n c >>= this.DB;\n }\n c += a.s;\n }\n r.s = c < 0 ? -1 : 0;\n if (c > 0)\n r[i++] = c;\n else if (c < -1)\n r[i++] = this.DV + c;\n r.t = i;\n r.clamp();\n}\n// (public) this + a\nfunction bnAdd(a) {\n const r = nbi();\n this.addTo(a, r);\n return r;\n}\n// (public) this - a\nfunction bnSubtract(a) {\n const r = nbi();\n this.subTo(a, r);\n return r;\n}\n// (public) this * a\nfunction bnMultiply(a) {\n const r = nbi();\n this.multiplyTo(a, r);\n return r;\n}\n// (public) this / a\nfunction bnDivide(a) {\n const r = nbi();\n this.divRemTo(a, r, null);\n return r;\n}\n// Montgomery reduction\nfunction Montgomery(m) {\n this.m = m;\n this.mp = m.invDigit();\n this.mpl = this.mp & 0x7fff;\n this.mph = this.mp >> 15;\n this.um = (1 << (m.DB - 15)) - 1;\n this.mt2 = 2 * m.t;\n}\n// xR mod m\nfunction montConvert(x) {\n const r = nbi();\n x.abs().dlShiftTo(this.m.t, r);\n r.divRemTo(this.m, null, r);\n if (x.s < 0 && r.compareTo(BigInteger.ZERO) > 0)\n this.m.subTo(r, r);\n return r;\n}\n// x/R mod m\nfunction montRevert(x) {\n const r = nbi();\n x.copyTo(r);\n this.reduce(r);\n return r;\n}\n// x = x/R mod m (HAC 14.32)\nfunction montReduce(x) {\n while (x.t <= this.mt2)\n // pad x so am has enough room later\n x[x.t++] = 0;\n for (let i = 0; i < this.m.t; ++i) {\n // faster way of calculating u0 = x[i]*mp mod DV\n let j = x[i] & 0x7fff;\n const u0 = (j * this.mpl +\n (((j * this.mph + (x[i] >> 15) * this.mpl) & this.um) << 15)) &\n x.DM;\n // use am to combine the multiply-shift-add into one call\n j = i + this.m.t;\n x[j] += this.m.am(0, u0, x, i, 0, this.m.t);\n // propagate carry\n while (x[j] >= x.DV) {\n x[j] -= x.DV;\n x[++j]++;\n }\n }\n x.clamp();\n x.drShiftTo(this.m.t, x);\n if (x.compareTo(this.m) >= 0)\n x.subTo(this.m, x);\n}\n// r = \"x^2/R mod m\"; x != r\nfunction montSqrTo(x, r) {\n x.squareTo(r);\n this.reduce(r);\n}\n// r = \"xy/R mod m\"; x,y != r\nfunction montMulTo(x, y, r) {\n x.multiplyTo(y, r);\n this.reduce(r);\n}\nMontgomery.prototype.convert = montConvert;\nMontgomery.prototype.revert = montRevert;\nMontgomery.prototype.reduce = montReduce;\nMontgomery.prototype.mulTo = montMulTo;\nMontgomery.prototype.sqrTo = montSqrTo;\n// (public) this^e % m (HAC 14.85)\nfunction bnModPow(e, m, callback) {\n let i = e.bitLength();\n let k;\n let r = nbv(1);\n const z = new Montgomery(m);\n if (i <= 0)\n return r;\n else if (i < 18)\n k = 1;\n else if (i < 48)\n k = 3;\n else if (i < 144)\n k = 4;\n else if (i < 768)\n k = 5;\n else\n k = 6;\n // precomputation\n const g = [];\n let n = 3;\n const k1 = k - 1;\n const km = (1 << k) - 1;\n g[1] = z.convert(this);\n if (k > 1) {\n const g2 = nbi();\n z.sqrTo(g[1], g2);\n while (n <= km) {\n g[n] = nbi();\n z.mulTo(g2, g[n - 2], g[n]);\n n += 2;\n }\n }\n let j = e.t - 1;\n let w;\n let is1 = true;\n let r2 = nbi();\n let t;\n i = nbits(e[j]) - 1;\n while (j >= 0) {\n if (i >= k1)\n w = (e[j] >> (i - k1)) & km;\n else {\n w = (e[j] & ((1 << (i + 1)) - 1)) << (k1 - i);\n if (j > 0)\n w |= e[j - 1] >> (this.DB + i - k1);\n }\n n = k;\n while ((w & 1) === 0) {\n w >>= 1;\n --n;\n }\n if ((i -= n) < 0) {\n i += this.DB;\n --j;\n }\n if (is1) {\n // ret == 1, don't bother squaring or multiplying it\n g[w].copyTo(r);\n is1 = false;\n }\n else {\n while (n > 1) {\n z.sqrTo(r, r2);\n z.sqrTo(r2, r);\n n -= 2;\n }\n if (n > 0)\n z.sqrTo(r, r2);\n else {\n t = r;\n r = r2;\n r2 = t;\n }\n z.mulTo(r2, g[w], r);\n }\n while (j >= 0 && (e[j] & (1 << i)) === 0) {\n z.sqrTo(r, r2);\n t = r;\n r = r2;\n r2 = t;\n if (--i < 0) {\n i = this.DB - 1;\n --j;\n }\n }\n }\n const result = z.revert(r);\n callback(null, result);\n return result;\n}\n// protected\nBigInteger.prototype.copyTo = bnpCopyTo;\nBigInteger.prototype.fromInt = bnpFromInt;\nBigInteger.prototype.fromString = bnpFromString;\nBigInteger.prototype.clamp = bnpClamp;\nBigInteger.prototype.dlShiftTo = bnpDLShiftTo;\nBigInteger.prototype.drShiftTo = bnpDRShiftTo;\nBigInteger.prototype.lShiftTo = bnpLShiftTo;\nBigInteger.prototype.rShiftTo = bnpRShiftTo;\nBigInteger.prototype.subTo = bnpSubTo;\nBigInteger.prototype.multiplyTo = bnpMultiplyTo;\nBigInteger.prototype.squareTo = bnpSquareTo;\nBigInteger.prototype.divRemTo = bnpDivRemTo;\nBigInteger.prototype.invDigit = bnpInvDigit;\nBigInteger.prototype.addTo = bnpAddTo;\n// public\nBigInteger.prototype.toString = bnToString;\nBigInteger.prototype.negate = bnNegate;\nBigInteger.prototype.abs = bnAbs;\nBigInteger.prototype.compareTo = bnCompareTo;\nBigInteger.prototype.bitLength = bnBitLength;\nBigInteger.prototype.mod = bnMod;\nBigInteger.prototype.equals = bnEquals;\nBigInteger.prototype.add = bnAdd;\nBigInteger.prototype.subtract = bnSubtract;\nBigInteger.prototype.multiply = bnMultiply;\nBigInteger.prototype.divide = bnDivide;\nBigInteger.prototype.modPow = bnModPow;\n// \"constants\"\nBigInteger.ZERO = nbv(0);\nBigInteger.ONE = nbv(1);\n\nexport { BigInteger as default };\n//# sourceMappingURL=BigInteger.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nconst calculateS = async ({ a, g, k, x, B, N, U, }) => {\n return new Promise((resolve, reject) => {\n g.modPow(x, N, (outerErr, outerResult) => {\n if (outerErr) {\n reject(outerErr);\n return;\n }\n B.subtract(k.multiply(outerResult)).modPow(a.add(U.multiply(x)), N, (innerErr, innerResult) => {\n if (innerErr) {\n reject(innerErr);\n return;\n }\n resolve(innerResult.mod(N));\n });\n });\n });\n};\n\nexport { calculateS };\n//# sourceMappingURL=calculateS.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst INIT_N = 'FFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD1' +\n '29024E088A67CC74020BBEA63B139B22514A08798E3404DD' +\n 'EF9519B3CD3A431B302B0A6DF25F14374FE1356D6D51C245' +\n 'E485B576625E7EC6F44C42E9A637ED6B0BFF5CB6F406B7ED' +\n 'EE386BFB5A899FA5AE9F24117C4B1FE649286651ECE45B3D' +\n 'C2007CB8A163BF0598DA48361C55D39A69163FA8FD24CF5F' +\n '83655D23DCA3AD961C62F356208552BB9ED529077096966D' +\n '670C354E4ABC9804F1746C08CA18217C32905E462E36CE3B' +\n 'E39E772C180E86039B2783A2EC07A28FB5C55DF06F4C52C9' +\n 'DE2BCBF6955817183995497CEA956AE515D2261898FA0510' +\n '15728E5A8AAAC42DAD33170D04507A33A85521ABDF1CBA64' +\n 'ECFB850458DBEF0A8AEA71575D060C7DB3970F85A6E1E4C7' +\n 'ABF5AE8CDB0933D71E8C94E04A25619DCEE3D2261AD2EE6B' +\n 'F12FFA06D98A0864D87602733EC86A64521F2B18177B200C' +\n 'BBE117577A615D6C770988C0BAD946E208E24FA074E5AB31' +\n '43DB5BFCE0FD108E4B82D120A93AD2CAFFFFFFFFFFFFFFFF';\nconst SHORT_TO_HEX = {};\nconst HEX_TO_SHORT = {};\nfor (let i = 0; i < 256; i++) {\n let encodedByte = i.toString(16).toLowerCase();\n if (encodedByte.length === 1) {\n encodedByte = `0${encodedByte}`;\n }\n SHORT_TO_HEX[i] = encodedByte;\n HEX_TO_SHORT[encodedByte] = i;\n}\n\nexport { HEX_TO_SHORT, INIT_N, SHORT_TO_HEX };\n//# sourceMappingURL=constants.mjs.map\n","import { HEX_TO_SHORT } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Converts a hexadecimal encoded string to a Uint8Array of bytes.\n *\n * @param encoded The hexadecimal encoded string\n */\nconst getBytesFromHex = (encoded) => {\n if (encoded.length % 2 !== 0) {\n throw new Error('Hex encoded strings must have an even number length');\n }\n const out = new Uint8Array(encoded.length / 2);\n for (let i = 0; i < encoded.length; i += 2) {\n const encodedByte = encoded.slice(i, i + 2).toLowerCase();\n if (encodedByte in HEX_TO_SHORT) {\n out[i / 2] = HEX_TO_SHORT[encodedByte];\n }\n else {\n throw new Error(`Cannot decode unrecognized sequence ${encodedByte} as hexadecimal`);\n }\n }\n return out;\n};\n\nexport { getBytesFromHex };\n//# sourceMappingURL=getBytesFromHex.mjs.map\n","import { SHORT_TO_HEX } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Converts a Uint8Array of binary data to a hexadecimal encoded string.\n *\n * @param bytes The binary data to encode\n */\nconst getHexFromBytes = (bytes) => {\n let out = '';\n for (let i = 0; i < bytes.byteLength; i++) {\n out += SHORT_TO_HEX[bytes[i]];\n }\n return out;\n};\n\nexport { getHexFromBytes };\n//# sourceMappingURL=getHexFromBytes.mjs.map\n","import { Sha256 } from '@aws-crypto/sha256-js';\nimport { getHexFromBytes } from './getHexFromBytes.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Calculate a hash from a `SourceData`\n * @param {SourceData} data Value to hash.\n * @returns {string} Hex-encoded hash.\n * @private\n */\nconst getHashFromData = (data) => {\n const sha256 = new Sha256();\n sha256.update(data);\n const hashedData = sha256.digestSync();\n const hashHexFromUint8 = getHexFromBytes(hashedData);\n return new Array(64 - hashHexFromUint8.length).join('0') + hashHexFromUint8;\n};\n\nexport { getHashFromData };\n//# sourceMappingURL=getHashFromData.mjs.map\n","import { getBytesFromHex } from './getBytesFromHex.mjs';\nimport { getHashFromData } from './getHashFromData.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Calculate a hash from a hex string\n * @param {string} hexStr Value to hash.\n * @returns {string} Hex-encoded hash.\n * @private\n */\nconst getHashFromHex = (hexStr) => getHashFromData(getBytesFromHex(hexStr));\n\nexport { getHashFromHex };\n//# sourceMappingURL=getHashFromHex.mjs.map\n","import BigInteger from './BigInteger/BigInteger.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Tests if a hex string has it most significant bit set (case-insensitive regex)\n */\nconst HEX_MSB_REGEX = /^[89a-f]/i;\n/**\n * Returns an unambiguous, even-length hex string of the two's complement encoding of an integer.\n *\n * It is compatible with the hex encoding of Java's BigInteger's toByteArray(), wich returns a\n * byte array containing the two's-complement representation of a BigInteger. The array contains\n * the minimum number of bytes required to represent the BigInteger, including at least one sign bit.\n *\n * Examples showing how ambiguity is avoided by left padding with:\n * \t\"00\" (for positive values where the most-significant-bit is set)\n * \"FF\" (for negative values where the most-significant-bit is set)\n *\n * padHex(bigInteger.fromInt(-236)) === \"FF14\"\n * padHex(bigInteger.fromInt(20)) === \"14\"\n *\n * padHex(bigInteger.fromInt(-200)) === \"FF38\"\n * padHex(bigInteger.fromInt(56)) === \"38\"\n *\n * padHex(bigInteger.fromInt(-20)) === \"EC\"\n * padHex(bigInteger.fromInt(236)) === \"00EC\"\n *\n * padHex(bigInteger.fromInt(-56)) === \"C8\"\n * padHex(bigInteger.fromInt(200)) === \"00C8\"\n *\n * @param {AuthBigInteger} bigInt Number to encode.\n * @returns {String} even-length hex string of the two's complement encoding.\n */\nconst getPaddedHex = (bigInt) => {\n if (!(bigInt instanceof BigInteger)) {\n throw new Error('Not a BigInteger');\n }\n const isNegative = bigInt.compareTo(BigInteger.ZERO) < 0;\n /* Get a hex string for abs(bigInt) */\n let hexStr = bigInt.abs().toString(16);\n /* Pad hex to even length if needed */\n hexStr = hexStr.length % 2 !== 0 ? `0${hexStr}` : hexStr;\n /* Prepend \"00\" if the most significant bit is set */\n hexStr = HEX_MSB_REGEX.test(hexStr) ? `00${hexStr}` : hexStr;\n if (isNegative) {\n /* Flip the bits of the representation */\n const invertedNibbles = hexStr\n .split('')\n .map((x) => {\n const invertedNibble = ~parseInt(x, 16) & 0xf;\n return '0123456789ABCDEF'.charAt(invertedNibble);\n })\n .join('');\n /* After flipping the bits, add one to get the 2's complement representation */\n const flippedBitsBI = new BigInteger(invertedNibbles, 16).add(BigInteger.ONE);\n hexStr = flippedBitsBI.toString(16);\n /*\n For hex strings starting with 'FF8', 'FF' can be dropped, e.g. 0xFFFF80=0xFF80=0x80=-128\n\n Any sequence of '1' bits on the left can always be substituted with a single '1' bit\n without changing the represented value.\n\n This only happens in the case when the input is 80...00\n */\n if (hexStr.toUpperCase().startsWith('FF8')) {\n hexStr = hexStr.substring(2);\n }\n }\n return hexStr;\n};\n\nexport { getPaddedHex };\n//# sourceMappingURL=getPaddedHex.mjs.map\n","import BigInteger from '../BigInteger/BigInteger.mjs';\nimport { getHashFromHex } from '../getHashFromHex.mjs';\nimport { getPaddedHex } from '../getPaddedHex.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nconst calculateU = ({ A, B, }) => {\n const U = new BigInteger(getHashFromHex(getPaddedHex(A) + getPaddedHex(B)), 16);\n if (U.equals(BigInteger.ZERO)) {\n throw new Error('U cannot be zero.');\n }\n return U;\n};\n\nexport { calculateU };\n//# sourceMappingURL=calculateU.mjs.map\n","import { Sha256 } from '@aws-crypto/sha256-js';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Standard HKDF algorithm.\n *\n * @param {Uint8Array} ikm Input key material.\n * @param {Uint8Array} salt Salt value.\n * @param {Uint8Array} info Context and application specific info.\n *\n * @returns {Uint8Array} Strong key material.\n *\n * @internal\n */\nconst getHkdfKey = (ikm, salt, info) => {\n const awsCryptoHash = new Sha256(salt);\n awsCryptoHash.update(ikm);\n const resultFromAWSCryptoPrk = awsCryptoHash.digestSync();\n const awsCryptoHashHmac = new Sha256(resultFromAWSCryptoPrk);\n awsCryptoHashHmac.update(info);\n const resultFromAWSCryptoHmac = awsCryptoHashHmac.digestSync();\n const hashHexFromAWSCrypto = resultFromAWSCryptoHmac;\n return hashHexFromAWSCrypto.slice(0, 16);\n};\n\nexport { getHkdfKey };\n//# sourceMappingURL=getHkdfKey.mjs.map\n","import { WordArray } from '@aws-amplify/core/internals/utils';\nimport { getBytesFromHex } from './getBytesFromHex.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a Uint8Array with a sequence of random nBytes\n *\n * @param {number} nBytes\n * @returns {Uint8Array} fixed-length sequence of random bytes\n */\nconst getRandomBytes = (nBytes) => {\n const str = new WordArray().random(nBytes).toString();\n return getBytesFromHex(str);\n};\n\nexport { getRandomBytes };\n//# sourceMappingURL=getRandomBytes.mjs.map\n","import { base64Encoder } from '@aws-amplify/core/internals/utils';\nimport { getRandomBytes } from './getRandomBytes.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Helper function to generate a random string\n * @returns {string} a random value.\n *\n * @internal\n */\nconst getRandomString = () => base64Encoder.convert(getRandomBytes(40));\n\nexport { getRandomString };\n//# sourceMappingURL=getRandomString.mjs.map\n","import { AuthError } from '../../../../../errors/AuthError.mjs';\nimport { textEncoder } from '../../textEncoder/index.mjs';\nimport BigInteger from '../BigInteger/BigInteger.mjs';\nimport { calculateS } from '../calculate/calculateS.mjs';\nimport { calculateU } from '../calculate/calculateU.mjs';\nimport { getBytesFromHex } from '../getBytesFromHex.mjs';\nimport { getHashFromData } from '../getHashFromData.mjs';\nimport { getHashFromHex } from '../getHashFromHex.mjs';\nimport { getHexFromBytes } from '../getHexFromBytes.mjs';\nimport { getHkdfKey } from '../getHkdfKey.mjs';\nimport { getPaddedHex } from '../getPaddedHex.mjs';\nimport { getRandomBytes } from '../getRandomBytes.mjs';\nimport { getRandomString } from '../getRandomString.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/** @class */\nclass AuthenticationHelper {\n constructor({ userPoolName, a, g, A, N, }) {\n this.encoder = textEncoder;\n this.userPoolName = userPoolName;\n this.a = a;\n this.g = g;\n this.A = A;\n this.N = N;\n this.k = new BigInteger(getHashFromHex(`${getPaddedHex(N)}${getPaddedHex(g)}`), 16);\n }\n /**\n * @returns {string} Generated random value included in password hash.\n */\n getRandomPassword() {\n if (!this.randomPassword) {\n throw new AuthError({\n name: 'EmptyBigIntegerRandomPassword',\n message: 'random password is empty',\n });\n }\n return this.randomPassword;\n }\n /**\n * @returns {string} Generated random value included in devices hash.\n */\n getSaltToHashDevices() {\n if (!this.saltToHashDevices) {\n throw new AuthError({\n name: 'EmptyBigIntegersaltToHashDevices',\n message: 'saltToHashDevices is empty',\n });\n }\n return this.saltToHashDevices;\n }\n /**\n * @returns {string} Value used to verify devices.\n */\n getVerifierDevices() {\n if (!this.verifierDevices) {\n throw new AuthError({\n name: 'EmptyBigIntegerVerifierDevices',\n message: 'verifyDevices is empty',\n });\n }\n return this.verifierDevices;\n }\n /**\n * Generate salts and compute verifier.\n *\n * @param {string} deviceGroupKey Devices to generate verifier for.\n * @param {string} username User to generate verifier for.\n *\n * @returns {Promise}\n */\n async generateHashDevice(deviceGroupKey, username) {\n this.randomPassword = getRandomString();\n const combinedString = `${deviceGroupKey}${username}:${this.randomPassword}`;\n const hashedString = getHashFromData(combinedString);\n const hexRandom = getHexFromBytes(getRandomBytes(16));\n // The random hex will be unambiguously represented as a postive integer\n this.saltToHashDevices = getPaddedHex(new BigInteger(hexRandom, 16));\n return new Promise((resolve, reject) => {\n this.g.modPow(new BigInteger(getHashFromHex(this.saltToHashDevices + hashedString), 16), this.N, (err, result) => {\n if (err) {\n reject(err);\n return;\n }\n this.verifierDevices = getPaddedHex(result);\n resolve();\n });\n });\n }\n /**\n * Calculates the final HKDF key based on computed S value, computed U value and the key\n *\n * @param {String} username Username.\n * @param {String} password Password.\n * @param {AuthBigInteger} B Server B value.\n * @param {AuthBigInteger} salt Generated salt.\n */\n async getPasswordAuthenticationKey({ username, password, serverBValue, salt, }) {\n if (serverBValue.mod(this.N).equals(BigInteger.ZERO)) {\n throw new Error('B cannot be zero.');\n }\n const U = calculateU({\n A: this.A,\n B: serverBValue,\n });\n const usernamePassword = `${this.userPoolName}${username}:${password}`;\n const usernamePasswordHash = getHashFromData(usernamePassword);\n const x = new BigInteger(getHashFromHex(getPaddedHex(salt) + usernamePasswordHash), 16);\n const S = await calculateS({\n a: this.a,\n g: this.g,\n k: this.k,\n x,\n B: serverBValue,\n N: this.N,\n U,\n });\n const context = this.encoder.convert('Caldera Derived Key');\n const spacer = this.encoder.convert(String.fromCharCode(1));\n const info = new Uint8Array(context.byteLength + spacer.byteLength);\n info.set(context, 0);\n info.set(spacer, context.byteLength);\n const hkdfKey = getHkdfKey(getBytesFromHex(getPaddedHex(S)), getBytesFromHex(getPaddedHex(U)), info);\n return hkdfKey;\n }\n}\n\nexport { AuthenticationHelper as default };\n//# sourceMappingURL=AuthenticationHelper.mjs.map\n","import BigInteger from '../BigInteger/BigInteger.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * @internal\n */\nconst calculateA = async ({ a, g, N, }) => {\n return new Promise((resolve, reject) => {\n g.modPow(a, N, (err, A) => {\n if (err) {\n reject(err);\n return;\n }\n if (A.mod(N).equals(BigInteger.ZERO)) {\n reject(new Error('Illegal parameter. A mod N cannot be 0.'));\n return;\n }\n resolve(A);\n });\n });\n};\n\nexport { calculateA };\n//# sourceMappingURL=calculateA.mjs.map\n","import AuthenticationHelper from './AuthenticationHelper/AuthenticationHelper.mjs';\nimport BigInteger from './BigInteger/BigInteger.mjs';\nimport { calculateA } from './calculate/calculateA.mjs';\nimport { INIT_N } from './constants.mjs';\nimport '@aws-crypto/sha256-js';\nimport { getHexFromBytes } from './getHexFromBytes.mjs';\nimport { getRandomBytes } from './getRandomBytes.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Returns a new {@link AuthenticationHelper} instance with randomly generated BigInteger seed\n *\n * @param userPoolName Cognito user pool name.\n * @returns An {@link AuthenticationHelper} instance.\n *\n * @internal\n */\nconst getAuthenticationHelper = async (userPoolName) => {\n const N = new BigInteger(INIT_N, 16);\n const g = new BigInteger('2', 16);\n const a = generateRandomBigInteger();\n const A = await calculateA({ a, g, N });\n return new AuthenticationHelper({ userPoolName, a, g, A, N });\n};\n/**\n * Generates a random BigInteger.\n *\n * @returns {BigInteger} a random value.\n */\nconst generateRandomBigInteger = () => {\n // This will be interpreted as a postive 128-bit integer\n const hexRandom = getHexFromBytes(getRandomBytes(128));\n // There is no need to do randomBigInt.mod(this.N - 1) as N (3072-bit) is > 128 bytes (1024-bit)\n return new BigInteger(hexRandom, 16);\n};\n\nexport { getAuthenticationHelper };\n//# sourceMappingURL=getAuthenticationHelper.mjs.map\n","import { base64Encoder, getDeviceName } from '@aws-amplify/core/internals/utils';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../../../errors/types/validation.mjs';\nimport '../types/errors.mjs';\nimport { createConfirmDeviceClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createConfirmDeviceClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { getAuthenticationHelper } from './srp/getAuthenticationHelper.mjs';\nimport { getBytesFromHex } from './srp/getBytesFromHex.mjs';\nimport '@aws-crypto/sha256-js';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * This function is used to kick off the device management flow.\n *\n * If an error is thrown while generating a hash device or calling the `ConfirmDevice`\n * client, then this API will ignore the error and return undefined. Otherwise the authentication\n * flow will not complete and the user won't be able to be signed in.\n *\n * @returns DeviceMetadata | undefined\n */\nasync function getNewDeviceMetadata({ userPoolId, userPoolEndpoint, newDeviceMetadata, accessToken, }) {\n if (!newDeviceMetadata)\n return undefined;\n const userPoolName = userPoolId.split('_')[1] || '';\n const authenticationHelper = await getAuthenticationHelper(userPoolName);\n const deviceKey = newDeviceMetadata?.DeviceKey;\n const deviceGroupKey = newDeviceMetadata?.DeviceGroupKey;\n try {\n await authenticationHelper.generateHashDevice(deviceGroupKey ?? '', deviceKey ?? '');\n }\n catch (errGenHash) {\n // TODO: log error here\n return undefined;\n }\n const deviceSecretVerifierConfig = {\n Salt: base64Encoder.convert(getBytesFromHex(authenticationHelper.getSaltToHashDevices())),\n PasswordVerifier: base64Encoder.convert(getBytesFromHex(authenticationHelper.getVerifierDevices())),\n };\n const randomPassword = authenticationHelper.getRandomPassword();\n try {\n const confirmDevice = createConfirmDeviceClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n await confirmDevice({ region: getRegionFromUserPoolId(userPoolId) }, {\n AccessToken: accessToken,\n DeviceName: await getDeviceName(),\n DeviceKey: newDeviceMetadata?.DeviceKey,\n DeviceSecretVerifierConfig: deviceSecretVerifierConfig,\n });\n return {\n deviceKey,\n deviceGroupKey,\n randomPassword,\n };\n }\n catch (error) {\n // TODO: log error here\n return undefined;\n }\n}\n\nexport { getNewDeviceMetadata };\n//# sourceMappingURL=getNewDeviceMetadata.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils';\nimport { AuthErrorCodes } from '../../../common/AuthErrorStrings.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../errors/types/validation.mjs';\nimport '../../../providers/cognito/types/errors.mjs';\nimport { createRespondToAuthChallengeClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createRespondToAuthChallengeClient.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../../../providers/cognito/factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { cacheCognitoTokens } from '../../../providers/cognito/tokenProvider/cacheTokens.mjs';\nimport { dispatchSignedInHubEvent } from '../../../providers/cognito/utils/dispatchSignedInHubEvent.mjs';\nimport '../../utils/store/autoSignInStore.mjs';\nimport { signInStore, setActiveSignInState } from '../../utils/store/signInStore.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport { assertPasskeyError, PasskeyErrorCode } from '../../utils/passkey/errors.mjs';\nimport { getPasskey } from '../../utils/passkey/getPasskey.mjs';\nimport { getNewDeviceMetadata } from '../../../providers/cognito/utils/getNewDeviceMetadata.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nasync function handleWebAuthnSignInResult(challengeParameters) {\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n const { username, signInSession, signInDetails, challengeName } = signInStore.getState();\n if (challengeName !== 'WEB_AUTHN' || !username) {\n throw new AuthError({\n name: AuthErrorCodes.SignInException,\n message: 'Unable to proceed due to invalid sign in state.',\n });\n }\n const { CREDENTIAL_REQUEST_OPTIONS: credentialRequestOptions } = challengeParameters;\n assertPasskeyError(!!credentialRequestOptions, PasskeyErrorCode.InvalidPasskeyAuthenticationOptions);\n const cred = await getPasskey(JSON.parse(credentialRequestOptions));\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: authConfig.userPoolEndpoint,\n }),\n });\n const { ChallengeName: nextChallengeName, ChallengeParameters: nextChallengeParameters, AuthenticationResult: authenticationResult, Session: nextSession, } = await respondToAuthChallenge({\n region: getRegionFromUserPoolId(authConfig.userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, {\n ChallengeName: 'WEB_AUTHN',\n ChallengeResponses: {\n USERNAME: username,\n CREDENTIAL: JSON.stringify(cred),\n },\n ClientId: authConfig.userPoolClientId,\n Session: signInSession,\n });\n setActiveSignInState({\n signInSession: nextSession,\n username,\n challengeName: nextChallengeName,\n signInDetails,\n });\n if (authenticationResult) {\n await cacheCognitoTokens({\n ...authenticationResult,\n username,\n NewDeviceMetadata: await getNewDeviceMetadata({\n userPoolId: authConfig.userPoolId,\n userPoolEndpoint: authConfig.userPoolEndpoint,\n newDeviceMetadata: authenticationResult.NewDeviceMetadata,\n accessToken: authenticationResult.AccessToken,\n }),\n signInDetails,\n });\n signInStore.dispatch({ type: 'RESET_STATE' });\n await dispatchSignedInHubEvent();\n return {\n isSignedIn: true,\n nextStep: { signInStep: 'DONE' },\n };\n }\n if (nextChallengeName === 'WEB_AUTHN') {\n throw new AuthError({\n name: AuthErrorCodes.SignInException,\n message: 'Sequential WEB_AUTHN challenges returned from underlying service cannot be handled.',\n });\n }\n return {\n challengeName: nextChallengeName,\n challengeParameters: nextChallengeParameters,\n };\n}\n\nexport { handleWebAuthnSignInResult };\n//# sourceMappingURL=handleWebAuthnSignInResult.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst MONTH_NAMES = [\n 'Jan',\n 'Feb',\n 'Mar',\n 'Apr',\n 'May',\n 'Jun',\n 'Jul',\n 'Aug',\n 'Sep',\n 'Oct',\n 'Nov',\n 'Dec',\n];\nconst WEEK_NAMES = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];\nconst getNowString = () => {\n const now = new Date();\n const weekDay = WEEK_NAMES[now.getUTCDay()];\n const month = MONTH_NAMES[now.getUTCMonth()];\n const day = now.getUTCDate();\n let hours = now.getUTCHours();\n if (hours < 10) {\n hours = `0${hours}`;\n }\n let minutes = now.getUTCMinutes();\n if (minutes < 10) {\n minutes = `0${minutes}`;\n }\n let seconds = now.getUTCSeconds();\n if (seconds < 10) {\n seconds = `0${seconds}`;\n }\n const year = now.getUTCFullYear();\n // ddd MMM D HH:mm:ss UTC YYYY\n const dateNow = `${weekDay} ${month} ${day} ${hours}:${minutes}:${seconds} UTC ${year}`;\n return dateNow;\n};\n\nexport { getNowString };\n//# sourceMappingURL=getNowString.mjs.map\n","import { Sha256 } from '@aws-crypto/sha256-js';\nimport { base64Encoder, base64Decoder } from '@aws-amplify/core/internals/utils';\nimport { textEncoder } from '../textEncoder/index.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst getSignatureString = ({ userPoolName, username, challengeParameters, dateNow, hkdf, }) => {\n const bufUPIDaToB = textEncoder.convert(userPoolName);\n const bufUNaToB = textEncoder.convert(username);\n const bufSBaToB = urlB64ToUint8Array(challengeParameters.SECRET_BLOCK);\n const bufDNaToB = textEncoder.convert(dateNow);\n const bufConcat = new Uint8Array(bufUPIDaToB.byteLength +\n bufUNaToB.byteLength +\n bufSBaToB.byteLength +\n bufDNaToB.byteLength);\n bufConcat.set(bufUPIDaToB, 0);\n bufConcat.set(bufUNaToB, bufUPIDaToB.byteLength);\n bufConcat.set(bufSBaToB, bufUPIDaToB.byteLength + bufUNaToB.byteLength);\n bufConcat.set(bufDNaToB, bufUPIDaToB.byteLength + bufUNaToB.byteLength + bufSBaToB.byteLength);\n const awsCryptoHash = new Sha256(hkdf);\n awsCryptoHash.update(bufConcat);\n const resultFromAWSCrypto = awsCryptoHash.digestSync();\n const signatureString = base64Encoder.convert(resultFromAWSCrypto);\n return signatureString;\n};\nconst urlB64ToUint8Array = (base64String) => {\n const padding = '='.repeat((4 - (base64String.length % 4)) % 4);\n const base64 = (base64String + padding).replace(/-/g, '+').replace(/_/g, '/');\n const rawData = base64Decoder.convert(base64);\n const outputArray = new Uint8Array(rawData.length);\n for (let i = 0; i < rawData.length; ++i) {\n outputArray[i] = rawData.charCodeAt(i);\n }\n return outputArray;\n};\n\nexport { getSignatureString };\n//# sourceMappingURL=getSignatureString.mjs.map\n","import '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../../../errors/types/validation.mjs';\nimport '../types/errors.mjs';\nimport { createRespondToAuthChallengeClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createRespondToAuthChallengeClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { assertDeviceMetadata } from './types.mjs';\nimport { getAuthenticationHelper } from './srp/getAuthenticationHelper.mjs';\nimport './srp/constants.mjs';\nimport { getNowString } from './srp/getNowString.mjs';\nimport { getSignatureString } from './srp/getSignatureString.mjs';\nimport BigInteger from './srp/BigInteger/BigInteger.mjs';\nimport { getUserContextData } from './userContextData.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nasync function handleDeviceSRPAuth({ username, config, clientMetadata, session, tokenOrchestrator, }) {\n const { userPoolId, userPoolEndpoint } = config;\n const clientId = config.userPoolClientId;\n const deviceMetadata = await tokenOrchestrator?.getDeviceMetadata(username);\n assertDeviceMetadata(deviceMetadata);\n const authenticationHelper = await getAuthenticationHelper(deviceMetadata.deviceGroupKey);\n const challengeResponses = {\n USERNAME: username,\n SRP_A: authenticationHelper.A.toString(16),\n DEVICE_KEY: deviceMetadata.deviceKey,\n };\n const jsonReqResponseChallenge = {\n ChallengeName: 'DEVICE_SRP_AUTH',\n ClientId: clientId,\n ChallengeResponses: challengeResponses,\n ClientMetadata: clientMetadata,\n Session: session,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const { ChallengeParameters: respondedChallengeParameters, Session } = await respondToAuthChallenge({ region: getRegionFromUserPoolId(userPoolId) }, jsonReqResponseChallenge);\n return handleDevicePasswordVerifier(username, respondedChallengeParameters, clientMetadata, Session, authenticationHelper, config, tokenOrchestrator);\n}\nasync function handleDevicePasswordVerifier(username, challengeParameters, clientMetadata, session, authenticationHelper, { userPoolId, userPoolClientId, userPoolEndpoint }, tokenOrchestrator) {\n const deviceMetadata = await tokenOrchestrator?.getDeviceMetadata(username);\n assertDeviceMetadata(deviceMetadata);\n const serverBValue = new BigInteger(challengeParameters?.SRP_B, 16);\n const salt = new BigInteger(challengeParameters?.SALT, 16);\n const { deviceKey } = deviceMetadata;\n const { deviceGroupKey } = deviceMetadata;\n const hkdf = await authenticationHelper.getPasswordAuthenticationKey({\n username: deviceMetadata.deviceKey,\n password: deviceMetadata.randomPassword,\n serverBValue,\n salt,\n });\n const dateNow = getNowString();\n const challengeResponses = {\n USERNAME: challengeParameters?.USERNAME ?? username,\n PASSWORD_CLAIM_SECRET_BLOCK: challengeParameters?.SECRET_BLOCK,\n TIMESTAMP: dateNow,\n PASSWORD_CLAIM_SIGNATURE: getSignatureString({\n username: deviceKey,\n userPoolName: deviceGroupKey,\n challengeParameters,\n dateNow,\n hkdf,\n }),\n DEVICE_KEY: deviceKey,\n };\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReqResponseChallenge = {\n ChallengeName: 'DEVICE_PASSWORD_VERIFIER',\n ClientId: userPoolClientId,\n ChallengeResponses: challengeResponses,\n Session: session,\n ClientMetadata: clientMetadata,\n UserContextData,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n return respondToAuthChallenge({ region: getRegionFromUserPoolId(userPoolId) }, jsonReqResponseChallenge);\n}\n\nexport { handleDeviceSRPAuth };\n//# sourceMappingURL=handleDeviceSRPAuth.mjs.map\n","import { AuthError } from '../../../errors/AuthError.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../../../errors/types/validation.mjs';\nimport '../types/errors.mjs';\nimport { createRespondToAuthChallengeClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createRespondToAuthChallengeClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport BigInteger from './srp/BigInteger/BigInteger.mjs';\nimport './srp/constants.mjs';\nimport '@aws-crypto/sha256-js';\nimport { getNowString } from './srp/getNowString.mjs';\nimport { getSignatureString } from './srp/getSignatureString.mjs';\nimport { getUserContextData } from './userContextData.mjs';\nimport { handleDeviceSRPAuth } from './handleDeviceSRPAuth.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nasync function handlePasswordVerifierChallenge(password, challengeParameters, clientMetadata, session, authenticationHelper, config, tokenOrchestrator) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n const userPoolName = userPoolId?.split('_')[1] || '';\n const serverBValue = new BigInteger(challengeParameters?.SRP_B, 16);\n const salt = new BigInteger(challengeParameters?.SALT, 16);\n const username = challengeParameters?.USER_ID_FOR_SRP;\n if (!username)\n throw new AuthError({\n name: 'EmptyUserIdForSRPException',\n message: 'USER_ID_FOR_SRP was not found in challengeParameters',\n });\n const hkdf = await authenticationHelper.getPasswordAuthenticationKey({\n username,\n password,\n serverBValue,\n salt,\n });\n const dateNow = getNowString();\n const challengeResponses = {\n USERNAME: username,\n PASSWORD_CLAIM_SECRET_BLOCK: challengeParameters?.SECRET_BLOCK,\n TIMESTAMP: dateNow,\n PASSWORD_CLAIM_SIGNATURE: getSignatureString({\n username,\n userPoolName,\n challengeParameters,\n dateNow,\n hkdf,\n }),\n };\n const deviceMetadata = await tokenOrchestrator.getDeviceMetadata(username);\n if (deviceMetadata && deviceMetadata.deviceKey) {\n challengeResponses.DEVICE_KEY = deviceMetadata.deviceKey;\n }\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReqResponseChallenge = {\n ChallengeName: 'PASSWORD_VERIFIER',\n ChallengeResponses: challengeResponses,\n ClientMetadata: clientMetadata,\n Session: session,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const response = await respondToAuthChallenge({ region: getRegionFromUserPoolId(userPoolId) }, jsonReqResponseChallenge);\n if (response.ChallengeName === 'DEVICE_SRP_AUTH')\n return handleDeviceSRPAuth({\n username,\n config,\n clientMetadata,\n session: response.Session,\n tokenOrchestrator,\n });\n return response;\n}\n\nexport { handlePasswordVerifierChallenge };\n//# sourceMappingURL=handlePasswordVerifierChallenge.mjs.map\n","import { AuthError } from '../../../errors/AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * It will retry the function if the error is a `ResourceNotFoundException` and\n * will clean the device keys stored in the storage mechanism.\n *\n */\nasync function retryOnResourceNotFoundException(func, args, username, tokenOrchestrator) {\n try {\n return await func(...args);\n }\n catch (error) {\n if (error instanceof AuthError &&\n error.name === 'ResourceNotFoundException' &&\n error.message.includes('Device does not exist.')) {\n await tokenOrchestrator.clearDeviceMetadata(username);\n return func(...args);\n }\n throw error;\n }\n}\n\nexport { retryOnResourceNotFoundException };\n//# sourceMappingURL=retryOnResourceNotFoundException.mjs.map\n","import '../../../client/utils/store/autoSignInStore.mjs';\nimport { signInStore } from '../../../client/utils/store/signInStore.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction setActiveSignInUsername(username) {\n const { dispatch } = signInStore;\n dispatch({ type: 'SET_USERNAME', value: username });\n}\n\nexport { setActiveSignInUsername };\n//# sourceMappingURL=setActiveSignInUsername.mjs.map\n","import { AuthAction } from '@aws-amplify/core/internals/utils';\nimport { getUserContextData } from '../../../providers/cognito/utils/userContextData.mjs';\nimport { getAuthenticationHelper } from '../../../providers/cognito/utils/srp/getAuthenticationHelper.mjs';\nimport '../../../providers/cognito/utils/srp/constants.mjs';\nimport '@aws-crypto/sha256-js';\nimport { createInitiateAuthClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createInitiateAuthClient.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../../../errors/types/validation.mjs';\nimport '../../../providers/cognito/types/errors.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../../../providers/cognito/factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport { handlePasswordVerifierChallenge } from '../../../providers/cognito/utils/handlePasswordVerifierChallenge.mjs';\nimport { retryOnResourceNotFoundException } from '../../../providers/cognito/utils/retryOnResourceNotFoundException.mjs';\nimport { setActiveSignInUsername } from '../../../providers/cognito/utils/setActiveSignInUsername.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Handles the Password SRP (Secure Remote Password) authentication flow.\n * This function can be used with both USER_SRP_AUTH and USER_AUTH flows.\n *\n * @param {Object} params - The parameters for the Password SRP authentication\n * @param {string} params.username - The username for authentication\n * @param {string} params.password - The user's password\n * @param {ClientMetadata} [params.clientMetadata] - Optional metadata to be sent with auth requests\n * @param {CognitoUserPoolConfig} params.config - Cognito User Pool configuration\n * @param {AuthTokenOrchestrator} params.tokenOrchestrator - Token orchestrator for managing auth tokens\n * @param {AuthFlowType} params.authFlow - The type of authentication flow ('USER_SRP_AUTH' or 'USER_AUTH')\n * @param {AuthFactorType} [params.preferredChallenge] - Optional preferred challenge type when using USER_AUTH flow\n *\n * @returns {Promise} The authentication response\n */\nasync function handlePasswordSRP({ username, password, clientMetadata, config, tokenOrchestrator, authFlow, preferredChallenge, }) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n const userPoolName = userPoolId?.split('_')[1] || '';\n const authenticationHelper = await getAuthenticationHelper(userPoolName);\n const authParameters = {\n USERNAME: username,\n SRP_A: authenticationHelper.A.toString(16),\n };\n if (authFlow === 'USER_AUTH' && preferredChallenge) {\n authParameters.PREFERRED_CHALLENGE = preferredChallenge;\n }\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n AuthFlow: authFlow,\n AuthParameters: authParameters,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const initiateAuth = createInitiateAuthClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const resp = await initiateAuth({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignIn),\n }, jsonReq);\n const { ChallengeParameters: challengeParameters, Session: session } = resp;\n const activeUsername = challengeParameters?.USERNAME ?? username;\n setActiveSignInUsername(activeUsername);\n if (resp.ChallengeName === 'PASSWORD_VERIFIER') {\n return retryOnResourceNotFoundException(handlePasswordVerifierChallenge, [\n password,\n challengeParameters,\n clientMetadata,\n session,\n authenticationHelper,\n config,\n tokenOrchestrator,\n ], activeUsername, tokenOrchestrator);\n }\n return resp;\n}\n\nexport { handlePasswordSRP };\n//# sourceMappingURL=handlePasswordSRP.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { AuthAction, assertTokenProviderConfig, AmplifyUrl } from '@aws-amplify/core/internals/utils';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { InitiateAuthException } from '../types/errors.mjs';\nimport { AuthErrorCodes } from '../../../common/AuthErrorStrings.mjs';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { USER_ALREADY_AUTHENTICATED_EXCEPTION } from '../../../errors/constants.mjs';\nimport { getCurrentUser } from '../apis/getCurrentUser.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport { createInitiateAuthClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createInitiateAuthClient.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport { createRespondToAuthChallengeClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createRespondToAuthChallengeClient.mjs';\nimport { createVerifySoftwareTokenClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createVerifySoftwareTokenClient.mjs';\nimport { createAssociateSoftwareTokenClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createAssociateSoftwareTokenClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { handleWebAuthnSignInResult } from '../../../client/flows/userAuth/handleWebAuthnSignInResult.mjs';\nimport { handlePasswordSRP } from '../../../client/flows/shared/handlePasswordSRP.mjs';\nimport { initiateSelectedChallenge } from '../../../client/flows/userAuth/handleSelectChallenge.mjs';\nimport { handleSelectChallengeWithPassword } from '../../../client/flows/userAuth/handleSelectChallengeWithPassword.mjs';\nimport { handleSelectChallengeWithPasswordSRP } from '../../../client/flows/userAuth/handleSelectChallengeWithPasswordSRP.mjs';\nimport '../../../client/utils/store/autoSignInStore.mjs';\nimport { signInStore } from '../../../client/utils/store/signInStore.mjs';\nimport { getAuthenticationHelper } from './srp/getAuthenticationHelper.mjs';\nimport './srp/constants.mjs';\nimport '@aws-crypto/sha256-js';\nimport { getUserContextData } from './userContextData.mjs';\nimport { handlePasswordVerifierChallenge } from './handlePasswordVerifierChallenge.mjs';\nimport { handleDeviceSRPAuth } from './handleDeviceSRPAuth.mjs';\nimport { retryOnResourceNotFoundException } from './retryOnResourceNotFoundException.mjs';\nimport { setActiveSignInUsername } from './setActiveSignInUsername.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst USER_ATTRIBUTES = 'userAttributes.';\nfunction isWebAuthnResultAuthSignInOutput(result) {\n return 'isSignedIn' in result && 'nextStep' in result;\n}\nasync function handleCustomChallenge({ challengeResponse, clientMetadata, session, username, config, tokenOrchestrator, }) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n const challengeResponses = {\n USERNAME: username,\n ANSWER: challengeResponse,\n };\n const deviceMetadata = await tokenOrchestrator?.getDeviceMetadata(username);\n if (deviceMetadata && deviceMetadata.deviceKey) {\n challengeResponses.DEVICE_KEY = deviceMetadata.deviceKey;\n }\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n ChallengeName: 'CUSTOM_CHALLENGE',\n ChallengeResponses: challengeResponses,\n Session: session,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const response = await respondToAuthChallenge({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, jsonReq);\n if (response.ChallengeName === 'DEVICE_SRP_AUTH') {\n return handleDeviceSRPAuth({\n username,\n config,\n clientMetadata,\n session: response.Session,\n tokenOrchestrator,\n });\n }\n return response;\n}\nasync function handleMFASetupChallenge({ challengeResponse, username, clientMetadata, session, deviceName, config, }) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n if (challengeResponse === 'EMAIL') {\n return {\n ChallengeName: 'MFA_SETUP',\n Session: session,\n ChallengeParameters: {\n MFAS_CAN_SETUP: '[\"EMAIL_OTP\"]',\n },\n $metadata: {},\n };\n }\n if (challengeResponse === 'TOTP') {\n return {\n ChallengeName: 'MFA_SETUP',\n Session: session,\n ChallengeParameters: {\n MFAS_CAN_SETUP: '[\"SOFTWARE_TOKEN_MFA\"]',\n },\n $metadata: {},\n };\n }\n const challengeResponses = {\n USERNAME: username,\n };\n const isTOTPCode = /^\\d+$/.test(challengeResponse);\n if (isTOTPCode) {\n const verifySoftwareToken = createVerifySoftwareTokenClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const { Session } = await verifySoftwareToken({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, {\n UserCode: challengeResponse,\n Session: session,\n FriendlyDeviceName: deviceName,\n });\n signInStore.dispatch({\n type: 'SET_SIGN_IN_SESSION',\n value: Session,\n });\n const jsonReq = {\n ChallengeName: 'MFA_SETUP',\n ChallengeResponses: challengeResponses,\n Session,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n return respondToAuthChallenge({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, jsonReq);\n }\n const isEmail = challengeResponse.includes('@');\n if (isEmail) {\n challengeResponses.EMAIL = challengeResponse;\n const jsonReq = {\n ChallengeName: 'MFA_SETUP',\n ChallengeResponses: challengeResponses,\n Session: session,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n return respondToAuthChallenge({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, jsonReq);\n }\n throw new AuthError({\n name: AuthErrorCodes.SignInException,\n message: `Cannot proceed with MFA setup using challengeResponse: ${challengeResponse}`,\n recoverySuggestion: 'Try passing \"EMAIL\", \"TOTP\", a valid email, or OTP code as the challengeResponse.',\n });\n}\nasync function handleSelectMFATypeChallenge({ challengeResponse, username, clientMetadata, session, config, }) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n assertValidationError(challengeResponse === 'TOTP' ||\n challengeResponse === 'SMS' ||\n challengeResponse === 'EMAIL', AuthValidationErrorCode.IncorrectMFAMethod);\n const challengeResponses = {\n USERNAME: username,\n ANSWER: mapMfaType(challengeResponse),\n };\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n ChallengeName: 'SELECT_MFA_TYPE',\n ChallengeResponses: challengeResponses,\n Session: session,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n return respondToAuthChallenge({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, jsonReq);\n}\nasync function handleCompleteNewPasswordChallenge({ challengeResponse, clientMetadata, session, username, requiredAttributes, config, }) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n const challengeResponses = {\n ...createAttributes(requiredAttributes),\n NEW_PASSWORD: challengeResponse,\n USERNAME: username,\n };\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n ChallengeName: 'NEW_PASSWORD_REQUIRED',\n ChallengeResponses: challengeResponses,\n ClientMetadata: clientMetadata,\n Session: session,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n return respondToAuthChallenge({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, jsonReq);\n}\nasync function handleUserPasswordAuthFlow(username, password, clientMetadata, config, tokenOrchestrator) {\n const { userPoolClientId, userPoolId, userPoolEndpoint } = config;\n const authParameters = {\n USERNAME: username,\n PASSWORD: password,\n };\n const deviceMetadata = await tokenOrchestrator.getDeviceMetadata(username);\n if (deviceMetadata && deviceMetadata.deviceKey) {\n authParameters.DEVICE_KEY = deviceMetadata.deviceKey;\n }\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n AuthFlow: 'USER_PASSWORD_AUTH',\n AuthParameters: authParameters,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const initiateAuth = createInitiateAuthClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const response = await initiateAuth({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignIn),\n }, jsonReq);\n const activeUsername = response.ChallengeParameters?.USERNAME ??\n response.ChallengeParameters?.USER_ID_FOR_SRP ??\n username;\n setActiveSignInUsername(activeUsername);\n if (response.ChallengeName === 'DEVICE_SRP_AUTH')\n return handleDeviceSRPAuth({\n username: activeUsername,\n config,\n clientMetadata,\n session: response.Session,\n tokenOrchestrator,\n });\n return response;\n}\nasync function handleUserSRPAuthFlow(username, password, clientMetadata, config, tokenOrchestrator) {\n return handlePasswordSRP({\n username,\n password,\n clientMetadata,\n config,\n tokenOrchestrator,\n authFlow: 'USER_SRP_AUTH',\n });\n}\nasync function handleCustomAuthFlowWithoutSRP(username, clientMetadata, config, tokenOrchestrator) {\n const { userPoolClientId, userPoolId, userPoolEndpoint } = config;\n const authParameters = {\n USERNAME: username,\n };\n const deviceMetadata = await tokenOrchestrator.getDeviceMetadata(username);\n if (deviceMetadata && deviceMetadata.deviceKey) {\n authParameters.DEVICE_KEY = deviceMetadata.deviceKey;\n }\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n AuthFlow: 'CUSTOM_AUTH',\n AuthParameters: authParameters,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const initiateAuth = createInitiateAuthClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const response = await initiateAuth({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignIn),\n }, jsonReq);\n const activeUsername = response.ChallengeParameters?.USERNAME ?? username;\n setActiveSignInUsername(activeUsername);\n if (response.ChallengeName === 'DEVICE_SRP_AUTH')\n return handleDeviceSRPAuth({\n username: activeUsername,\n config,\n clientMetadata,\n session: response.Session,\n tokenOrchestrator,\n });\n return response;\n}\nasync function handleCustomSRPAuthFlow(username, password, clientMetadata, config, tokenOrchestrator) {\n assertTokenProviderConfig(config);\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n const userPoolName = userPoolId?.split('_')[1] || '';\n const authenticationHelper = await getAuthenticationHelper(userPoolName);\n const authParameters = {\n USERNAME: username,\n SRP_A: authenticationHelper.A.toString(16),\n CHALLENGE_NAME: 'SRP_A',\n };\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n AuthFlow: 'CUSTOM_AUTH',\n AuthParameters: authParameters,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n };\n const initiateAuth = createInitiateAuthClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const { ChallengeParameters: challengeParameters, Session: session } = await initiateAuth({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignIn),\n }, jsonReq);\n const activeUsername = challengeParameters?.USERNAME ?? username;\n setActiveSignInUsername(activeUsername);\n return retryOnResourceNotFoundException(handlePasswordVerifierChallenge, [\n password,\n challengeParameters,\n clientMetadata,\n session,\n authenticationHelper,\n config,\n tokenOrchestrator,\n ], activeUsername, tokenOrchestrator);\n}\nasync function getSignInResult(params) {\n const { challengeName, challengeParameters, availableChallenges } = params;\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n switch (challengeName) {\n case 'CUSTOM_CHALLENGE':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONFIRM_SIGN_IN_WITH_CUSTOM_CHALLENGE',\n additionalInfo: challengeParameters,\n },\n };\n case 'MFA_SETUP': {\n const { signInSession, username } = signInStore.getState();\n const mfaSetupTypes = getMFATypes(parseMFATypes(challengeParameters.MFAS_CAN_SETUP)) || [];\n const allowedMfaSetupTypes = getAllowedMfaSetupTypes(mfaSetupTypes);\n const isTotpMfaSetupAvailable = allowedMfaSetupTypes.includes('TOTP');\n const isEmailMfaSetupAvailable = allowedMfaSetupTypes.includes('EMAIL');\n if (isTotpMfaSetupAvailable && isEmailMfaSetupAvailable) {\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONTINUE_SIGN_IN_WITH_MFA_SETUP_SELECTION',\n allowedMFATypes: allowedMfaSetupTypes,\n },\n };\n }\n if (isEmailMfaSetupAvailable) {\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONTINUE_SIGN_IN_WITH_EMAIL_SETUP',\n },\n };\n }\n if (isTotpMfaSetupAvailable) {\n const associateSoftwareToken = createAssociateSoftwareTokenClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: authConfig.userPoolEndpoint,\n }),\n });\n const { Session, SecretCode: secretCode } = await associateSoftwareToken({ region: getRegionFromUserPoolId(authConfig.userPoolId) }, {\n Session: signInSession,\n });\n signInStore.dispatch({\n type: 'SET_SIGN_IN_SESSION',\n value: Session,\n });\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONTINUE_SIGN_IN_WITH_TOTP_SETUP',\n totpSetupDetails: getTOTPSetupDetails(secretCode, username),\n },\n };\n }\n throw new AuthError({\n name: AuthErrorCodes.SignInException,\n message: `Cannot initiate MFA setup from available types: ${mfaSetupTypes}`,\n });\n }\n case 'NEW_PASSWORD_REQUIRED':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONFIRM_SIGN_IN_WITH_NEW_PASSWORD_REQUIRED',\n missingAttributes: parseAttributes(challengeParameters.requiredAttributes),\n },\n };\n case 'SELECT_MFA_TYPE':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONTINUE_SIGN_IN_WITH_MFA_SELECTION',\n allowedMFATypes: getMFATypes(parseMFATypes(challengeParameters.MFAS_CAN_CHOOSE)),\n },\n };\n case 'SMS_OTP':\n case 'SMS_MFA':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONFIRM_SIGN_IN_WITH_SMS_CODE',\n codeDeliveryDetails: {\n deliveryMedium: challengeParameters.CODE_DELIVERY_DELIVERY_MEDIUM,\n destination: challengeParameters.CODE_DELIVERY_DESTINATION,\n },\n },\n };\n case 'SOFTWARE_TOKEN_MFA':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONFIRM_SIGN_IN_WITH_TOTP_CODE',\n },\n };\n case 'EMAIL_OTP':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONFIRM_SIGN_IN_WITH_EMAIL_CODE',\n codeDeliveryDetails: {\n deliveryMedium: challengeParameters.CODE_DELIVERY_DELIVERY_MEDIUM,\n destination: challengeParameters.CODE_DELIVERY_DESTINATION,\n },\n },\n };\n case 'WEB_AUTHN': {\n const result = await handleWebAuthnSignInResult(challengeParameters);\n if (isWebAuthnResultAuthSignInOutput(result)) {\n return result;\n }\n return getSignInResult(result);\n }\n case 'PASSWORD':\n case 'PASSWORD_SRP':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONFIRM_SIGN_IN_WITH_PASSWORD',\n },\n };\n case 'SELECT_CHALLENGE':\n return {\n isSignedIn: false,\n nextStep: {\n signInStep: 'CONTINUE_SIGN_IN_WITH_FIRST_FACTOR_SELECTION',\n availableChallenges,\n },\n };\n }\n // TODO: remove this error message for production apps\n throw new AuthError({\n name: AuthErrorCodes.SignInException,\n message: 'An error occurred during the sign in process. ' +\n `${challengeName} challengeName returned by the underlying service was not addressed.`,\n });\n}\nfunction getTOTPSetupDetails(secretCode, username) {\n return {\n sharedSecret: secretCode,\n getSetupUri: (appName, accountName) => {\n const totpUri = `otpauth://totp/${appName}:${accountName ?? username}?secret=${secretCode}&issuer=${appName}`;\n return new AmplifyUrl(totpUri);\n },\n };\n}\nfunction getSignInResultFromError(errorName) {\n if (errorName === InitiateAuthException.PasswordResetRequiredException) {\n return {\n isSignedIn: false,\n nextStep: { signInStep: 'RESET_PASSWORD' },\n };\n }\n else if (errorName === InitiateAuthException.UserNotConfirmedException) {\n return {\n isSignedIn: false,\n nextStep: { signInStep: 'CONFIRM_SIGN_UP' },\n };\n }\n}\nfunction parseAttributes(attributes) {\n if (!attributes)\n return [];\n const parsedAttributes = JSON.parse(attributes).map(att => att.includes(USER_ATTRIBUTES) ? att.replace(USER_ATTRIBUTES, '') : att);\n return parsedAttributes;\n}\nfunction createAttributes(attributes) {\n if (!attributes)\n return {};\n const newAttributes = {};\n Object.entries(attributes).forEach(([key, value]) => {\n if (value)\n newAttributes[`${USER_ATTRIBUTES}${key}`] = value;\n });\n return newAttributes;\n}\nasync function handleChallengeName(username, challengeName, session, challengeResponse, config, tokenOrchestrator, clientMetadata, options) {\n const userAttributes = options?.userAttributes;\n const deviceName = options?.friendlyDeviceName;\n switch (challengeName) {\n case 'WEB_AUTHN':\n case 'SELECT_CHALLENGE':\n if (challengeResponse === 'PASSWORD_SRP' ||\n challengeResponse === 'PASSWORD') {\n return {\n ChallengeName: challengeResponse,\n Session: session,\n $metadata: {},\n };\n }\n return initiateSelectedChallenge({\n username,\n session,\n selectedChallenge: challengeResponse,\n config,\n clientMetadata,\n });\n case 'SELECT_MFA_TYPE':\n return handleSelectMFATypeChallenge({\n challengeResponse,\n clientMetadata,\n session,\n username,\n config,\n });\n case 'MFA_SETUP':\n return handleMFASetupChallenge({\n challengeResponse,\n clientMetadata,\n session,\n username,\n deviceName,\n config,\n });\n case 'NEW_PASSWORD_REQUIRED':\n return handleCompleteNewPasswordChallenge({\n challengeResponse,\n clientMetadata,\n session,\n username,\n requiredAttributes: userAttributes,\n config,\n });\n case 'CUSTOM_CHALLENGE':\n return retryOnResourceNotFoundException(handleCustomChallenge, [\n {\n challengeResponse,\n clientMetadata,\n session,\n username,\n config,\n tokenOrchestrator,\n },\n ], username, tokenOrchestrator);\n case 'SMS_MFA':\n case 'SOFTWARE_TOKEN_MFA':\n case 'SMS_OTP':\n case 'EMAIL_OTP':\n return handleMFAChallenge({\n challengeName,\n challengeResponse,\n clientMetadata,\n session,\n username,\n config,\n });\n case 'PASSWORD':\n return handleSelectChallengeWithPassword(username, challengeResponse, clientMetadata, config, session);\n case 'PASSWORD_SRP':\n return handleSelectChallengeWithPasswordSRP(username, challengeResponse, // This is the actual password\n clientMetadata, config, session, tokenOrchestrator);\n }\n // TODO: remove this error message for production apps\n throw new AuthError({\n name: AuthErrorCodes.SignInException,\n message: `An error occurred during the sign in process.\n\t\t${challengeName} challengeName returned by the underlying service was not addressed.`,\n });\n}\nfunction mapMfaType(mfa) {\n let mfaType = 'SMS_MFA';\n if (mfa === 'TOTP')\n mfaType = 'SOFTWARE_TOKEN_MFA';\n if (mfa === 'EMAIL')\n mfaType = 'EMAIL_OTP';\n return mfaType;\n}\nfunction getMFAType(type) {\n if (type === 'SMS_MFA')\n return 'SMS';\n if (type === 'SOFTWARE_TOKEN_MFA')\n return 'TOTP';\n if (type === 'EMAIL_OTP')\n return 'EMAIL';\n // TODO: log warning for unknown MFA type\n}\nfunction getMFATypes(types) {\n if (!types)\n return undefined;\n return types.map(getMFAType).filter(Boolean);\n}\nfunction parseMFATypes(mfa) {\n if (!mfa)\n return [];\n return JSON.parse(mfa);\n}\nfunction getAllowedMfaSetupTypes(availableMfaSetupTypes) {\n return availableMfaSetupTypes.filter(authMfaType => authMfaType === 'EMAIL' || authMfaType === 'TOTP');\n}\nasync function assertUserNotAuthenticated() {\n let authUser;\n try {\n authUser = await getCurrentUser();\n }\n catch (error) { }\n if (authUser && authUser.userId && authUser.username) {\n throw new AuthError({\n name: USER_ALREADY_AUTHENTICATED_EXCEPTION,\n message: 'There is already a signed in user.',\n recoverySuggestion: 'Call signOut before calling signIn again.',\n });\n }\n}\nfunction getActiveSignInUsername(username) {\n const state = signInStore.getState();\n return state.username ?? username;\n}\nasync function handleMFAChallenge({ challengeName, challengeResponse, clientMetadata, session, username, config, }) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n const challengeResponses = {\n USERNAME: username,\n };\n if (challengeName === 'EMAIL_OTP') {\n challengeResponses.EMAIL_OTP_CODE = challengeResponse;\n }\n if (challengeName === 'SMS_MFA') {\n challengeResponses.SMS_MFA_CODE = challengeResponse;\n }\n if (challengeName === 'SMS_OTP') {\n challengeResponses.SMS_OTP_CODE = challengeResponse;\n }\n if (challengeName === 'SOFTWARE_TOKEN_MFA') {\n challengeResponses.SOFTWARE_TOKEN_MFA_CODE = challengeResponse;\n }\n const userContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const jsonReq = {\n ChallengeName: challengeName,\n ChallengeResponses: challengeResponses,\n Session: session,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData: userContextData,\n };\n const respondToAuthChallenge = createRespondToAuthChallengeClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n return respondToAuthChallenge({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn),\n }, jsonReq);\n}\n\nexport { assertUserNotAuthenticated, createAttributes, getActiveSignInUsername, getAllowedMfaSetupTypes, getMFAType, getMFATypes, getSignInResult, getSignInResultFromError, getTOTPSetupDetails, handleChallengeName, handleCompleteNewPasswordChallenge, handleCustomAuthFlowWithoutSRP, handleCustomChallenge, handleCustomSRPAuthFlow, handleMFAChallenge, handleMFASetupChallenge, handleSelectMFATypeChallenge, handleUserPasswordAuthFlow, handleUserSRPAuthFlow, mapMfaType, parseAttributes, parseMFATypes };\n//# sourceMappingURL=signInHelpers.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { handleCustomAuthFlowWithoutSRP, getActiveSignInUsername, getSignInResult, getSignInResultFromError } from '../utils/signInHelpers.mjs';\nimport { setActiveSignInState, resetActiveSignInState } from '../../../client/utils/store/signInStore.mjs';\nimport { cacheCognitoTokens } from '../tokenProvider/cacheTokens.mjs';\nimport '../utils/refreshAuthTokens.mjs';\nimport '../tokenProvider/errorHelpers.mjs';\nimport '../utils/types.mjs';\nimport { tokenOrchestrator } from '../tokenProvider/tokenProvider.mjs';\nimport { dispatchSignedInHubEvent } from '../utils/dispatchSignedInHubEvent.mjs';\nimport { retryOnResourceNotFoundException } from '../utils/retryOnResourceNotFoundException.mjs';\nimport { getNewDeviceMetadata } from '../utils/getNewDeviceMetadata.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Signs a user in using a custom authentication flow without password\n *\n * @param input - The SignInWithCustomAuthInput object\n * @returns AuthSignInResult\n * @throws service: {@link InitiateAuthException } - Cognito service errors thrown during the sign-in process.\n * @throws validation: {@link AuthValidationErrorCode } - Validation errors thrown when either username or password\n * are not defined.\n * @throws SignInWithCustomAuthOutput - Thrown when the token provider config is invalid.\n */\nasync function signInWithCustomAuth(input) {\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n const { username, password, options } = input;\n const signInDetails = {\n loginId: username,\n authFlowType: 'CUSTOM_WITHOUT_SRP',\n };\n const metadata = options?.clientMetadata;\n assertValidationError(!!username, AuthValidationErrorCode.EmptySignInUsername);\n assertValidationError(!password, AuthValidationErrorCode.CustomAuthSignInPassword);\n try {\n const { ChallengeName: retriedChallengeName, ChallengeParameters: retiredChallengeParameters, AuthenticationResult, Session, } = await retryOnResourceNotFoundException(handleCustomAuthFlowWithoutSRP, [username, metadata, authConfig, tokenOrchestrator], username, tokenOrchestrator);\n const activeUsername = getActiveSignInUsername(username);\n // sets up local state used during the sign-in process\n setActiveSignInState({\n signInSession: Session,\n username: activeUsername,\n challengeName: retriedChallengeName,\n signInDetails,\n });\n if (AuthenticationResult) {\n await cacheCognitoTokens({\n username: activeUsername,\n ...AuthenticationResult,\n NewDeviceMetadata: await getNewDeviceMetadata({\n userPoolId: authConfig.userPoolId,\n userPoolEndpoint: authConfig.userPoolEndpoint,\n newDeviceMetadata: AuthenticationResult.NewDeviceMetadata,\n accessToken: AuthenticationResult.AccessToken,\n }),\n signInDetails,\n });\n resetActiveSignInState();\n await dispatchSignedInHubEvent();\n return {\n isSignedIn: true,\n nextStep: { signInStep: 'DONE' },\n };\n }\n return getSignInResult({\n challengeName: retriedChallengeName,\n challengeParameters: retiredChallengeParameters,\n });\n }\n catch (error) {\n resetActiveSignInState();\n assertServiceError(error);\n const result = getSignInResultFromError(error.name);\n if (result)\n return result;\n throw error;\n }\n}\n\nexport { signInWithCustomAuth };\n//# sourceMappingURL=signInWithCustomAuth.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { handleCustomSRPAuthFlow, getActiveSignInUsername, getSignInResult, getSignInResultFromError } from '../utils/signInHelpers.mjs';\nimport { setActiveSignInState, resetActiveSignInState } from '../../../client/utils/store/signInStore.mjs';\nimport { cacheCognitoTokens } from '../tokenProvider/cacheTokens.mjs';\nimport '../utils/refreshAuthTokens.mjs';\nimport '../tokenProvider/errorHelpers.mjs';\nimport '../utils/types.mjs';\nimport { tokenOrchestrator } from '../tokenProvider/tokenProvider.mjs';\nimport { dispatchSignedInHubEvent } from '../utils/dispatchSignedInHubEvent.mjs';\nimport { getNewDeviceMetadata } from '../utils/getNewDeviceMetadata.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Signs a user in using a custom authentication flow with SRP\n *\n * @param input - The SignInWithCustomSRPAuthInput object\n * @returns SignInWithCustomSRPAuthOutput\n * @throws service: {@link InitiateAuthException }, {@link RespondToAuthChallengeException } - Cognito\n * service errors thrown during the sign-in process.\n * @throws validation: {@link AuthValidationErrorCode } - Validation errors thrown when either username or password\n * are not defined.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function signInWithCustomSRPAuth(input) {\n const { username, password, options } = input;\n const signInDetails = {\n loginId: username,\n authFlowType: 'CUSTOM_WITH_SRP',\n };\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n const metadata = options?.clientMetadata;\n assertValidationError(!!username, AuthValidationErrorCode.EmptySignInUsername);\n assertValidationError(!!password, AuthValidationErrorCode.EmptySignInPassword);\n try {\n const { ChallengeName: handledChallengeName, ChallengeParameters: handledChallengeParameters, AuthenticationResult, Session, } = await handleCustomSRPAuthFlow(username, password, metadata, authConfig, tokenOrchestrator);\n const activeUsername = getActiveSignInUsername(username);\n // sets up local state used during the sign-in process\n setActiveSignInState({\n signInSession: Session,\n username: activeUsername,\n challengeName: handledChallengeName,\n signInDetails,\n });\n if (AuthenticationResult) {\n await cacheCognitoTokens({\n username: activeUsername,\n ...AuthenticationResult,\n NewDeviceMetadata: await getNewDeviceMetadata({\n userPoolId: authConfig.userPoolId,\n userPoolEndpoint: authConfig.userPoolEndpoint,\n newDeviceMetadata: AuthenticationResult.NewDeviceMetadata,\n accessToken: AuthenticationResult.AccessToken,\n }),\n signInDetails,\n });\n resetActiveSignInState();\n await dispatchSignedInHubEvent();\n return {\n isSignedIn: true,\n nextStep: { signInStep: 'DONE' },\n };\n }\n return getSignInResult({\n challengeName: handledChallengeName,\n challengeParameters: handledChallengeParameters,\n });\n }\n catch (error) {\n resetActiveSignInState();\n assertServiceError(error);\n const result = getSignInResultFromError(error.name);\n if (result)\n return result;\n throw error;\n }\n}\n\nexport { signInWithCustomSRPAuth };\n//# sourceMappingURL=signInWithCustomSRPAuth.mjs.map\n","import { autoSignInStore } from '../../../client/utils/store/autoSignInStore.mjs';\nimport '../../../client/utils/store/signInStore.mjs';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { AUTO_SIGN_IN_EXCEPTION } from '../../../errors/constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst initialAutoSignIn = async () => {\n throw new AuthError({\n name: AUTO_SIGN_IN_EXCEPTION,\n message: 'The autoSignIn flow has not started, or has been cancelled/completed.',\n recoverySuggestion: 'Please try to use the signIn API or log out before starting a new autoSignIn flow.',\n });\n};\n/**\n * Signs a user in automatically after finishing the sign-up process.\n *\n * This API will automatically sign a user in if the autoSignIn flow has been completed in the following cases:\n * - User confirmed their account with a verification code sent to their phone or email (default option).\n * - User confirmed their account with a verification link sent to their phone or email. In order to\n * enable this option you need to go to the Amazon Cognito [console](https://aws.amazon.com/pm/cognito),\n * look for your userpool, then go to the `Messaging` tab and enable `link` mode inside the `Verification message` option.\n * Finally you need to define the `signUpVerificationMethod` in your `Auth` config.\n *\n * @example\n * ```typescript\n * Amplify.configure({\n * Auth: {\n * Cognito: {\n * ...cognitoConfig,\n * signUpVerificationMethod: \"link\" // the default value is \"code\"\n * }\n *\t}});\n * ```\n *\n * @throws AutoSignInException - Thrown when the autoSignIn flow has not started, or has been cancelled/completed.\n * @returns The signInOutput.\n *\n * @example\n * ```typescript\n * // handleSignUp.ts\n * async function handleSignUp(\n * username:string,\n * password:string\n * ){\n * try {\n * const { nextStep } = await signUp({\n * username,\n * password,\n * options: {\n * userAttributes:{ email:'email@email.com'},\n * autoSignIn: true // This enables the auto sign-in flow.\n * },\n * });\n *\n * handleSignUpStep(nextStep);\n *\n * } catch (error) {\n * console.log(error);\n * }\n * }\n *\n * // handleConfirmSignUp.ts\n * async function handleConfirmSignUp(username:string, confirmationCode:string) {\n * try {\n * const { nextStep } = await confirmSignUp({\n * username,\n * confirmationCode,\n * });\n *\n * handleSignUpStep(nextStep);\n * } catch (error) {\n * console.log(error);\n * }\n * }\n *\n * // signUpUtils.ts\n * async function handleSignUpStep( step: SignUpOutput[\"nextStep\"]) {\n * switch (step.signUpStep) {\n * case \"CONFIRM_SIGN_UP\":\n *\n * // Redirect end-user to confirm-sign up screen.\n *\n * case \"COMPLETE_AUTO_SIGN_IN\":\n *\t const codeDeliveryDetails = step.codeDeliveryDetails;\n * if (codeDeliveryDetails) {\n * // Redirect user to confirm-sign-up with link screen.\n * }\n * const signInOutput = await autoSignIn();\n * // handle sign-in steps\n * }\n *\n * ```\n */\n// TODO(Eslint): can this be refactored not using `let` on exported member?\n// eslint-disable-next-line import/no-mutable-exports\nlet autoSignIn = initialAutoSignIn;\n/**\n * Sets the context of autoSignIn at run time.\n * @internal\n */\nfunction setAutoSignIn(callback) {\n autoSignIn = callback;\n}\n/**\n * Resets the context\n *\n * @internal\n */\nfunction resetAutoSignIn(resetCallback = true) {\n if (resetCallback) {\n autoSignIn = initialAutoSignIn;\n }\n autoSignInStore.dispatch({ type: 'RESET' });\n}\n\nexport { autoSignIn, resetAutoSignIn, setAutoSignIn };\n//# sourceMappingURL=autoSignIn.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { handleUserSRPAuthFlow, getActiveSignInUsername, getSignInResult, getSignInResultFromError } from '../utils/signInHelpers.mjs';\nimport { setActiveSignInState, resetActiveSignInState } from '../../../client/utils/store/signInStore.mjs';\nimport { cacheCognitoTokens } from '../tokenProvider/cacheTokens.mjs';\nimport '../utils/refreshAuthTokens.mjs';\nimport '../tokenProvider/errorHelpers.mjs';\nimport '../utils/types.mjs';\nimport { tokenOrchestrator } from '../tokenProvider/tokenProvider.mjs';\nimport { dispatchSignedInHubEvent } from '../utils/dispatchSignedInHubEvent.mjs';\nimport { getNewDeviceMetadata } from '../utils/getNewDeviceMetadata.mjs';\nimport { resetAutoSignIn } from './autoSignIn.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Signs a user in\n *\n * @param input - The SignInWithSRPInput object\n * @returns SignInWithSRPOutput\n * @throws service: {@link InitiateAuthException }, {@link RespondToAuthChallengeException } - Cognito service errors\n * thrown during the sign-in process.\n * @throws validation: {@link AuthValidationErrorCode } - Validation errors thrown when either username or password\n * are not defined.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function signInWithSRP(input) {\n const { username, password } = input;\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n const signInDetails = {\n loginId: username,\n authFlowType: 'USER_SRP_AUTH',\n };\n assertTokenProviderConfig(authConfig);\n const clientMetaData = input.options?.clientMetadata;\n assertValidationError(!!username, AuthValidationErrorCode.EmptySignInUsername);\n assertValidationError(!!password, AuthValidationErrorCode.EmptySignInPassword);\n try {\n const { ChallengeName: handledChallengeName, ChallengeParameters: handledChallengeParameters, AuthenticationResult, Session, } = await handleUserSRPAuthFlow(username, password, clientMetaData, authConfig, tokenOrchestrator);\n const activeUsername = getActiveSignInUsername(username);\n // sets up local state used during the sign-in process\n setActiveSignInState({\n signInSession: Session,\n username: activeUsername,\n challengeName: handledChallengeName,\n signInDetails,\n });\n if (AuthenticationResult) {\n await cacheCognitoTokens({\n username: activeUsername,\n ...AuthenticationResult,\n NewDeviceMetadata: await getNewDeviceMetadata({\n userPoolId: authConfig.userPoolId,\n userPoolEndpoint: authConfig.userPoolEndpoint,\n newDeviceMetadata: AuthenticationResult.NewDeviceMetadata,\n accessToken: AuthenticationResult.AccessToken,\n }),\n signInDetails,\n });\n resetActiveSignInState();\n await dispatchSignedInHubEvent();\n resetAutoSignIn();\n return {\n isSignedIn: true,\n nextStep: { signInStep: 'DONE' },\n };\n }\n return getSignInResult({\n challengeName: handledChallengeName,\n challengeParameters: handledChallengeParameters,\n });\n }\n catch (error) {\n resetActiveSignInState();\n resetAutoSignIn();\n assertServiceError(error);\n const result = getSignInResultFromError(error.name);\n if (result)\n return result;\n throw error;\n }\n}\n\nexport { signInWithSRP };\n//# sourceMappingURL=signInWithSRP.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { handleUserPasswordAuthFlow, getActiveSignInUsername, getSignInResult, getSignInResultFromError } from '../utils/signInHelpers.mjs';\nimport { setActiveSignInState, resetActiveSignInState } from '../../../client/utils/store/signInStore.mjs';\nimport { cacheCognitoTokens } from '../tokenProvider/cacheTokens.mjs';\nimport '../utils/refreshAuthTokens.mjs';\nimport '../tokenProvider/errorHelpers.mjs';\nimport '../utils/types.mjs';\nimport { tokenOrchestrator } from '../tokenProvider/tokenProvider.mjs';\nimport { dispatchSignedInHubEvent } from '../utils/dispatchSignedInHubEvent.mjs';\nimport { retryOnResourceNotFoundException } from '../utils/retryOnResourceNotFoundException.mjs';\nimport { getNewDeviceMetadata } from '../utils/getNewDeviceMetadata.mjs';\nimport { resetAutoSignIn } from './autoSignIn.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Signs a user in using USER_PASSWORD_AUTH AuthFlowType\n *\n * @param input - The SignInWithUserPasswordInput object\n * @returns SignInWithUserPasswordOutput\n * @throws service: {@link InitiateAuthException } - Cognito service error thrown during the sign-in process.\n * @throws validation: {@link AuthValidationErrorCode } - Validation errors thrown when either username or password\n * are not defined.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function signInWithUserPassword(input) {\n const { username, password, options } = input;\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n const signInDetails = {\n loginId: username,\n authFlowType: 'USER_PASSWORD_AUTH',\n };\n assertTokenProviderConfig(authConfig);\n const metadata = options?.clientMetadata;\n assertValidationError(!!username, AuthValidationErrorCode.EmptySignInUsername);\n assertValidationError(!!password, AuthValidationErrorCode.EmptySignInPassword);\n try {\n const { ChallengeName: retiredChallengeName, ChallengeParameters: retriedChallengeParameters, AuthenticationResult, Session, } = await retryOnResourceNotFoundException(handleUserPasswordAuthFlow, [username, password, metadata, authConfig, tokenOrchestrator], username, tokenOrchestrator);\n const activeUsername = getActiveSignInUsername(username);\n // sets up local state used during the sign-in process\n setActiveSignInState({\n signInSession: Session,\n username: activeUsername,\n challengeName: retiredChallengeName,\n signInDetails,\n });\n if (AuthenticationResult) {\n await cacheCognitoTokens({\n ...AuthenticationResult,\n username: activeUsername,\n NewDeviceMetadata: await getNewDeviceMetadata({\n userPoolId: authConfig.userPoolId,\n userPoolEndpoint: authConfig.userPoolEndpoint,\n newDeviceMetadata: AuthenticationResult.NewDeviceMetadata,\n accessToken: AuthenticationResult.AccessToken,\n }),\n signInDetails,\n });\n resetActiveSignInState();\n await dispatchSignedInHubEvent();\n resetAutoSignIn();\n return {\n isSignedIn: true,\n nextStep: { signInStep: 'DONE' },\n };\n }\n return getSignInResult({\n challengeName: retiredChallengeName,\n challengeParameters: retriedChallengeParameters,\n });\n }\n catch (error) {\n resetActiveSignInState();\n resetAutoSignIn();\n assertServiceError(error);\n const result = getSignInResultFromError(error.name);\n if (result)\n return result;\n throw error;\n }\n}\n\nexport { signInWithUserPassword };\n//# sourceMappingURL=signInWithUserPassword.mjs.map\n","import { AuthAction } from '@aws-amplify/core/internals/utils';\nimport { getUserContextData } from '../../../providers/cognito/utils/userContextData.mjs';\nimport { createInitiateAuthClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createInitiateAuthClient.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport '../../../providers/cognito/types/errors.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../../../providers/cognito/factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport { handlePasswordSRP } from '../shared/handlePasswordSRP.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { setActiveSignInUsername } from '../../../providers/cognito/utils/setActiveSignInUsername.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Handles user authentication flow with configurable challenge preferences.\n * Supports AuthFactorType challenges through the USER_AUTH flow.\n *\n * @param {HandleUserAuthFlowInput} params - Authentication flow parameters\n * @param {string} params.username - The username for authentication\n * @param {Record} [params.clientMetadata] - Optional metadata to pass to authentication service\n * @param {CognitoUserPoolConfig} params.config - Cognito User Pool configuration\n * @param {AuthTokenOrchestrator} params.tokenOrchestrator - Manages authentication tokens and device tracking\n * @param {AuthFactorType} [params.preferredChallenge] - Optional preferred authentication method\n * @param {string} [params.password] - Required when preferredChallenge is 'PASSWORD' or 'PASSWORD_SRP'\n *\n * @returns {Promise} The authentication response from Cognito\n */\nasync function handleUserAuthFlow({ username, clientMetadata, config, tokenOrchestrator, preferredChallenge, password, session, }) {\n const { userPoolId, userPoolClientId, userPoolEndpoint } = config;\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const authParameters = { USERNAME: username };\n if (preferredChallenge) {\n if (preferredChallenge === 'PASSWORD_SRP') {\n assertValidationError(!!password, AuthValidationErrorCode.EmptySignInPassword);\n return handlePasswordSRP({\n username,\n password,\n clientMetadata,\n config,\n tokenOrchestrator,\n authFlow: 'USER_AUTH',\n preferredChallenge,\n });\n }\n if (preferredChallenge === 'PASSWORD') {\n assertValidationError(!!password, AuthValidationErrorCode.EmptySignInPassword);\n authParameters.PASSWORD = password;\n }\n authParameters.PREFERRED_CHALLENGE = preferredChallenge;\n }\n const jsonReq = {\n AuthFlow: 'USER_AUTH',\n AuthParameters: authParameters,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n };\n if (session) {\n jsonReq.Session = session;\n }\n const initiateAuth = createInitiateAuthClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const response = await initiateAuth({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignIn),\n }, jsonReq);\n // Set the active username immediately after successful authentication attempt\n // If a user starts a new sign-in while another sign-in is incomplete,\n // this ensures we're tracking the correct user for subsequent auth challenges.\n setActiveSignInUsername(username);\n return response;\n}\n\nexport { handleUserAuthFlow };\n//# sourceMappingURL=handleUserAuthFlow.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { getActiveSignInUsername, getSignInResult, getSignInResultFromError } from '../utils/signInHelpers.mjs';\nimport { autoSignInStore } from '../../../client/utils/store/autoSignInStore.mjs';\nimport { setActiveSignInState, resetActiveSignInState } from '../../../client/utils/store/signInStore.mjs';\nimport { cacheCognitoTokens } from '../tokenProvider/cacheTokens.mjs';\nimport { dispatchSignedInHubEvent } from '../utils/dispatchSignedInHubEvent.mjs';\nimport '../utils/refreshAuthTokens.mjs';\nimport '../tokenProvider/errorHelpers.mjs';\nimport '../utils/types.mjs';\nimport { tokenOrchestrator } from '../tokenProvider/tokenProvider.mjs';\nimport { handleUserAuthFlow } from '../../../client/flows/userAuth/handleUserAuthFlow.mjs';\nimport { getNewDeviceMetadata } from '../utils/getNewDeviceMetadata.mjs';\nimport { resetAutoSignIn } from './autoSignIn.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Signs a user in through a registered email or phone number without a password by by receiving and entering an OTP.\n *\n * @param input - The SignInWithUserAuthInput object\n * @returns SignInWithUserAuthOutput\n * @throws service: {@link InitiateAuthException }, {@link RespondToAuthChallengeException } - Cognito service errors\n * thrown during the sign-in process.\n * @throws validation: {@link AuthValidationErrorCode } - Validation errors thrown when either username or password -- needs to change\n * are not defined.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function signInWithUserAuth(input) {\n const { username, password, options } = input;\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n const signInDetails = {\n loginId: username,\n authFlowType: 'USER_AUTH',\n };\n assertTokenProviderConfig(authConfig);\n const clientMetaData = options?.clientMetadata;\n const preferredChallenge = options?.preferredChallenge;\n assertValidationError(!!username, AuthValidationErrorCode.EmptySignInUsername);\n try {\n const handleUserAuthFlowInput = {\n username,\n config: authConfig,\n tokenOrchestrator,\n clientMetadata: clientMetaData,\n preferredChallenge,\n password,\n };\n const autoSignInStoreState = autoSignInStore.getState();\n if (autoSignInStoreState.active &&\n autoSignInStoreState.username === username) {\n handleUserAuthFlowInput.session = autoSignInStoreState.session;\n }\n const response = await handleUserAuthFlow(handleUserAuthFlowInput);\n const activeUsername = getActiveSignInUsername(username);\n setActiveSignInState({\n signInSession: response.Session,\n username: activeUsername,\n challengeName: response.ChallengeName,\n signInDetails,\n });\n if (response.AuthenticationResult) {\n await cacheCognitoTokens({\n username: activeUsername,\n ...response.AuthenticationResult,\n NewDeviceMetadata: await getNewDeviceMetadata({\n userPoolId: authConfig.userPoolId,\n userPoolEndpoint: authConfig.userPoolEndpoint,\n newDeviceMetadata: response.AuthenticationResult.NewDeviceMetadata,\n accessToken: response.AuthenticationResult.AccessToken,\n }),\n signInDetails,\n });\n resetActiveSignInState();\n await dispatchSignedInHubEvent();\n resetAutoSignIn();\n return {\n isSignedIn: true,\n nextStep: { signInStep: 'DONE' },\n };\n }\n return getSignInResult({\n challengeName: response.ChallengeName,\n challengeParameters: response.ChallengeParameters,\n availableChallenges: 'AvailableChallenges' in response\n ? response.AvailableChallenges\n : undefined,\n });\n }\n catch (error) {\n resetActiveSignInState();\n resetAutoSignIn();\n assertServiceError(error);\n const result = getSignInResultFromError(error.name);\n if (result)\n return result;\n throw error;\n }\n}\n\nexport { signInWithUserAuth };\n//# sourceMappingURL=signInWithUserAuth.mjs.map\n","import { assertUserNotAuthenticated } from '../utils/signInHelpers.mjs';\nimport { signInWithCustomAuth } from './signInWithCustomAuth.mjs';\nimport { signInWithCustomSRPAuth } from './signInWithCustomSRPAuth.mjs';\nimport { signInWithSRP } from './signInWithSRP.mjs';\nimport { signInWithUserPassword } from './signInWithUserPassword.mjs';\nimport { signInWithUserAuth } from './signInWithUserAuth.mjs';\nimport { resetAutoSignIn } from './autoSignIn.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Signs a user in\n *\n * @param input - The SignInInput object\n * @returns SignInOutput\n * @throws service: {@link InitiateAuthException }, {@link RespondToAuthChallengeException }\n * - Cognito service errors thrown during the sign-in process.\n * @throws validation: {@link AuthValidationErrorCode } - Validation errors thrown when either username or password\n * are not defined.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function signIn(input) {\n // Here we want to reset the store but not reassign the callback.\n // The callback is reset when the underlying promise resolves or rejects.\n // With the advent of session based sign in, this guarantees that the signIn API initiates a new auth flow,\n // regardless of whether it is called for a user currently engaged in an active auto sign in session.\n resetAutoSignIn(false);\n const authFlowType = input.options?.authFlowType;\n await assertUserNotAuthenticated();\n switch (authFlowType) {\n case 'USER_SRP_AUTH':\n return signInWithSRP(input);\n case 'USER_PASSWORD_AUTH':\n return signInWithUserPassword(input);\n case 'CUSTOM_WITHOUT_SRP':\n return signInWithCustomAuth(input);\n case 'CUSTOM_WITH_SRP':\n return signInWithCustomSRPAuth(input);\n case 'USER_AUTH':\n return signInWithUserAuth(input);\n default:\n return signInWithSRP(input);\n }\n}\n\nexport { signIn };\n//# sourceMappingURL=signIn.mjs.map\n","import { HubInternal } from '@aws-amplify/core/internals/utils';\nimport { signIn } from '../apis/signIn.mjs';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { setAutoSignIn, resetAutoSignIn } from '../apis/autoSignIn.mjs';\nimport { AUTO_SIGN_IN_EXCEPTION } from '../../../errors/constants.mjs';\nimport { signInWithUserAuth } from '../apis/signInWithUserAuth.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst MAX_AUTOSIGNIN_POLLING_MS = 3 * 60 * 1000;\nfunction handleCodeAutoSignIn(signInInput) {\n const stopHubListener = HubInternal.listen('auth-internal', async ({ payload }) => {\n switch (payload.event) {\n case 'confirmSignUp': {\n const response = payload.data;\n if (response?.isSignUpComplete) {\n HubInternal.dispatch('auth-internal', {\n event: 'autoSignIn',\n });\n setAutoSignIn(autoSignInWithCode(signInInput));\n stopHubListener();\n }\n }\n }\n });\n // This will stop the listener if confirmSignUp is not resolved.\n const timeOutId = setTimeout(() => {\n stopHubListener();\n clearTimeout(timeOutId);\n resetAutoSignIn();\n }, MAX_AUTOSIGNIN_POLLING_MS);\n}\nfunction debounce(fun, delay) {\n let timer;\n return (args) => {\n if (!timer) {\n fun(...args);\n }\n clearTimeout(timer);\n timer = setTimeout(() => {\n timer = undefined;\n }, delay);\n };\n}\nfunction handleAutoSignInWithLink(signInInput, resolve, reject) {\n const start = Date.now();\n const autoSignInPollingIntervalId = setInterval(async () => {\n const elapsedTime = Date.now() - start;\n const maxTime = MAX_AUTOSIGNIN_POLLING_MS;\n if (elapsedTime > maxTime) {\n clearInterval(autoSignInPollingIntervalId);\n reject(new AuthError({\n name: AUTO_SIGN_IN_EXCEPTION,\n message: 'The account was not confirmed on time.',\n recoverySuggestion: 'Try to verify your account by clicking the link sent your email or phone and then login manually.',\n }));\n resetAutoSignIn();\n }\n else {\n try {\n const signInOutput = await signIn(signInInput);\n if (signInOutput.nextStep.signInStep !== 'CONFIRM_SIGN_UP') {\n resolve(signInOutput);\n clearInterval(autoSignInPollingIntervalId);\n resetAutoSignIn();\n }\n }\n catch (error) {\n clearInterval(autoSignInPollingIntervalId);\n reject(error);\n resetAutoSignIn();\n }\n }\n }, 5000);\n}\nconst debouncedAutoSignInWithLink = debounce(handleAutoSignInWithLink, 300);\nconst debouncedAutoSignWithCodeOrUserConfirmed = debounce(handleAutoSignInWithCodeOrUserConfirmed, 300);\nfunction autoSignInWhenUserIsConfirmedWithLink(signInInput) {\n return async () => {\n return new Promise((resolve, reject) => {\n debouncedAutoSignInWithLink([signInInput, resolve, reject]);\n });\n };\n}\nasync function handleAutoSignInWithCodeOrUserConfirmed(signInInput, resolve, reject) {\n try {\n const output = signInInput?.options?.authFlowType === 'USER_AUTH'\n ? await signInWithUserAuth(signInInput)\n : await signIn(signInInput);\n resolve(output);\n resetAutoSignIn();\n }\n catch (error) {\n reject(error);\n resetAutoSignIn();\n }\n}\nfunction autoSignInWithCode(signInInput) {\n return async () => {\n return new Promise((resolve, reject) => {\n debouncedAutoSignWithCodeOrUserConfirmed([signInInput, resolve, reject]);\n });\n };\n}\nconst autoSignInUserConfirmed = autoSignInWithCode;\n\nexport { autoSignInUserConfirmed, autoSignInWhenUserIsConfirmedWithLink, handleCodeAutoSignIn };\n//# sourceMappingURL=signUpHelpers.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { parseJsonError, parseJsonBody } from '@aws-amplify/core/internals/aws-client-utils';\nimport { validationErrorMap } from '../../../../common/AuthErrorStrings.mjs';\nimport { AuthError } from '../../../../errors/AuthError.mjs';\nimport { AuthValidationErrorCode } from '../../../../errors/types/validation.mjs';\nimport { assertServiceError } from '../../../../errors/utils/assertServiceError.mjs';\nimport { SignUpException } from '../../../../providers/cognito/types/errors.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createSignUpClientDeserializer = () => async (response) => {\n if (response.statusCode >= 300) {\n const error = await parseJsonError(response);\n assertServiceError(error);\n if (\n // Missing Password Error\n // 1 validation error detected: Value at 'password'failed to satisfy constraint: Member must not be null\n error.name === SignUpException.InvalidParameterException &&\n /'password'/.test(error.message) &&\n /Member must not be null/.test(error.message)) {\n const name = AuthValidationErrorCode.EmptySignUpPassword;\n const { message, recoverySuggestion } = validationErrorMap[name];\n throw new AuthError({\n name,\n message,\n recoverySuggestion,\n });\n }\n throw new AuthError({ name: error.name, message: error.message });\n }\n return parseJsonBody(response);\n};\nconst createSignUpClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('SignUp'), createSignUpClientDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createSignUpClient, createSignUpClientDeserializer };\n//# sourceMappingURL=createSignUpClient.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { toAttributeType } from '../utils/apiHelpers.mjs';\nimport { handleCodeAutoSignIn, autoSignInUserConfirmed, autoSignInWhenUserIsConfirmedWithLink } from '../utils/signUpHelpers.mjs';\nimport { getUserContextData } from '../utils/userContextData.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport { createSignUpClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createSignUpClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { autoSignInStore } from '../../../client/utils/store/autoSignInStore.mjs';\nimport '../../../client/utils/store/signInStore.mjs';\nimport { setAutoSignIn } from './autoSignIn.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Creates a user\n *\n * @param input - The SignUpInput object\n * @returns SignUpOutput\n * @throws service: {@link SignUpException } - Cognito service errors thrown during the sign-up process.\n * @throws validation: {@link AuthValidationErrorCode } - Validation errors thrown either username or password\n * are not defined.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function signUp(input) {\n const { username, password, options } = input;\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n const signUpVerificationMethod = authConfig?.signUpVerificationMethod ?? 'code';\n const { clientMetadata, validationData, autoSignIn } = input.options ?? {};\n assertTokenProviderConfig(authConfig);\n assertValidationError(!!username, AuthValidationErrorCode.EmptySignUpUsername);\n const signInServiceOptions = typeof autoSignIn !== 'boolean' ? autoSignIn : undefined;\n const signInInput = {\n username,\n options: signInServiceOptions,\n };\n // if the authFlowType is 'CUSTOM_WITHOUT_SRP' then we don't include the password\n if (signInServiceOptions?.authFlowType !== 'CUSTOM_WITHOUT_SRP') {\n signInInput.password = password;\n }\n const { userPoolId, userPoolClientId, userPoolEndpoint } = authConfig;\n const signUpClient = createSignUpClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const signUpClientInput = {\n Username: username,\n Password: undefined,\n UserAttributes: options?.userAttributes && toAttributeType(options?.userAttributes),\n ClientMetadata: clientMetadata,\n ValidationData: validationData && toAttributeType(validationData),\n ClientId: userPoolClientId,\n UserContextData: getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n }),\n };\n if (password) {\n signUpClientInput.Password = password;\n }\n const { UserSub: userId, CodeDeliveryDetails: cdd, UserConfirmed: userConfirmed, Session: session, } = await signUpClient({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignUp),\n }, signUpClientInput);\n if (signInServiceOptions || autoSignIn === true) {\n autoSignInStore.dispatch({ type: 'START' });\n autoSignInStore.dispatch({ type: 'SET_USERNAME', value: username });\n autoSignInStore.dispatch({ type: 'SET_SESSION', value: session });\n }\n const codeDeliveryDetails = {\n destination: cdd?.Destination,\n deliveryMedium: cdd?.DeliveryMedium,\n attributeName: cdd?.AttributeName,\n };\n const isSignUpComplete = !!userConfirmed;\n const isAutoSignInStarted = autoSignInStore.getState().active;\n // Sign Up Complete\n // No Confirm Sign In Step Required\n if (isSignUpComplete) {\n if (isAutoSignInStarted) {\n setAutoSignIn(autoSignInUserConfirmed(signInInput));\n return {\n isSignUpComplete: true,\n nextStep: {\n signUpStep: 'COMPLETE_AUTO_SIGN_IN',\n },\n userId,\n };\n }\n return {\n isSignUpComplete: true,\n nextStep: {\n signUpStep: 'DONE',\n },\n userId,\n };\n }\n // Sign Up Not Complete\n // Confirm Sign Up Step Required\n if (isAutoSignInStarted) {\n // Confirmation Via Link Occurs In Separate Context\n // AutoSignIn Fn Will Initiate Polling Once Executed\n if (signUpVerificationMethod === 'link') {\n setAutoSignIn(autoSignInWhenUserIsConfirmedWithLink(signInInput));\n return {\n isSignUpComplete: false,\n nextStep: {\n signUpStep: 'COMPLETE_AUTO_SIGN_IN',\n codeDeliveryDetails,\n },\n userId,\n };\n }\n // Confirmation Via Code Occurs In Same Context\n // AutoSignIn Next Step Will Be Returned From Confirm Sign Up\n handleCodeAutoSignIn(signInInput);\n }\n return {\n isSignUpComplete: false,\n nextStep: {\n signUpStep: 'CONFIRM_SIGN_UP',\n codeDeliveryDetails,\n },\n userId,\n };\n}\n\nexport { signUp };\n//# sourceMappingURL=signUp.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createForgotPasswordClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('ForgotPassword'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createForgotPasswordClient };\n//# sourceMappingURL=createForgotPasswordClient.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport { getUserContextData } from '../utils/userContextData.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../types/errors.mjs';\nimport { createForgotPasswordClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createForgotPasswordClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Resets a user's password.\n *\n * @param input - The ResetPasswordInput object.\n * @returns ResetPasswordOutput\n * @throws -{@link ForgotPasswordException }\n * Thrown due to an invalid confirmation code or password.\n * @throws -{@link AuthValidationErrorCode }\n * Thrown due to an empty username.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n **/\nasync function resetPassword(input) {\n const { username } = input;\n assertValidationError(!!username, AuthValidationErrorCode.EmptyResetPasswordUsername);\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n const { userPoolClientId, userPoolId, userPoolEndpoint } = authConfig;\n const clientMetadata = input.options?.clientMetadata;\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const forgotPassword = createForgotPasswordClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const res = await forgotPassword({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ResetPassword),\n }, {\n Username: username,\n ClientMetadata: clientMetadata,\n ClientId: userPoolClientId,\n UserContextData,\n });\n const codeDeliveryDetails = res.CodeDeliveryDetails;\n return {\n isPasswordReset: false,\n nextStep: {\n resetPasswordStep: 'CONFIRM_RESET_PASSWORD_WITH_CODE',\n codeDeliveryDetails: {\n deliveryMedium: codeDeliveryDetails?.DeliveryMedium,\n destination: codeDeliveryDetails?.Destination,\n attributeName: codeDeliveryDetails?.AttributeName,\n },\n },\n };\n}\n\nexport { resetPassword };\n//# sourceMappingURL=resetPassword.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createConfirmForgotPasswordClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('ConfirmForgotPassword'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createConfirmForgotPasswordClient };\n//# sourceMappingURL=createConfirmForgotPasswordClient.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport { getUserContextData } from '../utils/userContextData.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../types/errors.mjs';\nimport { createConfirmForgotPasswordClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createConfirmForgotPasswordClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Confirms the new password and verification code to reset the password.\n *\n * @param input - The ConfirmResetPasswordInput object.\n * @throws -{@link ConfirmForgotPasswordException }\n * Thrown due to an invalid confirmation code or password.\n * @throws -{@link AuthValidationErrorCode }\n * Thrown due to an empty confirmation code, password or username.\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function confirmResetPassword(input) {\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n const { userPoolClientId, userPoolId, userPoolEndpoint } = authConfig;\n const { username, newPassword } = input;\n assertValidationError(!!username, AuthValidationErrorCode.EmptyConfirmResetPasswordUsername);\n assertValidationError(!!newPassword, AuthValidationErrorCode.EmptyConfirmResetPasswordNewPassword);\n const code = input.confirmationCode;\n assertValidationError(!!code, AuthValidationErrorCode.EmptyConfirmResetPasswordConfirmationCode);\n const metadata = input.options?.clientMetadata;\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const confirmForgotPassword = createConfirmForgotPasswordClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n await confirmForgotPassword({\n region: getRegionFromUserPoolId(authConfig.userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmResetPassword),\n }, {\n Username: username,\n ConfirmationCode: code,\n Password: newPassword,\n ClientMetadata: metadata,\n ClientId: authConfig.userPoolClientId,\n UserContextData,\n });\n}\n\nexport { confirmResetPassword };\n//# sourceMappingURL=confirmResetPassword.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createConfirmSignUpClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('ConfirmSignUp'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createConfirmSignUpClient };\n//# sourceMappingURL=createConfirmSignUpClient.mjs.map\n","import { Amplify } from '@aws-amplify/core';\nimport { assertTokenProviderConfig, AuthAction, HubInternal } from '@aws-amplify/core/internals/utils';\nimport { assertValidationError } from '../../../errors/utils/assertValidationError.mjs';\nimport { AuthValidationErrorCode } from '../../../errors/types/validation.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport { getUserContextData } from '../utils/userContextData.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../types/errors.mjs';\nimport { createConfirmSignUpClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createConfirmSignUpClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\nimport { autoSignInStore } from '../../../client/utils/store/autoSignInStore.mjs';\nimport '../../../client/utils/store/signInStore.mjs';\nimport { resetAutoSignIn } from './autoSignIn.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Confirms a new user account.\n *\n * @param input - The ConfirmSignUpInput object.\n * @returns ConfirmSignUpOutput\n * @throws -{@link ConfirmSignUpException }\n * Thrown due to an invalid confirmation code.\n * @throws -{@link AuthValidationErrorCode }\n * Thrown due to an empty confirmation code\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function confirmSignUp(input) {\n const { username, confirmationCode, options } = input;\n const authConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(authConfig);\n const { userPoolId, userPoolClientId, userPoolEndpoint } = authConfig;\n const clientMetadata = options?.clientMetadata;\n assertValidationError(!!username, AuthValidationErrorCode.EmptyConfirmSignUpUsername);\n assertValidationError(!!confirmationCode, AuthValidationErrorCode.EmptyConfirmSignUpCode);\n const UserContextData = getUserContextData({\n username,\n userPoolId,\n userPoolClientId,\n });\n const confirmSignUpClient = createConfirmSignUpClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n const { Session: session } = await confirmSignUpClient({\n region: getRegionFromUserPoolId(authConfig.userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignUp),\n }, {\n Username: username,\n ConfirmationCode: confirmationCode,\n ClientMetadata: clientMetadata,\n ForceAliasCreation: options?.forceAliasCreation,\n ClientId: authConfig.userPoolClientId,\n UserContextData,\n });\n return new Promise((resolve, reject) => {\n try {\n const signUpOut = {\n isSignUpComplete: true,\n nextStep: {\n signUpStep: 'DONE',\n },\n };\n const autoSignInStoreState = autoSignInStore.getState();\n if (!autoSignInStoreState.active ||\n autoSignInStoreState.username !== username) {\n resolve(signUpOut);\n resetAutoSignIn();\n return;\n }\n autoSignInStore.dispatch({ type: 'SET_SESSION', value: session });\n const stopListener = HubInternal.listen('auth-internal', ({ payload }) => {\n switch (payload.event) {\n case 'autoSignIn':\n resolve({\n isSignUpComplete: true,\n nextStep: {\n signUpStep: 'COMPLETE_AUTO_SIGN_IN',\n },\n });\n stopListener();\n }\n });\n HubInternal.dispatch('auth-internal', {\n event: 'confirmSignUp',\n data: signUpOut,\n });\n }\n catch (error) {\n reject(error);\n }\n });\n}\n\nexport { confirmSignUp };\n//# sourceMappingURL=confirmSignUp.mjs.map\n","import { invalidOriginException, invalidRedirectException, invalidPreferredRedirectUrlException } from '../../../../errors/constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/** @internal */\nfunction getRedirectUrl(redirects, preferredRedirectUrl) {\n if (preferredRedirectUrl) {\n const redirectUrl = redirects?.find(redirect => redirect === preferredRedirectUrl);\n if (!redirectUrl) {\n throw invalidPreferredRedirectUrlException;\n }\n return redirectUrl;\n }\n else {\n const redirectUrlFromTheSameOrigin = redirects?.find(isSameOriginAndPathName) ??\n redirects?.find(isTheSameDomain);\n const redirectUrlFromDifferentOrigin = redirects?.find(isHttps) ?? redirects?.find(isHttp);\n if (redirectUrlFromTheSameOrigin) {\n return redirectUrlFromTheSameOrigin;\n }\n else if (redirectUrlFromDifferentOrigin) {\n throw invalidOriginException;\n }\n throw invalidRedirectException;\n }\n}\n// origin + pathname => https://example.com/app\nconst isSameOriginAndPathName = (redirect) => redirect.startsWith(\n// eslint-disable-next-line no-constant-binary-expression\nString(window.location.origin + window.location.pathname ?? '/'));\n// domain => outlook.live.com, github.com\nconst isTheSameDomain = (redirect) => redirect.includes(String(window.location.hostname));\nconst isHttp = (redirect) => redirect.startsWith('http://');\nconst isHttps = (redirect) => redirect.startsWith('https://');\n\nexport { getRedirectUrl };\n//# sourceMappingURL=getRedirectUrl.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst openAuthSession = async (url) => {\n if (!window?.location) {\n return;\n }\n // enforce HTTPS\n window.location.href = url.replace('http://', 'https://');\n};\n\nexport { openAuthSession };\n//# sourceMappingURL=openAuthSession.mjs.map\n","import { clearCredentials, Hub } from '@aws-amplify/core';\nimport { AMPLIFY_SYMBOL } from '@aws-amplify/core/internals/utils';\nimport '../refreshAuthTokens.mjs';\nimport '../../tokenProvider/errorHelpers.mjs';\nimport '../types.mjs';\nimport { tokenOrchestrator } from '../../tokenProvider/tokenProvider.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst completeOAuthSignOut = async (store) => {\n await store.clearOAuthData();\n tokenOrchestrator.clearTokens();\n await clearCredentials();\n Hub.dispatch('auth', { event: 'signedOut' }, 'Auth', AMPLIFY_SYMBOL);\n};\n\nexport { completeOAuthSignOut };\n//# sourceMappingURL=completeOAuthSignOut.mjs.map\n","import { assertOAuthConfig } from '@aws-amplify/core/internals/utils';\nimport { openAuthSession } from '../../../../utils/openAuthSession.mjs';\nimport { getRedirectUrl } from './getRedirectUrl.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst oAuthSignOutRedirect = async (authConfig, preferPrivateSession = false, redirectUrl) => {\n assertOAuthConfig(authConfig);\n const { loginWith, userPoolClientId } = authConfig;\n const { domain, redirectSignOut } = loginWith.oauth;\n const signoutUri = getRedirectUrl(redirectSignOut, redirectUrl);\n const oAuthLogoutEndpoint = `https://${domain}/logout?${Object.entries({\n client_id: userPoolClientId,\n logout_uri: encodeURIComponent(signoutUri),\n })\n .map(([k, v]) => `${k}=${v}`)\n .join('&')}`;\n return openAuthSession(oAuthLogoutEndpoint);\n};\n\nexport { oAuthSignOutRedirect };\n//# sourceMappingURL=oAuthSignOutRedirect.mjs.map\n","import { completeOAuthSignOut } from './completeOAuthSignOut.mjs';\nimport { oAuthSignOutRedirect } from './oAuthSignOutRedirect.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst handleOAuthSignOut = async (cognitoConfig, store, tokenOrchestrator, redirectUrl) => {\n const { isOAuthSignIn } = await store.loadOAuthSignIn();\n const oauthMetadata = await tokenOrchestrator.getOAuthMetadata();\n // Clear everything before attempting to visted logout endpoint since the current application\n // state could be wiped away on redirect\n await completeOAuthSignOut(store);\n // The isOAuthSignIn flag is propagated by the oAuthToken store which manages oauth keys in local storage only.\n // These keys are used to determine if a user is in an inflight or signedIn oauth states.\n // However, this behavior represents an issue when 2 apps share the same set of tokens in Cookie storage because the app that didn't\n // start the OAuth will not have access to the oauth keys.\n // A heuristic solution is to add oauth metadata to the tokenOrchestrator which will have access to the underlying\n // storage mechanism that is used by Amplify.\n if (isOAuthSignIn || oauthMetadata?.oauthSignIn) {\n // On web, this will always end up being a void action\n return oAuthSignOutRedirect(cognitoConfig, false, redirectUrl);\n }\n};\n\nexport { handleOAuthSignOut };\n//# sourceMappingURL=handleOAuthSignOut.mjs.map\n","import { composeServiceApi } from '@aws-amplify/core/internals/aws-client-utils/composers';\nimport { cognitoUserPoolTransferHandler } from './shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport { createUserPoolSerializer } from './shared/serde/createUserPoolSerializer.mjs';\nimport { createUserPoolDeserializer } from './shared/serde/createUserPoolDeserializer.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '@aws-amplify/core/internals/utils';\nimport { DEFAULT_SERVICE_CLIENT_API_CONFIG } from './constants.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst createRevokeTokenClient = (config) => composeServiceApi(cognitoUserPoolTransferHandler, createUserPoolSerializer('RevokeToken'), createUserPoolDeserializer(), {\n ...DEFAULT_SERVICE_CLIENT_API_CONFIG,\n ...config,\n});\n\nexport { createRevokeTokenClient };\n//# sourceMappingURL=createRevokeTokenClient.mjs.map\n","import { ConsoleLogger, Amplify, clearCredentials, Hub, defaultStorage } from '@aws-amplify/core';\nimport { assertTokenProviderConfig, assertOAuthConfig, AMPLIFY_SYMBOL, AuthAction } from '@aws-amplify/core/internals/utils';\nimport { getAuthUserAgentValue } from '../../../utils/getAuthUserAgentValue.mjs';\nimport '../utils/refreshAuthTokens.mjs';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport '../tokenProvider/errorHelpers.mjs';\nimport { DefaultOAuthStore } from '../utils/signInWithRedirectStore.mjs';\nimport { tokenOrchestrator } from '../tokenProvider/tokenProvider.mjs';\nimport { getRegionFromUserPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { assertAuthTokens, assertAuthTokensWithRefreshToken } from '../utils/types.mjs';\nimport '@aws-crypto/sha256-js';\nimport { handleOAuthSignOut } from '../utils/oauth/handleOAuthSignOut.mjs';\nimport { OAUTH_SIGNOUT_EXCEPTION } from '../../../errors/constants.mjs';\nimport '../../../Errors.mjs';\nimport '../../../common/AuthErrorStrings.mjs';\nimport '../../../types/Auth.mjs';\nimport '@aws-amplify/core/internals/aws-client-utils/composers';\nimport '@aws-amplify/core/internals/aws-client-utils';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/shared/handler/cognitoUserPoolTransferHandler.mjs';\nimport '../../../foundation/factories/serviceClients/cognitoIdentityProvider/constants.mjs';\nimport { createRevokeTokenClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createRevokeTokenClient.mjs';\nimport '../../../errors/types/validation.mjs';\nimport '../types/errors.mjs';\nimport { createGlobalSignOutClient } from '../../../foundation/factories/serviceClients/cognitoIdentityProvider/createGlobalSignOutClient.mjs';\nimport { createCognitoUserPoolEndpointResolver } from '../factories/createCognitoUserPoolEndpointResolver.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst logger = new ConsoleLogger('Auth');\n/**\n * Signs a user out\n *\n * @param input - The SignOutInput object\n * @throws AuthTokenConfigException - Thrown when the token provider config is invalid.\n */\nasync function signOut(input) {\n const cognitoConfig = Amplify.getConfig().Auth?.Cognito;\n assertTokenProviderConfig(cognitoConfig);\n if (input?.global) {\n await globalSignOut(cognitoConfig);\n }\n else {\n await clientSignOut(cognitoConfig);\n }\n let hasOAuthConfig;\n try {\n assertOAuthConfig(cognitoConfig);\n hasOAuthConfig = true;\n }\n catch (err) {\n hasOAuthConfig = false;\n }\n if (hasOAuthConfig) {\n const oAuthStore = new DefaultOAuthStore(defaultStorage);\n oAuthStore.setAuthConfig(cognitoConfig);\n const { type } = (await handleOAuthSignOut(cognitoConfig, oAuthStore, tokenOrchestrator, input?.oauth?.redirectUrl)) ?? {};\n if (type === 'error') {\n throw new AuthError({\n name: OAUTH_SIGNOUT_EXCEPTION,\n message: `An error occurred when attempting to log out from OAuth provider.`,\n });\n }\n }\n else {\n // complete sign out\n tokenOrchestrator.clearTokens();\n await clearCredentials();\n Hub.dispatch('auth', { event: 'signedOut' }, 'Auth', AMPLIFY_SYMBOL);\n }\n}\nasync function clientSignOut(cognitoConfig) {\n try {\n const { userPoolEndpoint, userPoolId, userPoolClientId } = cognitoConfig;\n const authTokens = await tokenOrchestrator.getTokenStore().loadTokens();\n assertAuthTokensWithRefreshToken(authTokens);\n if (isSessionRevocable(authTokens.accessToken)) {\n const revokeToken = createRevokeTokenClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n await revokeToken({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignOut),\n }, {\n ClientId: userPoolClientId,\n Token: authTokens.refreshToken,\n });\n }\n }\n catch (err) {\n // this shouldn't throw\n logger.debug('Client signOut error caught but will proceed with token removal');\n }\n}\nasync function globalSignOut(cognitoConfig) {\n try {\n const { userPoolEndpoint, userPoolId } = cognitoConfig;\n const authTokens = await tokenOrchestrator.getTokenStore().loadTokens();\n assertAuthTokens(authTokens);\n const globalSignOutClient = createGlobalSignOutClient({\n endpointResolver: createCognitoUserPoolEndpointResolver({\n endpointOverride: userPoolEndpoint,\n }),\n });\n await globalSignOutClient({\n region: getRegionFromUserPoolId(userPoolId),\n userAgentValue: getAuthUserAgentValue(AuthAction.SignOut),\n }, {\n AccessToken: authTokens.accessToken.toString(),\n });\n }\n catch (err) {\n // it should not throw\n logger.debug('Global signOut error caught but will proceed with token removal');\n }\n}\nconst isSessionRevocable = (token) => !!token?.payload?.origin_jti;\n\nexport { signOut };\n//# sourceMappingURL=signOut.mjs.map\n","// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst IdentityIdStorageKeys = {\n identityId: 'identityId',\n};\n\nexport { IdentityIdStorageKeys };\n//# sourceMappingURL=types.mjs.map\n","import { ConsoleLogger } from '@aws-amplify/core';\nimport { assertIdentityPoolIdConfig } from '@aws-amplify/core/internals/utils';\nimport { getAuthStorageKeys } from '../tokenProvider/TokenStore.mjs';\nimport { IdentityIdStorageKeys } from './types.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst logger = new ConsoleLogger('DefaultIdentityIdStore');\nclass DefaultIdentityIdStore {\n setAuthConfig(authConfigParam) {\n assertIdentityPoolIdConfig(authConfigParam.Cognito);\n this.authConfig = authConfigParam;\n this._authKeys = createKeysForAuthStorage('Cognito', authConfigParam.Cognito.identityPoolId);\n }\n constructor(keyValueStorage) {\n this._authKeys = {};\n this._hasGuestIdentityId = false;\n this.keyValueStorage = keyValueStorage;\n }\n async loadIdentityId() {\n assertIdentityPoolIdConfig(this.authConfig?.Cognito);\n try {\n if (this._primaryIdentityId) {\n return {\n id: this._primaryIdentityId,\n type: 'primary',\n };\n }\n else {\n const storedIdentityId = await this.keyValueStorage.getItem(this._authKeys.identityId);\n if (storedIdentityId) {\n this._hasGuestIdentityId = true;\n return {\n id: storedIdentityId,\n type: 'guest',\n };\n }\n return null;\n }\n }\n catch (err) {\n logger.log('Error getting stored IdentityId.', err);\n return null;\n }\n }\n async storeIdentityId(identity) {\n assertIdentityPoolIdConfig(this.authConfig?.Cognito);\n if (identity.type === 'guest') {\n this.keyValueStorage.setItem(this._authKeys.identityId, identity.id);\n // Clear in-memory storage of primary identityId\n this._primaryIdentityId = undefined;\n this._hasGuestIdentityId = true;\n }\n else {\n this._primaryIdentityId = identity.id;\n // Clear locally stored guest id\n if (this._hasGuestIdentityId) {\n this.keyValueStorage.removeItem(this._authKeys.identityId);\n this._hasGuestIdentityId = false;\n }\n }\n }\n async clearIdentityId() {\n this._primaryIdentityId = undefined;\n await this.keyValueStorage.removeItem(this._authKeys.identityId);\n }\n}\nconst createKeysForAuthStorage = (provider, identifier) => {\n return getAuthStorageKeys(IdentityIdStorageKeys)(`com.amplify.${provider}`, identifier);\n};\n\nexport { DefaultIdentityIdStore };\n//# sourceMappingURL=IdentityIdStore.mjs.map\n","import { decodeJWT } from '@aws-amplify/core/internals/utils';\nimport { AuthError } from '../../../errors/AuthError.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nfunction formLoginsMap(idToken) {\n const issuer = decodeJWT(idToken).payload.iss;\n const res = {};\n if (!issuer) {\n throw new AuthError({\n name: 'InvalidIdTokenException',\n message: 'Invalid Idtoken.',\n });\n }\n const domainName = issuer.replace(/(^\\w+:|^)\\/\\//, '');\n res[domainName] = idToken;\n return res;\n}\n\nexport { formLoginsMap };\n//# sourceMappingURL=utils.mjs.map\n","import { getId } from '@aws-amplify/core';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { getRegionFromIdentityPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { formLoginsMap } from './utils.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Provides a Cognito identityId\n *\n * @param tokens - The AuthTokens received after SignIn\n * @returns string\n * @throws configuration exceptions: `InvalidIdentityPoolIdException`\n * - Auth errors that may arise from misconfiguration.\n * @throws service exceptions: {@link GetIdException }\n */\nasync function cognitoIdentityIdProvider({ tokens, authConfig, identityIdStore, }) {\n identityIdStore.setAuthConfig({ Cognito: authConfig });\n // will return null only if there is no identityId cached or if there is an error retrieving it\n const identityId = await identityIdStore.loadIdentityId();\n if (identityId) {\n return identityId.id;\n }\n const logins = tokens?.idToken\n ? formLoginsMap(tokens.idToken.toString())\n : {};\n const generatedIdentityId = await generateIdentityId(logins, authConfig);\n // Store generated identityId\n identityIdStore.storeIdentityId({\n id: generatedIdentityId,\n type: tokens ? 'primary' : 'guest',\n });\n return generatedIdentityId;\n}\nasync function generateIdentityId(logins, authConfig) {\n const identityPoolId = authConfig?.identityPoolId;\n const region = getRegionFromIdentityPoolId(identityPoolId);\n // IdentityId is absent so get it using IdentityPoolId with Cognito's GetId API\n let idResult;\n // for a first-time user, this will return a brand new identity\n // for a returning user, this will retrieve the previous identity assocaited with the logins\n try {\n idResult = (await getId({\n region,\n }, {\n IdentityPoolId: identityPoolId,\n Logins: logins,\n })).IdentityId;\n }\n catch (e) {\n assertServiceError(e);\n throw new AuthError(e);\n }\n if (!idResult) {\n throw new AuthError({\n name: 'GetIdResponseException',\n message: 'Received undefined response from getId operation',\n recoverySuggestion: 'Make sure to pass a valid identityPoolId in the configuration.',\n });\n }\n return idResult;\n}\n\nexport { cognitoIdentityIdProvider };\n//# sourceMappingURL=IdentityIdProvider.mjs.map\n","import { ConsoleLogger, getCredentialsForIdentity } from '@aws-amplify/core';\nimport { assertIdentityPoolIdConfig } from '@aws-amplify/core/internals/utils';\nimport { AuthError } from '../../../errors/AuthError.mjs';\nimport { assertServiceError } from '../../../errors/utils/assertServiceError.mjs';\nimport { getRegionFromIdentityPoolId } from '../../../foundation/parsers/regionParsers.mjs';\nimport { assertIdTokenInAuthTokens } from '../utils/types.mjs';\nimport { cognitoIdentityIdProvider } from './IdentityIdProvider.mjs';\nimport { formLoginsMap } from './utils.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst logger = new ConsoleLogger('CognitoCredentialsProvider');\nconst CREDENTIALS_TTL = 50 * 60 * 1000; // 50 min, can be modified on config if required in the future\nclass CognitoAWSCredentialsAndIdentityIdProvider {\n constructor(identityIdStore) {\n this._nextCredentialsRefresh = 0;\n this._identityIdStore = identityIdStore;\n }\n async clearCredentialsAndIdentityId() {\n logger.debug('Clearing out credentials and identityId');\n this._credentialsAndIdentityId = undefined;\n await this._identityIdStore.clearIdentityId();\n }\n async clearCredentials() {\n logger.debug('Clearing out in-memory credentials');\n this._credentialsAndIdentityId = undefined;\n }\n async getCredentialsAndIdentityId(getCredentialsOptions) {\n const isAuthenticated = getCredentialsOptions.authenticated;\n const { tokens } = getCredentialsOptions;\n const { authConfig } = getCredentialsOptions;\n try {\n assertIdentityPoolIdConfig(authConfig?.Cognito);\n }\n catch {\n // No identity pool configured, skipping\n return;\n }\n if (!isAuthenticated && !authConfig.Cognito.allowGuestAccess) {\n // TODO(V6): return partial result like Native platforms\n return;\n }\n const { forceRefresh } = getCredentialsOptions;\n const tokenHasChanged = this.hasTokenChanged(tokens);\n const identityId = await cognitoIdentityIdProvider({\n tokens,\n authConfig: authConfig.Cognito,\n identityIdStore: this._identityIdStore,\n });\n // Clear cached credentials when forceRefresh is true OR the cache token has changed\n if (forceRefresh || tokenHasChanged) {\n this.clearCredentials();\n }\n if (!isAuthenticated) {\n return this.getGuestCredentials(identityId, authConfig.Cognito);\n }\n else {\n assertIdTokenInAuthTokens(tokens);\n return this.credsForOIDCTokens(authConfig.Cognito, tokens, identityId);\n }\n }\n async getGuestCredentials(identityId, authConfig) {\n // Return existing in-memory cached credentials only if it exists, is not past it's lifetime and is unauthenticated credentials\n if (this._credentialsAndIdentityId &&\n !this.isPastTTL() &&\n this._credentialsAndIdentityId.isAuthenticatedCreds === false) {\n logger.info('returning stored credentials as they neither past TTL nor expired.');\n return this._credentialsAndIdentityId;\n }\n // Clear to discard if any authenticated credentials are set and start with a clean slate\n this.clearCredentials();\n const region = getRegionFromIdentityPoolId(authConfig.identityPoolId);\n // use identityId to obtain guest credentials\n // save credentials in-memory\n // No logins params should be passed for guest creds:\n // https://docs.aws.amazon.com/cognitoidentity/latest/APIReference/API_GetCredentialsForIdentity.html\n let clientResult;\n try {\n clientResult = await getCredentialsForIdentity({ region }, {\n IdentityId: identityId,\n });\n }\n catch (e) {\n assertServiceError(e);\n throw new AuthError(e);\n }\n if (clientResult?.Credentials?.AccessKeyId &&\n clientResult?.Credentials?.SecretKey) {\n this._nextCredentialsRefresh = new Date().getTime() + CREDENTIALS_TTL;\n const res = {\n credentials: {\n accessKeyId: clientResult.Credentials.AccessKeyId,\n secretAccessKey: clientResult.Credentials.SecretKey,\n sessionToken: clientResult.Credentials.SessionToken,\n expiration: clientResult.Credentials.Expiration,\n },\n identityId,\n };\n if (clientResult.IdentityId) {\n res.identityId = clientResult.IdentityId;\n this._identityIdStore.storeIdentityId({\n id: clientResult.IdentityId,\n type: 'guest',\n });\n }\n this._credentialsAndIdentityId = {\n ...res,\n isAuthenticatedCreds: false,\n };\n return res;\n }\n else {\n throw new AuthError({\n name: 'CredentialsNotFoundException',\n message: `Cognito did not respond with either Credentials, AccessKeyId or SecretKey.`,\n });\n }\n }\n async credsForOIDCTokens(authConfig, authTokens, identityId) {\n if (this._credentialsAndIdentityId &&\n !this.isPastTTL() &&\n this._credentialsAndIdentityId.isAuthenticatedCreds === true) {\n logger.debug('returning stored credentials as they neither past TTL nor expired.');\n return this._credentialsAndIdentityId;\n }\n // Clear to discard if any unauthenticated credentials are set and start with a clean slate\n this.clearCredentials();\n const logins = authTokens.idToken\n ? formLoginsMap(authTokens.idToken.toString())\n : {};\n const region = getRegionFromIdentityPoolId(authConfig.identityPoolId);\n let clientResult;\n try {\n clientResult = await getCredentialsForIdentity({ region }, {\n IdentityId: identityId,\n Logins: logins,\n });\n }\n catch (e) {\n assertServiceError(e);\n throw new AuthError(e);\n }\n if (clientResult?.Credentials?.AccessKeyId &&\n clientResult?.Credentials?.SecretKey) {\n this._nextCredentialsRefresh = new Date().getTime() + CREDENTIALS_TTL;\n const res = {\n credentials: {\n accessKeyId: clientResult.Credentials.AccessKeyId,\n secretAccessKey: clientResult.Credentials.SecretKey,\n sessionToken: clientResult.Credentials.SessionToken,\n expiration: clientResult.Credentials.Expiration,\n },\n identityId,\n };\n if (clientResult.IdentityId) {\n res.identityId = clientResult.IdentityId;\n // note: the following call removes guest identityId from the persistent store (localStorage)\n this._identityIdStore.storeIdentityId({\n id: clientResult.IdentityId,\n type: 'primary',\n });\n }\n // Store the credentials in-memory along with the expiration\n this._credentialsAndIdentityId = {\n ...res,\n isAuthenticatedCreds: true,\n associatedIdToken: authTokens.idToken?.toString(),\n };\n return res;\n }\n else {\n throw new AuthError({\n name: 'CredentialsException',\n message: `Cognito did not respond with either Credentials, AccessKeyId or SecretKey.`,\n });\n }\n }\n isPastTTL() {\n return this._nextCredentialsRefresh === undefined\n ? true\n : this._nextCredentialsRefresh <= Date.now();\n }\n hasTokenChanged(tokens) {\n return (!!tokens &&\n !!this._credentialsAndIdentityId?.associatedIdToken &&\n tokens.idToken?.toString() !==\n this._credentialsAndIdentityId.associatedIdToken);\n }\n}\n\nexport { CognitoAWSCredentialsAndIdentityIdProvider };\n//# sourceMappingURL=credentialsProvider.mjs.map\n","import { defaultStorage } from '@aws-amplify/core';\nimport { DefaultIdentityIdStore } from './IdentityIdStore.mjs';\nimport { CognitoAWSCredentialsAndIdentityIdProvider } from './credentialsProvider.mjs';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\n/**\n * Cognito specific implmentation of the CredentialsProvider interface\n * that manages setting and getting of AWS Credentials.\n *\n * @throws configuration expections: `InvalidIdentityPoolIdException`\n * - Auth errors that may arise from misconfiguration.\n * @throws service expections: {@link GetCredentialsForIdentityException}, {@link GetIdException}\n *\n */\nconst cognitoCredentialsProvider = new CognitoAWSCredentialsAndIdentityIdProvider(new DefaultIdentityIdStore(defaultStorage));\n\nexport { CognitoAWSCredentialsAndIdentityIdProvider, DefaultIdentityIdStore, cognitoCredentialsProvider };\n//# sourceMappingURL=index.mjs.map\n","import { Amplify, CookieStorage, defaultStorage } from '@aws-amplify/core';\nimport { parseAmplifyConfig } from '@aws-amplify/core/internals/utils';\nimport { cognitoUserPoolsTokenProvider, cognitoCredentialsProvider } from '@aws-amplify/auth/cognito';\n\n// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nconst DefaultAmplify = {\n /**\n * Configures Amplify with the {@link resourceConfig} and {@link libraryOptions}.\n *\n * @param resourceConfig The {@link ResourcesConfig} object that is typically imported from the\n * `amplifyconfiguration.json` file. It can also be an object literal created inline when calling `Amplify.configure`.\n * @param libraryOptions The {@link LibraryOptions} additional options for the library.\n *\n * @example\n * import config from './amplifyconfiguration.json';\n *\n * Amplify.configure(config);\n */\n configure(resourceConfig, libraryOptions) {\n const resolvedResourceConfig = parseAmplifyConfig(resourceConfig);\n // If no Auth config is provided, no special handling will be required, configure as is.\n // Otherwise, we can assume an Auth config is provided from here on.\n if (!resolvedResourceConfig.Auth) {\n Amplify.configure(resolvedResourceConfig, libraryOptions);\n return;\n }\n // If Auth options are provided, always just configure as is.\n // Otherwise, we can assume no Auth libraryOptions were provided from here on.\n if (libraryOptions?.Auth) {\n Amplify.configure(resolvedResourceConfig, libraryOptions);\n return;\n }\n // If no Auth libraryOptions were previously configured, then always add default providers.\n if (!Amplify.libraryOptions.Auth) {\n cognitoUserPoolsTokenProvider.setAuthConfig(resolvedResourceConfig.Auth);\n cognitoUserPoolsTokenProvider.setKeyValueStorage(\n // TODO: allow configure with a public interface\n libraryOptions?.ssr\n ? new CookieStorage({ sameSite: 'lax' })\n : defaultStorage);\n Amplify.configure(resolvedResourceConfig, {\n ...libraryOptions,\n Auth: {\n tokenProvider: cognitoUserPoolsTokenProvider,\n credentialsProvider: cognitoCredentialsProvider,\n },\n });\n return;\n }\n // At this point, Auth libraryOptions would have been previously configured and no overriding\n // Auth options were given, so we should preserve the currently configured Auth libraryOptions.\n if (libraryOptions) {\n // If ssr is provided through libraryOptions, we should respect the intentional reconfiguration.\n if (libraryOptions.ssr !== undefined) {\n cognitoUserPoolsTokenProvider.setKeyValueStorage(\n // TODO: allow configure with a public interface\n libraryOptions.ssr\n ? new CookieStorage({ sameSite: 'lax' })\n : defaultStorage);\n }\n Amplify.configure(resolvedResourceConfig, {\n Auth: Amplify.libraryOptions.Auth,\n ...libraryOptions,\n });\n return;\n }\n // Finally, if there were no libraryOptions given at all, we should simply not touch the currently\n // configured libraryOptions.\n Amplify.configure(resolvedResourceConfig);\n },\n /**\n * Returns the {@link ResourcesConfig} object passed in as the `resourceConfig` parameter when calling\n * `Amplify.configure`.\n *\n * @returns An {@link ResourcesConfig} object.\n */\n getConfig() {\n return Amplify.getConfig();\n },\n};\n\nexport { DefaultAmplify };\n//# sourceMappingURL=initSingleton.mjs.map\n"],"names":["AWS_CLOUDWATCH_CATEGORY","NO_HUBCALLBACK_PROVIDED_EXCEPTION","LogType","LOG_LEVELS","ConsoleLogger","name","level","n","dt","config","type","msg","loggerLevelName","loggerLevel","log","prefix","message","obj","plugin","logEvent","pluggable","AmplifyError","recoverySuggestion","underlyingError","metadata","extendedRequestId","httpStatusCode","requestId","AmplifyErrorCode","createAssertionFunction","errorMap","AssertionError","assertion","additionalContext","AMPLIFY_SYMBOL","logger","HubClass","channel","listener","holder","callback","payload","source","ampSymbol","capsule","e","listenerName","cb","Hub","HubInternal","getCrypto","getBtoa","getAtob","base64Decoder","input","options","inputStr","AuthConfigurationErrorCode","authConfigurationErrorMap","assert","assertTokenProviderConfig","cognitoConfig","assertionValid","assertOAuthConfig","validOAuthConfig","_b","_a","_d","_c","_f","_e","_h","_g","assertIdentityPoolIdConfig","validConfig","decodeJWT","token","tokenParts","base64","jsonStr","char","deepFreeze","object","propNames","value","authTypeMapping","parseAWSExports","aws_appsync_apiKey","aws_appsync_authenticationType","aws_appsync_graphqlEndpoint","aws_appsync_region","aws_bots_config","aws_cognito_identity_pool_id","aws_cognito_sign_up_verification_method","aws_cognito_mfa_configuration","aws_cognito_mfa_types","aws_cognito_password_protection_settings","aws_cognito_verification_mechanisms","aws_cognito_signup_attributes","aws_cognito_social_providers","aws_cognito_username_attributes","aws_mandatory_sign_in","aws_mobile_analytics_app_id","aws_mobile_analytics_app_region","aws_user_files_s3_bucket","aws_user_files_s3_bucket_region","aws_user_files_s3_dangerously_connect_to_http_endpoint_for_testing","aws_user_pools_id","aws_user_pools_web_client_id","geo","oauth","predictions","aws_cloud_logic_custom","Notifications","modelIntrospection","amplifyConfig","InAppMessaging","Push","appId","region","bot","defaultAuthMode","mfaConfig","passwordFormatConfig","userAttributes","attributes","key","loginWithEmailEnabled","loginWithPhoneEnabled","hasOAuthConfig","hasSocialProviderConfig","getOAuthConfig","parseSocialProviders","amazon_location_service","acc","api","endpoint","service","voiceId","getRedirectUrl","redirectStr","domain","scope","redirectSignIn","redirectSignOut","responseType","provider","updatedProvider","ADD_OAUTH_LISTENER","getRandomValues","rnds8","rng","byteToHex","i","unsafeStringify","arr","offset","randomUUID","native","v4","buf","rnds","isAmplifyOutputs","version","parseStorage","amplifyOutputsStorageProperties","bucket_name","aws_region","buckets","createBucketInfoMap","parseAuth","amplifyOutputsAuthProperties","user_pool_id","user_pool_client_id","identity_pool_id","password_policy","mfa_configuration","mfa_methods","unauthenticated_identities_enabled","username_attributes","standard_required_attributes","groups","authConfig","getMfaStatus","getOAuthProviders","curr","parseAnalytics","amplifyOutputsAnalyticsProperties","amazon_pinpoint","parseGeo","geofence_collections","maps","search_indices","parseData","amplifyOutputsDataProperties","default_authorization_type","url","api_key","model_introspection","getGraphQLAuthMode","parseCustom","amplifyOutputsCustomProperties","parseNotifications","amplifyOutputsNotificationsProperties","channels","amazon_pinpoint_app_id","hasInAppMessaging","hasPushNotification","notificationsConfig","parseAmplifyOutputs","amplifyOutputs","resourcesConfig","customConfig","authModeNames","authType","providerNames","providers","oAuthProviders","mfaConfiguration","mappedBuckets","bucketName","paths","sanitizedPaths","parseAmplifyConfig","BLOCK_SIZE","DIGEST_LENGTH","KEY","INIT","MAX_HASHABLE_LENGTH","RawSha256","data","position","byteLength","bitsHashed","bufferView","undecoratedLength","out","buffer","state","state0","state1","state2","state3","state4","state5","state6","state7","u","t1_1","t2_1","t1","t2","fromUtf8","Buffer","fromUtf8Browser","convertToBuffer","isEmptyData","Sha256","secret","toHash","__awaiter","__generator","inner","bufferFromSecret","outer","bufferHash","SHORT_TO_HEX","encodedByte","toHex","bytes","Framework","Category","AiAction","AnalyticsAction","ApiAction","AuthAction","DataStoreAction","GeoAction","InAppMessagingAction","InteractionsAction","PredictionsAction","PubSubAction","PushNotificationAction","StorageAction","globalExists","global","windowExists","documentExists","processExists","process","keyPrefixMatch","reactWebDetect","elementKeyPrefixedWithReact","elementIsReactEnabled","element","allElementsWithId","reactSSRDetect","define_process_env_default","vueWebDetect","vueSSRDetect","svelteWebDetect","svelteSSRDetect","nextWebDetect","nextSSRDetect","nuxtWebDetect","nuxtSSRDetect","angularWebDetect","angularVersionSetInDocument","angularContentSetInWindow","angularSSRDetect","reactNativeDetect","expoDetect","webDetect","detectionMap","detect","detectionEntry","frameworkCache","frameworkChangeObservers","resetTriggered","SSR_RESET_TIMEOUT","WEB_RESET_TIMEOUT","PRIME_FRAMEWORK_DELAY","detectFramework","fcn","resetTimeout","observeFrameworkChanges","clearCache","framework","delay","customUserAgentState","getCustomUserAgent","category","BASE_USER_AGENT","sanitizeAmplifyVersion","amplifyVersion","getAmplifyUserAgentObject","action","userAgent","customState","getAmplifyUserAgent","customUserAgentDetails","agentKey","agentValue","isBrowser","AuthClass","authResourcesConfig","authOptions","credentialsAndIdentityId","userSub","tokens","AmplifyClass","libraryOptions","resolvedResourceConfig","Amplify","fetchAuthSession","amplify","fetchAuthSession$1","clearCredentials","parseMetadata","response","headers","statusCode","isMetadataBearer","parseJsonError","body","parseJsonBody","code","rawValue","cleanValue","error","output","composeServiceApi","transferHandler","serializer","deserializer","defaultConfig","resolvedConfig","request","defaultPartition","partitionsInfo","getDnsSuffix","partitions","regions","outputs","regionRegex","regex","DEFAULT_RETRY_ATTEMPTS","AMZ_SDK_INVOCATION_ID_HEADER","AMZ_SDK_REQUEST_HEADER","DEFAULT_MAX_DELAY_MS","retryMiddlewareFactory","maxAttempts","retryDecider","computeDelay","abortSignal","next","context","attemptsCount","handleTerminalErrorOrResponse","addOrIncrementMetadataAttempts","isCredentialsExpiredError","retryable","cancellableSleep","timeoutMs","timeoutId","sleepPromiseResolveFn","sleepPromise","resolve","cancelSleep","_","nextHandlerOutput","attempts","amplifyUuid","amzSdkInvocationIdHeaderMiddlewareFactory","amzSdkRequestHeaderMiddlewareFactory","userAgentMiddlewareFactory","userAgentHeader","userAgentValue","headerName","composeTransferHandler","coreHandler","middleware","composedHandler","composeHandlerRequest","m","withMemoization","payloadAccessor","cached","shouldSendBody","method","fetchTransferHandler","cache","withCrossDomainCredentials","resp","responseHeaders","httpResponse","bodyWithMixin","unauthenticatedHandler","MAX_DELAY_MS","jitteredBackoff","maxDelayMs","attempt","jitteredBackoff$1","CLOCK_SKEW_ERROR_CODES","isClockSkewError","errorCode","getRetryDecider","errorParser","parsedError","isConnectionError","isThrottlingError","isServerSideError","THROTTLING_ERROR_CODES","TIMEOUT_ERROR_CODES","AmplifyUrl","AmplifyUrlSearchParams","SERVICE_NAME","endpointResolver","disableCacheMiddlewareFactory","cognitoIdentityTransferHandler","getSharedHeaders","operation","buildHttpRpcRequest","getIdSerializer","getIdDeserializer","getId","getCredentialsForIdentitySerializer","getCredentialsForIdentityDeserializer","deserializeCredentials","AccessKeyId","SecretKey","SessionToken","Expiration","getCredentialsForIdentity","PlatformNotSupportedError","KeyValueStorage","storage","InMemoryStorage","index","getLocalStorageWithFallback","getSessionStorageWithFallback","DefaultStorage","SessionStorage","SyncKeyValueStorage","SyncSessionStorage","assign","target","defaultConverter","init","converter","defaultAttributes","set","stringifiedAttributes","attributeName","get","cookies","jar","parts","found","CookieStorage","path","expires","sameSite","secure","JsCookie","cookie","promises","defaultStorage","syncSessionStorage","getSignedHeaders","AMZ_DATE_QUERY_PARAM","TOKEN_QUERY_PARAM","AUTH_HEADER","HOST_HEADER","AMZ_DATE_HEADER","TOKEN_HEADER","KEY_TYPE_IDENTIFIER","SHA256_ALGORITHM_IDENTIFIER","SIGNATURE_IDENTIFIER","EMPTY_HASH","UNSIGNED_PAYLOAD","getCredentialScope","date","getFormattedDates","longDate","getSigningValues","credentials","signingDate","signingRegion","signingService","uriEscapePath","accessKeyId","secretAccessKey","sessionToken","shortDate","credentialScope","getHashedData","sha256","getHashedDataAsHex","hashedData","getCanonicalHeaders","a","b","entry","getCanonicalQueryString","searchParams","keyA","valA","keyB","valB","val","escapeUri","uri","hexEncode","c","getCanonicalUri","pathname","getHashedPayload","isSourceData","isArrayBuffer","arg","getCanonicalRequest","getSigningKey","dateKey","regionKey","serviceKey","getStringToSign","hashedRequest","getSignature","canonicalRequest","stringToSign","signRequest","signingValues","requestToSign","signature","credentialEntry","signedHeadersEntry","signatureEntry","getSkewCorrectedDate","systemClockOffset","SKEW_WINDOW","isClockSkewed","clockTimeInMilliseconds","clockOffsetInMilliseconds","getUpdatedSystemClockOffset","currentSystemClockOffset","signingMiddlewareFactory","signRequestOptions","signedRequest","dateString","getDateHeader","extendedEncodeURIComponent","extendedCharacters","deDupeAsyncFunction","asyncFunction","inflightPromise","args","reject","result","isTokenExpired","expiresAt","clockDrift","tolerance","getDeviceName","userAgentData","platform","platformVersion","model","architecture","fullVersionList","versionList","v","bytesToString","byte","base64Encoder","encodedStr","cryptoSecureRandomInt","hexStringify","wordArray","words","sigBytes","hexChars","bite","WordArray","Words","nBytes","AuthValidationErrorCode","validationErrorMap","AuthErrorStrings","AuthErrorCodes","AuthError","params","assertValidationError","getRegionFromUserPoolId","userPoolId","getRegionFromIdentityPoolId","identityPoolId","toAttributeType","AssociateSoftwareTokenException","ChangePasswordException","ConfirmDeviceException","ConfirmForgotPasswordException","ConfirmSignUpException","DeleteUserAttributesException","DeleteUserException","ForgetDeviceException","ForgotPasswordException","GetUserException","GetIdException","GetCredentialsForIdentityException","GetUserAttributeVerificationException","GlobalSignOutException","InitiateAuthException","ResendConfirmationException","RespondToAuthChallengeException","SetUserMFAPreferenceException","SignUpException","UpdateUserAttributesException","VerifySoftwareTokenException","VerifyUserAttributeException","UpdateDeviceStatusException","ListDevicesException","USER_UNAUTHENTICATED_EXCEPTION","USER_ALREADY_AUTHENTICATED_EXCEPTION","DEVICE_METADATA_NOT_FOUND_EXCEPTION","INVALID_REDIRECT_EXCEPTION","INVALID_APP_SCHEME_EXCEPTION","INVALID_PREFERRED_REDIRECT_EXCEPTION","invalidRedirectException","INVALID_ORIGIN_EXCEPTION","invalidOriginException","OAUTH_SIGNOUT_EXCEPTION","TOKEN_REFRESH_EXCEPTION","UNEXPECTED_SIGN_IN_INTERRUPTION_EXCEPTION","assertAuthTokens","assertIdTokenInAuthTokens","oAuthTokenRefreshException","tokenRefreshException","assertAuthTokensWithRefreshToken","isAuthenticatedWithImplicitOauthFlow","isAuthenticatedWithRefreshToken","assertDeviceMetadata","deviceMetadata","OAuthStorageKeys","isAuthenticated","getCurrentUser","username","sub","authUser","signInDetails","getSignInDetailsFromTokens","getCurrentUser$1","getAuthUserAgentValue","createUserPoolSerializer","assertServiceError","createUserPoolDeserializer","cognitoUserPoolTransferHandler","COGNITO_IDP_SERVICE_NAME","DEFAULT_SERVICE_CLIENT_API_CONFIG","createInitiateAuthClient","createRespondToAuthChallengeClient","createAssociateSoftwareTokenClient","cognitoUserPoolEndpointResolver","createCognitoUserPoolEndpointResolver","endpointOverride","getUserContextData","userPoolClientId","amazonCognitoAdvancedSecurityData","advancedSecurityData","refreshAuthTokensFunction","userPoolEndpoint","refreshTokenString","AuthParameters","UserContextData","initiateAuth","AuthenticationResult","accessToken","idToken","iat","refreshAuthTokens","AuthTokenStorageKeys","TokenProviderErrorCode","tokenValidationErrorMap","AUTH_KEY_PREFIX","DefaultTokenStore","keyValueStorage","authKeys","accessTokenString","itString","refreshToken","clockDriftString","lastAuthUser","deviceKey","deviceGroupKey","randomPassword","createKeysForAuthStorage","identifier","oauthMetadataKey","oauthMetadata","getAuthStorageKeys","keys","authKey","V5_HOSTED_UI_KEY","DefaultOAuthStore","pkce","authConfigParam","inflight","isLegacyHostedUISignIn","isOAuthSignIn","preferPrivateSession","oauthSignIn","oAuthStore","TokenOrchestrator","_reject","tokenRefresher","tokenStore","idTokenExpired","accessTokenExpired","newTokens","err","CognitoUserPoolsTokenProvider","forceRefresh","cognitoUserPoolsTokenProvider","tokenOrchestrator","cacheCognitoTokens","accessTokenIssuedAtInMillis","currentTime","ERROR_MESSAGE","dispatchSignedInHubEvent","defaultState","autoSignInReducer","createAutoSignInStore","reducer","currentState","autoSignInStore","MS_TO_EXPIRY","TGT_STATE","SIGN_IN_STATE_KEYS","signInReducer","persistSignInState","getInitialState","clearPersistedSignInState","getDefaultState","isExpired","expiryDate","expiryTimestamp","currentTimestamp","resetActiveSignInState","signInStore","stateKey","expiry","challengeName","signInSession","createStore","setActiveSignInState","PasskeyError","PasskeyErrorCode","notSupportedRecoverySuggestion","abortOrCancelRecoverySuggestion","misconfigurationRecoverySuggestion","passkeyErrorMap","assertPasskeyError","handlePasskeyAuthenticationError","handlePasskeyError","getIsPasskeySupported","convertArrayBufferToBase64Url","convertBase64UrlToArrayBuffer","base64url","x","deserializeJsonToPkcGetOptions","challengeBuffer","allowedCredentialsWithBuffer","allowedCred","serializePkcWithAssertionToJson","resultJson","assertCredentialIsPkcWithAuthenticatorAssertionResponse","credential","getPasskey","isPasskeySupported","passkeyGetOptions","createConfirmDeviceClient","textEncoder","BigInteger","nbi","dbits","canary","j_lm","am1","w","j","am2","xl","xh","l","h","am3","inBrowser","BI_FP","BI_RM","BI_RC","rr","vv","int2char","intAt","s","bnpCopyTo","r","bnpFromInt","nbv","bnpFromString","k","mi","sh","bnpClamp","bnToString","km","d","p","bnNegate","bnAbs","bnCompareTo","nbits","t","bnBitLength","bnpDLShiftTo","bnpDRShiftTo","bnpLShiftTo","bs","cbs","bm","ds","bnpRShiftTo","bnpSubTo","bnpMultiplyTo","y","bnpSquareTo","bnpDivRemTo","q","pm","pt","ts","ms","nsh","ys","y0","yt","d1","d2","qd","bnMod","bnpInvDigit","bnEquals","bnpAddTo","bnAdd","bnSubtract","bnMultiply","bnDivide","Montgomery","montConvert","montRevert","montReduce","u0","montSqrTo","montMulTo","bnModPow","z","g","k1","g2","is1","r2","calculateS","B","N","U","outerErr","outerResult","innerErr","innerResult","INIT_N","HEX_TO_SHORT","getBytesFromHex","encoded","getHexFromBytes","getHashFromData","hashHexFromUint8","getHashFromHex","hexStr","HEX_MSB_REGEX","getPaddedHex","bigInt","isNegative","invertedNibbles","invertedNibble","calculateU","A","getHkdfKey","ikm","salt","info","awsCryptoHash","resultFromAWSCryptoPrk","awsCryptoHashHmac","getRandomBytes","str","getRandomString","AuthenticationHelper","userPoolName","combinedString","hashedString","hexRandom","password","serverBValue","usernamePassword","usernamePasswordHash","S","spacer","calculateA","getAuthenticationHelper","generateRandomBigInteger","getNewDeviceMetadata","newDeviceMetadata","authenticationHelper","deviceSecretVerifierConfig","handleWebAuthnSignInResult","challengeParameters","credentialRequestOptions","cred","respondToAuthChallenge","nextChallengeName","nextChallengeParameters","authenticationResult","nextSession","MONTH_NAMES","WEEK_NAMES","getNowString","now","weekDay","month","day","hours","minutes","seconds","year","getSignatureString","dateNow","hkdf","bufUPIDaToB","bufUNaToB","bufSBaToB","urlB64ToUint8Array","bufDNaToB","bufConcat","resultFromAWSCrypto","base64String","padding","rawData","outputArray","handleDeviceSRPAuth","clientMetadata","session","clientId","challengeResponses","jsonReqResponseChallenge","respondedChallengeParameters","Session","handleDevicePasswordVerifier","handlePasswordVerifierChallenge","retryOnResourceNotFoundException","func","setActiveSignInUsername","dispatch","handlePasswordSRP","authFlow","preferredChallenge","authParameters","jsonReq","activeUsername","USER_ATTRIBUTES","isWebAuthnResultAuthSignInOutput","handleUserPasswordAuthFlow","handleUserSRPAuthFlow","handleCustomAuthFlowWithoutSRP","handleCustomSRPAuthFlow","getSignInResult","availableChallenges","mfaSetupTypes","getMFATypes","parseMFATypes","allowedMfaSetupTypes","getAllowedMfaSetupTypes","isTotpMfaSetupAvailable","isEmailMfaSetupAvailable","associateSoftwareToken","secretCode","getTOTPSetupDetails","parseAttributes","appName","accountName","totpUri","getSignInResultFromError","errorName","att","getMFAType","types","mfa","availableMfaSetupTypes","authMfaType","assertUserNotAuthenticated","getActiveSignInUsername","signInWithCustomAuth","retriedChallengeName","retiredChallengeParameters","signInWithCustomSRPAuth","handledChallengeName","handledChallengeParameters","resetAutoSignIn","resetCallback","signInWithSRP","clientMetaData","signInWithUserPassword","retiredChallengeName","retriedChallengeParameters","handleUserAuthFlow","signInWithUserAuth","handleUserAuthFlowInput","autoSignInStoreState","signIn","authFlowType","MAX_AUTOSIGNIN_POLLING_MS","handleCodeAutoSignIn","signInInput","stopHubListener","timeOutId","createSignUpClientDeserializer","createSignUpClient","signUp","signUpVerificationMethod","validationData","autoSignIn","signInServiceOptions","signUpClient","signUpClientInput","userId","cdd","userConfirmed","codeDeliveryDetails","isSignUpComplete","isAutoSignInStarted","createForgotPasswordClient","resetPassword","createConfirmForgotPasswordClient","confirmResetPassword","newPassword","createConfirmSignUpClient","confirmSignUp","confirmationCode","confirmSignUpClient","signUpOut","stopListener","redirects","preferredRedirectUrl","redirectUrlFromTheSameOrigin","isSameOriginAndPathName","isTheSameDomain","redirectUrlFromDifferentOrigin","isHttps","isHttp","redirect","openAuthSession","completeOAuthSignOut","store","oAuthSignOutRedirect","redirectUrl","loginWith","signoutUri","oAuthLogoutEndpoint","handleOAuthSignOut","createRevokeTokenClient","signOut","clientSignOut","authTokens","isSessionRevocable","IdentityIdStorageKeys","DefaultIdentityIdStore","storedIdentityId","identity","formLoginsMap","issuer","res","domainName","cognitoIdentityIdProvider","identityIdStore","identityId","logins","generatedIdentityId","generateIdentityId","idResult","CREDENTIALS_TTL","CognitoAWSCredentialsAndIdentityIdProvider","getCredentialsOptions","tokenHasChanged","clientResult","cognitoCredentialsProvider","DefaultAmplify","resourceConfig"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213]}