{"version":3,"file":"login.js","sources":["../../../node_modules/@azure/msal-common/dist/error/AuthErrorCodes.mjs","../../../node_modules/@azure/msal-common/dist/error/AuthError.mjs","../../../node_modules/@azure/msal-common/dist/error/ClientAuthErrorCodes.mjs","../../../node_modules/@azure/msal-common/dist/error/ClientAuthError.mjs","../../../node_modules/@azure/msal-common/dist/account/AuthToken.mjs","../../../node_modules/@azure/msal-common/dist/authority/AuthorityType.mjs","../../../node_modules/@azure/msal-common/dist/authority/OpenIdConfigResponse.mjs","../../../node_modules/@azure/msal-common/dist/error/ClientConfigurationErrorCodes.mjs","../../../node_modules/@azure/msal-common/dist/error/ClientConfigurationError.mjs","../../../node_modules/@azure/msal-common/dist/utils/StringUtils.mjs","../../../node_modules/@azure/msal-common/dist/utils/UrlUtils.mjs","../../../node_modules/@azure/msal-common/dist/url/UrlString.mjs","../../../node_modules/@azure/msal-common/dist/authority/AuthorityMetadata.mjs","../../../node_modules/@azure/msal-common/dist/authority/ProtocolMode.mjs","../../../node_modules/@azure/msal-common/dist/authority/AuthorityOptions.mjs","../../../node_modules/@azure/msal-common/dist/authority/CloudInstanceDiscoveryResponse.mjs","../../../node_modules/@azure/msal-common/dist/authority/CloudInstanceDiscoveryErrorResponse.mjs","../../../node_modules/@azure/msal-common/dist/telemetry/performance/PerformanceEvent.mjs","../../../node_modules/@azure/msal-common/dist/utils/FunctionWrappers.mjs","../../../node_modules/@azure/msal-common/dist/authority/RegionDiscovery.mjs","../../../node_modules/@azure/msal-common/dist/utils/TimeUtils.mjs","../../../node_modules/@azure/msal-common/dist/cache/utils/CacheHelpers.mjs","../../../node_modules/@azure/msal-common/dist/authority/Authority.mjs","../../../node_modules/@azure/msal-common/dist/authority/AuthorityFactory.mjs","../../../node_modules/@azure/msal-common/dist/utils/ClientAssertionUtils.mjs","../../../node_modules/@azure/msal-common/dist/constants/AADServerParamKeys.mjs","../../../node_modules/@azure/msal-common/dist/crypto/ICrypto.mjs","../../../node_modules/@azure/msal-common/dist/packageMetadata.mjs","../../../node_modules/@azure/msal-common/dist/request/ScopeSet.mjs","../../../node_modules/@azure/msal-common/dist/account/ClientInfo.mjs","../../../node_modules/@azure/msal-common/dist/account/AccountInfo.mjs","../../../node_modules/@azure/msal-common/dist/account/TokenClaims.mjs","../../../node_modules/@azure/msal-common/dist/cache/entities/AccountEntity.mjs","../../../node_modules/@azure/msal-common/dist/error/CacheErrorCodes.mjs","../../../node_modules/@azure/msal-common/dist/error/CacheError.mjs","../../../node_modules/@azure/msal-common/dist/cache/CacheManager.mjs","../../../node_modules/@azure/msal-common/dist/config/ClientConfiguration.mjs","../../../node_modules/@azure/msal-common/dist/error/ServerError.mjs","../../../node_modules/@azure/msal-common/dist/network/ThrottlingUtils.mjs","../../../node_modules/@azure/msal-common/dist/network/NetworkManager.mjs","../../../node_modules/@azure/msal-common/dist/account/CcsCredential.mjs","../../../node_modules/@azure/msal-common/dist/request/RequestValidator.mjs","../../../node_modules/@azure/msal-common/dist/request/RequestParameterBuilder.mjs","../../../node_modules/@azure/msal-common/dist/client/BaseClient.mjs","../../../node_modules/@azure/msal-common/dist/error/InteractionRequiredAuthErrorCodes.mjs","../../../node_modules/@azure/msal-common/dist/error/InteractionRequiredAuthError.mjs","../../../node_modules/@azure/msal-common/dist/utils/ProtocolUtils.mjs","../../../node_modules/@azure/msal-common/dist/crypto/PopTokenGenerator.mjs","../../../node_modules/@azure/msal-common/dist/cache/persistence/TokenCacheContext.mjs","../../../node_modules/@azure/msal-common/dist/response/ResponseHandler.mjs","../../../node_modules/@azure/msal-common/dist/client/AuthorizationCodeClient.mjs","../../../node_modules/@azure/msal-common/dist/client/RefreshTokenClient.mjs","../../../node_modules/@azure/msal-common/dist/client/SilentFlowClient.mjs","../../../node_modules/@azure/msal-common/dist/network/INetworkModule.mjs","../../../node_modules/@azure/msal-common/dist/error/JoseHeaderErrorCodes.mjs","../../../node_modules/@azure/msal-common/dist/error/JoseHeaderError.mjs","../../../node_modules/@azure/msal-common/dist/crypto/JoseHeader.mjs","../../../node_modules/@azure/msal-common/dist/telemetry/server/ServerTelemetryManager.mjs","../../../node_modules/@azure/msal-common/dist/telemetry/performance/StubPerformanceClient.mjs","../../../node_modules/@azure/msal-browser/dist/error/BrowserAuthErrorCodes.mjs","../../../node_modules/@azure/msal-browser/dist/error/BrowserAuthError.mjs","../../../node_modules/@azure/msal-browser/dist/utils/BrowserConstants.mjs","../../../node_modules/@azure/msal-browser/dist/encode/Base64Encode.mjs","../../../node_modules/@azure/msal-browser/dist/crypto/BrowserCrypto.mjs","../../../node_modules/@azure/msal-browser/dist/error/BrowserConfigurationAuthErrorCodes.mjs","../../../node_modules/@azure/msal-browser/dist/error/BrowserConfigurationAuthError.mjs","../../../node_modules/@azure/msal-browser/dist/utils/BrowserUtils.mjs","../../../node_modules/@azure/msal-browser/dist/navigation/NavigationClient.mjs","../../../node_modules/@azure/msal-browser/dist/network/FetchClient.mjs","../../../node_modules/@azure/msal-browser/dist/config/Configuration.mjs","../../../node_modules/@azure/msal-browser/dist/packageMetadata.mjs","../../../node_modules/@azure/msal-browser/dist/operatingcontext/BaseOperatingContext.mjs","../../../node_modules/@azure/msal-browser/dist/operatingcontext/StandardOperatingContext.mjs","../../../node_modules/@azure/msal-browser/dist/encode/Base64Decode.mjs","../../../node_modules/@azure/msal-browser/dist/cache/DatabaseStorage.mjs","../../../node_modules/@azure/msal-browser/dist/cache/MemoryStorage.mjs","../../../node_modules/@azure/msal-browser/dist/cache/AsyncMemoryStorage.mjs","../../../node_modules/@azure/msal-browser/dist/crypto/CryptoOps.mjs","../../../node_modules/@azure/msal-browser/dist/cache/BrowserStorage.mjs","../../../node_modules/@azure/msal-browser/dist/utils/BrowserProtocolUtils.mjs","../../../node_modules/@azure/msal-browser/dist/cache/BrowserCacheManager.mjs","../../../node_modules/@azure/msal-browser/dist/cache/AccountManager.mjs","../../../node_modules/@azure/msal-browser/dist/event/EventType.mjs","../../../node_modules/@azure/msal-browser/dist/event/EventHandler.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/BaseInteractionClient.mjs","../../../node_modules/@azure/msal-browser/dist/crypto/PkceGenerator.mjs","../../../node_modules/@azure/msal-browser/dist/request/RequestHelpers.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/StandardInteractionClient.mjs","../../../node_modules/@azure/msal-browser/dist/error/NativeAuthErrorCodes.mjs","../../../node_modules/@azure/msal-browser/dist/broker/nativeBroker/NativeStatusCodes.mjs","../../../node_modules/@azure/msal-browser/dist/error/NativeAuthError.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/SilentCacheClient.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/NativeInteractionClient.mjs","../../../node_modules/@azure/msal-browser/dist/broker/nativeBroker/NativeMessageHandler.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_handler/InteractionHandler.mjs","../../../node_modules/@azure/msal-browser/dist/response/ResponseHandler.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/PopupClient.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_handler/RedirectHandler.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/RedirectClient.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_handler/SilentHandler.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/SilentIframeClient.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/SilentRefreshClient.mjs","../../../node_modules/@azure/msal-browser/dist/cache/TokenCache.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/HybridSpaAuthorizationCodeClient.mjs","../../../node_modules/@azure/msal-browser/dist/interaction_client/SilentAuthCodeClient.mjs","../../../node_modules/@azure/msal-browser/dist/controllers/StandardController.mjs","../../../node_modules/@azure/msal-browser/dist/controllers/ControllerFactory.mjs","../../../node_modules/@azure/msal-browser/dist/app/PublicClientApplication.mjs","../../../node_modules/@fluentui/react-tabster/lib/hooks/useFocusableGroup.js","../../../node_modules/@fluentui/tokens/lib/themeToTokensObject.js","../../../node_modules/@fluentui/react-divider/lib/components/Divider/renderDivider.js","../../../node_modules/@fluentui/react-divider/lib/components/Divider/useDivider.js","../../../node_modules/@fluentui/react-divider/lib/components/Divider/useDividerStyles.styles.js","../../../node_modules/@fluentui/react-divider/lib/components/Divider/Divider.js","../../../node_modules/@fluentui/react-card/lib/components/Card/useCardSelectable.js","../../../node_modules/@fluentui/react-card/lib/components/Card/CardContext.js","../../../node_modules/@fluentui/react-card/lib/components/Card/useCard.js","../../../node_modules/@fluentui/react-card/lib/components/Card/renderCard.js","../../../node_modules/@fluentui/react-card/lib/components/CardHeader/useCardHeaderStyles.styles.js","../../../node_modules/@fluentui/react-card/lib/components/CardFooter/useCardFooterStyles.styles.js","../../../node_modules/@fluentui/react-card/lib/components/Card/useCardStyles.styles.js","../../../node_modules/@fluentui/react-card/lib/components/Card/useCardContextValue.js","../../../node_modules/@fluentui/react-card/lib/components/Card/Card.js","../../../node_modules/@fluentui/react-card/lib/components/CardFooter/useCardFooter.js","../../../node_modules/@fluentui/react-card/lib/components/CardFooter/renderCardFooter.js","../../../node_modules/@fluentui/react-card/lib/components/CardFooter/CardFooter.js","../../../node_modules/@fluentui/react-card/lib/components/CardHeader/useCardHeader.js","../../../node_modules/@fluentui/react-card/lib/components/CardHeader/renderCardHeader.js","../../../node_modules/@fluentui/react-card/lib/components/CardHeader/CardHeader.js","../../../node_modules/zustand/esm/vanilla.mjs","../../../node_modules/zustand/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.min.js","../../../node_modules/zustand/node_modules/use-sync-external-store/shim/index.js","../../../node_modules/zustand/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim/with-selector.production.min.js","../../../node_modules/zustand/node_modules/use-sync-external-store/shim/with-selector.js","../../../node_modules/zustand/esm/index.mjs","../../../node_modules/zustand/esm/middleware.mjs","../../../ts/apiFunctions/store/store.ts","../../../ts/apiFunctions/store/persistentStore.ts","../../../node_modules/validator/lib/util/assertString.js","../../../node_modules/validator/lib/toDate.js","../../../node_modules/validator/lib/alpha.js","../../../node_modules/validator/lib/isFloat.js","../../../node_modules/validator/lib/toFloat.js","../../../node_modules/validator/lib/toInt.js","../../../node_modules/validator/lib/toBoolean.js","../../../node_modules/validator/lib/equals.js","../../../node_modules/validator/lib/util/toString.js","../../../node_modules/validator/lib/util/merge.js","../../../node_modules/validator/lib/contains.js","../../../node_modules/validator/lib/matches.js","../../../node_modules/validator/lib/isByteLength.js","../../../node_modules/validator/lib/isFQDN.js","../../../node_modules/validator/lib/isIP.js","../../../node_modules/validator/lib/isEmail.js","../../../node_modules/validator/lib/isURL.js","../../../node_modules/validator/lib/isMACAddress.js","../../../node_modules/validator/lib/isIPRange.js","../../../node_modules/validator/lib/isDate.js","../../../node_modules/validator/lib/isTime.js","../../../node_modules/validator/lib/isBoolean.js","../../../node_modules/validator/lib/isLocale.js","../../../node_modules/validator/lib/isAlpha.js","../../../node_modules/validator/lib/isAlphanumeric.js","../../../node_modules/validator/lib/isNumeric.js","../../../node_modules/validator/lib/isPassportNumber.js","../../../node_modules/validator/lib/isInt.js","../../../node_modules/validator/lib/isPort.js","../../../node_modules/validator/lib/isLowercase.js","../../../node_modules/validator/lib/isUppercase.js","../../../node_modules/validator/lib/isIMEI.js","../../../node_modules/validator/lib/isAscii.js","../../../node_modules/validator/lib/isFullWidth.js","../../../node_modules/validator/lib/isHalfWidth.js","../../../node_modules/validator/lib/isVariableWidth.js","../../../node_modules/validator/lib/isMultibyte.js","../../../node_modules/validator/lib/util/multilineRegex.js","../../../node_modules/validator/lib/isSemVer.js","../../../node_modules/validator/lib/isSurrogatePair.js","../../../node_modules/validator/lib/util/includes.js","../../../node_modules/validator/lib/isDecimal.js","../../../node_modules/validator/lib/isHexadecimal.js","../../../node_modules/validator/lib/isOctal.js","../../../node_modules/validator/lib/isDivisibleBy.js","../../../node_modules/validator/lib/isHexColor.js","../../../node_modules/validator/lib/isRgbColor.js","../../../node_modules/validator/lib/isHSL.js","../../../node_modules/validator/lib/isISRC.js","../../../node_modules/validator/lib/isIBAN.js","../../../node_modules/validator/lib/isISO31661Alpha2.js","../../../node_modules/validator/lib/isBIC.js","../../../node_modules/validator/lib/isMD5.js","../../../node_modules/validator/lib/isHash.js","../../../node_modules/validator/lib/isBase64.js","../../../node_modules/validator/lib/isJWT.js","../../../node_modules/validator/lib/isJSON.js","../../../node_modules/validator/lib/isEmpty.js","../../../node_modules/validator/lib/isLength.js","../../../node_modules/validator/lib/isUUID.js","../../../node_modules/validator/lib/isMongoId.js","../../../node_modules/validator/lib/isAfter.js","../../../node_modules/validator/lib/isBefore.js","../../../node_modules/validator/lib/isIn.js","../../../node_modules/validator/lib/isLuhnNumber.js","../../../node_modules/validator/lib/isCreditCard.js","../../../node_modules/validator/lib/isIdentityCard.js","../../../node_modules/validator/lib/isEAN.js","../../../node_modules/validator/lib/isISIN.js","../../../node_modules/validator/lib/isISBN.js","../../../node_modules/validator/lib/isISSN.js","../../../node_modules/validator/lib/util/algorithms.js","../../../node_modules/validator/lib/isTaxID.js","../../../node_modules/validator/lib/isMobilePhone.js","../../../node_modules/validator/lib/isEthereumAddress.js","../../../node_modules/validator/lib/isCurrency.js","../../../node_modules/validator/lib/isBtcAddress.js","../../../node_modules/validator/lib/isISO6346.js","../../../node_modules/validator/lib/isISO6391.js","../../../node_modules/validator/lib/isISO8601.js","../../../node_modules/validator/lib/isRFC3339.js","../../../node_modules/validator/lib/isISO31661Alpha3.js","../../../node_modules/validator/lib/isISO4217.js","../../../node_modules/validator/lib/isBase32.js","../../../node_modules/validator/lib/isBase58.js","../../../node_modules/validator/lib/isDataURI.js","../../../node_modules/validator/lib/isMagnetURI.js","../../../node_modules/validator/lib/rtrim.js","../../../node_modules/validator/lib/ltrim.js","../../../node_modules/validator/lib/trim.js","../../../node_modules/validator/lib/isMailtoURI.js","../../../node_modules/validator/lib/isMimeType.js","../../../node_modules/validator/lib/isLatLong.js","../../../node_modules/validator/lib/isPostalCode.js","../../../node_modules/validator/lib/escape.js","../../../node_modules/validator/lib/unescape.js","../../../node_modules/validator/lib/blacklist.js","../../../node_modules/validator/lib/stripLow.js","../../../node_modules/validator/lib/whitelist.js","../../../node_modules/validator/lib/isWhitelisted.js","../../../node_modules/validator/lib/normalizeEmail.js","../../../node_modules/validator/lib/isSlug.js","../../../node_modules/validator/lib/isLicensePlate.js","../../../node_modules/validator/lib/isStrongPassword.js","../../../node_modules/validator/lib/isVAT.js","../../../node_modules/validator/index.js","../../../ts/components/login.tsx"],"sourcesContent":["/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * AuthErrorMessage class containing string constants used by error codes and messages.\n */\nconst unexpectedError = \"unexpected_error\";\nconst postRequestFailed = \"post_request_failed\";\n\nexport { postRequestFailed, unexpectedError };\n//# sourceMappingURL=AuthErrorCodes.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Constants } from '../utils/Constants.mjs';\nimport { unexpectedError, postRequestFailed } from './AuthErrorCodes.mjs';\nimport * as AuthErrorCodes from './AuthErrorCodes.mjs';\nexport { AuthErrorCodes };\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst AuthErrorMessages = {\n [unexpectedError]: \"Unexpected error in authentication.\",\n [postRequestFailed]: \"Post request failed from the network, could be a 4xx/5xx or a network unavailability. Please check the exact error code for details.\",\n};\n/**\n * AuthErrorMessage class containing string constants used by error codes and messages.\n * @deprecated Use AuthErrorCodes instead\n */\nconst AuthErrorMessage = {\n unexpectedError: {\n code: unexpectedError,\n desc: AuthErrorMessages[unexpectedError],\n },\n postRequestFailed: {\n code: postRequestFailed,\n desc: AuthErrorMessages[postRequestFailed],\n },\n};\n/**\n * General error class thrown by the MSAL.js library.\n */\nclass AuthError extends Error {\n constructor(errorCode, errorMessage, suberror) {\n const errorString = errorMessage\n ? `${errorCode}: ${errorMessage}`\n : errorCode;\n super(errorString);\n Object.setPrototypeOf(this, AuthError.prototype);\n this.errorCode = errorCode || Constants.EMPTY_STRING;\n this.errorMessage = errorMessage || Constants.EMPTY_STRING;\n this.subError = suberror || Constants.EMPTY_STRING;\n this.name = \"AuthError\";\n }\n setCorrelationId(correlationId) {\n this.correlationId = correlationId;\n }\n}\nfunction createAuthError(code, additionalMessage) {\n return new AuthError(code, additionalMessage\n ? `${AuthErrorMessages[code]} ${additionalMessage}`\n : AuthErrorMessages[code]);\n}\n\nexport { AuthError, AuthErrorMessage, AuthErrorMessages, createAuthError };\n//# sourceMappingURL=AuthError.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst clientInfoDecodingError = \"client_info_decoding_error\";\nconst clientInfoEmptyError = \"client_info_empty_error\";\nconst tokenParsingError = \"token_parsing_error\";\nconst nullOrEmptyToken = \"null_or_empty_token\";\nconst endpointResolutionError = \"endpoints_resolution_error\";\nconst networkError = \"network_error\";\nconst openIdConfigError = \"openid_config_error\";\nconst hashNotDeserialized = \"hash_not_deserialized\";\nconst invalidState = \"invalid_state\";\nconst stateMismatch = \"state_mismatch\";\nconst stateNotFound = \"state_not_found\";\nconst nonceMismatch = \"nonce_mismatch\";\nconst authTimeNotFound = \"auth_time_not_found\";\nconst maxAgeTranspired = \"max_age_transpired\";\nconst multipleMatchingTokens = \"multiple_matching_tokens\";\nconst multipleMatchingAccounts = \"multiple_matching_accounts\";\nconst multipleMatchingAppMetadata = \"multiple_matching_appMetadata\";\nconst requestCannotBeMade = \"request_cannot_be_made\";\nconst cannotRemoveEmptyScope = \"cannot_remove_empty_scope\";\nconst cannotAppendScopeSet = \"cannot_append_scopeset\";\nconst emptyInputScopeSet = \"empty_input_scopeset\";\nconst deviceCodePollingCancelled = \"device_code_polling_cancelled\";\nconst deviceCodeExpired = \"device_code_expired\";\nconst deviceCodeUnknownError = \"device_code_unknown_error\";\nconst noAccountInSilentRequest = \"no_account_in_silent_request\";\nconst invalidCacheRecord = \"invalid_cache_record\";\nconst invalidCacheEnvironment = \"invalid_cache_environment\";\nconst noAccountFound = \"no_account_found\";\nconst noCryptoObject = \"no_crypto_object\";\nconst unexpectedCredentialType = \"unexpected_credential_type\";\nconst invalidAssertion = \"invalid_assertion\";\nconst invalidClientCredential = \"invalid_client_credential\";\nconst tokenRefreshRequired = \"token_refresh_required\";\nconst userTimeoutReached = \"user_timeout_reached\";\nconst tokenClaimsCnfRequiredForSignedJwt = \"token_claims_cnf_required_for_signedjwt\";\nconst authorizationCodeMissingFromServerResponse = \"authorization_code_missing_from_server_response\";\nconst bindingKeyNotRemoved = \"binding_key_not_removed\";\nconst endSessionEndpointNotSupported = \"end_session_endpoint_not_supported\";\nconst keyIdMissing = \"key_id_missing\";\nconst noNetworkConnectivity = \"no_network_connectivity\";\nconst userCanceled = \"user_canceled\";\nconst missingTenantIdError = \"missing_tenant_id_error\";\nconst methodNotImplemented = \"method_not_implemented\";\nconst nestedAppAuthBridgeDisabled = \"nested_app_auth_bridge_disabled\";\n\nexport { authTimeNotFound, authorizationCodeMissingFromServerResponse, bindingKeyNotRemoved, cannotAppendScopeSet, cannotRemoveEmptyScope, clientInfoDecodingError, clientInfoEmptyError, deviceCodeExpired, deviceCodePollingCancelled, deviceCodeUnknownError, emptyInputScopeSet, endSessionEndpointNotSupported, endpointResolutionError, hashNotDeserialized, invalidAssertion, invalidCacheEnvironment, invalidCacheRecord, invalidClientCredential, invalidState, keyIdMissing, maxAgeTranspired, methodNotImplemented, missingTenantIdError, multipleMatchingAccounts, multipleMatchingAppMetadata, multipleMatchingTokens, nestedAppAuthBridgeDisabled, networkError, noAccountFound, noAccountInSilentRequest, noCryptoObject, noNetworkConnectivity, nonceMismatch, nullOrEmptyToken, openIdConfigError, requestCannotBeMade, stateMismatch, stateNotFound, tokenClaimsCnfRequiredForSignedJwt, tokenParsingError, tokenRefreshRequired, unexpectedCredentialType, userCanceled, userTimeoutReached };\n//# sourceMappingURL=ClientAuthErrorCodes.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { AuthError } from './AuthError.mjs';\nimport { clientInfoDecodingError, clientInfoEmptyError, tokenParsingError, nullOrEmptyToken, endpointResolutionError, networkError, openIdConfigError, hashNotDeserialized, invalidState, stateMismatch, stateNotFound, nonceMismatch, authTimeNotFound, maxAgeTranspired, multipleMatchingTokens, multipleMatchingAccounts, multipleMatchingAppMetadata, requestCannotBeMade, cannotRemoveEmptyScope, cannotAppendScopeSet, emptyInputScopeSet, deviceCodePollingCancelled, deviceCodeExpired, deviceCodeUnknownError, noAccountInSilentRequest, invalidCacheRecord, invalidCacheEnvironment, noAccountFound, noCryptoObject, unexpectedCredentialType, invalidAssertion, invalidClientCredential, tokenRefreshRequired, userTimeoutReached, tokenClaimsCnfRequiredForSignedJwt, authorizationCodeMissingFromServerResponse, bindingKeyNotRemoved, endSessionEndpointNotSupported, keyIdMissing, noNetworkConnectivity, userCanceled, missingTenantIdError, nestedAppAuthBridgeDisabled, methodNotImplemented } from './ClientAuthErrorCodes.mjs';\nimport * as ClientAuthErrorCodes from './ClientAuthErrorCodes.mjs';\nexport { ClientAuthErrorCodes };\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * ClientAuthErrorMessage class containing string constants used by error codes and messages.\n */\nconst ClientAuthErrorMessages = {\n [clientInfoDecodingError]: \"The client info could not be parsed/decoded correctly\",\n [clientInfoEmptyError]: \"The client info was empty\",\n [tokenParsingError]: \"Token cannot be parsed\",\n [nullOrEmptyToken]: \"The token is null or empty\",\n [endpointResolutionError]: \"Endpoints cannot be resolved\",\n [networkError]: \"Network request failed\",\n [openIdConfigError]: \"Could not retrieve endpoints. Check your authority and verify the .well-known/openid-configuration endpoint returns the required endpoints.\",\n [hashNotDeserialized]: \"The hash parameters could not be deserialized\",\n [invalidState]: \"State was not the expected format\",\n [stateMismatch]: \"State mismatch error\",\n [stateNotFound]: \"State not found\",\n [nonceMismatch]: \"Nonce mismatch error\",\n [authTimeNotFound]: \"Max Age was requested and the ID token is missing the auth_time variable.\" +\n \" auth_time is an optional claim and is not enabled by default - it must be enabled.\" +\n \" See https://aka.ms/msaljs/optional-claims for more information.\",\n [maxAgeTranspired]: \"Max Age is set to 0, or too much time has elapsed since the last end-user authentication.\",\n [multipleMatchingTokens]: \"The cache contains multiple tokens satisfying the requirements. \" +\n \"Call AcquireToken again providing more requirements such as authority or account.\",\n [multipleMatchingAccounts]: \"The cache contains multiple accounts satisfying the given parameters. Please pass more info to obtain the correct account\",\n [multipleMatchingAppMetadata]: \"The cache contains multiple appMetadata satisfying the given parameters. Please pass more info to obtain the correct appMetadata\",\n [requestCannotBeMade]: \"Token request cannot be made without authorization code or refresh token.\",\n [cannotRemoveEmptyScope]: \"Cannot remove null or empty scope from ScopeSet\",\n [cannotAppendScopeSet]: \"Cannot append ScopeSet\",\n [emptyInputScopeSet]: \"Empty input ScopeSet cannot be processed\",\n [deviceCodePollingCancelled]: \"Caller has cancelled token endpoint polling during device code flow by setting DeviceCodeRequest.cancel = true.\",\n [deviceCodeExpired]: \"Device code is expired.\",\n [deviceCodeUnknownError]: \"Device code stopped polling for unknown reasons.\",\n [noAccountInSilentRequest]: \"Please pass an account object, silent flow is not supported without account information\",\n [invalidCacheRecord]: \"Cache record object was null or undefined.\",\n [invalidCacheEnvironment]: \"Invalid environment when attempting to create cache entry\",\n [noAccountFound]: \"No account found in cache for given key.\",\n [noCryptoObject]: \"No crypto object detected.\",\n [unexpectedCredentialType]: \"Unexpected credential type.\",\n [invalidAssertion]: \"Client assertion must meet requirements described in https://tools.ietf.org/html/rfc7515\",\n [invalidClientCredential]: \"Client credential (secret, certificate, or assertion) must not be empty when creating a confidential client. An application should at most have one credential\",\n [tokenRefreshRequired]: \"Cannot return token from cache because it must be refreshed. This may be due to one of the following reasons: forceRefresh parameter is set to true, claims have been requested, there is no cached access token or it is expired.\",\n [userTimeoutReached]: \"User defined timeout for device code polling reached\",\n [tokenClaimsCnfRequiredForSignedJwt]: \"Cannot generate a POP jwt if the token_claims are not populated\",\n [authorizationCodeMissingFromServerResponse]: \"Server response does not contain an authorization code to proceed\",\n [bindingKeyNotRemoved]: \"Could not remove the credential's binding key from storage.\",\n [endSessionEndpointNotSupported]: \"The provided authority does not support logout\",\n [keyIdMissing]: \"A keyId value is missing from the requested bound token's cache record and is required to match the token to it's stored binding key.\",\n [noNetworkConnectivity]: \"No network connectivity. Check your internet connection.\",\n [userCanceled]: \"User cancelled the flow.\",\n [missingTenantIdError]: \"A tenant id - not common, organizations, or consumers - must be specified when using the client_credentials flow.\",\n [methodNotImplemented]: \"This method has not been implemented\",\n [nestedAppAuthBridgeDisabled]: \"The nested app auth bridge is disabled\",\n};\n/**\n * String constants used by error codes and messages.\n * @deprecated Use ClientAuthErrorCodes instead\n */\nconst ClientAuthErrorMessage = {\n clientInfoDecodingError: {\n code: clientInfoDecodingError,\n desc: ClientAuthErrorMessages[clientInfoDecodingError],\n },\n clientInfoEmptyError: {\n code: clientInfoEmptyError,\n desc: ClientAuthErrorMessages[clientInfoEmptyError],\n },\n tokenParsingError: {\n code: tokenParsingError,\n desc: ClientAuthErrorMessages[tokenParsingError],\n },\n nullOrEmptyToken: {\n code: nullOrEmptyToken,\n desc: ClientAuthErrorMessages[nullOrEmptyToken],\n },\n endpointResolutionError: {\n code: endpointResolutionError,\n desc: ClientAuthErrorMessages[endpointResolutionError],\n },\n networkError: {\n code: networkError,\n desc: ClientAuthErrorMessages[networkError],\n },\n unableToGetOpenidConfigError: {\n code: openIdConfigError,\n desc: ClientAuthErrorMessages[openIdConfigError],\n },\n hashNotDeserialized: {\n code: hashNotDeserialized,\n desc: ClientAuthErrorMessages[hashNotDeserialized],\n },\n invalidStateError: {\n code: invalidState,\n desc: ClientAuthErrorMessages[invalidState],\n },\n stateMismatchError: {\n code: stateMismatch,\n desc: ClientAuthErrorMessages[stateMismatch],\n },\n stateNotFoundError: {\n code: stateNotFound,\n desc: ClientAuthErrorMessages[stateNotFound],\n },\n nonceMismatchError: {\n code: nonceMismatch,\n desc: ClientAuthErrorMessages[nonceMismatch],\n },\n authTimeNotFoundError: {\n code: authTimeNotFound,\n desc: ClientAuthErrorMessages[authTimeNotFound],\n },\n maxAgeTranspired: {\n code: maxAgeTranspired,\n desc: ClientAuthErrorMessages[maxAgeTranspired],\n },\n multipleMatchingTokens: {\n code: multipleMatchingTokens,\n desc: ClientAuthErrorMessages[multipleMatchingTokens],\n },\n multipleMatchingAccounts: {\n code: multipleMatchingAccounts,\n desc: ClientAuthErrorMessages[multipleMatchingAccounts],\n },\n multipleMatchingAppMetadata: {\n code: multipleMatchingAppMetadata,\n desc: ClientAuthErrorMessages[multipleMatchingAppMetadata],\n },\n tokenRequestCannotBeMade: {\n code: requestCannotBeMade,\n desc: ClientAuthErrorMessages[requestCannotBeMade],\n },\n removeEmptyScopeError: {\n code: cannotRemoveEmptyScope,\n desc: ClientAuthErrorMessages[cannotRemoveEmptyScope],\n },\n appendScopeSetError: {\n code: cannotAppendScopeSet,\n desc: ClientAuthErrorMessages[cannotAppendScopeSet],\n },\n emptyInputScopeSetError: {\n code: emptyInputScopeSet,\n desc: ClientAuthErrorMessages[emptyInputScopeSet],\n },\n DeviceCodePollingCancelled: {\n code: deviceCodePollingCancelled,\n desc: ClientAuthErrorMessages[deviceCodePollingCancelled],\n },\n DeviceCodeExpired: {\n code: deviceCodeExpired,\n desc: ClientAuthErrorMessages[deviceCodeExpired],\n },\n DeviceCodeUnknownError: {\n code: deviceCodeUnknownError,\n desc: ClientAuthErrorMessages[deviceCodeUnknownError],\n },\n NoAccountInSilentRequest: {\n code: noAccountInSilentRequest,\n desc: ClientAuthErrorMessages[noAccountInSilentRequest],\n },\n invalidCacheRecord: {\n code: invalidCacheRecord,\n desc: ClientAuthErrorMessages[invalidCacheRecord],\n },\n invalidCacheEnvironment: {\n code: invalidCacheEnvironment,\n desc: ClientAuthErrorMessages[invalidCacheEnvironment],\n },\n noAccountFound: {\n code: noAccountFound,\n desc: ClientAuthErrorMessages[noAccountFound],\n },\n noCryptoObj: {\n code: noCryptoObject,\n desc: ClientAuthErrorMessages[noCryptoObject],\n },\n unexpectedCredentialType: {\n code: unexpectedCredentialType,\n desc: ClientAuthErrorMessages[unexpectedCredentialType],\n },\n invalidAssertion: {\n code: invalidAssertion,\n desc: ClientAuthErrorMessages[invalidAssertion],\n },\n invalidClientCredential: {\n code: invalidClientCredential,\n desc: ClientAuthErrorMessages[invalidClientCredential],\n },\n tokenRefreshRequired: {\n code: tokenRefreshRequired,\n desc: ClientAuthErrorMessages[tokenRefreshRequired],\n },\n userTimeoutReached: {\n code: userTimeoutReached,\n desc: ClientAuthErrorMessages[userTimeoutReached],\n },\n tokenClaimsRequired: {\n code: tokenClaimsCnfRequiredForSignedJwt,\n desc: ClientAuthErrorMessages[tokenClaimsCnfRequiredForSignedJwt],\n },\n noAuthorizationCodeFromServer: {\n code: authorizationCodeMissingFromServerResponse,\n desc: ClientAuthErrorMessages[authorizationCodeMissingFromServerResponse],\n },\n bindingKeyNotRemovedError: {\n code: bindingKeyNotRemoved,\n desc: ClientAuthErrorMessages[bindingKeyNotRemoved],\n },\n logoutNotSupported: {\n code: endSessionEndpointNotSupported,\n desc: ClientAuthErrorMessages[endSessionEndpointNotSupported],\n },\n keyIdMissing: {\n code: keyIdMissing,\n desc: ClientAuthErrorMessages[keyIdMissing],\n },\n noNetworkConnectivity: {\n code: noNetworkConnectivity,\n desc: ClientAuthErrorMessages[noNetworkConnectivity],\n },\n userCanceledError: {\n code: userCanceled,\n desc: ClientAuthErrorMessages[userCanceled],\n },\n missingTenantIdError: {\n code: missingTenantIdError,\n desc: ClientAuthErrorMessages[missingTenantIdError],\n },\n nestedAppAuthBridgeDisabled: {\n code: nestedAppAuthBridgeDisabled,\n desc: ClientAuthErrorMessages[nestedAppAuthBridgeDisabled],\n },\n};\n/**\n * Error thrown when there is an error in the client code running on the browser.\n */\nclass ClientAuthError extends AuthError {\n constructor(errorCode, additionalMessage) {\n super(errorCode, additionalMessage\n ? `${ClientAuthErrorMessages[errorCode]}: ${additionalMessage}`\n : ClientAuthErrorMessages[errorCode]);\n this.name = \"ClientAuthError\";\n Object.setPrototypeOf(this, ClientAuthError.prototype);\n }\n}\nfunction createClientAuthError(errorCode, additionalMessage) {\n return new ClientAuthError(errorCode, additionalMessage);\n}\n\nexport { ClientAuthError, ClientAuthErrorMessage, ClientAuthErrorMessages, createClientAuthError };\n//# sourceMappingURL=ClientAuthError.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { tokenParsingError, nullOrEmptyToken, maxAgeTranspired } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Extract token by decoding the rawToken\n *\n * @param encodedToken\n */\nfunction extractTokenClaims(encodedToken, base64Decode) {\n const jswPayload = getJWSPayload(encodedToken);\n // token will be decoded to get the username\n try {\n // base64Decode() should throw an error if there is an issue\n const base64Decoded = base64Decode(jswPayload);\n return JSON.parse(base64Decoded);\n }\n catch (err) {\n throw createClientAuthError(tokenParsingError);\n }\n}\n/**\n * decode a JWT\n *\n * @param authToken\n */\nfunction getJWSPayload(authToken) {\n if (!authToken) {\n throw createClientAuthError(nullOrEmptyToken);\n }\n const tokenPartsRegex = /^([^\\.\\s]*)\\.([^\\.\\s]+)\\.([^\\.\\s]*)$/;\n const matches = tokenPartsRegex.exec(authToken);\n if (!matches || matches.length < 4) {\n throw createClientAuthError(tokenParsingError);\n }\n /**\n * const crackedToken = {\n * header: matches[1],\n * JWSPayload: matches[2],\n * JWSSig: matches[3],\n * };\n */\n return matches[2];\n}\n/**\n * Determine if the token's max_age has transpired\n */\nfunction checkMaxAge(authTime, maxAge) {\n /*\n * per https://openid.net/specs/openid-connect-core-1_0.html#AuthRequest\n * To force an immediate re-authentication: If an app requires that a user re-authenticate prior to access,\n * provide a value of 0 for the max_age parameter and the AS will force a fresh login.\n */\n const fiveMinuteSkew = 300000; // five minutes in milliseconds\n if (maxAge === 0 || Date.now() - fiveMinuteSkew > authTime + maxAge) {\n throw createClientAuthError(maxAgeTranspired);\n }\n}\n\nexport { checkMaxAge, extractTokenClaims, getJWSPayload };\n//# sourceMappingURL=AuthToken.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Authority types supported by MSAL.\n */\nconst AuthorityType = {\n Default: 0,\n Adfs: 1,\n Dsts: 2,\n Ciam: 3,\n};\n\nexport { AuthorityType };\n//# sourceMappingURL=AuthorityType.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nfunction isOpenIdConfigResponse(response) {\n return (response.hasOwnProperty(\"authorization_endpoint\") &&\n response.hasOwnProperty(\"token_endpoint\") &&\n response.hasOwnProperty(\"issuer\") &&\n response.hasOwnProperty(\"jwks_uri\"));\n}\n\nexport { isOpenIdConfigResponse };\n//# sourceMappingURL=OpenIdConfigResponse.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst redirectUriEmpty = \"redirect_uri_empty\";\nconst claimsRequestParsingError = \"claims_request_parsing_error\";\nconst authorityUriInsecure = \"authority_uri_insecure\";\nconst urlParseError = \"url_parse_error\";\nconst urlEmptyError = \"empty_url_error\";\nconst emptyInputScopesError = \"empty_input_scopes_error\";\nconst invalidPromptValue = \"invalid_prompt_value\";\nconst invalidClaims = \"invalid_claims\";\nconst tokenRequestEmpty = \"token_request_empty\";\nconst logoutRequestEmpty = \"logout_request_empty\";\nconst invalidCodeChallengeMethod = \"invalid_code_challenge_method\";\nconst pkceParamsMissing = \"pkce_params_missing\";\nconst invalidCloudDiscoveryMetadata = \"invalid_cloud_discovery_metadata\";\nconst invalidAuthorityMetadata = \"invalid_authority_metadata\";\nconst untrustedAuthority = \"untrusted_authority\";\nconst missingSshJwk = \"missing_ssh_jwk\";\nconst missingSshKid = \"missing_ssh_kid\";\nconst missingNonceAuthenticationHeader = \"missing_nonce_authentication_header\";\nconst invalidAuthenticationHeader = \"invalid_authentication_header\";\nconst cannotSetOIDCOptions = \"cannot_set_OIDCOptions\";\nconst cannotAllowNativeBroker = \"cannot_allow_native_broker\";\nconst authorityMismatch = \"authority_mismatch\";\n\nexport { authorityMismatch, authorityUriInsecure, cannotAllowNativeBroker, cannotSetOIDCOptions, claimsRequestParsingError, emptyInputScopesError, invalidAuthenticationHeader, invalidAuthorityMetadata, invalidClaims, invalidCloudDiscoveryMetadata, invalidCodeChallengeMethod, invalidPromptValue, logoutRequestEmpty, missingNonceAuthenticationHeader, missingSshJwk, missingSshKid, pkceParamsMissing, redirectUriEmpty, tokenRequestEmpty, untrustedAuthority, urlEmptyError, urlParseError };\n//# sourceMappingURL=ClientConfigurationErrorCodes.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { AuthError } from './AuthError.mjs';\nimport { redirectUriEmpty, claimsRequestParsingError, authorityUriInsecure, urlParseError, urlEmptyError, emptyInputScopesError, invalidPromptValue, invalidClaims, tokenRequestEmpty, logoutRequestEmpty, invalidCodeChallengeMethod, pkceParamsMissing, invalidCloudDiscoveryMetadata, invalidAuthorityMetadata, untrustedAuthority, missingSshJwk, missingSshKid, missingNonceAuthenticationHeader, invalidAuthenticationHeader, cannotSetOIDCOptions, cannotAllowNativeBroker, authorityMismatch } from './ClientConfigurationErrorCodes.mjs';\nimport * as ClientConfigurationErrorCodes from './ClientConfigurationErrorCodes.mjs';\nexport { ClientConfigurationErrorCodes };\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst ClientConfigurationErrorMessages = {\n [redirectUriEmpty]: \"A redirect URI is required for all calls, and none has been set.\",\n [claimsRequestParsingError]: \"Could not parse the given claims request object.\",\n [authorityUriInsecure]: \"Authority URIs must use https. Please see here for valid authority configuration options: https://docs.microsoft.com/en-us/azure/active-directory/develop/msal-js-initializing-client-applications#configuration-options\",\n [urlParseError]: \"URL could not be parsed into appropriate segments.\",\n [urlEmptyError]: \"URL was empty or null.\",\n [emptyInputScopesError]: \"Scopes cannot be passed as null, undefined or empty array because they are required to obtain an access token.\",\n [invalidPromptValue]: \"Please see here for valid configuration options: https://azuread.github.io/microsoft-authentication-library-for-js/ref/modules/_azure_msal_common.html#commonauthorizationurlrequest\",\n [invalidClaims]: \"Given claims parameter must be a stringified JSON object.\",\n [tokenRequestEmpty]: \"Token request was empty and not found in cache.\",\n [logoutRequestEmpty]: \"The logout request was null or undefined.\",\n [invalidCodeChallengeMethod]: 'code_challenge_method passed is invalid. Valid values are \"plain\" and \"S256\".',\n [pkceParamsMissing]: \"Both params: code_challenge and code_challenge_method are to be passed if to be sent in the request\",\n [invalidCloudDiscoveryMetadata]: \"Invalid cloudDiscoveryMetadata provided. Must be a stringified JSON object containing tenant_discovery_endpoint and metadata fields\",\n [invalidAuthorityMetadata]: \"Invalid authorityMetadata provided. Must by a stringified JSON object containing authorization_endpoint, token_endpoint, issuer fields.\",\n [untrustedAuthority]: \"The provided authority is not a trusted authority. Please include this authority in the knownAuthorities config parameter.\",\n [missingSshJwk]: \"Missing sshJwk in SSH certificate request. A stringified JSON Web Key is required when using the SSH authentication scheme.\",\n [missingSshKid]: \"Missing sshKid in SSH certificate request. A string that uniquely identifies the public SSH key is required when using the SSH authentication scheme.\",\n [missingNonceAuthenticationHeader]: \"Unable to find an authentication header containing server nonce. Either the Authentication-Info or WWW-Authenticate headers must be present in order to obtain a server nonce.\",\n [invalidAuthenticationHeader]: \"Invalid authentication header provided\",\n [cannotSetOIDCOptions]: \"Cannot set OIDCOptions parameter. Please change the protocol mode to OIDC or use a non-Microsoft authority.\",\n [cannotAllowNativeBroker]: \"Cannot set allowNativeBroker parameter to true when not in AAD protocol mode.\",\n [authorityMismatch]: \"Authority mismatch error. Authority provided in login request or PublicClientApplication config does not match the environment of the provided account. Please use a matching account or make an interactive request to login to this authority.\",\n};\n/**\n * ClientConfigurationErrorMessage class containing string constants used by error codes and messages.\n * @deprecated Use ClientConfigurationErrorCodes instead\n */\nconst ClientConfigurationErrorMessage = {\n redirectUriNotSet: {\n code: redirectUriEmpty,\n desc: ClientConfigurationErrorMessages[redirectUriEmpty],\n },\n claimsRequestParsingError: {\n code: claimsRequestParsingError,\n desc: ClientConfigurationErrorMessages[claimsRequestParsingError],\n },\n authorityUriInsecure: {\n code: authorityUriInsecure,\n desc: ClientConfigurationErrorMessages[authorityUriInsecure],\n },\n urlParseError: {\n code: urlParseError,\n desc: ClientConfigurationErrorMessages[urlParseError],\n },\n urlEmptyError: {\n code: urlEmptyError,\n desc: ClientConfigurationErrorMessages[urlEmptyError],\n },\n emptyScopesError: {\n code: emptyInputScopesError,\n desc: ClientConfigurationErrorMessages[emptyInputScopesError],\n },\n invalidPrompt: {\n code: invalidPromptValue,\n desc: ClientConfigurationErrorMessages[invalidPromptValue],\n },\n invalidClaimsRequest: {\n code: invalidClaims,\n desc: ClientConfigurationErrorMessages[invalidClaims],\n },\n tokenRequestEmptyError: {\n code: tokenRequestEmpty,\n desc: ClientConfigurationErrorMessages[tokenRequestEmpty],\n },\n logoutRequestEmptyError: {\n code: logoutRequestEmpty,\n desc: ClientConfigurationErrorMessages[logoutRequestEmpty],\n },\n invalidCodeChallengeMethod: {\n code: invalidCodeChallengeMethod,\n desc: ClientConfigurationErrorMessages[invalidCodeChallengeMethod],\n },\n invalidCodeChallengeParams: {\n code: pkceParamsMissing,\n desc: ClientConfigurationErrorMessages[pkceParamsMissing],\n },\n invalidCloudDiscoveryMetadata: {\n code: invalidCloudDiscoveryMetadata,\n desc: ClientConfigurationErrorMessages[invalidCloudDiscoveryMetadata],\n },\n invalidAuthorityMetadata: {\n code: invalidAuthorityMetadata,\n desc: ClientConfigurationErrorMessages[invalidAuthorityMetadata],\n },\n untrustedAuthority: {\n code: untrustedAuthority,\n desc: ClientConfigurationErrorMessages[untrustedAuthority],\n },\n missingSshJwk: {\n code: missingSshJwk,\n desc: ClientConfigurationErrorMessages[missingSshJwk],\n },\n missingSshKid: {\n code: missingSshKid,\n desc: ClientConfigurationErrorMessages[missingSshKid],\n },\n missingNonceAuthenticationHeader: {\n code: missingNonceAuthenticationHeader,\n desc: ClientConfigurationErrorMessages[missingNonceAuthenticationHeader],\n },\n invalidAuthenticationHeader: {\n code: invalidAuthenticationHeader,\n desc: ClientConfigurationErrorMessages[invalidAuthenticationHeader],\n },\n cannotSetOIDCOptions: {\n code: cannotSetOIDCOptions,\n desc: ClientConfigurationErrorMessages[cannotSetOIDCOptions],\n },\n cannotAllowNativeBroker: {\n code: cannotAllowNativeBroker,\n desc: ClientConfigurationErrorMessages[cannotAllowNativeBroker],\n },\n authorityMismatch: {\n code: authorityMismatch,\n desc: ClientConfigurationErrorMessages[authorityMismatch],\n },\n};\n/**\n * Error thrown when there is an error in configuration of the MSAL.js library.\n */\nclass ClientConfigurationError extends AuthError {\n constructor(errorCode) {\n super(errorCode, ClientConfigurationErrorMessages[errorCode]);\n this.name = \"ClientConfigurationError\";\n Object.setPrototypeOf(this, ClientConfigurationError.prototype);\n }\n}\nfunction createClientConfigurationError(errorCode) {\n return new ClientConfigurationError(errorCode);\n}\n\nexport { ClientConfigurationError, ClientConfigurationErrorMessage, ClientConfigurationErrorMessages, createClientConfigurationError };\n//# sourceMappingURL=ClientConfigurationError.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * @hidden\n */\nclass StringUtils {\n /**\n * Check if stringified object is empty\n * @param strObj\n */\n static isEmptyObj(strObj) {\n if (strObj) {\n try {\n const obj = JSON.parse(strObj);\n return Object.keys(obj).length === 0;\n }\n catch (e) { }\n }\n return true;\n }\n static startsWith(str, search) {\n return str.indexOf(search) === 0;\n }\n static endsWith(str, search) {\n return (str.length >= search.length &&\n str.lastIndexOf(search) === str.length - search.length);\n }\n /**\n * Parses string into an object.\n *\n * @param query\n */\n static queryStringToObject(query) {\n const obj = {};\n const params = query.split(\"&\");\n const decode = (s) => decodeURIComponent(s.replace(/\\+/g, \" \"));\n params.forEach((pair) => {\n if (pair.trim()) {\n const [key, value] = pair.split(/=(.+)/g, 2); // Split on the first occurence of the '=' character\n if (key && value) {\n obj[decode(key)] = decode(value);\n }\n }\n });\n return obj;\n }\n /**\n * Trims entries in an array.\n *\n * @param arr\n */\n static trimArrayEntries(arr) {\n return arr.map((entry) => entry.trim());\n }\n /**\n * Removes empty strings from array\n * @param arr\n */\n static removeEmptyStringsFromArray(arr) {\n return arr.filter((entry) => {\n return !!entry;\n });\n }\n /**\n * Attempts to parse a string into JSON\n * @param str\n */\n static jsonParseHelper(str) {\n try {\n return JSON.parse(str);\n }\n catch (e) {\n return null;\n }\n }\n /**\n * Tests if a given string matches a given pattern, with support for wildcards and queries.\n * @param pattern Wildcard pattern to string match. Supports \"*\" for wildcards and \"?\" for queries\n * @param input String to match against\n */\n static matchPattern(pattern, input) {\n /**\n * Wildcard support: https://stackoverflow.com/a/3117248/4888559\n * Queries: replaces \"?\" in string with escaped \"\\?\" for regex test\n */\n // eslint-disable-next-line security/detect-non-literal-regexp\n const regex = new RegExp(pattern\n .replace(/\\\\/g, \"\\\\\\\\\")\n .replace(/\\*/g, \"[^ ]*\")\n .replace(/\\?/g, \"\\\\?\"));\n return regex.test(input);\n }\n}\n\nexport { StringUtils };\n//# sourceMappingURL=StringUtils.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { hashNotDeserialized } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Parses hash string from given string. Returns empty string if no hash symbol is found.\n * @param hashString\n */\nfunction stripLeadingHashOrQuery(responseString) {\n if (responseString.startsWith(\"#/\")) {\n return responseString.substring(2);\n }\n else if (responseString.startsWith(\"#\") ||\n responseString.startsWith(\"?\")) {\n return responseString.substring(1);\n }\n return responseString;\n}\n/**\n * Returns URL hash as server auth code response object.\n */\nfunction getDeserializedResponse(responseString) {\n // Check if given hash is empty\n if (!responseString || responseString.indexOf(\"=\") < 0) {\n return null;\n }\n try {\n // Strip the # or ? symbol if present\n const normalizedResponse = stripLeadingHashOrQuery(responseString);\n // If # symbol was not present, above will return empty string, so give original hash value\n const deserializedHash = Object.fromEntries(new URLSearchParams(normalizedResponse));\n // Check for known response properties\n if (deserializedHash.code ||\n deserializedHash.error ||\n deserializedHash.error_description ||\n deserializedHash.state) {\n return deserializedHash;\n }\n }\n catch (e) {\n throw createClientAuthError(hashNotDeserialized);\n }\n return null;\n}\n\nexport { getDeserializedResponse, stripLeadingHashOrQuery };\n//# sourceMappingURL=UrlUtils.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientConfigurationError } from '../error/ClientConfigurationError.mjs';\nimport { StringUtils } from '../utils/StringUtils.mjs';\nimport { AADAuthorityConstants, Constants } from '../utils/Constants.mjs';\nimport { getDeserializedResponse } from '../utils/UrlUtils.mjs';\nimport { urlEmptyError, urlParseError, authorityUriInsecure } from '../error/ClientConfigurationErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Url object class which can perform various transformations on url strings.\n */\nclass UrlString {\n get urlString() {\n return this._urlString;\n }\n constructor(url) {\n this._urlString = url;\n if (!this._urlString) {\n // Throws error if url is empty\n throw createClientConfigurationError(urlEmptyError);\n }\n if (!url.includes(\"#\")) {\n this._urlString = UrlString.canonicalizeUri(url);\n }\n }\n /**\n * Ensure urls are lower case and end with a / character.\n * @param url\n */\n static canonicalizeUri(url) {\n if (url) {\n let lowerCaseUrl = url.toLowerCase();\n if (StringUtils.endsWith(lowerCaseUrl, \"?\")) {\n lowerCaseUrl = lowerCaseUrl.slice(0, -1);\n }\n else if (StringUtils.endsWith(lowerCaseUrl, \"?/\")) {\n lowerCaseUrl = lowerCaseUrl.slice(0, -2);\n }\n if (!StringUtils.endsWith(lowerCaseUrl, \"/\")) {\n lowerCaseUrl += \"/\";\n }\n return lowerCaseUrl;\n }\n return url;\n }\n /**\n * Throws if urlString passed is not a valid authority URI string.\n */\n validateAsUri() {\n // Attempts to parse url for uri components\n let components;\n try {\n components = this.getUrlComponents();\n }\n catch (e) {\n throw createClientConfigurationError(urlParseError);\n }\n // Throw error if URI or path segments are not parseable.\n if (!components.HostNameAndPort || !components.PathSegments) {\n throw createClientConfigurationError(urlParseError);\n }\n // Throw error if uri is insecure.\n if (!components.Protocol ||\n components.Protocol.toLowerCase() !== \"https:\") {\n throw createClientConfigurationError(authorityUriInsecure);\n }\n }\n /**\n * Given a url and a query string return the url with provided query string appended\n * @param url\n * @param queryString\n */\n static appendQueryString(url, queryString) {\n if (!queryString) {\n return url;\n }\n return url.indexOf(\"?\") < 0\n ? `${url}?${queryString}`\n : `${url}&${queryString}`;\n }\n /**\n * Returns a url with the hash removed\n * @param url\n */\n static removeHashFromUrl(url) {\n return UrlString.canonicalizeUri(url.split(\"#\")[0]);\n }\n /**\n * Given a url like https://a:b/common/d?e=f#g, and a tenantId, returns https://a:b/tenantId/d\n * @param href The url\n * @param tenantId The tenant id to replace\n */\n replaceTenantPath(tenantId) {\n const urlObject = this.getUrlComponents();\n const pathArray = urlObject.PathSegments;\n if (tenantId &&\n pathArray.length !== 0 &&\n (pathArray[0] === AADAuthorityConstants.COMMON ||\n pathArray[0] === AADAuthorityConstants.ORGANIZATIONS)) {\n pathArray[0] = tenantId;\n }\n return UrlString.constructAuthorityUriFromObject(urlObject);\n }\n /**\n * Parses out the components from a url string.\n * @returns An object with the various components. Please cache this value insted of calling this multiple times on the same url.\n */\n getUrlComponents() {\n // https://gist.github.com/curtisz/11139b2cfcaef4a261e0\n const regEx = RegExp(\"^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\\\\?([^#]*))?(#(.*))?\");\n // If url string does not match regEx, we throw an error\n const match = this.urlString.match(regEx);\n if (!match) {\n throw createClientConfigurationError(urlParseError);\n }\n // Url component object\n const urlComponents = {\n Protocol: match[1],\n HostNameAndPort: match[4],\n AbsolutePath: match[5],\n QueryString: match[7],\n };\n let pathSegments = urlComponents.AbsolutePath.split(\"/\");\n pathSegments = pathSegments.filter((val) => val && val.length > 0); // remove empty elements\n urlComponents.PathSegments = pathSegments;\n if (urlComponents.QueryString &&\n urlComponents.QueryString.endsWith(\"/\")) {\n urlComponents.QueryString = urlComponents.QueryString.substring(0, urlComponents.QueryString.length - 1);\n }\n return urlComponents;\n }\n static getDomainFromUrl(url) {\n const regEx = RegExp(\"^([^:/?#]+://)?([^/?#]*)\");\n const match = url.match(regEx);\n if (!match) {\n throw createClientConfigurationError(urlParseError);\n }\n return match[2];\n }\n static getAbsoluteUrl(relativeUrl, baseUrl) {\n if (relativeUrl[0] === Constants.FORWARD_SLASH) {\n const url = new UrlString(baseUrl);\n const baseComponents = url.getUrlComponents();\n return (baseComponents.Protocol +\n \"//\" +\n baseComponents.HostNameAndPort +\n relativeUrl);\n }\n return relativeUrl;\n }\n static constructAuthorityUriFromObject(urlObject) {\n return new UrlString(urlObject.Protocol +\n \"//\" +\n urlObject.HostNameAndPort +\n \"/\" +\n urlObject.PathSegments.join(\"/\"));\n }\n /**\n * Check if the hash of the URL string contains known properties\n * @deprecated This API will be removed in a future version\n */\n static hashContainsKnownProperties(response) {\n return !!getDeserializedResponse(response);\n }\n}\n\nexport { UrlString };\n//# sourceMappingURL=UrlString.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { UrlString } from '../url/UrlString.mjs';\nimport { AuthorityMetadataSource } from '../utils/Constants.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst rawMetdataJSON = {\n endpointMetadata: {\n \"login.microsoftonline.com\": {\n token_endpoint: \"https://login.microsoftonline.com/{tenantid}/oauth2/v2.0/token\",\n jwks_uri: \"https://login.microsoftonline.com/{tenantid}/discovery/v2.0/keys\",\n issuer: \"https://login.microsoftonline.com/{tenantid}/v2.0\",\n authorization_endpoint: \"https://login.microsoftonline.com/{tenantid}/oauth2/v2.0/authorize\",\n end_session_endpoint: \"https://login.microsoftonline.com/{tenantid}/oauth2/v2.0/logout\",\n },\n \"login.chinacloudapi.cn\": {\n token_endpoint: \"https://login.chinacloudapi.cn/{tenantid}/oauth2/v2.0/token\",\n jwks_uri: \"https://login.chinacloudapi.cn/{tenantid}/discovery/v2.0/keys\",\n issuer: \"https://login.partner.microsoftonline.cn/{tenantid}/v2.0\",\n authorization_endpoint: \"https://login.chinacloudapi.cn/{tenantid}/oauth2/v2.0/authorize\",\n end_session_endpoint: \"https://login.chinacloudapi.cn/{tenantid}/oauth2/v2.0/logout\",\n },\n \"login.microsoftonline.us\": {\n token_endpoint: \"https://login.microsoftonline.us/{tenantid}/oauth2/v2.0/token\",\n jwks_uri: \"https://login.microsoftonline.us/{tenantid}/discovery/v2.0/keys\",\n issuer: \"https://login.microsoftonline.us/{tenantid}/v2.0\",\n authorization_endpoint: \"https://login.microsoftonline.us/{tenantid}/oauth2/v2.0/authorize\",\n end_session_endpoint: \"https://login.microsoftonline.us/{tenantid}/oauth2/v2.0/logout\",\n },\n },\n instanceDiscoveryMetadata: {\n tenant_discovery_endpoint: \"https://{canonicalAuthority}/v2.0/.well-known/openid-configuration\",\n metadata: [\n {\n preferred_network: \"login.microsoftonline.com\",\n preferred_cache: \"login.windows.net\",\n aliases: [\n \"login.microsoftonline.com\",\n \"login.windows.net\",\n \"login.microsoft.com\",\n \"sts.windows.net\",\n ],\n },\n {\n preferred_network: \"login.partner.microsoftonline.cn\",\n preferred_cache: \"login.partner.microsoftonline.cn\",\n aliases: [\n \"login.partner.microsoftonline.cn\",\n \"login.chinacloudapi.cn\",\n ],\n },\n {\n preferred_network: \"login.microsoftonline.de\",\n preferred_cache: \"login.microsoftonline.de\",\n aliases: [\"login.microsoftonline.de\"],\n },\n {\n preferred_network: \"login.microsoftonline.us\",\n preferred_cache: \"login.microsoftonline.us\",\n aliases: [\n \"login.microsoftonline.us\",\n \"login.usgovcloudapi.net\",\n ],\n },\n {\n preferred_network: \"login-us.microsoftonline.com\",\n preferred_cache: \"login-us.microsoftonline.com\",\n aliases: [\"login-us.microsoftonline.com\"],\n },\n ],\n },\n};\nconst EndpointMetadata = rawMetdataJSON.endpointMetadata;\nconst InstanceDiscoveryMetadata = rawMetdataJSON.instanceDiscoveryMetadata;\nconst InstanceDiscoveryMetadataAliases = new Set();\nInstanceDiscoveryMetadata.metadata.forEach((metadataEntry) => {\n metadataEntry.aliases.forEach((alias) => {\n InstanceDiscoveryMetadataAliases.add(alias);\n });\n});\n/**\n * Attempts to get an aliases array from the static authority metadata sources based on the canonical authority host\n * @param staticAuthorityOptions\n * @param logger\n * @returns\n */\nfunction getAliasesFromStaticSources(staticAuthorityOptions, logger) {\n let staticAliases;\n const canonicalAuthority = staticAuthorityOptions.canonicalAuthority;\n if (canonicalAuthority) {\n const authorityHost = new UrlString(canonicalAuthority).getUrlComponents().HostNameAndPort;\n staticAliases =\n getAliasesFromMetadata(authorityHost, staticAuthorityOptions.cloudDiscoveryMetadata?.metadata, AuthorityMetadataSource.CONFIG, logger) ||\n getAliasesFromMetadata(authorityHost, InstanceDiscoveryMetadata.metadata, AuthorityMetadataSource.HARDCODED_VALUES, logger) ||\n staticAuthorityOptions.knownAuthorities;\n }\n return staticAliases || [];\n}\n/**\n * Returns aliases for from the raw cloud discovery metadata passed in\n * @param authorityHost\n * @param rawCloudDiscoveryMetadata\n * @returns\n */\nfunction getAliasesFromMetadata(authorityHost, cloudDiscoveryMetadata, source, logger) {\n logger?.trace(`getAliasesFromMetadata called with source: ${source}`);\n if (authorityHost && cloudDiscoveryMetadata) {\n const metadata = getCloudDiscoveryMetadataFromNetworkResponse(cloudDiscoveryMetadata, authorityHost);\n if (metadata) {\n logger?.trace(`getAliasesFromMetadata: found cloud discovery metadata in ${source}, returning aliases`);\n return metadata.aliases;\n }\n else {\n logger?.trace(`getAliasesFromMetadata: did not find cloud discovery metadata in ${source}`);\n }\n }\n return null;\n}\n/**\n * Get cloud discovery metadata for common authorities\n */\nfunction getCloudDiscoveryMetadataFromHardcodedValues(authorityHost) {\n const metadata = getCloudDiscoveryMetadataFromNetworkResponse(InstanceDiscoveryMetadata.metadata, authorityHost);\n return metadata;\n}\n/**\n * Searches instance discovery network response for the entry that contains the host in the aliases list\n * @param response\n * @param authority\n */\nfunction getCloudDiscoveryMetadataFromNetworkResponse(response, authorityHost) {\n for (let i = 0; i < response.length; i++) {\n const metadata = response[i];\n if (metadata.aliases.includes(authorityHost)) {\n return metadata;\n }\n }\n return null;\n}\n\nexport { EndpointMetadata, InstanceDiscoveryMetadata, InstanceDiscoveryMetadataAliases, getAliasesFromMetadata, getAliasesFromStaticSources, getCloudDiscoveryMetadataFromHardcodedValues, getCloudDiscoveryMetadataFromNetworkResponse, rawMetdataJSON };\n//# sourceMappingURL=AuthorityMetadata.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Protocol modes supported by MSAL.\n */\nconst ProtocolMode = {\n AAD: \"AAD\",\n OIDC: \"OIDC\",\n};\n\nexport { ProtocolMode };\n//# sourceMappingURL=ProtocolMode.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst AzureCloudInstance = {\n // AzureCloudInstance is not specified.\n None: \"none\",\n // Microsoft Azure public cloud\n AzurePublic: \"https://login.microsoftonline.com\",\n // Microsoft PPE\n AzurePpe: \"https://login.windows-ppe.net\",\n // Microsoft Chinese national/regional cloud\n AzureChina: \"https://login.chinacloudapi.cn\",\n // Microsoft German national/regional cloud (\"Black Forest\")\n AzureGermany: \"https://login.microsoftonline.de\",\n // US Government cloud\n AzureUsGovernment: \"https://login.microsoftonline.us\",\n};\n\nexport { AzureCloudInstance };\n//# sourceMappingURL=AuthorityOptions.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nfunction isCloudInstanceDiscoveryResponse(response) {\n return (response.hasOwnProperty(\"tenant_discovery_endpoint\") &&\n response.hasOwnProperty(\"metadata\"));\n}\n\nexport { isCloudInstanceDiscoveryResponse };\n//# sourceMappingURL=CloudInstanceDiscoveryResponse.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nfunction isCloudInstanceDiscoveryErrorResponse(response) {\n return (response.hasOwnProperty(\"error\") &&\n response.hasOwnProperty(\"error_description\"));\n}\n\nexport { isCloudInstanceDiscoveryErrorResponse };\n//# sourceMappingURL=CloudInstanceDiscoveryErrorResponse.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Enumeration of operations that are instrumented by have their performance measured by the PerformanceClient.\n *\n * @export\n * @enum {number}\n */\nconst PerformanceEvents = {\n /**\n * acquireTokenByCode API (msal-browser and msal-node).\n * Used to acquire tokens by trading an authorization code against the token endpoint.\n */\n AcquireTokenByCode: \"acquireTokenByCode\",\n /**\n * acquireTokenByRefreshToken API (msal-browser and msal-node).\n * Used to renew an access token using a refresh token against the token endpoint.\n */\n AcquireTokenByRefreshToken: \"acquireTokenByRefreshToken\",\n /**\n * acquireTokenSilent API (msal-browser and msal-node).\n * Used to silently acquire a new access token (from the cache or the network).\n */\n AcquireTokenSilent: \"acquireTokenSilent\",\n /**\n * acquireTokenSilentAsync (msal-browser).\n * Internal API for acquireTokenSilent.\n */\n AcquireTokenSilentAsync: \"acquireTokenSilentAsync\",\n /**\n * acquireTokenPopup (msal-browser).\n * Used to acquire a new access token interactively through pop ups\n */\n AcquireTokenPopup: \"acquireTokenPopup\",\n /**\n * acquireTokenPreRedirect (msal-browser).\n * First part of the redirect flow.\n * Used to acquire a new access token interactively through redirects.\n */\n AcquireTokenPreRedirect: \"acquireTokenPreRedirect\",\n /**\n * acquireTokenRedirect (msal-browser).\n * Second part of the redirect flow.\n * Used to acquire a new access token interactively through redirects.\n */\n AcquireTokenRedirect: \"acquireTokenRedirect\",\n /**\n * getPublicKeyThumbprint API in CryptoOpts class (msal-browser).\n * Used to generate a public/private keypair and generate a public key thumbprint for pop requests.\n */\n CryptoOptsGetPublicKeyThumbprint: \"cryptoOptsGetPublicKeyThumbprint\",\n /**\n * signJwt API in CryptoOpts class (msal-browser).\n * Used to signed a pop token.\n */\n CryptoOptsSignJwt: \"cryptoOptsSignJwt\",\n /**\n * acquireToken API in the SilentCacheClient class (msal-browser).\n * Used to read access tokens from the cache.\n */\n SilentCacheClientAcquireToken: \"silentCacheClientAcquireToken\",\n /**\n * acquireToken API in the SilentIframeClient class (msal-browser).\n * Used to acquire a new set of tokens from the authorize endpoint in a hidden iframe.\n */\n SilentIframeClientAcquireToken: \"silentIframeClientAcquireToken\",\n AwaitConcurrentIframe: \"awaitConcurrentIframe\",\n /**\n * acquireToken API in SilentRereshClient (msal-browser).\n * Used to acquire a new set of tokens from the token endpoint using a refresh token.\n */\n SilentRefreshClientAcquireToken: \"silentRefreshClientAcquireToken\",\n /**\n * ssoSilent API (msal-browser).\n * Used to silently acquire an authorization code and set of tokens using a hidden iframe.\n */\n SsoSilent: \"ssoSilent\",\n /**\n * getDiscoveredAuthority API in StandardInteractionClient class (msal-browser).\n * Used to load authority metadata for a request.\n */\n StandardInteractionClientGetDiscoveredAuthority: \"standardInteractionClientGetDiscoveredAuthority\",\n /**\n * acquireToken APIs in msal-browser.\n * Used to make an /authorize endpoint call with native brokering enabled.\n */\n FetchAccountIdWithNativeBroker: \"fetchAccountIdWithNativeBroker\",\n /**\n * acquireToken API in NativeInteractionClient class (msal-browser).\n * Used to acquire a token from Native component when native brokering is enabled.\n */\n NativeInteractionClientAcquireToken: \"nativeInteractionClientAcquireToken\",\n /**\n * Time spent creating default headers for requests to token endpoint\n */\n BaseClientCreateTokenRequestHeaders: \"baseClientCreateTokenRequestHeaders\",\n /**\n * Time spent sending/waiting for the response of a request to the token endpoint\n */\n RefreshTokenClientExecutePostToTokenEndpoint: \"refreshTokenClientExecutePostToTokenEndpoint\",\n AuthorizationCodeClientExecutePostToTokenEndpoint: \"authorizationCodeClientExecutePostToTokenEndpoint\",\n /**\n * Used to measure the time taken for completing embedded-broker handshake (PW-Broker).\n */\n BrokerHandhshake: \"brokerHandshake\",\n /**\n * acquireTokenByRefreshToken API in BrokerClientApplication (PW-Broker) .\n */\n AcquireTokenByRefreshTokenInBroker: \"acquireTokenByRefreshTokenInBroker\",\n /**\n * Time taken for token acquisition by broker\n */\n AcquireTokenByBroker: \"acquireTokenByBroker\",\n /**\n * Time spent on the network for refresh token acquisition\n */\n RefreshTokenClientExecuteTokenRequest: \"refreshTokenClientExecuteTokenRequest\",\n /**\n * Time taken for acquiring refresh token , records RT size\n */\n RefreshTokenClientAcquireToken: \"refreshTokenClientAcquireToken\",\n /**\n * Time taken for acquiring cached refresh token\n */\n RefreshTokenClientAcquireTokenWithCachedRefreshToken: \"refreshTokenClientAcquireTokenWithCachedRefreshToken\",\n /**\n * acquireTokenByRefreshToken API in RefreshTokenClient (msal-common).\n */\n RefreshTokenClientAcquireTokenByRefreshToken: \"refreshTokenClientAcquireTokenByRefreshToken\",\n /**\n * Helper function to create token request body in RefreshTokenClient (msal-common).\n */\n RefreshTokenClientCreateTokenRequestBody: \"refreshTokenClientCreateTokenRequestBody\",\n /**\n * acquireTokenFromCache (msal-browser).\n * Internal API for acquiring token from cache\n */\n AcquireTokenFromCache: \"acquireTokenFromCache\",\n SilentFlowClientAcquireCachedToken: \"silentFlowClientAcquireCachedToken\",\n SilentFlowClientGenerateResultFromCacheRecord: \"silentFlowClientGenerateResultFromCacheRecord\",\n /**\n * acquireTokenBySilentIframe (msal-browser).\n * Internal API for acquiring token by silent Iframe\n */\n AcquireTokenBySilentIframe: \"acquireTokenBySilentIframe\",\n /**\n * Internal API for initializing base request in BaseInteractionClient (msal-browser)\n */\n InitializeBaseRequest: \"initializeBaseRequest\",\n /**\n * Internal API for initializing silent request in SilentCacheClient (msal-browser)\n */\n InitializeSilentRequest: \"initializeSilentRequest\",\n InitializeClientApplication: \"initializeClientApplication\",\n /**\n * Helper function in SilentIframeClient class (msal-browser).\n */\n SilentIframeClientTokenHelper: \"silentIframeClientTokenHelper\",\n /**\n * SilentHandler\n */\n SilentHandlerInitiateAuthRequest: \"silentHandlerInitiateAuthRequest\",\n SilentHandlerMonitorIframeForHash: \"silentHandlerMonitorIframeForHash\",\n SilentHandlerLoadFrame: \"silentHandlerLoadFrame\",\n SilentHandlerLoadFrameSync: \"silentHandlerLoadFrameSync\",\n /**\n * Helper functions in StandardInteractionClient class (msal-browser)\n */\n StandardInteractionClientCreateAuthCodeClient: \"standardInteractionClientCreateAuthCodeClient\",\n StandardInteractionClientGetClientConfiguration: \"standardInteractionClientGetClientConfiguration\",\n StandardInteractionClientInitializeAuthorizationRequest: \"standardInteractionClientInitializeAuthorizationRequest\",\n StandardInteractionClientInitializeAuthorizationCodeRequest: \"standardInteractionClientInitializeAuthorizationCodeRequest\",\n /**\n * getAuthCodeUrl API (msal-browser and msal-node).\n */\n GetAuthCodeUrl: \"getAuthCodeUrl\",\n /**\n * Functions from InteractionHandler (msal-browser)\n */\n HandleCodeResponseFromServer: \"handleCodeResponseFromServer\",\n HandleCodeResponse: \"handleCodeResponse\",\n UpdateTokenEndpointAuthority: \"updateTokenEndpointAuthority\",\n /**\n * APIs in Authorization Code Client (msal-common)\n */\n AuthClientAcquireToken: \"authClientAcquireToken\",\n AuthClientExecuteTokenRequest: \"authClientExecuteTokenRequest\",\n AuthClientCreateTokenRequestBody: \"authClientCreateTokenRequestBody\",\n AuthClientCreateQueryString: \"authClientCreateQueryString\",\n /**\n * Generate functions in PopTokenGenerator (msal-common)\n */\n PopTokenGenerateCnf: \"popTokenGenerateCnf\",\n PopTokenGenerateKid: \"popTokenGenerateKid\",\n /**\n * handleServerTokenResponse API in ResponseHandler (msal-common)\n */\n HandleServerTokenResponse: \"handleServerTokenResponse\",\n DeserializeResponse: \"deserializeResponse\",\n /**\n * Authority functions\n */\n AuthorityFactoryCreateDiscoveredInstance: \"authorityFactoryCreateDiscoveredInstance\",\n AuthorityResolveEndpointsAsync: \"authorityResolveEndpointsAsync\",\n AuthorityResolveEndpointsFromLocalSources: \"authorityResolveEndpointsFromLocalSources\",\n AuthorityGetCloudDiscoveryMetadataFromNetwork: \"authorityGetCloudDiscoveryMetadataFromNetwork\",\n AuthorityUpdateCloudDiscoveryMetadata: \"authorityUpdateCloudDiscoveryMetadata\",\n AuthorityGetEndpointMetadataFromNetwork: \"authorityGetEndpointMetadataFromNetwork\",\n AuthorityUpdateEndpointMetadata: \"authorityUpdateEndpointMetadata\",\n AuthorityUpdateMetadataWithRegionalInformation: \"authorityUpdateMetadataWithRegionalInformation\",\n /**\n * Region Discovery functions\n */\n RegionDiscoveryDetectRegion: \"regionDiscoveryDetectRegion\",\n RegionDiscoveryGetRegionFromIMDS: \"regionDiscoveryGetRegionFromIMDS\",\n RegionDiscoveryGetCurrentVersion: \"regionDiscoveryGetCurrentVersion\",\n AcquireTokenByCodeAsync: \"acquireTokenByCodeAsync\",\n GetEndpointMetadataFromNetwork: \"getEndpointMetadataFromNetwork\",\n GetCloudDiscoveryMetadataFromNetworkMeasurement: \"getCloudDiscoveryMetadataFromNetworkMeasurement\",\n HandleRedirectPromiseMeasurement: \"handleRedirectPromise\",\n HandleNativeRedirectPromiseMeasurement: \"handleNativeRedirectPromise\",\n UpdateCloudDiscoveryMetadataMeasurement: \"updateCloudDiscoveryMetadataMeasurement\",\n UsernamePasswordClientAcquireToken: \"usernamePasswordClientAcquireToken\",\n NativeMessageHandlerHandshake: \"nativeMessageHandlerHandshake\",\n NativeGenerateAuthResult: \"nativeGenerateAuthResult\",\n RemoveHiddenIframe: \"removeHiddenIframe\",\n /**\n * Cache operations\n */\n ClearTokensAndKeysWithClaims: \"clearTokensAndKeysWithClaims\",\n CacheManagerGetRefreshToken: \"cacheManagerGetRefreshToken\",\n /**\n * Crypto Operations\n */\n GeneratePkceCodes: \"generatePkceCodes\",\n GenerateCodeVerifier: \"generateCodeVerifier\",\n GenerateCodeChallengeFromVerifier: \"generateCodeChallengeFromVerifier\",\n Sha256Digest: \"sha256Digest\",\n GetRandomValues: \"getRandomValues\",\n};\nconst PerformanceEventAbbreviations = new Map([\n [PerformanceEvents.AcquireTokenByCode, \"ATByCode\"],\n [PerformanceEvents.AcquireTokenByRefreshToken, \"ATByRT\"],\n [PerformanceEvents.AcquireTokenSilent, \"ATS\"],\n [PerformanceEvents.AcquireTokenSilentAsync, \"ATSAsync\"],\n [PerformanceEvents.AcquireTokenPopup, \"ATPopup\"],\n [PerformanceEvents.AcquireTokenRedirect, \"ATRedirect\"],\n [\n PerformanceEvents.CryptoOptsGetPublicKeyThumbprint,\n \"CryptoGetPKThumb\",\n ],\n [PerformanceEvents.CryptoOptsSignJwt, \"CryptoSignJwt\"],\n [PerformanceEvents.SilentCacheClientAcquireToken, \"SltCacheClientAT\"],\n [PerformanceEvents.SilentIframeClientAcquireToken, \"SltIframeClientAT\"],\n [PerformanceEvents.SilentRefreshClientAcquireToken, \"SltRClientAT\"],\n [PerformanceEvents.SsoSilent, \"SsoSlt\"],\n [\n PerformanceEvents.StandardInteractionClientGetDiscoveredAuthority,\n \"StdIntClientGetDiscAuth\",\n ],\n [\n PerformanceEvents.FetchAccountIdWithNativeBroker,\n \"FetchAccIdWithNtvBroker\",\n ],\n [\n PerformanceEvents.NativeInteractionClientAcquireToken,\n \"NtvIntClientAT\",\n ],\n [\n PerformanceEvents.BaseClientCreateTokenRequestHeaders,\n \"BaseClientCreateTReqHead\",\n ],\n [\n PerformanceEvents.RefreshTokenClientExecutePostToTokenEndpoint,\n \"RTClientExecPost\",\n ],\n [\n PerformanceEvents.AuthorizationCodeClientExecutePostToTokenEndpoint,\n \"AuthCodeClientExecPost\",\n ],\n [PerformanceEvents.BrokerHandhshake, \"BrokerHandshake\"],\n [\n PerformanceEvents.AcquireTokenByRefreshTokenInBroker,\n \"ATByRTInBroker\",\n ],\n [PerformanceEvents.AcquireTokenByBroker, \"ATByBroker\"],\n [\n PerformanceEvents.RefreshTokenClientExecuteTokenRequest,\n \"RTClientExecTReq\",\n ],\n [PerformanceEvents.RefreshTokenClientAcquireToken, \"RTClientAT\"],\n [\n PerformanceEvents.RefreshTokenClientAcquireTokenWithCachedRefreshToken,\n \"RTClientATWithCachedRT\",\n ],\n [\n PerformanceEvents.RefreshTokenClientAcquireTokenByRefreshToken,\n \"RTClientATByRT\",\n ],\n [\n PerformanceEvents.RefreshTokenClientCreateTokenRequestBody,\n \"RTClientCreateTReqBody\",\n ],\n [PerformanceEvents.AcquireTokenFromCache, \"ATFromCache\"],\n [\n PerformanceEvents.SilentFlowClientAcquireCachedToken,\n \"SltFlowClientATCached\",\n ],\n [\n PerformanceEvents.SilentFlowClientGenerateResultFromCacheRecord,\n \"SltFlowClientGenResFromCache\",\n ],\n [PerformanceEvents.AcquireTokenBySilentIframe, \"ATBySltIframe\"],\n [PerformanceEvents.InitializeBaseRequest, \"InitBaseReq\"],\n [PerformanceEvents.InitializeSilentRequest, \"InitSltReq\"],\n [\n PerformanceEvents.InitializeClientApplication,\n \"InitClientApplication\",\n ],\n [PerformanceEvents.SilentIframeClientTokenHelper, \"SIClientTHelper\"],\n [\n PerformanceEvents.SilentHandlerInitiateAuthRequest,\n \"SHandlerInitAuthReq\",\n ],\n [\n PerformanceEvents.SilentHandlerMonitorIframeForHash,\n \"SltHandlerMonitorIframeForHash\",\n ],\n [PerformanceEvents.SilentHandlerLoadFrame, \"SHandlerLoadFrame\"],\n [PerformanceEvents.SilentHandlerLoadFrameSync, \"SHandlerLoadFrameSync\"],\n [\n PerformanceEvents.StandardInteractionClientCreateAuthCodeClient,\n \"StdIntClientCreateAuthCodeClient\",\n ],\n [\n PerformanceEvents.StandardInteractionClientGetClientConfiguration,\n \"StdIntClientGetClientConf\",\n ],\n [\n PerformanceEvents.StandardInteractionClientInitializeAuthorizationRequest,\n \"StdIntClientInitAuthReq\",\n ],\n [\n PerformanceEvents.StandardInteractionClientInitializeAuthorizationCodeRequest,\n \"StdIntClientInitAuthCodeReq\",\n ],\n [PerformanceEvents.GetAuthCodeUrl, \"GetAuthCodeUrl\"],\n [\n PerformanceEvents.HandleCodeResponseFromServer,\n \"HandleCodeResFromServer\",\n ],\n [PerformanceEvents.HandleCodeResponse, \"HandleCodeResp\"],\n [PerformanceEvents.UpdateTokenEndpointAuthority, \"UpdTEndpointAuth\"],\n [PerformanceEvents.AuthClientAcquireToken, \"AuthClientAT\"],\n [PerformanceEvents.AuthClientExecuteTokenRequest, \"AuthClientExecTReq\"],\n [\n PerformanceEvents.AuthClientCreateTokenRequestBody,\n \"AuthClientCreateTReqBody\",\n ],\n [\n PerformanceEvents.AuthClientCreateQueryString,\n \"AuthClientCreateQueryStr\",\n ],\n [PerformanceEvents.PopTokenGenerateCnf, \"PopTGenCnf\"],\n [PerformanceEvents.PopTokenGenerateKid, \"PopTGenKid\"],\n [PerformanceEvents.HandleServerTokenResponse, \"HandleServerTRes\"],\n [PerformanceEvents.DeserializeResponse, \"DeserializeRes\"],\n [\n PerformanceEvents.AuthorityFactoryCreateDiscoveredInstance,\n \"AuthFactCreateDiscInst\",\n ],\n [\n PerformanceEvents.AuthorityResolveEndpointsAsync,\n \"AuthResolveEndpointsAsync\",\n ],\n [\n PerformanceEvents.AuthorityResolveEndpointsFromLocalSources,\n \"AuthResolveEndpointsFromLocal\",\n ],\n [\n PerformanceEvents.AuthorityGetCloudDiscoveryMetadataFromNetwork,\n \"AuthGetCDMetaFromNet\",\n ],\n [\n PerformanceEvents.AuthorityUpdateCloudDiscoveryMetadata,\n \"AuthUpdCDMeta\",\n ],\n [\n PerformanceEvents.AuthorityGetEndpointMetadataFromNetwork,\n \"AuthUpdCDMetaFromNet\",\n ],\n [\n PerformanceEvents.AuthorityUpdateEndpointMetadata,\n \"AuthUpdEndpointMeta\",\n ],\n [\n PerformanceEvents.AuthorityUpdateMetadataWithRegionalInformation,\n \"AuthUpdMetaWithRegInfo\",\n ],\n [PerformanceEvents.RegionDiscoveryDetectRegion, \"RegDiscDetectReg\"],\n [\n PerformanceEvents.RegionDiscoveryGetRegionFromIMDS,\n \"RegDiscGetRegFromIMDS\",\n ],\n [\n PerformanceEvents.RegionDiscoveryGetCurrentVersion,\n \"RegDiscGetCurrentVer\",\n ],\n [PerformanceEvents.AcquireTokenByCodeAsync, \"ATByCodeAsync\"],\n [\n PerformanceEvents.GetEndpointMetadataFromNetwork,\n \"GetEndpointMetaFromNet\",\n ],\n [\n PerformanceEvents.GetCloudDiscoveryMetadataFromNetworkMeasurement,\n \"GetCDMetaFromNet\",\n ],\n [\n PerformanceEvents.HandleRedirectPromiseMeasurement,\n \"HandleRedirectPromise\",\n ],\n [\n PerformanceEvents.HandleNativeRedirectPromiseMeasurement,\n \"HandleNtvRedirectPromise\",\n ],\n [\n PerformanceEvents.UpdateCloudDiscoveryMetadataMeasurement,\n \"UpdateCDMeta\",\n ],\n [\n PerformanceEvents.UsernamePasswordClientAcquireToken,\n \"UserPassClientAT\",\n ],\n [\n PerformanceEvents.NativeMessageHandlerHandshake,\n \"NtvMsgHandlerHandshake\",\n ],\n [PerformanceEvents.NativeGenerateAuthResult, \"NtvGenAuthRes\"],\n [PerformanceEvents.RemoveHiddenIframe, \"RemoveHiddenIframe\"],\n [\n PerformanceEvents.ClearTokensAndKeysWithClaims,\n \"ClearTAndKeysWithClaims\",\n ],\n [PerformanceEvents.CacheManagerGetRefreshToken, \"CacheManagerGetRT\"],\n [PerformanceEvents.GeneratePkceCodes, \"GenPkceCodes\"],\n [PerformanceEvents.GenerateCodeVerifier, \"GenCodeVerifier\"],\n [\n PerformanceEvents.GenerateCodeChallengeFromVerifier,\n \"GenCodeChallengeFromVerifier\",\n ],\n [PerformanceEvents.Sha256Digest, \"Sha256Digest\"],\n [PerformanceEvents.GetRandomValues, \"GetRandomValues\"],\n]);\n/**\n * State of the performance event.\n *\n * @export\n * @enum {number}\n */\nconst PerformanceEventStatus = {\n NotStarted: 0,\n InProgress: 1,\n Completed: 2,\n};\nconst IntFields = new Set([\n \"accessTokenSize\",\n \"durationMs\",\n \"idTokenSize\",\n \"matsSilentStatus\",\n \"matsHttpStatus\",\n \"refreshTokenSize\",\n \"queuedTimeMs\",\n \"startTimeMs\",\n \"status\",\n \"multiMatchedAT\",\n \"multiMatchedID\",\n \"multiMatchedRT\",\n]);\n\nexport { IntFields, PerformanceEventAbbreviations, PerformanceEventStatus, PerformanceEvents };\n//# sourceMappingURL=PerformanceEvent.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Wraps a function with a performance measurement.\n * Usage: invoke(functionToCall, performanceClient, \"EventName\", \"correlationId\")(...argsToPassToFunction)\n * @param callback\n * @param eventName\n * @param logger\n * @param telemetryClient\n * @param correlationId\n * @returns\n * @internal\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst invoke = (callback, eventName, logger, telemetryClient, correlationId) => {\n return (...args) => {\n logger.trace(`Executing function ${eventName}`);\n const inProgressEvent = telemetryClient?.startMeasurement(eventName, correlationId);\n if (correlationId) {\n // Track number of times this API is called in a single request\n const eventCount = eventName + \"CallCount\";\n telemetryClient?.incrementFields({ [eventCount]: 1 }, correlationId);\n }\n try {\n const result = callback(...args);\n inProgressEvent?.end({\n success: true,\n });\n logger.trace(`Returning result from ${eventName}`);\n return result;\n }\n catch (e) {\n logger.trace(`Error occurred in ${eventName}`);\n try {\n logger.trace(JSON.stringify(e));\n }\n catch (e) {\n logger.trace(\"Unable to print error message.\");\n }\n inProgressEvent?.end({\n success: false,\n }, e);\n throw e;\n }\n };\n};\n/**\n * Wraps an async function with a performance measurement.\n * Usage: invokeAsync(functionToCall, performanceClient, \"EventName\", \"correlationId\")(...argsToPassToFunction)\n * @param callback\n * @param eventName\n * @param logger\n * @param telemetryClient\n * @param correlationId\n * @returns\n * @internal\n *\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst invokeAsync = (callback, eventName, logger, telemetryClient, correlationId) => {\n return (...args) => {\n logger.trace(`Executing function ${eventName}`);\n const inProgressEvent = telemetryClient?.startMeasurement(eventName, correlationId);\n if (correlationId) {\n // Track number of times this API is called in a single request\n const eventCount = eventName + \"CallCount\";\n telemetryClient?.incrementFields({ [eventCount]: 1 }, correlationId);\n }\n telemetryClient?.setPreQueueTime(eventName, correlationId);\n return callback(...args)\n .then((response) => {\n logger.trace(`Returning result from ${eventName}`);\n inProgressEvent?.end({\n success: true,\n });\n return response;\n })\n .catch((e) => {\n logger.trace(`Error occurred in ${eventName}`);\n try {\n logger.trace(JSON.stringify(e));\n }\n catch (e) {\n logger.trace(\"Unable to print error message.\");\n }\n inProgressEvent?.end({\n success: false,\n }, e);\n throw e;\n });\n };\n};\n\nexport { invoke, invokeAsync };\n//# sourceMappingURL=FunctionWrappers.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Constants, ResponseCodes, RegionDiscoverySources } from '../utils/Constants.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { invokeAsync } from '../utils/FunctionWrappers.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass RegionDiscovery {\n constructor(networkInterface, logger, performanceClient, correlationId) {\n this.networkInterface = networkInterface;\n this.logger = logger;\n this.performanceClient = performanceClient;\n this.correlationId = correlationId;\n }\n /**\n * Detect the region from the application's environment.\n *\n * @returns Promise\n */\n async detectRegion(environmentRegion, regionDiscoveryMetadata) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RegionDiscoveryDetectRegion, this.correlationId);\n // Initialize auto detected region with the region from the envrionment\n let autodetectedRegionName = environmentRegion;\n // Check if a region was detected from the environment, if not, attempt to get the region from IMDS\n if (!autodetectedRegionName) {\n const options = RegionDiscovery.IMDS_OPTIONS;\n try {\n const localIMDSVersionResponse = await invokeAsync(this.getRegionFromIMDS.bind(this), PerformanceEvents.RegionDiscoveryGetRegionFromIMDS, this.logger, this.performanceClient, this.correlationId)(Constants.IMDS_VERSION, options);\n if (localIMDSVersionResponse.status ===\n ResponseCodes.httpSuccess) {\n autodetectedRegionName = localIMDSVersionResponse.body;\n regionDiscoveryMetadata.region_source =\n RegionDiscoverySources.IMDS;\n }\n // If the response using the local IMDS version failed, try to fetch the current version of IMDS and retry.\n if (localIMDSVersionResponse.status ===\n ResponseCodes.httpBadRequest) {\n const currentIMDSVersion = await invokeAsync(this.getCurrentVersion.bind(this), PerformanceEvents.RegionDiscoveryGetCurrentVersion, this.logger, this.performanceClient, this.correlationId)(options);\n if (!currentIMDSVersion) {\n regionDiscoveryMetadata.region_source =\n RegionDiscoverySources.FAILED_AUTO_DETECTION;\n return null;\n }\n const currentIMDSVersionResponse = await invokeAsync(this.getRegionFromIMDS.bind(this), PerformanceEvents.RegionDiscoveryGetRegionFromIMDS, this.logger, this.performanceClient, this.correlationId)(currentIMDSVersion, options);\n if (currentIMDSVersionResponse.status ===\n ResponseCodes.httpSuccess) {\n autodetectedRegionName =\n currentIMDSVersionResponse.body;\n regionDiscoveryMetadata.region_source =\n RegionDiscoverySources.IMDS;\n }\n }\n }\n catch (e) {\n regionDiscoveryMetadata.region_source =\n RegionDiscoverySources.FAILED_AUTO_DETECTION;\n return null;\n }\n }\n else {\n regionDiscoveryMetadata.region_source =\n RegionDiscoverySources.ENVIRONMENT_VARIABLE;\n }\n // If no region was auto detected from the environment or from the IMDS endpoint, mark the attempt as a FAILED_AUTO_DETECTION\n if (!autodetectedRegionName) {\n regionDiscoveryMetadata.region_source =\n RegionDiscoverySources.FAILED_AUTO_DETECTION;\n }\n return autodetectedRegionName || null;\n }\n /**\n * Make the call to the IMDS endpoint\n *\n * @param imdsEndpointUrl\n * @returns Promise>\n */\n async getRegionFromIMDS(version, options) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RegionDiscoveryGetRegionFromIMDS, this.correlationId);\n return this.networkInterface.sendGetRequestAsync(`${Constants.IMDS_ENDPOINT}?api-version=${version}&format=text`, options, Constants.IMDS_TIMEOUT);\n }\n /**\n * Get the most recent version of the IMDS endpoint available\n *\n * @returns Promise\n */\n async getCurrentVersion(options) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RegionDiscoveryGetCurrentVersion, this.correlationId);\n try {\n const response = await this.networkInterface.sendGetRequestAsync(`${Constants.IMDS_ENDPOINT}?format=json`, options);\n // When IMDS endpoint is called without the api version query param, bad request response comes back with latest version.\n if (response.status === ResponseCodes.httpBadRequest &&\n response.body &&\n response.body[\"newest-versions\"] &&\n response.body[\"newest-versions\"].length > 0) {\n return response.body[\"newest-versions\"][0];\n }\n return null;\n }\n catch (e) {\n return null;\n }\n }\n}\n// Options for the IMDS endpoint request\nRegionDiscovery.IMDS_OPTIONS = {\n headers: {\n Metadata: \"true\",\n },\n};\n\nexport { RegionDiscovery };\n//# sourceMappingURL=RegionDiscovery.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Utility functions for managing date and time operations.\n */\n/**\n * return the current time in Unix time (seconds).\n */\nfunction nowSeconds() {\n // Date.getTime() returns in milliseconds.\n return Math.round(new Date().getTime() / 1000.0);\n}\n/**\n * check if a token is expired based on given UTC time in seconds.\n * @param expiresOn\n */\nfunction isTokenExpired(expiresOn, offset) {\n // check for access token expiry\n const expirationSec = Number(expiresOn) || 0;\n const offsetCurrentTimeSec = nowSeconds() + offset;\n // If current time + offset is greater than token expiration time, then token is expired.\n return offsetCurrentTimeSec > expirationSec;\n}\n/**\n * If the current time is earlier than the time that a token was cached at, we must discard the token\n * i.e. The system clock was turned back after acquiring the cached token\n * @param cachedAt\n * @param offset\n */\nfunction wasClockTurnedBack(cachedAt) {\n const cachedAtSec = Number(cachedAt);\n return cachedAtSec > nowSeconds();\n}\n/**\n * Waits for t number of milliseconds\n * @param t number\n * @param value T\n */\nfunction delay(t, value) {\n return new Promise((resolve) => setTimeout(() => resolve(value), t));\n}\n\nexport { delay, isTokenExpired, nowSeconds, wasClockTurnedBack };\n//# sourceMappingURL=TimeUtils.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { extractTokenClaims } from '../../account/AuthToken.mjs';\nimport { createClientAuthError } from '../../error/ClientAuthError.mjs';\nimport { Separators, CredentialType, AuthenticationScheme, SERVER_TELEM_CONSTANTS, ThrottlingConstants, APP_METADATA, AUTHORITY_METADATA_CONSTANTS } from '../../utils/Constants.mjs';\nimport { nowSeconds } from '../../utils/TimeUtils.mjs';\nimport { tokenClaimsCnfRequiredForSignedJwt } from '../../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Cache Key: -------\n * IdToken Example: uid.utid-login.microsoftonline.com-idtoken-app_client_id-contoso.com\n * AccessToken Example: uid.utid-login.microsoftonline.com-accesstoken-app_client_id-contoso.com-scope1 scope2--pop\n * RefreshToken Example: uid.utid-login.microsoftonline.com-refreshtoken-1-contoso.com\n * @param credentialEntity\n * @returns\n */\nfunction generateCredentialKey(credentialEntity) {\n const credentialKey = [\n generateAccountId(credentialEntity),\n generateCredentialId(credentialEntity),\n generateTarget(credentialEntity),\n generateClaimsHash(credentialEntity),\n generateScheme(credentialEntity),\n ];\n return credentialKey.join(Separators.CACHE_KEY_SEPARATOR).toLowerCase();\n}\n/**\n * Create IdTokenEntity\n * @param homeAccountId\n * @param authenticationResult\n * @param clientId\n * @param authority\n */\nfunction createIdTokenEntity(homeAccountId, environment, idToken, clientId, tenantId) {\n const idTokenEntity = {\n credentialType: CredentialType.ID_TOKEN,\n homeAccountId: homeAccountId,\n environment: environment,\n clientId: clientId,\n secret: idToken,\n realm: tenantId,\n };\n return idTokenEntity;\n}\n/**\n * Create AccessTokenEntity\n * @param homeAccountId\n * @param environment\n * @param accessToken\n * @param clientId\n * @param tenantId\n * @param scopes\n * @param expiresOn\n * @param extExpiresOn\n */\nfunction createAccessTokenEntity(homeAccountId, environment, accessToken, clientId, tenantId, scopes, expiresOn, extExpiresOn, base64Decode, refreshOn, tokenType, userAssertionHash, keyId, requestedClaims, requestedClaimsHash) {\n const atEntity = {\n homeAccountId: homeAccountId,\n credentialType: CredentialType.ACCESS_TOKEN,\n secret: accessToken,\n cachedAt: nowSeconds().toString(),\n expiresOn: expiresOn.toString(),\n extendedExpiresOn: extExpiresOn.toString(),\n environment: environment,\n clientId: clientId,\n realm: tenantId,\n target: scopes,\n tokenType: tokenType || AuthenticationScheme.BEARER,\n };\n if (userAssertionHash) {\n atEntity.userAssertionHash = userAssertionHash;\n }\n if (refreshOn) {\n atEntity.refreshOn = refreshOn.toString();\n }\n if (requestedClaims) {\n atEntity.requestedClaims = requestedClaims;\n atEntity.requestedClaimsHash = requestedClaimsHash;\n }\n /*\n * Create Access Token With Auth Scheme instead of regular access token\n * Cast to lower to handle \"bearer\" from ADFS\n */\n if (atEntity.tokenType?.toLowerCase() !==\n AuthenticationScheme.BEARER.toLowerCase()) {\n atEntity.credentialType = CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME;\n switch (atEntity.tokenType) {\n case AuthenticationScheme.POP:\n // Make sure keyId is present and add it to credential\n const tokenClaims = extractTokenClaims(accessToken, base64Decode);\n if (!tokenClaims?.cnf?.kid) {\n throw createClientAuthError(tokenClaimsCnfRequiredForSignedJwt);\n }\n atEntity.keyId = tokenClaims.cnf.kid;\n break;\n case AuthenticationScheme.SSH:\n atEntity.keyId = keyId;\n }\n }\n return atEntity;\n}\n/**\n * Create RefreshTokenEntity\n * @param homeAccountId\n * @param authenticationResult\n * @param clientId\n * @param authority\n */\nfunction createRefreshTokenEntity(homeAccountId, environment, refreshToken, clientId, familyId, userAssertionHash, expiresOn) {\n const rtEntity = {\n credentialType: CredentialType.REFRESH_TOKEN,\n homeAccountId: homeAccountId,\n environment: environment,\n clientId: clientId,\n secret: refreshToken,\n };\n if (userAssertionHash) {\n rtEntity.userAssertionHash = userAssertionHash;\n }\n if (familyId) {\n rtEntity.familyId = familyId;\n }\n if (expiresOn) {\n rtEntity.expiresOn = expiresOn.toString();\n }\n return rtEntity;\n}\nfunction isCredentialEntity(entity) {\n return (entity.hasOwnProperty(\"homeAccountId\") &&\n entity.hasOwnProperty(\"environment\") &&\n entity.hasOwnProperty(\"credentialType\") &&\n entity.hasOwnProperty(\"clientId\") &&\n entity.hasOwnProperty(\"secret\"));\n}\n/**\n * Validates an entity: checks for all expected params\n * @param entity\n */\nfunction isAccessTokenEntity(entity) {\n if (!entity) {\n return false;\n }\n return (isCredentialEntity(entity) &&\n entity.hasOwnProperty(\"realm\") &&\n entity.hasOwnProperty(\"target\") &&\n (entity[\"credentialType\"] === CredentialType.ACCESS_TOKEN ||\n entity[\"credentialType\"] ===\n CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME));\n}\n/**\n * Validates an entity: checks for all expected params\n * @param entity\n */\nfunction isIdTokenEntity(entity) {\n if (!entity) {\n return false;\n }\n return (isCredentialEntity(entity) &&\n entity.hasOwnProperty(\"realm\") &&\n entity[\"credentialType\"] === CredentialType.ID_TOKEN);\n}\n/**\n * Validates an entity: checks for all expected params\n * @param entity\n */\nfunction isRefreshTokenEntity(entity) {\n if (!entity) {\n return false;\n }\n return (isCredentialEntity(entity) &&\n entity[\"credentialType\"] === CredentialType.REFRESH_TOKEN);\n}\n/**\n * Generate Account Id key component as per the schema: -\n */\nfunction generateAccountId(credentialEntity) {\n const accountId = [\n credentialEntity.homeAccountId,\n credentialEntity.environment,\n ];\n return accountId.join(Separators.CACHE_KEY_SEPARATOR).toLowerCase();\n}\n/**\n * Generate Credential Id key component as per the schema: --\n */\nfunction generateCredentialId(credentialEntity) {\n const clientOrFamilyId = credentialEntity.credentialType === CredentialType.REFRESH_TOKEN\n ? credentialEntity.familyId || credentialEntity.clientId\n : credentialEntity.clientId;\n const credentialId = [\n credentialEntity.credentialType,\n clientOrFamilyId,\n credentialEntity.realm || \"\",\n ];\n return credentialId.join(Separators.CACHE_KEY_SEPARATOR).toLowerCase();\n}\n/**\n * Generate target key component as per schema: \n */\nfunction generateTarget(credentialEntity) {\n return (credentialEntity.target || \"\").toLowerCase();\n}\n/**\n * Generate requested claims key component as per schema: \n */\nfunction generateClaimsHash(credentialEntity) {\n return (credentialEntity.requestedClaimsHash || \"\").toLowerCase();\n}\n/**\n * Generate scheme key componenet as per schema: \n */\nfunction generateScheme(credentialEntity) {\n /*\n * PoP Tokens and SSH certs include scheme in cache key\n * Cast to lowercase to handle \"bearer\" from ADFS\n */\n return credentialEntity.tokenType &&\n credentialEntity.tokenType.toLowerCase() !==\n AuthenticationScheme.BEARER.toLowerCase()\n ? credentialEntity.tokenType.toLowerCase()\n : \"\";\n}\n/**\n * validates if a given cache entry is \"Telemetry\", parses \n * @param key\n * @param entity\n */\nfunction isServerTelemetryEntity(key, entity) {\n const validateKey = key.indexOf(SERVER_TELEM_CONSTANTS.CACHE_KEY) === 0;\n let validateEntity = true;\n if (entity) {\n validateEntity =\n entity.hasOwnProperty(\"failedRequests\") &&\n entity.hasOwnProperty(\"errors\") &&\n entity.hasOwnProperty(\"cacheHits\");\n }\n return validateKey && validateEntity;\n}\n/**\n * validates if a given cache entry is \"Throttling\", parses \n * @param key\n * @param entity\n */\nfunction isThrottlingEntity(key, entity) {\n let validateKey = false;\n if (key) {\n validateKey = key.indexOf(ThrottlingConstants.THROTTLING_PREFIX) === 0;\n }\n let validateEntity = true;\n if (entity) {\n validateEntity = entity.hasOwnProperty(\"throttleTime\");\n }\n return validateKey && validateEntity;\n}\n/**\n * Generate AppMetadata Cache Key as per the schema: appmetadata--\n */\nfunction generateAppMetadataKey({ environment, clientId, }) {\n const appMetaDataKeyArray = [\n APP_METADATA,\n environment,\n clientId,\n ];\n return appMetaDataKeyArray\n .join(Separators.CACHE_KEY_SEPARATOR)\n .toLowerCase();\n}\n/*\n * Validates an entity: checks for all expected params\n * @param entity\n */\nfunction isAppMetadataEntity(key, entity) {\n if (!entity) {\n return false;\n }\n return (key.indexOf(APP_METADATA) === 0 &&\n entity.hasOwnProperty(\"clientId\") &&\n entity.hasOwnProperty(\"environment\"));\n}\n/**\n * Validates an entity: checks for all expected params\n * @param entity\n */\nfunction isAuthorityMetadataEntity(key, entity) {\n if (!entity) {\n return false;\n }\n return (key.indexOf(AUTHORITY_METADATA_CONSTANTS.CACHE_KEY) === 0 &&\n entity.hasOwnProperty(\"aliases\") &&\n entity.hasOwnProperty(\"preferred_cache\") &&\n entity.hasOwnProperty(\"preferred_network\") &&\n entity.hasOwnProperty(\"canonical_authority\") &&\n entity.hasOwnProperty(\"authorization_endpoint\") &&\n entity.hasOwnProperty(\"token_endpoint\") &&\n entity.hasOwnProperty(\"issuer\") &&\n entity.hasOwnProperty(\"aliasesFromNetwork\") &&\n entity.hasOwnProperty(\"endpointsFromNetwork\") &&\n entity.hasOwnProperty(\"expiresAt\") &&\n entity.hasOwnProperty(\"jwks_uri\"));\n}\n/**\n * Reset the exiresAt value\n */\nfunction generateAuthorityMetadataExpiresAt() {\n return (nowSeconds() +\n AUTHORITY_METADATA_CONSTANTS.REFRESH_TIME_SECONDS);\n}\nfunction updateAuthorityEndpointMetadata(authorityMetadata, updatedValues, fromNetwork) {\n authorityMetadata.authorization_endpoint =\n updatedValues.authorization_endpoint;\n authorityMetadata.token_endpoint = updatedValues.token_endpoint;\n authorityMetadata.end_session_endpoint = updatedValues.end_session_endpoint;\n authorityMetadata.issuer = updatedValues.issuer;\n authorityMetadata.endpointsFromNetwork = fromNetwork;\n authorityMetadata.jwks_uri = updatedValues.jwks_uri;\n}\nfunction updateCloudDiscoveryMetadata(authorityMetadata, updatedValues, fromNetwork) {\n authorityMetadata.aliases = updatedValues.aliases;\n authorityMetadata.preferred_cache = updatedValues.preferred_cache;\n authorityMetadata.preferred_network = updatedValues.preferred_network;\n authorityMetadata.aliasesFromNetwork = fromNetwork;\n}\n/**\n * Returns whether or not the data needs to be refreshed\n */\nfunction isAuthorityMetadataExpired(metadata) {\n return metadata.expiresAt <= nowSeconds();\n}\n\nexport { createAccessTokenEntity, createIdTokenEntity, createRefreshTokenEntity, generateAppMetadataKey, generateAuthorityMetadataExpiresAt, generateCredentialKey, isAccessTokenEntity, isAppMetadataEntity, isAuthorityMetadataEntity, isAuthorityMetadataExpired, isCredentialEntity, isIdTokenEntity, isRefreshTokenEntity, isServerTelemetryEntity, isThrottlingEntity, updateAuthorityEndpointMetadata, updateCloudDiscoveryMetadata };\n//# sourceMappingURL=CacheHelpers.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { AuthorityType } from './AuthorityType.mjs';\nimport { isOpenIdConfigResponse } from './OpenIdConfigResponse.mjs';\nimport { UrlString } from '../url/UrlString.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { Constants, AuthorityMetadataSource, RegionDiscoveryOutcomes, AADAuthorityConstants } from '../utils/Constants.mjs';\nimport { EndpointMetadata, getCloudDiscoveryMetadataFromHardcodedValues, getCloudDiscoveryMetadataFromNetworkResponse, InstanceDiscoveryMetadataAliases } from './AuthorityMetadata.mjs';\nimport { createClientConfigurationError } from '../error/ClientConfigurationError.mjs';\nimport { ProtocolMode } from './ProtocolMode.mjs';\nimport { AzureCloudInstance } from './AuthorityOptions.mjs';\nimport { isCloudInstanceDiscoveryResponse } from './CloudInstanceDiscoveryResponse.mjs';\nimport { isCloudInstanceDiscoveryErrorResponse } from './CloudInstanceDiscoveryErrorResponse.mjs';\nimport { RegionDiscovery } from './RegionDiscovery.mjs';\nimport { AuthError } from '../error/AuthError.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { invokeAsync } from '../utils/FunctionWrappers.mjs';\nimport { generateAuthorityMetadataExpiresAt, updateAuthorityEndpointMetadata, isAuthorityMetadataExpired, updateCloudDiscoveryMetadata } from '../cache/utils/CacheHelpers.mjs';\nimport { endpointResolutionError, endSessionEndpointNotSupported, openIdConfigError } from '../error/ClientAuthErrorCodes.mjs';\nimport { invalidAuthorityMetadata, untrustedAuthority, invalidCloudDiscoveryMetadata } from '../error/ClientConfigurationErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * The authority class validates the authority URIs used by the user, and retrieves the OpenID Configuration Data from the\n * endpoint. It will store the pertinent config data in this object for use during token calls.\n * @internal\n */\nclass Authority {\n constructor(authority, networkInterface, cacheManager, authorityOptions, logger, correlationId, performanceClient, managedIdentity) {\n this.canonicalAuthority = authority;\n this._canonicalAuthority.validateAsUri();\n this.networkInterface = networkInterface;\n this.cacheManager = cacheManager;\n this.authorityOptions = authorityOptions;\n this.regionDiscoveryMetadata = {\n region_used: undefined,\n region_source: undefined,\n region_outcome: undefined,\n };\n this.logger = logger;\n this.performanceClient = performanceClient;\n this.correlationId = correlationId;\n this.managedIdentity = managedIdentity || false;\n this.regionDiscovery = new RegionDiscovery(networkInterface, this.logger, this.performanceClient, this.correlationId);\n }\n /**\n * Get {@link AuthorityType}\n * @param authorityUri {@link IUri}\n * @private\n */\n getAuthorityType(authorityUri) {\n // CIAM auth url pattern is being standardized as: .ciamlogin.com\n if (authorityUri.HostNameAndPort.endsWith(Constants.CIAM_AUTH_URL)) {\n return AuthorityType.Ciam;\n }\n const pathSegments = authorityUri.PathSegments;\n if (pathSegments.length) {\n switch (pathSegments[0].toLowerCase()) {\n case Constants.ADFS:\n return AuthorityType.Adfs;\n case Constants.DSTS:\n return AuthorityType.Dsts;\n }\n }\n return AuthorityType.Default;\n }\n // See above for AuthorityType\n get authorityType() {\n return this.getAuthorityType(this.canonicalAuthorityUrlComponents);\n }\n /**\n * ProtocolMode enum representing the way endpoints are constructed.\n */\n get protocolMode() {\n return this.authorityOptions.protocolMode;\n }\n /**\n * Returns authorityOptions which can be used to reinstantiate a new authority instance\n */\n get options() {\n return this.authorityOptions;\n }\n /**\n * A URL that is the authority set by the developer\n */\n get canonicalAuthority() {\n return this._canonicalAuthority.urlString;\n }\n /**\n * Sets canonical authority.\n */\n set canonicalAuthority(url) {\n this._canonicalAuthority = new UrlString(url);\n this._canonicalAuthority.validateAsUri();\n this._canonicalAuthorityUrlComponents = null;\n }\n /**\n * Get authority components.\n */\n get canonicalAuthorityUrlComponents() {\n if (!this._canonicalAuthorityUrlComponents) {\n this._canonicalAuthorityUrlComponents =\n this._canonicalAuthority.getUrlComponents();\n }\n return this._canonicalAuthorityUrlComponents;\n }\n /**\n * Get hostname and port i.e. login.microsoftonline.com\n */\n get hostnameAndPort() {\n return this.canonicalAuthorityUrlComponents.HostNameAndPort.toLowerCase();\n }\n /**\n * Get tenant for authority.\n */\n get tenant() {\n return this.canonicalAuthorityUrlComponents.PathSegments[0];\n }\n /**\n * OAuth /authorize endpoint for requests\n */\n get authorizationEndpoint() {\n if (this.discoveryComplete()) {\n return this.replacePath(this.metadata.authorization_endpoint);\n }\n else {\n throw createClientAuthError(endpointResolutionError);\n }\n }\n /**\n * OAuth /token endpoint for requests\n */\n get tokenEndpoint() {\n if (this.discoveryComplete()) {\n return this.replacePath(this.metadata.token_endpoint);\n }\n else {\n throw createClientAuthError(endpointResolutionError);\n }\n }\n get deviceCodeEndpoint() {\n if (this.discoveryComplete()) {\n return this.replacePath(this.metadata.token_endpoint.replace(\"/token\", \"/devicecode\"));\n }\n else {\n throw createClientAuthError(endpointResolutionError);\n }\n }\n /**\n * OAuth logout endpoint for requests\n */\n get endSessionEndpoint() {\n if (this.discoveryComplete()) {\n // ROPC policies may not have end_session_endpoint set\n if (!this.metadata.end_session_endpoint) {\n throw createClientAuthError(endSessionEndpointNotSupported);\n }\n return this.replacePath(this.metadata.end_session_endpoint);\n }\n else {\n throw createClientAuthError(endpointResolutionError);\n }\n }\n /**\n * OAuth issuer for requests\n */\n get selfSignedJwtAudience() {\n if (this.discoveryComplete()) {\n return this.replacePath(this.metadata.issuer);\n }\n else {\n throw createClientAuthError(endpointResolutionError);\n }\n }\n /**\n * Jwks_uri for token signing keys\n */\n get jwksUri() {\n if (this.discoveryComplete()) {\n return this.replacePath(this.metadata.jwks_uri);\n }\n else {\n throw createClientAuthError(endpointResolutionError);\n }\n }\n /**\n * Returns a flag indicating that tenant name can be replaced in authority {@link IUri}\n * @param authorityUri {@link IUri}\n * @private\n */\n canReplaceTenant(authorityUri) {\n return (authorityUri.PathSegments.length === 1 &&\n !Authority.reservedTenantDomains.has(authorityUri.PathSegments[0]) &&\n this.getAuthorityType(authorityUri) === AuthorityType.Default &&\n this.protocolMode === ProtocolMode.AAD);\n }\n /**\n * Replaces tenant in url path with current tenant. Defaults to common.\n * @param urlString\n */\n replaceTenant(urlString) {\n return urlString.replace(/{tenant}|{tenantid}/g, this.tenant);\n }\n /**\n * Replaces path such as tenant or policy with the current tenant or policy.\n * @param urlString\n */\n replacePath(urlString) {\n let endpoint = urlString;\n const cachedAuthorityUrl = new UrlString(this.metadata.canonical_authority);\n const cachedAuthorityUrlComponents = cachedAuthorityUrl.getUrlComponents();\n const cachedAuthorityParts = cachedAuthorityUrlComponents.PathSegments;\n const currentAuthorityParts = this.canonicalAuthorityUrlComponents.PathSegments;\n currentAuthorityParts.forEach((currentPart, index) => {\n let cachedPart = cachedAuthorityParts[index];\n if (index === 0 &&\n this.canReplaceTenant(cachedAuthorityUrlComponents)) {\n const tenantId = new UrlString(this.metadata.authorization_endpoint).getUrlComponents().PathSegments[0];\n /**\n * Check if AAD canonical authority contains tenant domain name, for example \"testdomain.onmicrosoft.com\",\n * by comparing its first path segment to the corresponding authorization endpoint path segment, which is\n * always resolved with tenant id by OIDC.\n */\n if (cachedPart !== tenantId) {\n this.logger.verbose(`Replacing tenant domain name ${cachedPart} with id ${tenantId}`);\n cachedPart = tenantId;\n }\n }\n if (currentPart !== cachedPart) {\n endpoint = endpoint.replace(`/${cachedPart}/`, `/${currentPart}/`);\n }\n });\n return this.replaceTenant(endpoint);\n }\n /**\n * The default open id configuration endpoint for any canonical authority.\n */\n get defaultOpenIdConfigurationEndpoint() {\n const canonicalAuthorityHost = this.hostnameAndPort;\n if (this.canonicalAuthority.endsWith(\"v2.0/\") ||\n this.authorityType === AuthorityType.Adfs ||\n (this.protocolMode !== ProtocolMode.AAD &&\n !this.isAliasOfKnownMicrosoftAuthority(canonicalAuthorityHost))) {\n return `${this.canonicalAuthority}.well-known/openid-configuration`;\n }\n return `${this.canonicalAuthority}v2.0/.well-known/openid-configuration`;\n }\n /**\n * Boolean that returns whether or not tenant discovery has been completed.\n */\n discoveryComplete() {\n return !!this.metadata;\n }\n /**\n * Perform endpoint discovery to discover aliases, preferred_cache, preferred_network\n * and the /authorize, /token and logout endpoints.\n */\n async resolveEndpointsAsync() {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthorityResolveEndpointsAsync, this.correlationId);\n const metadataEntity = this.getCurrentMetadataEntity();\n const cloudDiscoverySource = await invokeAsync(this.updateCloudDiscoveryMetadata.bind(this), PerformanceEvents.AuthorityUpdateCloudDiscoveryMetadata, this.logger, this.performanceClient, this.correlationId)(metadataEntity);\n this.canonicalAuthority = this.canonicalAuthority.replace(this.hostnameAndPort, metadataEntity.preferred_network);\n const endpointSource = await invokeAsync(this.updateEndpointMetadata.bind(this), PerformanceEvents.AuthorityUpdateEndpointMetadata, this.logger, this.performanceClient, this.correlationId)(metadataEntity);\n this.updateCachedMetadata(metadataEntity, cloudDiscoverySource, {\n source: endpointSource,\n });\n this.performanceClient?.addFields({\n cloudDiscoverySource: cloudDiscoverySource,\n authorityEndpointSource: endpointSource,\n }, this.correlationId);\n }\n /**\n * Returns metadata entity from cache if it exists, otherwiser returns a new metadata entity built\n * from the configured canonical authority\n * @returns\n */\n getCurrentMetadataEntity() {\n let metadataEntity = this.cacheManager.getAuthorityMetadataByAlias(this.hostnameAndPort);\n if (!metadataEntity) {\n metadataEntity = {\n aliases: [],\n preferred_cache: this.hostnameAndPort,\n preferred_network: this.hostnameAndPort,\n canonical_authority: this.canonicalAuthority,\n authorization_endpoint: \"\",\n token_endpoint: \"\",\n end_session_endpoint: \"\",\n issuer: \"\",\n aliasesFromNetwork: false,\n endpointsFromNetwork: false,\n expiresAt: generateAuthorityMetadataExpiresAt(),\n jwks_uri: \"\",\n };\n }\n return metadataEntity;\n }\n /**\n * Updates cached metadata based on metadata source and sets the instance's metadata\n * property to the same value\n * @param metadataEntity\n * @param cloudDiscoverySource\n * @param endpointMetadataResult\n */\n updateCachedMetadata(metadataEntity, cloudDiscoverySource, endpointMetadataResult) {\n if (cloudDiscoverySource !== AuthorityMetadataSource.CACHE &&\n endpointMetadataResult?.source !== AuthorityMetadataSource.CACHE) {\n // Reset the expiration time unless both values came from a successful cache lookup\n metadataEntity.expiresAt =\n generateAuthorityMetadataExpiresAt();\n metadataEntity.canonical_authority = this.canonicalAuthority;\n }\n const cacheKey = this.cacheManager.generateAuthorityMetadataCacheKey(metadataEntity.preferred_cache);\n this.cacheManager.setAuthorityMetadata(cacheKey, metadataEntity);\n this.metadata = metadataEntity;\n }\n /**\n * Update AuthorityMetadataEntity with new endpoints and return where the information came from\n * @param metadataEntity\n */\n async updateEndpointMetadata(metadataEntity) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthorityUpdateEndpointMetadata, this.correlationId);\n const localMetadata = this.updateEndpointMetadataFromLocalSources(metadataEntity);\n // Further update may be required for hardcoded metadata if regional metadata is preferred\n if (localMetadata) {\n if (localMetadata.source ===\n AuthorityMetadataSource.HARDCODED_VALUES) {\n // If the user prefers to use an azure region replace the global endpoints with regional information.\n if (this.authorityOptions.azureRegionConfiguration?.azureRegion) {\n if (localMetadata.metadata) {\n const hardcodedMetadata = await invokeAsync(this.updateMetadataWithRegionalInformation.bind(this), PerformanceEvents.AuthorityUpdateMetadataWithRegionalInformation, this.logger, this.performanceClient, this.correlationId)(localMetadata.metadata);\n updateAuthorityEndpointMetadata(metadataEntity, hardcodedMetadata, false);\n metadataEntity.canonical_authority =\n this.canonicalAuthority;\n }\n }\n }\n return localMetadata.source;\n }\n // Get metadata from network if local sources aren't available\n let metadata = await invokeAsync(this.getEndpointMetadataFromNetwork.bind(this), PerformanceEvents.AuthorityGetEndpointMetadataFromNetwork, this.logger, this.performanceClient, this.correlationId)();\n if (metadata) {\n // If the user prefers to use an azure region replace the global endpoints with regional information.\n if (this.authorityOptions.azureRegionConfiguration?.azureRegion) {\n metadata = await invokeAsync(this.updateMetadataWithRegionalInformation.bind(this), PerformanceEvents.AuthorityUpdateMetadataWithRegionalInformation, this.logger, this.performanceClient, this.correlationId)(metadata);\n }\n updateAuthorityEndpointMetadata(metadataEntity, metadata, true);\n return AuthorityMetadataSource.NETWORK;\n }\n else {\n // Metadata could not be obtained from the config, cache, network or hardcoded values\n throw createClientAuthError(openIdConfigError, this.defaultOpenIdConfigurationEndpoint);\n }\n }\n /**\n * Updates endpoint metadata from local sources and returns where the information was retrieved from and the metadata config\n * response if the source is hardcoded metadata\n * @param metadataEntity\n * @returns\n */\n updateEndpointMetadataFromLocalSources(metadataEntity) {\n this.logger.verbose(\"Attempting to get endpoint metadata from authority configuration\");\n const configMetadata = this.getEndpointMetadataFromConfig();\n if (configMetadata) {\n this.logger.verbose(\"Found endpoint metadata in authority configuration\");\n updateAuthorityEndpointMetadata(metadataEntity, configMetadata, false);\n return {\n source: AuthorityMetadataSource.CONFIG,\n };\n }\n this.logger.verbose(\"Did not find endpoint metadata in the config... Attempting to get endpoint metadata from the hardcoded values.\");\n // skipAuthorityMetadataCache is used to bypass hardcoded authority metadata and force a network metadata cache lookup and network metadata request if no cached response is available.\n if (this.authorityOptions.skipAuthorityMetadataCache) {\n this.logger.verbose(\"Skipping hardcoded metadata cache since skipAuthorityMetadataCache is set to true. Attempting to get endpoint metadata from the network metadata cache.\");\n }\n else {\n const hardcodedMetadata = this.getEndpointMetadataFromHardcodedValues();\n if (hardcodedMetadata) {\n updateAuthorityEndpointMetadata(metadataEntity, hardcodedMetadata, false);\n return {\n source: AuthorityMetadataSource.HARDCODED_VALUES,\n metadata: hardcodedMetadata,\n };\n }\n else {\n this.logger.verbose(\"Did not find endpoint metadata in hardcoded values... Attempting to get endpoint metadata from the network metadata cache.\");\n }\n }\n // Check cached metadata entity expiration status\n const metadataEntityExpired = isAuthorityMetadataExpired(metadataEntity);\n if (this.isAuthoritySameType(metadataEntity) &&\n metadataEntity.endpointsFromNetwork &&\n !metadataEntityExpired) {\n // No need to update\n this.logger.verbose(\"Found endpoint metadata in the cache.\");\n return { source: AuthorityMetadataSource.CACHE };\n }\n else if (metadataEntityExpired) {\n this.logger.verbose(\"The metadata entity is expired.\");\n }\n return null;\n }\n /**\n * Compares the number of url components after the domain to determine if the cached\n * authority metadata can be used for the requested authority. Protects against same domain different\n * authority such as login.microsoftonline.com/tenant and login.microsoftonline.com/tfp/tenant/policy\n * @param metadataEntity\n */\n isAuthoritySameType(metadataEntity) {\n const cachedAuthorityUrl = new UrlString(metadataEntity.canonical_authority);\n const cachedParts = cachedAuthorityUrl.getUrlComponents().PathSegments;\n return (cachedParts.length ===\n this.canonicalAuthorityUrlComponents.PathSegments.length);\n }\n /**\n * Parse authorityMetadata config option\n */\n getEndpointMetadataFromConfig() {\n if (this.authorityOptions.authorityMetadata) {\n try {\n return JSON.parse(this.authorityOptions.authorityMetadata);\n }\n catch (e) {\n throw createClientConfigurationError(invalidAuthorityMetadata);\n }\n }\n return null;\n }\n /**\n * Gets OAuth endpoints from the given OpenID configuration endpoint.\n *\n * @param hasHardcodedMetadata boolean\n */\n async getEndpointMetadataFromNetwork() {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthorityGetEndpointMetadataFromNetwork, this.correlationId);\n const options = {};\n /*\n * TODO: Add a timeout if the authority exists in our library's\n * hardcoded list of metadata\n */\n const openIdConfigurationEndpoint = this.defaultOpenIdConfigurationEndpoint;\n this.logger.verbose(`Authority.getEndpointMetadataFromNetwork: attempting to retrieve OAuth endpoints from ${openIdConfigurationEndpoint}`);\n try {\n const response = await this.networkInterface.sendGetRequestAsync(openIdConfigurationEndpoint, options);\n const isValidResponse = isOpenIdConfigResponse(response.body);\n if (isValidResponse) {\n return response.body;\n }\n else {\n this.logger.verbose(`Authority.getEndpointMetadataFromNetwork: could not parse response as OpenID configuration`);\n return null;\n }\n }\n catch (e) {\n this.logger.verbose(`Authority.getEndpointMetadataFromNetwork: ${e}`);\n return null;\n }\n }\n /**\n * Get OAuth endpoints for common authorities.\n */\n getEndpointMetadataFromHardcodedValues() {\n if (this.hostnameAndPort in EndpointMetadata) {\n return EndpointMetadata[this.hostnameAndPort];\n }\n return null;\n }\n /**\n * Update the retrieved metadata with regional information.\n * User selected Azure region will be used if configured.\n */\n async updateMetadataWithRegionalInformation(metadata) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthorityUpdateMetadataWithRegionalInformation, this.correlationId);\n const userConfiguredAzureRegion = this.authorityOptions.azureRegionConfiguration?.azureRegion;\n if (userConfiguredAzureRegion) {\n if (userConfiguredAzureRegion !==\n Constants.AZURE_REGION_AUTO_DISCOVER_FLAG) {\n this.regionDiscoveryMetadata.region_outcome =\n RegionDiscoveryOutcomes.CONFIGURED_NO_AUTO_DETECTION;\n this.regionDiscoveryMetadata.region_used =\n userConfiguredAzureRegion;\n return Authority.replaceWithRegionalInformation(metadata, userConfiguredAzureRegion);\n }\n const autodetectedRegionName = await invokeAsync(this.regionDiscovery.detectRegion.bind(this.regionDiscovery), PerformanceEvents.RegionDiscoveryDetectRegion, this.logger, this.performanceClient, this.correlationId)(this.authorityOptions.azureRegionConfiguration\n ?.environmentRegion, this.regionDiscoveryMetadata);\n if (autodetectedRegionName) {\n this.regionDiscoveryMetadata.region_outcome =\n RegionDiscoveryOutcomes.AUTO_DETECTION_REQUESTED_SUCCESSFUL;\n this.regionDiscoveryMetadata.region_used =\n autodetectedRegionName;\n return Authority.replaceWithRegionalInformation(metadata, autodetectedRegionName);\n }\n this.regionDiscoveryMetadata.region_outcome =\n RegionDiscoveryOutcomes.AUTO_DETECTION_REQUESTED_FAILED;\n }\n return metadata;\n }\n /**\n * Updates the AuthorityMetadataEntity with new aliases, preferred_network and preferred_cache\n * and returns where the information was retrieved from\n * @param metadataEntity\n * @returns AuthorityMetadataSource\n */\n async updateCloudDiscoveryMetadata(metadataEntity) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthorityUpdateCloudDiscoveryMetadata, this.correlationId);\n const localMetadataSource = this.updateCloudDiscoveryMetadataFromLocalSources(metadataEntity);\n if (localMetadataSource) {\n return localMetadataSource;\n }\n // Fallback to network as metadata source\n const metadata = await invokeAsync(this.getCloudDiscoveryMetadataFromNetwork.bind(this), PerformanceEvents.AuthorityGetCloudDiscoveryMetadataFromNetwork, this.logger, this.performanceClient, this.correlationId)();\n if (metadata) {\n updateCloudDiscoveryMetadata(metadataEntity, metadata, true);\n return AuthorityMetadataSource.NETWORK;\n }\n // Metadata could not be obtained from the config, cache, network or hardcoded values\n throw createClientConfigurationError(untrustedAuthority);\n }\n updateCloudDiscoveryMetadataFromLocalSources(metadataEntity) {\n this.logger.verbose(\"Attempting to get cloud discovery metadata from authority configuration\");\n this.logger.verbosePii(`Known Authorities: ${this.authorityOptions.knownAuthorities ||\n Constants.NOT_APPLICABLE}`);\n this.logger.verbosePii(`Authority Metadata: ${this.authorityOptions.authorityMetadata ||\n Constants.NOT_APPLICABLE}`);\n this.logger.verbosePii(`Canonical Authority: ${metadataEntity.canonical_authority || Constants.NOT_APPLICABLE}`);\n const metadata = this.getCloudDiscoveryMetadataFromConfig();\n if (metadata) {\n this.logger.verbose(\"Found cloud discovery metadata in authority configuration\");\n updateCloudDiscoveryMetadata(metadataEntity, metadata, false);\n return AuthorityMetadataSource.CONFIG;\n }\n // If the cached metadata came from config but that config was not passed to this instance, we must go to hardcoded values\n this.logger.verbose(\"Did not find cloud discovery metadata in the config... Attempting to get cloud discovery metadata from the hardcoded values.\");\n if (this.options.skipAuthorityMetadataCache) {\n this.logger.verbose(\"Skipping hardcoded cloud discovery metadata cache since skipAuthorityMetadataCache is set to true. Attempting to get cloud discovery metadata from the network metadata cache.\");\n }\n else {\n const hardcodedMetadata = getCloudDiscoveryMetadataFromHardcodedValues(this.hostnameAndPort);\n if (hardcodedMetadata) {\n this.logger.verbose(\"Found cloud discovery metadata from hardcoded values.\");\n updateCloudDiscoveryMetadata(metadataEntity, hardcodedMetadata, false);\n return AuthorityMetadataSource.HARDCODED_VALUES;\n }\n this.logger.verbose(\"Did not find cloud discovery metadata in hardcoded values... Attempting to get cloud discovery metadata from the network metadata cache.\");\n }\n const metadataEntityExpired = isAuthorityMetadataExpired(metadataEntity);\n if (this.isAuthoritySameType(metadataEntity) &&\n metadataEntity.aliasesFromNetwork &&\n !metadataEntityExpired) {\n this.logger.verbose(\"Found cloud discovery metadata in the cache.\");\n // No need to update\n return AuthorityMetadataSource.CACHE;\n }\n else if (metadataEntityExpired) {\n this.logger.verbose(\"The metadata entity is expired.\");\n }\n return null;\n }\n /**\n * Parse cloudDiscoveryMetadata config or check knownAuthorities\n */\n getCloudDiscoveryMetadataFromConfig() {\n // CIAM does not support cloud discovery metadata\n if (this.authorityType === AuthorityType.Ciam) {\n this.logger.verbose(\"CIAM authorities do not support cloud discovery metadata, generate the aliases from authority host.\");\n return Authority.createCloudDiscoveryMetadataFromHost(this.hostnameAndPort);\n }\n // Check if network response was provided in config\n if (this.authorityOptions.cloudDiscoveryMetadata) {\n this.logger.verbose(\"The cloud discovery metadata has been provided as a network response, in the config.\");\n try {\n this.logger.verbose(\"Attempting to parse the cloud discovery metadata.\");\n const parsedResponse = JSON.parse(this.authorityOptions.cloudDiscoveryMetadata);\n const metadata = getCloudDiscoveryMetadataFromNetworkResponse(parsedResponse.metadata, this.hostnameAndPort);\n this.logger.verbose(\"Parsed the cloud discovery metadata.\");\n if (metadata) {\n this.logger.verbose(\"There is returnable metadata attached to the parsed cloud discovery metadata.\");\n return metadata;\n }\n else {\n this.logger.verbose(\"There is no metadata attached to the parsed cloud discovery metadata.\");\n }\n }\n catch (e) {\n this.logger.verbose(\"Unable to parse the cloud discovery metadata. Throwing Invalid Cloud Discovery Metadata Error.\");\n throw createClientConfigurationError(invalidCloudDiscoveryMetadata);\n }\n }\n // If cloudDiscoveryMetadata is empty or does not contain the host, check knownAuthorities\n if (this.isInKnownAuthorities()) {\n this.logger.verbose(\"The host is included in knownAuthorities. Creating new cloud discovery metadata from the host.\");\n return Authority.createCloudDiscoveryMetadataFromHost(this.hostnameAndPort);\n }\n return null;\n }\n /**\n * Called to get metadata from network if CloudDiscoveryMetadata was not populated by config\n *\n * @param hasHardcodedMetadata boolean\n */\n async getCloudDiscoveryMetadataFromNetwork() {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthorityGetCloudDiscoveryMetadataFromNetwork, this.correlationId);\n const instanceDiscoveryEndpoint = `${Constants.AAD_INSTANCE_DISCOVERY_ENDPT}${this.canonicalAuthority}oauth2/v2.0/authorize`;\n const options = {};\n /*\n * TODO: Add a timeout if the authority exists in our library's\n * hardcoded list of metadata\n */\n let match = null;\n try {\n const response = await this.networkInterface.sendGetRequestAsync(instanceDiscoveryEndpoint, options);\n let typedResponseBody;\n let metadata;\n if (isCloudInstanceDiscoveryResponse(response.body)) {\n typedResponseBody =\n response.body;\n metadata = typedResponseBody.metadata;\n this.logger.verbosePii(`tenant_discovery_endpoint is: ${typedResponseBody.tenant_discovery_endpoint}`);\n }\n else if (isCloudInstanceDiscoveryErrorResponse(response.body)) {\n this.logger.warning(`A CloudInstanceDiscoveryErrorResponse was returned. The cloud instance discovery network request's status code is: ${response.status}`);\n typedResponseBody =\n response.body;\n if (typedResponseBody.error === Constants.INVALID_INSTANCE) {\n this.logger.error(\"The CloudInstanceDiscoveryErrorResponse error is invalid_instance.\");\n return null;\n }\n this.logger.warning(`The CloudInstanceDiscoveryErrorResponse error is ${typedResponseBody.error}`);\n this.logger.warning(`The CloudInstanceDiscoveryErrorResponse error description is ${typedResponseBody.error_description}`);\n this.logger.warning(\"Setting the value of the CloudInstanceDiscoveryMetadata (returned from the network) to []\");\n metadata = [];\n }\n else {\n this.logger.error(\"AAD did not return a CloudInstanceDiscoveryResponse or CloudInstanceDiscoveryErrorResponse\");\n return null;\n }\n this.logger.verbose(\"Attempting to find a match between the developer's authority and the CloudInstanceDiscoveryMetadata returned from the network request.\");\n match = getCloudDiscoveryMetadataFromNetworkResponse(metadata, this.hostnameAndPort);\n }\n catch (error) {\n if (error instanceof AuthError) {\n this.logger.error(`There was a network error while attempting to get the cloud discovery instance metadata.\\nError: ${error.errorCode}\\nError Description: ${error.errorMessage}`);\n }\n else {\n const typedError = error;\n this.logger.error(`A non-MSALJS error was thrown while attempting to get the cloud instance discovery metadata.\\nError: ${typedError.name}\\nError Description: ${typedError.message}`);\n }\n return null;\n }\n // Custom Domain scenario, host is trusted because Instance Discovery call succeeded\n if (!match) {\n this.logger.warning(\"The developer's authority was not found within the CloudInstanceDiscoveryMetadata returned from the network request.\");\n this.logger.verbose(\"Creating custom Authority for custom domain scenario.\");\n match = Authority.createCloudDiscoveryMetadataFromHost(this.hostnameAndPort);\n }\n return match;\n }\n /**\n * Helper function to determine if this host is included in the knownAuthorities config option\n */\n isInKnownAuthorities() {\n const matches = this.authorityOptions.knownAuthorities.filter((authority) => {\n return (authority &&\n UrlString.getDomainFromUrl(authority).toLowerCase() ===\n this.hostnameAndPort);\n });\n return matches.length > 0;\n }\n /**\n * helper function to populate the authority based on azureCloudOptions\n * @param authorityString\n * @param azureCloudOptions\n */\n static generateAuthority(authorityString, azureCloudOptions) {\n let authorityAzureCloudInstance;\n if (azureCloudOptions &&\n azureCloudOptions.azureCloudInstance !== AzureCloudInstance.None) {\n const tenant = azureCloudOptions.tenant\n ? azureCloudOptions.tenant\n : Constants.DEFAULT_COMMON_TENANT;\n authorityAzureCloudInstance = `${azureCloudOptions.azureCloudInstance}/${tenant}/`;\n }\n return authorityAzureCloudInstance\n ? authorityAzureCloudInstance\n : authorityString;\n }\n /**\n * Creates cloud discovery metadata object from a given host\n * @param host\n */\n static createCloudDiscoveryMetadataFromHost(host) {\n return {\n preferred_network: host,\n preferred_cache: host,\n aliases: [host],\n };\n }\n /**\n * helper function to generate environment from authority object\n */\n getPreferredCache() {\n if (this.managedIdentity) {\n return Constants.DEFAULT_AUTHORITY_HOST;\n }\n else if (this.discoveryComplete()) {\n return this.metadata.preferred_cache;\n }\n else {\n throw createClientAuthError(endpointResolutionError);\n }\n }\n /**\n * Returns whether or not the provided host is an alias of this authority instance\n * @param host\n */\n isAlias(host) {\n return this.metadata.aliases.indexOf(host) > -1;\n }\n /**\n * Returns whether or not the provided host is an alias of a known Microsoft authority for purposes of endpoint discovery\n * @param host\n */\n isAliasOfKnownMicrosoftAuthority(host) {\n return InstanceDiscoveryMetadataAliases.has(host);\n }\n /**\n * Checks whether the provided host is that of a public cloud authority\n *\n * @param authority string\n * @returns bool\n */\n static isPublicCloudAuthority(host) {\n return Constants.KNOWN_PUBLIC_CLOUDS.indexOf(host) >= 0;\n }\n /**\n * Rebuild the authority string with the region\n *\n * @param host string\n * @param region string\n */\n static buildRegionalAuthorityString(host, region, queryString) {\n // Create and validate a Url string object with the initial authority string\n const authorityUrlInstance = new UrlString(host);\n authorityUrlInstance.validateAsUri();\n const authorityUrlParts = authorityUrlInstance.getUrlComponents();\n let hostNameAndPort = `${region}.${authorityUrlParts.HostNameAndPort}`;\n if (this.isPublicCloudAuthority(authorityUrlParts.HostNameAndPort)) {\n hostNameAndPort = `${region}.${Constants.REGIONAL_AUTH_PUBLIC_CLOUD_SUFFIX}`;\n }\n // Include the query string portion of the url\n const url = UrlString.constructAuthorityUriFromObject({\n ...authorityUrlInstance.getUrlComponents(),\n HostNameAndPort: hostNameAndPort,\n }).urlString;\n // Add the query string if a query string was provided\n if (queryString)\n return `${url}?${queryString}`;\n return url;\n }\n /**\n * Replace the endpoints in the metadata object with their regional equivalents.\n *\n * @param metadata OpenIdConfigResponse\n * @param azureRegion string\n */\n static replaceWithRegionalInformation(metadata, azureRegion) {\n const regionalMetadata = { ...metadata };\n regionalMetadata.authorization_endpoint =\n Authority.buildRegionalAuthorityString(regionalMetadata.authorization_endpoint, azureRegion);\n regionalMetadata.token_endpoint =\n Authority.buildRegionalAuthorityString(regionalMetadata.token_endpoint, azureRegion);\n if (regionalMetadata.end_session_endpoint) {\n regionalMetadata.end_session_endpoint =\n Authority.buildRegionalAuthorityString(regionalMetadata.end_session_endpoint, azureRegion);\n }\n return regionalMetadata;\n }\n /**\n * Transform CIAM_AUTHORIY as per the below rules:\n * If no path segments found and it is a CIAM authority (hostname ends with .ciamlogin.com), then transform it\n *\n * NOTE: The transformation path should go away once STS supports CIAM with the format: `tenantIdorDomain.ciamlogin.com`\n * `ciamlogin.com` can also change in the future and we should accommodate the same\n *\n * @param authority\n */\n static transformCIAMAuthority(authority) {\n let ciamAuthority = authority;\n const authorityUrl = new UrlString(authority);\n const authorityUrlComponents = authorityUrl.getUrlComponents();\n // check if transformation is needed\n if (authorityUrlComponents.PathSegments.length === 0 &&\n authorityUrlComponents.HostNameAndPort.endsWith(Constants.CIAM_AUTH_URL)) {\n const tenantIdOrDomain = authorityUrlComponents.HostNameAndPort.split(\".\")[0];\n ciamAuthority = `${ciamAuthority}${tenantIdOrDomain}${Constants.AAD_TENANT_DOMAIN_SUFFIX}`;\n }\n return ciamAuthority;\n }\n}\n// Reserved tenant domain names that will not be replaced with tenant id\nAuthority.reservedTenantDomains = new Set([\n \"{tenant}\",\n \"{tenantid}\",\n AADAuthorityConstants.COMMON,\n AADAuthorityConstants.CONSUMERS,\n AADAuthorityConstants.ORGANIZATIONS,\n]);\n/**\n * Extract tenantId from authority\n */\nfunction getTenantFromAuthorityString(authority) {\n const authorityUrl = new UrlString(authority);\n const authorityUrlComponents = authorityUrl.getUrlComponents();\n /**\n * For credential matching purposes, tenantId is the last path segment of the authority URL:\n * AAD Authority - domain/tenantId -> Credentials are cached with realm = tenantId\n * B2C Authority - domain/{tenantId}?/.../policy -> Credentials are cached with realm = policy\n * tenantId is downcased because B2C policies can have mixed case but tfp claim is downcased\n *\n * Note that we may not have any path segments in certain OIDC scenarios.\n */\n const tenantId = authorityUrlComponents.PathSegments.slice(-1)[0]?.toLowerCase();\n switch (tenantId) {\n case AADAuthorityConstants.COMMON:\n case AADAuthorityConstants.ORGANIZATIONS:\n case AADAuthorityConstants.CONSUMERS:\n return undefined;\n default:\n return tenantId;\n }\n}\nfunction formatAuthorityUri(authorityUri) {\n return authorityUri.endsWith(Constants.FORWARD_SLASH)\n ? authorityUri\n : `${authorityUri}${Constants.FORWARD_SLASH}`;\n}\nfunction buildStaticAuthorityOptions(authOptions) {\n const rawCloudDiscoveryMetadata = authOptions.cloudDiscoveryMetadata;\n let cloudDiscoveryMetadata = undefined;\n if (rawCloudDiscoveryMetadata) {\n try {\n cloudDiscoveryMetadata = JSON.parse(rawCloudDiscoveryMetadata);\n }\n catch (e) {\n throw createClientConfigurationError(invalidCloudDiscoveryMetadata);\n }\n }\n return {\n canonicalAuthority: authOptions.authority\n ? formatAuthorityUri(authOptions.authority)\n : undefined,\n knownAuthorities: authOptions.knownAuthorities,\n cloudDiscoveryMetadata: cloudDiscoveryMetadata,\n };\n}\n\nexport { Authority, buildStaticAuthorityOptions, formatAuthorityUri, getTenantFromAuthorityString };\n//# sourceMappingURL=Authority.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Authority, formatAuthorityUri } from './Authority.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { invokeAsync } from '../utils/FunctionWrappers.mjs';\nimport { endpointResolutionError } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Create an authority object of the correct type based on the url\n * Performs basic authority validation - checks to see if the authority is of a valid type (i.e. aad, b2c, adfs)\n *\n * Also performs endpoint discovery.\n *\n * @param authorityUri\n * @param networkClient\n * @param protocolMode\n * @internal\n */\nasync function createDiscoveredInstance(authorityUri, networkClient, cacheManager, authorityOptions, logger, correlationId, performanceClient) {\n performanceClient?.addQueueMeasurement(PerformanceEvents.AuthorityFactoryCreateDiscoveredInstance, correlationId);\n const authorityUriFinal = Authority.transformCIAMAuthority(formatAuthorityUri(authorityUri));\n // Initialize authority and perform discovery endpoint check.\n const acquireTokenAuthority = new Authority(authorityUriFinal, networkClient, cacheManager, authorityOptions, logger, correlationId, performanceClient);\n try {\n await invokeAsync(acquireTokenAuthority.resolveEndpointsAsync.bind(acquireTokenAuthority), PerformanceEvents.AuthorityResolveEndpointsAsync, logger, performanceClient, correlationId)();\n return acquireTokenAuthority;\n }\n catch (e) {\n throw createClientAuthError(endpointResolutionError);\n }\n}\n\nexport { createDiscoveredInstance };\n//# sourceMappingURL=AuthorityFactory.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nasync function getClientAssertion(clientAssertion, clientId, tokenEndpoint) {\n if (typeof clientAssertion === \"string\") {\n return clientAssertion;\n }\n else {\n const config = {\n clientId: clientId,\n tokenEndpoint: tokenEndpoint,\n };\n return clientAssertion(config);\n }\n}\n\nexport { getClientAssertion };\n//# sourceMappingURL=ClientAssertionUtils.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst CLIENT_ID = \"client_id\";\nconst REDIRECT_URI = \"redirect_uri\";\nconst RESPONSE_TYPE = \"response_type\";\nconst RESPONSE_MODE = \"response_mode\";\nconst GRANT_TYPE = \"grant_type\";\nconst CLAIMS = \"claims\";\nconst SCOPE = \"scope\";\nconst ERROR = \"error\";\nconst ERROR_DESCRIPTION = \"error_description\";\nconst ACCESS_TOKEN = \"access_token\";\nconst ID_TOKEN = \"id_token\";\nconst REFRESH_TOKEN = \"refresh_token\";\nconst EXPIRES_IN = \"expires_in\";\nconst REFRESH_TOKEN_EXPIRES_IN = \"refresh_token_expires_in\";\nconst STATE = \"state\";\nconst NONCE = \"nonce\";\nconst PROMPT = \"prompt\";\nconst SESSION_STATE = \"session_state\";\nconst CLIENT_INFO = \"client_info\";\nconst CODE = \"code\";\nconst CODE_CHALLENGE = \"code_challenge\";\nconst CODE_CHALLENGE_METHOD = \"code_challenge_method\";\nconst CODE_VERIFIER = \"code_verifier\";\nconst CLIENT_REQUEST_ID = \"client-request-id\";\nconst X_CLIENT_SKU = \"x-client-SKU\";\nconst X_CLIENT_VER = \"x-client-VER\";\nconst X_CLIENT_OS = \"x-client-OS\";\nconst X_CLIENT_CPU = \"x-client-CPU\";\nconst X_CLIENT_CURR_TELEM = \"x-client-current-telemetry\";\nconst X_CLIENT_LAST_TELEM = \"x-client-last-telemetry\";\nconst X_MS_LIB_CAPABILITY = \"x-ms-lib-capability\";\nconst X_APP_NAME = \"x-app-name\";\nconst X_APP_VER = \"x-app-ver\";\nconst POST_LOGOUT_URI = \"post_logout_redirect_uri\";\nconst ID_TOKEN_HINT = \"id_token_hint\";\nconst DEVICE_CODE = \"device_code\";\nconst CLIENT_SECRET = \"client_secret\";\nconst CLIENT_ASSERTION = \"client_assertion\";\nconst CLIENT_ASSERTION_TYPE = \"client_assertion_type\";\nconst TOKEN_TYPE = \"token_type\";\nconst REQ_CNF = \"req_cnf\";\nconst OBO_ASSERTION = \"assertion\";\nconst REQUESTED_TOKEN_USE = \"requested_token_use\";\nconst ON_BEHALF_OF = \"on_behalf_of\";\nconst FOCI = \"foci\";\nconst CCS_HEADER = \"X-AnchorMailbox\";\nconst RETURN_SPA_CODE = \"return_spa_code\";\nconst NATIVE_BROKER = \"nativebroker\";\nconst LOGOUT_HINT = \"logout_hint\";\nconst SID = \"sid\";\nconst LOGIN_HINT = \"login_hint\";\nconst DOMAIN_HINT = \"domain_hint\";\n\nexport { ACCESS_TOKEN, CCS_HEADER, CLAIMS, CLIENT_ASSERTION, CLIENT_ASSERTION_TYPE, CLIENT_ID, CLIENT_INFO, CLIENT_REQUEST_ID, CLIENT_SECRET, CODE, CODE_CHALLENGE, CODE_CHALLENGE_METHOD, CODE_VERIFIER, DEVICE_CODE, DOMAIN_HINT, ERROR, ERROR_DESCRIPTION, EXPIRES_IN, FOCI, GRANT_TYPE, ID_TOKEN, ID_TOKEN_HINT, LOGIN_HINT, LOGOUT_HINT, NATIVE_BROKER, NONCE, OBO_ASSERTION, ON_BEHALF_OF, POST_LOGOUT_URI, PROMPT, REDIRECT_URI, REFRESH_TOKEN, REFRESH_TOKEN_EXPIRES_IN, REQUESTED_TOKEN_USE, REQ_CNF, RESPONSE_MODE, RESPONSE_TYPE, RETURN_SPA_CODE, SCOPE, SESSION_STATE, SID, STATE, TOKEN_TYPE, X_APP_NAME, X_APP_VER, X_CLIENT_CPU, X_CLIENT_CURR_TELEM, X_CLIENT_LAST_TELEM, X_CLIENT_OS, X_CLIENT_SKU, X_CLIENT_VER, X_MS_LIB_CAPABILITY };\n//# sourceMappingURL=AADServerParamKeys.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { methodNotImplemented } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst DEFAULT_CRYPTO_IMPLEMENTATION = {\n createNewGuid: () => {\n throw createClientAuthError(methodNotImplemented);\n },\n base64Decode: () => {\n throw createClientAuthError(methodNotImplemented);\n },\n base64Encode: () => {\n throw createClientAuthError(methodNotImplemented);\n },\n base64UrlEncode: () => {\n throw createClientAuthError(methodNotImplemented);\n },\n encodeKid: () => {\n throw createClientAuthError(methodNotImplemented);\n },\n async getPublicKeyThumbprint() {\n throw createClientAuthError(methodNotImplemented);\n },\n async removeTokenBindingKey() {\n throw createClientAuthError(methodNotImplemented);\n },\n async clearKeystore() {\n throw createClientAuthError(methodNotImplemented);\n },\n async signJwt() {\n throw createClientAuthError(methodNotImplemented);\n },\n async hashString() {\n throw createClientAuthError(methodNotImplemented);\n },\n};\n\nexport { DEFAULT_CRYPTO_IMPLEMENTATION };\n//# sourceMappingURL=ICrypto.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/* eslint-disable header/header */\nconst name = \"@azure/msal-common\";\nconst version = \"14.13.1\";\n\nexport { name, version };\n//# sourceMappingURL=packageMetadata.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientConfigurationError } from '../error/ClientConfigurationError.mjs';\nimport { StringUtils } from '../utils/StringUtils.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { Constants, OIDC_SCOPES } from '../utils/Constants.mjs';\nimport { emptyInputScopesError } from '../error/ClientConfigurationErrorCodes.mjs';\nimport { cannotAppendScopeSet, cannotRemoveEmptyScope, emptyInputScopeSet } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * The ScopeSet class creates a set of scopes. Scopes are case-insensitive, unique values, so the Set object in JS makes\n * the most sense to implement for this class. All scopes are trimmed and converted to lower case strings in intersection and union functions\n * to ensure uniqueness of strings.\n */\nclass ScopeSet {\n constructor(inputScopes) {\n // Filter empty string and null/undefined array items\n const scopeArr = inputScopes\n ? StringUtils.trimArrayEntries([...inputScopes])\n : [];\n const filteredInput = scopeArr\n ? StringUtils.removeEmptyStringsFromArray(scopeArr)\n : [];\n // Validate and filter scopes (validate function throws if validation fails)\n this.validateInputScopes(filteredInput);\n this.scopes = new Set(); // Iterator in constructor not supported by IE11\n filteredInput.forEach((scope) => this.scopes.add(scope));\n }\n /**\n * Factory method to create ScopeSet from space-delimited string\n * @param inputScopeString\n * @param appClientId\n * @param scopesRequired\n */\n static fromString(inputScopeString) {\n const scopeString = inputScopeString || Constants.EMPTY_STRING;\n const inputScopes = scopeString.split(\" \");\n return new ScopeSet(inputScopes);\n }\n /**\n * Creates the set of scopes to search for in cache lookups\n * @param inputScopeString\n * @returns\n */\n static createSearchScopes(inputScopeString) {\n const scopeSet = new ScopeSet(inputScopeString);\n if (!scopeSet.containsOnlyOIDCScopes()) {\n scopeSet.removeOIDCScopes();\n }\n else {\n scopeSet.removeScope(Constants.OFFLINE_ACCESS_SCOPE);\n }\n return scopeSet;\n }\n /**\n * Used to validate the scopes input parameter requested by the developer.\n * @param {Array} inputScopes - Developer requested permissions. Not all scopes are guaranteed to be included in the access token returned.\n * @param {boolean} scopesRequired - Boolean indicating whether the scopes array is required or not\n */\n validateInputScopes(inputScopes) {\n // Check if scopes are required but not given or is an empty array\n if (!inputScopes || inputScopes.length < 1) {\n throw createClientConfigurationError(emptyInputScopesError);\n }\n }\n /**\n * Check if a given scope is present in this set of scopes.\n * @param scope\n */\n containsScope(scope) {\n const lowerCaseScopes = this.printScopesLowerCase().split(\" \");\n const lowerCaseScopesSet = new ScopeSet(lowerCaseScopes);\n // compare lowercase scopes\n return scope\n ? lowerCaseScopesSet.scopes.has(scope.toLowerCase())\n : false;\n }\n /**\n * Check if a set of scopes is present in this set of scopes.\n * @param scopeSet\n */\n containsScopeSet(scopeSet) {\n if (!scopeSet || scopeSet.scopes.size <= 0) {\n return false;\n }\n return (this.scopes.size >= scopeSet.scopes.size &&\n scopeSet.asArray().every((scope) => this.containsScope(scope)));\n }\n /**\n * Check if set of scopes contains only the defaults\n */\n containsOnlyOIDCScopes() {\n let defaultScopeCount = 0;\n OIDC_SCOPES.forEach((defaultScope) => {\n if (this.containsScope(defaultScope)) {\n defaultScopeCount += 1;\n }\n });\n return this.scopes.size === defaultScopeCount;\n }\n /**\n * Appends single scope if passed\n * @param newScope\n */\n appendScope(newScope) {\n if (newScope) {\n this.scopes.add(newScope.trim());\n }\n }\n /**\n * Appends multiple scopes if passed\n * @param newScopes\n */\n appendScopes(newScopes) {\n try {\n newScopes.forEach((newScope) => this.appendScope(newScope));\n }\n catch (e) {\n throw createClientAuthError(cannotAppendScopeSet);\n }\n }\n /**\n * Removes element from set of scopes.\n * @param scope\n */\n removeScope(scope) {\n if (!scope) {\n throw createClientAuthError(cannotRemoveEmptyScope);\n }\n this.scopes.delete(scope.trim());\n }\n /**\n * Removes default scopes from set of scopes\n * Primarily used to prevent cache misses if the default scopes are not returned from the server\n */\n removeOIDCScopes() {\n OIDC_SCOPES.forEach((defaultScope) => {\n this.scopes.delete(defaultScope);\n });\n }\n /**\n * Combines an array of scopes with the current set of scopes.\n * @param otherScopes\n */\n unionScopeSets(otherScopes) {\n if (!otherScopes) {\n throw createClientAuthError(emptyInputScopeSet);\n }\n const unionScopes = new Set(); // Iterator in constructor not supported in IE11\n otherScopes.scopes.forEach((scope) => unionScopes.add(scope.toLowerCase()));\n this.scopes.forEach((scope) => unionScopes.add(scope.toLowerCase()));\n return unionScopes;\n }\n /**\n * Check if scopes intersect between this set and another.\n * @param otherScopes\n */\n intersectingScopeSets(otherScopes) {\n if (!otherScopes) {\n throw createClientAuthError(emptyInputScopeSet);\n }\n // Do not allow OIDC scopes to be the only intersecting scopes\n if (!otherScopes.containsOnlyOIDCScopes()) {\n otherScopes.removeOIDCScopes();\n }\n const unionScopes = this.unionScopeSets(otherScopes);\n const sizeOtherScopes = otherScopes.getScopeCount();\n const sizeThisScopes = this.getScopeCount();\n const sizeUnionScopes = unionScopes.size;\n return sizeUnionScopes < sizeThisScopes + sizeOtherScopes;\n }\n /**\n * Returns size of set of scopes.\n */\n getScopeCount() {\n return this.scopes.size;\n }\n /**\n * Returns the scopes as an array of string values\n */\n asArray() {\n const array = [];\n this.scopes.forEach((val) => array.push(val));\n return array;\n }\n /**\n * Prints scopes into a space-delimited string\n */\n printScopes() {\n if (this.scopes) {\n const scopeArr = this.asArray();\n return scopeArr.join(\" \");\n }\n return Constants.EMPTY_STRING;\n }\n /**\n * Prints scopes into a space-delimited lower-case string (used for caching)\n */\n printScopesLowerCase() {\n return this.printScopes().toLowerCase();\n }\n}\n\nexport { ScopeSet };\n//# sourceMappingURL=ScopeSet.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { Separators, Constants } from '../utils/Constants.mjs';\nimport { clientInfoEmptyError, clientInfoDecodingError } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Function to build a client info object from server clientInfo string\n * @param rawClientInfo\n * @param crypto\n */\nfunction buildClientInfo(rawClientInfo, base64Decode) {\n if (!rawClientInfo) {\n throw createClientAuthError(clientInfoEmptyError);\n }\n try {\n const decodedClientInfo = base64Decode(rawClientInfo);\n return JSON.parse(decodedClientInfo);\n }\n catch (e) {\n throw createClientAuthError(clientInfoDecodingError);\n }\n}\n/**\n * Function to build a client info object from cached homeAccountId string\n * @param homeAccountId\n */\nfunction buildClientInfoFromHomeAccountId(homeAccountId) {\n if (!homeAccountId) {\n throw createClientAuthError(clientInfoDecodingError);\n }\n const clientInfoParts = homeAccountId.split(Separators.CLIENT_INFO_SEPARATOR, 2);\n return {\n uid: clientInfoParts[0],\n utid: clientInfoParts.length < 2\n ? Constants.EMPTY_STRING\n : clientInfoParts[1],\n };\n}\n\nexport { buildClientInfo, buildClientInfoFromHomeAccountId };\n//# sourceMappingURL=ClientInfo.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Returns true if tenantId matches the utid portion of homeAccountId\n * @param tenantId\n * @param homeAccountId\n * @returns\n */\nfunction tenantIdMatchesHomeTenant(tenantId, homeAccountId) {\n return (!!tenantId &&\n !!homeAccountId &&\n tenantId === homeAccountId.split(\".\")[1]);\n}\n/**\n * Build tenant profile\n * @param homeAccountId - Home account identifier for this account object\n * @param localAccountId - Local account identifer for this account object\n * @param tenantId - Full tenant or organizational id that this account belongs to\n * @param idTokenClaims - Claims from the ID token\n * @returns\n */\nfunction buildTenantProfile(homeAccountId, localAccountId, tenantId, idTokenClaims) {\n if (idTokenClaims) {\n const { oid, sub, tid, name, tfp, acr } = idTokenClaims;\n /**\n * Since there is no way to determine if the authority is AAD or B2C, we exhaust all the possible claims that can serve as tenant ID with the following precedence:\n * tid - TenantID claim that identifies the tenant that issued the token in AAD. Expected in all AAD ID tokens, not present in B2C ID Tokens.\n * tfp - Trust Framework Policy claim that identifies the policy that was used to authenticate the user. Functions as tenant for B2C scenarios.\n * acr - Authentication Context Class Reference claim used only with older B2C policies. Fallback in case tfp is not present, but likely won't be present anyway.\n */\n const tenantId = tid || tfp || acr || \"\";\n return {\n tenantId: tenantId,\n localAccountId: oid || sub || \"\",\n name: name,\n isHomeTenant: tenantIdMatchesHomeTenant(tenantId, homeAccountId),\n };\n }\n else {\n return {\n tenantId,\n localAccountId,\n isHomeTenant: tenantIdMatchesHomeTenant(tenantId, homeAccountId),\n };\n }\n}\n/**\n * Replaces account info that varies by tenant profile sourced from the ID token claims passed in with the tenant-specific account info\n * @param baseAccountInfo\n * @param idTokenClaims\n * @returns\n */\nfunction updateAccountTenantProfileData(baseAccountInfo, tenantProfile, idTokenClaims, idTokenSecret) {\n let updatedAccountInfo = baseAccountInfo;\n // Tenant Profile overrides passed in account info\n if (tenantProfile) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { isHomeTenant, ...tenantProfileOverride } = tenantProfile;\n updatedAccountInfo = { ...baseAccountInfo, ...tenantProfileOverride };\n }\n // ID token claims override passed in account info and tenant profile\n if (idTokenClaims) {\n // Ignore isHomeTenant, loginHint, and sid which are part of tenant profile but not base account info\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { isHomeTenant, ...claimsSourcedTenantProfile } = buildTenantProfile(baseAccountInfo.homeAccountId, baseAccountInfo.localAccountId, baseAccountInfo.tenantId, idTokenClaims);\n updatedAccountInfo = {\n ...updatedAccountInfo,\n ...claimsSourcedTenantProfile,\n idTokenClaims: idTokenClaims,\n idToken: idTokenSecret,\n };\n return updatedAccountInfo;\n }\n return updatedAccountInfo;\n}\n\nexport { buildTenantProfile, tenantIdMatchesHomeTenant, updateAccountTenantProfileData };\n//# sourceMappingURL=AccountInfo.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Gets tenantId from available ID token claims to set as credential realm with the following precedence:\n * 1. tid - if the token is acquired from an Azure AD tenant tid will be present\n * 2. tfp - if the token is acquired from a modern B2C tenant tfp should be present\n * 3. acr - if the token is acquired from a legacy B2C tenant acr should be present\n * Downcased to match the realm case-insensitive comparison requirements\n * @param idTokenClaims\n * @returns\n */\nfunction getTenantIdFromIdTokenClaims(idTokenClaims) {\n if (idTokenClaims) {\n const tenantId = idTokenClaims.tid || idTokenClaims.tfp || idTokenClaims.acr;\n return tenantId || null;\n }\n return null;\n}\n\nexport { getTenantIdFromIdTokenClaims };\n//# sourceMappingURL=TokenClaims.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Separators, CacheAccountType } from '../../utils/Constants.mjs';\nimport { buildClientInfo } from '../../account/ClientInfo.mjs';\nimport { buildTenantProfile } from '../../account/AccountInfo.mjs';\nimport { createClientAuthError } from '../../error/ClientAuthError.mjs';\nimport { AuthorityType } from '../../authority/AuthorityType.mjs';\nimport { getTenantIdFromIdTokenClaims } from '../../account/TokenClaims.mjs';\nimport { ProtocolMode } from '../../authority/ProtocolMode.mjs';\nimport { invalidCacheEnvironment } from '../../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Type that defines required and optional parameters for an Account field (based on universal cache schema implemented by all MSALs).\n *\n * Key : Value Schema\n *\n * Key: --\n *\n * Value Schema:\n * {\n * homeAccountId: home account identifier for the auth scheme,\n * environment: entity that issued the token, represented as a full host\n * realm: Full tenant or organizational identifier that the account belongs to\n * localAccountId: Original tenant-specific accountID, usually used for legacy cases\n * username: primary username that represents the user, usually corresponds to preferred_username in the v2 endpt\n * authorityType: Accounts authority type as a string\n * name: Full name for the account, including given name and family name,\n * lastModificationTime: last time this entity was modified in the cache\n * lastModificationApp:\n * nativeAccountId: Account identifier on the native device\n * tenantProfiles: Array of tenant profile objects for each tenant that the account has authenticated with in the browser\n * }\n * @internal\n */\nclass AccountEntity {\n /**\n * Generate Account Id key component as per the schema: -\n */\n generateAccountId() {\n const accountId = [this.homeAccountId, this.environment];\n return accountId.join(Separators.CACHE_KEY_SEPARATOR).toLowerCase();\n }\n /**\n * Generate Account Cache Key as per the schema: --\n */\n generateAccountKey() {\n return AccountEntity.generateAccountCacheKey({\n homeAccountId: this.homeAccountId,\n environment: this.environment,\n tenantId: this.realm,\n username: this.username,\n localAccountId: this.localAccountId,\n });\n }\n /**\n * Returns the AccountInfo interface for this account.\n */\n getAccountInfo() {\n return {\n homeAccountId: this.homeAccountId,\n environment: this.environment,\n tenantId: this.realm,\n username: this.username,\n localAccountId: this.localAccountId,\n name: this.name,\n nativeAccountId: this.nativeAccountId,\n authorityType: this.authorityType,\n // Deserialize tenant profiles array into a Map\n tenantProfiles: new Map((this.tenantProfiles || []).map((tenantProfile) => {\n return [tenantProfile.tenantId, tenantProfile];\n })),\n };\n }\n /**\n * Returns true if the account entity is in single tenant format (outdated), false otherwise\n */\n isSingleTenant() {\n return !this.tenantProfiles;\n }\n /**\n * Generates account key from interface\n * @param accountInterface\n */\n static generateAccountCacheKey(accountInterface) {\n const homeTenantId = accountInterface.homeAccountId.split(\".\")[1];\n const accountKey = [\n accountInterface.homeAccountId,\n accountInterface.environment || \"\",\n homeTenantId || accountInterface.tenantId || \"\",\n ];\n return accountKey.join(Separators.CACHE_KEY_SEPARATOR).toLowerCase();\n }\n /**\n * Build Account cache from IdToken, clientInfo and authority/policy. Associated with AAD.\n * @param accountDetails\n */\n static createAccount(accountDetails, authority, base64Decode) {\n const account = new AccountEntity();\n if (authority.authorityType === AuthorityType.Adfs) {\n account.authorityType = CacheAccountType.ADFS_ACCOUNT_TYPE;\n }\n else if (authority.protocolMode === ProtocolMode.AAD) {\n account.authorityType = CacheAccountType.MSSTS_ACCOUNT_TYPE;\n }\n else {\n account.authorityType = CacheAccountType.GENERIC_ACCOUNT_TYPE;\n }\n let clientInfo;\n if (accountDetails.clientInfo && base64Decode) {\n clientInfo = buildClientInfo(accountDetails.clientInfo, base64Decode);\n }\n account.clientInfo = accountDetails.clientInfo;\n account.homeAccountId = accountDetails.homeAccountId;\n account.nativeAccountId = accountDetails.nativeAccountId;\n const env = accountDetails.environment ||\n (authority && authority.getPreferredCache());\n if (!env) {\n throw createClientAuthError(invalidCacheEnvironment);\n }\n account.environment = env;\n // non AAD scenarios can have empty realm\n account.realm =\n clientInfo?.utid ||\n getTenantIdFromIdTokenClaims(accountDetails.idTokenClaims) ||\n \"\";\n // How do you account for MSA CID here?\n account.localAccountId =\n clientInfo?.uid ||\n accountDetails.idTokenClaims?.oid ||\n accountDetails.idTokenClaims?.sub ||\n \"\";\n /*\n * In B2C scenarios the emails claim is used instead of preferred_username and it is an array.\n * In most cases it will contain a single email. This field should not be relied upon if a custom\n * policy is configured to return more than 1 email.\n */\n const preferredUsername = accountDetails.idTokenClaims?.preferred_username ||\n accountDetails.idTokenClaims?.upn;\n const email = accountDetails.idTokenClaims?.emails\n ? accountDetails.idTokenClaims.emails[0]\n : null;\n account.username = preferredUsername || email || \"\";\n account.name = accountDetails.idTokenClaims?.name || \"\";\n account.cloudGraphHostName = accountDetails.cloudGraphHostName;\n account.msGraphHost = accountDetails.msGraphHost;\n if (accountDetails.tenantProfiles) {\n account.tenantProfiles = accountDetails.tenantProfiles;\n }\n else {\n const tenantProfile = buildTenantProfile(accountDetails.homeAccountId, account.localAccountId, account.realm, accountDetails.idTokenClaims);\n account.tenantProfiles = [tenantProfile];\n }\n return account;\n }\n /**\n * Creates an AccountEntity object from AccountInfo\n * @param accountInfo\n * @param cloudGraphHostName\n * @param msGraphHost\n * @returns\n */\n static createFromAccountInfo(accountInfo, cloudGraphHostName, msGraphHost) {\n const account = new AccountEntity();\n account.authorityType =\n accountInfo.authorityType || CacheAccountType.GENERIC_ACCOUNT_TYPE;\n account.homeAccountId = accountInfo.homeAccountId;\n account.localAccountId = accountInfo.localAccountId;\n account.nativeAccountId = accountInfo.nativeAccountId;\n account.realm = accountInfo.tenantId;\n account.environment = accountInfo.environment;\n account.username = accountInfo.username;\n account.name = accountInfo.name;\n account.cloudGraphHostName = cloudGraphHostName;\n account.msGraphHost = msGraphHost;\n // Serialize tenant profiles map into an array\n account.tenantProfiles = Array.from(accountInfo.tenantProfiles?.values() || []);\n return account;\n }\n /**\n * Generate HomeAccountId from server response\n * @param serverClientInfo\n * @param authType\n */\n static generateHomeAccountId(serverClientInfo, authType, logger, cryptoObj, idTokenClaims) {\n // since ADFS/DSTS do not have tid and does not set client_info\n if (!(authType === AuthorityType.Adfs ||\n authType === AuthorityType.Dsts)) {\n // for cases where there is clientInfo\n if (serverClientInfo) {\n try {\n const clientInfo = buildClientInfo(serverClientInfo, cryptoObj.base64Decode);\n if (clientInfo.uid && clientInfo.utid) {\n return `${clientInfo.uid}.${clientInfo.utid}`;\n }\n }\n catch (e) { }\n }\n logger.warning(\"No client info in response\");\n }\n // default to \"sub\" claim\n return idTokenClaims?.sub || \"\";\n }\n /**\n * Validates an entity: checks for all expected params\n * @param entity\n */\n static isAccountEntity(entity) {\n if (!entity) {\n return false;\n }\n return (entity.hasOwnProperty(\"homeAccountId\") &&\n entity.hasOwnProperty(\"environment\") &&\n entity.hasOwnProperty(\"realm\") &&\n entity.hasOwnProperty(\"localAccountId\") &&\n entity.hasOwnProperty(\"username\") &&\n entity.hasOwnProperty(\"authorityType\"));\n }\n /**\n * Helper function to determine whether 2 accountInfo objects represent the same account\n * @param accountA\n * @param accountB\n * @param compareClaims - If set to true idTokenClaims will also be compared to determine account equality\n */\n static accountInfoIsEqual(accountA, accountB, compareClaims) {\n if (!accountA || !accountB) {\n return false;\n }\n let claimsMatch = true; // default to true so as to not fail comparison below if compareClaims: false\n if (compareClaims) {\n const accountAClaims = (accountA.idTokenClaims ||\n {});\n const accountBClaims = (accountB.idTokenClaims ||\n {});\n // issued at timestamp and nonce are expected to change each time a new id token is acquired\n claimsMatch =\n accountAClaims.iat === accountBClaims.iat &&\n accountAClaims.nonce === accountBClaims.nonce;\n }\n return (accountA.homeAccountId === accountB.homeAccountId &&\n accountA.localAccountId === accountB.localAccountId &&\n accountA.username === accountB.username &&\n accountA.tenantId === accountB.tenantId &&\n accountA.environment === accountB.environment &&\n accountA.nativeAccountId === accountB.nativeAccountId &&\n claimsMatch);\n }\n}\n\nexport { AccountEntity };\n//# sourceMappingURL=AccountEntity.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst cacheQuotaExceededErrorCode = \"cache_quota_exceeded\";\nconst cacheUnknownErrorCode = \"cache_error_unknown\";\n\nexport { cacheQuotaExceededErrorCode, cacheUnknownErrorCode };\n//# sourceMappingURL=CacheErrorCodes.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { cacheUnknownErrorCode, cacheQuotaExceededErrorCode } from './CacheErrorCodes.mjs';\nimport * as CacheErrorCodes from './CacheErrorCodes.mjs';\nexport { CacheErrorCodes };\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst CacheErrorMessages = {\n [cacheQuotaExceededErrorCode]: \"Exceeded cache storage capacity.\",\n [cacheUnknownErrorCode]: \"Unexpected error occurred when using cache storage.\",\n};\n/**\n * Error thrown when there is an error with the cache\n */\nclass CacheError extends Error {\n constructor(errorCode, errorMessage) {\n const message = errorMessage ||\n (CacheErrorMessages[errorCode]\n ? CacheErrorMessages[errorCode]\n : CacheErrorMessages[cacheUnknownErrorCode]);\n super(`${errorCode}: ${message}`);\n Object.setPrototypeOf(this, CacheError.prototype);\n this.name = \"CacheError\";\n this.errorCode = errorCode;\n this.errorMessage = message;\n }\n}\n\nexport { CacheError, CacheErrorMessages };\n//# sourceMappingURL=CacheError.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Separators, CredentialType, AuthenticationScheme, THE_FAMILY_ID, APP_METADATA, AUTHORITY_METADATA_CONSTANTS } from '../utils/Constants.mjs';\nimport { generateCredentialKey } from './utils/CacheHelpers.mjs';\nimport { ScopeSet } from '../request/ScopeSet.mjs';\nimport { AccountEntity } from './entities/AccountEntity.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { updateAccountTenantProfileData, tenantIdMatchesHomeTenant } from '../account/AccountInfo.mjs';\nimport { extractTokenClaims } from '../account/AuthToken.mjs';\nimport { name, version } from '../packageMetadata.mjs';\nimport { getAliasesFromStaticSources } from '../authority/AuthorityMetadata.mjs';\nimport { CacheError } from '../error/CacheError.mjs';\nimport { invalidCacheRecord, bindingKeyNotRemoved, multipleMatchingAppMetadata, methodNotImplemented } from '../error/ClientAuthErrorCodes.mjs';\nimport { cacheQuotaExceededErrorCode, cacheUnknownErrorCode } from '../error/CacheErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Interface class which implement cache storage functions used by MSAL to perform validity checks, and store tokens.\n * @internal\n */\nclass CacheManager {\n constructor(clientId, cryptoImpl, logger, staticAuthorityOptions) {\n this.clientId = clientId;\n this.cryptoImpl = cryptoImpl;\n this.commonLogger = logger.clone(name, version);\n this.staticAuthorityOptions = staticAuthorityOptions;\n }\n /**\n * Returns all the accounts in the cache that match the optional filter. If no filter is provided, all accounts are returned.\n * @param accountFilter - (Optional) filter to narrow down the accounts returned\n * @returns Array of AccountInfo objects in cache\n */\n getAllAccounts(accountFilter) {\n return this.buildTenantProfiles(this.getAccountsFilteredBy(accountFilter || {}), accountFilter);\n }\n /**\n * Gets first tenanted AccountInfo object found based on provided filters\n */\n getAccountInfoFilteredBy(accountFilter) {\n const allAccounts = this.getAllAccounts(accountFilter);\n if (allAccounts.length > 1) {\n // If one or more accounts are found, prioritize accounts that have an ID token\n const sortedAccounts = allAccounts.sort((account) => {\n return account.idTokenClaims ? -1 : 1;\n });\n return sortedAccounts[0];\n }\n else if (allAccounts.length === 1) {\n // If only one account is found, return it regardless of whether a matching ID token was found\n return allAccounts[0];\n }\n else {\n return null;\n }\n }\n /**\n * Returns a single matching\n * @param accountFilter\n * @returns\n */\n getBaseAccountInfo(accountFilter) {\n const accountEntities = this.getAccountsFilteredBy(accountFilter);\n if (accountEntities.length > 0) {\n return accountEntities[0].getAccountInfo();\n }\n else {\n return null;\n }\n }\n /**\n * Matches filtered account entities with cached ID tokens that match the tenant profile-specific account filters\n * and builds the account info objects from the matching ID token's claims\n * @param cachedAccounts\n * @param accountFilter\n * @returns Array of AccountInfo objects that match account and tenant profile filters\n */\n buildTenantProfiles(cachedAccounts, accountFilter) {\n return cachedAccounts.flatMap((accountEntity) => {\n return this.getTenantProfilesFromAccountEntity(accountEntity, accountFilter?.tenantId, accountFilter);\n });\n }\n getTenantedAccountInfoByFilter(accountInfo, tokenKeys, tenantProfile, tenantProfileFilter) {\n let tenantedAccountInfo = null;\n let idTokenClaims;\n if (tenantProfileFilter) {\n if (!this.tenantProfileMatchesFilter(tenantProfile, tenantProfileFilter)) {\n return null;\n }\n }\n const idToken = this.getIdToken(accountInfo, tokenKeys, tenantProfile.tenantId);\n if (idToken) {\n idTokenClaims = extractTokenClaims(idToken.secret, this.cryptoImpl.base64Decode);\n if (!this.idTokenClaimsMatchTenantProfileFilter(idTokenClaims, tenantProfileFilter)) {\n // ID token sourced claims don't match so this tenant profile is not a match\n return null;\n }\n }\n // Expand tenant profile into account info based on matching tenant profile and if available matching ID token claims\n tenantedAccountInfo = updateAccountTenantProfileData(accountInfo, tenantProfile, idTokenClaims, idToken?.secret);\n return tenantedAccountInfo;\n }\n getTenantProfilesFromAccountEntity(accountEntity, targetTenantId, tenantProfileFilter) {\n const accountInfo = accountEntity.getAccountInfo();\n let searchTenantProfiles = accountInfo.tenantProfiles || new Map();\n const tokenKeys = this.getTokenKeys();\n // If a tenant ID was provided, only return the tenant profile for that tenant ID if it exists\n if (targetTenantId) {\n const tenantProfile = searchTenantProfiles.get(targetTenantId);\n if (tenantProfile) {\n // Reduce search field to just this tenant profile\n searchTenantProfiles = new Map([\n [targetTenantId, tenantProfile],\n ]);\n }\n else {\n // No tenant profile for search tenant ID, return empty array\n return [];\n }\n }\n const matchingTenantProfiles = [];\n searchTenantProfiles.forEach((tenantProfile) => {\n const tenantedAccountInfo = this.getTenantedAccountInfoByFilter(accountInfo, tokenKeys, tenantProfile, tenantProfileFilter);\n if (tenantedAccountInfo) {\n matchingTenantProfiles.push(tenantedAccountInfo);\n }\n });\n return matchingTenantProfiles;\n }\n tenantProfileMatchesFilter(tenantProfile, tenantProfileFilter) {\n if (!!tenantProfileFilter.localAccountId &&\n !this.matchLocalAccountIdFromTenantProfile(tenantProfile, tenantProfileFilter.localAccountId)) {\n return false;\n }\n if (!!tenantProfileFilter.name &&\n !(tenantProfile.name === tenantProfileFilter.name)) {\n return false;\n }\n if (tenantProfileFilter.isHomeTenant !== undefined &&\n !(tenantProfile.isHomeTenant === tenantProfileFilter.isHomeTenant)) {\n return false;\n }\n return true;\n }\n idTokenClaimsMatchTenantProfileFilter(idTokenClaims, tenantProfileFilter) {\n // Tenant Profile filtering\n if (tenantProfileFilter) {\n if (!!tenantProfileFilter.localAccountId &&\n !this.matchLocalAccountIdFromTokenClaims(idTokenClaims, tenantProfileFilter.localAccountId)) {\n return false;\n }\n if (!!tenantProfileFilter.loginHint &&\n !this.matchLoginHintFromTokenClaims(idTokenClaims, tenantProfileFilter.loginHint)) {\n return false;\n }\n if (!!tenantProfileFilter.username &&\n !this.matchUsername(idTokenClaims.preferred_username, tenantProfileFilter.username)) {\n return false;\n }\n if (!!tenantProfileFilter.name &&\n !this.matchName(idTokenClaims, tenantProfileFilter.name)) {\n return false;\n }\n if (!!tenantProfileFilter.sid &&\n !this.matchSid(idTokenClaims, tenantProfileFilter.sid)) {\n return false;\n }\n }\n return true;\n }\n /**\n * saves a cache record\n * @param cacheRecord {CacheRecord}\n * @param storeInCache {?StoreInCache}\n * @param correlationId {?string} correlation id\n */\n async saveCacheRecord(cacheRecord, storeInCache, correlationId) {\n if (!cacheRecord) {\n throw createClientAuthError(invalidCacheRecord);\n }\n try {\n if (!!cacheRecord.account) {\n this.setAccount(cacheRecord.account);\n }\n if (!!cacheRecord.idToken && storeInCache?.idToken !== false) {\n this.setIdTokenCredential(cacheRecord.idToken);\n }\n if (!!cacheRecord.accessToken &&\n storeInCache?.accessToken !== false) {\n await this.saveAccessToken(cacheRecord.accessToken);\n }\n if (!!cacheRecord.refreshToken &&\n storeInCache?.refreshToken !== false) {\n this.setRefreshTokenCredential(cacheRecord.refreshToken);\n }\n if (!!cacheRecord.appMetadata) {\n this.setAppMetadata(cacheRecord.appMetadata);\n }\n }\n catch (e) {\n this.commonLogger?.error(`CacheManager.saveCacheRecord: failed`);\n if (e instanceof Error) {\n this.commonLogger?.errorPii(`CacheManager.saveCacheRecord: ${e.message}`, correlationId);\n if (e.name === \"QuotaExceededError\" ||\n e.name === \"NS_ERROR_DOM_QUOTA_REACHED\" ||\n e.message.includes(\"exceeded the quota\")) {\n this.commonLogger?.error(`CacheManager.saveCacheRecord: exceeded storage quota`, correlationId);\n throw new CacheError(cacheQuotaExceededErrorCode);\n }\n else {\n throw new CacheError(e.name, e.message);\n }\n }\n else {\n this.commonLogger?.errorPii(`CacheManager.saveCacheRecord: ${e}`, correlationId);\n throw new CacheError(cacheUnknownErrorCode);\n }\n }\n }\n /**\n * saves access token credential\n * @param credential\n */\n async saveAccessToken(credential) {\n const accessTokenFilter = {\n clientId: credential.clientId,\n credentialType: credential.credentialType,\n environment: credential.environment,\n homeAccountId: credential.homeAccountId,\n realm: credential.realm,\n tokenType: credential.tokenType,\n requestedClaimsHash: credential.requestedClaimsHash,\n };\n const tokenKeys = this.getTokenKeys();\n const currentScopes = ScopeSet.fromString(credential.target);\n const removedAccessTokens = [];\n tokenKeys.accessToken.forEach((key) => {\n if (!this.accessTokenKeyMatchesFilter(key, accessTokenFilter, false)) {\n return;\n }\n const tokenEntity = this.getAccessTokenCredential(key);\n if (tokenEntity &&\n this.credentialMatchesFilter(tokenEntity, accessTokenFilter)) {\n const tokenScopeSet = ScopeSet.fromString(tokenEntity.target);\n if (tokenScopeSet.intersectingScopeSets(currentScopes)) {\n removedAccessTokens.push(this.removeAccessToken(key));\n }\n }\n });\n await Promise.all(removedAccessTokens);\n this.setAccessTokenCredential(credential);\n }\n /**\n * Retrieve account entities matching all provided tenant-agnostic filters; if no filter is set, get all account entities in the cache\n * Not checking for casing as keys are all generated in lower case, remember to convert to lower case if object properties are compared\n * @param accountFilter - An object containing Account properties to filter by\n */\n getAccountsFilteredBy(accountFilter) {\n const allAccountKeys = this.getAccountKeys();\n const matchingAccounts = [];\n allAccountKeys.forEach((cacheKey) => {\n if (!this.isAccountKey(cacheKey, accountFilter.homeAccountId)) {\n // Don't parse value if the key doesn't match the account filters\n return;\n }\n const entity = this.getAccount(cacheKey, this.commonLogger);\n // Match base account fields\n if (!entity) {\n return;\n }\n if (!!accountFilter.homeAccountId &&\n !this.matchHomeAccountId(entity, accountFilter.homeAccountId)) {\n return;\n }\n if (!!accountFilter.username &&\n !this.matchUsername(entity.username, accountFilter.username)) {\n return;\n }\n if (!!accountFilter.environment &&\n !this.matchEnvironment(entity, accountFilter.environment)) {\n return;\n }\n if (!!accountFilter.realm &&\n !this.matchRealm(entity, accountFilter.realm)) {\n return;\n }\n if (!!accountFilter.nativeAccountId &&\n !this.matchNativeAccountId(entity, accountFilter.nativeAccountId)) {\n return;\n }\n if (!!accountFilter.authorityType &&\n !this.matchAuthorityType(entity, accountFilter.authorityType)) {\n return;\n }\n // If at least one tenant profile matches the tenant profile filter, add the account to the list of matching accounts\n const tenantProfileFilter = {\n localAccountId: accountFilter?.localAccountId,\n name: accountFilter?.name,\n };\n const matchingTenantProfiles = entity.tenantProfiles?.filter((tenantProfile) => {\n return this.tenantProfileMatchesFilter(tenantProfile, tenantProfileFilter);\n });\n if (matchingTenantProfiles && matchingTenantProfiles.length === 0) {\n // No tenant profile for this account matches filter, don't add to list of matching accounts\n return;\n }\n matchingAccounts.push(entity);\n });\n return matchingAccounts;\n }\n /**\n * Returns true if the given key matches our account key schema. Also matches homeAccountId and/or tenantId if provided\n * @param key\n * @param homeAccountId\n * @param tenantId\n * @returns\n */\n isAccountKey(key, homeAccountId, tenantId) {\n if (key.split(Separators.CACHE_KEY_SEPARATOR).length < 3) {\n // Account cache keys contain 3 items separated by '-' (each item may also contain '-')\n return false;\n }\n if (homeAccountId &&\n !key.toLowerCase().includes(homeAccountId.toLowerCase())) {\n return false;\n }\n if (tenantId && !key.toLowerCase().includes(tenantId.toLowerCase())) {\n return false;\n }\n // Do not check environment as aliasing can cause false negatives\n return true;\n }\n /**\n * Returns true if the given key matches our credential key schema.\n * @param key\n */\n isCredentialKey(key) {\n if (key.split(Separators.CACHE_KEY_SEPARATOR).length < 6) {\n // Credential cache keys contain 6 items separated by '-' (each item may also contain '-')\n return false;\n }\n const lowerCaseKey = key.toLowerCase();\n // Credential keys must indicate what credential type they represent\n if (lowerCaseKey.indexOf(CredentialType.ID_TOKEN.toLowerCase()) ===\n -1 &&\n lowerCaseKey.indexOf(CredentialType.ACCESS_TOKEN.toLowerCase()) ===\n -1 &&\n lowerCaseKey.indexOf(CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME.toLowerCase()) === -1 &&\n lowerCaseKey.indexOf(CredentialType.REFRESH_TOKEN.toLowerCase()) ===\n -1) {\n return false;\n }\n if (lowerCaseKey.indexOf(CredentialType.REFRESH_TOKEN.toLowerCase()) >\n -1) {\n // Refresh tokens must contain the client id or family id\n const clientIdValidation = `${CredentialType.REFRESH_TOKEN}${Separators.CACHE_KEY_SEPARATOR}${this.clientId}${Separators.CACHE_KEY_SEPARATOR}`;\n const familyIdValidation = `${CredentialType.REFRESH_TOKEN}${Separators.CACHE_KEY_SEPARATOR}${THE_FAMILY_ID}${Separators.CACHE_KEY_SEPARATOR}`;\n if (lowerCaseKey.indexOf(clientIdValidation.toLowerCase()) === -1 &&\n lowerCaseKey.indexOf(familyIdValidation.toLowerCase()) === -1) {\n return false;\n }\n }\n else if (lowerCaseKey.indexOf(this.clientId.toLowerCase()) === -1) {\n // Tokens must contain the clientId\n return false;\n }\n return true;\n }\n /**\n * Returns whether or not the given credential entity matches the filter\n * @param entity\n * @param filter\n * @returns\n */\n credentialMatchesFilter(entity, filter) {\n if (!!filter.clientId && !this.matchClientId(entity, filter.clientId)) {\n return false;\n }\n if (!!filter.userAssertionHash &&\n !this.matchUserAssertionHash(entity, filter.userAssertionHash)) {\n return false;\n }\n /*\n * homeAccountId can be undefined, and we want to filter out cached items that have a homeAccountId of \"\"\n * because we don't want a client_credential request to return a cached token that has a homeAccountId\n */\n if (typeof filter.homeAccountId === \"string\" &&\n !this.matchHomeAccountId(entity, filter.homeAccountId)) {\n return false;\n }\n if (!!filter.environment &&\n !this.matchEnvironment(entity, filter.environment)) {\n return false;\n }\n if (!!filter.realm && !this.matchRealm(entity, filter.realm)) {\n return false;\n }\n if (!!filter.credentialType &&\n !this.matchCredentialType(entity, filter.credentialType)) {\n return false;\n }\n if (!!filter.familyId && !this.matchFamilyId(entity, filter.familyId)) {\n return false;\n }\n /*\n * idTokens do not have \"target\", target specific refreshTokens do exist for some types of authentication\n * Resource specific refresh tokens case will be added when the support is deemed necessary\n */\n if (!!filter.target && !this.matchTarget(entity, filter.target)) {\n return false;\n }\n // If request OR cached entity has requested Claims Hash, check if they match\n if (filter.requestedClaimsHash || entity.requestedClaimsHash) {\n // Don't match if either is undefined or they are different\n if (entity.requestedClaimsHash !== filter.requestedClaimsHash) {\n return false;\n }\n }\n // Access Token with Auth Scheme specific matching\n if (entity.credentialType ===\n CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME) {\n if (!!filter.tokenType &&\n !this.matchTokenType(entity, filter.tokenType)) {\n return false;\n }\n // KeyId (sshKid) in request must match cached SSH certificate keyId because SSH cert is bound to a specific key\n if (filter.tokenType === AuthenticationScheme.SSH) {\n if (filter.keyId && !this.matchKeyId(entity, filter.keyId)) {\n return false;\n }\n }\n }\n return true;\n }\n /**\n * retrieve appMetadata matching all provided filters; if no filter is set, get all appMetadata\n * @param filter\n */\n getAppMetadataFilteredBy(filter) {\n const allCacheKeys = this.getKeys();\n const matchingAppMetadata = {};\n allCacheKeys.forEach((cacheKey) => {\n // don't parse any non-appMetadata type cache entities\n if (!this.isAppMetadata(cacheKey)) {\n return;\n }\n // Attempt retrieval\n const entity = this.getAppMetadata(cacheKey);\n if (!entity) {\n return;\n }\n if (!!filter.environment &&\n !this.matchEnvironment(entity, filter.environment)) {\n return;\n }\n if (!!filter.clientId &&\n !this.matchClientId(entity, filter.clientId)) {\n return;\n }\n matchingAppMetadata[cacheKey] = entity;\n });\n return matchingAppMetadata;\n }\n /**\n * retrieve authorityMetadata that contains a matching alias\n * @param filter\n */\n getAuthorityMetadataByAlias(host) {\n const allCacheKeys = this.getAuthorityMetadataKeys();\n let matchedEntity = null;\n allCacheKeys.forEach((cacheKey) => {\n // don't parse any non-authorityMetadata type cache entities\n if (!this.isAuthorityMetadata(cacheKey) ||\n cacheKey.indexOf(this.clientId) === -1) {\n return;\n }\n // Attempt retrieval\n const entity = this.getAuthorityMetadata(cacheKey);\n if (!entity) {\n return;\n }\n if (entity.aliases.indexOf(host) === -1) {\n return;\n }\n matchedEntity = entity;\n });\n return matchedEntity;\n }\n /**\n * Removes all accounts and related tokens from cache.\n */\n async removeAllAccounts() {\n const allAccountKeys = this.getAccountKeys();\n const removedAccounts = [];\n allAccountKeys.forEach((cacheKey) => {\n removedAccounts.push(this.removeAccount(cacheKey));\n });\n await Promise.all(removedAccounts);\n }\n /**\n * Removes the account and related tokens for a given account key\n * @param account\n */\n async removeAccount(accountKey) {\n const account = this.getAccount(accountKey, this.commonLogger);\n if (!account) {\n return;\n }\n await this.removeAccountContext(account);\n this.removeItem(accountKey);\n }\n /**\n * Removes credentials associated with the provided account\n * @param account\n */\n async removeAccountContext(account) {\n const allTokenKeys = this.getTokenKeys();\n const accountId = account.generateAccountId();\n const removedCredentials = [];\n allTokenKeys.idToken.forEach((key) => {\n if (key.indexOf(accountId) === 0) {\n this.removeIdToken(key);\n }\n });\n allTokenKeys.accessToken.forEach((key) => {\n if (key.indexOf(accountId) === 0) {\n removedCredentials.push(this.removeAccessToken(key));\n }\n });\n allTokenKeys.refreshToken.forEach((key) => {\n if (key.indexOf(accountId) === 0) {\n this.removeRefreshToken(key);\n }\n });\n await Promise.all(removedCredentials);\n }\n /**\n * Migrates a single-tenant account and all it's associated alternate cross-tenant account objects in the\n * cache into a condensed multi-tenant account object with tenant profiles.\n * @param accountKey\n * @param accountEntity\n * @param logger\n * @returns\n */\n updateOutdatedCachedAccount(accountKey, accountEntity, logger) {\n // Only update if account entity is defined and has no tenantProfiles object (is outdated)\n if (accountEntity && accountEntity.isSingleTenant()) {\n this.commonLogger?.verbose(\"updateOutdatedCachedAccount: Found a single-tenant (outdated) account entity in the cache, migrating to multi-tenant account entity\");\n // Get keys of all accounts belonging to user\n const matchingAccountKeys = this.getAccountKeys().filter((key) => {\n return key.startsWith(accountEntity.homeAccountId);\n });\n // Get all account entities belonging to user\n const accountsToMerge = [];\n matchingAccountKeys.forEach((key) => {\n const account = this.getCachedAccountEntity(key);\n if (account) {\n accountsToMerge.push(account);\n }\n });\n // Set base account to home account if available, any account if not\n const baseAccount = accountsToMerge.find((account) => {\n return tenantIdMatchesHomeTenant(account.realm, account.homeAccountId);\n }) || accountsToMerge[0];\n // Populate tenant profiles built from each account entity belonging to the user\n baseAccount.tenantProfiles = accountsToMerge.map((account) => {\n return {\n tenantId: account.realm,\n localAccountId: account.localAccountId,\n name: account.name,\n isHomeTenant: tenantIdMatchesHomeTenant(account.realm, account.homeAccountId),\n };\n });\n const updatedAccount = CacheManager.toObject(new AccountEntity(), {\n ...baseAccount,\n });\n const newAccountKey = updatedAccount.generateAccountKey();\n // Clear cache of legacy account objects that have been collpsed into tenant profiles\n matchingAccountKeys.forEach((key) => {\n if (key !== newAccountKey) {\n this.removeOutdatedAccount(accountKey);\n }\n });\n // Cache updated account object\n this.setAccount(updatedAccount);\n logger?.verbose(\"Updated an outdated account entity in the cache\");\n return updatedAccount;\n }\n // No update is necessary\n return accountEntity;\n }\n /**\n * returns a boolean if the given credential is removed\n * @param credential\n */\n async removeAccessToken(key) {\n const credential = this.getAccessTokenCredential(key);\n if (!credential) {\n return;\n }\n // Remove Token Binding Key from key store for PoP Tokens Credentials\n if (credential.credentialType.toLowerCase() ===\n CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME.toLowerCase()) {\n if (credential.tokenType === AuthenticationScheme.POP) {\n const accessTokenWithAuthSchemeEntity = credential;\n const kid = accessTokenWithAuthSchemeEntity.keyId;\n if (kid) {\n try {\n await this.cryptoImpl.removeTokenBindingKey(kid);\n }\n catch (error) {\n throw createClientAuthError(bindingKeyNotRemoved);\n }\n }\n }\n }\n return this.removeItem(key);\n }\n /**\n * Removes all app metadata objects from cache.\n */\n removeAppMetadata() {\n const allCacheKeys = this.getKeys();\n allCacheKeys.forEach((cacheKey) => {\n if (this.isAppMetadata(cacheKey)) {\n this.removeItem(cacheKey);\n }\n });\n return true;\n }\n /**\n * Retrieve AccountEntity from cache\n * @param account\n */\n readAccountFromCache(account) {\n const accountKey = AccountEntity.generateAccountCacheKey(account);\n return this.getAccount(accountKey, this.commonLogger);\n }\n /**\n * Retrieve IdTokenEntity from cache\n * @param account {AccountInfo}\n * @param tokenKeys {?TokenKeys}\n * @param targetRealm {?string}\n * @param performanceClient {?IPerformanceClient}\n * @param correlationId {?string}\n */\n getIdToken(account, tokenKeys, targetRealm, performanceClient, correlationId) {\n this.commonLogger.trace(\"CacheManager - getIdToken called\");\n const idTokenFilter = {\n homeAccountId: account.homeAccountId,\n environment: account.environment,\n credentialType: CredentialType.ID_TOKEN,\n clientId: this.clientId,\n realm: targetRealm,\n };\n const idTokenMap = this.getIdTokensByFilter(idTokenFilter, tokenKeys);\n const numIdTokens = idTokenMap.size;\n if (numIdTokens < 1) {\n this.commonLogger.info(\"CacheManager:getIdToken - No token found\");\n return null;\n }\n else if (numIdTokens > 1) {\n let tokensToBeRemoved = idTokenMap;\n // Multiple tenant profiles and no tenant specified, pick home account\n if (!targetRealm) {\n const homeIdTokenMap = new Map();\n idTokenMap.forEach((idToken, key) => {\n if (idToken.realm === account.tenantId) {\n homeIdTokenMap.set(key, idToken);\n }\n });\n const numHomeIdTokens = homeIdTokenMap.size;\n if (numHomeIdTokens < 1) {\n this.commonLogger.info(\"CacheManager:getIdToken - Multiple ID tokens found for account but none match account entity tenant id, returning first result\");\n return idTokenMap.values().next().value;\n }\n else if (numHomeIdTokens === 1) {\n this.commonLogger.info(\"CacheManager:getIdToken - Multiple ID tokens found for account, defaulting to home tenant profile\");\n return homeIdTokenMap.values().next().value;\n }\n else {\n // Multiple ID tokens for home tenant profile, remove all and return null\n tokensToBeRemoved = homeIdTokenMap;\n }\n }\n // Multiple tokens for a single tenant profile, remove all and return null\n this.commonLogger.info(\"CacheManager:getIdToken - Multiple matching ID tokens found, clearing them\");\n tokensToBeRemoved.forEach((idToken, key) => {\n this.removeIdToken(key);\n });\n if (performanceClient && correlationId) {\n performanceClient.addFields({ multiMatchedID: idTokenMap.size }, correlationId);\n }\n return null;\n }\n this.commonLogger.info(\"CacheManager:getIdToken - Returning ID token\");\n return idTokenMap.values().next().value;\n }\n /**\n * Gets all idTokens matching the given filter\n * @param filter\n * @returns\n */\n getIdTokensByFilter(filter, tokenKeys) {\n const idTokenKeys = (tokenKeys && tokenKeys.idToken) || this.getTokenKeys().idToken;\n const idTokens = new Map();\n idTokenKeys.forEach((key) => {\n if (!this.idTokenKeyMatchesFilter(key, {\n clientId: this.clientId,\n ...filter,\n })) {\n return;\n }\n const idToken = this.getIdTokenCredential(key);\n if (idToken && this.credentialMatchesFilter(idToken, filter)) {\n idTokens.set(key, idToken);\n }\n });\n return idTokens;\n }\n /**\n * Validate the cache key against filter before retrieving and parsing cache value\n * @param key\n * @param filter\n * @returns\n */\n idTokenKeyMatchesFilter(inputKey, filter) {\n const key = inputKey.toLowerCase();\n if (filter.clientId &&\n key.indexOf(filter.clientId.toLowerCase()) === -1) {\n return false;\n }\n if (filter.homeAccountId &&\n key.indexOf(filter.homeAccountId.toLowerCase()) === -1) {\n return false;\n }\n return true;\n }\n /**\n * Removes idToken from the cache\n * @param key\n */\n removeIdToken(key) {\n this.removeItem(key);\n }\n /**\n * Removes refresh token from the cache\n * @param key\n */\n removeRefreshToken(key) {\n this.removeItem(key);\n }\n /**\n * Retrieve AccessTokenEntity from cache\n * @param account {AccountInfo}\n * @param request {BaseAuthRequest}\n * @param tokenKeys {?TokenKeys}\n * @param performanceClient {?IPerformanceClient}\n * @param correlationId {?string}\n */\n getAccessToken(account, request, tokenKeys, targetRealm, performanceClient, correlationId) {\n this.commonLogger.trace(\"CacheManager - getAccessToken called\");\n const scopes = ScopeSet.createSearchScopes(request.scopes);\n const authScheme = request.authenticationScheme || AuthenticationScheme.BEARER;\n /*\n * Distinguish between Bearer and PoP/SSH token cache types\n * Cast to lowercase to handle \"bearer\" from ADFS\n */\n const credentialType = authScheme &&\n authScheme.toLowerCase() !==\n AuthenticationScheme.BEARER.toLowerCase()\n ? CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME\n : CredentialType.ACCESS_TOKEN;\n const accessTokenFilter = {\n homeAccountId: account.homeAccountId,\n environment: account.environment,\n credentialType: credentialType,\n clientId: this.clientId,\n realm: targetRealm || account.tenantId,\n target: scopes,\n tokenType: authScheme,\n keyId: request.sshKid,\n requestedClaimsHash: request.requestedClaimsHash,\n };\n const accessTokenKeys = (tokenKeys && tokenKeys.accessToken) ||\n this.getTokenKeys().accessToken;\n const accessTokens = [];\n accessTokenKeys.forEach((key) => {\n // Validate key\n if (this.accessTokenKeyMatchesFilter(key, accessTokenFilter, true)) {\n const accessToken = this.getAccessTokenCredential(key);\n // Validate value\n if (accessToken &&\n this.credentialMatchesFilter(accessToken, accessTokenFilter)) {\n accessTokens.push(accessToken);\n }\n }\n });\n const numAccessTokens = accessTokens.length;\n if (numAccessTokens < 1) {\n this.commonLogger.info(\"CacheManager:getAccessToken - No token found\");\n return null;\n }\n else if (numAccessTokens > 1) {\n this.commonLogger.info(\"CacheManager:getAccessToken - Multiple access tokens found, clearing them\");\n accessTokens.forEach((accessToken) => {\n void this.removeAccessToken(generateCredentialKey(accessToken));\n });\n if (performanceClient && correlationId) {\n performanceClient.addFields({ multiMatchedAT: accessTokens.length }, correlationId);\n }\n return null;\n }\n this.commonLogger.info(\"CacheManager:getAccessToken - Returning access token\");\n return accessTokens[0];\n }\n /**\n * Validate the cache key against filter before retrieving and parsing cache value\n * @param key\n * @param filter\n * @param keyMustContainAllScopes\n * @returns\n */\n accessTokenKeyMatchesFilter(inputKey, filter, keyMustContainAllScopes) {\n const key = inputKey.toLowerCase();\n if (filter.clientId &&\n key.indexOf(filter.clientId.toLowerCase()) === -1) {\n return false;\n }\n if (filter.homeAccountId &&\n key.indexOf(filter.homeAccountId.toLowerCase()) === -1) {\n return false;\n }\n if (filter.realm && key.indexOf(filter.realm.toLowerCase()) === -1) {\n return false;\n }\n if (filter.requestedClaimsHash &&\n key.indexOf(filter.requestedClaimsHash.toLowerCase()) === -1) {\n return false;\n }\n if (filter.target) {\n const scopes = filter.target.asArray();\n for (let i = 0; i < scopes.length; i++) {\n if (keyMustContainAllScopes &&\n !key.includes(scopes[i].toLowerCase())) {\n // When performing a cache lookup a missing scope would be a cache miss\n return false;\n }\n else if (!keyMustContainAllScopes &&\n key.includes(scopes[i].toLowerCase())) {\n // When performing a cache write, any token with a subset of requested scopes should be replaced\n return true;\n }\n }\n }\n return true;\n }\n /**\n * Gets all access tokens matching the filter\n * @param filter\n * @returns\n */\n getAccessTokensByFilter(filter) {\n const tokenKeys = this.getTokenKeys();\n const accessTokens = [];\n tokenKeys.accessToken.forEach((key) => {\n if (!this.accessTokenKeyMatchesFilter(key, filter, true)) {\n return;\n }\n const accessToken = this.getAccessTokenCredential(key);\n if (accessToken &&\n this.credentialMatchesFilter(accessToken, filter)) {\n accessTokens.push(accessToken);\n }\n });\n return accessTokens;\n }\n /**\n * Helper to retrieve the appropriate refresh token from cache\n * @param account {AccountInfo}\n * @param familyRT {boolean}\n * @param tokenKeys {?TokenKeys}\n * @param performanceClient {?IPerformanceClient}\n * @param correlationId {?string}\n */\n getRefreshToken(account, familyRT, tokenKeys, performanceClient, correlationId) {\n this.commonLogger.trace(\"CacheManager - getRefreshToken called\");\n const id = familyRT ? THE_FAMILY_ID : undefined;\n const refreshTokenFilter = {\n homeAccountId: account.homeAccountId,\n environment: account.environment,\n credentialType: CredentialType.REFRESH_TOKEN,\n clientId: this.clientId,\n familyId: id,\n };\n const refreshTokenKeys = (tokenKeys && tokenKeys.refreshToken) ||\n this.getTokenKeys().refreshToken;\n const refreshTokens = [];\n refreshTokenKeys.forEach((key) => {\n // Validate key\n if (this.refreshTokenKeyMatchesFilter(key, refreshTokenFilter)) {\n const refreshToken = this.getRefreshTokenCredential(key);\n // Validate value\n if (refreshToken &&\n this.credentialMatchesFilter(refreshToken, refreshTokenFilter)) {\n refreshTokens.push(refreshToken);\n }\n }\n });\n const numRefreshTokens = refreshTokens.length;\n if (numRefreshTokens < 1) {\n this.commonLogger.info(\"CacheManager:getRefreshToken - No refresh token found.\");\n return null;\n }\n // address the else case after remove functions address environment aliases\n if (numRefreshTokens > 1 && performanceClient && correlationId) {\n performanceClient.addFields({ multiMatchedRT: numRefreshTokens }, correlationId);\n }\n this.commonLogger.info(\"CacheManager:getRefreshToken - returning refresh token\");\n return refreshTokens[0];\n }\n /**\n * Validate the cache key against filter before retrieving and parsing cache value\n * @param key\n * @param filter\n */\n refreshTokenKeyMatchesFilter(inputKey, filter) {\n const key = inputKey.toLowerCase();\n if (filter.familyId &&\n key.indexOf(filter.familyId.toLowerCase()) === -1) {\n return false;\n }\n // If familyId is used, clientId is not in the key\n if (!filter.familyId &&\n filter.clientId &&\n key.indexOf(filter.clientId.toLowerCase()) === -1) {\n return false;\n }\n if (filter.homeAccountId &&\n key.indexOf(filter.homeAccountId.toLowerCase()) === -1) {\n return false;\n }\n return true;\n }\n /**\n * Retrieve AppMetadataEntity from cache\n */\n readAppMetadataFromCache(environment) {\n const appMetadataFilter = {\n environment,\n clientId: this.clientId,\n };\n const appMetadata = this.getAppMetadataFilteredBy(appMetadataFilter);\n const appMetadataEntries = Object.keys(appMetadata).map((key) => appMetadata[key]);\n const numAppMetadata = appMetadataEntries.length;\n if (numAppMetadata < 1) {\n return null;\n }\n else if (numAppMetadata > 1) {\n throw createClientAuthError(multipleMatchingAppMetadata);\n }\n return appMetadataEntries[0];\n }\n /**\n * Return the family_id value associated with FOCI\n * @param environment\n * @param clientId\n */\n isAppMetadataFOCI(environment) {\n const appMetadata = this.readAppMetadataFromCache(environment);\n return !!(appMetadata && appMetadata.familyId === THE_FAMILY_ID);\n }\n /**\n * helper to match account ids\n * @param value\n * @param homeAccountId\n */\n matchHomeAccountId(entity, homeAccountId) {\n return !!(typeof entity.homeAccountId === \"string\" &&\n homeAccountId === entity.homeAccountId);\n }\n /**\n * helper to match account ids\n * @param entity\n * @param localAccountId\n * @returns\n */\n matchLocalAccountIdFromTokenClaims(tokenClaims, localAccountId) {\n const idTokenLocalAccountId = tokenClaims.oid || tokenClaims.sub;\n return localAccountId === idTokenLocalAccountId;\n }\n matchLocalAccountIdFromTenantProfile(tenantProfile, localAccountId) {\n return tenantProfile.localAccountId === localAccountId;\n }\n /**\n * helper to match names\n * @param entity\n * @param name\n * @returns true if the downcased name properties are present and match in the filter and the entity\n */\n matchName(claims, name) {\n return !!(name.toLowerCase() === claims.name?.toLowerCase());\n }\n /**\n * helper to match usernames\n * @param entity\n * @param username\n * @returns\n */\n matchUsername(cachedUsername, filterUsername) {\n return !!(cachedUsername &&\n typeof cachedUsername === \"string\" &&\n filterUsername?.toLowerCase() === cachedUsername.toLowerCase());\n }\n /**\n * helper to match assertion\n * @param value\n * @param oboAssertion\n */\n matchUserAssertionHash(entity, userAssertionHash) {\n return !!(entity.userAssertionHash &&\n userAssertionHash === entity.userAssertionHash);\n }\n /**\n * helper to match environment\n * @param value\n * @param environment\n */\n matchEnvironment(entity, environment) {\n // Check static authority options first for cases where authority metadata has not been resolved and cached yet\n if (this.staticAuthorityOptions) {\n const staticAliases = getAliasesFromStaticSources(this.staticAuthorityOptions, this.commonLogger);\n if (staticAliases.includes(environment) &&\n staticAliases.includes(entity.environment)) {\n return true;\n }\n }\n // Query metadata cache if no static authority configuration has aliases that match enviroment\n const cloudMetadata = this.getAuthorityMetadataByAlias(environment);\n if (cloudMetadata &&\n cloudMetadata.aliases.indexOf(entity.environment) > -1) {\n return true;\n }\n return false;\n }\n /**\n * helper to match credential type\n * @param entity\n * @param credentialType\n */\n matchCredentialType(entity, credentialType) {\n return (entity.credentialType &&\n credentialType.toLowerCase() === entity.credentialType.toLowerCase());\n }\n /**\n * helper to match client ids\n * @param entity\n * @param clientId\n */\n matchClientId(entity, clientId) {\n return !!(entity.clientId && clientId === entity.clientId);\n }\n /**\n * helper to match family ids\n * @param entity\n * @param familyId\n */\n matchFamilyId(entity, familyId) {\n return !!(entity.familyId && familyId === entity.familyId);\n }\n /**\n * helper to match realm\n * @param entity\n * @param realm\n */\n matchRealm(entity, realm) {\n return !!(entity.realm?.toLowerCase() === realm.toLowerCase());\n }\n /**\n * helper to match nativeAccountId\n * @param entity\n * @param nativeAccountId\n * @returns boolean indicating the match result\n */\n matchNativeAccountId(entity, nativeAccountId) {\n return !!(entity.nativeAccountId && nativeAccountId === entity.nativeAccountId);\n }\n /**\n * helper to match loginHint which can be either:\n * 1. login_hint ID token claim\n * 2. username in cached account object\n * 3. upn in ID token claims\n * @param entity\n * @param loginHint\n * @returns\n */\n matchLoginHintFromTokenClaims(tokenClaims, loginHint) {\n if (tokenClaims.login_hint === loginHint) {\n return true;\n }\n if (tokenClaims.preferred_username === loginHint) {\n return true;\n }\n if (tokenClaims.upn === loginHint) {\n return true;\n }\n return false;\n }\n /**\n * Helper to match sid\n * @param entity\n * @param sid\n * @returns true if the sid claim is present and matches the filter\n */\n matchSid(idTokenClaims, sid) {\n return idTokenClaims.sid === sid;\n }\n matchAuthorityType(entity, authorityType) {\n return !!(entity.authorityType &&\n authorityType.toLowerCase() === entity.authorityType.toLowerCase());\n }\n /**\n * Returns true if the target scopes are a subset of the current entity's scopes, false otherwise.\n * @param entity\n * @param target\n */\n matchTarget(entity, target) {\n const isNotAccessTokenCredential = entity.credentialType !== CredentialType.ACCESS_TOKEN &&\n entity.credentialType !==\n CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME;\n if (isNotAccessTokenCredential || !entity.target) {\n return false;\n }\n const entityScopeSet = ScopeSet.fromString(entity.target);\n return entityScopeSet.containsScopeSet(target);\n }\n /**\n * Returns true if the credential's tokenType or Authentication Scheme matches the one in the request, false otherwise\n * @param entity\n * @param tokenType\n */\n matchTokenType(entity, tokenType) {\n return !!(entity.tokenType && entity.tokenType === tokenType);\n }\n /**\n * Returns true if the credential's keyId matches the one in the request, false otherwise\n * @param entity\n * @param keyId\n */\n matchKeyId(entity, keyId) {\n return !!(entity.keyId && entity.keyId === keyId);\n }\n /**\n * returns if a given cache entity is of the type appmetadata\n * @param key\n */\n isAppMetadata(key) {\n return key.indexOf(APP_METADATA) !== -1;\n }\n /**\n * returns if a given cache entity is of the type authoritymetadata\n * @param key\n */\n isAuthorityMetadata(key) {\n return key.indexOf(AUTHORITY_METADATA_CONSTANTS.CACHE_KEY) !== -1;\n }\n /**\n * returns cache key used for cloud instance metadata\n */\n generateAuthorityMetadataCacheKey(authority) {\n return `${AUTHORITY_METADATA_CONSTANTS.CACHE_KEY}-${this.clientId}-${authority}`;\n }\n /**\n * Helper to convert serialized data to object\n * @param obj\n * @param json\n */\n static toObject(obj, json) {\n for (const propertyName in json) {\n obj[propertyName] = json[propertyName];\n }\n return obj;\n }\n}\n/** @internal */\nclass DefaultStorageClass extends CacheManager {\n setAccount() {\n throw createClientAuthError(methodNotImplemented);\n }\n getAccount() {\n throw createClientAuthError(methodNotImplemented);\n }\n getCachedAccountEntity() {\n throw createClientAuthError(methodNotImplemented);\n }\n setIdTokenCredential() {\n throw createClientAuthError(methodNotImplemented);\n }\n getIdTokenCredential() {\n throw createClientAuthError(methodNotImplemented);\n }\n setAccessTokenCredential() {\n throw createClientAuthError(methodNotImplemented);\n }\n getAccessTokenCredential() {\n throw createClientAuthError(methodNotImplemented);\n }\n setRefreshTokenCredential() {\n throw createClientAuthError(methodNotImplemented);\n }\n getRefreshTokenCredential() {\n throw createClientAuthError(methodNotImplemented);\n }\n setAppMetadata() {\n throw createClientAuthError(methodNotImplemented);\n }\n getAppMetadata() {\n throw createClientAuthError(methodNotImplemented);\n }\n setServerTelemetry() {\n throw createClientAuthError(methodNotImplemented);\n }\n getServerTelemetry() {\n throw createClientAuthError(methodNotImplemented);\n }\n setAuthorityMetadata() {\n throw createClientAuthError(methodNotImplemented);\n }\n getAuthorityMetadata() {\n throw createClientAuthError(methodNotImplemented);\n }\n getAuthorityMetadataKeys() {\n throw createClientAuthError(methodNotImplemented);\n }\n setThrottlingCache() {\n throw createClientAuthError(methodNotImplemented);\n }\n getThrottlingCache() {\n throw createClientAuthError(methodNotImplemented);\n }\n removeItem() {\n throw createClientAuthError(methodNotImplemented);\n }\n getKeys() {\n throw createClientAuthError(methodNotImplemented);\n }\n getAccountKeys() {\n throw createClientAuthError(methodNotImplemented);\n }\n getTokenKeys() {\n throw createClientAuthError(methodNotImplemented);\n }\n async clear() {\n throw createClientAuthError(methodNotImplemented);\n }\n updateCredentialCacheKey() {\n throw createClientAuthError(methodNotImplemented);\n }\n removeOutdatedAccount() {\n throw createClientAuthError(methodNotImplemented);\n }\n}\n\nexport { CacheManager, DefaultStorageClass };\n//# sourceMappingURL=CacheManager.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { DEFAULT_CRYPTO_IMPLEMENTATION } from '../crypto/ICrypto.mjs';\nimport { Logger, LogLevel } from '../logger/Logger.mjs';\nimport { DEFAULT_TOKEN_RENEWAL_OFFSET_SEC, Constants } from '../utils/Constants.mjs';\nimport { version } from '../packageMetadata.mjs';\nimport { AzureCloudInstance } from '../authority/AuthorityOptions.mjs';\nimport { DefaultStorageClass } from '../cache/CacheManager.mjs';\nimport { ProtocolMode } from '../authority/ProtocolMode.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { methodNotImplemented } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst DEFAULT_SYSTEM_OPTIONS = {\n tokenRenewalOffsetSeconds: DEFAULT_TOKEN_RENEWAL_OFFSET_SEC,\n preventCorsPreflight: false,\n};\nconst DEFAULT_LOGGER_IMPLEMENTATION = {\n loggerCallback: () => {\n // allow users to not set loggerCallback\n },\n piiLoggingEnabled: false,\n logLevel: LogLevel.Info,\n correlationId: Constants.EMPTY_STRING,\n};\nconst DEFAULT_CACHE_OPTIONS = {\n claimsBasedCachingEnabled: false,\n};\nconst DEFAULT_NETWORK_IMPLEMENTATION = {\n async sendGetRequestAsync() {\n throw createClientAuthError(methodNotImplemented);\n },\n async sendPostRequestAsync() {\n throw createClientAuthError(methodNotImplemented);\n },\n};\nconst DEFAULT_LIBRARY_INFO = {\n sku: Constants.SKU,\n version: version,\n cpu: Constants.EMPTY_STRING,\n os: Constants.EMPTY_STRING,\n};\nconst DEFAULT_CLIENT_CREDENTIALS = {\n clientSecret: Constants.EMPTY_STRING,\n clientAssertion: undefined,\n};\nconst DEFAULT_AZURE_CLOUD_OPTIONS = {\n azureCloudInstance: AzureCloudInstance.None,\n tenant: `${Constants.DEFAULT_COMMON_TENANT}`,\n};\nconst DEFAULT_TELEMETRY_OPTIONS = {\n application: {\n appName: \"\",\n appVersion: \"\",\n },\n};\n/**\n * Function that sets the default options when not explicitly configured from app developer\n *\n * @param Configuration\n *\n * @returns Configuration\n */\nfunction buildClientConfiguration({ authOptions: userAuthOptions, systemOptions: userSystemOptions, loggerOptions: userLoggerOption, cacheOptions: userCacheOptions, storageInterface: storageImplementation, networkInterface: networkImplementation, cryptoInterface: cryptoImplementation, clientCredentials: clientCredentials, libraryInfo: libraryInfo, telemetry: telemetry, serverTelemetryManager: serverTelemetryManager, persistencePlugin: persistencePlugin, serializableCache: serializableCache, }) {\n const loggerOptions = {\n ...DEFAULT_LOGGER_IMPLEMENTATION,\n ...userLoggerOption,\n };\n return {\n authOptions: buildAuthOptions(userAuthOptions),\n systemOptions: { ...DEFAULT_SYSTEM_OPTIONS, ...userSystemOptions },\n loggerOptions: loggerOptions,\n cacheOptions: { ...DEFAULT_CACHE_OPTIONS, ...userCacheOptions },\n storageInterface: storageImplementation ||\n new DefaultStorageClass(userAuthOptions.clientId, DEFAULT_CRYPTO_IMPLEMENTATION, new Logger(loggerOptions)),\n networkInterface: networkImplementation || DEFAULT_NETWORK_IMPLEMENTATION,\n cryptoInterface: cryptoImplementation || DEFAULT_CRYPTO_IMPLEMENTATION,\n clientCredentials: clientCredentials || DEFAULT_CLIENT_CREDENTIALS,\n libraryInfo: { ...DEFAULT_LIBRARY_INFO, ...libraryInfo },\n telemetry: { ...DEFAULT_TELEMETRY_OPTIONS, ...telemetry },\n serverTelemetryManager: serverTelemetryManager || null,\n persistencePlugin: persistencePlugin || null,\n serializableCache: serializableCache || null,\n };\n}\n/**\n * Construct authoptions from the client and platform passed values\n * @param authOptions\n */\nfunction buildAuthOptions(authOptions) {\n return {\n clientCapabilities: [],\n azureCloudOptions: DEFAULT_AZURE_CLOUD_OPTIONS,\n skipAuthorityMetadataCache: false,\n ...authOptions,\n };\n}\n/**\n * Returns true if config has protocolMode set to ProtocolMode.OIDC, false otherwise\n * @param ClientConfiguration\n */\nfunction isOidcProtocolMode(config) {\n return (config.authOptions.authority.options.protocolMode === ProtocolMode.OIDC);\n}\n\nexport { DEFAULT_SYSTEM_OPTIONS, buildClientConfiguration, isOidcProtocolMode };\n//# sourceMappingURL=ClientConfiguration.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { AuthError } from './AuthError.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Error thrown when there is an error with the server code, for example, unavailability.\n */\nclass ServerError extends AuthError {\n constructor(errorCode, errorMessage, subError, errorNo, status) {\n super(errorCode, errorMessage, subError);\n this.name = \"ServerError\";\n this.errorNo = errorNo;\n this.status = status;\n Object.setPrototypeOf(this, ServerError.prototype);\n }\n}\n\nexport { ServerError };\n//# sourceMappingURL=ServerError.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { ThrottlingConstants, Constants, HeaderNames } from '../utils/Constants.mjs';\nimport { ServerError } from '../error/ServerError.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/** @internal */\nclass ThrottlingUtils {\n /**\n * Prepares a RequestThumbprint to be stored as a key.\n * @param thumbprint\n */\n static generateThrottlingStorageKey(thumbprint) {\n return `${ThrottlingConstants.THROTTLING_PREFIX}.${JSON.stringify(thumbprint)}`;\n }\n /**\n * Performs necessary throttling checks before a network request.\n * @param cacheManager\n * @param thumbprint\n */\n static preProcess(cacheManager, thumbprint) {\n const key = ThrottlingUtils.generateThrottlingStorageKey(thumbprint);\n const value = cacheManager.getThrottlingCache(key);\n if (value) {\n if (value.throttleTime < Date.now()) {\n cacheManager.removeItem(key);\n return;\n }\n throw new ServerError(value.errorCodes?.join(\" \") || Constants.EMPTY_STRING, value.errorMessage, value.subError);\n }\n }\n /**\n * Performs necessary throttling checks after a network request.\n * @param cacheManager\n * @param thumbprint\n * @param response\n */\n static postProcess(cacheManager, thumbprint, response) {\n if (ThrottlingUtils.checkResponseStatus(response) ||\n ThrottlingUtils.checkResponseForRetryAfter(response)) {\n const thumbprintValue = {\n throttleTime: ThrottlingUtils.calculateThrottleTime(parseInt(response.headers[HeaderNames.RETRY_AFTER])),\n error: response.body.error,\n errorCodes: response.body.error_codes,\n errorMessage: response.body.error_description,\n subError: response.body.suberror,\n };\n cacheManager.setThrottlingCache(ThrottlingUtils.generateThrottlingStorageKey(thumbprint), thumbprintValue);\n }\n }\n /**\n * Checks a NetworkResponse object's status codes against 429 or 5xx\n * @param response\n */\n static checkResponseStatus(response) {\n return (response.status === 429 ||\n (response.status >= 500 && response.status < 600));\n }\n /**\n * Checks a NetworkResponse object's RetryAfter header\n * @param response\n */\n static checkResponseForRetryAfter(response) {\n if (response.headers) {\n return (response.headers.hasOwnProperty(HeaderNames.RETRY_AFTER) &&\n (response.status < 200 || response.status >= 300));\n }\n return false;\n }\n /**\n * Calculates the Unix-time value for a throttle to expire given throttleTime in seconds.\n * @param throttleTime\n */\n static calculateThrottleTime(throttleTime) {\n const time = throttleTime <= 0 ? 0 : throttleTime;\n const currentSeconds = Date.now() / 1000;\n return Math.floor(Math.min(currentSeconds +\n (time || ThrottlingConstants.DEFAULT_THROTTLE_TIME_SECONDS), currentSeconds +\n ThrottlingConstants.DEFAULT_MAX_THROTTLE_TIME_SECONDS) * 1000);\n }\n static removeThrottle(cacheManager, clientId, request, homeAccountIdentifier) {\n const thumbprint = {\n clientId: clientId,\n authority: request.authority,\n scopes: request.scopes,\n homeAccountIdentifier: homeAccountIdentifier,\n claims: request.claims,\n authenticationScheme: request.authenticationScheme,\n resourceRequestMethod: request.resourceRequestMethod,\n resourceRequestUri: request.resourceRequestUri,\n shrClaims: request.shrClaims,\n sshKid: request.sshKid,\n };\n const key = this.generateThrottlingStorageKey(thumbprint);\n cacheManager.removeItem(key);\n }\n}\n\nexport { ThrottlingUtils };\n//# sourceMappingURL=ThrottlingUtils.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { ThrottlingUtils } from './ThrottlingUtils.mjs';\nimport { AuthError } from '../error/AuthError.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { networkError } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/** @internal */\nclass NetworkManager {\n constructor(networkClient, cacheManager) {\n this.networkClient = networkClient;\n this.cacheManager = cacheManager;\n }\n /**\n * Wraps sendPostRequestAsync with necessary preflight and postflight logic\n * @param thumbprint\n * @param tokenEndpoint\n * @param options\n */\n async sendPostRequest(thumbprint, tokenEndpoint, options) {\n ThrottlingUtils.preProcess(this.cacheManager, thumbprint);\n let response;\n try {\n response = await this.networkClient.sendPostRequestAsync(tokenEndpoint, options);\n }\n catch (e) {\n if (e instanceof AuthError) {\n throw e;\n }\n else {\n throw createClientAuthError(networkError);\n }\n }\n ThrottlingUtils.postProcess(this.cacheManager, thumbprint, response);\n return response;\n }\n}\n\nexport { NetworkManager };\n//# sourceMappingURL=NetworkManager.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst CcsCredentialType = {\n HOME_ACCOUNT_ID: \"home_account_id\",\n UPN: \"UPN\",\n};\n\nexport { CcsCredentialType };\n//# sourceMappingURL=CcsCredential.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientConfigurationError } from '../error/ClientConfigurationError.mjs';\nimport { CodeChallengeMethodValues, PromptValue } from '../utils/Constants.mjs';\nimport { redirectUriEmpty, invalidPromptValue, invalidClaims, pkceParamsMissing, invalidCodeChallengeMethod } from '../error/ClientConfigurationErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Validates server consumable params from the \"request\" objects\n */\nclass RequestValidator {\n /**\n * Utility to check if the `redirectUri` in the request is a non-null value\n * @param redirectUri\n */\n static validateRedirectUri(redirectUri) {\n if (!redirectUri) {\n throw createClientConfigurationError(redirectUriEmpty);\n }\n }\n /**\n * Utility to validate prompt sent by the user in the request\n * @param prompt\n */\n static validatePrompt(prompt) {\n const promptValues = [];\n for (const value in PromptValue) {\n promptValues.push(PromptValue[value]);\n }\n if (promptValues.indexOf(prompt) < 0) {\n throw createClientConfigurationError(invalidPromptValue);\n }\n }\n static validateClaims(claims) {\n try {\n JSON.parse(claims);\n }\n catch (e) {\n throw createClientConfigurationError(invalidClaims);\n }\n }\n /**\n * Utility to validate code_challenge and code_challenge_method\n * @param codeChallenge\n * @param codeChallengeMethod\n */\n static validateCodeChallengeParams(codeChallenge, codeChallengeMethod) {\n if (!codeChallenge || !codeChallengeMethod) {\n throw createClientConfigurationError(pkceParamsMissing);\n }\n else {\n this.validateCodeChallengeMethod(codeChallengeMethod);\n }\n }\n /**\n * Utility to validate code_challenge_method\n * @param codeChallengeMethod\n */\n static validateCodeChallengeMethod(codeChallengeMethod) {\n if ([\n CodeChallengeMethodValues.PLAIN,\n CodeChallengeMethodValues.S256,\n ].indexOf(codeChallengeMethod) < 0) {\n throw createClientConfigurationError(invalidCodeChallengeMethod);\n }\n }\n}\n\nexport { RequestValidator };\n//# sourceMappingURL=RequestValidator.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Constants, ResponseMode, OIDC_DEFAULT_SCOPES, HeaderNames, CLIENT_INFO, ClaimsRequestKeys, PasswordGrantConstants, AuthenticationScheme, ThrottlingConstants } from '../utils/Constants.mjs';\nimport { RESPONSE_TYPE, RESPONSE_MODE, NATIVE_BROKER, SCOPE, CLIENT_ID, REDIRECT_URI, POST_LOGOUT_URI, ID_TOKEN_HINT, DOMAIN_HINT, LOGIN_HINT, SID, CLAIMS, CLIENT_REQUEST_ID, X_CLIENT_SKU, X_CLIENT_VER, X_CLIENT_OS, X_CLIENT_CPU, X_APP_NAME, X_APP_VER, PROMPT, STATE, NONCE, CODE_CHALLENGE, CODE_CHALLENGE_METHOD, CODE, DEVICE_CODE, REFRESH_TOKEN, CODE_VERIFIER, CLIENT_SECRET, CLIENT_ASSERTION, CLIENT_ASSERTION_TYPE, OBO_ASSERTION, REQUESTED_TOKEN_USE, GRANT_TYPE, TOKEN_TYPE, REQ_CNF, X_CLIENT_CURR_TELEM, X_CLIENT_LAST_TELEM, X_MS_LIB_CAPABILITY, LOGOUT_HINT } from '../constants/AADServerParamKeys.mjs';\nimport { ScopeSet } from './ScopeSet.mjs';\nimport { createClientConfigurationError } from '../error/ClientConfigurationError.mjs';\nimport { RequestValidator } from './RequestValidator.mjs';\nimport { pkceParamsMissing, invalidClaims } from '../error/ClientConfigurationErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/** @internal */\nclass RequestParameterBuilder {\n constructor() {\n this.parameters = new Map();\n }\n /**\n * add response_type = code\n */\n addResponseTypeCode() {\n this.parameters.set(RESPONSE_TYPE, encodeURIComponent(Constants.CODE_RESPONSE_TYPE));\n }\n /**\n * add response_type = token id_token\n */\n addResponseTypeForTokenAndIdToken() {\n this.parameters.set(RESPONSE_TYPE, encodeURIComponent(`${Constants.TOKEN_RESPONSE_TYPE} ${Constants.ID_TOKEN_RESPONSE_TYPE}`));\n }\n /**\n * add response_mode. defaults to query.\n * @param responseMode\n */\n addResponseMode(responseMode) {\n this.parameters.set(RESPONSE_MODE, encodeURIComponent(responseMode ? responseMode : ResponseMode.QUERY));\n }\n /**\n * Add flag to indicate STS should attempt to use WAM if available\n */\n addNativeBroker() {\n this.parameters.set(NATIVE_BROKER, encodeURIComponent(\"1\"));\n }\n /**\n * add scopes. set addOidcScopes to false to prevent default scopes in non-user scenarios\n * @param scopeSet\n * @param addOidcScopes\n */\n addScopes(scopes, addOidcScopes = true, defaultScopes = OIDC_DEFAULT_SCOPES) {\n // Always add openid to the scopes when adding OIDC scopes\n if (addOidcScopes &&\n !defaultScopes.includes(\"openid\") &&\n !scopes.includes(\"openid\")) {\n defaultScopes.push(\"openid\");\n }\n const requestScopes = addOidcScopes\n ? [...(scopes || []), ...defaultScopes]\n : scopes || [];\n const scopeSet = new ScopeSet(requestScopes);\n this.parameters.set(SCOPE, encodeURIComponent(scopeSet.printScopes()));\n }\n /**\n * add clientId\n * @param clientId\n */\n addClientId(clientId) {\n this.parameters.set(CLIENT_ID, encodeURIComponent(clientId));\n }\n /**\n * add redirect_uri\n * @param redirectUri\n */\n addRedirectUri(redirectUri) {\n RequestValidator.validateRedirectUri(redirectUri);\n this.parameters.set(REDIRECT_URI, encodeURIComponent(redirectUri));\n }\n /**\n * add post logout redirectUri\n * @param redirectUri\n */\n addPostLogoutRedirectUri(redirectUri) {\n RequestValidator.validateRedirectUri(redirectUri);\n this.parameters.set(POST_LOGOUT_URI, encodeURIComponent(redirectUri));\n }\n /**\n * add id_token_hint to logout request\n * @param idTokenHint\n */\n addIdTokenHint(idTokenHint) {\n this.parameters.set(ID_TOKEN_HINT, encodeURIComponent(idTokenHint));\n }\n /**\n * add domain_hint\n * @param domainHint\n */\n addDomainHint(domainHint) {\n this.parameters.set(DOMAIN_HINT, encodeURIComponent(domainHint));\n }\n /**\n * add login_hint\n * @param loginHint\n */\n addLoginHint(loginHint) {\n this.parameters.set(LOGIN_HINT, encodeURIComponent(loginHint));\n }\n /**\n * Adds the CCS (Cache Credential Service) query parameter for login_hint\n * @param loginHint\n */\n addCcsUpn(loginHint) {\n this.parameters.set(HeaderNames.CCS_HEADER, encodeURIComponent(`UPN:${loginHint}`));\n }\n /**\n * Adds the CCS (Cache Credential Service) query parameter for account object\n * @param loginHint\n */\n addCcsOid(clientInfo) {\n this.parameters.set(HeaderNames.CCS_HEADER, encodeURIComponent(`Oid:${clientInfo.uid}@${clientInfo.utid}`));\n }\n /**\n * add sid\n * @param sid\n */\n addSid(sid) {\n this.parameters.set(SID, encodeURIComponent(sid));\n }\n /**\n * add claims\n * @param claims\n */\n addClaims(claims, clientCapabilities) {\n const mergedClaims = this.addClientCapabilitiesToClaims(claims, clientCapabilities);\n RequestValidator.validateClaims(mergedClaims);\n this.parameters.set(CLAIMS, encodeURIComponent(mergedClaims));\n }\n /**\n * add correlationId\n * @param correlationId\n */\n addCorrelationId(correlationId) {\n this.parameters.set(CLIENT_REQUEST_ID, encodeURIComponent(correlationId));\n }\n /**\n * add library info query params\n * @param libraryInfo\n */\n addLibraryInfo(libraryInfo) {\n // Telemetry Info\n this.parameters.set(X_CLIENT_SKU, libraryInfo.sku);\n this.parameters.set(X_CLIENT_VER, libraryInfo.version);\n if (libraryInfo.os) {\n this.parameters.set(X_CLIENT_OS, libraryInfo.os);\n }\n if (libraryInfo.cpu) {\n this.parameters.set(X_CLIENT_CPU, libraryInfo.cpu);\n }\n }\n /**\n * Add client telemetry parameters\n * @param appTelemetry\n */\n addApplicationTelemetry(appTelemetry) {\n if (appTelemetry?.appName) {\n this.parameters.set(X_APP_NAME, appTelemetry.appName);\n }\n if (appTelemetry?.appVersion) {\n this.parameters.set(X_APP_VER, appTelemetry.appVersion);\n }\n }\n /**\n * add prompt\n * @param prompt\n */\n addPrompt(prompt) {\n RequestValidator.validatePrompt(prompt);\n this.parameters.set(`${PROMPT}`, encodeURIComponent(prompt));\n }\n /**\n * add state\n * @param state\n */\n addState(state) {\n if (state) {\n this.parameters.set(STATE, encodeURIComponent(state));\n }\n }\n /**\n * add nonce\n * @param nonce\n */\n addNonce(nonce) {\n this.parameters.set(NONCE, encodeURIComponent(nonce));\n }\n /**\n * add code_challenge and code_challenge_method\n * - throw if either of them are not passed\n * @param codeChallenge\n * @param codeChallengeMethod\n */\n addCodeChallengeParams(codeChallenge, codeChallengeMethod) {\n RequestValidator.validateCodeChallengeParams(codeChallenge, codeChallengeMethod);\n if (codeChallenge && codeChallengeMethod) {\n this.parameters.set(CODE_CHALLENGE, encodeURIComponent(codeChallenge));\n this.parameters.set(CODE_CHALLENGE_METHOD, encodeURIComponent(codeChallengeMethod));\n }\n else {\n throw createClientConfigurationError(pkceParamsMissing);\n }\n }\n /**\n * add the `authorization_code` passed by the user to exchange for a token\n * @param code\n */\n addAuthorizationCode(code) {\n this.parameters.set(CODE, encodeURIComponent(code));\n }\n /**\n * add the `authorization_code` passed by the user to exchange for a token\n * @param code\n */\n addDeviceCode(code) {\n this.parameters.set(DEVICE_CODE, encodeURIComponent(code));\n }\n /**\n * add the `refreshToken` passed by the user\n * @param refreshToken\n */\n addRefreshToken(refreshToken) {\n this.parameters.set(REFRESH_TOKEN, encodeURIComponent(refreshToken));\n }\n /**\n * add the `code_verifier` passed by the user to exchange for a token\n * @param codeVerifier\n */\n addCodeVerifier(codeVerifier) {\n this.parameters.set(CODE_VERIFIER, encodeURIComponent(codeVerifier));\n }\n /**\n * add client_secret\n * @param clientSecret\n */\n addClientSecret(clientSecret) {\n this.parameters.set(CLIENT_SECRET, encodeURIComponent(clientSecret));\n }\n /**\n * add clientAssertion for confidential client flows\n * @param clientAssertion\n */\n addClientAssertion(clientAssertion) {\n if (clientAssertion) {\n this.parameters.set(CLIENT_ASSERTION, encodeURIComponent(clientAssertion));\n }\n }\n /**\n * add clientAssertionType for confidential client flows\n * @param clientAssertionType\n */\n addClientAssertionType(clientAssertionType) {\n if (clientAssertionType) {\n this.parameters.set(CLIENT_ASSERTION_TYPE, encodeURIComponent(clientAssertionType));\n }\n }\n /**\n * add OBO assertion for confidential client flows\n * @param clientAssertion\n */\n addOboAssertion(oboAssertion) {\n this.parameters.set(OBO_ASSERTION, encodeURIComponent(oboAssertion));\n }\n /**\n * add grant type\n * @param grantType\n */\n addRequestTokenUse(tokenUse) {\n this.parameters.set(REQUESTED_TOKEN_USE, encodeURIComponent(tokenUse));\n }\n /**\n * add grant type\n * @param grantType\n */\n addGrantType(grantType) {\n this.parameters.set(GRANT_TYPE, encodeURIComponent(grantType));\n }\n /**\n * add client info\n *\n */\n addClientInfo() {\n this.parameters.set(CLIENT_INFO, \"1\");\n }\n /**\n * add extraQueryParams\n * @param eQParams\n */\n addExtraQueryParameters(eQParams) {\n Object.entries(eQParams).forEach(([key, value]) => {\n if (!this.parameters.has(key) && value) {\n this.parameters.set(key, value);\n }\n });\n }\n addClientCapabilitiesToClaims(claims, clientCapabilities) {\n let mergedClaims;\n // Parse provided claims into JSON object or initialize empty object\n if (!claims) {\n mergedClaims = {};\n }\n else {\n try {\n mergedClaims = JSON.parse(claims);\n }\n catch (e) {\n throw createClientConfigurationError(invalidClaims);\n }\n }\n if (clientCapabilities && clientCapabilities.length > 0) {\n if (!mergedClaims.hasOwnProperty(ClaimsRequestKeys.ACCESS_TOKEN)) {\n // Add access_token key to claims object\n mergedClaims[ClaimsRequestKeys.ACCESS_TOKEN] = {};\n }\n // Add xms_cc claim with provided clientCapabilities to access_token key\n mergedClaims[ClaimsRequestKeys.ACCESS_TOKEN][ClaimsRequestKeys.XMS_CC] = {\n values: clientCapabilities,\n };\n }\n return JSON.stringify(mergedClaims);\n }\n /**\n * adds `username` for Password Grant flow\n * @param username\n */\n addUsername(username) {\n this.parameters.set(PasswordGrantConstants.username, encodeURIComponent(username));\n }\n /**\n * adds `password` for Password Grant flow\n * @param password\n */\n addPassword(password) {\n this.parameters.set(PasswordGrantConstants.password, encodeURIComponent(password));\n }\n /**\n * add pop_jwk to query params\n * @param cnfString\n */\n addPopToken(cnfString) {\n if (cnfString) {\n this.parameters.set(TOKEN_TYPE, AuthenticationScheme.POP);\n this.parameters.set(REQ_CNF, encodeURIComponent(cnfString));\n }\n }\n /**\n * add SSH JWK and key ID to query params\n */\n addSshJwk(sshJwkString) {\n if (sshJwkString) {\n this.parameters.set(TOKEN_TYPE, AuthenticationScheme.SSH);\n this.parameters.set(REQ_CNF, encodeURIComponent(sshJwkString));\n }\n }\n /**\n * add server telemetry fields\n * @param serverTelemetryManager\n */\n addServerTelemetry(serverTelemetryManager) {\n this.parameters.set(X_CLIENT_CURR_TELEM, serverTelemetryManager.generateCurrentRequestHeaderValue());\n this.parameters.set(X_CLIENT_LAST_TELEM, serverTelemetryManager.generateLastRequestHeaderValue());\n }\n /**\n * Adds parameter that indicates to the server that throttling is supported\n */\n addThrottling() {\n this.parameters.set(X_MS_LIB_CAPABILITY, ThrottlingConstants.X_MS_LIB_CAPABILITY_VALUE);\n }\n /**\n * Adds logout_hint parameter for \"silent\" logout which prevent server account picker\n */\n addLogoutHint(logoutHint) {\n this.parameters.set(LOGOUT_HINT, encodeURIComponent(logoutHint));\n }\n /**\n * Utility to create a URL from the params map\n */\n createQueryString() {\n const queryParameterArray = new Array();\n this.parameters.forEach((value, key) => {\n queryParameterArray.push(`${key}=${value}`);\n });\n return queryParameterArray.join(\"&\");\n }\n}\n\nexport { RequestParameterBuilder };\n//# sourceMappingURL=RequestParameterBuilder.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { buildClientConfiguration } from '../config/ClientConfiguration.mjs';\nimport { NetworkManager } from '../network/NetworkManager.mjs';\nimport { Logger } from '../logger/Logger.mjs';\nimport { HeaderNames, Constants } from '../utils/Constants.mjs';\nimport { name, version } from '../packageMetadata.mjs';\nimport { CcsCredentialType } from '../account/CcsCredential.mjs';\nimport { buildClientInfoFromHomeAccountId } from '../account/ClientInfo.mjs';\nimport { RequestParameterBuilder } from '../request/RequestParameterBuilder.mjs';\nimport { createDiscoveredInstance } from '../authority/AuthorityFactory.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Base application class which will construct requests to send to and handle responses from the Microsoft STS using the authorization code flow.\n * @internal\n */\nclass BaseClient {\n constructor(configuration, performanceClient) {\n // Set the configuration\n this.config = buildClientConfiguration(configuration);\n // Initialize the logger\n this.logger = new Logger(this.config.loggerOptions, name, version);\n // Initialize crypto\n this.cryptoUtils = this.config.cryptoInterface;\n // Initialize storage interface\n this.cacheManager = this.config.storageInterface;\n // Set the network interface\n this.networkClient = this.config.networkInterface;\n // Set the NetworkManager\n this.networkManager = new NetworkManager(this.networkClient, this.cacheManager);\n // Set TelemetryManager\n this.serverTelemetryManager = this.config.serverTelemetryManager;\n // set Authority\n this.authority = this.config.authOptions.authority;\n // set performance telemetry client\n this.performanceClient = performanceClient;\n }\n /**\n * Creates default headers for requests to token endpoint\n */\n createTokenRequestHeaders(ccsCred) {\n const headers = {};\n headers[HeaderNames.CONTENT_TYPE] = Constants.URL_FORM_CONTENT_TYPE;\n if (!this.config.systemOptions.preventCorsPreflight && ccsCred) {\n switch (ccsCred.type) {\n case CcsCredentialType.HOME_ACCOUNT_ID:\n try {\n const clientInfo = buildClientInfoFromHomeAccountId(ccsCred.credential);\n headers[HeaderNames.CCS_HEADER] = `Oid:${clientInfo.uid}@${clientInfo.utid}`;\n }\n catch (e) {\n this.logger.verbose(\"Could not parse home account ID for CCS Header: \" +\n e);\n }\n break;\n case CcsCredentialType.UPN:\n headers[HeaderNames.CCS_HEADER] = `UPN: ${ccsCred.credential}`;\n break;\n }\n }\n return headers;\n }\n /**\n * Http post to token endpoint\n * @param tokenEndpoint\n * @param queryString\n * @param headers\n * @param thumbprint\n */\n async executePostToTokenEndpoint(tokenEndpoint, queryString, headers, thumbprint, correlationId, queuedEvent) {\n if (queuedEvent) {\n this.performanceClient?.addQueueMeasurement(queuedEvent, correlationId);\n }\n const response = await this.networkManager.sendPostRequest(thumbprint, tokenEndpoint, { body: queryString, headers: headers });\n this.performanceClient?.addFields({\n refreshTokenSize: response.body.refresh_token?.length || 0,\n httpVerToken: response.headers?.[HeaderNames.X_MS_HTTP_VERSION] || \"\",\n }, correlationId);\n if (this.config.serverTelemetryManager &&\n response.status < 500 &&\n response.status !== 429) {\n // Telemetry data successfully logged by server, clear Telemetry cache\n this.config.serverTelemetryManager.clearTelemetryCache();\n }\n return response;\n }\n /**\n * Updates the authority object of the client. Endpoint discovery must be completed.\n * @param updatedAuthority\n */\n async updateAuthority(cloudInstanceHostname, correlationId) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.UpdateTokenEndpointAuthority, correlationId);\n const cloudInstanceAuthorityUri = `https://${cloudInstanceHostname}/${this.authority.tenant}/`;\n const cloudInstanceAuthority = await createDiscoveredInstance(cloudInstanceAuthorityUri, this.networkClient, this.cacheManager, this.authority.options, this.logger, correlationId, this.performanceClient);\n this.authority = cloudInstanceAuthority;\n }\n /**\n * Creates query string for the /token request\n * @param request\n */\n createTokenQueryParameters(request) {\n const parameterBuilder = new RequestParameterBuilder();\n if (request.tokenQueryParameters) {\n parameterBuilder.addExtraQueryParameters(request.tokenQueryParameters);\n }\n return parameterBuilder.createQueryString();\n }\n}\n\nexport { BaseClient };\n//# sourceMappingURL=BaseClient.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n// Codes defined by MSAL\nconst noTokensFound = \"no_tokens_found\";\nconst nativeAccountUnavailable = \"native_account_unavailable\";\nconst refreshTokenExpired = \"refresh_token_expired\";\n// Codes potentially returned by server\nconst interactionRequired = \"interaction_required\";\nconst consentRequired = \"consent_required\";\nconst loginRequired = \"login_required\";\nconst badToken = \"bad_token\";\n\nexport { badToken, consentRequired, interactionRequired, loginRequired, nativeAccountUnavailable, noTokensFound, refreshTokenExpired };\n//# sourceMappingURL=InteractionRequiredAuthErrorCodes.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Constants } from '../utils/Constants.mjs';\nimport { AuthError } from './AuthError.mjs';\nimport { noTokensFound, nativeAccountUnavailable, badToken, refreshTokenExpired, interactionRequired, consentRequired, loginRequired } from './InteractionRequiredAuthErrorCodes.mjs';\nimport * as InteractionRequiredAuthErrorCodes from './InteractionRequiredAuthErrorCodes.mjs';\nexport { InteractionRequiredAuthErrorCodes };\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * InteractionRequiredServerErrorMessage contains string constants used by error codes and messages returned by the server indicating interaction is required\n */\nconst InteractionRequiredServerErrorMessage = [\n interactionRequired,\n consentRequired,\n loginRequired,\n badToken,\n];\nconst InteractionRequiredAuthSubErrorMessage = [\n \"message_only\",\n \"additional_action\",\n \"basic_action\",\n \"user_password_expired\",\n \"consent_required\",\n \"bad_token\",\n];\nconst InteractionRequiredAuthErrorMessages = {\n [noTokensFound]: \"No refresh token found in the cache. Please sign-in.\",\n [nativeAccountUnavailable]: \"The requested account is not available in the native broker. It may have been deleted or logged out. Please sign-in again using an interactive API.\",\n [refreshTokenExpired]: \"Refresh token has expired.\",\n [badToken]: \"Identity provider returned bad_token due to an expired or invalid refresh token. Please invoke an interactive API to resolve.\",\n};\n/**\n * Interaction required errors defined by the SDK\n * @deprecated Use InteractionRequiredAuthErrorCodes instead\n */\nconst InteractionRequiredAuthErrorMessage = {\n noTokensFoundError: {\n code: noTokensFound,\n desc: InteractionRequiredAuthErrorMessages[noTokensFound],\n },\n native_account_unavailable: {\n code: nativeAccountUnavailable,\n desc: InteractionRequiredAuthErrorMessages[nativeAccountUnavailable],\n },\n bad_token: {\n code: badToken,\n desc: InteractionRequiredAuthErrorMessages[badToken],\n },\n};\n/**\n * Error thrown when user interaction is required.\n */\nclass InteractionRequiredAuthError extends AuthError {\n constructor(errorCode, errorMessage, subError, timestamp, traceId, correlationId, claims, errorNo) {\n super(errorCode, errorMessage, subError);\n Object.setPrototypeOf(this, InteractionRequiredAuthError.prototype);\n this.timestamp = timestamp || Constants.EMPTY_STRING;\n this.traceId = traceId || Constants.EMPTY_STRING;\n this.correlationId = correlationId || Constants.EMPTY_STRING;\n this.claims = claims || Constants.EMPTY_STRING;\n this.name = \"InteractionRequiredAuthError\";\n this.errorNo = errorNo;\n }\n}\n/**\n * Helper function used to determine if an error thrown by the server requires interaction to resolve\n * @param errorCode\n * @param errorString\n * @param subError\n */\nfunction isInteractionRequiredError(errorCode, errorString, subError) {\n const isInteractionRequiredErrorCode = !!errorCode &&\n InteractionRequiredServerErrorMessage.indexOf(errorCode) > -1;\n const isInteractionRequiredSubError = !!subError &&\n InteractionRequiredAuthSubErrorMessage.indexOf(subError) > -1;\n const isInteractionRequiredErrorDesc = !!errorString &&\n InteractionRequiredServerErrorMessage.some((irErrorCode) => {\n return errorString.indexOf(irErrorCode) > -1;\n });\n return (isInteractionRequiredErrorCode ||\n isInteractionRequiredErrorDesc ||\n isInteractionRequiredSubError);\n}\n/**\n * Creates an InteractionRequiredAuthError\n */\nfunction createInteractionRequiredAuthError(errorCode) {\n return new InteractionRequiredAuthError(errorCode, InteractionRequiredAuthErrorMessages[errorCode]);\n}\n\nexport { InteractionRequiredAuthError, InteractionRequiredAuthErrorMessage, InteractionRequiredAuthSubErrorMessage, InteractionRequiredServerErrorMessage, createInteractionRequiredAuthError, isInteractionRequiredError };\n//# sourceMappingURL=InteractionRequiredAuthError.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { Constants } from './Constants.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { noCryptoObject, invalidState } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Class which provides helpers for OAuth 2.0 protocol specific values\n */\nclass ProtocolUtils {\n /**\n * Appends user state with random guid, or returns random guid.\n * @param userState\n * @param randomGuid\n */\n static setRequestState(cryptoObj, userState, meta) {\n const libraryState = ProtocolUtils.generateLibraryState(cryptoObj, meta);\n return userState\n ? `${libraryState}${Constants.RESOURCE_DELIM}${userState}`\n : libraryState;\n }\n /**\n * Generates the state value used by the common library.\n * @param randomGuid\n * @param cryptoObj\n */\n static generateLibraryState(cryptoObj, meta) {\n if (!cryptoObj) {\n throw createClientAuthError(noCryptoObject);\n }\n // Create a state object containing a unique id and the timestamp of the request creation\n const stateObj = {\n id: cryptoObj.createNewGuid(),\n };\n if (meta) {\n stateObj.meta = meta;\n }\n const stateString = JSON.stringify(stateObj);\n return cryptoObj.base64Encode(stateString);\n }\n /**\n * Parses the state into the RequestStateObject, which contains the LibraryState info and the state passed by the user.\n * @param state\n * @param cryptoObj\n */\n static parseRequestState(cryptoObj, state) {\n if (!cryptoObj) {\n throw createClientAuthError(noCryptoObject);\n }\n if (!state) {\n throw createClientAuthError(invalidState);\n }\n try {\n // Split the state between library state and user passed state and decode them separately\n const splitState = state.split(Constants.RESOURCE_DELIM);\n const libraryState = splitState[0];\n const userState = splitState.length > 1\n ? splitState.slice(1).join(Constants.RESOURCE_DELIM)\n : Constants.EMPTY_STRING;\n const libraryStateString = cryptoObj.base64Decode(libraryState);\n const libraryStateObj = JSON.parse(libraryStateString);\n return {\n userRequestState: userState || Constants.EMPTY_STRING,\n libraryState: libraryStateObj,\n };\n }\n catch (e) {\n throw createClientAuthError(invalidState);\n }\n }\n}\n\nexport { ProtocolUtils };\n//# sourceMappingURL=ProtocolUtils.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { nowSeconds } from '../utils/TimeUtils.mjs';\nimport { UrlString } from '../url/UrlString.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { invokeAsync } from '../utils/FunctionWrappers.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst KeyLocation = {\n SW: \"sw\",\n UHW: \"uhw\",\n};\n/** @internal */\nclass PopTokenGenerator {\n constructor(cryptoUtils, performanceClient) {\n this.cryptoUtils = cryptoUtils;\n this.performanceClient = performanceClient;\n }\n /**\n * Generates the req_cnf validated at the RP in the POP protocol for SHR parameters\n * and returns an object containing the keyid, the full req_cnf string and the req_cnf string hash\n * @param request\n * @returns\n */\n async generateCnf(request, logger) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.PopTokenGenerateCnf, request.correlationId);\n const reqCnf = await invokeAsync(this.generateKid.bind(this), PerformanceEvents.PopTokenGenerateCnf, logger, this.performanceClient, request.correlationId)(request);\n const reqCnfString = this.cryptoUtils.base64UrlEncode(JSON.stringify(reqCnf));\n return {\n kid: reqCnf.kid,\n reqCnfString,\n };\n }\n /**\n * Generates key_id for a SHR token request\n * @param request\n * @returns\n */\n async generateKid(request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.PopTokenGenerateKid, request.correlationId);\n const kidThumbprint = await this.cryptoUtils.getPublicKeyThumbprint(request);\n return {\n kid: kidThumbprint,\n xms_ksl: KeyLocation.SW,\n };\n }\n /**\n * Signs the POP access_token with the local generated key-pair\n * @param accessToken\n * @param request\n * @returns\n */\n async signPopToken(accessToken, keyId, request) {\n return this.signPayload(accessToken, keyId, request);\n }\n /**\n * Utility function to generate the signed JWT for an access_token\n * @param payload\n * @param kid\n * @param request\n * @param claims\n * @returns\n */\n async signPayload(payload, keyId, request, claims) {\n // Deconstruct request to extract SHR parameters\n const { resourceRequestMethod, resourceRequestUri, shrClaims, shrNonce, shrOptions, } = request;\n const resourceUrlString = resourceRequestUri\n ? new UrlString(resourceRequestUri)\n : undefined;\n const resourceUrlComponents = resourceUrlString?.getUrlComponents();\n return this.cryptoUtils.signJwt({\n at: payload,\n ts: nowSeconds(),\n m: resourceRequestMethod?.toUpperCase(),\n u: resourceUrlComponents?.HostNameAndPort,\n nonce: shrNonce || this.cryptoUtils.createNewGuid(),\n p: resourceUrlComponents?.AbsolutePath,\n q: resourceUrlComponents?.QueryString\n ? [[], resourceUrlComponents.QueryString]\n : undefined,\n client_claims: shrClaims || undefined,\n ...claims,\n }, keyId, shrOptions, request.correlationId);\n }\n}\n\nexport { PopTokenGenerator };\n//# sourceMappingURL=PopTokenGenerator.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * This class instance helps track the memory changes facilitating\n * decisions to read from and write to the persistent cache\n */ class TokenCacheContext {\n constructor(tokenCache, hasChanged) {\n this.cache = tokenCache;\n this.hasChanged = hasChanged;\n }\n /**\n * boolean which indicates the changes in cache\n */\n get cacheHasChanged() {\n return this.hasChanged;\n }\n /**\n * function to retrieve the token cache\n */\n get tokenCache() {\n return this.cache;\n }\n}\n\nexport { TokenCacheContext };\n//# sourceMappingURL=TokenCacheContext.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { ServerError } from '../error/ServerError.mjs';\nimport { ScopeSet } from '../request/ScopeSet.mjs';\nimport { AccountEntity } from '../cache/entities/AccountEntity.mjs';\nimport { isInteractionRequiredError, InteractionRequiredAuthError } from '../error/InteractionRequiredAuthError.mjs';\nimport { ProtocolUtils } from '../utils/ProtocolUtils.mjs';\nimport { HttpStatus, Constants, AuthenticationScheme, THE_FAMILY_ID } from '../utils/Constants.mjs';\nimport { PopTokenGenerator } from '../crypto/PopTokenGenerator.mjs';\nimport { TokenCacheContext } from '../cache/persistence/TokenCacheContext.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { extractTokenClaims, checkMaxAge } from '../account/AuthToken.mjs';\nimport { getTenantIdFromIdTokenClaims } from '../account/TokenClaims.mjs';\nimport { updateAccountTenantProfileData, buildTenantProfile } from '../account/AccountInfo.mjs';\nimport { createAccessTokenEntity, createRefreshTokenEntity, createIdTokenEntity } from '../cache/utils/CacheHelpers.mjs';\nimport { stateNotFound, invalidState, stateMismatch, nonceMismatch, authTimeNotFound, invalidCacheEnvironment, keyIdMissing } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nfunction parseServerErrorNo(serverResponse) {\n const errorCodePrefix = \"code=\";\n const errorCodePrefixIndex = serverResponse.error_uri?.lastIndexOf(errorCodePrefix);\n return errorCodePrefixIndex && errorCodePrefixIndex >= 0\n ? serverResponse.error_uri?.substring(errorCodePrefixIndex + errorCodePrefix.length)\n : undefined;\n}\n/**\n * Class that handles response parsing.\n * @internal\n */\nclass ResponseHandler {\n constructor(clientId, cacheStorage, cryptoObj, logger, serializableCache, persistencePlugin, performanceClient) {\n this.clientId = clientId;\n this.cacheStorage = cacheStorage;\n this.cryptoObj = cryptoObj;\n this.logger = logger;\n this.serializableCache = serializableCache;\n this.persistencePlugin = persistencePlugin;\n this.performanceClient = performanceClient;\n }\n /**\n * Function which validates server authorization code response.\n * @param serverResponseHash\n * @param requestState\n * @param cryptoObj\n */\n validateServerAuthorizationCodeResponse(serverResponse, requestState) {\n if (!serverResponse.state || !requestState) {\n throw serverResponse.state\n ? createClientAuthError(stateNotFound, \"Cached State\")\n : createClientAuthError(stateNotFound, \"Server State\");\n }\n let decodedServerResponseState;\n let decodedRequestState;\n try {\n decodedServerResponseState = decodeURIComponent(serverResponse.state);\n }\n catch (e) {\n throw createClientAuthError(invalidState, serverResponse.state);\n }\n try {\n decodedRequestState = decodeURIComponent(requestState);\n }\n catch (e) {\n throw createClientAuthError(invalidState, serverResponse.state);\n }\n if (decodedServerResponseState !== decodedRequestState) {\n throw createClientAuthError(stateMismatch);\n }\n // Check for error\n if (serverResponse.error ||\n serverResponse.error_description ||\n serverResponse.suberror) {\n const serverErrorNo = parseServerErrorNo(serverResponse);\n if (isInteractionRequiredError(serverResponse.error, serverResponse.error_description, serverResponse.suberror)) {\n throw new InteractionRequiredAuthError(serverResponse.error || \"\", serverResponse.error_description, serverResponse.suberror, serverResponse.timestamp || \"\", serverResponse.trace_id || \"\", serverResponse.correlation_id || \"\", serverResponse.claims || \"\", serverErrorNo);\n }\n throw new ServerError(serverResponse.error || \"\", serverResponse.error_description, serverResponse.suberror, serverErrorNo);\n }\n }\n /**\n * Function which validates server authorization token response.\n * @param serverResponse\n * @param refreshAccessToken\n */\n validateTokenResponse(serverResponse, refreshAccessToken) {\n // Check for error\n if (serverResponse.error ||\n serverResponse.error_description ||\n serverResponse.suberror) {\n const errString = `Error(s): ${serverResponse.error_codes || Constants.NOT_AVAILABLE} - Timestamp: ${serverResponse.timestamp || Constants.NOT_AVAILABLE} - Description: ${serverResponse.error_description || Constants.NOT_AVAILABLE} - Correlation ID: ${serverResponse.correlation_id || Constants.NOT_AVAILABLE} - Trace ID: ${serverResponse.trace_id || Constants.NOT_AVAILABLE}`;\n const serverErrorNo = serverResponse.error_codes?.length\n ? serverResponse.error_codes[0]\n : undefined;\n const serverError = new ServerError(serverResponse.error, errString, serverResponse.suberror, serverErrorNo, serverResponse.status);\n // check if 500 error\n if (refreshAccessToken &&\n serverResponse.status &&\n serverResponse.status >= HttpStatus.SERVER_ERROR_RANGE_START &&\n serverResponse.status <= HttpStatus.SERVER_ERROR_RANGE_END) {\n this.logger.warning(`executeTokenRequest:validateTokenResponse - AAD is currently unavailable and the access token is unable to be refreshed.\\n${serverError}`);\n // don't throw an exception, but alert the user via a log that the token was unable to be refreshed\n return;\n // check if 400 error\n }\n else if (refreshAccessToken &&\n serverResponse.status &&\n serverResponse.status >= HttpStatus.CLIENT_ERROR_RANGE_START &&\n serverResponse.status <= HttpStatus.CLIENT_ERROR_RANGE_END) {\n this.logger.warning(`executeTokenRequest:validateTokenResponse - AAD is currently available but is unable to refresh the access token.\\n${serverError}`);\n // don't throw an exception, but alert the user via a log that the token was unable to be refreshed\n return;\n }\n if (isInteractionRequiredError(serverResponse.error, serverResponse.error_description, serverResponse.suberror)) {\n throw new InteractionRequiredAuthError(serverResponse.error, serverResponse.error_description, serverResponse.suberror, serverResponse.timestamp || Constants.EMPTY_STRING, serverResponse.trace_id || Constants.EMPTY_STRING, serverResponse.correlation_id || Constants.EMPTY_STRING, serverResponse.claims || Constants.EMPTY_STRING, serverErrorNo);\n }\n throw serverError;\n }\n }\n /**\n * Returns a constructed token response based on given string. Also manages the cache updates and cleanups.\n * @param serverTokenResponse\n * @param authority\n */\n async handleServerTokenResponse(serverTokenResponse, authority, reqTimestamp, request, authCodePayload, userAssertionHash, handlingRefreshTokenResponse, forceCacheRefreshTokenResponse, serverRequestId) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.HandleServerTokenResponse, serverTokenResponse.correlation_id);\n // create an idToken object (not entity)\n let idTokenClaims;\n if (serverTokenResponse.id_token) {\n idTokenClaims = extractTokenClaims(serverTokenResponse.id_token || Constants.EMPTY_STRING, this.cryptoObj.base64Decode);\n // token nonce check (TODO: Add a warning if no nonce is given?)\n if (authCodePayload && authCodePayload.nonce) {\n if (idTokenClaims.nonce !== authCodePayload.nonce) {\n throw createClientAuthError(nonceMismatch);\n }\n }\n // token max_age check\n if (request.maxAge || request.maxAge === 0) {\n const authTime = idTokenClaims.auth_time;\n if (!authTime) {\n throw createClientAuthError(authTimeNotFound);\n }\n checkMaxAge(authTime, request.maxAge);\n }\n }\n // generate homeAccountId\n this.homeAccountIdentifier = AccountEntity.generateHomeAccountId(serverTokenResponse.client_info || Constants.EMPTY_STRING, authority.authorityType, this.logger, this.cryptoObj, idTokenClaims);\n // save the response tokens\n let requestStateObj;\n if (!!authCodePayload && !!authCodePayload.state) {\n requestStateObj = ProtocolUtils.parseRequestState(this.cryptoObj, authCodePayload.state);\n }\n // Add keyId from request to serverTokenResponse if defined\n serverTokenResponse.key_id =\n serverTokenResponse.key_id || request.sshKid || undefined;\n const cacheRecord = this.generateCacheRecord(serverTokenResponse, authority, reqTimestamp, request, idTokenClaims, userAssertionHash, authCodePayload);\n let cacheContext;\n try {\n if (this.persistencePlugin && this.serializableCache) {\n this.logger.verbose(\"Persistence enabled, calling beforeCacheAccess\");\n cacheContext = new TokenCacheContext(this.serializableCache, true);\n await this.persistencePlugin.beforeCacheAccess(cacheContext);\n }\n /*\n * When saving a refreshed tokens to the cache, it is expected that the account that was used is present in the cache.\n * If not present, we should return null, as it's the case that another application called removeAccount in between\n * the calls to getAllAccounts and acquireTokenSilent. We should not overwrite that removal, unless explicitly flagged by\n * the developer, as in the case of refresh token flow used in ADAL Node to MSAL Node migration.\n */\n if (handlingRefreshTokenResponse &&\n !forceCacheRefreshTokenResponse &&\n cacheRecord.account) {\n const key = cacheRecord.account.generateAccountKey();\n const account = this.cacheStorage.getAccount(key, this.logger);\n if (!account) {\n this.logger.warning(\"Account used to refresh tokens not in persistence, refreshed tokens will not be stored in the cache\");\n return await ResponseHandler.generateAuthenticationResult(this.cryptoObj, authority, cacheRecord, false, request, idTokenClaims, requestStateObj, undefined, serverRequestId);\n }\n }\n await this.cacheStorage.saveCacheRecord(cacheRecord, request.storeInCache, request.correlationId);\n }\n finally {\n if (this.persistencePlugin &&\n this.serializableCache &&\n cacheContext) {\n this.logger.verbose(\"Persistence enabled, calling afterCacheAccess\");\n await this.persistencePlugin.afterCacheAccess(cacheContext);\n }\n }\n return ResponseHandler.generateAuthenticationResult(this.cryptoObj, authority, cacheRecord, false, request, idTokenClaims, requestStateObj, serverTokenResponse, serverRequestId);\n }\n /**\n * Generates CacheRecord\n * @param serverTokenResponse\n * @param idTokenObj\n * @param authority\n */\n generateCacheRecord(serverTokenResponse, authority, reqTimestamp, request, idTokenClaims, userAssertionHash, authCodePayload) {\n const env = authority.getPreferredCache();\n if (!env) {\n throw createClientAuthError(invalidCacheEnvironment);\n }\n const claimsTenantId = getTenantIdFromIdTokenClaims(idTokenClaims);\n // IdToken: non AAD scenarios can have empty realm\n let cachedIdToken;\n let cachedAccount;\n if (serverTokenResponse.id_token && !!idTokenClaims) {\n cachedIdToken = createIdTokenEntity(this.homeAccountIdentifier, env, serverTokenResponse.id_token, this.clientId, claimsTenantId || \"\");\n cachedAccount = buildAccountToCache(this.cacheStorage, authority, this.homeAccountIdentifier, this.cryptoObj.base64Decode, idTokenClaims, serverTokenResponse.client_info, env, claimsTenantId, authCodePayload, undefined, // nativeAccountId\n this.logger);\n }\n // AccessToken\n let cachedAccessToken = null;\n if (serverTokenResponse.access_token) {\n // If scopes not returned in server response, use request scopes\n const responseScopes = serverTokenResponse.scope\n ? ScopeSet.fromString(serverTokenResponse.scope)\n : new ScopeSet(request.scopes || []);\n /*\n * Use timestamp calculated before request\n * Server may return timestamps as strings, parse to numbers if so.\n */\n const expiresIn = (typeof serverTokenResponse.expires_in === \"string\"\n ? parseInt(serverTokenResponse.expires_in, 10)\n : serverTokenResponse.expires_in) || 0;\n const extExpiresIn = (typeof serverTokenResponse.ext_expires_in === \"string\"\n ? parseInt(serverTokenResponse.ext_expires_in, 10)\n : serverTokenResponse.ext_expires_in) || 0;\n const refreshIn = (typeof serverTokenResponse.refresh_in === \"string\"\n ? parseInt(serverTokenResponse.refresh_in, 10)\n : serverTokenResponse.refresh_in) || undefined;\n const tokenExpirationSeconds = reqTimestamp + expiresIn;\n const extendedTokenExpirationSeconds = tokenExpirationSeconds + extExpiresIn;\n const refreshOnSeconds = refreshIn && refreshIn > 0\n ? reqTimestamp + refreshIn\n : undefined;\n // non AAD scenarios can have empty realm\n cachedAccessToken = createAccessTokenEntity(this.homeAccountIdentifier, env, serverTokenResponse.access_token, this.clientId, claimsTenantId || authority.tenant || \"\", responseScopes.printScopes(), tokenExpirationSeconds, extendedTokenExpirationSeconds, this.cryptoObj.base64Decode, refreshOnSeconds, serverTokenResponse.token_type, userAssertionHash, serverTokenResponse.key_id, request.claims, request.requestedClaimsHash);\n }\n // refreshToken\n let cachedRefreshToken = null;\n if (serverTokenResponse.refresh_token) {\n let rtExpiresOn;\n if (serverTokenResponse.refresh_token_expires_in) {\n const rtExpiresIn = typeof serverTokenResponse.refresh_token_expires_in ===\n \"string\"\n ? parseInt(serverTokenResponse.refresh_token_expires_in, 10)\n : serverTokenResponse.refresh_token_expires_in;\n rtExpiresOn = reqTimestamp + rtExpiresIn;\n }\n cachedRefreshToken = createRefreshTokenEntity(this.homeAccountIdentifier, env, serverTokenResponse.refresh_token, this.clientId, serverTokenResponse.foci, userAssertionHash, rtExpiresOn);\n }\n // appMetadata\n let cachedAppMetadata = null;\n if (serverTokenResponse.foci) {\n cachedAppMetadata = {\n clientId: this.clientId,\n environment: env,\n familyId: serverTokenResponse.foci,\n };\n }\n return {\n account: cachedAccount,\n idToken: cachedIdToken,\n accessToken: cachedAccessToken,\n refreshToken: cachedRefreshToken,\n appMetadata: cachedAppMetadata,\n };\n }\n /**\n * Creates an @AuthenticationResult from @CacheRecord , @IdToken , and a boolean that states whether or not the result is from cache.\n *\n * Optionally takes a state string that is set as-is in the response.\n *\n * @param cacheRecord\n * @param idTokenObj\n * @param fromTokenCache\n * @param stateString\n */\n static async generateAuthenticationResult(cryptoObj, authority, cacheRecord, fromTokenCache, request, idTokenClaims, requestState, serverTokenResponse, requestId) {\n let accessToken = Constants.EMPTY_STRING;\n let responseScopes = [];\n let expiresOn = null;\n let extExpiresOn;\n let refreshOn;\n let familyId = Constants.EMPTY_STRING;\n if (cacheRecord.accessToken) {\n /*\n * if the request object has `popKid` property, `signPopToken` will be set to false and\n * the token will be returned unsigned\n */\n if (cacheRecord.accessToken.tokenType ===\n AuthenticationScheme.POP &&\n !request.popKid) {\n const popTokenGenerator = new PopTokenGenerator(cryptoObj);\n const { secret, keyId } = cacheRecord.accessToken;\n if (!keyId) {\n throw createClientAuthError(keyIdMissing);\n }\n accessToken = await popTokenGenerator.signPopToken(secret, keyId, request);\n }\n else {\n accessToken = cacheRecord.accessToken.secret;\n }\n responseScopes = ScopeSet.fromString(cacheRecord.accessToken.target).asArray();\n expiresOn = new Date(Number(cacheRecord.accessToken.expiresOn) * 1000);\n extExpiresOn = new Date(Number(cacheRecord.accessToken.extendedExpiresOn) * 1000);\n if (cacheRecord.accessToken.refreshOn) {\n refreshOn = new Date(Number(cacheRecord.accessToken.refreshOn) * 1000);\n }\n }\n if (cacheRecord.appMetadata) {\n familyId =\n cacheRecord.appMetadata.familyId === THE_FAMILY_ID\n ? THE_FAMILY_ID\n : \"\";\n }\n const uid = idTokenClaims?.oid || idTokenClaims?.sub || \"\";\n const tid = idTokenClaims?.tid || \"\";\n // for hybrid + native bridge enablement, send back the native account Id\n if (serverTokenResponse?.spa_accountid && !!cacheRecord.account) {\n cacheRecord.account.nativeAccountId =\n serverTokenResponse?.spa_accountid;\n }\n const accountInfo = cacheRecord.account\n ? updateAccountTenantProfileData(cacheRecord.account.getAccountInfo(), undefined, // tenantProfile optional\n idTokenClaims, cacheRecord.idToken?.secret)\n : null;\n return {\n authority: authority.canonicalAuthority,\n uniqueId: uid,\n tenantId: tid,\n scopes: responseScopes,\n account: accountInfo,\n idToken: cacheRecord?.idToken?.secret || \"\",\n idTokenClaims: idTokenClaims || {},\n accessToken: accessToken,\n fromCache: fromTokenCache,\n expiresOn: expiresOn,\n extExpiresOn: extExpiresOn,\n refreshOn: refreshOn,\n correlationId: request.correlationId,\n requestId: requestId || Constants.EMPTY_STRING,\n familyId: familyId,\n tokenType: cacheRecord.accessToken?.tokenType || Constants.EMPTY_STRING,\n state: requestState\n ? requestState.userRequestState\n : Constants.EMPTY_STRING,\n cloudGraphHostName: cacheRecord.account?.cloudGraphHostName ||\n Constants.EMPTY_STRING,\n msGraphHost: cacheRecord.account?.msGraphHost || Constants.EMPTY_STRING,\n code: serverTokenResponse?.spa_code,\n fromNativeBroker: false,\n };\n }\n}\nfunction buildAccountToCache(cacheStorage, authority, homeAccountId, base64Decode, idTokenClaims, clientInfo, environment, claimsTenantId, authCodePayload, nativeAccountId, logger) {\n logger?.verbose(\"setCachedAccount called\");\n // Check if base account is already cached\n const accountKeys = cacheStorage.getAccountKeys();\n const baseAccountKey = accountKeys.find((accountKey) => {\n return accountKey.startsWith(homeAccountId);\n });\n let cachedAccount = null;\n if (baseAccountKey) {\n cachedAccount = cacheStorage.getAccount(baseAccountKey, logger);\n }\n const baseAccount = cachedAccount ||\n AccountEntity.createAccount({\n homeAccountId,\n idTokenClaims,\n clientInfo,\n environment,\n cloudGraphHostName: authCodePayload?.cloud_graph_host_name,\n msGraphHost: authCodePayload?.msgraph_host,\n nativeAccountId: nativeAccountId,\n }, authority, base64Decode);\n const tenantProfiles = baseAccount.tenantProfiles || [];\n const tenantId = claimsTenantId || baseAccount.realm;\n if (tenantId &&\n !tenantProfiles.find((tenantProfile) => {\n return tenantProfile.tenantId === tenantId;\n })) {\n const newTenantProfile = buildTenantProfile(homeAccountId, baseAccount.localAccountId, tenantId, idTokenClaims);\n tenantProfiles.push(newTenantProfile);\n }\n baseAccount.tenantProfiles = tenantProfiles;\n return baseAccount;\n}\n\nexport { ResponseHandler, buildAccountToCache };\n//# sourceMappingURL=ResponseHandler.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { BaseClient } from './BaseClient.mjs';\nimport { RequestParameterBuilder } from '../request/RequestParameterBuilder.mjs';\nimport { Separators, GrantType, AuthenticationScheme, PromptValue, HeaderNames } from '../utils/Constants.mjs';\nimport { CLIENT_ID, RETURN_SPA_CODE } from '../constants/AADServerParamKeys.mjs';\nimport { isOidcProtocolMode } from '../config/ClientConfiguration.mjs';\nimport { ResponseHandler } from '../response/ResponseHandler.mjs';\nimport { StringUtils } from '../utils/StringUtils.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { UrlString } from '../url/UrlString.mjs';\nimport { PopTokenGenerator } from '../crypto/PopTokenGenerator.mjs';\nimport { nowSeconds } from '../utils/TimeUtils.mjs';\nimport { buildClientInfo, buildClientInfoFromHomeAccountId } from '../account/ClientInfo.mjs';\nimport { CcsCredentialType } from '../account/CcsCredential.mjs';\nimport { createClientConfigurationError } from '../error/ClientConfigurationError.mjs';\nimport { RequestValidator } from '../request/RequestValidator.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { invokeAsync } from '../utils/FunctionWrappers.mjs';\nimport { getClientAssertion } from '../utils/ClientAssertionUtils.mjs';\nimport { requestCannotBeMade, authorizationCodeMissingFromServerResponse } from '../error/ClientAuthErrorCodes.mjs';\nimport { logoutRequestEmpty, missingSshJwk } from '../error/ClientConfigurationErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Oauth2.0 Authorization Code client\n * @internal\n */\nclass AuthorizationCodeClient extends BaseClient {\n constructor(configuration, performanceClient) {\n super(configuration, performanceClient);\n // Flag to indicate if client is for hybrid spa auth code redemption\n this.includeRedirectUri = true;\n this.oidcDefaultScopes =\n this.config.authOptions.authority.options.OIDCOptions?.defaultScopes;\n }\n /**\n * Creates the URL of the authorization request letting the user input credentials and consent to the\n * application. The URL target the /authorize endpoint of the authority configured in the\n * application object.\n *\n * Once the user inputs their credentials and consents, the authority will send a response to the redirect URI\n * sent in the request and should contain an authorization code, which can then be used to acquire tokens via\n * acquireToken(AuthorizationCodeRequest)\n * @param request\n */\n async getAuthCodeUrl(request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.GetAuthCodeUrl, request.correlationId);\n const queryString = await invokeAsync(this.createAuthCodeUrlQueryString.bind(this), PerformanceEvents.AuthClientCreateQueryString, this.logger, this.performanceClient, request.correlationId)(request);\n return UrlString.appendQueryString(this.authority.authorizationEndpoint, queryString);\n }\n /**\n * API to acquire a token in exchange of 'authorization_code` acquired by the user in the first leg of the\n * authorization_code_grant\n * @param request\n */\n async acquireToken(request, authCodePayload) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthClientAcquireToken, request.correlationId);\n if (!request.code) {\n throw createClientAuthError(requestCannotBeMade);\n }\n const reqTimestamp = nowSeconds();\n const response = await invokeAsync(this.executeTokenRequest.bind(this), PerformanceEvents.AuthClientExecuteTokenRequest, this.logger, this.performanceClient, request.correlationId)(this.authority, request);\n // Retrieve requestId from response headers\n const requestId = response.headers?.[HeaderNames.X_MS_REQUEST_ID];\n const responseHandler = new ResponseHandler(this.config.authOptions.clientId, this.cacheManager, this.cryptoUtils, this.logger, this.config.serializableCache, this.config.persistencePlugin, this.performanceClient);\n // Validate response. This function throws a server error if an error is returned by the server.\n responseHandler.validateTokenResponse(response.body);\n return invokeAsync(responseHandler.handleServerTokenResponse.bind(responseHandler), PerformanceEvents.HandleServerTokenResponse, this.logger, this.performanceClient, request.correlationId)(response.body, this.authority, reqTimestamp, request, authCodePayload, undefined, undefined, undefined, requestId);\n }\n /**\n * Handles the hash fragment response from public client code request. Returns a code response used by\n * the client to exchange for a token in acquireToken.\n * @param hashFragment\n */\n handleFragmentResponse(serverParams, cachedState) {\n // Handle responses.\n const responseHandler = new ResponseHandler(this.config.authOptions.clientId, this.cacheManager, this.cryptoUtils, this.logger, null, null);\n // Get code response\n responseHandler.validateServerAuthorizationCodeResponse(serverParams, cachedState);\n // throw when there is no auth code in the response\n if (!serverParams.code) {\n throw createClientAuthError(authorizationCodeMissingFromServerResponse);\n }\n return serverParams;\n }\n /**\n * Used to log out the current user, and redirect the user to the postLogoutRedirectUri.\n * Default behaviour is to redirect the user to `window.location.href`.\n * @param authorityUri\n */\n getLogoutUri(logoutRequest) {\n // Throw error if logoutRequest is null/undefined\n if (!logoutRequest) {\n throw createClientConfigurationError(logoutRequestEmpty);\n }\n const queryString = this.createLogoutUrlQueryString(logoutRequest);\n // Construct logout URI\n return UrlString.appendQueryString(this.authority.endSessionEndpoint, queryString);\n }\n /**\n * Executes POST request to token endpoint\n * @param authority\n * @param request\n */\n async executeTokenRequest(authority, request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthClientExecuteTokenRequest, request.correlationId);\n const queryParametersString = this.createTokenQueryParameters(request);\n const endpoint = UrlString.appendQueryString(authority.tokenEndpoint, queryParametersString);\n const requestBody = await invokeAsync(this.createTokenRequestBody.bind(this), PerformanceEvents.AuthClientCreateTokenRequestBody, this.logger, this.performanceClient, request.correlationId)(request);\n let ccsCredential = undefined;\n if (request.clientInfo) {\n try {\n const clientInfo = buildClientInfo(request.clientInfo, this.cryptoUtils.base64Decode);\n ccsCredential = {\n credential: `${clientInfo.uid}${Separators.CLIENT_INFO_SEPARATOR}${clientInfo.utid}`,\n type: CcsCredentialType.HOME_ACCOUNT_ID,\n };\n }\n catch (e) {\n this.logger.verbose(\"Could not parse client info for CCS Header: \" + e);\n }\n }\n const headers = this.createTokenRequestHeaders(ccsCredential || request.ccsCredential);\n const thumbprint = {\n clientId: request.tokenBodyParameters?.clientId ||\n this.config.authOptions.clientId,\n authority: authority.canonicalAuthority,\n scopes: request.scopes,\n claims: request.claims,\n authenticationScheme: request.authenticationScheme,\n resourceRequestMethod: request.resourceRequestMethod,\n resourceRequestUri: request.resourceRequestUri,\n shrClaims: request.shrClaims,\n sshKid: request.sshKid,\n };\n return invokeAsync(this.executePostToTokenEndpoint.bind(this), PerformanceEvents.AuthorizationCodeClientExecutePostToTokenEndpoint, this.logger, this.performanceClient, request.correlationId)(endpoint, requestBody, headers, thumbprint, request.correlationId, PerformanceEvents.AuthorizationCodeClientExecutePostToTokenEndpoint);\n }\n /**\n * Generates a map for all the params to be sent to the service\n * @param request\n */\n async createTokenRequestBody(request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthClientCreateTokenRequestBody, request.correlationId);\n const parameterBuilder = new RequestParameterBuilder();\n parameterBuilder.addClientId(request.tokenBodyParameters?.[CLIENT_ID] ||\n this.config.authOptions.clientId);\n /*\n * For hybrid spa flow, there will be a code but no verifier\n * In this scenario, don't include redirect uri as auth code will not be bound to redirect URI\n */\n if (!this.includeRedirectUri) {\n // Just validate\n RequestValidator.validateRedirectUri(request.redirectUri);\n }\n else {\n // Validate and include redirect uri\n parameterBuilder.addRedirectUri(request.redirectUri);\n }\n // Add scope array, parameter builder will add default scopes and dedupe\n parameterBuilder.addScopes(request.scopes, true, this.oidcDefaultScopes);\n // add code: user set, not validated\n parameterBuilder.addAuthorizationCode(request.code);\n // Add library metadata\n parameterBuilder.addLibraryInfo(this.config.libraryInfo);\n parameterBuilder.addApplicationTelemetry(this.config.telemetry.application);\n parameterBuilder.addThrottling();\n if (this.serverTelemetryManager && !isOidcProtocolMode(this.config)) {\n parameterBuilder.addServerTelemetry(this.serverTelemetryManager);\n }\n // add code_verifier if passed\n if (request.codeVerifier) {\n parameterBuilder.addCodeVerifier(request.codeVerifier);\n }\n if (this.config.clientCredentials.clientSecret) {\n parameterBuilder.addClientSecret(this.config.clientCredentials.clientSecret);\n }\n if (this.config.clientCredentials.clientAssertion) {\n const clientAssertion = this.config.clientCredentials.clientAssertion;\n parameterBuilder.addClientAssertion(await getClientAssertion(clientAssertion.assertion, this.config.authOptions.clientId, request.resourceRequestUri));\n parameterBuilder.addClientAssertionType(clientAssertion.assertionType);\n }\n parameterBuilder.addGrantType(GrantType.AUTHORIZATION_CODE_GRANT);\n parameterBuilder.addClientInfo();\n if (request.authenticationScheme === AuthenticationScheme.POP) {\n const popTokenGenerator = new PopTokenGenerator(this.cryptoUtils, this.performanceClient);\n let reqCnfData;\n if (!request.popKid) {\n const generatedReqCnfData = await invokeAsync(popTokenGenerator.generateCnf.bind(popTokenGenerator), PerformanceEvents.PopTokenGenerateCnf, this.logger, this.performanceClient, request.correlationId)(request, this.logger);\n reqCnfData = generatedReqCnfData.reqCnfString;\n }\n else {\n reqCnfData = this.cryptoUtils.encodeKid(request.popKid);\n }\n // SPA PoP requires full Base64Url encoded req_cnf string (unhashed)\n parameterBuilder.addPopToken(reqCnfData);\n }\n else if (request.authenticationScheme === AuthenticationScheme.SSH) {\n if (request.sshJwk) {\n parameterBuilder.addSshJwk(request.sshJwk);\n }\n else {\n throw createClientConfigurationError(missingSshJwk);\n }\n }\n const correlationId = request.correlationId ||\n this.config.cryptoInterface.createNewGuid();\n parameterBuilder.addCorrelationId(correlationId);\n if (!StringUtils.isEmptyObj(request.claims) ||\n (this.config.authOptions.clientCapabilities &&\n this.config.authOptions.clientCapabilities.length > 0)) {\n parameterBuilder.addClaims(request.claims, this.config.authOptions.clientCapabilities);\n }\n let ccsCred = undefined;\n if (request.clientInfo) {\n try {\n const clientInfo = buildClientInfo(request.clientInfo, this.cryptoUtils.base64Decode);\n ccsCred = {\n credential: `${clientInfo.uid}${Separators.CLIENT_INFO_SEPARATOR}${clientInfo.utid}`,\n type: CcsCredentialType.HOME_ACCOUNT_ID,\n };\n }\n catch (e) {\n this.logger.verbose(\"Could not parse client info for CCS Header: \" + e);\n }\n }\n else {\n ccsCred = request.ccsCredential;\n }\n // Adds these as parameters in the request instead of headers to prevent CORS preflight request\n if (this.config.systemOptions.preventCorsPreflight && ccsCred) {\n switch (ccsCred.type) {\n case CcsCredentialType.HOME_ACCOUNT_ID:\n try {\n const clientInfo = buildClientInfoFromHomeAccountId(ccsCred.credential);\n parameterBuilder.addCcsOid(clientInfo);\n }\n catch (e) {\n this.logger.verbose(\"Could not parse home account ID for CCS Header: \" +\n e);\n }\n break;\n case CcsCredentialType.UPN:\n parameterBuilder.addCcsUpn(ccsCred.credential);\n break;\n }\n }\n if (request.tokenBodyParameters) {\n parameterBuilder.addExtraQueryParameters(request.tokenBodyParameters);\n }\n // Add hybrid spa parameters if not already provided\n if (request.enableSpaAuthorizationCode &&\n (!request.tokenBodyParameters ||\n !request.tokenBodyParameters[RETURN_SPA_CODE])) {\n parameterBuilder.addExtraQueryParameters({\n [RETURN_SPA_CODE]: \"1\",\n });\n }\n return parameterBuilder.createQueryString();\n }\n /**\n * This API validates the `AuthorizationCodeUrlRequest` and creates a URL\n * @param request\n */\n async createAuthCodeUrlQueryString(request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.AuthClientCreateQueryString, request.correlationId);\n const parameterBuilder = new RequestParameterBuilder();\n parameterBuilder.addClientId(request.extraQueryParameters?.[CLIENT_ID] ||\n this.config.authOptions.clientId);\n const requestScopes = [\n ...(request.scopes || []),\n ...(request.extraScopesToConsent || []),\n ];\n parameterBuilder.addScopes(requestScopes, true, this.oidcDefaultScopes);\n // validate the redirectUri (to be a non null value)\n parameterBuilder.addRedirectUri(request.redirectUri);\n // generate the correlationId if not set by the user and add\n const correlationId = request.correlationId ||\n this.config.cryptoInterface.createNewGuid();\n parameterBuilder.addCorrelationId(correlationId);\n // add response_mode. If not passed in it defaults to query.\n parameterBuilder.addResponseMode(request.responseMode);\n // add response_type = code\n parameterBuilder.addResponseTypeCode();\n // add library info parameters\n parameterBuilder.addLibraryInfo(this.config.libraryInfo);\n if (!isOidcProtocolMode(this.config)) {\n parameterBuilder.addApplicationTelemetry(this.config.telemetry.application);\n }\n // add client_info=1\n parameterBuilder.addClientInfo();\n if (request.codeChallenge && request.codeChallengeMethod) {\n parameterBuilder.addCodeChallengeParams(request.codeChallenge, request.codeChallengeMethod);\n }\n if (request.prompt) {\n parameterBuilder.addPrompt(request.prompt);\n }\n if (request.domainHint) {\n parameterBuilder.addDomainHint(request.domainHint);\n }\n // Add sid or loginHint with preference for login_hint claim (in request) -> sid -> loginHint (upn/email) -> username of AccountInfo object\n if (request.prompt !== PromptValue.SELECT_ACCOUNT) {\n // AAD will throw if prompt=select_account is passed with an account hint\n if (request.sid && request.prompt === PromptValue.NONE) {\n // SessionID is only used in silent calls\n this.logger.verbose(\"createAuthCodeUrlQueryString: Prompt is none, adding sid from request\");\n parameterBuilder.addSid(request.sid);\n }\n else if (request.account) {\n const accountSid = this.extractAccountSid(request.account);\n let accountLoginHintClaim = this.extractLoginHint(request.account);\n if (accountLoginHintClaim && request.domainHint) {\n this.logger.warning(`AuthorizationCodeClient.createAuthCodeUrlQueryString: \"domainHint\" param is set, skipping opaque \"login_hint\" claim. Please consider not passing domainHint`);\n accountLoginHintClaim = null;\n }\n // If login_hint claim is present, use it over sid/username\n if (accountLoginHintClaim) {\n this.logger.verbose(\"createAuthCodeUrlQueryString: login_hint claim present on account\");\n parameterBuilder.addLoginHint(accountLoginHintClaim);\n try {\n const clientInfo = buildClientInfoFromHomeAccountId(request.account.homeAccountId);\n parameterBuilder.addCcsOid(clientInfo);\n }\n catch (e) {\n this.logger.verbose(\"createAuthCodeUrlQueryString: Could not parse home account ID for CCS Header\");\n }\n }\n else if (accountSid && request.prompt === PromptValue.NONE) {\n /*\n * If account and loginHint are provided, we will check account first for sid before adding loginHint\n * SessionId is only used in silent calls\n */\n this.logger.verbose(\"createAuthCodeUrlQueryString: Prompt is none, adding sid from account\");\n parameterBuilder.addSid(accountSid);\n try {\n const clientInfo = buildClientInfoFromHomeAccountId(request.account.homeAccountId);\n parameterBuilder.addCcsOid(clientInfo);\n }\n catch (e) {\n this.logger.verbose(\"createAuthCodeUrlQueryString: Could not parse home account ID for CCS Header\");\n }\n }\n else if (request.loginHint) {\n this.logger.verbose(\"createAuthCodeUrlQueryString: Adding login_hint from request\");\n parameterBuilder.addLoginHint(request.loginHint);\n parameterBuilder.addCcsUpn(request.loginHint);\n }\n else if (request.account.username) {\n // Fallback to account username if provided\n this.logger.verbose(\"createAuthCodeUrlQueryString: Adding login_hint from account\");\n parameterBuilder.addLoginHint(request.account.username);\n try {\n const clientInfo = buildClientInfoFromHomeAccountId(request.account.homeAccountId);\n parameterBuilder.addCcsOid(clientInfo);\n }\n catch (e) {\n this.logger.verbose(\"createAuthCodeUrlQueryString: Could not parse home account ID for CCS Header\");\n }\n }\n }\n else if (request.loginHint) {\n this.logger.verbose(\"createAuthCodeUrlQueryString: No account, adding login_hint from request\");\n parameterBuilder.addLoginHint(request.loginHint);\n parameterBuilder.addCcsUpn(request.loginHint);\n }\n }\n else {\n this.logger.verbose(\"createAuthCodeUrlQueryString: Prompt is select_account, ignoring account hints\");\n }\n if (request.nonce) {\n parameterBuilder.addNonce(request.nonce);\n }\n if (request.state) {\n parameterBuilder.addState(request.state);\n }\n if (request.claims ||\n (this.config.authOptions.clientCapabilities &&\n this.config.authOptions.clientCapabilities.length > 0)) {\n parameterBuilder.addClaims(request.claims, this.config.authOptions.clientCapabilities);\n }\n if (request.extraQueryParameters) {\n parameterBuilder.addExtraQueryParameters(request.extraQueryParameters);\n }\n if (request.nativeBroker) {\n // signal ests that this is a WAM call\n parameterBuilder.addNativeBroker();\n // pass the req_cnf for POP\n if (request.authenticationScheme === AuthenticationScheme.POP) {\n const popTokenGenerator = new PopTokenGenerator(this.cryptoUtils);\n // req_cnf is always sent as a string for SPAs\n let reqCnfData;\n if (!request.popKid) {\n const generatedReqCnfData = await invokeAsync(popTokenGenerator.generateCnf.bind(popTokenGenerator), PerformanceEvents.PopTokenGenerateCnf, this.logger, this.performanceClient, request.correlationId)(request, this.logger);\n reqCnfData = generatedReqCnfData.reqCnfString;\n }\n else {\n reqCnfData = this.cryptoUtils.encodeKid(request.popKid);\n }\n parameterBuilder.addPopToken(reqCnfData);\n }\n }\n return parameterBuilder.createQueryString();\n }\n /**\n * This API validates the `EndSessionRequest` and creates a URL\n * @param request\n */\n createLogoutUrlQueryString(request) {\n const parameterBuilder = new RequestParameterBuilder();\n if (request.postLogoutRedirectUri) {\n parameterBuilder.addPostLogoutRedirectUri(request.postLogoutRedirectUri);\n }\n if (request.correlationId) {\n parameterBuilder.addCorrelationId(request.correlationId);\n }\n if (request.idTokenHint) {\n parameterBuilder.addIdTokenHint(request.idTokenHint);\n }\n if (request.state) {\n parameterBuilder.addState(request.state);\n }\n if (request.logoutHint) {\n parameterBuilder.addLogoutHint(request.logoutHint);\n }\n if (request.extraQueryParameters) {\n parameterBuilder.addExtraQueryParameters(request.extraQueryParameters);\n }\n return parameterBuilder.createQueryString();\n }\n /**\n * Helper to get sid from account. Returns null if idTokenClaims are not present or sid is not present.\n * @param account\n */\n extractAccountSid(account) {\n return account.idTokenClaims?.sid || null;\n }\n extractLoginHint(account) {\n return account.idTokenClaims?.login_hint || null;\n }\n}\n\nexport { AuthorizationCodeClient };\n//# sourceMappingURL=AuthorizationCodeClient.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { isOidcProtocolMode } from '../config/ClientConfiguration.mjs';\nimport { BaseClient } from './BaseClient.mjs';\nimport { RequestParameterBuilder } from '../request/RequestParameterBuilder.mjs';\nimport { GrantType, AuthenticationScheme, HeaderNames, Errors } from '../utils/Constants.mjs';\nimport { CLIENT_ID } from '../constants/AADServerParamKeys.mjs';\nimport { ResponseHandler } from '../response/ResponseHandler.mjs';\nimport { PopTokenGenerator } from '../crypto/PopTokenGenerator.mjs';\nimport { StringUtils } from '../utils/StringUtils.mjs';\nimport { createClientConfigurationError } from '../error/ClientConfigurationError.mjs';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { ServerError } from '../error/ServerError.mjs';\nimport { nowSeconds, isTokenExpired } from '../utils/TimeUtils.mjs';\nimport { UrlString } from '../url/UrlString.mjs';\nimport { CcsCredentialType } from '../account/CcsCredential.mjs';\nimport { buildClientInfoFromHomeAccountId } from '../account/ClientInfo.mjs';\nimport { createInteractionRequiredAuthError, InteractionRequiredAuthError } from '../error/InteractionRequiredAuthError.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { invokeAsync, invoke } from '../utils/FunctionWrappers.mjs';\nimport { generateCredentialKey } from '../cache/utils/CacheHelpers.mjs';\nimport { getClientAssertion } from '../utils/ClientAssertionUtils.mjs';\nimport { tokenRequestEmpty, missingSshJwk } from '../error/ClientConfigurationErrorCodes.mjs';\nimport { noAccountInSilentRequest } from '../error/ClientAuthErrorCodes.mjs';\nimport { noTokensFound, refreshTokenExpired, badToken } from '../error/InteractionRequiredAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst DEFAULT_REFRESH_TOKEN_EXPIRATION_OFFSET_SECONDS = 300; // 5 Minutes\n/**\n * OAuth2.0 refresh token client\n * @internal\n */\nclass RefreshTokenClient extends BaseClient {\n constructor(configuration, performanceClient) {\n super(configuration, performanceClient);\n }\n async acquireToken(request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RefreshTokenClientAcquireToken, request.correlationId);\n const reqTimestamp = nowSeconds();\n const response = await invokeAsync(this.executeTokenRequest.bind(this), PerformanceEvents.RefreshTokenClientExecuteTokenRequest, this.logger, this.performanceClient, request.correlationId)(request, this.authority);\n // Retrieve requestId from response headers\n const requestId = response.headers?.[HeaderNames.X_MS_REQUEST_ID];\n const responseHandler = new ResponseHandler(this.config.authOptions.clientId, this.cacheManager, this.cryptoUtils, this.logger, this.config.serializableCache, this.config.persistencePlugin);\n responseHandler.validateTokenResponse(response.body);\n return invokeAsync(responseHandler.handleServerTokenResponse.bind(responseHandler), PerformanceEvents.HandleServerTokenResponse, this.logger, this.performanceClient, request.correlationId)(response.body, this.authority, reqTimestamp, request, undefined, undefined, true, request.forceCache, requestId);\n }\n /**\n * Gets cached refresh token and attaches to request, then calls acquireToken API\n * @param request\n */\n async acquireTokenByRefreshToken(request) {\n // Cannot renew token if no request object is given.\n if (!request) {\n throw createClientConfigurationError(tokenRequestEmpty);\n }\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RefreshTokenClientAcquireTokenByRefreshToken, request.correlationId);\n // We currently do not support silent flow for account === null use cases; This will be revisited for confidential flow usecases\n if (!request.account) {\n throw createClientAuthError(noAccountInSilentRequest);\n }\n // try checking if FOCI is enabled for the given application\n const isFOCI = this.cacheManager.isAppMetadataFOCI(request.account.environment);\n // if the app is part of the family, retrive a Family refresh token if present and make a refreshTokenRequest\n if (isFOCI) {\n try {\n return await invokeAsync(this.acquireTokenWithCachedRefreshToken.bind(this), PerformanceEvents.RefreshTokenClientAcquireTokenWithCachedRefreshToken, this.logger, this.performanceClient, request.correlationId)(request, true);\n }\n catch (e) {\n const noFamilyRTInCache = e instanceof InteractionRequiredAuthError &&\n e.errorCode ===\n noTokensFound;\n const clientMismatchErrorWithFamilyRT = e instanceof ServerError &&\n e.errorCode === Errors.INVALID_GRANT_ERROR &&\n e.subError === Errors.CLIENT_MISMATCH_ERROR;\n // if family Refresh Token (FRT) cache acquisition fails or if client_mismatch error is seen with FRT, reattempt with application Refresh Token (ART)\n if (noFamilyRTInCache || clientMismatchErrorWithFamilyRT) {\n return invokeAsync(this.acquireTokenWithCachedRefreshToken.bind(this), PerformanceEvents.RefreshTokenClientAcquireTokenWithCachedRefreshToken, this.logger, this.performanceClient, request.correlationId)(request, false);\n // throw in all other cases\n }\n else {\n throw e;\n }\n }\n }\n // fall back to application refresh token acquisition\n return invokeAsync(this.acquireTokenWithCachedRefreshToken.bind(this), PerformanceEvents.RefreshTokenClientAcquireTokenWithCachedRefreshToken, this.logger, this.performanceClient, request.correlationId)(request, false);\n }\n /**\n * makes a network call to acquire tokens by exchanging RefreshToken available in userCache; throws if refresh token is not cached\n * @param request\n */\n async acquireTokenWithCachedRefreshToken(request, foci) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RefreshTokenClientAcquireTokenWithCachedRefreshToken, request.correlationId);\n // fetches family RT or application RT based on FOCI value\n const refreshToken = invoke(this.cacheManager.getRefreshToken.bind(this.cacheManager), PerformanceEvents.CacheManagerGetRefreshToken, this.logger, this.performanceClient, request.correlationId)(request.account, foci, undefined, this.performanceClient, request.correlationId);\n if (!refreshToken) {\n throw createInteractionRequiredAuthError(noTokensFound);\n }\n if (refreshToken.expiresOn &&\n isTokenExpired(refreshToken.expiresOn, request.refreshTokenExpirationOffsetSeconds ||\n DEFAULT_REFRESH_TOKEN_EXPIRATION_OFFSET_SECONDS)) {\n throw createInteractionRequiredAuthError(refreshTokenExpired);\n }\n // attach cached RT size to the current measurement\n const refreshTokenRequest = {\n ...request,\n refreshToken: refreshToken.secret,\n authenticationScheme: request.authenticationScheme || AuthenticationScheme.BEARER,\n ccsCredential: {\n credential: request.account.homeAccountId,\n type: CcsCredentialType.HOME_ACCOUNT_ID,\n },\n };\n try {\n return await invokeAsync(this.acquireToken.bind(this), PerformanceEvents.RefreshTokenClientAcquireToken, this.logger, this.performanceClient, request.correlationId)(refreshTokenRequest);\n }\n catch (e) {\n if (e instanceof InteractionRequiredAuthError &&\n e.subError === badToken) {\n // Remove bad refresh token from cache\n this.logger.verbose(\"acquireTokenWithRefreshToken: bad refresh token, removing from cache\");\n const badRefreshTokenKey = generateCredentialKey(refreshToken);\n this.cacheManager.removeRefreshToken(badRefreshTokenKey);\n }\n throw e;\n }\n }\n /**\n * Constructs the network message and makes a NW call to the underlying secure token service\n * @param request\n * @param authority\n */\n async executeTokenRequest(request, authority) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RefreshTokenClientExecuteTokenRequest, request.correlationId);\n const queryParametersString = this.createTokenQueryParameters(request);\n const endpoint = UrlString.appendQueryString(authority.tokenEndpoint, queryParametersString);\n const requestBody = await invokeAsync(this.createTokenRequestBody.bind(this), PerformanceEvents.RefreshTokenClientCreateTokenRequestBody, this.logger, this.performanceClient, request.correlationId)(request);\n const headers = this.createTokenRequestHeaders(request.ccsCredential);\n const thumbprint = {\n clientId: request.tokenBodyParameters?.clientId ||\n this.config.authOptions.clientId,\n authority: authority.canonicalAuthority,\n scopes: request.scopes,\n claims: request.claims,\n authenticationScheme: request.authenticationScheme,\n resourceRequestMethod: request.resourceRequestMethod,\n resourceRequestUri: request.resourceRequestUri,\n shrClaims: request.shrClaims,\n sshKid: request.sshKid,\n };\n return invokeAsync(this.executePostToTokenEndpoint.bind(this), PerformanceEvents.RefreshTokenClientExecutePostToTokenEndpoint, this.logger, this.performanceClient, request.correlationId)(endpoint, requestBody, headers, thumbprint, request.correlationId, PerformanceEvents.RefreshTokenClientExecutePostToTokenEndpoint);\n }\n /**\n * Helper function to create the token request body\n * @param request\n */\n async createTokenRequestBody(request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.RefreshTokenClientCreateTokenRequestBody, request.correlationId);\n const correlationId = request.correlationId;\n const parameterBuilder = new RequestParameterBuilder();\n parameterBuilder.addClientId(request.tokenBodyParameters?.[CLIENT_ID] ||\n this.config.authOptions.clientId);\n if (request.redirectUri) {\n parameterBuilder.addRedirectUri(request.redirectUri);\n }\n parameterBuilder.addScopes(request.scopes, true, this.config.authOptions.authority.options.OIDCOptions?.defaultScopes);\n parameterBuilder.addGrantType(GrantType.REFRESH_TOKEN_GRANT);\n parameterBuilder.addClientInfo();\n parameterBuilder.addLibraryInfo(this.config.libraryInfo);\n parameterBuilder.addApplicationTelemetry(this.config.telemetry.application);\n parameterBuilder.addThrottling();\n if (this.serverTelemetryManager && !isOidcProtocolMode(this.config)) {\n parameterBuilder.addServerTelemetry(this.serverTelemetryManager);\n }\n parameterBuilder.addCorrelationId(correlationId);\n parameterBuilder.addRefreshToken(request.refreshToken);\n if (this.config.clientCredentials.clientSecret) {\n parameterBuilder.addClientSecret(this.config.clientCredentials.clientSecret);\n }\n if (this.config.clientCredentials.clientAssertion) {\n const clientAssertion = this.config.clientCredentials.clientAssertion;\n parameterBuilder.addClientAssertion(await getClientAssertion(clientAssertion.assertion, this.config.authOptions.clientId, request.resourceRequestUri));\n parameterBuilder.addClientAssertionType(clientAssertion.assertionType);\n }\n if (request.authenticationScheme === AuthenticationScheme.POP) {\n const popTokenGenerator = new PopTokenGenerator(this.cryptoUtils, this.performanceClient);\n let reqCnfData;\n if (!request.popKid) {\n const generatedReqCnfData = await invokeAsync(popTokenGenerator.generateCnf.bind(popTokenGenerator), PerformanceEvents.PopTokenGenerateCnf, this.logger, this.performanceClient, request.correlationId)(request, this.logger);\n reqCnfData = generatedReqCnfData.reqCnfString;\n }\n else {\n reqCnfData = this.cryptoUtils.encodeKid(request.popKid);\n }\n // SPA PoP requires full Base64Url encoded req_cnf string (unhashed)\n parameterBuilder.addPopToken(reqCnfData);\n }\n else if (request.authenticationScheme === AuthenticationScheme.SSH) {\n if (request.sshJwk) {\n parameterBuilder.addSshJwk(request.sshJwk);\n }\n else {\n throw createClientConfigurationError(missingSshJwk);\n }\n }\n if (!StringUtils.isEmptyObj(request.claims) ||\n (this.config.authOptions.clientCapabilities &&\n this.config.authOptions.clientCapabilities.length > 0)) {\n parameterBuilder.addClaims(request.claims, this.config.authOptions.clientCapabilities);\n }\n if (this.config.systemOptions.preventCorsPreflight &&\n request.ccsCredential) {\n switch (request.ccsCredential.type) {\n case CcsCredentialType.HOME_ACCOUNT_ID:\n try {\n const clientInfo = buildClientInfoFromHomeAccountId(request.ccsCredential.credential);\n parameterBuilder.addCcsOid(clientInfo);\n }\n catch (e) {\n this.logger.verbose(\"Could not parse home account ID for CCS Header: \" +\n e);\n }\n break;\n case CcsCredentialType.UPN:\n parameterBuilder.addCcsUpn(request.ccsCredential.credential);\n break;\n }\n }\n if (request.tokenBodyParameters) {\n parameterBuilder.addExtraQueryParameters(request.tokenBodyParameters);\n }\n return parameterBuilder.createQueryString();\n }\n}\n\nexport { RefreshTokenClient };\n//# sourceMappingURL=RefreshTokenClient.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { BaseClient } from './BaseClient.mjs';\nimport { wasClockTurnedBack, isTokenExpired } from '../utils/TimeUtils.mjs';\nimport { RefreshTokenClient } from './RefreshTokenClient.mjs';\nimport { ClientAuthError, createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { ResponseHandler } from '../response/ResponseHandler.mjs';\nimport { OIDC_DEFAULT_SCOPES, CacheOutcome } from '../utils/Constants.mjs';\nimport { StringUtils } from '../utils/StringUtils.mjs';\nimport { extractTokenClaims, checkMaxAge } from '../account/AuthToken.mjs';\nimport { PerformanceEvents } from '../telemetry/performance/PerformanceEvent.mjs';\nimport { invokeAsync } from '../utils/FunctionWrappers.mjs';\nimport { getTenantFromAuthorityString } from '../authority/Authority.mjs';\nimport { tokenRefreshRequired, noAccountInSilentRequest, authTimeNotFound } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/** @internal */\nclass SilentFlowClient extends BaseClient {\n constructor(configuration, performanceClient) {\n super(configuration, performanceClient);\n }\n /**\n * Retrieves a token from cache if it is still valid, or uses the cached refresh token to renew\n * the given token and returns the renewed token\n * @param request\n */\n async acquireToken(request) {\n try {\n const [authResponse, cacheOutcome] = await this.acquireCachedToken({\n ...request,\n scopes: request.scopes?.length\n ? request.scopes\n : [...OIDC_DEFAULT_SCOPES],\n });\n // if the token is not expired but must be refreshed; get a new one in the background\n if (cacheOutcome === CacheOutcome.PROACTIVELY_REFRESHED) {\n this.logger.info(\"SilentFlowClient:acquireCachedToken - Cached access token's refreshOn property has been exceeded'. It's not expired, but must be refreshed.\");\n // refresh the access token in the background\n const refreshTokenClient = new RefreshTokenClient(this.config, this.performanceClient);\n refreshTokenClient\n .acquireTokenByRefreshToken(request)\n .catch(() => {\n // do nothing, this is running in the background and no action is to be taken upon success or failure\n });\n }\n // return the cached token\n return authResponse;\n }\n catch (e) {\n if (e instanceof ClientAuthError &&\n e.errorCode === tokenRefreshRequired) {\n const refreshTokenClient = new RefreshTokenClient(this.config, this.performanceClient);\n return refreshTokenClient.acquireTokenByRefreshToken(request);\n }\n else {\n throw e;\n }\n }\n }\n /**\n * Retrieves token from cache or throws an error if it must be refreshed.\n * @param request\n */\n async acquireCachedToken(request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.SilentFlowClientAcquireCachedToken, request.correlationId);\n let lastCacheOutcome = CacheOutcome.NOT_APPLICABLE;\n if (request.forceRefresh ||\n (!this.config.cacheOptions.claimsBasedCachingEnabled &&\n !StringUtils.isEmptyObj(request.claims))) {\n // Must refresh due to present force_refresh flag.\n this.setCacheOutcome(CacheOutcome.FORCE_REFRESH_OR_CLAIMS, request.correlationId);\n throw createClientAuthError(tokenRefreshRequired);\n }\n // We currently do not support silent flow for account === null use cases; This will be revisited for confidential flow usecases\n if (!request.account) {\n throw createClientAuthError(noAccountInSilentRequest);\n }\n const requestTenantId = request.account.tenantId ||\n getTenantFromAuthorityString(request.authority);\n const tokenKeys = this.cacheManager.getTokenKeys();\n const cachedAccessToken = this.cacheManager.getAccessToken(request.account, request, tokenKeys, requestTenantId, this.performanceClient, request.correlationId);\n if (!cachedAccessToken) {\n // must refresh due to non-existent access_token\n this.setCacheOutcome(CacheOutcome.NO_CACHED_ACCESS_TOKEN, request.correlationId);\n throw createClientAuthError(tokenRefreshRequired);\n }\n else if (wasClockTurnedBack(cachedAccessToken.cachedAt) ||\n isTokenExpired(cachedAccessToken.expiresOn, this.config.systemOptions.tokenRenewalOffsetSeconds)) {\n // must refresh due to the expires_in value\n this.setCacheOutcome(CacheOutcome.CACHED_ACCESS_TOKEN_EXPIRED, request.correlationId);\n throw createClientAuthError(tokenRefreshRequired);\n }\n else if (cachedAccessToken.refreshOn &&\n isTokenExpired(cachedAccessToken.refreshOn, 0)) {\n // must refresh (in the background) due to the refresh_in value\n lastCacheOutcome = CacheOutcome.PROACTIVELY_REFRESHED;\n // don't throw ClientAuthError.createRefreshRequiredError(), return cached token instead\n }\n const environment = request.authority || this.authority.getPreferredCache();\n const cacheRecord = {\n account: this.cacheManager.readAccountFromCache(request.account),\n accessToken: cachedAccessToken,\n idToken: this.cacheManager.getIdToken(request.account, tokenKeys, requestTenantId, this.performanceClient, request.correlationId),\n refreshToken: null,\n appMetadata: this.cacheManager.readAppMetadataFromCache(environment),\n };\n this.setCacheOutcome(lastCacheOutcome, request.correlationId);\n if (this.config.serverTelemetryManager) {\n this.config.serverTelemetryManager.incrementCacheHits();\n }\n return [\n await invokeAsync(this.generateResultFromCacheRecord.bind(this), PerformanceEvents.SilentFlowClientGenerateResultFromCacheRecord, this.logger, this.performanceClient, request.correlationId)(cacheRecord, request),\n lastCacheOutcome,\n ];\n }\n setCacheOutcome(cacheOutcome, correlationId) {\n this.serverTelemetryManager?.setCacheOutcome(cacheOutcome);\n this.performanceClient?.addFields({\n cacheOutcome: cacheOutcome,\n }, correlationId);\n if (cacheOutcome !== CacheOutcome.NOT_APPLICABLE) {\n this.logger.info(`Token refresh is required due to cache outcome: ${cacheOutcome}`);\n }\n }\n /**\n * Helper function to build response object from the CacheRecord\n * @param cacheRecord\n */\n async generateResultFromCacheRecord(cacheRecord, request) {\n this.performanceClient?.addQueueMeasurement(PerformanceEvents.SilentFlowClientGenerateResultFromCacheRecord, request.correlationId);\n let idTokenClaims;\n if (cacheRecord.idToken) {\n idTokenClaims = extractTokenClaims(cacheRecord.idToken.secret, this.config.cryptoInterface.base64Decode);\n }\n // token max_age check\n if (request.maxAge || request.maxAge === 0) {\n const authTime = idTokenClaims?.auth_time;\n if (!authTime) {\n throw createClientAuthError(authTimeNotFound);\n }\n checkMaxAge(authTime, request.maxAge);\n }\n return ResponseHandler.generateAuthenticationResult(this.cryptoUtils, this.authority, cacheRecord, true, request, idTokenClaims);\n }\n}\n\nexport { SilentFlowClient };\n//# sourceMappingURL=SilentFlowClient.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createClientAuthError } from '../error/ClientAuthError.mjs';\nimport { methodNotImplemented } from '../error/ClientAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst StubbedNetworkModule = {\n sendGetRequestAsync: () => {\n return Promise.reject(createClientAuthError(methodNotImplemented));\n },\n sendPostRequestAsync: () => {\n return Promise.reject(createClientAuthError(methodNotImplemented));\n },\n};\n\nexport { StubbedNetworkModule };\n//# sourceMappingURL=INetworkModule.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst missingKidError = \"missing_kid_error\";\nconst missingAlgError = \"missing_alg_error\";\n\nexport { missingAlgError, missingKidError };\n//# sourceMappingURL=JoseHeaderErrorCodes.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { AuthError } from './AuthError.mjs';\nimport { missingKidError, missingAlgError } from './JoseHeaderErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst JoseHeaderErrorMessages = {\n [missingKidError]: \"The JOSE Header for the requested JWT, JWS or JWK object requires a keyId to be configured as the 'kid' header claim. No 'kid' value was provided.\",\n [missingAlgError]: \"The JOSE Header for the requested JWT, JWS or JWK object requires an algorithm to be specified as the 'alg' header claim. No 'alg' value was provided.\",\n};\n/**\n * Error thrown when there is an error in the client code running on the browser.\n */\nclass JoseHeaderError extends AuthError {\n constructor(errorCode, errorMessage) {\n super(errorCode, errorMessage);\n this.name = \"JoseHeaderError\";\n Object.setPrototypeOf(this, JoseHeaderError.prototype);\n }\n}\n/** Returns JoseHeaderError object */\nfunction createJoseHeaderError(code) {\n return new JoseHeaderError(code, JoseHeaderErrorMessages[code]);\n}\n\nexport { JoseHeaderError, JoseHeaderErrorMessages, createJoseHeaderError };\n//# sourceMappingURL=JoseHeaderError.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { createJoseHeaderError } from '../error/JoseHeaderError.mjs';\nimport { JsonWebTokenTypes } from '../utils/Constants.mjs';\nimport { missingKidError, missingAlgError } from '../error/JoseHeaderErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/** @internal */\nclass JoseHeader {\n constructor(options) {\n this.typ = options.typ;\n this.alg = options.alg;\n this.kid = options.kid;\n }\n /**\n * Builds SignedHttpRequest formatted JOSE Header from the\n * JOSE Header options provided or previously set on the object and returns\n * the stringified header object.\n * Throws if keyId or algorithm aren't provided since they are required for Access Token Binding.\n * @param shrHeaderOptions\n * @returns\n */\n static getShrHeaderString(shrHeaderOptions) {\n // KeyID is required on the SHR header\n if (!shrHeaderOptions.kid) {\n throw createJoseHeaderError(missingKidError);\n }\n // Alg is required on the SHR header\n if (!shrHeaderOptions.alg) {\n throw createJoseHeaderError(missingAlgError);\n }\n const shrHeader = new JoseHeader({\n // Access Token PoP headers must have type pop, but the type header can be overriden for special cases\n typ: shrHeaderOptions.typ || JsonWebTokenTypes.Pop,\n kid: shrHeaderOptions.kid,\n alg: shrHeaderOptions.alg,\n });\n return JSON.stringify(shrHeader);\n }\n}\n\nexport { JoseHeader };\n//# sourceMappingURL=JoseHeader.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { CacheOutcome, Constants, SERVER_TELEM_CONSTANTS, Separators } from '../../utils/Constants.mjs';\nimport { AuthError } from '../../error/AuthError.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/** @internal */\nclass ServerTelemetryManager {\n constructor(telemetryRequest, cacheManager) {\n this.cacheOutcome = CacheOutcome.NOT_APPLICABLE;\n this.cacheManager = cacheManager;\n this.apiId = telemetryRequest.apiId;\n this.correlationId = telemetryRequest.correlationId;\n this.wrapperSKU = telemetryRequest.wrapperSKU || Constants.EMPTY_STRING;\n this.wrapperVer = telemetryRequest.wrapperVer || Constants.EMPTY_STRING;\n this.telemetryCacheKey =\n SERVER_TELEM_CONSTANTS.CACHE_KEY +\n Separators.CACHE_KEY_SEPARATOR +\n telemetryRequest.clientId;\n }\n /**\n * API to add MSER Telemetry to request\n */\n generateCurrentRequestHeaderValue() {\n const request = `${this.apiId}${SERVER_TELEM_CONSTANTS.VALUE_SEPARATOR}${this.cacheOutcome}`;\n const platformFields = [this.wrapperSKU, this.wrapperVer].join(SERVER_TELEM_CONSTANTS.VALUE_SEPARATOR);\n const regionDiscoveryFields = this.getRegionDiscoveryFields();\n const requestWithRegionDiscoveryFields = [\n request,\n regionDiscoveryFields,\n ].join(SERVER_TELEM_CONSTANTS.VALUE_SEPARATOR);\n return [\n SERVER_TELEM_CONSTANTS.SCHEMA_VERSION,\n requestWithRegionDiscoveryFields,\n platformFields,\n ].join(SERVER_TELEM_CONSTANTS.CATEGORY_SEPARATOR);\n }\n /**\n * API to add MSER Telemetry for the last failed request\n */\n generateLastRequestHeaderValue() {\n const lastRequests = this.getLastRequests();\n const maxErrors = ServerTelemetryManager.maxErrorsToSend(lastRequests);\n const failedRequests = lastRequests.failedRequests\n .slice(0, 2 * maxErrors)\n .join(SERVER_TELEM_CONSTANTS.VALUE_SEPARATOR);\n const errors = lastRequests.errors\n .slice(0, maxErrors)\n .join(SERVER_TELEM_CONSTANTS.VALUE_SEPARATOR);\n const errorCount = lastRequests.errors.length;\n // Indicate whether this header contains all data or partial data\n const overflow = maxErrors < errorCount\n ? SERVER_TELEM_CONSTANTS.OVERFLOW_TRUE\n : SERVER_TELEM_CONSTANTS.OVERFLOW_FALSE;\n const platformFields = [errorCount, overflow].join(SERVER_TELEM_CONSTANTS.VALUE_SEPARATOR);\n return [\n SERVER_TELEM_CONSTANTS.SCHEMA_VERSION,\n lastRequests.cacheHits,\n failedRequests,\n errors,\n platformFields,\n ].join(SERVER_TELEM_CONSTANTS.CATEGORY_SEPARATOR);\n }\n /**\n * API to cache token failures for MSER data capture\n * @param error\n */\n cacheFailedRequest(error) {\n const lastRequests = this.getLastRequests();\n if (lastRequests.errors.length >=\n SERVER_TELEM_CONSTANTS.MAX_CACHED_ERRORS) {\n // Remove a cached error to make room, first in first out\n lastRequests.failedRequests.shift(); // apiId\n lastRequests.failedRequests.shift(); // correlationId\n lastRequests.errors.shift();\n }\n lastRequests.failedRequests.push(this.apiId, this.correlationId);\n if (error instanceof Error && !!error && error.toString()) {\n if (error instanceof AuthError) {\n if (error.subError) {\n lastRequests.errors.push(error.subError);\n }\n else if (error.errorCode) {\n lastRequests.errors.push(error.errorCode);\n }\n else {\n lastRequests.errors.push(error.toString());\n }\n }\n else {\n lastRequests.errors.push(error.toString());\n }\n }\n else {\n lastRequests.errors.push(SERVER_TELEM_CONSTANTS.UNKNOWN_ERROR);\n }\n this.cacheManager.setServerTelemetry(this.telemetryCacheKey, lastRequests);\n return;\n }\n /**\n * Update server telemetry cache entry by incrementing cache hit counter\n */\n incrementCacheHits() {\n const lastRequests = this.getLastRequests();\n lastRequests.cacheHits += 1;\n this.cacheManager.setServerTelemetry(this.telemetryCacheKey, lastRequests);\n return lastRequests.cacheHits;\n }\n /**\n * Get the server telemetry entity from cache or initialize a new one\n */\n getLastRequests() {\n const initialValue = {\n failedRequests: [],\n errors: [],\n cacheHits: 0,\n };\n const lastRequests = this.cacheManager.getServerTelemetry(this.telemetryCacheKey);\n return lastRequests || initialValue;\n }\n /**\n * Remove server telemetry cache entry\n */\n clearTelemetryCache() {\n const lastRequests = this.getLastRequests();\n const numErrorsFlushed = ServerTelemetryManager.maxErrorsToSend(lastRequests);\n const errorCount = lastRequests.errors.length;\n if (numErrorsFlushed === errorCount) {\n // All errors were sent on last request, clear Telemetry cache\n this.cacheManager.removeItem(this.telemetryCacheKey);\n }\n else {\n // Partial data was flushed to server, construct a new telemetry cache item with errors that were not flushed\n const serverTelemEntity = {\n failedRequests: lastRequests.failedRequests.slice(numErrorsFlushed * 2),\n errors: lastRequests.errors.slice(numErrorsFlushed),\n cacheHits: 0,\n };\n this.cacheManager.setServerTelemetry(this.telemetryCacheKey, serverTelemEntity);\n }\n }\n /**\n * Returns the maximum number of errors that can be flushed to the server in the next network request\n * @param serverTelemetryEntity\n */\n static maxErrorsToSend(serverTelemetryEntity) {\n let i;\n let maxErrors = 0;\n let dataSize = 0;\n const errorCount = serverTelemetryEntity.errors.length;\n for (i = 0; i < errorCount; i++) {\n // failedRequests parameter contains pairs of apiId and correlationId, multiply index by 2 to preserve pairs\n const apiId = serverTelemetryEntity.failedRequests[2 * i] ||\n Constants.EMPTY_STRING;\n const correlationId = serverTelemetryEntity.failedRequests[2 * i + 1] ||\n Constants.EMPTY_STRING;\n const errorCode = serverTelemetryEntity.errors[i] || Constants.EMPTY_STRING;\n // Count number of characters that would be added to header, each character is 1 byte. Add 3 at the end to account for separators\n dataSize +=\n apiId.toString().length +\n correlationId.toString().length +\n errorCode.length +\n 3;\n if (dataSize < SERVER_TELEM_CONSTANTS.MAX_LAST_HEADER_BYTES) {\n // Adding this entry to the header would still keep header size below the limit\n maxErrors += 1;\n }\n else {\n break;\n }\n }\n return maxErrors;\n }\n /**\n * Get the region discovery fields\n *\n * @returns string\n */\n getRegionDiscoveryFields() {\n const regionDiscoveryFields = [];\n regionDiscoveryFields.push(this.regionUsed || Constants.EMPTY_STRING);\n regionDiscoveryFields.push(this.regionSource || Constants.EMPTY_STRING);\n regionDiscoveryFields.push(this.regionOutcome || Constants.EMPTY_STRING);\n return regionDiscoveryFields.join(\",\");\n }\n /**\n * Update the region discovery metadata\n *\n * @param regionDiscoveryMetadata\n * @returns void\n */\n updateRegionDiscoveryMetadata(regionDiscoveryMetadata) {\n this.regionUsed = regionDiscoveryMetadata.region_used;\n this.regionSource = regionDiscoveryMetadata.region_source;\n this.regionOutcome = regionDiscoveryMetadata.region_outcome;\n }\n /**\n * Set cache outcome\n */\n setCacheOutcome(cacheOutcome) {\n this.cacheOutcome = cacheOutcome;\n }\n}\n\nexport { ServerTelemetryManager };\n//# sourceMappingURL=ServerTelemetryManager.mjs.map\n","/*! @azure/msal-common v14.13.1 2024-07-16 */\n'use strict';\nimport { PerformanceEventStatus } from './PerformanceEvent.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass StubPerformanceMeasurement {\n startMeasurement() {\n return;\n }\n endMeasurement() {\n return;\n }\n flushMeasurement() {\n return null;\n }\n}\nclass StubPerformanceClient {\n generateId() {\n return \"callback-id\";\n }\n startMeasurement(measureName, correlationId) {\n return {\n end: () => null,\n discard: () => { },\n add: () => { },\n increment: () => { },\n event: {\n eventId: this.generateId(),\n status: PerformanceEventStatus.InProgress,\n authority: \"\",\n libraryName: \"\",\n libraryVersion: \"\",\n clientId: \"\",\n name: measureName,\n startTimeMs: Date.now(),\n correlationId: correlationId || \"\",\n },\n measurement: new StubPerformanceMeasurement(),\n };\n }\n startPerformanceMeasurement() {\n return new StubPerformanceMeasurement();\n }\n calculateQueuedTime() {\n return 0;\n }\n addQueueMeasurement() {\n return;\n }\n setPreQueueTime() {\n return;\n }\n endMeasurement() {\n return null;\n }\n discardMeasurements() {\n return;\n }\n removePerformanceCallback() {\n return true;\n }\n addPerformanceCallback() {\n return \"\";\n }\n emitEvents() {\n return;\n }\n addFields() {\n return;\n }\n incrementFields() {\n return;\n }\n cacheEventByCorrelationId() {\n return;\n }\n}\n\nexport { StubPerformanceClient, StubPerformanceMeasurement };\n//# sourceMappingURL=StubPerformanceClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst pkceNotCreated = \"pkce_not_created\";\nconst cryptoNonExistent = \"crypto_nonexistent\";\nconst emptyNavigateUri = \"empty_navigate_uri\";\nconst hashEmptyError = \"hash_empty_error\";\nconst noStateInHash = \"no_state_in_hash\";\nconst hashDoesNotContainKnownProperties = \"hash_does_not_contain_known_properties\";\nconst unableToParseState = \"unable_to_parse_state\";\nconst stateInteractionTypeMismatch = \"state_interaction_type_mismatch\";\nconst interactionInProgress = \"interaction_in_progress\";\nconst popupWindowError = \"popup_window_error\";\nconst emptyWindowError = \"empty_window_error\";\nconst userCancelled = \"user_cancelled\";\nconst monitorPopupTimeout = \"monitor_popup_timeout\";\nconst monitorWindowTimeout = \"monitor_window_timeout\";\nconst redirectInIframe = \"redirect_in_iframe\";\nconst blockIframeReload = \"block_iframe_reload\";\nconst blockNestedPopups = \"block_nested_popups\";\nconst iframeClosedPrematurely = \"iframe_closed_prematurely\";\nconst silentLogoutUnsupported = \"silent_logout_unsupported\";\nconst noAccountError = \"no_account_error\";\nconst silentPromptValueError = \"silent_prompt_value_error\";\nconst noTokenRequestCacheError = \"no_token_request_cache_error\";\nconst unableToParseTokenRequestCacheError = \"unable_to_parse_token_request_cache_error\";\nconst noCachedAuthorityError = \"no_cached_authority_error\";\nconst authRequestNotSetError = \"auth_request_not_set_error\";\nconst invalidCacheType = \"invalid_cache_type\";\nconst nonBrowserEnvironment = \"non_browser_environment\";\nconst databaseNotOpen = \"database_not_open\";\nconst noNetworkConnectivity = \"no_network_connectivity\";\nconst postRequestFailed = \"post_request_failed\";\nconst getRequestFailed = \"get_request_failed\";\nconst failedToParseResponse = \"failed_to_parse_response\";\nconst unableToLoadToken = \"unable_to_load_token\";\nconst cryptoKeyNotFound = \"crypto_key_not_found\";\nconst authCodeRequired = \"auth_code_required\";\nconst authCodeOrNativeAccountIdRequired = \"auth_code_or_nativeAccountId_required\";\nconst spaCodeAndNativeAccountIdPresent = \"spa_code_and_nativeAccountId_present\";\nconst databaseUnavailable = \"database_unavailable\";\nconst unableToAcquireTokenFromNativePlatform = \"unable_to_acquire_token_from_native_platform\";\nconst nativeHandshakeTimeout = \"native_handshake_timeout\";\nconst nativeExtensionNotInstalled = \"native_extension_not_installed\";\nconst nativeConnectionNotEstablished = \"native_connection_not_established\";\nconst uninitializedPublicClientApplication = \"uninitialized_public_client_application\";\nconst nativePromptNotSupported = \"native_prompt_not_supported\";\nconst invalidBase64String = \"invalid_base64_string\";\nconst invalidPopTokenRequest = \"invalid_pop_token_request\";\n\nexport { authCodeOrNativeAccountIdRequired, authCodeRequired, authRequestNotSetError, blockIframeReload, blockNestedPopups, cryptoKeyNotFound, cryptoNonExistent, databaseNotOpen, databaseUnavailable, emptyNavigateUri, emptyWindowError, failedToParseResponse, getRequestFailed, hashDoesNotContainKnownProperties, hashEmptyError, iframeClosedPrematurely, interactionInProgress, invalidBase64String, invalidCacheType, invalidPopTokenRequest, monitorPopupTimeout, monitorWindowTimeout, nativeConnectionNotEstablished, nativeExtensionNotInstalled, nativeHandshakeTimeout, nativePromptNotSupported, noAccountError, noCachedAuthorityError, noNetworkConnectivity, noStateInHash, noTokenRequestCacheError, nonBrowserEnvironment, pkceNotCreated, popupWindowError, postRequestFailed, redirectInIframe, silentLogoutUnsupported, silentPromptValueError, spaCodeAndNativeAccountIdPresent, stateInteractionTypeMismatch, unableToAcquireTokenFromNativePlatform, unableToLoadToken, unableToParseState, unableToParseTokenRequestCacheError, uninitializedPublicClientApplication, userCancelled };\n//# sourceMappingURL=BrowserAuthErrorCodes.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { AuthError } from '@azure/msal-common';\nimport { pkceNotCreated, cryptoNonExistent, emptyNavigateUri, hashEmptyError, noStateInHash, hashDoesNotContainKnownProperties, unableToParseState, stateInteractionTypeMismatch, interactionInProgress, popupWindowError, emptyWindowError, userCancelled, monitorPopupTimeout, monitorWindowTimeout, redirectInIframe, blockIframeReload, blockNestedPopups, iframeClosedPrematurely, silentLogoutUnsupported, noAccountError, silentPromptValueError, noTokenRequestCacheError, unableToParseTokenRequestCacheError, noCachedAuthorityError, authRequestNotSetError, invalidCacheType, nonBrowserEnvironment, databaseNotOpen, noNetworkConnectivity, postRequestFailed, getRequestFailed, failedToParseResponse, unableToLoadToken, cryptoKeyNotFound, authCodeRequired, authCodeOrNativeAccountIdRequired, spaCodeAndNativeAccountIdPresent, databaseUnavailable, unableToAcquireTokenFromNativePlatform, nativeHandshakeTimeout, nativeExtensionNotInstalled, nativeConnectionNotEstablished, uninitializedPublicClientApplication, nativePromptNotSupported, invalidBase64String, invalidPopTokenRequest } from './BrowserAuthErrorCodes.mjs';\nimport * as BrowserAuthErrorCodes from './BrowserAuthErrorCodes.mjs';\nexport { BrowserAuthErrorCodes };\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst ErrorLink = \"For more visit: aka.ms/msaljs/browser-errors\";\n/**\n * BrowserAuthErrorMessage class containing string constants used by error codes and messages.\n */\nconst BrowserAuthErrorMessages = {\n [pkceNotCreated]: \"The PKCE code challenge and verifier could not be generated.\",\n [cryptoNonExistent]: \"The crypto object or function is not available.\",\n [emptyNavigateUri]: \"Navigation URI is empty. Please check stack trace for more info.\",\n [hashEmptyError]: `Hash value cannot be processed because it is empty. Please verify that your redirectUri is not clearing the hash. ${ErrorLink}`,\n [noStateInHash]: \"Hash does not contain state. Please verify that the request originated from msal.\",\n [hashDoesNotContainKnownProperties]: `Hash does not contain known properites. Please verify that your redirectUri is not changing the hash. ${ErrorLink}`,\n [unableToParseState]: \"Unable to parse state. Please verify that the request originated from msal.\",\n [stateInteractionTypeMismatch]: \"Hash contains state but the interaction type does not match the caller.\",\n [interactionInProgress]: `Interaction is currently in progress. Please ensure that this interaction has been completed before calling an interactive API. ${ErrorLink}`,\n [popupWindowError]: \"Error opening popup window. This can happen if you are using IE or if popups are blocked in the browser.\",\n [emptyWindowError]: \"window.open returned null or undefined window object.\",\n [userCancelled]: \"User cancelled the flow.\",\n [monitorPopupTimeout]: `Token acquisition in popup failed due to timeout. ${ErrorLink}`,\n [monitorWindowTimeout]: `Token acquisition in iframe failed due to timeout. ${ErrorLink}`,\n [redirectInIframe]: \"Redirects are not supported for iframed or brokered applications. Please ensure you are using MSAL.js in a top frame of the window if using the redirect APIs, or use the popup APIs.\",\n [blockIframeReload]: `Request was blocked inside an iframe because MSAL detected an authentication response. ${ErrorLink}`,\n [blockNestedPopups]: \"Request was blocked inside a popup because MSAL detected it was running in a popup.\",\n [iframeClosedPrematurely]: \"The iframe being monitored was closed prematurely.\",\n [silentLogoutUnsupported]: \"Silent logout not supported. Please call logoutRedirect or logoutPopup instead.\",\n [noAccountError]: \"No account object provided to acquireTokenSilent and no active account has been set. Please call setActiveAccount or provide an account on the request.\",\n [silentPromptValueError]: \"The value given for the prompt value is not valid for silent requests - must be set to 'none' or 'no_session'.\",\n [noTokenRequestCacheError]: \"No token request found in cache.\",\n [unableToParseTokenRequestCacheError]: \"The cached token request could not be parsed.\",\n [noCachedAuthorityError]: \"No cached authority found.\",\n [authRequestNotSetError]: \"Auth Request not set. Please ensure initiateAuthRequest was called from the InteractionHandler\",\n [invalidCacheType]: \"Invalid cache type\",\n [nonBrowserEnvironment]: \"Login and token requests are not supported in non-browser environments.\",\n [databaseNotOpen]: \"Database is not open!\",\n [noNetworkConnectivity]: \"No network connectivity. Check your internet connection.\",\n [postRequestFailed]: \"Network request failed: If the browser threw a CORS error, check that the redirectUri is registered in the Azure App Portal as type 'SPA'\",\n [getRequestFailed]: \"Network request failed. Please check the network trace to determine root cause.\",\n [failedToParseResponse]: \"Failed to parse network response. Check network trace.\",\n [unableToLoadToken]: \"Error loading token to cache.\",\n [cryptoKeyNotFound]: \"Cryptographic Key or Keypair not found in browser storage.\",\n [authCodeRequired]: \"An authorization code must be provided (as the `code` property on the request) to this flow.\",\n [authCodeOrNativeAccountIdRequired]: \"An authorization code or nativeAccountId must be provided to this flow.\",\n [spaCodeAndNativeAccountIdPresent]: \"Request cannot contain both spa code and native account id.\",\n [databaseUnavailable]: \"IndexedDB, which is required for persistent cryptographic key storage, is unavailable. This may be caused by browser privacy features which block persistent storage in third-party contexts.\",\n [unableToAcquireTokenFromNativePlatform]: `Unable to acquire token from native platform. ${ErrorLink}`,\n [nativeHandshakeTimeout]: \"Timed out while attempting to establish connection to browser extension\",\n [nativeExtensionNotInstalled]: \"Native extension is not installed. If you think this is a mistake call the initialize function.\",\n [nativeConnectionNotEstablished]: `Connection to native platform has not been established. Please install a compatible browser extension and run initialize(). ${ErrorLink}`,\n [uninitializedPublicClientApplication]: `You must call and await the initialize function before attempting to call any other MSAL API. ${ErrorLink}`,\n [nativePromptNotSupported]: \"The provided prompt is not supported by the native platform. This request should be routed to the web based flow.\",\n [invalidBase64String]: \"Invalid base64 encoded string.\",\n [invalidPopTokenRequest]: \"Invalid PoP token request. The request should not have both a popKid value and signPopToken set to true.\",\n};\n/**\n * BrowserAuthErrorMessage class containing string constants used by error codes and messages.\n * @deprecated Use exported BrowserAuthErrorCodes instead.\n * In your app you can do :\n * ```\n * import { BrowserAuthErrorCodes } from \"@azure/msal-browser\";\n * ```\n */\nconst BrowserAuthErrorMessage = {\n pkceNotGenerated: {\n code: pkceNotCreated,\n desc: BrowserAuthErrorMessages[pkceNotCreated],\n },\n cryptoDoesNotExist: {\n code: cryptoNonExistent,\n desc: BrowserAuthErrorMessages[cryptoNonExistent],\n },\n emptyNavigateUriError: {\n code: emptyNavigateUri,\n desc: BrowserAuthErrorMessages[emptyNavigateUri],\n },\n hashEmptyError: {\n code: hashEmptyError,\n desc: BrowserAuthErrorMessages[hashEmptyError],\n },\n hashDoesNotContainStateError: {\n code: noStateInHash,\n desc: BrowserAuthErrorMessages[noStateInHash],\n },\n hashDoesNotContainKnownPropertiesError: {\n code: hashDoesNotContainKnownProperties,\n desc: BrowserAuthErrorMessages[hashDoesNotContainKnownProperties],\n },\n unableToParseStateError: {\n code: unableToParseState,\n desc: BrowserAuthErrorMessages[unableToParseState],\n },\n stateInteractionTypeMismatchError: {\n code: stateInteractionTypeMismatch,\n desc: BrowserAuthErrorMessages[stateInteractionTypeMismatch],\n },\n interactionInProgress: {\n code: interactionInProgress,\n desc: BrowserAuthErrorMessages[interactionInProgress],\n },\n popupWindowError: {\n code: popupWindowError,\n desc: BrowserAuthErrorMessages[popupWindowError],\n },\n emptyWindowError: {\n code: emptyWindowError,\n desc: BrowserAuthErrorMessages[emptyWindowError],\n },\n userCancelledError: {\n code: userCancelled,\n desc: BrowserAuthErrorMessages[userCancelled],\n },\n monitorPopupTimeoutError: {\n code: monitorPopupTimeout,\n desc: BrowserAuthErrorMessages[monitorPopupTimeout],\n },\n monitorIframeTimeoutError: {\n code: monitorWindowTimeout,\n desc: BrowserAuthErrorMessages[monitorWindowTimeout],\n },\n redirectInIframeError: {\n code: redirectInIframe,\n desc: BrowserAuthErrorMessages[redirectInIframe],\n },\n blockTokenRequestsInHiddenIframeError: {\n code: blockIframeReload,\n desc: BrowserAuthErrorMessages[blockIframeReload],\n },\n blockAcquireTokenInPopupsError: {\n code: blockNestedPopups,\n desc: BrowserAuthErrorMessages[blockNestedPopups],\n },\n iframeClosedPrematurelyError: {\n code: iframeClosedPrematurely,\n desc: BrowserAuthErrorMessages[iframeClosedPrematurely],\n },\n silentLogoutUnsupportedError: {\n code: silentLogoutUnsupported,\n desc: BrowserAuthErrorMessages[silentLogoutUnsupported],\n },\n noAccountError: {\n code: noAccountError,\n desc: BrowserAuthErrorMessages[noAccountError],\n },\n silentPromptValueError: {\n code: silentPromptValueError,\n desc: BrowserAuthErrorMessages[silentPromptValueError],\n },\n noTokenRequestCacheError: {\n code: noTokenRequestCacheError,\n desc: BrowserAuthErrorMessages[noTokenRequestCacheError],\n },\n unableToParseTokenRequestCacheError: {\n code: unableToParseTokenRequestCacheError,\n desc: BrowserAuthErrorMessages[unableToParseTokenRequestCacheError],\n },\n noCachedAuthorityError: {\n code: noCachedAuthorityError,\n desc: BrowserAuthErrorMessages[noCachedAuthorityError],\n },\n authRequestNotSet: {\n code: authRequestNotSetError,\n desc: BrowserAuthErrorMessages[authRequestNotSetError],\n },\n invalidCacheType: {\n code: invalidCacheType,\n desc: BrowserAuthErrorMessages[invalidCacheType],\n },\n notInBrowserEnvironment: {\n code: nonBrowserEnvironment,\n desc: BrowserAuthErrorMessages[nonBrowserEnvironment],\n },\n databaseNotOpen: {\n code: databaseNotOpen,\n desc: BrowserAuthErrorMessages[databaseNotOpen],\n },\n noNetworkConnectivity: {\n code: noNetworkConnectivity,\n desc: BrowserAuthErrorMessages[noNetworkConnectivity],\n },\n postRequestFailed: {\n code: postRequestFailed,\n desc: BrowserAuthErrorMessages[postRequestFailed],\n },\n getRequestFailed: {\n code: getRequestFailed,\n desc: BrowserAuthErrorMessages[getRequestFailed],\n },\n failedToParseNetworkResponse: {\n code: failedToParseResponse,\n desc: BrowserAuthErrorMessages[failedToParseResponse],\n },\n unableToLoadTokenError: {\n code: unableToLoadToken,\n desc: BrowserAuthErrorMessages[unableToLoadToken],\n },\n signingKeyNotFoundInStorage: {\n code: cryptoKeyNotFound,\n desc: BrowserAuthErrorMessages[cryptoKeyNotFound],\n },\n authCodeRequired: {\n code: authCodeRequired,\n desc: BrowserAuthErrorMessages[authCodeRequired],\n },\n authCodeOrNativeAccountRequired: {\n code: authCodeOrNativeAccountIdRequired,\n desc: BrowserAuthErrorMessages[authCodeOrNativeAccountIdRequired],\n },\n spaCodeAndNativeAccountPresent: {\n code: spaCodeAndNativeAccountIdPresent,\n desc: BrowserAuthErrorMessages[spaCodeAndNativeAccountIdPresent],\n },\n databaseUnavailable: {\n code: databaseUnavailable,\n desc: BrowserAuthErrorMessages[databaseUnavailable],\n },\n unableToAcquireTokenFromNativePlatform: {\n code: unableToAcquireTokenFromNativePlatform,\n desc: BrowserAuthErrorMessages[unableToAcquireTokenFromNativePlatform],\n },\n nativeHandshakeTimeout: {\n code: nativeHandshakeTimeout,\n desc: BrowserAuthErrorMessages[nativeHandshakeTimeout],\n },\n nativeExtensionNotInstalled: {\n code: nativeExtensionNotInstalled,\n desc: BrowserAuthErrorMessages[nativeExtensionNotInstalled],\n },\n nativeConnectionNotEstablished: {\n code: nativeConnectionNotEstablished,\n desc: BrowserAuthErrorMessages[nativeConnectionNotEstablished],\n },\n uninitializedPublicClientApplication: {\n code: uninitializedPublicClientApplication,\n desc: BrowserAuthErrorMessages[uninitializedPublicClientApplication],\n },\n nativePromptNotSupported: {\n code: nativePromptNotSupported,\n desc: BrowserAuthErrorMessages[nativePromptNotSupported],\n },\n invalidBase64StringError: {\n code: invalidBase64String,\n desc: BrowserAuthErrorMessages[invalidBase64String],\n },\n invalidPopTokenRequest: {\n code: invalidPopTokenRequest,\n desc: BrowserAuthErrorMessages[invalidPopTokenRequest],\n },\n};\n/**\n * Browser library error class thrown by the MSAL.js library for SPAs\n */\nclass BrowserAuthError extends AuthError {\n constructor(errorCode) {\n super(errorCode, BrowserAuthErrorMessages[errorCode]);\n Object.setPrototypeOf(this, BrowserAuthError.prototype);\n this.name = \"BrowserAuthError\";\n }\n}\nfunction createBrowserAuthError(errorCode) {\n return new BrowserAuthError(errorCode);\n}\n\nexport { BrowserAuthError, BrowserAuthErrorMessage, BrowserAuthErrorMessages, createBrowserAuthError };\n//# sourceMappingURL=BrowserAuthError.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { OIDC_DEFAULT_SCOPES } from '@azure/msal-common';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Constants\n */\nconst BrowserConstants = {\n /**\n * Interaction in progress cache value\n */\n INTERACTION_IN_PROGRESS_VALUE: \"interaction_in_progress\",\n /**\n * Invalid grant error code\n */\n INVALID_GRANT_ERROR: \"invalid_grant\",\n /**\n * Default popup window width\n */\n POPUP_WIDTH: 483,\n /**\n * Default popup window height\n */\n POPUP_HEIGHT: 600,\n /**\n * Name of the popup window starts with\n */\n POPUP_NAME_PREFIX: \"msal\",\n /**\n * Default popup monitor poll interval in milliseconds\n */\n DEFAULT_POLL_INTERVAL_MS: 30,\n /**\n * Msal-browser SKU\n */\n MSAL_SKU: \"msal.js.browser\",\n};\nconst NativeConstants = {\n CHANNEL_ID: \"53ee284d-920a-4b59-9d30-a60315b26836\",\n PREFERRED_EXTENSION_ID: \"ppnbnpeolgkicgegkbkbjmhlideopiji\",\n MATS_TELEMETRY: \"MATS\",\n};\nconst NativeExtensionMethod = {\n HandshakeRequest: \"Handshake\",\n HandshakeResponse: \"HandshakeResponse\",\n GetToken: \"GetToken\",\n Response: \"Response\",\n};\nconst BrowserCacheLocation = {\n LocalStorage: \"localStorage\",\n SessionStorage: \"sessionStorage\",\n MemoryStorage: \"memoryStorage\",\n};\n/**\n * HTTP Request types supported by MSAL.\n */\nconst HTTP_REQUEST_TYPE = {\n GET: \"GET\",\n POST: \"POST\",\n};\n/**\n * Temporary cache keys for MSAL, deleted after any request.\n */\nconst TemporaryCacheKeys = {\n AUTHORITY: \"authority\",\n ACQUIRE_TOKEN_ACCOUNT: \"acquireToken.account\",\n SESSION_STATE: \"session.state\",\n REQUEST_STATE: \"request.state\",\n NONCE_IDTOKEN: \"nonce.id_token\",\n ORIGIN_URI: \"request.origin\",\n RENEW_STATUS: \"token.renew.status\",\n URL_HASH: \"urlHash\",\n REQUEST_PARAMS: \"request.params\",\n SCOPES: \"scopes\",\n INTERACTION_STATUS_KEY: \"interaction.status\",\n CCS_CREDENTIAL: \"ccs.credential\",\n CORRELATION_ID: \"request.correlationId\",\n NATIVE_REQUEST: \"request.native\",\n REDIRECT_CONTEXT: \"request.redirect.context\",\n};\nconst StaticCacheKeys = {\n ACCOUNT_KEYS: \"msal.account.keys\",\n TOKEN_KEYS: \"msal.token.keys\",\n};\n/**\n * Cache keys stored in-memory\n */\nconst InMemoryCacheKeys = {\n WRAPPER_SKU: \"wrapper.sku\",\n WRAPPER_VER: \"wrapper.version\",\n};\n/**\n * API Codes for Telemetry purposes.\n * Before adding a new code you must claim it in the MSAL Telemetry tracker as these number spaces are shared across all MSALs\n * 0-99 Silent Flow\n * 800-899 Auth Code Flow\n */\nconst ApiId = {\n acquireTokenRedirect: 861,\n acquireTokenPopup: 862,\n ssoSilent: 863,\n acquireTokenSilent_authCode: 864,\n handleRedirectPromise: 865,\n acquireTokenByCode: 866,\n acquireTokenSilent_silentFlow: 61,\n logout: 961,\n logoutPopup: 962,\n};\n/*\n * Interaction type of the API - used for state and telemetry\n */\nvar InteractionType;\n(function (InteractionType) {\n InteractionType[\"Redirect\"] = \"redirect\";\n InteractionType[\"Popup\"] = \"popup\";\n InteractionType[\"Silent\"] = \"silent\";\n InteractionType[\"None\"] = \"none\";\n})(InteractionType || (InteractionType = {}));\n/**\n * Types of interaction currently in progress.\n * Used in events in wrapper libraries to invoke functions when certain interaction is in progress or all interactions are complete.\n */\nconst InteractionStatus = {\n /**\n * Initial status before interaction occurs\n */\n Startup: \"startup\",\n /**\n * Status set when all login calls occuring\n */\n Login: \"login\",\n /**\n * Status set when logout call occuring\n */\n Logout: \"logout\",\n /**\n * Status set for acquireToken calls\n */\n AcquireToken: \"acquireToken\",\n /**\n * Status set for ssoSilent calls\n */\n SsoSilent: \"ssoSilent\",\n /**\n * Status set when handleRedirect in progress\n */\n HandleRedirect: \"handleRedirect\",\n /**\n * Status set when interaction is complete\n */\n None: \"none\",\n};\nconst DEFAULT_REQUEST = {\n scopes: OIDC_DEFAULT_SCOPES,\n};\n/**\n * JWK Key Format string (Type MUST be defined for window crypto APIs)\n */\nconst KEY_FORMAT_JWK = \"jwk\";\n// Supported wrapper SKUs\nconst WrapperSKU = {\n React: \"@azure/msal-react\",\n Angular: \"@azure/msal-angular\",\n};\n// DatabaseStorage Constants\nconst DB_NAME = \"msal.db\";\nconst DB_VERSION = 1;\nconst DB_TABLE_NAME = `${DB_NAME}.keys`;\nconst CacheLookupPolicy = {\n /*\n * acquireTokenSilent will attempt to retrieve an access token from the cache. If the access token is expired\n * or cannot be found the refresh token will be used to acquire a new one. Finally, if the refresh token\n * is expired acquireTokenSilent will attempt to acquire new access and refresh tokens.\n */\n Default: 0,\n /*\n * acquireTokenSilent will only look for access tokens in the cache. It will not attempt to renew access or\n * refresh tokens.\n */\n AccessToken: 1,\n /*\n * acquireTokenSilent will attempt to retrieve an access token from the cache. If the access token is expired or\n * cannot be found, the refresh token will be used to acquire a new one. If the refresh token is expired, it\n * will not be renewed and acquireTokenSilent will fail.\n */\n AccessTokenAndRefreshToken: 2,\n /*\n * acquireTokenSilent will not attempt to retrieve access tokens from the cache and will instead attempt to\n * exchange the cached refresh token for a new access token. If the refresh token is expired, it will not be\n * renewed and acquireTokenSilent will fail.\n */\n RefreshToken: 3,\n /*\n * acquireTokenSilent will not look in the cache for the access token. It will go directly to network with the\n * cached refresh token. If the refresh token is expired an attempt will be made to renew it. This is equivalent to\n * setting \"forceRefresh: true\".\n */\n RefreshTokenAndNetwork: 4,\n /*\n * acquireTokenSilent will attempt to renew both access and refresh tokens. It will not look in the cache. This will\n * always fail if 3rd party cookies are blocked by the browser.\n */\n Skip: 5,\n};\nconst iFrameRenewalPolicies = [\n CacheLookupPolicy.Default,\n CacheLookupPolicy.Skip,\n CacheLookupPolicy.RefreshTokenAndNetwork,\n];\nconst LOG_LEVEL_CACHE_KEY = \"msal.browser.log.level\";\nconst LOG_PII_CACHE_KEY = \"msal.browser.log.pii\";\nconst BROWSER_PERF_ENABLED_KEY = \"msal.browser.performance.enabled\";\n\nexport { ApiId, BROWSER_PERF_ENABLED_KEY, BrowserCacheLocation, BrowserConstants, CacheLookupPolicy, DB_NAME, DB_TABLE_NAME, DB_VERSION, DEFAULT_REQUEST, HTTP_REQUEST_TYPE, InMemoryCacheKeys, InteractionStatus, InteractionType, KEY_FORMAT_JWK, LOG_LEVEL_CACHE_KEY, LOG_PII_CACHE_KEY, NativeConstants, NativeExtensionMethod, StaticCacheKeys, TemporaryCacheKeys, WrapperSKU, iFrameRenewalPolicies };\n//# sourceMappingURL=BrowserConstants.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Class which exposes APIs to encode plaintext to base64 encoded string. See here for implementation details:\n * https://developer.mozilla.org/en-US/docs/Web/API/WindowBase64/Base64_encoding_and_decoding#Solution_2_%E2%80%93_JavaScript's_UTF-16_%3E_UTF-8_%3E_base64\n */\n/**\n * Returns URL Safe b64 encoded string from a plaintext string.\n * @param input\n */\nfunction urlEncode(input) {\n return encodeURIComponent(base64Encode(input)\n .replace(/=/g, \"\")\n .replace(/\\+/g, \"-\")\n .replace(/\\//g, \"_\"));\n}\n/**\n * Returns URL Safe b64 encoded string from an int8Array.\n * @param inputArr\n */\nfunction urlEncodeArr(inputArr) {\n return base64EncArr(inputArr)\n .replace(/=/g, \"\")\n .replace(/\\+/g, \"-\")\n .replace(/\\//g, \"_\");\n}\n/**\n * Returns b64 encoded string from plaintext string.\n * @param input\n */\nfunction base64Encode(input) {\n return base64EncArr(new TextEncoder().encode(input));\n}\n/**\n * Base64 encode byte array\n * @param aBytes\n */\nfunction base64EncArr(aBytes) {\n const binString = Array.from(aBytes, (x) => String.fromCodePoint(x)).join(\"\");\n return btoa(binString);\n}\n\nexport { base64Encode, urlEncode, urlEncodeArr };\n//# sourceMappingURL=Base64Encode.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { PerformanceEvents } from '@azure/msal-common';\nimport { KEY_FORMAT_JWK } from '../utils/BrowserConstants.mjs';\nimport { urlEncodeArr } from '../encode/Base64Encode.mjs';\nimport { cryptoNonExistent } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * This file defines functions used by the browser library to perform cryptography operations such as\n * hashing and encoding. It also has helper functions to validate the availability of specific APIs.\n */\n/**\n * See here for more info on RsaHashedKeyGenParams: https://developer.mozilla.org/en-US/docs/Web/API/RsaHashedKeyGenParams\n */\n// RSA KeyGen Algorithm\nconst PKCS1_V15_KEYGEN_ALG = \"RSASSA-PKCS1-v1_5\";\n// SHA-256 hashing algorithm\nconst S256_HASH_ALG = \"SHA-256\";\n// MOD length for PoP tokens\nconst MODULUS_LENGTH = 2048;\n// Public Exponent\nconst PUBLIC_EXPONENT = new Uint8Array([0x01, 0x00, 0x01]);\n// UUID hex digits\nconst UUID_CHARS = \"0123456789abcdef\";\n// Array to store UINT32 random value\nconst UINT32_ARR = new Uint32Array(1);\nconst keygenAlgorithmOptions = {\n name: PKCS1_V15_KEYGEN_ALG,\n hash: S256_HASH_ALG,\n modulusLength: MODULUS_LENGTH,\n publicExponent: PUBLIC_EXPONENT,\n};\n/**\n * Check whether browser crypto is available.\n */\nfunction validateCryptoAvailable(logger) {\n if (\"crypto\" in window) {\n logger.verbose(\"BrowserCrypto: modern crypto interface available\");\n }\n else {\n logger.error(\"BrowserCrypto: crypto interface is unavailable\");\n throw createBrowserAuthError(cryptoNonExistent);\n }\n}\n/**\n * Returns a sha-256 hash of the given dataString as an ArrayBuffer.\n * @param dataString {string} data string\n * @param performanceClient {?IPerformanceClient}\n * @param correlationId {?string} correlation id\n */\nasync function sha256Digest(dataString, performanceClient, correlationId) {\n performanceClient?.addQueueMeasurement(PerformanceEvents.Sha256Digest, correlationId);\n const encoder = new TextEncoder();\n const data = encoder.encode(dataString);\n return window.crypto.subtle.digest(S256_HASH_ALG, data);\n}\n/**\n * Populates buffer with cryptographically random values.\n * @param dataBuffer\n */\nfunction getRandomValues(dataBuffer) {\n return window.crypto.getRandomValues(dataBuffer);\n}\n/**\n * Returns random Uint32 value.\n * @returns {number}\n */\nfunction getRandomUint32() {\n window.crypto.getRandomValues(UINT32_ARR);\n return UINT32_ARR[0];\n}\n/**\n * Creates a UUID v7 from the current timestamp.\n * Implementation relies on the system clock to guarantee increasing order of generated identifiers.\n * @returns {number}\n */\nfunction createNewGuid() {\n const currentTimestamp = Date.now();\n const baseRand = getRandomUint32() * 0x400 + (getRandomUint32() & 0x3ff);\n // Result byte array\n const bytes = new Uint8Array(16);\n // A 12-bit `rand_a` field value\n const randA = Math.trunc(baseRand / 2 ** 30);\n // The higher 30 bits of 62-bit `rand_b` field value\n const randBHi = baseRand & (2 ** 30 - 1);\n // The lower 32 bits of 62-bit `rand_b` field value\n const randBLo = getRandomUint32();\n bytes[0] = currentTimestamp / 2 ** 40;\n bytes[1] = currentTimestamp / 2 ** 32;\n bytes[2] = currentTimestamp / 2 ** 24;\n bytes[3] = currentTimestamp / 2 ** 16;\n bytes[4] = currentTimestamp / 2 ** 8;\n bytes[5] = currentTimestamp;\n bytes[6] = 0x70 | (randA >>> 8);\n bytes[7] = randA;\n bytes[8] = 0x80 | (randBHi >>> 24);\n bytes[9] = randBHi >>> 16;\n bytes[10] = randBHi >>> 8;\n bytes[11] = randBHi;\n bytes[12] = randBLo >>> 24;\n bytes[13] = randBLo >>> 16;\n bytes[14] = randBLo >>> 8;\n bytes[15] = randBLo;\n let text = \"\";\n for (let i = 0; i < bytes.length; i++) {\n text += UUID_CHARS.charAt(bytes[i] >>> 4);\n text += UUID_CHARS.charAt(bytes[i] & 0xf);\n if (i === 3 || i === 5 || i === 7 || i === 9) {\n text += \"-\";\n }\n }\n return text;\n}\n/**\n * Generates a keypair based on current keygen algorithm config.\n * @param extractable\n * @param usages\n */\nasync function generateKeyPair(extractable, usages) {\n return window.crypto.subtle.generateKey(keygenAlgorithmOptions, extractable, usages);\n}\n/**\n * Export key as Json Web Key (JWK)\n * @param key\n */\nasync function exportJwk(key) {\n return window.crypto.subtle.exportKey(KEY_FORMAT_JWK, key);\n}\n/**\n * Imports key as Json Web Key (JWK), can set extractable and usages.\n * @param key\n * @param extractable\n * @param usages\n */\nasync function importJwk(key, extractable, usages) {\n return window.crypto.subtle.importKey(KEY_FORMAT_JWK, key, keygenAlgorithmOptions, extractable, usages);\n}\n/**\n * Signs given data with given key\n * @param key\n * @param data\n */\nasync function sign(key, data) {\n return window.crypto.subtle.sign(keygenAlgorithmOptions, key, data);\n}\n/**\n * Returns the SHA-256 hash of an input string\n * @param plainText\n */\nasync function hashString(plainText) {\n const hashBuffer = await sha256Digest(plainText);\n const hashBytes = new Uint8Array(hashBuffer);\n return urlEncodeArr(hashBytes);\n}\n\nexport { createNewGuid, exportJwk, generateKeyPair, getRandomValues, hashString, importJwk, sha256Digest, sign, validateCryptoAvailable };\n//# sourceMappingURL=BrowserCrypto.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst storageNotSupported = \"storage_not_supported\";\nconst stubbedPublicClientApplicationCalled = \"stubbed_public_client_application_called\";\nconst inMemRedirectUnavailable = \"in_mem_redirect_unavailable\";\n\nexport { inMemRedirectUnavailable, storageNotSupported, stubbedPublicClientApplicationCalled };\n//# sourceMappingURL=BrowserConfigurationAuthErrorCodes.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { AuthError } from '@azure/msal-common';\nimport { storageNotSupported, stubbedPublicClientApplicationCalled, inMemRedirectUnavailable } from './BrowserConfigurationAuthErrorCodes.mjs';\nimport * as BrowserConfigurationAuthErrorCodes from './BrowserConfigurationAuthErrorCodes.mjs';\nexport { BrowserConfigurationAuthErrorCodes };\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst BrowserConfigurationAuthErrorMessages = {\n [storageNotSupported]: \"Given storage configuration option was not supported.\",\n [stubbedPublicClientApplicationCalled]: \"Stub instance of Public Client Application was called. If using msal-react, please ensure context is not used without a provider. For more visit: aka.ms/msaljs/browser-errors\",\n [inMemRedirectUnavailable]: \"Redirect cannot be supported. In-memory storage was selected and storeAuthStateInCookie=false, which would cause the library to be unable to handle the incoming hash. If you would like to use the redirect API, please use session/localStorage or set storeAuthStateInCookie=true.\",\n};\n/**\n * BrowserAuthErrorMessage class containing string constants used by error codes and messages.\n * @deprecated Use BrowserAuthErrorCodes instead\n */\nconst BrowserConfigurationAuthErrorMessage = {\n storageNotSupportedError: {\n code: storageNotSupported,\n desc: BrowserConfigurationAuthErrorMessages[storageNotSupported],\n },\n stubPcaInstanceCalled: {\n code: stubbedPublicClientApplicationCalled,\n desc: BrowserConfigurationAuthErrorMessages[stubbedPublicClientApplicationCalled],\n },\n inMemRedirectUnavailable: {\n code: inMemRedirectUnavailable,\n desc: BrowserConfigurationAuthErrorMessages[inMemRedirectUnavailable],\n },\n};\n/**\n * Browser library error class thrown by the MSAL.js library for SPAs\n */\nclass BrowserConfigurationAuthError extends AuthError {\n constructor(errorCode, errorMessage) {\n super(errorCode, errorMessage);\n this.name = \"BrowserConfigurationAuthError\";\n Object.setPrototypeOf(this, BrowserConfigurationAuthError.prototype);\n }\n}\nfunction createBrowserConfigurationAuthError(errorCode) {\n return new BrowserConfigurationAuthError(errorCode, BrowserConfigurationAuthErrorMessages[errorCode]);\n}\n\nexport { BrowserConfigurationAuthError, BrowserConfigurationAuthErrorMessage, BrowserConfigurationAuthErrorMessages, createBrowserConfigurationAuthError };\n//# sourceMappingURL=BrowserConfigurationAuthError.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { UrlString } from '@azure/msal-common';\nexport { invoke, invokeAsync } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { BrowserConstants, BrowserCacheLocation } from './BrowserConstants.mjs';\nimport { createNewGuid } from '../crypto/BrowserCrypto.mjs';\nimport { createBrowserConfigurationAuthError } from '../error/BrowserConfigurationAuthError.mjs';\nimport { blockIframeReload, redirectInIframe, blockNestedPopups, nonBrowserEnvironment, uninitializedPublicClientApplication } from '../error/BrowserAuthErrorCodes.mjs';\nimport { inMemRedirectUnavailable } from '../error/BrowserConfigurationAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Clears hash from window url.\n */\nfunction clearHash(contentWindow) {\n // Office.js sets history.replaceState to null\n contentWindow.location.hash = \"\";\n if (typeof contentWindow.history.replaceState === \"function\") {\n // Full removes \"#\" from url\n contentWindow.history.replaceState(null, \"\", `${contentWindow.location.origin}${contentWindow.location.pathname}${contentWindow.location.search}`);\n }\n}\n/**\n * Replaces current hash with hash from provided url\n */\nfunction replaceHash(url) {\n const urlParts = url.split(\"#\");\n urlParts.shift(); // Remove part before the hash\n window.location.hash = urlParts.length > 0 ? urlParts.join(\"#\") : \"\";\n}\n/**\n * Returns boolean of whether the current window is in an iframe or not.\n */\nfunction isInIframe() {\n return window.parent !== window;\n}\n/**\n * Returns boolean of whether or not the current window is a popup opened by msal\n */\nfunction isInPopup() {\n return (typeof window !== \"undefined\" &&\n !!window.opener &&\n window.opener !== window &&\n typeof window.name === \"string\" &&\n window.name.indexOf(`${BrowserConstants.POPUP_NAME_PREFIX}.`) === 0);\n}\n// #endregion\n/**\n * Returns current window URL as redirect uri\n */\nfunction getCurrentUri() {\n return window.location.href.split(\"?\")[0].split(\"#\")[0];\n}\n/**\n * Gets the homepage url for the current window location.\n */\nfunction getHomepage() {\n const currentUrl = new UrlString(window.location.href);\n const urlComponents = currentUrl.getUrlComponents();\n return `${urlComponents.Protocol}//${urlComponents.HostNameAndPort}/`;\n}\n/**\n * Throws error if we have completed an auth and are\n * attempting another auth request inside an iframe.\n */\nfunction blockReloadInHiddenIframes() {\n const isResponseHash = UrlString.hashContainsKnownProperties(window.location.hash);\n // return an error if called from the hidden iframe created by the msal js silent calls\n if (isResponseHash && isInIframe()) {\n throw createBrowserAuthError(blockIframeReload);\n }\n}\n/**\n * Block redirect operations in iframes unless explicitly allowed\n * @param interactionType Interaction type for the request\n * @param allowRedirectInIframe Config value to allow redirects when app is inside an iframe\n */\nfunction blockRedirectInIframe(allowRedirectInIframe) {\n if (isInIframe() && !allowRedirectInIframe) {\n // If we are not in top frame, we shouldn't redirect. This is also handled by the service.\n throw createBrowserAuthError(redirectInIframe);\n }\n}\n/**\n * Block redirectUri loaded in popup from calling AcquireToken APIs\n */\nfunction blockAcquireTokenInPopups() {\n // Popups opened by msal popup APIs are given a name that starts with \"msal.\"\n if (isInPopup()) {\n throw createBrowserAuthError(blockNestedPopups);\n }\n}\n/**\n * Throws error if token requests are made in non-browser environment\n * @param isBrowserEnvironment Flag indicating if environment is a browser.\n */\nfunction blockNonBrowserEnvironment() {\n if (typeof window === \"undefined\") {\n throw createBrowserAuthError(nonBrowserEnvironment);\n }\n}\n/**\n * Throws error if initialize hasn't been called\n * @param initialized\n */\nfunction blockAPICallsBeforeInitialize(initialized) {\n if (!initialized) {\n throw createBrowserAuthError(uninitializedPublicClientApplication);\n }\n}\n/**\n * Helper to validate app environment before making an auth request\n * @param initialized\n */\nfunction preflightCheck(initialized) {\n // Block request if not in browser environment\n blockNonBrowserEnvironment();\n // Block auth requests inside a hidden iframe\n blockReloadInHiddenIframes();\n // Block redirectUri opened in a popup from calling MSAL APIs\n blockAcquireTokenInPopups();\n // Block token acquisition before initialize has been called\n blockAPICallsBeforeInitialize(initialized);\n}\n/**\n * Helper to validate app enviornment before making redirect request\n * @param initialized\n * @param config\n */\nfunction redirectPreflightCheck(initialized, config) {\n preflightCheck(initialized);\n blockRedirectInIframe(config.system.allowRedirectInIframe);\n // Block redirects if memory storage is enabled but storeAuthStateInCookie is not\n if (config.cache.cacheLocation === BrowserCacheLocation.MemoryStorage &&\n !config.cache.storeAuthStateInCookie) {\n throw createBrowserConfigurationAuthError(inMemRedirectUnavailable);\n }\n}\n/**\n * Adds a preconnect link element to the header which begins DNS resolution and SSL connection in anticipation of the /token request\n * @param loginDomain Authority domain, including https protocol e.g. https://login.microsoftonline.com\n * @returns\n */\nfunction preconnect(authority) {\n const link = document.createElement(\"link\");\n link.rel = \"preconnect\";\n link.href = new URL(authority).origin;\n link.crossOrigin = \"anonymous\";\n document.head.appendChild(link);\n // The browser will close connection if not used within a few seconds, remove element from the header after 10s\n window.setTimeout(() => {\n try {\n document.head.removeChild(link);\n }\n catch { }\n }, 10000); // 10s Timeout\n}\n/**\n * Wrapper function that creates a UUID v7 from the current timestamp.\n * @returns {string}\n */\nfunction createGuid() {\n return createNewGuid();\n}\n\nexport { blockAPICallsBeforeInitialize, blockAcquireTokenInPopups, blockNonBrowserEnvironment, blockRedirectInIframe, blockReloadInHiddenIframes, clearHash, createGuid, getCurrentUri, getHomepage, isInIframe, isInPopup, preconnect, preflightCheck, redirectPreflightCheck, replaceHash };\n//# sourceMappingURL=BrowserUtils.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass NavigationClient {\n /**\n * Navigates to other pages within the same web application\n * @param url\n * @param options\n */\n navigateInternal(url, options) {\n return NavigationClient.defaultNavigateWindow(url, options);\n }\n /**\n * Navigates to other pages outside the web application i.e. the Identity Provider\n * @param url\n * @param options\n */\n navigateExternal(url, options) {\n return NavigationClient.defaultNavigateWindow(url, options);\n }\n /**\n * Default navigation implementation invoked by the internal and external functions\n * @param url\n * @param options\n */\n static defaultNavigateWindow(url, options) {\n if (options.noHistory) {\n window.location.replace(url);\n }\n else {\n window.location.assign(url);\n }\n return new Promise((resolve) => {\n setTimeout(() => {\n resolve(true);\n }, options.timeout);\n });\n }\n}\n\nexport { NavigationClient };\n//# sourceMappingURL=NavigationClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { Constants } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { HTTP_REQUEST_TYPE } from '../utils/BrowserConstants.mjs';\nimport { getRequestFailed, noNetworkConnectivity, failedToParseResponse, postRequestFailed } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * This class implements the Fetch API for GET and POST requests. See more here: https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API\n */\nclass FetchClient {\n /**\n * Fetch Client for REST endpoints - Get request\n * @param url\n * @param headers\n * @param body\n */\n async sendGetRequestAsync(url, options) {\n let response;\n try {\n response = await fetch(url, {\n method: HTTP_REQUEST_TYPE.GET,\n headers: this.getFetchHeaders(options),\n });\n }\n catch (e) {\n if (window.navigator.onLine) {\n throw createBrowserAuthError(getRequestFailed);\n }\n else {\n throw createBrowserAuthError(noNetworkConnectivity);\n }\n }\n try {\n return {\n headers: this.getHeaderDict(response.headers),\n body: (await response.json()),\n status: response.status,\n };\n }\n catch (e) {\n throw createBrowserAuthError(failedToParseResponse);\n }\n }\n /**\n * Fetch Client for REST endpoints - Post request\n * @param url\n * @param headers\n * @param body\n */\n async sendPostRequestAsync(url, options) {\n const reqBody = (options && options.body) || Constants.EMPTY_STRING;\n let response;\n try {\n response = await fetch(url, {\n method: HTTP_REQUEST_TYPE.POST,\n headers: this.getFetchHeaders(options),\n body: reqBody,\n });\n }\n catch (e) {\n if (window.navigator.onLine) {\n throw createBrowserAuthError(postRequestFailed);\n }\n else {\n throw createBrowserAuthError(noNetworkConnectivity);\n }\n }\n try {\n return {\n headers: this.getHeaderDict(response.headers),\n body: (await response.json()),\n status: response.status,\n };\n }\n catch (e) {\n throw createBrowserAuthError(failedToParseResponse);\n }\n }\n /**\n * Get Fetch API Headers object from string map\n * @param inputHeaders\n */\n getFetchHeaders(options) {\n const headers = new Headers();\n if (!(options && options.headers)) {\n return headers;\n }\n const optionsHeaders = options.headers;\n Object.keys(optionsHeaders).forEach((key) => {\n headers.append(key, optionsHeaders[key]);\n });\n return headers;\n }\n getHeaderDict(headers) {\n const headerDict = {};\n headers.forEach((value, key) => {\n headerDict[key] = value;\n });\n return headerDict;\n }\n}\n\nexport { FetchClient };\n//# sourceMappingURL=FetchClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { Constants, StubPerformanceClient, ProtocolMode, Logger, createClientConfigurationError, ClientConfigurationErrorCodes, ServerResponseType, AzureCloudInstance, LogLevel, DEFAULT_SYSTEM_OPTIONS, StubbedNetworkModule } from '@azure/msal-common';\nimport { BrowserCacheLocation, BrowserConstants } from '../utils/BrowserConstants.mjs';\nimport { NavigationClient } from '../navigation/NavigationClient.mjs';\nimport { FetchClient } from '../network/FetchClient.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n// Default timeout for popup windows and iframes in milliseconds\nconst DEFAULT_POPUP_TIMEOUT_MS = 60000;\nconst DEFAULT_IFRAME_TIMEOUT_MS = 10000;\nconst DEFAULT_REDIRECT_TIMEOUT_MS = 30000;\nconst DEFAULT_NATIVE_BROKER_HANDSHAKE_TIMEOUT_MS = 2000;\n/**\n * MSAL function that sets the default options when not explicitly configured from app developer\n *\n * @param auth\n * @param cache\n * @param system\n *\n * @returns Configuration object\n */\nfunction buildConfiguration({ auth: userInputAuth, cache: userInputCache, system: userInputSystem, telemetry: userInputTelemetry, }, isBrowserEnvironment) {\n // Default auth options for browser\n const DEFAULT_AUTH_OPTIONS = {\n clientId: Constants.EMPTY_STRING,\n authority: `${Constants.DEFAULT_AUTHORITY}`,\n knownAuthorities: [],\n cloudDiscoveryMetadata: Constants.EMPTY_STRING,\n authorityMetadata: Constants.EMPTY_STRING,\n redirectUri: Constants.EMPTY_STRING,\n postLogoutRedirectUri: Constants.EMPTY_STRING,\n navigateToLoginRequestUrl: true,\n clientCapabilities: [],\n protocolMode: ProtocolMode.AAD,\n OIDCOptions: {\n serverResponseType: ServerResponseType.FRAGMENT,\n defaultScopes: [\n Constants.OPENID_SCOPE,\n Constants.PROFILE_SCOPE,\n Constants.OFFLINE_ACCESS_SCOPE,\n ],\n },\n azureCloudOptions: {\n azureCloudInstance: AzureCloudInstance.None,\n tenant: Constants.EMPTY_STRING,\n },\n skipAuthorityMetadataCache: false,\n supportsNestedAppAuth: false,\n };\n // Default cache options for browser\n const DEFAULT_CACHE_OPTIONS = {\n cacheLocation: BrowserCacheLocation.SessionStorage,\n temporaryCacheLocation: BrowserCacheLocation.SessionStorage,\n storeAuthStateInCookie: false,\n secureCookies: false,\n // Default cache migration to true if cache location is localStorage since entries are preserved across tabs/windows. Migration has little to no benefit in sessionStorage and memoryStorage\n cacheMigrationEnabled: userInputCache &&\n userInputCache.cacheLocation === BrowserCacheLocation.LocalStorage\n ? true\n : false,\n claimsBasedCachingEnabled: false,\n };\n // Default logger options for browser\n const DEFAULT_LOGGER_OPTIONS = {\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n loggerCallback: () => {\n // allow users to not set logger call back\n },\n logLevel: LogLevel.Info,\n piiLoggingEnabled: false,\n };\n // Default system options for browser\n const DEFAULT_BROWSER_SYSTEM_OPTIONS = {\n ...DEFAULT_SYSTEM_OPTIONS,\n loggerOptions: DEFAULT_LOGGER_OPTIONS,\n networkClient: isBrowserEnvironment\n ? new FetchClient()\n : StubbedNetworkModule,\n navigationClient: new NavigationClient(),\n loadFrameTimeout: 0,\n // If loadFrameTimeout is provided, use that as default.\n windowHashTimeout: userInputSystem?.loadFrameTimeout || DEFAULT_POPUP_TIMEOUT_MS,\n iframeHashTimeout: userInputSystem?.loadFrameTimeout || DEFAULT_IFRAME_TIMEOUT_MS,\n navigateFrameWait: 0,\n redirectNavigationTimeout: DEFAULT_REDIRECT_TIMEOUT_MS,\n asyncPopups: false,\n allowRedirectInIframe: false,\n allowNativeBroker: false,\n nativeBrokerHandshakeTimeout: userInputSystem?.nativeBrokerHandshakeTimeout ||\n DEFAULT_NATIVE_BROKER_HANDSHAKE_TIMEOUT_MS,\n pollIntervalMilliseconds: BrowserConstants.DEFAULT_POLL_INTERVAL_MS,\n };\n const providedSystemOptions = {\n ...DEFAULT_BROWSER_SYSTEM_OPTIONS,\n ...userInputSystem,\n loggerOptions: userInputSystem?.loggerOptions || DEFAULT_LOGGER_OPTIONS,\n };\n const DEFAULT_TELEMETRY_OPTIONS = {\n application: {\n appName: Constants.EMPTY_STRING,\n appVersion: Constants.EMPTY_STRING,\n },\n client: new StubPerformanceClient(),\n };\n // Throw an error if user has set OIDCOptions without being in OIDC protocol mode\n if (userInputAuth?.protocolMode !== ProtocolMode.OIDC &&\n userInputAuth?.OIDCOptions) {\n const logger = new Logger(providedSystemOptions.loggerOptions);\n logger.warning(JSON.stringify(createClientConfigurationError(ClientConfigurationErrorCodes.cannotSetOIDCOptions)));\n }\n // Throw an error if user has set allowNativeBroker to true without being in AAD protocol mode\n if (userInputAuth?.protocolMode &&\n userInputAuth.protocolMode !== ProtocolMode.AAD &&\n providedSystemOptions?.allowNativeBroker) {\n throw createClientConfigurationError(ClientConfigurationErrorCodes.cannotAllowNativeBroker);\n }\n const overlayedConfig = {\n auth: {\n ...DEFAULT_AUTH_OPTIONS,\n ...userInputAuth,\n OIDCOptions: {\n ...DEFAULT_AUTH_OPTIONS.OIDCOptions,\n ...userInputAuth?.OIDCOptions,\n },\n },\n cache: { ...DEFAULT_CACHE_OPTIONS, ...userInputCache },\n system: providedSystemOptions,\n telemetry: { ...DEFAULT_TELEMETRY_OPTIONS, ...userInputTelemetry },\n };\n return overlayedConfig;\n}\n\nexport { DEFAULT_IFRAME_TIMEOUT_MS, DEFAULT_NATIVE_BROKER_HANDSHAKE_TIMEOUT_MS, DEFAULT_POPUP_TIMEOUT_MS, DEFAULT_REDIRECT_TIMEOUT_MS, buildConfiguration };\n//# sourceMappingURL=Configuration.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/* eslint-disable header/header */\nconst name = \"@azure/msal-browser\";\nconst version = \"3.19.1\";\n\nexport { name, version };\n//# sourceMappingURL=packageMetadata.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { LogLevel, Logger } from '@azure/msal-common';\nimport { buildConfiguration } from '../config/Configuration.mjs';\nimport { name, version } from '../packageMetadata.mjs';\nimport { BrowserCacheLocation, LOG_LEVEL_CACHE_KEY, LOG_PII_CACHE_KEY } from '../utils/BrowserConstants.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Base class for operating context\n * Operating contexts are contexts in which MSAL.js is being run\n * More than one operating context may be available at a time\n * It's important from a logging and telemetry point of view for us to be able to identify the operating context.\n * For example: Some operating contexts will pre-cache tokens impacting performance telemetry\n */\nclass BaseOperatingContext {\n static loggerCallback(level, message) {\n switch (level) {\n case LogLevel.Error:\n // eslint-disable-next-line no-console\n console.error(message);\n return;\n case LogLevel.Info:\n // eslint-disable-next-line no-console\n console.info(message);\n return;\n case LogLevel.Verbose:\n // eslint-disable-next-line no-console\n console.debug(message);\n return;\n case LogLevel.Warning:\n // eslint-disable-next-line no-console\n console.warn(message);\n return;\n default:\n // eslint-disable-next-line no-console\n console.log(message);\n return;\n }\n }\n constructor(config) {\n /*\n * If loaded in an environment where window is not available,\n * set internal flag to false so that further requests fail.\n * This is to support server-side rendering environments.\n */\n this.browserEnvironment = typeof window !== \"undefined\";\n this.config = buildConfiguration(config, this.browserEnvironment);\n let sessionStorage;\n try {\n sessionStorage = window[BrowserCacheLocation.SessionStorage];\n // Mute errors if it's a non-browser environment or cookies are blocked.\n }\n catch (e) { }\n const logLevelKey = sessionStorage?.getItem(LOG_LEVEL_CACHE_KEY);\n const piiLoggingKey = sessionStorage\n ?.getItem(LOG_PII_CACHE_KEY)\n ?.toLowerCase();\n const piiLoggingEnabled = piiLoggingKey === \"true\"\n ? true\n : piiLoggingKey === \"false\"\n ? false\n : undefined;\n const loggerOptions = { ...this.config.system.loggerOptions };\n const logLevel = logLevelKey && Object.keys(LogLevel).includes(logLevelKey)\n ? LogLevel[logLevelKey]\n : undefined;\n if (logLevel) {\n loggerOptions.loggerCallback = BaseOperatingContext.loggerCallback;\n loggerOptions.logLevel = logLevel;\n }\n if (piiLoggingEnabled !== undefined) {\n loggerOptions.piiLoggingEnabled = piiLoggingEnabled;\n }\n this.logger = new Logger(loggerOptions, name, version);\n this.available = false;\n }\n /**\n * Return the MSAL config\n * @returns BrowserConfiguration\n */\n getConfig() {\n return this.config;\n }\n /**\n * Returns the MSAL Logger\n * @returns Logger\n */\n getLogger() {\n return this.logger;\n }\n isAvailable() {\n return this.available;\n }\n isBrowserEnvironment() {\n return this.browserEnvironment;\n }\n}\n\nexport { BaseOperatingContext };\n//# sourceMappingURL=BaseOperatingContext.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { BaseOperatingContext } from './BaseOperatingContext.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass StandardOperatingContext extends BaseOperatingContext {\n /**\n * Return the module name. Intended for use with import() to enable dynamic import\n * of the implementation associated with this operating context\n * @returns\n */\n getModuleName() {\n return StandardOperatingContext.MODULE_NAME;\n }\n /**\n * Returns the unique identifier for this operating context\n * @returns string\n */\n getId() {\n return StandardOperatingContext.ID;\n }\n /**\n * Checks whether the operating context is available.\n * Confirms that the code is running a browser rather. This is required.\n * @returns Promise indicating whether this operating context is currently available.\n */\n async initialize() {\n this.available = typeof window !== \"undefined\";\n return this.available;\n /*\n * NOTE: The standard context is available as long as there is a window. If/when we split out WAM from Browser\n * We can move the current contents of the initialize method to here and verify that the WAM extension is available\n */\n }\n}\n/*\n * TODO: Once we have determine the bundling code return here to specify the name of the bundle\n * containing the implementation for this operating context\n */\nStandardOperatingContext.MODULE_NAME = \"\";\n/**\n * Unique identifier for the operating context\n */\nStandardOperatingContext.ID = \"StandardOperatingContext\";\n\nexport { StandardOperatingContext };\n//# sourceMappingURL=StandardOperatingContext.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { invalidBase64String } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Class which exposes APIs to decode base64 strings to plaintext. See here for implementation details:\n * https://developer.mozilla.org/en-US/docs/Glossary/Base64#the_unicode_problem\n */\n/**\n * Returns a URL-safe plaintext decoded string from b64 encoded input.\n * @param input\n */\nfunction base64Decode(input) {\n return new TextDecoder().decode(base64DecToArr(input));\n}\n/**\n * Decodes base64 into Uint8Array\n * @param base64String\n */\nfunction base64DecToArr(base64String) {\n let encodedString = base64String.replace(/-/g, \"+\").replace(/_/g, \"/\");\n switch (encodedString.length % 4) {\n case 0:\n break;\n case 2:\n encodedString += \"==\";\n break;\n case 3:\n encodedString += \"=\";\n break;\n default:\n throw createBrowserAuthError(invalidBase64String);\n }\n const binString = atob(encodedString);\n return Uint8Array.from(binString, (m) => m.codePointAt(0) || 0);\n}\n\nexport { base64Decode };\n//# sourceMappingURL=Base64Decode.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { DB_NAME, DB_VERSION, DB_TABLE_NAME } from '../utils/BrowserConstants.mjs';\nimport { databaseUnavailable, databaseNotOpen } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Storage wrapper for IndexedDB storage in browsers: https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API\n */\nclass DatabaseStorage {\n constructor() {\n this.dbName = DB_NAME;\n this.version = DB_VERSION;\n this.tableName = DB_TABLE_NAME;\n this.dbOpen = false;\n }\n /**\n * Opens IndexedDB instance.\n */\n async open() {\n return new Promise((resolve, reject) => {\n const openDB = window.indexedDB.open(this.dbName, this.version);\n openDB.addEventListener(\"upgradeneeded\", (e) => {\n const event = e;\n event.target.result.createObjectStore(this.tableName);\n });\n openDB.addEventListener(\"success\", (e) => {\n const event = e;\n this.db = event.target.result;\n this.dbOpen = true;\n resolve();\n });\n openDB.addEventListener(\"error\", () => reject(createBrowserAuthError(databaseUnavailable)));\n });\n }\n /**\n * Closes the connection to IndexedDB database when all pending transactions\n * complete.\n */\n closeConnection() {\n const db = this.db;\n if (db && this.dbOpen) {\n db.close();\n this.dbOpen = false;\n }\n }\n /**\n * Opens database if it's not already open\n */\n async validateDbIsOpen() {\n if (!this.dbOpen) {\n return this.open();\n }\n }\n /**\n * Retrieves item from IndexedDB instance.\n * @param key\n */\n async getItem(key) {\n await this.validateDbIsOpen();\n return new Promise((resolve, reject) => {\n // TODO: Add timeouts?\n if (!this.db) {\n return reject(createBrowserAuthError(databaseNotOpen));\n }\n const transaction = this.db.transaction([this.tableName], \"readonly\");\n const objectStore = transaction.objectStore(this.tableName);\n const dbGet = objectStore.get(key);\n dbGet.addEventListener(\"success\", (e) => {\n const event = e;\n this.closeConnection();\n resolve(event.target.result);\n });\n dbGet.addEventListener(\"error\", (e) => {\n this.closeConnection();\n reject(e);\n });\n });\n }\n /**\n * Adds item to IndexedDB under given key\n * @param key\n * @param payload\n */\n async setItem(key, payload) {\n await this.validateDbIsOpen();\n return new Promise((resolve, reject) => {\n // TODO: Add timeouts?\n if (!this.db) {\n return reject(createBrowserAuthError(databaseNotOpen));\n }\n const transaction = this.db.transaction([this.tableName], \"readwrite\");\n const objectStore = transaction.objectStore(this.tableName);\n const dbPut = objectStore.put(payload, key);\n dbPut.addEventListener(\"success\", () => {\n this.closeConnection();\n resolve();\n });\n dbPut.addEventListener(\"error\", (e) => {\n this.closeConnection();\n reject(e);\n });\n });\n }\n /**\n * Removes item from IndexedDB under given key\n * @param key\n */\n async removeItem(key) {\n await this.validateDbIsOpen();\n return new Promise((resolve, reject) => {\n if (!this.db) {\n return reject(createBrowserAuthError(databaseNotOpen));\n }\n const transaction = this.db.transaction([this.tableName], \"readwrite\");\n const objectStore = transaction.objectStore(this.tableName);\n const dbDelete = objectStore.delete(key);\n dbDelete.addEventListener(\"success\", () => {\n this.closeConnection();\n resolve();\n });\n dbDelete.addEventListener(\"error\", (e) => {\n this.closeConnection();\n reject(e);\n });\n });\n }\n /**\n * Get all the keys from the storage object as an iterable array of strings.\n */\n async getKeys() {\n await this.validateDbIsOpen();\n return new Promise((resolve, reject) => {\n if (!this.db) {\n return reject(createBrowserAuthError(databaseNotOpen));\n }\n const transaction = this.db.transaction([this.tableName], \"readonly\");\n const objectStore = transaction.objectStore(this.tableName);\n const dbGetKeys = objectStore.getAllKeys();\n dbGetKeys.addEventListener(\"success\", (e) => {\n const event = e;\n this.closeConnection();\n resolve(event.target.result);\n });\n dbGetKeys.addEventListener(\"error\", (e) => {\n this.closeConnection();\n reject(e);\n });\n });\n }\n /**\n *\n * Checks whether there is an object under the search key in the object store\n */\n async containsKey(key) {\n await this.validateDbIsOpen();\n return new Promise((resolve, reject) => {\n if (!this.db) {\n return reject(createBrowserAuthError(databaseNotOpen));\n }\n const transaction = this.db.transaction([this.tableName], \"readonly\");\n const objectStore = transaction.objectStore(this.tableName);\n const dbContainsKey = objectStore.count(key);\n dbContainsKey.addEventListener(\"success\", (e) => {\n const event = e;\n this.closeConnection();\n resolve(event.target.result === 1);\n });\n dbContainsKey.addEventListener(\"error\", (e) => {\n this.closeConnection();\n reject(e);\n });\n });\n }\n /**\n * Deletes the MSAL database. The database is deleted rather than cleared to make it possible\n * for client applications to downgrade to a previous MSAL version without worrying about forward compatibility issues\n * with IndexedDB database versions.\n */\n async deleteDatabase() {\n // Check if database being deleted exists\n if (this.db && this.dbOpen) {\n this.closeConnection();\n }\n return new Promise((resolve, reject) => {\n const deleteDbRequest = window.indexedDB.deleteDatabase(DB_NAME);\n const id = setTimeout(() => reject(false), 200); // Reject if events aren't raised within 200ms\n deleteDbRequest.addEventListener(\"success\", () => {\n clearTimeout(id);\n return resolve(true);\n });\n deleteDbRequest.addEventListener(\"blocked\", () => {\n clearTimeout(id);\n return resolve(true);\n });\n deleteDbRequest.addEventListener(\"error\", () => {\n clearTimeout(id);\n return reject(false);\n });\n });\n }\n}\n\nexport { DatabaseStorage };\n//# sourceMappingURL=DatabaseStorage.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass MemoryStorage {\n constructor() {\n this.cache = new Map();\n }\n getItem(key) {\n return this.cache.get(key) || null;\n }\n setItem(key, value) {\n this.cache.set(key, value);\n }\n removeItem(key) {\n this.cache.delete(key);\n }\n getKeys() {\n const cacheKeys = [];\n this.cache.forEach((value, key) => {\n cacheKeys.push(key);\n });\n return cacheKeys;\n }\n containsKey(key) {\n return this.cache.has(key);\n }\n clear() {\n this.cache.clear();\n }\n}\n\nexport { MemoryStorage };\n//# sourceMappingURL=MemoryStorage.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { BrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { DatabaseStorage } from './DatabaseStorage.mjs';\nimport { MemoryStorage } from './MemoryStorage.mjs';\nimport { databaseUnavailable } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * This class allows MSAL to store artifacts asynchronously using the DatabaseStorage IndexedDB wrapper,\n * backed up with the more volatile MemoryStorage object for cases in which IndexedDB may be unavailable.\n */\nclass AsyncMemoryStorage {\n constructor(logger) {\n this.inMemoryCache = new MemoryStorage();\n this.indexedDBCache = new DatabaseStorage();\n this.logger = logger;\n }\n handleDatabaseAccessError(error) {\n if (error instanceof BrowserAuthError &&\n error.errorCode === databaseUnavailable) {\n this.logger.error(\"Could not access persistent storage. This may be caused by browser privacy features which block persistent storage in third-party contexts.\");\n }\n else {\n throw error;\n }\n }\n /**\n * Get the item matching the given key. Tries in-memory cache first, then in the asynchronous\n * storage object if item isn't found in-memory.\n * @param key\n */\n async getItem(key) {\n const item = this.inMemoryCache.getItem(key);\n if (!item) {\n try {\n this.logger.verbose(\"Queried item not found in in-memory cache, now querying persistent storage.\");\n return await this.indexedDBCache.getItem(key);\n }\n catch (e) {\n this.handleDatabaseAccessError(e);\n }\n }\n return item;\n }\n /**\n * Sets the item in the in-memory cache and then tries to set it in the asynchronous\n * storage object with the given key.\n * @param key\n * @param value\n */\n async setItem(key, value) {\n this.inMemoryCache.setItem(key, value);\n try {\n await this.indexedDBCache.setItem(key, value);\n }\n catch (e) {\n this.handleDatabaseAccessError(e);\n }\n }\n /**\n * Removes the item matching the key from the in-memory cache, then tries to remove it from the asynchronous storage object.\n * @param key\n */\n async removeItem(key) {\n this.inMemoryCache.removeItem(key);\n try {\n await this.indexedDBCache.removeItem(key);\n }\n catch (e) {\n this.handleDatabaseAccessError(e);\n }\n }\n /**\n * Get all the keys from the in-memory cache as an iterable array of strings. If no keys are found, query the keys in the\n * asynchronous storage object.\n */\n async getKeys() {\n const cacheKeys = this.inMemoryCache.getKeys();\n if (cacheKeys.length === 0) {\n try {\n this.logger.verbose(\"In-memory cache is empty, now querying persistent storage.\");\n return await this.indexedDBCache.getKeys();\n }\n catch (e) {\n this.handleDatabaseAccessError(e);\n }\n }\n return cacheKeys;\n }\n /**\n * Returns true or false if the given key is present in the cache.\n * @param key\n */\n async containsKey(key) {\n const containsKey = this.inMemoryCache.containsKey(key);\n if (!containsKey) {\n try {\n this.logger.verbose(\"Key not found in in-memory cache, now querying persistent storage.\");\n return await this.indexedDBCache.containsKey(key);\n }\n catch (e) {\n this.handleDatabaseAccessError(e);\n }\n }\n return containsKey;\n }\n /**\n * Clears in-memory Map\n */\n clearInMemory() {\n // InMemory cache is a Map instance, clear is straightforward\n this.logger.verbose(`Deleting in-memory keystore`);\n this.inMemoryCache.clear();\n this.logger.verbose(`In-memory keystore deleted`);\n }\n /**\n * Tries to delete the IndexedDB database\n * @returns\n */\n async clearPersistent() {\n try {\n this.logger.verbose(\"Deleting persistent keystore\");\n const dbDeleted = await this.indexedDBCache.deleteDatabase();\n if (dbDeleted) {\n this.logger.verbose(\"Persistent keystore deleted\");\n }\n return dbDeleted;\n }\n catch (e) {\n this.handleDatabaseAccessError(e);\n return false;\n }\n }\n}\n\nexport { AsyncMemoryStorage };\n//# sourceMappingURL=AsyncMemoryStorage.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, JoseHeader } from '@azure/msal-common';\nimport { base64Encode, urlEncode, urlEncodeArr } from '../encode/Base64Encode.mjs';\nimport { base64Decode } from '../encode/Base64Decode.mjs';\nimport { validateCryptoAvailable, createNewGuid, generateKeyPair, exportJwk, importJwk, sign, hashString } from './BrowserCrypto.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { AsyncMemoryStorage } from '../cache/AsyncMemoryStorage.mjs';\nimport { cryptoKeyNotFound } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * This class implements MSAL's crypto interface, which allows it to perform base64 encoding and decoding, generating cryptographically random GUIDs and\n * implementing Proof Key for Code Exchange specs for the OAuth Authorization Code Flow using PKCE (rfc here: https://tools.ietf.org/html/rfc7636).\n */\nclass CryptoOps {\n constructor(logger, performanceClient) {\n this.logger = logger;\n // Browser crypto needs to be validated first before any other classes can be set.\n validateCryptoAvailable(logger);\n this.cache = new AsyncMemoryStorage(this.logger);\n this.performanceClient = performanceClient;\n }\n /**\n * Creates a new random GUID - used to populate state and nonce.\n * @returns string (GUID)\n */\n createNewGuid() {\n return createNewGuid();\n }\n /**\n * Encodes input string to base64.\n * @param input\n */\n base64Encode(input) {\n return base64Encode(input);\n }\n /**\n * Decodes input string from base64.\n * @param input\n */\n base64Decode(input) {\n return base64Decode(input);\n }\n /**\n * Encodes input string to base64 URL safe string.\n * @param input\n */\n base64UrlEncode(input) {\n return urlEncode(input);\n }\n /**\n * Stringifies and base64Url encodes input public key\n * @param inputKid\n * @returns Base64Url encoded public key\n */\n encodeKid(inputKid) {\n return this.base64UrlEncode(JSON.stringify({ kid: inputKid }));\n }\n /**\n * Generates a keypair, stores it and returns a thumbprint\n * @param request\n */\n async getPublicKeyThumbprint(request) {\n const publicKeyThumbMeasurement = this.performanceClient?.startMeasurement(PerformanceEvents.CryptoOptsGetPublicKeyThumbprint, request.correlationId);\n // Generate Keypair\n const keyPair = await generateKeyPair(CryptoOps.EXTRACTABLE, CryptoOps.POP_KEY_USAGES);\n // Generate Thumbprint for Public Key\n const publicKeyJwk = await exportJwk(keyPair.publicKey);\n const pubKeyThumprintObj = {\n e: publicKeyJwk.e,\n kty: publicKeyJwk.kty,\n n: publicKeyJwk.n,\n };\n const publicJwkString = getSortedObjectString(pubKeyThumprintObj);\n const publicJwkHash = await this.hashString(publicJwkString);\n // Generate Thumbprint for Private Key\n const privateKeyJwk = await exportJwk(keyPair.privateKey);\n // Re-import private key to make it unextractable\n const unextractablePrivateKey = await importJwk(privateKeyJwk, false, [\"sign\"]);\n // Store Keypair data in keystore\n await this.cache.setItem(publicJwkHash, {\n privateKey: unextractablePrivateKey,\n publicKey: keyPair.publicKey,\n requestMethod: request.resourceRequestMethod,\n requestUri: request.resourceRequestUri,\n });\n if (publicKeyThumbMeasurement) {\n publicKeyThumbMeasurement.end({\n success: true,\n });\n }\n return publicJwkHash;\n }\n /**\n * Removes cryptographic keypair from key store matching the keyId passed in\n * @param kid\n */\n async removeTokenBindingKey(kid) {\n await this.cache.removeItem(kid);\n const keyFound = await this.cache.containsKey(kid);\n return !keyFound;\n }\n /**\n * Removes all cryptographic keys from IndexedDB storage\n */\n async clearKeystore() {\n // Delete in-memory keystores\n this.cache.clearInMemory();\n /**\n * There is only one database, so calling clearPersistent on asymmetric keystore takes care of\n * every persistent keystore\n */\n try {\n await this.cache.clearPersistent();\n return true;\n }\n catch (e) {\n if (e instanceof Error) {\n this.logger.error(`Clearing keystore failed with error: ${e.message}`);\n }\n else {\n this.logger.error(\"Clearing keystore failed with unknown error\");\n }\n return false;\n }\n }\n /**\n * Signs the given object as a jwt payload with private key retrieved by given kid.\n * @param payload\n * @param kid\n */\n async signJwt(payload, kid, shrOptions, correlationId) {\n const signJwtMeasurement = this.performanceClient?.startMeasurement(PerformanceEvents.CryptoOptsSignJwt, correlationId);\n const cachedKeyPair = await this.cache.getItem(kid);\n if (!cachedKeyPair) {\n throw createBrowserAuthError(cryptoKeyNotFound);\n }\n // Get public key as JWK\n const publicKeyJwk = await exportJwk(cachedKeyPair.publicKey);\n const publicKeyJwkString = getSortedObjectString(publicKeyJwk);\n // Base64URL encode public key thumbprint with keyId only: BASE64URL({ kid: \"FULL_PUBLIC_KEY_HASH\" })\n const encodedKeyIdThumbprint = urlEncode(JSON.stringify({ kid: kid }));\n // Generate header\n const shrHeader = JoseHeader.getShrHeaderString({\n ...shrOptions?.header,\n alg: publicKeyJwk.alg,\n kid: encodedKeyIdThumbprint,\n });\n const encodedShrHeader = urlEncode(shrHeader);\n // Generate payload\n payload.cnf = {\n jwk: JSON.parse(publicKeyJwkString),\n };\n const encodedPayload = urlEncode(JSON.stringify(payload));\n // Form token string\n const tokenString = `${encodedShrHeader}.${encodedPayload}`;\n // Sign token\n const encoder = new TextEncoder();\n const tokenBuffer = encoder.encode(tokenString);\n const signatureBuffer = await sign(cachedKeyPair.privateKey, tokenBuffer);\n const encodedSignature = urlEncodeArr(new Uint8Array(signatureBuffer));\n const signedJwt = `${tokenString}.${encodedSignature}`;\n if (signJwtMeasurement) {\n signJwtMeasurement.end({\n success: true,\n });\n }\n return signedJwt;\n }\n /**\n * Returns the SHA-256 hash of an input string\n * @param plainText\n */\n async hashString(plainText) {\n return hashString(plainText);\n }\n}\nCryptoOps.POP_KEY_USAGES = [\"sign\", \"verify\"];\nCryptoOps.EXTRACTABLE = true;\nfunction getSortedObjectString(obj) {\n return JSON.stringify(obj, Object.keys(obj).sort());\n}\n\nexport { CryptoOps };\n//# sourceMappingURL=CryptoOps.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { createBrowserConfigurationAuthError } from '../error/BrowserConfigurationAuthError.mjs';\nimport { BrowserCacheLocation } from '../utils/BrowserConstants.mjs';\nimport { storageNotSupported } from '../error/BrowserConfigurationAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass BrowserStorage {\n constructor(cacheLocation) {\n this.validateWindowStorage(cacheLocation);\n this.windowStorage = window[cacheLocation];\n }\n validateWindowStorage(cacheLocation) {\n if ((cacheLocation !== BrowserCacheLocation.LocalStorage &&\n cacheLocation !== BrowserCacheLocation.SessionStorage) ||\n !window[cacheLocation]) {\n throw createBrowserConfigurationAuthError(storageNotSupported);\n }\n }\n getItem(key) {\n return this.windowStorage.getItem(key);\n }\n setItem(key, value) {\n this.windowStorage.setItem(key, value);\n }\n removeItem(key) {\n this.windowStorage.removeItem(key);\n }\n getKeys() {\n return Object.keys(this.windowStorage);\n }\n containsKey(key) {\n return this.windowStorage.hasOwnProperty(key);\n }\n}\n\nexport { BrowserStorage };\n//# sourceMappingURL=BrowserStorage.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { ProtocolUtils, createClientAuthError, ClientAuthErrorCodes } from '@azure/msal-common';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Extracts the BrowserStateObject from the state string.\n * @param browserCrypto\n * @param state\n */\nfunction extractBrowserRequestState(browserCrypto, state) {\n if (!state) {\n return null;\n }\n try {\n const requestStateObj = ProtocolUtils.parseRequestState(browserCrypto, state);\n return requestStateObj.libraryState.meta;\n }\n catch (e) {\n throw createClientAuthError(ClientAuthErrorCodes.invalidState);\n }\n}\n\nexport { extractBrowserRequestState };\n//# sourceMappingURL=BrowserProtocolUtils.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { CacheManager, CredentialType, CacheHelpers, AccountEntity, createClientAuthError, ClientAuthErrorCodes, Constants, PersistentCacheKeys, PerformanceEvents, StringUtils, ProtocolUtils, AuthToken, CacheError, DEFAULT_CRYPTO_IMPLEMENTATION, CcsCredentialType } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { BrowserCacheLocation, StaticCacheKeys, InMemoryCacheKeys, TemporaryCacheKeys } from '../utils/BrowserConstants.mjs';\nimport { BrowserStorage } from './BrowserStorage.mjs';\nimport { MemoryStorage } from './MemoryStorage.mjs';\nimport { extractBrowserRequestState } from '../utils/BrowserProtocolUtils.mjs';\nimport { base64Decode } from '../encode/Base64Decode.mjs';\nimport { base64Encode } from '../encode/Base64Encode.mjs';\nimport { noTokenRequestCacheError, unableToParseTokenRequestCacheError, noCachedAuthorityError, interactionInProgress } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * This class implements the cache storage interface for MSAL through browser local or session storage.\n * Cookies are only used if storeAuthStateInCookie is true, and are only used for\n * parameters such as state and nonce, generally.\n */\nclass BrowserCacheManager extends CacheManager {\n constructor(clientId, cacheConfig, cryptoImpl, logger, staticAuthorityOptions, performanceClient) {\n super(clientId, cryptoImpl, logger, staticAuthorityOptions);\n // Cookie life calculation (hours * minutes * seconds * ms)\n this.COOKIE_LIFE_MULTIPLIER = 24 * 60 * 60 * 1000;\n this.cacheConfig = cacheConfig;\n this.logger = logger;\n this.internalStorage = new MemoryStorage();\n this.browserStorage = this.setupBrowserStorage(this.cacheConfig.cacheLocation);\n this.temporaryCacheStorage = this.setupTemporaryCacheStorage(this.cacheConfig.temporaryCacheLocation, this.cacheConfig.cacheLocation);\n // Migrate cache entries from older versions of MSAL.\n if (cacheConfig.cacheMigrationEnabled) {\n this.migrateCacheEntries();\n this.createKeyMaps();\n }\n this.performanceClient = performanceClient;\n }\n /**\n * Returns a window storage class implementing the IWindowStorage interface that corresponds to the configured cacheLocation.\n * @param cacheLocation\n */\n setupBrowserStorage(cacheLocation) {\n switch (cacheLocation) {\n case BrowserCacheLocation.LocalStorage:\n case BrowserCacheLocation.SessionStorage:\n try {\n return new BrowserStorage(cacheLocation);\n }\n catch (e) {\n this.logger.verbose(e);\n break;\n }\n }\n this.cacheConfig.cacheLocation = BrowserCacheLocation.MemoryStorage;\n return new MemoryStorage();\n }\n /**\n * Returns a window storage class implementing the IWindowStorage interface that corresponds to the configured temporaryCacheLocation.\n * @param temporaryCacheLocation\n * @param cacheLocation\n */\n setupTemporaryCacheStorage(temporaryCacheLocation, cacheLocation) {\n switch (cacheLocation) {\n case BrowserCacheLocation.LocalStorage:\n case BrowserCacheLocation.SessionStorage:\n try {\n // Temporary cache items will always be stored in session storage to mitigate problems caused by multiple tabs\n return new BrowserStorage(temporaryCacheLocation ||\n BrowserCacheLocation.SessionStorage);\n }\n catch (e) {\n this.logger.verbose(e);\n return this.internalStorage;\n }\n case BrowserCacheLocation.MemoryStorage:\n default:\n return this.internalStorage;\n }\n }\n /**\n * Migrate all old cache entries to new schema. No rollback supported.\n * @param storeAuthStateInCookie\n */\n migrateCacheEntries() {\n const idTokenKey = `${Constants.CACHE_PREFIX}.${PersistentCacheKeys.ID_TOKEN}`;\n const clientInfoKey = `${Constants.CACHE_PREFIX}.${PersistentCacheKeys.CLIENT_INFO}`;\n const errorKey = `${Constants.CACHE_PREFIX}.${PersistentCacheKeys.ERROR}`;\n const errorDescKey = `${Constants.CACHE_PREFIX}.${PersistentCacheKeys.ERROR_DESC}`;\n const idTokenValue = this.browserStorage.getItem(idTokenKey);\n const clientInfoValue = this.browserStorage.getItem(clientInfoKey);\n const errorValue = this.browserStorage.getItem(errorKey);\n const errorDescValue = this.browserStorage.getItem(errorDescKey);\n const values = [\n idTokenValue,\n clientInfoValue,\n errorValue,\n errorDescValue,\n ];\n const keysToMigrate = [\n PersistentCacheKeys.ID_TOKEN,\n PersistentCacheKeys.CLIENT_INFO,\n PersistentCacheKeys.ERROR,\n PersistentCacheKeys.ERROR_DESC,\n ];\n keysToMigrate.forEach((cacheKey, index) => {\n const value = values[index];\n if (value) {\n this.setTemporaryCache(cacheKey, value, true);\n }\n });\n }\n /**\n * Searches all cache entries for MSAL accounts and creates the account key map\n * This is used to migrate users from older versions of MSAL which did not create the map.\n * @returns\n */\n createKeyMaps() {\n this.logger.trace(\"BrowserCacheManager - createKeyMaps called.\");\n const accountKeys = this.getItem(StaticCacheKeys.ACCOUNT_KEYS);\n const tokenKeys = this.getItem(`${StaticCacheKeys.TOKEN_KEYS}.${this.clientId}`);\n if (accountKeys && tokenKeys) {\n this.logger.verbose(\"BrowserCacheManager:createKeyMaps - account and token key maps already exist, skipping migration.\");\n // Key maps already exist, no need to iterate through cache\n return;\n }\n const allKeys = this.browserStorage.getKeys();\n allKeys.forEach((key) => {\n if (this.isCredentialKey(key)) {\n // Get item, parse, validate and write key to map\n const value = this.getItem(key);\n if (value) {\n const credObj = this.validateAndParseJson(value);\n if (credObj && credObj.hasOwnProperty(\"credentialType\")) {\n switch (credObj[\"credentialType\"]) {\n case CredentialType.ID_TOKEN:\n if (CacheHelpers.isIdTokenEntity(credObj)) {\n this.logger.trace(\"BrowserCacheManager:createKeyMaps - idToken found, saving key to token key map\");\n this.logger.tracePii(`BrowserCacheManager:createKeyMaps - idToken with key: ${key} found, saving key to token key map`);\n const idTokenEntity = credObj;\n const newKey = this.updateCredentialCacheKey(key, idTokenEntity);\n this.addTokenKey(newKey, CredentialType.ID_TOKEN);\n return;\n }\n else {\n this.logger.trace(\"BrowserCacheManager:createKeyMaps - key found matching idToken schema with value containing idToken credentialType field but value failed IdTokenEntity validation, skipping.\");\n this.logger.tracePii(`BrowserCacheManager:createKeyMaps - failed idToken validation on key: ${key}`);\n }\n break;\n case CredentialType.ACCESS_TOKEN:\n case CredentialType.ACCESS_TOKEN_WITH_AUTH_SCHEME:\n if (CacheHelpers.isAccessTokenEntity(credObj)) {\n this.logger.trace(\"BrowserCacheManager:createKeyMaps - accessToken found, saving key to token key map\");\n this.logger.tracePii(`BrowserCacheManager:createKeyMaps - accessToken with key: ${key} found, saving key to token key map`);\n const accessTokenEntity = credObj;\n const newKey = this.updateCredentialCacheKey(key, accessTokenEntity);\n this.addTokenKey(newKey, CredentialType.ACCESS_TOKEN);\n return;\n }\n else {\n this.logger.trace(\"BrowserCacheManager:createKeyMaps - key found matching accessToken schema with value containing accessToken credentialType field but value failed AccessTokenEntity validation, skipping.\");\n this.logger.tracePii(`BrowserCacheManager:createKeyMaps - failed accessToken validation on key: ${key}`);\n }\n break;\n case CredentialType.REFRESH_TOKEN:\n if (CacheHelpers.isRefreshTokenEntity(credObj)) {\n this.logger.trace(\"BrowserCacheManager:createKeyMaps - refreshToken found, saving key to token key map\");\n this.logger.tracePii(`BrowserCacheManager:createKeyMaps - refreshToken with key: ${key} found, saving key to token key map`);\n const refreshTokenEntity = credObj;\n const newKey = this.updateCredentialCacheKey(key, refreshTokenEntity);\n this.addTokenKey(newKey, CredentialType.REFRESH_TOKEN);\n return;\n }\n else {\n this.logger.trace(\"BrowserCacheManager:createKeyMaps - key found matching refreshToken schema with value containing refreshToken credentialType field but value failed RefreshTokenEntity validation, skipping.\");\n this.logger.tracePii(`BrowserCacheManager:createKeyMaps - failed refreshToken validation on key: ${key}`);\n }\n break;\n // If credentialType isn't one of our predefined ones, it may not be an MSAL cache value. Ignore.\n }\n }\n }\n }\n if (this.isAccountKey(key)) {\n const value = this.getItem(key);\n if (value) {\n const accountObj = this.validateAndParseJson(value);\n if (accountObj &&\n AccountEntity.isAccountEntity(accountObj)) {\n this.logger.trace(\"BrowserCacheManager:createKeyMaps - account found, saving key to account key map\");\n this.logger.tracePii(`BrowserCacheManager:createKeyMaps - account with key: ${key} found, saving key to account key map`);\n this.addAccountKeyToMap(key);\n }\n }\n }\n });\n }\n /**\n * Parses passed value as JSON object, JSON.parse() will throw an error.\n * @param input\n */\n validateAndParseJson(jsonValue) {\n try {\n const parsedJson = JSON.parse(jsonValue);\n /**\n * There are edge cases in which JSON.parse will successfully parse a non-valid JSON object\n * (e.g. JSON.parse will parse an escaped string into an unescaped string), so adding a type check\n * of the parsed value is necessary in order to be certain that the string represents a valid JSON object.\n *\n */\n return parsedJson && typeof parsedJson === \"object\"\n ? parsedJson\n : null;\n }\n catch (error) {\n return null;\n }\n }\n /**\n * fetches the entry from the browser storage based off the key\n * @param key\n */\n getItem(key) {\n return this.browserStorage.getItem(key);\n }\n /**\n * sets the entry in the browser storage\n * @param key\n * @param value\n */\n setItem(key, value) {\n this.browserStorage.setItem(key, value);\n }\n /**\n * fetch the account entity from the platform cache\n * @param accountKey\n */\n getAccount(accountKey, logger) {\n this.logger.trace(\"BrowserCacheManager.getAccount called\");\n const accountEntity = this.getCachedAccountEntity(accountKey);\n return this.updateOutdatedCachedAccount(accountKey, accountEntity, logger);\n }\n /**\n * Reads account from cache, deserializes it into an account entity and returns it.\n * If account is not found from the key, returns null and removes key from map.\n * @param accountKey\n * @returns\n */\n getCachedAccountEntity(accountKey) {\n const serializedAccount = this.getItem(accountKey);\n if (!serializedAccount) {\n this.removeAccountKeyFromMap(accountKey);\n return null;\n }\n const parsedAccount = this.validateAndParseJson(serializedAccount);\n if (!parsedAccount || !AccountEntity.isAccountEntity(parsedAccount)) {\n this.removeAccountKeyFromMap(accountKey);\n return null;\n }\n return CacheManager.toObject(new AccountEntity(), parsedAccount);\n }\n /**\n * set account entity in the platform cache\n * @param account\n */\n setAccount(account) {\n this.logger.trace(\"BrowserCacheManager.setAccount called\");\n const key = account.generateAccountKey();\n this.setItem(key, JSON.stringify(account));\n this.addAccountKeyToMap(key);\n }\n /**\n * Returns the array of account keys currently cached\n * @returns\n */\n getAccountKeys() {\n this.logger.trace(\"BrowserCacheManager.getAccountKeys called\");\n const accountKeys = this.getItem(StaticCacheKeys.ACCOUNT_KEYS);\n if (accountKeys) {\n return JSON.parse(accountKeys);\n }\n this.logger.verbose(\"BrowserCacheManager.getAccountKeys - No account keys found\");\n return [];\n }\n /**\n * Add a new account to the key map\n * @param key\n */\n addAccountKeyToMap(key) {\n this.logger.trace(\"BrowserCacheManager.addAccountKeyToMap called\");\n this.logger.tracePii(`BrowserCacheManager.addAccountKeyToMap called with key: ${key}`);\n const accountKeys = this.getAccountKeys();\n if (accountKeys.indexOf(key) === -1) {\n // Only add key if it does not already exist in the map\n accountKeys.push(key);\n this.setItem(StaticCacheKeys.ACCOUNT_KEYS, JSON.stringify(accountKeys));\n this.logger.verbose(\"BrowserCacheManager.addAccountKeyToMap account key added\");\n }\n else {\n this.logger.verbose(\"BrowserCacheManager.addAccountKeyToMap account key already exists in map\");\n }\n }\n /**\n * Remove an account from the key map\n * @param key\n */\n removeAccountKeyFromMap(key) {\n this.logger.trace(\"BrowserCacheManager.removeAccountKeyFromMap called\");\n this.logger.tracePii(`BrowserCacheManager.removeAccountKeyFromMap called with key: ${key}`);\n const accountKeys = this.getAccountKeys();\n const removalIndex = accountKeys.indexOf(key);\n if (removalIndex > -1) {\n accountKeys.splice(removalIndex, 1);\n this.setItem(StaticCacheKeys.ACCOUNT_KEYS, JSON.stringify(accountKeys));\n this.logger.trace(\"BrowserCacheManager.removeAccountKeyFromMap account key removed\");\n }\n else {\n this.logger.trace(\"BrowserCacheManager.removeAccountKeyFromMap key not found in existing map\");\n }\n }\n /**\n * Extends inherited removeAccount function to include removal of the account key from the map\n * @param key\n */\n async removeAccount(key) {\n void super.removeAccount(key);\n this.removeAccountKeyFromMap(key);\n }\n /**\n * Remove account entity from the platform cache if it's outdated\n * @param accountKey\n */\n removeOutdatedAccount(accountKey) {\n this.removeItem(accountKey);\n this.removeAccountKeyFromMap(accountKey);\n }\n /**\n * Removes given idToken from the cache and from the key map\n * @param key\n */\n removeIdToken(key) {\n super.removeIdToken(key);\n this.removeTokenKey(key, CredentialType.ID_TOKEN);\n }\n /**\n * Removes given accessToken from the cache and from the key map\n * @param key\n */\n async removeAccessToken(key) {\n void super.removeAccessToken(key);\n this.removeTokenKey(key, CredentialType.ACCESS_TOKEN);\n }\n /**\n * Removes given refreshToken from the cache and from the key map\n * @param key\n */\n removeRefreshToken(key) {\n super.removeRefreshToken(key);\n this.removeTokenKey(key, CredentialType.REFRESH_TOKEN);\n }\n /**\n * Gets the keys for the cached tokens associated with this clientId\n * @returns\n */\n getTokenKeys() {\n this.logger.trace(\"BrowserCacheManager.getTokenKeys called\");\n const item = this.getItem(`${StaticCacheKeys.TOKEN_KEYS}.${this.clientId}`);\n if (item) {\n const tokenKeys = this.validateAndParseJson(item);\n if (tokenKeys &&\n tokenKeys.hasOwnProperty(\"idToken\") &&\n tokenKeys.hasOwnProperty(\"accessToken\") &&\n tokenKeys.hasOwnProperty(\"refreshToken\")) {\n return tokenKeys;\n }\n else {\n this.logger.error(\"BrowserCacheManager.getTokenKeys - Token keys found but in an unknown format. Returning empty key map.\");\n }\n }\n else {\n this.logger.verbose(\"BrowserCacheManager.getTokenKeys - No token keys found\");\n }\n return {\n idToken: [],\n accessToken: [],\n refreshToken: [],\n };\n }\n /**\n * Adds the given key to the token key map\n * @param key\n * @param type\n */\n addTokenKey(key, type) {\n this.logger.trace(\"BrowserCacheManager addTokenKey called\");\n const tokenKeys = this.getTokenKeys();\n switch (type) {\n case CredentialType.ID_TOKEN:\n if (tokenKeys.idToken.indexOf(key) === -1) {\n this.logger.info(\"BrowserCacheManager: addTokenKey - idToken added to map\");\n tokenKeys.idToken.push(key);\n }\n break;\n case CredentialType.ACCESS_TOKEN:\n if (tokenKeys.accessToken.indexOf(key) === -1) {\n this.logger.info(\"BrowserCacheManager: addTokenKey - accessToken added to map\");\n tokenKeys.accessToken.push(key);\n }\n break;\n case CredentialType.REFRESH_TOKEN:\n if (tokenKeys.refreshToken.indexOf(key) === -1) {\n this.logger.info(\"BrowserCacheManager: addTokenKey - refreshToken added to map\");\n tokenKeys.refreshToken.push(key);\n }\n break;\n default:\n this.logger.error(`BrowserCacheManager:addTokenKey - CredentialType provided invalid. CredentialType: ${type}`);\n throw createClientAuthError(ClientAuthErrorCodes.unexpectedCredentialType);\n }\n this.setItem(`${StaticCacheKeys.TOKEN_KEYS}.${this.clientId}`, JSON.stringify(tokenKeys));\n }\n /**\n * Removes the given key from the token key map\n * @param key\n * @param type\n */\n removeTokenKey(key, type) {\n this.logger.trace(\"BrowserCacheManager removeTokenKey called\");\n const tokenKeys = this.getTokenKeys();\n switch (type) {\n case CredentialType.ID_TOKEN:\n this.logger.infoPii(`BrowserCacheManager: removeTokenKey - attempting to remove idToken with key: ${key} from map`);\n const idRemoval = tokenKeys.idToken.indexOf(key);\n if (idRemoval > -1) {\n this.logger.info(\"BrowserCacheManager: removeTokenKey - idToken removed from map\");\n tokenKeys.idToken.splice(idRemoval, 1);\n }\n else {\n this.logger.info(\"BrowserCacheManager: removeTokenKey - idToken does not exist in map. Either it was previously removed or it was never added.\");\n }\n break;\n case CredentialType.ACCESS_TOKEN:\n this.logger.infoPii(`BrowserCacheManager: removeTokenKey - attempting to remove accessToken with key: ${key} from map`);\n const accessRemoval = tokenKeys.accessToken.indexOf(key);\n if (accessRemoval > -1) {\n this.logger.info(\"BrowserCacheManager: removeTokenKey - accessToken removed from map\");\n tokenKeys.accessToken.splice(accessRemoval, 1);\n }\n else {\n this.logger.info(\"BrowserCacheManager: removeTokenKey - accessToken does not exist in map. Either it was previously removed or it was never added.\");\n }\n break;\n case CredentialType.REFRESH_TOKEN:\n this.logger.infoPii(`BrowserCacheManager: removeTokenKey - attempting to remove refreshToken with key: ${key} from map`);\n const refreshRemoval = tokenKeys.refreshToken.indexOf(key);\n if (refreshRemoval > -1) {\n this.logger.info(\"BrowserCacheManager: removeTokenKey - refreshToken removed from map\");\n tokenKeys.refreshToken.splice(refreshRemoval, 1);\n }\n else {\n this.logger.info(\"BrowserCacheManager: removeTokenKey - refreshToken does not exist in map. Either it was previously removed or it was never added.\");\n }\n break;\n default:\n this.logger.error(`BrowserCacheManager:removeTokenKey - CredentialType provided invalid. CredentialType: ${type}`);\n throw createClientAuthError(ClientAuthErrorCodes.unexpectedCredentialType);\n }\n this.setItem(`${StaticCacheKeys.TOKEN_KEYS}.${this.clientId}`, JSON.stringify(tokenKeys));\n }\n /**\n * generates idToken entity from a string\n * @param idTokenKey\n */\n getIdTokenCredential(idTokenKey) {\n const value = this.getItem(idTokenKey);\n if (!value) {\n this.logger.trace(\"BrowserCacheManager.getIdTokenCredential: called, no cache hit\");\n this.removeTokenKey(idTokenKey, CredentialType.ID_TOKEN);\n return null;\n }\n const parsedIdToken = this.validateAndParseJson(value);\n if (!parsedIdToken || !CacheHelpers.isIdTokenEntity(parsedIdToken)) {\n this.logger.trace(\"BrowserCacheManager.getIdTokenCredential: called, no cache hit\");\n this.removeTokenKey(idTokenKey, CredentialType.ID_TOKEN);\n return null;\n }\n this.logger.trace(\"BrowserCacheManager.getIdTokenCredential: cache hit\");\n return parsedIdToken;\n }\n /**\n * set IdToken credential to the platform cache\n * @param idToken\n */\n setIdTokenCredential(idToken) {\n this.logger.trace(\"BrowserCacheManager.setIdTokenCredential called\");\n const idTokenKey = CacheHelpers.generateCredentialKey(idToken);\n this.setItem(idTokenKey, JSON.stringify(idToken));\n this.addTokenKey(idTokenKey, CredentialType.ID_TOKEN);\n }\n /**\n * generates accessToken entity from a string\n * @param key\n */\n getAccessTokenCredential(accessTokenKey) {\n const value = this.getItem(accessTokenKey);\n if (!value) {\n this.logger.trace(\"BrowserCacheManager.getAccessTokenCredential: called, no cache hit\");\n this.removeTokenKey(accessTokenKey, CredentialType.ACCESS_TOKEN);\n return null;\n }\n const parsedAccessToken = this.validateAndParseJson(value);\n if (!parsedAccessToken ||\n !CacheHelpers.isAccessTokenEntity(parsedAccessToken)) {\n this.logger.trace(\"BrowserCacheManager.getAccessTokenCredential: called, no cache hit\");\n this.removeTokenKey(accessTokenKey, CredentialType.ACCESS_TOKEN);\n return null;\n }\n this.logger.trace(\"BrowserCacheManager.getAccessTokenCredential: cache hit\");\n return parsedAccessToken;\n }\n /**\n * set accessToken credential to the platform cache\n * @param accessToken\n */\n setAccessTokenCredential(accessToken) {\n this.logger.trace(\"BrowserCacheManager.setAccessTokenCredential called\");\n const accessTokenKey = CacheHelpers.generateCredentialKey(accessToken);\n this.setItem(accessTokenKey, JSON.stringify(accessToken));\n this.addTokenKey(accessTokenKey, CredentialType.ACCESS_TOKEN);\n }\n /**\n * generates refreshToken entity from a string\n * @param refreshTokenKey\n */\n getRefreshTokenCredential(refreshTokenKey) {\n const value = this.getItem(refreshTokenKey);\n if (!value) {\n this.logger.trace(\"BrowserCacheManager.getRefreshTokenCredential: called, no cache hit\");\n this.removeTokenKey(refreshTokenKey, CredentialType.REFRESH_TOKEN);\n return null;\n }\n const parsedRefreshToken = this.validateAndParseJson(value);\n if (!parsedRefreshToken ||\n !CacheHelpers.isRefreshTokenEntity(parsedRefreshToken)) {\n this.logger.trace(\"BrowserCacheManager.getRefreshTokenCredential: called, no cache hit\");\n this.removeTokenKey(refreshTokenKey, CredentialType.REFRESH_TOKEN);\n return null;\n }\n this.logger.trace(\"BrowserCacheManager.getRefreshTokenCredential: cache hit\");\n return parsedRefreshToken;\n }\n /**\n * set refreshToken credential to the platform cache\n * @param refreshToken\n */\n setRefreshTokenCredential(refreshToken) {\n this.logger.trace(\"BrowserCacheManager.setRefreshTokenCredential called\");\n const refreshTokenKey = CacheHelpers.generateCredentialKey(refreshToken);\n this.setItem(refreshTokenKey, JSON.stringify(refreshToken));\n this.addTokenKey(refreshTokenKey, CredentialType.REFRESH_TOKEN);\n }\n /**\n * fetch appMetadata entity from the platform cache\n * @param appMetadataKey\n */\n getAppMetadata(appMetadataKey) {\n const value = this.getItem(appMetadataKey);\n if (!value) {\n this.logger.trace(\"BrowserCacheManager.getAppMetadata: called, no cache hit\");\n return null;\n }\n const parsedMetadata = this.validateAndParseJson(value);\n if (!parsedMetadata ||\n !CacheHelpers.isAppMetadataEntity(appMetadataKey, parsedMetadata)) {\n this.logger.trace(\"BrowserCacheManager.getAppMetadata: called, no cache hit\");\n return null;\n }\n this.logger.trace(\"BrowserCacheManager.getAppMetadata: cache hit\");\n return parsedMetadata;\n }\n /**\n * set appMetadata entity to the platform cache\n * @param appMetadata\n */\n setAppMetadata(appMetadata) {\n this.logger.trace(\"BrowserCacheManager.setAppMetadata called\");\n const appMetadataKey = CacheHelpers.generateAppMetadataKey(appMetadata);\n this.setItem(appMetadataKey, JSON.stringify(appMetadata));\n }\n /**\n * fetch server telemetry entity from the platform cache\n * @param serverTelemetryKey\n */\n getServerTelemetry(serverTelemetryKey) {\n const value = this.getItem(serverTelemetryKey);\n if (!value) {\n this.logger.trace(\"BrowserCacheManager.getServerTelemetry: called, no cache hit\");\n return null;\n }\n const parsedEntity = this.validateAndParseJson(value);\n if (!parsedEntity ||\n !CacheHelpers.isServerTelemetryEntity(serverTelemetryKey, parsedEntity)) {\n this.logger.trace(\"BrowserCacheManager.getServerTelemetry: called, no cache hit\");\n return null;\n }\n this.logger.trace(\"BrowserCacheManager.getServerTelemetry: cache hit\");\n return parsedEntity;\n }\n /**\n * set server telemetry entity to the platform cache\n * @param serverTelemetryKey\n * @param serverTelemetry\n */\n setServerTelemetry(serverTelemetryKey, serverTelemetry) {\n this.logger.trace(\"BrowserCacheManager.setServerTelemetry called\");\n this.setItem(serverTelemetryKey, JSON.stringify(serverTelemetry));\n }\n /**\n *\n */\n getAuthorityMetadata(key) {\n const value = this.internalStorage.getItem(key);\n if (!value) {\n this.logger.trace(\"BrowserCacheManager.getAuthorityMetadata: called, no cache hit\");\n return null;\n }\n const parsedMetadata = this.validateAndParseJson(value);\n if (parsedMetadata &&\n CacheHelpers.isAuthorityMetadataEntity(key, parsedMetadata)) {\n this.logger.trace(\"BrowserCacheManager.getAuthorityMetadata: cache hit\");\n return parsedMetadata;\n }\n return null;\n }\n /**\n *\n */\n getAuthorityMetadataKeys() {\n const allKeys = this.internalStorage.getKeys();\n return allKeys.filter((key) => {\n return this.isAuthorityMetadata(key);\n });\n }\n /**\n * Sets wrapper metadata in memory\n * @param wrapperSKU\n * @param wrapperVersion\n */\n setWrapperMetadata(wrapperSKU, wrapperVersion) {\n this.internalStorage.setItem(InMemoryCacheKeys.WRAPPER_SKU, wrapperSKU);\n this.internalStorage.setItem(InMemoryCacheKeys.WRAPPER_VER, wrapperVersion);\n }\n /**\n * Returns wrapper metadata from in-memory storage\n */\n getWrapperMetadata() {\n const sku = this.internalStorage.getItem(InMemoryCacheKeys.WRAPPER_SKU) ||\n Constants.EMPTY_STRING;\n const version = this.internalStorage.getItem(InMemoryCacheKeys.WRAPPER_VER) ||\n Constants.EMPTY_STRING;\n return [sku, version];\n }\n /**\n *\n * @param entity\n */\n setAuthorityMetadata(key, entity) {\n this.logger.trace(\"BrowserCacheManager.setAuthorityMetadata called\");\n this.internalStorage.setItem(key, JSON.stringify(entity));\n }\n /**\n * Gets the active account\n */\n getActiveAccount() {\n const activeAccountKeyFilters = this.generateCacheKey(PersistentCacheKeys.ACTIVE_ACCOUNT_FILTERS);\n const activeAccountValueFilters = this.getItem(activeAccountKeyFilters);\n if (!activeAccountValueFilters) {\n // if new active account cache type isn't found, it's an old version, so look for that instead\n this.logger.trace(\"BrowserCacheManager.getActiveAccount: No active account filters cache schema found, looking for legacy schema\");\n const activeAccountKeyLocal = this.generateCacheKey(PersistentCacheKeys.ACTIVE_ACCOUNT);\n const activeAccountValueLocal = this.getItem(activeAccountKeyLocal);\n if (!activeAccountValueLocal) {\n this.logger.trace(\"BrowserCacheManager.getActiveAccount: No active account found\");\n return null;\n }\n const activeAccount = this.getAccountInfoFilteredBy({\n localAccountId: activeAccountValueLocal,\n });\n if (activeAccount) {\n this.logger.trace(\"BrowserCacheManager.getActiveAccount: Legacy active account cache schema found\");\n this.logger.trace(\"BrowserCacheManager.getActiveAccount: Adding active account filters cache schema\");\n this.setActiveAccount(activeAccount);\n return activeAccount;\n }\n return null;\n }\n const activeAccountValueObj = this.validateAndParseJson(activeAccountValueFilters);\n if (activeAccountValueObj) {\n this.logger.trace(\"BrowserCacheManager.getActiveAccount: Active account filters schema found\");\n return this.getAccountInfoFilteredBy({\n homeAccountId: activeAccountValueObj.homeAccountId,\n localAccountId: activeAccountValueObj.localAccountId,\n tenantId: activeAccountValueObj.tenantId,\n });\n }\n this.logger.trace(\"BrowserCacheManager.getActiveAccount: No active account found\");\n return null;\n }\n /**\n * Sets the active account's localAccountId in cache\n * @param account\n */\n setActiveAccount(account) {\n const activeAccountKey = this.generateCacheKey(PersistentCacheKeys.ACTIVE_ACCOUNT_FILTERS);\n const activeAccountKeyLocal = this.generateCacheKey(PersistentCacheKeys.ACTIVE_ACCOUNT);\n if (account) {\n this.logger.verbose(\"setActiveAccount: Active account set\");\n const activeAccountValue = {\n homeAccountId: account.homeAccountId,\n localAccountId: account.localAccountId,\n tenantId: account.tenantId,\n };\n this.browserStorage.setItem(activeAccountKey, JSON.stringify(activeAccountValue));\n this.browserStorage.setItem(activeAccountKeyLocal, account.localAccountId);\n }\n else {\n this.logger.verbose(\"setActiveAccount: No account passed, active account not set\");\n this.browserStorage.removeItem(activeAccountKey);\n this.browserStorage.removeItem(activeAccountKeyLocal);\n }\n }\n /**\n * fetch throttling entity from the platform cache\n * @param throttlingCacheKey\n */\n getThrottlingCache(throttlingCacheKey) {\n const value = this.getItem(throttlingCacheKey);\n if (!value) {\n this.logger.trace(\"BrowserCacheManager.getThrottlingCache: called, no cache hit\");\n return null;\n }\n const parsedThrottlingCache = this.validateAndParseJson(value);\n if (!parsedThrottlingCache ||\n !CacheHelpers.isThrottlingEntity(throttlingCacheKey, parsedThrottlingCache)) {\n this.logger.trace(\"BrowserCacheManager.getThrottlingCache: called, no cache hit\");\n return null;\n }\n this.logger.trace(\"BrowserCacheManager.getThrottlingCache: cache hit\");\n return parsedThrottlingCache;\n }\n /**\n * set throttling entity to the platform cache\n * @param throttlingCacheKey\n * @param throttlingCache\n */\n setThrottlingCache(throttlingCacheKey, throttlingCache) {\n this.logger.trace(\"BrowserCacheManager.setThrottlingCache called\");\n this.setItem(throttlingCacheKey, JSON.stringify(throttlingCache));\n }\n /**\n * Gets cache item with given key.\n * Will retrieve from cookies if storeAuthStateInCookie is set to true.\n * @param key\n */\n getTemporaryCache(cacheKey, generateKey) {\n const key = generateKey ? this.generateCacheKey(cacheKey) : cacheKey;\n if (this.cacheConfig.storeAuthStateInCookie) {\n const itemCookie = this.getItemCookie(key);\n if (itemCookie) {\n this.logger.trace(\"BrowserCacheManager.getTemporaryCache: storeAuthStateInCookies set to true, retrieving from cookies\");\n return itemCookie;\n }\n }\n const value = this.temporaryCacheStorage.getItem(key);\n if (!value) {\n // If temp cache item not found in session/memory, check local storage for items set by old versions\n if (this.cacheConfig.cacheLocation ===\n BrowserCacheLocation.LocalStorage) {\n const item = this.browserStorage.getItem(key);\n if (item) {\n this.logger.trace(\"BrowserCacheManager.getTemporaryCache: Temporary cache item found in local storage\");\n return item;\n }\n }\n this.logger.trace(\"BrowserCacheManager.getTemporaryCache: No cache item found in local storage\");\n return null;\n }\n this.logger.trace(\"BrowserCacheManager.getTemporaryCache: Temporary cache item returned\");\n return value;\n }\n /**\n * Sets the cache item with the key and value given.\n * Stores in cookie if storeAuthStateInCookie is set to true.\n * This can cause cookie overflow if used incorrectly.\n * @param key\n * @param value\n */\n setTemporaryCache(cacheKey, value, generateKey) {\n const key = generateKey ? this.generateCacheKey(cacheKey) : cacheKey;\n this.temporaryCacheStorage.setItem(key, value);\n if (this.cacheConfig.storeAuthStateInCookie) {\n this.logger.trace(\"BrowserCacheManager.setTemporaryCache: storeAuthStateInCookie set to true, setting item cookie\");\n this.setItemCookie(key, value);\n }\n }\n /**\n * Removes the cache item with the given key.\n * @param key\n */\n removeItem(key) {\n this.browserStorage.removeItem(key);\n }\n /**\n * Removes the temporary cache item with the given key.\n * Will also clear the cookie item if storeAuthStateInCookie is set to true.\n * @param key\n */\n removeTemporaryItem(key) {\n this.temporaryCacheStorage.removeItem(key);\n if (this.cacheConfig.storeAuthStateInCookie) {\n this.logger.trace(\"BrowserCacheManager.removeItem: storeAuthStateInCookie is true, clearing item cookie\");\n this.clearItemCookie(key);\n }\n }\n /**\n * Gets all keys in window.\n */\n getKeys() {\n return this.browserStorage.getKeys();\n }\n /**\n * Clears all cache entries created by MSAL.\n */\n async clear() {\n // Removes all accounts and their credentials\n await this.removeAllAccounts();\n this.removeAppMetadata();\n // Remove temp storage first to make sure any cookies are cleared\n this.temporaryCacheStorage.getKeys().forEach((cacheKey) => {\n if (cacheKey.indexOf(Constants.CACHE_PREFIX) !== -1 ||\n cacheKey.indexOf(this.clientId) !== -1) {\n this.removeTemporaryItem(cacheKey);\n }\n });\n // Removes all remaining MSAL cache items\n this.browserStorage.getKeys().forEach((cacheKey) => {\n if (cacheKey.indexOf(Constants.CACHE_PREFIX) !== -1 ||\n cacheKey.indexOf(this.clientId) !== -1) {\n this.browserStorage.removeItem(cacheKey);\n }\n });\n this.internalStorage.clear();\n }\n /**\n * Clears all access tokes that have claims prior to saving the current one\n * @param performanceClient {IPerformanceClient}\n * @param correlationId {string} correlation id\n * @returns\n */\n async clearTokensAndKeysWithClaims(performanceClient, correlationId) {\n performanceClient.addQueueMeasurement(PerformanceEvents.ClearTokensAndKeysWithClaims, correlationId);\n const tokenKeys = this.getTokenKeys();\n const removedAccessTokens = [];\n tokenKeys.accessToken.forEach((key) => {\n // if the access token has claims in its key, remove the token key and the token\n const credential = this.getAccessTokenCredential(key);\n if (credential?.requestedClaimsHash &&\n key.includes(credential.requestedClaimsHash.toLowerCase())) {\n removedAccessTokens.push(this.removeAccessToken(key));\n }\n });\n await Promise.all(removedAccessTokens);\n // warn if any access tokens are removed\n if (removedAccessTokens.length > 0) {\n this.logger.warning(`${removedAccessTokens.length} access tokens with claims in the cache keys have been removed from the cache.`);\n }\n }\n /**\n * Add value to cookies\n * @param cookieName\n * @param cookieValue\n * @param expires\n * @deprecated\n */\n setItemCookie(cookieName, cookieValue, expires) {\n let cookieStr = `${encodeURIComponent(cookieName)}=${encodeURIComponent(cookieValue)};path=/;SameSite=Lax;`;\n if (expires) {\n const expireTime = this.getCookieExpirationTime(expires);\n cookieStr += `expires=${expireTime};`;\n }\n if (this.cacheConfig.secureCookies) {\n cookieStr += \"Secure;\";\n }\n document.cookie = cookieStr;\n }\n /**\n * Get one item by key from cookies\n * @param cookieName\n * @deprecated\n */\n getItemCookie(cookieName) {\n const name = `${encodeURIComponent(cookieName)}=`;\n const cookieList = document.cookie.split(\";\");\n for (let i = 0; i < cookieList.length; i++) {\n let cookie = cookieList[i];\n while (cookie.charAt(0) === \" \") {\n cookie = cookie.substring(1);\n }\n if (cookie.indexOf(name) === 0) {\n return decodeURIComponent(cookie.substring(name.length, cookie.length));\n }\n }\n return Constants.EMPTY_STRING;\n }\n /**\n * Clear all msal-related cookies currently set in the browser. Should only be used to clear temporary cache items.\n * @deprecated\n */\n clearMsalCookies() {\n const cookiePrefix = `${Constants.CACHE_PREFIX}.${this.clientId}`;\n const cookieList = document.cookie.split(\";\");\n cookieList.forEach((cookie) => {\n while (cookie.charAt(0) === \" \") {\n // eslint-disable-next-line no-param-reassign\n cookie = cookie.substring(1);\n }\n if (cookie.indexOf(cookiePrefix) === 0) {\n const cookieKey = cookie.split(\"=\")[0];\n this.clearItemCookie(cookieKey);\n }\n });\n }\n /**\n * Clear an item in the cookies by key\n * @param cookieName\n * @deprecated\n */\n clearItemCookie(cookieName) {\n this.setItemCookie(cookieName, Constants.EMPTY_STRING, -1);\n }\n /**\n * Get cookie expiration time\n * @param cookieLifeDays\n * @deprecated\n */\n getCookieExpirationTime(cookieLifeDays) {\n const today = new Date();\n const expr = new Date(today.getTime() + cookieLifeDays * this.COOKIE_LIFE_MULTIPLIER);\n return expr.toUTCString();\n }\n /**\n * Prepend msal. to each key; Skip for any JSON object as Key (defined schemas do not need the key appended: AccessToken Keys or the upcoming schema)\n * @param key\n * @param addInstanceId\n */\n generateCacheKey(key) {\n const generatedKey = this.validateAndParseJson(key);\n if (!generatedKey) {\n if (StringUtils.startsWith(key, Constants.CACHE_PREFIX) ||\n StringUtils.startsWith(key, PersistentCacheKeys.ADAL_ID_TOKEN)) {\n return key;\n }\n return `${Constants.CACHE_PREFIX}.${this.clientId}.${key}`;\n }\n return JSON.stringify(key);\n }\n /**\n * Create authorityKey to cache authority\n * @param state\n */\n generateAuthorityKey(stateString) {\n const { libraryState: { id: stateId }, } = ProtocolUtils.parseRequestState(this.cryptoImpl, stateString);\n return this.generateCacheKey(`${TemporaryCacheKeys.AUTHORITY}.${stateId}`);\n }\n /**\n * Create Nonce key to cache nonce\n * @param state\n */\n generateNonceKey(stateString) {\n const { libraryState: { id: stateId }, } = ProtocolUtils.parseRequestState(this.cryptoImpl, stateString);\n return this.generateCacheKey(`${TemporaryCacheKeys.NONCE_IDTOKEN}.${stateId}`);\n }\n /**\n * Creates full cache key for the request state\n * @param stateString State string for the request\n */\n generateStateKey(stateString) {\n // Use the library state id to key temp storage for uniqueness for multiple concurrent requests\n const { libraryState: { id: stateId }, } = ProtocolUtils.parseRequestState(this.cryptoImpl, stateString);\n return this.generateCacheKey(`${TemporaryCacheKeys.REQUEST_STATE}.${stateId}`);\n }\n /**\n * Gets the cached authority based on the cached state. Returns empty if no cached state found.\n */\n getCachedAuthority(cachedState) {\n const stateCacheKey = this.generateStateKey(cachedState);\n const state = this.getTemporaryCache(stateCacheKey);\n if (!state) {\n return null;\n }\n const authorityCacheKey = this.generateAuthorityKey(state);\n return this.getTemporaryCache(authorityCacheKey);\n }\n /**\n * Updates account, authority, and state in cache\n * @param serverAuthenticationRequest\n * @param account\n */\n updateCacheEntries(state, nonce, authorityInstance, loginHint, account) {\n this.logger.trace(\"BrowserCacheManager.updateCacheEntries called\");\n // Cache the request state\n const stateCacheKey = this.generateStateKey(state);\n this.setTemporaryCache(stateCacheKey, state, false);\n // Cache the nonce\n const nonceCacheKey = this.generateNonceKey(state);\n this.setTemporaryCache(nonceCacheKey, nonce, false);\n // Cache authorityKey\n const authorityCacheKey = this.generateAuthorityKey(state);\n this.setTemporaryCache(authorityCacheKey, authorityInstance, false);\n if (account) {\n const ccsCredential = {\n credential: account.homeAccountId,\n type: CcsCredentialType.HOME_ACCOUNT_ID,\n };\n this.setTemporaryCache(TemporaryCacheKeys.CCS_CREDENTIAL, JSON.stringify(ccsCredential), true);\n }\n else if (loginHint) {\n const ccsCredential = {\n credential: loginHint,\n type: CcsCredentialType.UPN,\n };\n this.setTemporaryCache(TemporaryCacheKeys.CCS_CREDENTIAL, JSON.stringify(ccsCredential), true);\n }\n }\n /**\n * Reset all temporary cache items\n * @param state\n */\n resetRequestCache(state) {\n this.logger.trace(\"BrowserCacheManager.resetRequestCache called\");\n // check state and remove associated cache items\n if (state) {\n this.temporaryCacheStorage.getKeys().forEach((key) => {\n if (key.indexOf(state) !== -1) {\n this.removeTemporaryItem(key);\n }\n });\n // delete generic interactive request parameters\n this.removeTemporaryItem(this.generateStateKey(state));\n this.removeTemporaryItem(this.generateNonceKey(state));\n this.removeTemporaryItem(this.generateAuthorityKey(state));\n }\n this.removeTemporaryItem(this.generateCacheKey(TemporaryCacheKeys.REQUEST_PARAMS));\n this.removeTemporaryItem(this.generateCacheKey(TemporaryCacheKeys.ORIGIN_URI));\n this.removeTemporaryItem(this.generateCacheKey(TemporaryCacheKeys.URL_HASH));\n this.removeTemporaryItem(this.generateCacheKey(TemporaryCacheKeys.CORRELATION_ID));\n this.removeTemporaryItem(this.generateCacheKey(TemporaryCacheKeys.CCS_CREDENTIAL));\n this.removeTemporaryItem(this.generateCacheKey(TemporaryCacheKeys.NATIVE_REQUEST));\n this.setInteractionInProgress(false);\n }\n /**\n * Removes temporary cache for the provided state\n * @param stateString\n */\n cleanRequestByState(stateString) {\n this.logger.trace(\"BrowserCacheManager.cleanRequestByState called\");\n // Interaction is completed - remove interaction status.\n if (stateString) {\n const stateKey = this.generateStateKey(stateString);\n const cachedState = this.temporaryCacheStorage.getItem(stateKey);\n this.logger.infoPii(`BrowserCacheManager.cleanRequestByState: Removing temporary cache items for state: ${cachedState}`);\n this.resetRequestCache(cachedState || Constants.EMPTY_STRING);\n }\n this.clearMsalCookies();\n }\n /**\n * Looks in temporary cache for any state values with the provided interactionType and removes all temporary cache items for that state\n * Used in scenarios where temp cache needs to be cleaned but state is not known, such as clicking browser back button.\n * @param interactionType\n */\n cleanRequestByInteractionType(interactionType) {\n this.logger.trace(\"BrowserCacheManager.cleanRequestByInteractionType called\");\n // Loop through all keys to find state key\n this.temporaryCacheStorage.getKeys().forEach((key) => {\n // If this key is not the state key, move on\n if (key.indexOf(TemporaryCacheKeys.REQUEST_STATE) === -1) {\n return;\n }\n // Retrieve state value, return if not a valid value\n const stateValue = this.temporaryCacheStorage.getItem(key);\n if (!stateValue) {\n return;\n }\n // Extract state and ensure it matches given InteractionType, then clean request cache\n const parsedState = extractBrowserRequestState(this.cryptoImpl, stateValue);\n if (parsedState &&\n parsedState.interactionType === interactionType) {\n this.logger.infoPii(`BrowserCacheManager.cleanRequestByInteractionType: Removing temporary cache items for state: ${stateValue}`);\n this.resetRequestCache(stateValue);\n }\n });\n this.clearMsalCookies();\n this.setInteractionInProgress(false);\n }\n cacheCodeRequest(authCodeRequest) {\n this.logger.trace(\"BrowserCacheManager.cacheCodeRequest called\");\n const encodedValue = base64Encode(JSON.stringify(authCodeRequest));\n this.setTemporaryCache(TemporaryCacheKeys.REQUEST_PARAMS, encodedValue, true);\n }\n /**\n * Gets the token exchange parameters from the cache. Throws an error if nothing is found.\n */\n getCachedRequest(state) {\n this.logger.trace(\"BrowserCacheManager.getCachedRequest called\");\n // Get token request from cache and parse as TokenExchangeParameters.\n const encodedTokenRequest = this.getTemporaryCache(TemporaryCacheKeys.REQUEST_PARAMS, true);\n if (!encodedTokenRequest) {\n throw createBrowserAuthError(noTokenRequestCacheError);\n }\n let parsedRequest;\n try {\n parsedRequest = JSON.parse(base64Decode(encodedTokenRequest));\n }\n catch (e) {\n this.logger.errorPii(`Attempted to parse: ${encodedTokenRequest}`);\n this.logger.error(`Parsing cached token request threw with error: ${e}`);\n throw createBrowserAuthError(unableToParseTokenRequestCacheError);\n }\n this.removeTemporaryItem(this.generateCacheKey(TemporaryCacheKeys.REQUEST_PARAMS));\n // Get cached authority and use if no authority is cached with request.\n if (!parsedRequest.authority) {\n const authorityCacheKey = this.generateAuthorityKey(state);\n const cachedAuthority = this.getTemporaryCache(authorityCacheKey);\n if (!cachedAuthority) {\n throw createBrowserAuthError(noCachedAuthorityError);\n }\n parsedRequest.authority = cachedAuthority;\n }\n return parsedRequest;\n }\n /**\n * Gets cached native request for redirect flows\n */\n getCachedNativeRequest() {\n this.logger.trace(\"BrowserCacheManager.getCachedNativeRequest called\");\n const cachedRequest = this.getTemporaryCache(TemporaryCacheKeys.NATIVE_REQUEST, true);\n if (!cachedRequest) {\n this.logger.trace(\"BrowserCacheManager.getCachedNativeRequest: No cached native request found\");\n return null;\n }\n const parsedRequest = this.validateAndParseJson(cachedRequest);\n if (!parsedRequest) {\n this.logger.error(\"BrowserCacheManager.getCachedNativeRequest: Unable to parse native request\");\n return null;\n }\n return parsedRequest;\n }\n isInteractionInProgress(matchClientId) {\n const clientId = this.getInteractionInProgress();\n if (matchClientId) {\n return clientId === this.clientId;\n }\n else {\n return !!clientId;\n }\n }\n getInteractionInProgress() {\n const key = `${Constants.CACHE_PREFIX}.${TemporaryCacheKeys.INTERACTION_STATUS_KEY}`;\n return this.getTemporaryCache(key, false);\n }\n setInteractionInProgress(inProgress) {\n // Ensure we don't overwrite interaction in progress for a different clientId\n const key = `${Constants.CACHE_PREFIX}.${TemporaryCacheKeys.INTERACTION_STATUS_KEY}`;\n if (inProgress) {\n if (this.getInteractionInProgress()) {\n throw createBrowserAuthError(interactionInProgress);\n }\n else {\n // No interaction is in progress\n this.setTemporaryCache(key, this.clientId, false);\n }\n }\n else if (!inProgress &&\n this.getInteractionInProgress() === this.clientId) {\n this.removeTemporaryItem(key);\n }\n }\n /**\n * Returns username retrieved from ADAL or MSAL v1 idToken\n * @deprecated\n */\n getLegacyLoginHint() {\n // Only check for adal/msal token if no SSO params are being used\n const adalIdTokenString = this.getTemporaryCache(PersistentCacheKeys.ADAL_ID_TOKEN);\n if (adalIdTokenString) {\n this.browserStorage.removeItem(PersistentCacheKeys.ADAL_ID_TOKEN);\n this.logger.verbose(\"Cached ADAL id token retrieved.\");\n }\n // Check for cached MSAL v1 id token\n const msalIdTokenString = this.getTemporaryCache(PersistentCacheKeys.ID_TOKEN, true);\n if (msalIdTokenString) {\n this.browserStorage.removeItem(this.generateCacheKey(PersistentCacheKeys.ID_TOKEN));\n this.logger.verbose(\"Cached MSAL.js v1 id token retrieved\");\n }\n const cachedIdTokenString = msalIdTokenString || adalIdTokenString;\n if (cachedIdTokenString) {\n const idTokenClaims = AuthToken.extractTokenClaims(cachedIdTokenString, base64Decode);\n if (idTokenClaims.preferred_username) {\n this.logger.verbose(\"No SSO params used and ADAL/MSAL v1 token retrieved, setting ADAL/MSAL v1 preferred_username as loginHint\");\n return idTokenClaims.preferred_username;\n }\n else if (idTokenClaims.upn) {\n this.logger.verbose(\"No SSO params used and ADAL/MSAL v1 token retrieved, setting ADAL/MSAL v1 upn as loginHint\");\n return idTokenClaims.upn;\n }\n else {\n this.logger.verbose(\"No SSO params used and ADAL/MSAL v1 token retrieved, however, no account hint claim found. Enable preferred_username or upn id token claim to get SSO.\");\n }\n }\n return null;\n }\n /**\n * Updates a credential's cache key if the current cache key is outdated\n */\n updateCredentialCacheKey(currentCacheKey, credential) {\n const updatedCacheKey = CacheHelpers.generateCredentialKey(credential);\n if (currentCacheKey !== updatedCacheKey) {\n const cacheItem = this.getItem(currentCacheKey);\n if (cacheItem) {\n this.browserStorage.removeItem(currentCacheKey);\n this.setItem(updatedCacheKey, cacheItem);\n this.logger.verbose(`Updated an outdated ${credential.credentialType} cache key`);\n return updatedCacheKey;\n }\n else {\n this.logger.error(`Attempted to update an outdated ${credential.credentialType} cache key but no item matching the outdated key was found in storage`);\n }\n }\n return currentCacheKey;\n }\n /**\n * Builds credential entities from AuthenticationResult object and saves the resulting credentials to the cache\n * @param result\n * @param request\n */\n async hydrateCache(result, request) {\n const idTokenEntity = CacheHelpers.createIdTokenEntity(result.account?.homeAccountId, result.account?.environment, result.idToken, this.clientId, result.tenantId);\n let claimsHash;\n if (request.claims) {\n claimsHash = await this.cryptoImpl.hashString(request.claims);\n }\n /**\n * meta data for cache stores time in seconds from epoch\n * AuthenticationResult returns expiresOn and extExpiresOn in milliseconds (as a Date object which is in ms)\n * We need to map these for the cache when building tokens from AuthenticationResult\n *\n * The next MSAL VFuture should map these both to same value if possible\n */\n const accessTokenEntity = CacheHelpers.createAccessTokenEntity(result.account?.homeAccountId, result.account.environment, result.accessToken, this.clientId, result.tenantId, result.scopes.join(\" \"), result.expiresOn ? result.expiresOn.getTime() / 1000 : 0, result.extExpiresOn ? result.extExpiresOn.getTime() / 1000 : 0, base64Decode, undefined, // refreshOn\n result.tokenType, undefined, // userAssertionHash\n request.sshKid, request.claims, claimsHash);\n const cacheRecord = {\n idToken: idTokenEntity,\n accessToken: accessTokenEntity,\n };\n return this.saveCacheRecord(cacheRecord);\n }\n /**\n * saves a cache record\n * @param cacheRecord {CacheRecord}\n * @param storeInCache {?StoreInCache}\n * @param correlationId {?string} correlation id\n */\n async saveCacheRecord(cacheRecord, storeInCache, correlationId) {\n try {\n await super.saveCacheRecord(cacheRecord, storeInCache, correlationId);\n }\n catch (e) {\n if (e instanceof CacheError &&\n this.performanceClient &&\n correlationId) {\n try {\n const tokenKeys = this.getTokenKeys();\n this.performanceClient.addFields({\n cacheRtCount: tokenKeys.refreshToken.length,\n cacheIdCount: tokenKeys.idToken.length,\n cacheAtCount: tokenKeys.accessToken.length,\n }, correlationId);\n }\n catch (e) { }\n }\n throw e;\n }\n }\n}\nconst DEFAULT_BROWSER_CACHE_MANAGER = (clientId, logger) => {\n const cacheOptions = {\n cacheLocation: BrowserCacheLocation.MemoryStorage,\n temporaryCacheLocation: BrowserCacheLocation.MemoryStorage,\n storeAuthStateInCookie: false,\n secureCookies: false,\n cacheMigrationEnabled: false,\n claimsBasedCachingEnabled: false,\n };\n return new BrowserCacheManager(clientId, cacheOptions, DEFAULT_CRYPTO_IMPLEMENTATION, logger);\n};\n\nexport { BrowserCacheManager, DEFAULT_BROWSER_CACHE_MANAGER };\n//# sourceMappingURL=BrowserCacheManager.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Returns all the accounts in the cache that match the optional filter. If no filter is provided, all accounts are returned.\n * @param accountFilter - (Optional) filter to narrow down the accounts returned\n * @returns Array of AccountInfo objects in cache\n */\nfunction getAllAccounts(logger, browserStorage, isInBrowser, accountFilter) {\n logger.verbose(\"getAllAccounts called\");\n return isInBrowser ? browserStorage.getAllAccounts(accountFilter) : [];\n}\n/**\n * Returns the first account found in the cache that matches the account filter passed in.\n * @param accountFilter\n * @returns The first account found in the cache matching the provided filter or null if no account could be found.\n */\nfunction getAccount(accountFilter, logger, browserStorage) {\n logger.trace(\"getAccount called\");\n if (Object.keys(accountFilter).length === 0) {\n logger.warning(\"getAccount: No accountFilter provided\");\n return null;\n }\n const account = browserStorage.getAccountInfoFilteredBy(accountFilter);\n if (account) {\n logger.verbose(\"getAccount: Account matching provided filter found, returning\");\n return account;\n }\n else {\n logger.verbose(\"getAccount: No matching account found, returning null\");\n return null;\n }\n}\n/**\n * Returns the signed in account matching username.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found.\n * This API is provided for convenience but getAccountById should be used for best reliability\n * @param username\n * @returns The account object stored in MSAL\n */\nfunction getAccountByUsername(username, logger, browserStorage) {\n logger.trace(\"getAccountByUsername called\");\n if (!username) {\n logger.warning(\"getAccountByUsername: No username provided\");\n return null;\n }\n const account = browserStorage.getAccountInfoFilteredBy({\n username,\n });\n if (account) {\n logger.verbose(\"getAccountByUsername: Account matching username found, returning\");\n logger.verbosePii(`getAccountByUsername: Returning signed-in accounts matching username: ${username}`);\n return account;\n }\n else {\n logger.verbose(\"getAccountByUsername: No matching account found, returning null\");\n return null;\n }\n}\n/**\n * Returns the signed in account matching homeAccountId.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found\n * @param homeAccountId\n * @returns The account object stored in MSAL\n */\nfunction getAccountByHomeId(homeAccountId, logger, browserStorage) {\n logger.trace(\"getAccountByHomeId called\");\n if (!homeAccountId) {\n logger.warning(\"getAccountByHomeId: No homeAccountId provided\");\n return null;\n }\n const account = browserStorage.getAccountInfoFilteredBy({\n homeAccountId,\n });\n if (account) {\n logger.verbose(\"getAccountByHomeId: Account matching homeAccountId found, returning\");\n logger.verbosePii(`getAccountByHomeId: Returning signed-in accounts matching homeAccountId: ${homeAccountId}`);\n return account;\n }\n else {\n logger.verbose(\"getAccountByHomeId: No matching account found, returning null\");\n return null;\n }\n}\n/**\n * Returns the signed in account matching localAccountId.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found\n * @param localAccountId\n * @returns The account object stored in MSAL\n */\nfunction getAccountByLocalId(localAccountId, logger, browserStorage) {\n logger.trace(\"getAccountByLocalId called\");\n if (!localAccountId) {\n logger.warning(\"getAccountByLocalId: No localAccountId provided\");\n return null;\n }\n const account = browserStorage.getAccountInfoFilteredBy({\n localAccountId,\n });\n if (account) {\n logger.verbose(\"getAccountByLocalId: Account matching localAccountId found, returning\");\n logger.verbosePii(`getAccountByLocalId: Returning signed-in accounts matching localAccountId: ${localAccountId}`);\n return account;\n }\n else {\n logger.verbose(\"getAccountByLocalId: No matching account found, returning null\");\n return null;\n }\n}\n/**\n * Sets the account to use as the active account. If no account is passed to the acquireToken APIs, then MSAL will use this active account.\n * @param account\n */\nfunction setActiveAccount(account, browserStorage) {\n browserStorage.setActiveAccount(account);\n}\n/**\n * Gets the currently active account\n */\nfunction getActiveAccount(browserStorage) {\n return browserStorage.getActiveAccount();\n}\n\nexport { getAccount, getAccountByHomeId, getAccountByLocalId, getAccountByUsername, getActiveAccount, getAllAccounts, setActiveAccount };\n//# sourceMappingURL=AccountManager.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst EventType = {\n INITIALIZE_START: \"msal:initializeStart\",\n INITIALIZE_END: \"msal:initializeEnd\",\n ACCOUNT_ADDED: \"msal:accountAdded\",\n ACCOUNT_REMOVED: \"msal:accountRemoved\",\n ACTIVE_ACCOUNT_CHANGED: \"msal:activeAccountChanged\",\n LOGIN_START: \"msal:loginStart\",\n LOGIN_SUCCESS: \"msal:loginSuccess\",\n LOGIN_FAILURE: \"msal:loginFailure\",\n ACQUIRE_TOKEN_START: \"msal:acquireTokenStart\",\n ACQUIRE_TOKEN_SUCCESS: \"msal:acquireTokenSuccess\",\n ACQUIRE_TOKEN_FAILURE: \"msal:acquireTokenFailure\",\n ACQUIRE_TOKEN_NETWORK_START: \"msal:acquireTokenFromNetworkStart\",\n SSO_SILENT_START: \"msal:ssoSilentStart\",\n SSO_SILENT_SUCCESS: \"msal:ssoSilentSuccess\",\n SSO_SILENT_FAILURE: \"msal:ssoSilentFailure\",\n ACQUIRE_TOKEN_BY_CODE_START: \"msal:acquireTokenByCodeStart\",\n ACQUIRE_TOKEN_BY_CODE_SUCCESS: \"msal:acquireTokenByCodeSuccess\",\n ACQUIRE_TOKEN_BY_CODE_FAILURE: \"msal:acquireTokenByCodeFailure\",\n HANDLE_REDIRECT_START: \"msal:handleRedirectStart\",\n HANDLE_REDIRECT_END: \"msal:handleRedirectEnd\",\n POPUP_OPENED: \"msal:popupOpened\",\n LOGOUT_START: \"msal:logoutStart\",\n LOGOUT_SUCCESS: \"msal:logoutSuccess\",\n LOGOUT_FAILURE: \"msal:logoutFailure\",\n LOGOUT_END: \"msal:logoutEnd\",\n RESTORE_FROM_BFCACHE: \"msal:restoreFromBFCache\",\n};\n\nexport { EventType };\n//# sourceMappingURL=EventType.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PersistentCacheKeys, AccountEntity, CacheManager } from '@azure/msal-common';\nimport { EventType } from './EventType.mjs';\nimport { createNewGuid } from '../crypto/BrowserCrypto.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass EventHandler {\n constructor(logger, browserCrypto) {\n this.eventCallbacks = new Map();\n this.logger = logger;\n this.browserCrypto = browserCrypto;\n this.listeningToStorageEvents = false;\n this.handleAccountCacheChange =\n this.handleAccountCacheChange.bind(this);\n }\n /**\n * Adds event callbacks to array\n * @param callback\n */\n addEventCallback(callback) {\n if (typeof window !== \"undefined\") {\n const callbackId = createNewGuid();\n this.eventCallbacks.set(callbackId, callback);\n this.logger.verbose(`Event callback registered with id: ${callbackId}`);\n return callbackId;\n }\n return null;\n }\n /**\n * Removes callback with provided id from callback array\n * @param callbackId\n */\n removeEventCallback(callbackId) {\n this.eventCallbacks.delete(callbackId);\n this.logger.verbose(`Event callback ${callbackId} removed.`);\n }\n /**\n * Adds event listener that emits an event when a user account is added or removed from localstorage in a different browser tab or window\n */\n enableAccountStorageEvents() {\n if (typeof window === \"undefined\") {\n return;\n }\n if (!this.listeningToStorageEvents) {\n this.logger.verbose(\"Adding account storage listener.\");\n this.listeningToStorageEvents = true;\n window.addEventListener(\"storage\", this.handleAccountCacheChange);\n }\n else {\n this.logger.verbose(\"Account storage listener already registered.\");\n }\n }\n /**\n * Removes event listener that emits an event when a user account is added or removed from localstorage in a different browser tab or window\n */\n disableAccountStorageEvents() {\n if (typeof window === \"undefined\") {\n return;\n }\n if (this.listeningToStorageEvents) {\n this.logger.verbose(\"Removing account storage listener.\");\n window.removeEventListener(\"storage\", this.handleAccountCacheChange);\n this.listeningToStorageEvents = false;\n }\n else {\n this.logger.verbose(\"No account storage listener registered.\");\n }\n }\n /**\n * Emits events by calling callback with event message\n * @param eventType\n * @param interactionType\n * @param payload\n * @param error\n */\n emitEvent(eventType, interactionType, payload, error) {\n if (typeof window !== \"undefined\") {\n const message = {\n eventType: eventType,\n interactionType: interactionType || null,\n payload: payload || null,\n error: error || null,\n timestamp: Date.now(),\n };\n this.logger.info(`Emitting event: ${eventType}`);\n this.eventCallbacks.forEach((callback, callbackId) => {\n this.logger.verbose(`Emitting event to callback ${callbackId}: ${eventType}`);\n callback.apply(null, [message]);\n });\n }\n }\n /**\n * Emit account added/removed events when cached accounts are changed in a different tab or frame\n */\n handleAccountCacheChange(e) {\n try {\n // Handle active account filter change\n if (e.key?.includes(PersistentCacheKeys.ACTIVE_ACCOUNT_FILTERS)) {\n // This event has no payload, it only signals cross-tab app instances that the results of calling getActiveAccount() will have changed\n this.emitEvent(EventType.ACTIVE_ACCOUNT_CHANGED);\n }\n // Handle account object change\n const cacheValue = e.newValue || e.oldValue;\n if (!cacheValue) {\n return;\n }\n const parsedValue = JSON.parse(cacheValue);\n if (typeof parsedValue !== \"object\" ||\n !AccountEntity.isAccountEntity(parsedValue)) {\n return;\n }\n const accountEntity = CacheManager.toObject(new AccountEntity(), parsedValue);\n const accountInfo = accountEntity.getAccountInfo();\n if (!e.oldValue && e.newValue) {\n this.logger.info(\"Account was added to cache in a different window\");\n this.emitEvent(EventType.ACCOUNT_ADDED, undefined, accountInfo);\n }\n else if (!e.newValue && e.oldValue) {\n this.logger.info(\"Account was removed from cache in a different window\");\n this.emitEvent(EventType.ACCOUNT_REMOVED, undefined, accountInfo);\n }\n }\n catch (e) {\n return;\n }\n }\n}\n\nexport { EventHandler };\n//# sourceMappingURL=EventHandler.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { AccountEntity, UrlString, ServerTelemetryManager, PerformanceEvents, Authority, invokeAsync, AuthorityFactory, createClientConfigurationError, ClientConfigurationErrorCodes } from '@azure/msal-common';\nimport { version } from '../packageMetadata.mjs';\nimport { BrowserConstants } from '../utils/BrowserConstants.mjs';\nimport { getCurrentUri } from '../utils/BrowserUtils.mjs';\nimport { createNewGuid } from '../crypto/BrowserCrypto.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass BaseInteractionClient {\n constructor(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, performanceClient, nativeMessageHandler, correlationId) {\n this.config = config;\n this.browserStorage = storageImpl;\n this.browserCrypto = browserCrypto;\n this.networkClient = this.config.system.networkClient;\n this.eventHandler = eventHandler;\n this.navigationClient = navigationClient;\n this.nativeMessageHandler = nativeMessageHandler;\n this.correlationId = correlationId || createNewGuid();\n this.logger = logger.clone(BrowserConstants.MSAL_SKU, version, this.correlationId);\n this.performanceClient = performanceClient;\n }\n async clearCacheOnLogout(account) {\n if (account) {\n if (AccountEntity.accountInfoIsEqual(account, this.browserStorage.getActiveAccount(), false)) {\n this.logger.verbose(\"Setting active account to null\");\n this.browserStorage.setActiveAccount(null);\n }\n // Clear given account.\n try {\n await this.browserStorage.removeAccount(AccountEntity.generateAccountCacheKey(account));\n this.logger.verbose(\"Cleared cache items belonging to the account provided in the logout request.\");\n }\n catch (error) {\n this.logger.error(\"Account provided in logout request was not found. Local cache unchanged.\");\n }\n }\n else {\n try {\n this.logger.verbose(\"No account provided in logout request, clearing all cache items.\", this.correlationId);\n // Clear all accounts and tokens\n await this.browserStorage.clear();\n // Clear any stray keys from IndexedDB\n await this.browserCrypto.clearKeystore();\n }\n catch (e) {\n this.logger.error(\"Attempted to clear all MSAL cache items and failed. Local cache unchanged.\");\n }\n }\n }\n /**\n *\n * Use to get the redirect uri configured in MSAL or null.\n * @param requestRedirectUri\n * @returns Redirect URL\n *\n */\n getRedirectUri(requestRedirectUri) {\n this.logger.verbose(\"getRedirectUri called\");\n const redirectUri = requestRedirectUri ||\n this.config.auth.redirectUri ||\n getCurrentUri();\n return UrlString.getAbsoluteUrl(redirectUri, getCurrentUri());\n }\n /**\n *\n * @param apiId\n * @param correlationId\n * @param forceRefresh\n */\n initializeServerTelemetryManager(apiId, forceRefresh) {\n this.logger.verbose(\"initializeServerTelemetryManager called\");\n const telemetryPayload = {\n clientId: this.config.auth.clientId,\n correlationId: this.correlationId,\n apiId: apiId,\n forceRefresh: forceRefresh || false,\n wrapperSKU: this.browserStorage.getWrapperMetadata()[0],\n wrapperVer: this.browserStorage.getWrapperMetadata()[1],\n };\n return new ServerTelemetryManager(telemetryPayload, this.browserStorage);\n }\n /**\n * Used to get a discovered version of the default authority.\n * @param requestAuthority\n * @param requestAzureCloudOptions\n * @param account\n */\n async getDiscoveredAuthority(requestAuthority, requestAzureCloudOptions, account) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.StandardInteractionClientGetDiscoveredAuthority, this.correlationId);\n const authorityOptions = {\n protocolMode: this.config.auth.protocolMode,\n OIDCOptions: this.config.auth.OIDCOptions,\n knownAuthorities: this.config.auth.knownAuthorities,\n cloudDiscoveryMetadata: this.config.auth.cloudDiscoveryMetadata,\n authorityMetadata: this.config.auth.authorityMetadata,\n skipAuthorityMetadataCache: this.config.auth.skipAuthorityMetadataCache,\n };\n // build authority string based on auth params, precedence - azureCloudInstance + tenant >> authority\n const userAuthority = requestAuthority\n ? requestAuthority\n : this.config.auth.authority;\n // fall back to the authority from config\n const builtAuthority = Authority.generateAuthority(userAuthority, requestAzureCloudOptions || this.config.auth.azureCloudOptions);\n const discoveredAuthority = await invokeAsync(AuthorityFactory.createDiscoveredInstance, PerformanceEvents.AuthorityFactoryCreateDiscoveredInstance, this.logger, this.performanceClient, this.correlationId)(builtAuthority, this.config.system.networkClient, this.browserStorage, authorityOptions, this.logger, this.correlationId, this.performanceClient);\n if (account && !discoveredAuthority.isAlias(account.environment)) {\n throw createClientConfigurationError(ClientConfigurationErrorCodes.authorityMismatch);\n }\n return discoveredAuthority;\n }\n}\n\nexport { BaseInteractionClient };\n//# sourceMappingURL=BaseInteractionClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, invoke, invokeAsync } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { urlEncodeArr } from '../encode/Base64Encode.mjs';\nimport { getRandomValues, sha256Digest } from './BrowserCrypto.mjs';\nimport { pkceNotCreated } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n// Constant byte array length\nconst RANDOM_BYTE_ARR_LENGTH = 32;\n/**\n * This file defines APIs to generate PKCE codes and code verifiers.\n */\n/**\n * Generates PKCE Codes. See the RFC for more information: https://tools.ietf.org/html/rfc7636\n */\nasync function generatePkceCodes(performanceClient, logger, correlationId) {\n performanceClient.addQueueMeasurement(PerformanceEvents.GeneratePkceCodes, correlationId);\n const codeVerifier = invoke(generateCodeVerifier, PerformanceEvents.GenerateCodeVerifier, logger, performanceClient, correlationId)(performanceClient, logger, correlationId);\n const codeChallenge = await invokeAsync(generateCodeChallengeFromVerifier, PerformanceEvents.GenerateCodeChallengeFromVerifier, logger, performanceClient, correlationId)(codeVerifier, performanceClient, logger, correlationId);\n return {\n verifier: codeVerifier,\n challenge: codeChallenge,\n };\n}\n/**\n * Generates a random 32 byte buffer and returns the base64\n * encoded string to be used as a PKCE Code Verifier\n */\nfunction generateCodeVerifier(performanceClient, logger, correlationId) {\n try {\n // Generate random values as utf-8\n const buffer = new Uint8Array(RANDOM_BYTE_ARR_LENGTH);\n invoke(getRandomValues, PerformanceEvents.GetRandomValues, logger, performanceClient, correlationId)(buffer);\n // encode verifier as base64\n const pkceCodeVerifierB64 = urlEncodeArr(buffer);\n return pkceCodeVerifierB64;\n }\n catch (e) {\n throw createBrowserAuthError(pkceNotCreated);\n }\n}\n/**\n * Creates a base64 encoded PKCE Code Challenge string from the\n * hash created from the PKCE Code Verifier supplied\n */\nasync function generateCodeChallengeFromVerifier(pkceCodeVerifier, performanceClient, logger, correlationId) {\n performanceClient.addQueueMeasurement(PerformanceEvents.GenerateCodeChallengeFromVerifier, correlationId);\n try {\n // hashed verifier\n const pkceHashedCodeVerifier = await invokeAsync(sha256Digest, PerformanceEvents.Sha256Digest, logger, performanceClient, correlationId)(pkceCodeVerifier, performanceClient, correlationId);\n // encode hash as base64\n return urlEncodeArr(new Uint8Array(pkceHashedCodeVerifier));\n }\n catch (e) {\n throw createBrowserAuthError(pkceNotCreated);\n }\n}\n\nexport { generatePkceCodes };\n//# sourceMappingURL=PkceGenerator.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, invokeAsync, AuthenticationScheme, createClientConfigurationError, ClientConfigurationErrorCodes, StringUtils } from '@azure/msal-common';\nimport { hashString } from '../crypto/BrowserCrypto.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Initializer function for all request APIs\n * @param request\n */\nasync function initializeBaseRequest(request, config, performanceClient, logger) {\n performanceClient.addQueueMeasurement(PerformanceEvents.InitializeBaseRequest, request.correlationId);\n const authority = request.authority || config.auth.authority;\n const scopes = [...((request && request.scopes) || [])];\n const validatedRequest = {\n ...request,\n correlationId: request.correlationId,\n authority,\n scopes,\n };\n // Set authenticationScheme to BEARER if not explicitly set in the request\n if (!validatedRequest.authenticationScheme) {\n validatedRequest.authenticationScheme = AuthenticationScheme.BEARER;\n logger.verbose('Authentication Scheme wasn\\'t explicitly set in request, defaulting to \"Bearer\" request');\n }\n else {\n if (validatedRequest.authenticationScheme === AuthenticationScheme.SSH) {\n if (!request.sshJwk) {\n throw createClientConfigurationError(ClientConfigurationErrorCodes.missingSshJwk);\n }\n if (!request.sshKid) {\n throw createClientConfigurationError(ClientConfigurationErrorCodes.missingSshKid);\n }\n }\n logger.verbose(`Authentication Scheme set to \"${validatedRequest.authenticationScheme}\" as configured in Auth request`);\n }\n // Set requested claims hash if claims-based caching is enabled and claims were requested\n if (config.cache.claimsBasedCachingEnabled &&\n request.claims &&\n // Checks for empty stringified object \"{}\" which doesn't qualify as requested claims\n !StringUtils.isEmptyObj(request.claims)) {\n validatedRequest.requestedClaimsHash = await hashString(request.claims);\n }\n return validatedRequest;\n}\nasync function initializeSilentRequest(request, account, config, performanceClient, logger) {\n performanceClient.addQueueMeasurement(PerformanceEvents.InitializeSilentRequest, request.correlationId);\n const baseRequest = await invokeAsync(initializeBaseRequest, PerformanceEvents.InitializeBaseRequest, logger, performanceClient, request.correlationId)(request, config, performanceClient, logger);\n return {\n ...request,\n ...baseRequest,\n account: account,\n forceRefresh: request.forceRefresh || false,\n };\n}\n\nexport { initializeBaseRequest, initializeSilentRequest };\n//# sourceMappingURL=RequestHelpers.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, invokeAsync, Constants, UrlString, AuthorizationCodeClient, ProtocolUtils } from '@azure/msal-common';\nimport { BaseInteractionClient } from './BaseInteractionClient.mjs';\nimport { BrowserConstants } from '../utils/BrowserConstants.mjs';\nimport { version } from '../packageMetadata.mjs';\nimport { getCurrentUri } from '../utils/BrowserUtils.mjs';\nimport { generatePkceCodes } from '../crypto/PkceGenerator.mjs';\nimport { createNewGuid } from '../crypto/BrowserCrypto.mjs';\nimport { initializeBaseRequest } from '../request/RequestHelpers.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Defines the class structure and helper functions used by the \"standard\", non-brokered auth flows (popup, redirect, silent (RT), silent (iframe))\n */\nclass StandardInteractionClient extends BaseInteractionClient {\n /**\n * Generates an auth code request tied to the url request.\n * @param request\n */\n async initializeAuthorizationCodeRequest(request) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.StandardInteractionClientInitializeAuthorizationCodeRequest, this.correlationId);\n const generatedPkceParams = await invokeAsync(generatePkceCodes, PerformanceEvents.GeneratePkceCodes, this.logger, this.performanceClient, this.correlationId)(this.performanceClient, this.logger, this.correlationId);\n const authCodeRequest = {\n ...request,\n redirectUri: request.redirectUri,\n code: Constants.EMPTY_STRING,\n codeVerifier: generatedPkceParams.verifier,\n };\n request.codeChallenge = generatedPkceParams.challenge;\n request.codeChallengeMethod = Constants.S256_CODE_CHALLENGE_METHOD;\n return authCodeRequest;\n }\n /**\n * Initializer for the logout request.\n * @param logoutRequest\n */\n initializeLogoutRequest(logoutRequest) {\n this.logger.verbose(\"initializeLogoutRequest called\", logoutRequest?.correlationId);\n const validLogoutRequest = {\n correlationId: this.correlationId || createNewGuid(),\n ...logoutRequest,\n };\n /**\n * Set logout_hint to be login_hint from ID Token Claims if present\n * and logoutHint attribute wasn't manually set in logout request\n */\n if (logoutRequest) {\n // If logoutHint isn't set and an account was passed in, try to extract logoutHint from ID Token Claims\n if (!logoutRequest.logoutHint) {\n if (logoutRequest.account) {\n const logoutHint = this.getLogoutHintFromIdTokenClaims(logoutRequest.account);\n if (logoutHint) {\n this.logger.verbose(\"Setting logoutHint to login_hint ID Token Claim value for the account provided\");\n validLogoutRequest.logoutHint = logoutHint;\n }\n }\n else {\n this.logger.verbose(\"logoutHint was not set and account was not passed into logout request, logoutHint will not be set\");\n }\n }\n else {\n this.logger.verbose(\"logoutHint has already been set in logoutRequest\");\n }\n }\n else {\n this.logger.verbose(\"logoutHint will not be set since no logout request was configured\");\n }\n /*\n * Only set redirect uri if logout request isn't provided or the set uri isn't null.\n * Otherwise, use passed uri, config, or current page.\n */\n if (!logoutRequest || logoutRequest.postLogoutRedirectUri !== null) {\n if (logoutRequest && logoutRequest.postLogoutRedirectUri) {\n this.logger.verbose(\"Setting postLogoutRedirectUri to uri set on logout request\", validLogoutRequest.correlationId);\n validLogoutRequest.postLogoutRedirectUri =\n UrlString.getAbsoluteUrl(logoutRequest.postLogoutRedirectUri, getCurrentUri());\n }\n else if (this.config.auth.postLogoutRedirectUri === null) {\n this.logger.verbose(\"postLogoutRedirectUri configured as null and no uri set on request, not passing post logout redirect\", validLogoutRequest.correlationId);\n }\n else if (this.config.auth.postLogoutRedirectUri) {\n this.logger.verbose(\"Setting postLogoutRedirectUri to configured uri\", validLogoutRequest.correlationId);\n validLogoutRequest.postLogoutRedirectUri =\n UrlString.getAbsoluteUrl(this.config.auth.postLogoutRedirectUri, getCurrentUri());\n }\n else {\n this.logger.verbose(\"Setting postLogoutRedirectUri to current page\", validLogoutRequest.correlationId);\n validLogoutRequest.postLogoutRedirectUri =\n UrlString.getAbsoluteUrl(getCurrentUri(), getCurrentUri());\n }\n }\n else {\n this.logger.verbose(\"postLogoutRedirectUri passed as null, not setting post logout redirect uri\", validLogoutRequest.correlationId);\n }\n return validLogoutRequest;\n }\n /**\n * Parses login_hint ID Token Claim out of AccountInfo object to be used as\n * logout_hint in end session request.\n * @param account\n */\n getLogoutHintFromIdTokenClaims(account) {\n const idTokenClaims = account.idTokenClaims;\n if (idTokenClaims) {\n if (idTokenClaims.login_hint) {\n return idTokenClaims.login_hint;\n }\n else {\n this.logger.verbose(\"The ID Token Claims tied to the provided account do not contain a login_hint claim, logoutHint will not be added to logout request\");\n }\n }\n else {\n this.logger.verbose(\"The provided account does not contain ID Token Claims, logoutHint will not be added to logout request\");\n }\n return null;\n }\n /**\n * Creates an Authorization Code Client with the given authority, or the default authority.\n * @param serverTelemetryManager\n * @param authorityUrl\n */\n async createAuthCodeClient(serverTelemetryManager, authorityUrl, requestAzureCloudOptions, account) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.StandardInteractionClientCreateAuthCodeClient, this.correlationId);\n // Create auth module.\n const clientConfig = await invokeAsync(this.getClientConfiguration.bind(this), PerformanceEvents.StandardInteractionClientGetClientConfiguration, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, authorityUrl, requestAzureCloudOptions, account);\n return new AuthorizationCodeClient(clientConfig, this.performanceClient);\n }\n /**\n * Creates a Client Configuration object with the given request authority, or the default authority.\n * @param serverTelemetryManager\n * @param requestAuthority\n * @param requestCorrelationId\n */\n async getClientConfiguration(serverTelemetryManager, requestAuthority, requestAzureCloudOptions, account) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.StandardInteractionClientGetClientConfiguration, this.correlationId);\n const discoveredAuthority = await invokeAsync(this.getDiscoveredAuthority.bind(this), PerformanceEvents.StandardInteractionClientGetDiscoveredAuthority, this.logger, this.performanceClient, this.correlationId)(requestAuthority, requestAzureCloudOptions, account);\n const logger = this.config.system.loggerOptions;\n return {\n authOptions: {\n clientId: this.config.auth.clientId,\n authority: discoveredAuthority,\n clientCapabilities: this.config.auth.clientCapabilities,\n },\n systemOptions: {\n tokenRenewalOffsetSeconds: this.config.system.tokenRenewalOffsetSeconds,\n preventCorsPreflight: true,\n },\n loggerOptions: {\n loggerCallback: logger.loggerCallback,\n piiLoggingEnabled: logger.piiLoggingEnabled,\n logLevel: logger.logLevel,\n correlationId: this.correlationId,\n },\n cacheOptions: {\n claimsBasedCachingEnabled: this.config.cache.claimsBasedCachingEnabled,\n },\n cryptoInterface: this.browserCrypto,\n networkInterface: this.networkClient,\n storageInterface: this.browserStorage,\n serverTelemetryManager: serverTelemetryManager,\n libraryInfo: {\n sku: BrowserConstants.MSAL_SKU,\n version: version,\n cpu: Constants.EMPTY_STRING,\n os: Constants.EMPTY_STRING,\n },\n telemetry: this.config.telemetry,\n };\n }\n /**\n * Helper to initialize required request parameters for interactive APIs and ssoSilent()\n * @param request\n * @param interactionType\n */\n async initializeAuthorizationRequest(request, interactionType) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.StandardInteractionClientInitializeAuthorizationRequest, this.correlationId);\n const redirectUri = this.getRedirectUri(request.redirectUri);\n const browserState = {\n interactionType: interactionType,\n };\n const state = ProtocolUtils.setRequestState(this.browserCrypto, (request && request.state) || Constants.EMPTY_STRING, browserState);\n const baseRequest = await invokeAsync(initializeBaseRequest, PerformanceEvents.InitializeBaseRequest, this.logger, this.performanceClient, this.correlationId)({ ...request, correlationId: this.correlationId }, this.config, this.performanceClient, this.logger);\n const validatedRequest = {\n ...baseRequest,\n redirectUri: redirectUri,\n state: state,\n nonce: request.nonce || createNewGuid(),\n responseMode: this.config.auth.OIDCOptions\n .serverResponseType,\n };\n const account = request.account || this.browserStorage.getActiveAccount();\n if (account) {\n this.logger.verbose(\"Setting validated request account\", this.correlationId);\n this.logger.verbosePii(`Setting validated request account: ${account.homeAccountId}`, this.correlationId);\n validatedRequest.account = account;\n }\n // Check for ADAL/MSAL v1 SSO\n if (!validatedRequest.loginHint && !account) {\n const legacyLoginHint = this.browserStorage.getLegacyLoginHint();\n if (legacyLoginHint) {\n validatedRequest.loginHint = legacyLoginHint;\n }\n }\n return validatedRequest;\n }\n}\n\nexport { StandardInteractionClient };\n//# sourceMappingURL=StandardInteractionClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst contentError = \"ContentError\";\nconst userSwitch = \"user_switch\";\n\nexport { contentError, userSwitch };\n//# sourceMappingURL=NativeAuthErrorCodes.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n// Status Codes that can be thrown by WAM\nconst USER_INTERACTION_REQUIRED = \"USER_INTERACTION_REQUIRED\";\nconst USER_CANCEL = \"USER_CANCEL\";\nconst NO_NETWORK = \"NO_NETWORK\";\nconst PERSISTENT_ERROR = \"PERSISTENT_ERROR\";\nconst DISABLED = \"DISABLED\";\nconst ACCOUNT_UNAVAILABLE = \"ACCOUNT_UNAVAILABLE\";\n\nexport { ACCOUNT_UNAVAILABLE, DISABLED, NO_NETWORK, PERSISTENT_ERROR, USER_CANCEL, USER_INTERACTION_REQUIRED };\n//# sourceMappingURL=NativeStatusCodes.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { AuthError, InteractionRequiredAuthError, createInteractionRequiredAuthError, InteractionRequiredAuthErrorCodes } from '@azure/msal-common';\nimport { createBrowserAuthError } from './BrowserAuthError.mjs';\nimport { contentError, userSwitch } from './NativeAuthErrorCodes.mjs';\nimport { PERSISTENT_ERROR, DISABLED, NO_NETWORK, USER_CANCEL, USER_INTERACTION_REQUIRED, ACCOUNT_UNAVAILABLE } from '../broker/nativeBroker/NativeStatusCodes.mjs';\nimport { noNetworkConnectivity, userCancelled } from './BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst INVALID_METHOD_ERROR = -2147186943;\nconst NativeAuthErrorMessages = {\n [userSwitch]: \"User attempted to switch accounts in the native broker, which is not allowed. All new accounts must sign-in through the standard web flow first, please try again.\",\n};\nclass NativeAuthError extends AuthError {\n constructor(errorCode, description, ext) {\n super(errorCode, description);\n Object.setPrototypeOf(this, NativeAuthError.prototype);\n this.name = \"NativeAuthError\";\n this.ext = ext;\n }\n}\n/**\n * These errors should result in a fallback to the 'standard' browser based auth flow.\n */\nfunction isFatalNativeAuthError(error) {\n if (error.ext &&\n error.ext.status &&\n (error.ext.status === PERSISTENT_ERROR ||\n error.ext.status === DISABLED)) {\n return true;\n }\n if (error.ext &&\n error.ext.error &&\n error.ext.error === INVALID_METHOD_ERROR) {\n return true;\n }\n switch (error.errorCode) {\n case contentError:\n return true;\n default:\n return false;\n }\n}\n/**\n * Create the appropriate error object based on the WAM status code.\n * @param code\n * @param description\n * @param ext\n * @returns\n */\nfunction createNativeAuthError(code, description, ext) {\n if (ext && ext.status) {\n switch (ext.status) {\n case ACCOUNT_UNAVAILABLE:\n return createInteractionRequiredAuthError(InteractionRequiredAuthErrorCodes.nativeAccountUnavailable);\n case USER_INTERACTION_REQUIRED:\n return new InteractionRequiredAuthError(code, description);\n case USER_CANCEL:\n return createBrowserAuthError(userCancelled);\n case NO_NETWORK:\n return createBrowserAuthError(noNetworkConnectivity);\n }\n }\n return new NativeAuthError(code, NativeAuthErrorMessages[code] || description, ext);\n}\n\nexport { NativeAuthError, NativeAuthErrorMessages, createNativeAuthError, isFatalNativeAuthError };\n//# sourceMappingURL=NativeAuthError.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { StandardInteractionClient } from './StandardInteractionClient.mjs';\nimport { PerformanceEvents, invokeAsync, SilentFlowClient } from '@azure/msal-common';\nimport { ApiId } from '../utils/BrowserConstants.mjs';\nimport { BrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { cryptoKeyNotFound } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass SilentCacheClient extends StandardInteractionClient {\n /**\n * Returns unexpired tokens from the cache, if available\n * @param silentRequest\n */\n async acquireToken(silentRequest) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.SilentCacheClientAcquireToken, silentRequest.correlationId);\n // Telemetry manager only used to increment cacheHits here\n const serverTelemetryManager = this.initializeServerTelemetryManager(ApiId.acquireTokenSilent_silentFlow);\n const clientConfig = await invokeAsync(this.getClientConfiguration.bind(this), PerformanceEvents.StandardInteractionClientGetClientConfiguration, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, silentRequest.authority, silentRequest.azureCloudOptions, silentRequest.account);\n const silentAuthClient = new SilentFlowClient(clientConfig, this.performanceClient);\n this.logger.verbose(\"Silent auth client created\");\n try {\n const response = await invokeAsync(silentAuthClient.acquireCachedToken.bind(silentAuthClient), PerformanceEvents.SilentFlowClientAcquireCachedToken, this.logger, this.performanceClient, silentRequest.correlationId)(silentRequest);\n const authResponse = response[0];\n this.performanceClient.addFields({\n fromCache: true,\n }, silentRequest.correlationId);\n return authResponse;\n }\n catch (error) {\n if (error instanceof BrowserAuthError &&\n error.errorCode === cryptoKeyNotFound) {\n this.logger.verbose(\"Signing keypair for bound access token not found. Refreshing bound access token and generating a new crypto keypair.\");\n }\n throw error;\n }\n }\n /**\n * API to silenty clear the browser cache.\n * @param logoutRequest\n */\n logout(logoutRequest) {\n this.logger.verbose(\"logoutRedirect called\");\n const validLogoutRequest = this.initializeLogoutRequest(logoutRequest);\n return this.clearCacheOnLogout(validLogoutRequest?.account);\n }\n}\n\nexport { SilentCacheClient };\n//# sourceMappingURL=SilentCacheClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, TimeUtils, ScopeSet, createClientAuthError, ClientAuthErrorCodes, AuthToken, buildAccountToCache, AccountEntity, Constants, AuthorityType, AuthenticationScheme, PopTokenGenerator, updateAccountTenantProfileData, CacheHelpers, createAuthError, AuthErrorCodes, UrlString, OIDC_DEFAULT_SCOPES, invokeAsync, AADServerParamKeys, PromptValue } from '@azure/msal-common';\nimport { BaseInteractionClient } from './BaseInteractionClient.mjs';\nimport { TemporaryCacheKeys, NativeConstants, NativeExtensionMethod, ApiId } from '../utils/BrowserConstants.mjs';\nimport { NativeAuthError, isFatalNativeAuthError, createNativeAuthError } from '../error/NativeAuthError.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { SilentCacheClient } from './SilentCacheClient.mjs';\nimport { base64Decode } from '../encode/Base64Decode.mjs';\nimport { invalidPopTokenRequest, nativePromptNotSupported } from '../error/BrowserAuthErrorCodes.mjs';\nimport { userSwitch } from '../error/NativeAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nconst BrokerServerParamKeys = {\n BROKER_CLIENT_ID: \"brk_client_id\",\n BROKER_REDIRECT_URI: \"brk_redirect_uri\",\n};\nclass NativeInteractionClient extends BaseInteractionClient {\n constructor(config, browserStorage, browserCrypto, logger, eventHandler, navigationClient, apiId, performanceClient, provider, accountId, nativeStorageImpl, correlationId) {\n super(config, browserStorage, browserCrypto, logger, eventHandler, navigationClient, performanceClient, provider, correlationId);\n this.apiId = apiId;\n this.accountId = accountId;\n this.nativeMessageHandler = provider;\n this.nativeStorageManager = nativeStorageImpl;\n this.silentCacheClient = new SilentCacheClient(config, this.nativeStorageManager, browserCrypto, logger, eventHandler, navigationClient, performanceClient, provider, correlationId);\n }\n /**\n * Acquire token from native platform via browser extension\n * @param request\n */\n async acquireToken(request) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.NativeInteractionClientAcquireToken, request.correlationId);\n this.logger.trace(\"NativeInteractionClient - acquireToken called.\");\n // start the perf measurement\n const nativeATMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.NativeInteractionClientAcquireToken, request.correlationId);\n const reqTimestamp = TimeUtils.nowSeconds();\n // initialize native request\n const nativeRequest = await this.initializeNativeRequest(request);\n // check if the tokens can be retrieved from internal cache\n try {\n const result = await this.acquireTokensFromCache(this.accountId, nativeRequest);\n nativeATMeasurement.end({\n success: true,\n isNativeBroker: false,\n fromCache: true,\n });\n return result;\n }\n catch (e) {\n // continue with a native call for any and all errors\n this.logger.info(\"MSAL internal Cache does not contain tokens, proceed to make a native call\");\n }\n const { ...nativeTokenRequest } = nativeRequest;\n // fall back to native calls\n const messageBody = {\n method: NativeExtensionMethod.GetToken,\n request: nativeTokenRequest,\n };\n const response = await this.nativeMessageHandler.sendMessage(messageBody);\n const validatedResponse = this.validateNativeResponse(response);\n return this.handleNativeResponse(validatedResponse, nativeRequest, reqTimestamp)\n .then((result) => {\n nativeATMeasurement.end({\n success: true,\n isNativeBroker: true,\n requestId: result.requestId,\n });\n return result;\n })\n .catch((error) => {\n nativeATMeasurement.end({\n success: false,\n errorCode: error.errorCode,\n subErrorCode: error.subError,\n isNativeBroker: true,\n });\n throw error;\n });\n }\n /**\n * Creates silent flow request\n * @param request\n * @param cachedAccount\n * @returns CommonSilentFlowRequest\n */\n createSilentCacheRequest(request, cachedAccount) {\n return {\n authority: request.authority,\n correlationId: this.correlationId,\n scopes: ScopeSet.fromString(request.scope).asArray(),\n account: cachedAccount,\n forceRefresh: false,\n };\n }\n /**\n * Fetches the tokens from the cache if un-expired\n * @param nativeAccountId\n * @param request\n * @returns authenticationResult\n */\n async acquireTokensFromCache(nativeAccountId, request) {\n if (!nativeAccountId) {\n this.logger.warning(\"NativeInteractionClient:acquireTokensFromCache - No nativeAccountId provided\");\n throw createClientAuthError(ClientAuthErrorCodes.noAccountFound);\n }\n // fetch the account from browser cache\n const account = this.browserStorage.getBaseAccountInfo({\n nativeAccountId,\n });\n if (!account) {\n throw createClientAuthError(ClientAuthErrorCodes.noAccountFound);\n }\n // leverage silent flow for cached tokens retrieval\n try {\n const silentRequest = this.createSilentCacheRequest(request, account);\n const result = await this.silentCacheClient.acquireToken(silentRequest);\n const fullAccount = {\n ...account,\n idTokenClaims: result?.idTokenClaims,\n idToken: result?.idToken,\n };\n return {\n ...result,\n account: fullAccount,\n };\n }\n catch (e) {\n throw e;\n }\n }\n /**\n * Acquires a token from native platform then redirects to the redirectUri instead of returning the response\n * @param {RedirectRequest} request\n * @param {InProgressPerformanceEvent} rootMeasurement\n */\n async acquireTokenRedirect(request, rootMeasurement) {\n this.logger.trace(\"NativeInteractionClient - acquireTokenRedirect called.\");\n const { ...remainingParameters } = request;\n delete remainingParameters.onRedirectNavigate;\n const nativeRequest = await this.initializeNativeRequest(remainingParameters);\n const messageBody = {\n method: NativeExtensionMethod.GetToken,\n request: nativeRequest,\n };\n try {\n const response = await this.nativeMessageHandler.sendMessage(messageBody);\n this.validateNativeResponse(response);\n }\n catch (e) {\n // Only throw fatal errors here to allow application to fallback to regular redirect. Otherwise proceed and the error will be thrown in handleRedirectPromise\n if (e instanceof NativeAuthError && isFatalNativeAuthError(e)) {\n throw e;\n }\n }\n this.browserStorage.setTemporaryCache(TemporaryCacheKeys.NATIVE_REQUEST, JSON.stringify(nativeRequest), true);\n const navigationOptions = {\n apiId: ApiId.acquireTokenRedirect,\n timeout: this.config.system.redirectNavigationTimeout,\n noHistory: false,\n };\n const redirectUri = this.config.auth.navigateToLoginRequestUrl\n ? window.location.href\n : this.getRedirectUri(request.redirectUri);\n rootMeasurement.end({ success: true });\n await this.navigationClient.navigateExternal(redirectUri, navigationOptions); // Need to treat this as external to ensure handleRedirectPromise is run again\n }\n /**\n * If the previous page called native platform for a token using redirect APIs, send the same request again and return the response\n * @param performanceClient {IPerformanceClient?}\n * @param correlationId {string?} correlation identifier\n */\n async handleRedirectPromise(performanceClient, correlationId) {\n this.logger.trace(\"NativeInteractionClient - handleRedirectPromise called.\");\n if (!this.browserStorage.isInteractionInProgress(true)) {\n this.logger.info(\"handleRedirectPromise called but there is no interaction in progress, returning null.\");\n return null;\n }\n // remove prompt from the request to prevent WAM from prompting twice\n const cachedRequest = this.browserStorage.getCachedNativeRequest();\n if (!cachedRequest) {\n this.logger.verbose(\"NativeInteractionClient - handleRedirectPromise called but there is no cached request, returning null.\");\n if (performanceClient && correlationId) {\n performanceClient?.addFields({ errorCode: \"no_cached_request\" }, correlationId);\n }\n return null;\n }\n const { prompt, ...request } = cachedRequest;\n if (prompt) {\n this.logger.verbose(\"NativeInteractionClient - handleRedirectPromise called and prompt was included in the original request, removing prompt from cached request to prevent second interaction with native broker window.\");\n }\n this.browserStorage.removeItem(this.browserStorage.generateCacheKey(TemporaryCacheKeys.NATIVE_REQUEST));\n const messageBody = {\n method: NativeExtensionMethod.GetToken,\n request: request,\n };\n const reqTimestamp = TimeUtils.nowSeconds();\n try {\n this.logger.verbose(\"NativeInteractionClient - handleRedirectPromise sending message to native broker.\");\n const response = await this.nativeMessageHandler.sendMessage(messageBody);\n this.validateNativeResponse(response);\n const result = this.handleNativeResponse(response, request, reqTimestamp);\n this.browserStorage.setInteractionInProgress(false);\n return await result;\n }\n catch (e) {\n this.browserStorage.setInteractionInProgress(false);\n throw e;\n }\n }\n /**\n * Logout from native platform via browser extension\n * @param request\n */\n logout() {\n this.logger.trace(\"NativeInteractionClient - logout called.\");\n return Promise.reject(\"Logout not implemented yet\");\n }\n /**\n * Transform response from native platform into AuthenticationResult object which will be returned to the end user\n * @param response\n * @param request\n * @param reqTimestamp\n */\n async handleNativeResponse(response, request, reqTimestamp) {\n this.logger.trace(\"NativeInteractionClient - handleNativeResponse called.\");\n // generate identifiers\n const idTokenClaims = AuthToken.extractTokenClaims(response.id_token, base64Decode);\n const homeAccountIdentifier = this.createHomeAccountIdentifier(response, idTokenClaims);\n const cachedhomeAccountId = this.browserStorage.getAccountInfoFilteredBy({\n nativeAccountId: request.accountId,\n })?.homeAccountId;\n if (homeAccountIdentifier !== cachedhomeAccountId &&\n response.account.id !== request.accountId) {\n // User switch in native broker prompt is not supported. All users must first sign in through web flow to ensure server state is in sync\n throw createNativeAuthError(userSwitch);\n }\n // Get the preferred_cache domain for the given authority\n const authority = await this.getDiscoveredAuthority(request.authority);\n const baseAccount = buildAccountToCache(this.browserStorage, authority, homeAccountIdentifier, base64Decode, idTokenClaims, response.client_info, undefined, // environment\n idTokenClaims.tid, undefined, // auth code payload\n response.account.id, this.logger);\n // generate authenticationResult\n const result = await this.generateAuthenticationResult(response, request, idTokenClaims, baseAccount, authority.canonicalAuthority, reqTimestamp);\n // cache accounts and tokens in the appropriate storage\n this.cacheAccount(baseAccount);\n this.cacheNativeTokens(response, request, homeAccountIdentifier, idTokenClaims, response.access_token, result.tenantId, reqTimestamp);\n return result;\n }\n /**\n * creates an homeAccountIdentifier for the account\n * @param response\n * @param idTokenObj\n * @returns\n */\n createHomeAccountIdentifier(response, idTokenClaims) {\n // Save account in browser storage\n const homeAccountIdentifier = AccountEntity.generateHomeAccountId(response.client_info || Constants.EMPTY_STRING, AuthorityType.Default, this.logger, this.browserCrypto, idTokenClaims);\n return homeAccountIdentifier;\n }\n /**\n * Helper to generate scopes\n * @param response\n * @param request\n * @returns\n */\n generateScopes(response, request) {\n return response.scope\n ? ScopeSet.fromString(response.scope)\n : ScopeSet.fromString(request.scope);\n }\n /**\n * If PoP token is requesred, records the PoP token if returned from the WAM, else generates one in the browser\n * @param request\n * @param response\n */\n async generatePopAccessToken(response, request) {\n if (request.tokenType === AuthenticationScheme.POP &&\n request.signPopToken) {\n /**\n * This code prioritizes SHR returned from the native layer. In case of error/SHR not calculated from WAM and the AT\n * is still received, SHR is calculated locally\n */\n // Check if native layer returned an SHR token\n if (response.shr) {\n this.logger.trace(\"handleNativeServerResponse: SHR is enabled in native layer\");\n return response.shr;\n }\n // Generate SHR in msal js if WAM does not compute it when POP is enabled\n const popTokenGenerator = new PopTokenGenerator(this.browserCrypto);\n const shrParameters = {\n resourceRequestMethod: request.resourceRequestMethod,\n resourceRequestUri: request.resourceRequestUri,\n shrClaims: request.shrClaims,\n shrNonce: request.shrNonce,\n };\n /**\n * KeyID must be present in the native request from when the PoP key was generated in order for\n * PopTokenGenerator to query the full key for signing\n */\n if (!request.keyId) {\n throw createClientAuthError(ClientAuthErrorCodes.keyIdMissing);\n }\n return popTokenGenerator.signPopToken(response.access_token, request.keyId, shrParameters);\n }\n else {\n return response.access_token;\n }\n }\n /**\n * Generates authentication result\n * @param response\n * @param request\n * @param idTokenObj\n * @param accountEntity\n * @param authority\n * @param reqTimestamp\n * @returns\n */\n async generateAuthenticationResult(response, request, idTokenClaims, accountEntity, authority, reqTimestamp) {\n // Add Native Broker fields to Telemetry\n const mats = this.addTelemetryFromNativeResponse(response);\n // If scopes not returned in server response, use request scopes\n const responseScopes = response.scope\n ? ScopeSet.fromString(response.scope)\n : ScopeSet.fromString(request.scope);\n const accountProperties = response.account.properties || {};\n const uid = accountProperties[\"UID\"] ||\n idTokenClaims.oid ||\n idTokenClaims.sub ||\n Constants.EMPTY_STRING;\n const tid = accountProperties[\"TenantId\"] ||\n idTokenClaims.tid ||\n Constants.EMPTY_STRING;\n const accountInfo = updateAccountTenantProfileData(accountEntity.getAccountInfo(), undefined, // tenantProfile optional\n idTokenClaims, response.id_token);\n /**\n * In pairwise broker flows, this check prevents the broker's native account id\n * from being returned over the embedded app's account id.\n */\n if (accountInfo.nativeAccountId !== response.account.id) {\n accountInfo.nativeAccountId = response.account.id;\n }\n // generate PoP token as needed\n const responseAccessToken = await this.generatePopAccessToken(response, request);\n const tokenType = request.tokenType === AuthenticationScheme.POP\n ? AuthenticationScheme.POP\n : AuthenticationScheme.BEARER;\n const result = {\n authority: authority,\n uniqueId: uid,\n tenantId: tid,\n scopes: responseScopes.asArray(),\n account: accountInfo,\n idToken: response.id_token,\n idTokenClaims: idTokenClaims,\n accessToken: responseAccessToken,\n fromCache: mats ? this.isResponseFromCache(mats) : false,\n expiresOn: new Date(Number(reqTimestamp + response.expires_in) * 1000),\n tokenType: tokenType,\n correlationId: this.correlationId,\n state: response.state,\n fromNativeBroker: true,\n };\n return result;\n }\n /**\n * cache the account entity in browser storage\n * @param accountEntity\n */\n cacheAccount(accountEntity) {\n // Store the account info and hence `nativeAccountId` in browser cache\n this.browserStorage.setAccount(accountEntity);\n // Remove any existing cached tokens for this account in browser storage\n this.browserStorage.removeAccountContext(accountEntity).catch((e) => {\n this.logger.error(`Error occurred while removing account context from browser storage. ${e}`);\n });\n }\n /**\n * Stores the access_token and id_token in inmemory storage\n * @param response\n * @param request\n * @param homeAccountIdentifier\n * @param idTokenObj\n * @param responseAccessToken\n * @param tenantId\n * @param reqTimestamp\n */\n cacheNativeTokens(response, request, homeAccountIdentifier, idTokenClaims, responseAccessToken, tenantId, reqTimestamp) {\n const cachedIdToken = CacheHelpers.createIdTokenEntity(homeAccountIdentifier, request.authority, response.id_token || \"\", request.clientId, idTokenClaims.tid || \"\");\n // cache accessToken in inmemory storage\n const expiresIn = request.tokenType === AuthenticationScheme.POP\n ? Constants.SHR_NONCE_VALIDITY\n : (typeof response.expires_in === \"string\"\n ? parseInt(response.expires_in, 10)\n : response.expires_in) || 0;\n const tokenExpirationSeconds = reqTimestamp + expiresIn;\n const responseScopes = this.generateScopes(response, request);\n const cachedAccessToken = CacheHelpers.createAccessTokenEntity(homeAccountIdentifier, request.authority, responseAccessToken, request.clientId, idTokenClaims.tid || tenantId, responseScopes.printScopes(), tokenExpirationSeconds, 0, base64Decode, undefined, request.tokenType, undefined, request.keyId);\n const nativeCacheRecord = {\n idToken: cachedIdToken,\n accessToken: cachedAccessToken,\n };\n void this.nativeStorageManager.saveCacheRecord(nativeCacheRecord, request.storeInCache);\n }\n addTelemetryFromNativeResponse(response) {\n const mats = this.getMATSFromResponse(response);\n if (!mats) {\n return null;\n }\n this.performanceClient.addFields({\n extensionId: this.nativeMessageHandler.getExtensionId(),\n extensionVersion: this.nativeMessageHandler.getExtensionVersion(),\n matsBrokerVersion: mats.broker_version,\n matsAccountJoinOnStart: mats.account_join_on_start,\n matsAccountJoinOnEnd: mats.account_join_on_end,\n matsDeviceJoin: mats.device_join,\n matsPromptBehavior: mats.prompt_behavior,\n matsApiErrorCode: mats.api_error_code,\n matsUiVisible: mats.ui_visible,\n matsSilentCode: mats.silent_code,\n matsSilentBiSubCode: mats.silent_bi_sub_code,\n matsSilentMessage: mats.silent_message,\n matsSilentStatus: mats.silent_status,\n matsHttpStatus: mats.http_status,\n matsHttpEventCount: mats.http_event_count,\n }, this.correlationId);\n return mats;\n }\n /**\n * Validates native platform response before processing\n * @param response\n */\n validateNativeResponse(response) {\n if (response.hasOwnProperty(\"access_token\") &&\n response.hasOwnProperty(\"id_token\") &&\n response.hasOwnProperty(\"client_info\") &&\n response.hasOwnProperty(\"account\") &&\n response.hasOwnProperty(\"scope\") &&\n response.hasOwnProperty(\"expires_in\")) {\n return response;\n }\n else {\n throw createAuthError(AuthErrorCodes.unexpectedError, \"Response missing expected properties.\");\n }\n }\n /**\n * Gets MATS telemetry from native response\n * @param response\n * @returns\n */\n getMATSFromResponse(response) {\n if (response.properties.MATS) {\n try {\n return JSON.parse(response.properties.MATS);\n }\n catch (e) {\n this.logger.error(\"NativeInteractionClient - Error parsing MATS telemetry, returning null instead\");\n }\n }\n return null;\n }\n /**\n * Returns whether or not response came from native cache\n * @param response\n * @returns\n */\n isResponseFromCache(mats) {\n if (typeof mats.is_cached === \"undefined\") {\n this.logger.verbose(\"NativeInteractionClient - MATS telemetry does not contain field indicating if response was served from cache. Returning false.\");\n return false;\n }\n return !!mats.is_cached;\n }\n /**\n * Translates developer provided request object into NativeRequest object\n * @param request\n */\n async initializeNativeRequest(request) {\n this.logger.trace(\"NativeInteractionClient - initializeNativeRequest called\");\n const authority = request.authority || this.config.auth.authority;\n if (request.account) {\n // validate authority\n await this.getDiscoveredAuthority(authority, request.azureCloudOptions, request.account);\n }\n const canonicalAuthority = new UrlString(authority);\n canonicalAuthority.validateAsUri();\n // scopes are expected to be received by the native broker as \"scope\" and will be added to the request below. Other properties that should be dropped from the request to the native broker can be included in the object destructuring here.\n const { scopes, ...remainingProperties } = request;\n const scopeSet = new ScopeSet(scopes || []);\n scopeSet.appendScopes(OIDC_DEFAULT_SCOPES);\n const getPrompt = () => {\n // If request is silent, prompt is always none\n switch (this.apiId) {\n case ApiId.ssoSilent:\n case ApiId.acquireTokenSilent_silentFlow:\n this.logger.trace(\"initializeNativeRequest: silent request sets prompt to none\");\n return PromptValue.NONE;\n }\n // Prompt not provided, request may proceed and native broker decides if it needs to prompt\n if (!request.prompt) {\n this.logger.trace(\"initializeNativeRequest: prompt was not provided\");\n return undefined;\n }\n // If request is interactive, check if prompt provided is allowed to go directly to native broker\n switch (request.prompt) {\n case PromptValue.NONE:\n case PromptValue.CONSENT:\n case PromptValue.LOGIN:\n this.logger.trace(\"initializeNativeRequest: prompt is compatible with native flow\");\n return request.prompt;\n default:\n this.logger.trace(`initializeNativeRequest: prompt = ${request.prompt} is not compatible with native flow`);\n throw createBrowserAuthError(nativePromptNotSupported);\n }\n };\n const validatedRequest = {\n ...remainingProperties,\n accountId: this.accountId,\n clientId: this.config.auth.clientId,\n authority: canonicalAuthority.urlString,\n scope: scopeSet.printScopes(),\n redirectUri: this.getRedirectUri(request.redirectUri),\n prompt: getPrompt(),\n correlationId: this.correlationId,\n tokenType: request.authenticationScheme,\n windowTitleSubstring: document.title,\n extraParameters: {\n ...request.extraQueryParameters,\n ...request.tokenQueryParameters,\n },\n extendedExpiryToken: false,\n keyId: request.popKid,\n };\n // Check for PoP token requests: signPopToken should only be set to true if popKid is not set\n if (validatedRequest.signPopToken && !!request.popKid) {\n throw createBrowserAuthError(invalidPopTokenRequest);\n }\n this.handleExtraBrokerParams(validatedRequest);\n validatedRequest.extraParameters =\n validatedRequest.extraParameters || {};\n validatedRequest.extraParameters.telemetry =\n NativeConstants.MATS_TELEMETRY;\n if (request.authenticationScheme === AuthenticationScheme.POP) {\n // add POP request type\n const shrParameters = {\n resourceRequestUri: request.resourceRequestUri,\n resourceRequestMethod: request.resourceRequestMethod,\n shrClaims: request.shrClaims,\n shrNonce: request.shrNonce,\n };\n const popTokenGenerator = new PopTokenGenerator(this.browserCrypto);\n // generate reqCnf if not provided in the request\n let reqCnfData;\n if (!validatedRequest.keyId) {\n const generatedReqCnfData = await invokeAsync(popTokenGenerator.generateCnf.bind(popTokenGenerator), PerformanceEvents.PopTokenGenerateCnf, this.logger, this.performanceClient, request.correlationId)(shrParameters, this.logger);\n reqCnfData = generatedReqCnfData.reqCnfString;\n validatedRequest.keyId = generatedReqCnfData.kid;\n validatedRequest.signPopToken = true;\n }\n else {\n reqCnfData = this.browserCrypto.base64UrlEncode(JSON.stringify({ kid: validatedRequest.keyId }));\n validatedRequest.signPopToken = false;\n }\n // SPAs require whole string to be passed to broker\n validatedRequest.reqCnf = reqCnfData;\n }\n return validatedRequest;\n }\n /**\n * Handles extra broker request parameters\n * @param request {NativeTokenRequest}\n * @private\n */\n handleExtraBrokerParams(request) {\n if (!request.extraParameters) {\n return;\n }\n if (request.extraParameters.hasOwnProperty(BrokerServerParamKeys.BROKER_CLIENT_ID) &&\n request.extraParameters.hasOwnProperty(BrokerServerParamKeys.BROKER_REDIRECT_URI) &&\n request.extraParameters.hasOwnProperty(AADServerParamKeys.CLIENT_ID)) {\n const child_client_id = request.extraParameters[AADServerParamKeys.CLIENT_ID];\n const child_redirect_uri = request.redirectUri;\n const brk_redirect_uri = request.extraParameters[BrokerServerParamKeys.BROKER_REDIRECT_URI];\n request.extraParameters = {\n child_client_id,\n child_redirect_uri,\n };\n request.redirectUri = brk_redirect_uri;\n }\n }\n}\n\nexport { NativeInteractionClient };\n//# sourceMappingURL=NativeInteractionClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { NativeConstants, NativeExtensionMethod } from '../../utils/BrowserConstants.mjs';\nimport { PerformanceEvents, createAuthError, AuthErrorCodes, AuthenticationScheme } from '@azure/msal-common';\nimport { createNativeAuthError } from '../../error/NativeAuthError.mjs';\nimport { createBrowserAuthError } from '../../error/BrowserAuthError.mjs';\nimport { createNewGuid } from '../../crypto/BrowserCrypto.mjs';\nimport { nativeHandshakeTimeout, nativeExtensionNotInstalled } from '../../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass NativeMessageHandler {\n constructor(logger, handshakeTimeoutMs, performanceClient, extensionId) {\n this.logger = logger;\n this.handshakeTimeoutMs = handshakeTimeoutMs;\n this.extensionId = extensionId;\n this.resolvers = new Map(); // Used for non-handshake messages\n this.handshakeResolvers = new Map(); // Used for handshake messages\n this.messageChannel = new MessageChannel();\n this.windowListener = this.onWindowMessage.bind(this); // Window event callback doesn't have access to 'this' unless it's bound\n this.performanceClient = performanceClient;\n this.handshakeEvent = performanceClient.startMeasurement(PerformanceEvents.NativeMessageHandlerHandshake);\n }\n /**\n * Sends a given message to the extension and resolves with the extension response\n * @param body\n */\n async sendMessage(body) {\n this.logger.trace(\"NativeMessageHandler - sendMessage called.\");\n const req = {\n channel: NativeConstants.CHANNEL_ID,\n extensionId: this.extensionId,\n responseId: createNewGuid(),\n body: body,\n };\n this.logger.trace(\"NativeMessageHandler - Sending request to browser extension\");\n this.logger.tracePii(`NativeMessageHandler - Sending request to browser extension: ${JSON.stringify(req)}`);\n this.messageChannel.port1.postMessage(req);\n return new Promise((resolve, reject) => {\n this.resolvers.set(req.responseId, { resolve, reject });\n });\n }\n /**\n * Returns an instance of the MessageHandler that has successfully established a connection with an extension\n * @param {Logger} logger\n * @param {number} handshakeTimeoutMs\n * @param {IPerformanceClient} performanceClient\n * @param {ICrypto} crypto\n */\n static async createProvider(logger, handshakeTimeoutMs, performanceClient) {\n logger.trace(\"NativeMessageHandler - createProvider called.\");\n try {\n const preferredProvider = new NativeMessageHandler(logger, handshakeTimeoutMs, performanceClient, NativeConstants.PREFERRED_EXTENSION_ID);\n await preferredProvider.sendHandshakeRequest();\n return preferredProvider;\n }\n catch (e) {\n // If preferred extension fails for whatever reason, fallback to using any installed extension\n const backupProvider = new NativeMessageHandler(logger, handshakeTimeoutMs, performanceClient);\n await backupProvider.sendHandshakeRequest();\n return backupProvider;\n }\n }\n /**\n * Send handshake request helper.\n */\n async sendHandshakeRequest() {\n this.logger.trace(\"NativeMessageHandler - sendHandshakeRequest called.\");\n // Register this event listener before sending handshake\n window.addEventListener(\"message\", this.windowListener, false); // false is important, because content script message processing should work first\n const req = {\n channel: NativeConstants.CHANNEL_ID,\n extensionId: this.extensionId,\n responseId: createNewGuid(),\n body: {\n method: NativeExtensionMethod.HandshakeRequest,\n },\n };\n this.handshakeEvent.add({\n extensionId: this.extensionId,\n extensionHandshakeTimeoutMs: this.handshakeTimeoutMs,\n });\n this.messageChannel.port1.onmessage = (event) => {\n this.onChannelMessage(event);\n };\n window.postMessage(req, window.origin, [this.messageChannel.port2]);\n return new Promise((resolve, reject) => {\n this.handshakeResolvers.set(req.responseId, { resolve, reject });\n this.timeoutId = window.setTimeout(() => {\n /*\n * Throw an error if neither HandshakeResponse nor original Handshake request are received in a reasonable timeframe.\n * This typically suggests an event handler stopped propagation of the Handshake request but did not respond to it on the MessageChannel port\n */\n window.removeEventListener(\"message\", this.windowListener, false);\n this.messageChannel.port1.close();\n this.messageChannel.port2.close();\n this.handshakeEvent.end({\n extensionHandshakeTimedOut: true,\n success: false,\n });\n reject(createBrowserAuthError(nativeHandshakeTimeout));\n this.handshakeResolvers.delete(req.responseId);\n }, this.handshakeTimeoutMs); // Use a reasonable timeout in milliseconds here\n });\n }\n /**\n * Invoked when a message is posted to the window. If a handshake request is received it means the extension is not installed.\n * @param event\n */\n onWindowMessage(event) {\n this.logger.trace(\"NativeMessageHandler - onWindowMessage called\");\n // We only accept messages from ourselves\n if (event.source !== window) {\n return;\n }\n const request = event.data;\n if (!request.channel ||\n request.channel !== NativeConstants.CHANNEL_ID) {\n return;\n }\n if (request.extensionId && request.extensionId !== this.extensionId) {\n return;\n }\n if (request.body.method === NativeExtensionMethod.HandshakeRequest) {\n const handshakeResolver = this.handshakeResolvers.get(request.responseId);\n /*\n * Filter out responses with no matched resolvers sooner to keep channel ports open while waiting for\n * the proper response.\n */\n if (!handshakeResolver) {\n this.logger.trace(`NativeMessageHandler.onWindowMessage - resolver can't be found for request ${request.responseId}`);\n return;\n }\n // If we receive this message back it means no extension intercepted the request, meaning no extension supporting handshake protocol is installed\n this.logger.verbose(request.extensionId\n ? `Extension with id: ${request.extensionId} not installed`\n : \"No extension installed\");\n clearTimeout(this.timeoutId);\n this.messageChannel.port1.close();\n this.messageChannel.port2.close();\n window.removeEventListener(\"message\", this.windowListener, false);\n this.handshakeEvent.end({\n success: false,\n extensionInstalled: false,\n });\n handshakeResolver.reject(createBrowserAuthError(nativeExtensionNotInstalled));\n }\n }\n /**\n * Invoked when a message is received from the extension on the MessageChannel port\n * @param event\n */\n onChannelMessage(event) {\n this.logger.trace(\"NativeMessageHandler - onChannelMessage called.\");\n const request = event.data;\n const resolver = this.resolvers.get(request.responseId);\n const handshakeResolver = this.handshakeResolvers.get(request.responseId);\n try {\n const method = request.body.method;\n if (method === NativeExtensionMethod.Response) {\n if (!resolver) {\n return;\n }\n const response = request.body.response;\n this.logger.trace(\"NativeMessageHandler - Received response from browser extension\");\n this.logger.tracePii(`NativeMessageHandler - Received response from browser extension: ${JSON.stringify(response)}`);\n if (response.status !== \"Success\") {\n resolver.reject(createNativeAuthError(response.code, response.description, response.ext));\n }\n else if (response.result) {\n if (response.result[\"code\"] &&\n response.result[\"description\"]) {\n resolver.reject(createNativeAuthError(response.result[\"code\"], response.result[\"description\"], response.result[\"ext\"]));\n }\n else {\n resolver.resolve(response.result);\n }\n }\n else {\n throw createAuthError(AuthErrorCodes.unexpectedError, \"Event does not contain result.\");\n }\n this.resolvers.delete(request.responseId);\n }\n else if (method === NativeExtensionMethod.HandshakeResponse) {\n if (!handshakeResolver) {\n this.logger.trace(`NativeMessageHandler.onChannelMessage - resolver can't be found for request ${request.responseId}`);\n return;\n }\n clearTimeout(this.timeoutId); // Clear setTimeout\n window.removeEventListener(\"message\", this.windowListener, false); // Remove 'No extension' listener\n this.extensionId = request.extensionId;\n this.extensionVersion = request.body.version;\n this.logger.verbose(`NativeMessageHandler - Received HandshakeResponse from extension: ${this.extensionId}`);\n this.handshakeEvent.end({\n extensionInstalled: true,\n success: true,\n });\n handshakeResolver.resolve();\n this.handshakeResolvers.delete(request.responseId);\n }\n // Do nothing if method is not Response or HandshakeResponse\n }\n catch (err) {\n this.logger.error(\"Error parsing response from WAM Extension\");\n this.logger.errorPii(`Error parsing response from WAM Extension: ${err}`);\n this.logger.errorPii(`Unable to parse ${event}`);\n if (resolver) {\n resolver.reject(err);\n }\n else if (handshakeResolver) {\n handshakeResolver.reject(err);\n }\n }\n }\n /**\n * Returns the Id for the browser extension this handler is communicating with\n * @returns\n */\n getExtensionId() {\n return this.extensionId;\n }\n /**\n * Returns the version for the browser extension this handler is communicating with\n * @returns\n */\n getExtensionVersion() {\n return this.extensionVersion;\n }\n /**\n * Returns boolean indicating whether or not the request should attempt to use native broker\n * @param logger\n * @param config\n * @param nativeExtensionProvider\n * @param authenticationScheme\n */\n static isNativeAvailable(config, logger, nativeExtensionProvider, authenticationScheme) {\n logger.trace(\"isNativeAvailable called\");\n if (!config.system.allowNativeBroker) {\n logger.trace(\"isNativeAvailable: allowNativeBroker is not enabled, returning false\");\n // Developer disabled WAM\n return false;\n }\n if (!nativeExtensionProvider) {\n logger.trace(\"isNativeAvailable: WAM extension provider is not initialized, returning false\");\n // Extension is not available\n return false;\n }\n if (authenticationScheme) {\n switch (authenticationScheme) {\n case AuthenticationScheme.BEARER:\n case AuthenticationScheme.POP:\n logger.trace(\"isNativeAvailable: authenticationScheme is supported, returning true\");\n return true;\n default:\n logger.trace(\"isNativeAvailable: authenticationScheme is not supported, returning false\");\n return false;\n }\n }\n return true;\n }\n}\n\nexport { NativeMessageHandler };\n//# sourceMappingURL=NativeMessageHandler.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, ServerError, invokeAsync, CcsCredentialType } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { userCancelled } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Abstract class which defines operations for a browser interaction handling class.\n */\nclass InteractionHandler {\n constructor(authCodeModule, storageImpl, authCodeRequest, logger, performanceClient) {\n this.authModule = authCodeModule;\n this.browserStorage = storageImpl;\n this.authCodeRequest = authCodeRequest;\n this.logger = logger;\n this.performanceClient = performanceClient;\n }\n /**\n * Function to handle response parameters from hash.\n * @param locationHash\n */\n async handleCodeResponse(response, request) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.HandleCodeResponse, request.correlationId);\n let authCodeResponse;\n try {\n authCodeResponse = this.authModule.handleFragmentResponse(response, request.state);\n }\n catch (e) {\n if (e instanceof ServerError &&\n e.subError === userCancelled) {\n // Translate server error caused by user closing native prompt to corresponding first class MSAL error\n throw createBrowserAuthError(userCancelled);\n }\n else {\n throw e;\n }\n }\n return invokeAsync(this.handleCodeResponseFromServer.bind(this), PerformanceEvents.HandleCodeResponseFromServer, this.logger, this.performanceClient, request.correlationId)(authCodeResponse, request);\n }\n /**\n * Process auth code response from AAD\n * @param authCodeResponse\n * @param state\n * @param authority\n * @param networkModule\n * @returns\n */\n async handleCodeResponseFromServer(authCodeResponse, request, validateNonce = true) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.HandleCodeResponseFromServer, request.correlationId);\n this.logger.trace(\"InteractionHandler.handleCodeResponseFromServer called\");\n // Assign code to request\n this.authCodeRequest.code = authCodeResponse.code;\n // Check for new cloud instance\n if (authCodeResponse.cloud_instance_host_name) {\n await invokeAsync(this.authModule.updateAuthority.bind(this.authModule), PerformanceEvents.UpdateTokenEndpointAuthority, this.logger, this.performanceClient, request.correlationId)(authCodeResponse.cloud_instance_host_name, request.correlationId);\n }\n // Nonce validation not needed when redirect not involved (e.g. hybrid spa, renewing token via rt)\n if (validateNonce) {\n // TODO: Assigning \"response nonce\" to \"request nonce\" is confusing. Refactor the function doing validation to accept request nonce directly\n authCodeResponse.nonce = request.nonce || undefined;\n }\n authCodeResponse.state = request.state;\n // Add CCS parameters if available\n if (authCodeResponse.client_info) {\n this.authCodeRequest.clientInfo = authCodeResponse.client_info;\n }\n else {\n const ccsCred = this.createCcsCredentials(request);\n if (ccsCred) {\n this.authCodeRequest.ccsCredential = ccsCred;\n }\n }\n // Acquire token with retrieved code.\n const tokenResponse = (await invokeAsync(this.authModule.acquireToken.bind(this.authModule), PerformanceEvents.AuthClientAcquireToken, this.logger, this.performanceClient, request.correlationId)(this.authCodeRequest, authCodeResponse));\n return tokenResponse;\n }\n /**\n * Build ccs creds if available\n */\n createCcsCredentials(request) {\n if (request.account) {\n return {\n credential: request.account.homeAccountId,\n type: CcsCredentialType.HOME_ACCOUNT_ID,\n };\n }\n else if (request.loginHint) {\n return {\n credential: request.loginHint,\n type: CcsCredentialType.UPN,\n };\n }\n return null;\n }\n}\n\nexport { InteractionHandler };\n//# sourceMappingURL=InteractionHandler.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { UrlUtils } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { extractBrowserRequestState } from '../utils/BrowserProtocolUtils.mjs';\nimport { hashEmptyError, hashDoesNotContainKnownProperties, noStateInHash, unableToParseState, stateInteractionTypeMismatch } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nfunction deserializeResponse(responseString, responseLocation, logger) {\n // Deserialize hash fragment response parameters.\n const serverParams = UrlUtils.getDeserializedResponse(responseString);\n if (!serverParams) {\n if (!UrlUtils.stripLeadingHashOrQuery(responseString)) {\n // Hash or Query string is empty\n logger.error(`The request has returned to the redirectUri but a ${responseLocation} is not present. It's likely that the ${responseLocation} has been removed or the page has been redirected by code running on the redirectUri page.`);\n throw createBrowserAuthError(hashEmptyError);\n }\n else {\n logger.error(`A ${responseLocation} is present in the iframe but it does not contain known properties. It's likely that the ${responseLocation} has been replaced by code running on the redirectUri page.`);\n logger.errorPii(`The ${responseLocation} detected is: ${responseString}`);\n throw createBrowserAuthError(hashDoesNotContainKnownProperties);\n }\n }\n return serverParams;\n}\n/**\n * Returns the interaction type that the response object belongs to\n */\nfunction validateInteractionType(response, browserCrypto, interactionType) {\n if (!response.state) {\n throw createBrowserAuthError(noStateInHash);\n }\n const platformStateObj = extractBrowserRequestState(browserCrypto, response.state);\n if (!platformStateObj) {\n throw createBrowserAuthError(unableToParseState);\n }\n if (platformStateObj.interactionType !== interactionType) {\n throw createBrowserAuthError(stateInteractionTypeMismatch);\n }\n}\n\nexport { deserializeResponse, validateInteractionType };\n//# sourceMappingURL=ResponseHandler.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { OIDC_DEFAULT_SCOPES, invokeAsync, PerformanceEvents, invoke, ThrottlingUtils, ProtocolUtils, AuthError, ProtocolMode, UrlString, ServerResponseType } from '@azure/msal-common';\nimport { StandardInteractionClient } from './StandardInteractionClient.mjs';\nimport { EventType } from '../event/EventType.mjs';\nimport { ApiId, InteractionType, BrowserConstants } from '../utils/BrowserConstants.mjs';\nimport { preconnect, getCurrentUri } from '../utils/BrowserUtils.mjs';\nimport { NativeInteractionClient } from './NativeInteractionClient.mjs';\nimport { NativeMessageHandler } from '../broker/nativeBroker/NativeMessageHandler.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { InteractionHandler } from '../interaction_handler/InteractionHandler.mjs';\nimport { deserializeResponse } from '../response/ResponseHandler.mjs';\nimport { nativeConnectionNotEstablished, emptyNavigateUri, userCancelled, emptyWindowError, popupWindowError } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass PopupClient extends StandardInteractionClient {\n constructor(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, performanceClient, nativeStorageImpl, nativeMessageHandler, correlationId) {\n super(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, performanceClient, nativeMessageHandler, correlationId);\n // Properly sets this reference for the unload event.\n this.unloadWindow = this.unloadWindow.bind(this);\n this.nativeStorage = nativeStorageImpl;\n }\n /**\n * Acquires tokens by opening a popup window to the /authorize endpoint of the authority\n * @param request\n */\n acquireToken(request) {\n try {\n const popupName = this.generatePopupName(request.scopes || OIDC_DEFAULT_SCOPES, request.authority || this.config.auth.authority);\n const popupWindowAttributes = request.popupWindowAttributes || {};\n // asyncPopups flag is true. Acquires token without first opening popup. Popup will be opened later asynchronously.\n if (this.config.system.asyncPopups) {\n this.logger.verbose(\"asyncPopups set to true, acquiring token\");\n // Passes on popup position and dimensions if in request\n return this.acquireTokenPopupAsync(request, popupName, popupWindowAttributes);\n }\n else {\n // asyncPopups flag is set to false. Opens popup before acquiring token.\n this.logger.verbose(\"asyncPopup set to false, opening popup before acquiring token\");\n const popup = this.openSizedPopup(\"about:blank\", popupName, popupWindowAttributes);\n return this.acquireTokenPopupAsync(request, popupName, popupWindowAttributes, popup);\n }\n }\n catch (e) {\n return Promise.reject(e);\n }\n }\n /**\n * Clears local cache for the current user then opens a popup window prompting the user to sign-out of the server\n * @param logoutRequest\n */\n logout(logoutRequest) {\n try {\n this.logger.verbose(\"logoutPopup called\");\n const validLogoutRequest = this.initializeLogoutRequest(logoutRequest);\n const popupName = this.generateLogoutPopupName(validLogoutRequest);\n const authority = logoutRequest && logoutRequest.authority;\n const mainWindowRedirectUri = logoutRequest && logoutRequest.mainWindowRedirectUri;\n const popupWindowAttributes = logoutRequest?.popupWindowAttributes || {};\n // asyncPopups flag is true. Acquires token without first opening popup. Popup will be opened later asynchronously.\n if (this.config.system.asyncPopups) {\n this.logger.verbose(\"asyncPopups set to true\");\n // Passes on popup position and dimensions if in request\n return this.logoutPopupAsync(validLogoutRequest, popupName, popupWindowAttributes, authority, undefined, mainWindowRedirectUri);\n }\n else {\n // asyncPopups flag is set to false. Opens popup before logging out.\n this.logger.verbose(\"asyncPopup set to false, opening popup\");\n const popup = this.openSizedPopup(\"about:blank\", popupName, popupWindowAttributes);\n return this.logoutPopupAsync(validLogoutRequest, popupName, popupWindowAttributes, authority, popup, mainWindowRedirectUri);\n }\n }\n catch (e) {\n // Since this function is synchronous we need to reject\n return Promise.reject(e);\n }\n }\n /**\n * Helper which obtains an access_token for your API via opening a popup window in the user's browser\n * @param validRequest\n * @param popupName\n * @param popup\n * @param popupWindowAttributes\n *\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n async acquireTokenPopupAsync(request, popupName, popupWindowAttributes, popup) {\n this.logger.verbose(\"acquireTokenPopupAsync called\");\n const serverTelemetryManager = this.initializeServerTelemetryManager(ApiId.acquireTokenPopup);\n const validRequest = await invokeAsync(this.initializeAuthorizationRequest.bind(this), PerformanceEvents.StandardInteractionClientInitializeAuthorizationRequest, this.logger, this.performanceClient, this.correlationId)(request, InteractionType.Popup);\n preconnect(validRequest.authority);\n try {\n // Create auth code request and generate PKCE params\n const authCodeRequest = await invokeAsync(this.initializeAuthorizationCodeRequest.bind(this), PerformanceEvents.StandardInteractionClientInitializeAuthorizationCodeRequest, this.logger, this.performanceClient, this.correlationId)(validRequest);\n // Initialize the client\n const authClient = await invokeAsync(this.createAuthCodeClient.bind(this), PerformanceEvents.StandardInteractionClientCreateAuthCodeClient, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, validRequest.authority, validRequest.azureCloudOptions, validRequest.account);\n const isNativeBroker = NativeMessageHandler.isNativeAvailable(this.config, this.logger, this.nativeMessageHandler, request.authenticationScheme);\n // Start measurement for server calls with native brokering enabled\n let fetchNativeAccountIdMeasurement;\n if (isNativeBroker) {\n fetchNativeAccountIdMeasurement =\n this.performanceClient.startMeasurement(PerformanceEvents.FetchAccountIdWithNativeBroker, request.correlationId);\n }\n // Create acquire token url.\n const navigateUrl = await authClient.getAuthCodeUrl({\n ...validRequest,\n nativeBroker: isNativeBroker,\n });\n // Create popup interaction handler.\n const interactionHandler = new InteractionHandler(authClient, this.browserStorage, authCodeRequest, this.logger, this.performanceClient);\n // Show the UI once the url has been created. Get the window handle for the popup.\n const popupParameters = {\n popup,\n popupName,\n popupWindowAttributes,\n };\n const popupWindow = this.initiateAuthRequest(navigateUrl, popupParameters);\n this.eventHandler.emitEvent(EventType.POPUP_OPENED, InteractionType.Popup, { popupWindow }, null);\n // Monitor the window for the hash. Return the string value and close the popup when the hash is received. Default timeout is 60 seconds.\n const responseString = await this.monitorPopupForHash(popupWindow);\n const serverParams = invoke(deserializeResponse, PerformanceEvents.DeserializeResponse, this.logger, this.performanceClient, this.correlationId)(responseString, this.config.auth.OIDCOptions.serverResponseType, this.logger);\n // Remove throttle if it exists\n ThrottlingUtils.removeThrottle(this.browserStorage, this.config.auth.clientId, authCodeRequest);\n if (serverParams.accountId) {\n this.logger.verbose(\"Account id found in hash, calling WAM for token\");\n // end measurement for server call with native brokering enabled\n if (fetchNativeAccountIdMeasurement) {\n fetchNativeAccountIdMeasurement.end({\n success: true,\n isNativeBroker: true,\n });\n }\n if (!this.nativeMessageHandler) {\n throw createBrowserAuthError(nativeConnectionNotEstablished);\n }\n const nativeInteractionClient = new NativeInteractionClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, ApiId.acquireTokenPopup, this.performanceClient, this.nativeMessageHandler, serverParams.accountId, this.nativeStorage, validRequest.correlationId);\n const { userRequestState } = ProtocolUtils.parseRequestState(this.browserCrypto, validRequest.state);\n return await nativeInteractionClient.acquireToken({\n ...validRequest,\n state: userRequestState,\n prompt: undefined, // Server should handle the prompt, ideally native broker can do this part silently\n });\n }\n // Handle response from hash string.\n const result = await interactionHandler.handleCodeResponse(serverParams, validRequest);\n return result;\n }\n catch (e) {\n if (popup) {\n // Close the synchronous popup if an error is thrown before the window unload event is registered\n popup.close();\n }\n if (e instanceof AuthError) {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n }\n throw e;\n }\n }\n /**\n *\n * @param validRequest\n * @param popupName\n * @param requestAuthority\n * @param popup\n * @param mainWindowRedirectUri\n * @param popupWindowAttributes\n */\n async logoutPopupAsync(validRequest, popupName, popupWindowAttributes, requestAuthority, popup, mainWindowRedirectUri) {\n this.logger.verbose(\"logoutPopupAsync called\");\n this.eventHandler.emitEvent(EventType.LOGOUT_START, InteractionType.Popup, validRequest);\n const serverTelemetryManager = this.initializeServerTelemetryManager(ApiId.logoutPopup);\n try {\n // Clear cache on logout\n await this.clearCacheOnLogout(validRequest.account);\n // Initialize the client\n const authClient = await invokeAsync(this.createAuthCodeClient.bind(this), PerformanceEvents.StandardInteractionClientCreateAuthCodeClient, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, requestAuthority, undefined, // AzureCloudOptions\n validRequest.account || undefined);\n try {\n authClient.authority.endSessionEndpoint;\n }\n catch {\n if (validRequest.account?.homeAccountId &&\n validRequest.postLogoutRedirectUri &&\n authClient.authority.protocolMode === ProtocolMode.OIDC) {\n void this.browserStorage.removeAccount(validRequest.account?.homeAccountId);\n this.eventHandler.emitEvent(EventType.LOGOUT_SUCCESS, InteractionType.Popup, validRequest);\n if (mainWindowRedirectUri) {\n const navigationOptions = {\n apiId: ApiId.logoutPopup,\n timeout: this.config.system.redirectNavigationTimeout,\n noHistory: false,\n };\n const absoluteUrl = UrlString.getAbsoluteUrl(mainWindowRedirectUri, getCurrentUri());\n await this.navigationClient.navigateInternal(absoluteUrl, navigationOptions);\n }\n if (popup) {\n popup.close();\n }\n return;\n }\n }\n // Create logout string and navigate user window to logout.\n const logoutUri = authClient.getLogoutUri(validRequest);\n this.eventHandler.emitEvent(EventType.LOGOUT_SUCCESS, InteractionType.Popup, validRequest);\n // Open the popup window to requestUrl.\n const popupWindow = this.openPopup(logoutUri, {\n popupName,\n popupWindowAttributes,\n popup,\n });\n this.eventHandler.emitEvent(EventType.POPUP_OPENED, InteractionType.Popup, { popupWindow }, null);\n await this.monitorPopupForHash(popupWindow).catch(() => {\n // Swallow any errors related to monitoring the window. Server logout is best effort\n });\n if (mainWindowRedirectUri) {\n const navigationOptions = {\n apiId: ApiId.logoutPopup,\n timeout: this.config.system.redirectNavigationTimeout,\n noHistory: false,\n };\n const absoluteUrl = UrlString.getAbsoluteUrl(mainWindowRedirectUri, getCurrentUri());\n this.logger.verbose(\"Redirecting main window to url specified in the request\");\n this.logger.verbosePii(`Redirecting main window to: ${absoluteUrl}`);\n await this.navigationClient.navigateInternal(absoluteUrl, navigationOptions);\n }\n else {\n this.logger.verbose(\"No main window navigation requested\");\n }\n }\n catch (e) {\n if (popup) {\n // Close the synchronous popup if an error is thrown before the window unload event is registered\n popup.close();\n }\n if (e instanceof AuthError) {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n }\n this.browserStorage.setInteractionInProgress(false);\n this.eventHandler.emitEvent(EventType.LOGOUT_FAILURE, InteractionType.Popup, null, e);\n this.eventHandler.emitEvent(EventType.LOGOUT_END, InteractionType.Popup);\n throw e;\n }\n this.eventHandler.emitEvent(EventType.LOGOUT_END, InteractionType.Popup);\n }\n /**\n * Opens a popup window with given request Url.\n * @param requestUrl\n */\n initiateAuthRequest(requestUrl, params) {\n // Check that request url is not empty.\n if (requestUrl) {\n this.logger.infoPii(`Navigate to: ${requestUrl}`);\n // Open the popup window to requestUrl.\n return this.openPopup(requestUrl, params);\n }\n else {\n // Throw error if request URL is empty.\n this.logger.error(\"Navigate url is empty\");\n throw createBrowserAuthError(emptyNavigateUri);\n }\n }\n /**\n * Monitors a window until it loads a url with the same origin.\n * @param popupWindow - window that is being monitored\n * @param timeout - timeout for processing hash once popup is redirected back to application\n */\n monitorPopupForHash(popupWindow) {\n return new Promise((resolve, reject) => {\n this.logger.verbose(\"PopupHandler.monitorPopupForHash - polling started\");\n const intervalId = setInterval(() => {\n // Window is closed\n if (popupWindow.closed) {\n this.logger.error(\"PopupHandler.monitorPopupForHash - window closed\");\n clearInterval(intervalId);\n reject(createBrowserAuthError(userCancelled));\n return;\n }\n let href = \"\";\n try {\n /*\n * Will throw if cross origin,\n * which should be caught and ignored\n * since we need the interval to keep running while on STS UI.\n */\n href = popupWindow.location.href;\n }\n catch (e) { }\n // Don't process blank pages or cross domain\n if (!href || href === \"about:blank\") {\n return;\n }\n clearInterval(intervalId);\n let responseString = \"\";\n const responseType = this.config.auth.OIDCOptions.serverResponseType;\n if (popupWindow) {\n if (responseType === ServerResponseType.QUERY) {\n responseString = popupWindow.location.search;\n }\n else {\n responseString = popupWindow.location.hash;\n }\n }\n this.logger.verbose(\"PopupHandler.monitorPopupForHash - popup window is on same origin as caller\");\n resolve(responseString);\n }, this.config.system.pollIntervalMilliseconds);\n }).finally(() => {\n this.cleanPopup(popupWindow);\n });\n }\n /**\n * @hidden\n *\n * Configures popup window for login.\n *\n * @param urlNavigate\n * @param title\n * @param popUpWidth\n * @param popUpHeight\n * @param popupWindowAttributes\n * @ignore\n * @hidden\n */\n openPopup(urlNavigate, popupParams) {\n try {\n let popupWindow;\n // Popup window passed in, setting url to navigate to\n if (popupParams.popup) {\n popupWindow = popupParams.popup;\n this.logger.verbosePii(`Navigating popup window to: ${urlNavigate}`);\n popupWindow.location.assign(urlNavigate);\n }\n else if (typeof popupParams.popup === \"undefined\") {\n // Popup will be undefined if it was not passed in\n this.logger.verbosePii(`Opening popup window to: ${urlNavigate}`);\n popupWindow = this.openSizedPopup(urlNavigate, popupParams.popupName, popupParams.popupWindowAttributes);\n }\n // Popup will be null if popups are blocked\n if (!popupWindow) {\n throw createBrowserAuthError(emptyWindowError);\n }\n if (popupWindow.focus) {\n popupWindow.focus();\n }\n this.currentWindow = popupWindow;\n window.addEventListener(\"beforeunload\", this.unloadWindow);\n return popupWindow;\n }\n catch (e) {\n this.logger.error(\"error opening popup \" + e.message);\n this.browserStorage.setInteractionInProgress(false);\n throw createBrowserAuthError(popupWindowError);\n }\n }\n /**\n * Helper function to set popup window dimensions and position\n * @param urlNavigate\n * @param popupName\n * @param popupWindowAttributes\n * @returns\n */\n openSizedPopup(urlNavigate, popupName, popupWindowAttributes) {\n /**\n * adding winLeft and winTop to account for dual monitor\n * using screenLeft and screenTop for IE8 and earlier\n */\n const winLeft = window.screenLeft ? window.screenLeft : window.screenX;\n const winTop = window.screenTop ? window.screenTop : window.screenY;\n /**\n * window.innerWidth displays browser window\"s height and width excluding toolbars\n * using document.documentElement.clientWidth for IE8 and earlier\n */\n const winWidth = window.innerWidth ||\n document.documentElement.clientWidth ||\n document.body.clientWidth;\n const winHeight = window.innerHeight ||\n document.documentElement.clientHeight ||\n document.body.clientHeight;\n let width = popupWindowAttributes.popupSize?.width;\n let height = popupWindowAttributes.popupSize?.height;\n let top = popupWindowAttributes.popupPosition?.top;\n let left = popupWindowAttributes.popupPosition?.left;\n if (!width || width < 0 || width > winWidth) {\n this.logger.verbose(\"Default popup window width used. Window width not configured or invalid.\");\n width = BrowserConstants.POPUP_WIDTH;\n }\n if (!height || height < 0 || height > winHeight) {\n this.logger.verbose(\"Default popup window height used. Window height not configured or invalid.\");\n height = BrowserConstants.POPUP_HEIGHT;\n }\n if (!top || top < 0 || top > winHeight) {\n this.logger.verbose(\"Default popup window top position used. Window top not configured or invalid.\");\n top = Math.max(0, winHeight / 2 - BrowserConstants.POPUP_HEIGHT / 2 + winTop);\n }\n if (!left || left < 0 || left > winWidth) {\n this.logger.verbose(\"Default popup window left position used. Window left not configured or invalid.\");\n left = Math.max(0, winWidth / 2 - BrowserConstants.POPUP_WIDTH / 2 + winLeft);\n }\n return window.open(urlNavigate, popupName, `width=${width}, height=${height}, top=${top}, left=${left}, scrollbars=yes`);\n }\n /**\n * Event callback to unload main window.\n */\n unloadWindow(e) {\n this.browserStorage.cleanRequestByInteractionType(InteractionType.Popup);\n if (this.currentWindow) {\n this.currentWindow.close();\n }\n // Guarantees browser unload will happen, so no other errors will be thrown.\n e.preventDefault();\n }\n /**\n * Closes popup, removes any state vars created during popup calls.\n * @param popupWindow\n */\n cleanPopup(popupWindow) {\n if (popupWindow) {\n // Close window.\n popupWindow.close();\n }\n // Remove window unload function\n window.removeEventListener(\"beforeunload\", this.unloadWindow);\n // Interaction is completed - remove interaction status.\n this.browserStorage.setInteractionInProgress(false);\n }\n /**\n * Generates the name for the popup based on the client id and request\n * @param clientId\n * @param request\n */\n generatePopupName(scopes, authority) {\n return `${BrowserConstants.POPUP_NAME_PREFIX}.${this.config.auth.clientId}.${scopes.join(\"-\")}.${authority}.${this.correlationId}`;\n }\n /**\n * Generates the name for the popup based on the client id and request for logouts\n * @param clientId\n * @param request\n */\n generateLogoutPopupName(request) {\n const homeAccountId = request.account && request.account.homeAccountId;\n return `${BrowserConstants.POPUP_NAME_PREFIX}.${this.config.auth.clientId}.${homeAccountId}.${this.correlationId}`;\n }\n}\n\nexport { PopupClient };\n//# sourceMappingURL=PopupClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { createClientAuthError, ClientAuthErrorCodes, ServerError, invokeAsync, PerformanceEvents } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { TemporaryCacheKeys, ApiId } from '../utils/BrowserConstants.mjs';\nimport { emptyNavigateUri, userCancelled } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass RedirectHandler {\n constructor(authCodeModule, storageImpl, authCodeRequest, logger, performanceClient) {\n this.authModule = authCodeModule;\n this.browserStorage = storageImpl;\n this.authCodeRequest = authCodeRequest;\n this.logger = logger;\n this.performanceClient = performanceClient;\n }\n /**\n * Redirects window to given URL.\n * @param urlNavigate\n */\n async initiateAuthRequest(requestUrl, params) {\n this.logger.verbose(\"RedirectHandler.initiateAuthRequest called\");\n // Navigate if valid URL\n if (requestUrl) {\n // Cache start page, returns to this page after redirectUri if navigateToLoginRequestUrl is true\n if (params.redirectStartPage) {\n this.logger.verbose(\"RedirectHandler.initiateAuthRequest: redirectStartPage set, caching start page\");\n this.browserStorage.setTemporaryCache(TemporaryCacheKeys.ORIGIN_URI, params.redirectStartPage, true);\n }\n // Set interaction status in the library.\n this.browserStorage.setTemporaryCache(TemporaryCacheKeys.CORRELATION_ID, this.authCodeRequest.correlationId, true);\n this.browserStorage.cacheCodeRequest(this.authCodeRequest);\n this.logger.infoPii(`RedirectHandler.initiateAuthRequest: Navigate to: ${requestUrl}`);\n const navigationOptions = {\n apiId: ApiId.acquireTokenRedirect,\n timeout: params.redirectTimeout,\n noHistory: false,\n };\n // If onRedirectNavigate is implemented, invoke it and provide requestUrl\n if (typeof params.onRedirectNavigate === \"function\") {\n this.logger.verbose(\"RedirectHandler.initiateAuthRequest: Invoking onRedirectNavigate callback\");\n const navigate = params.onRedirectNavigate(requestUrl);\n // Returning false from onRedirectNavigate will stop navigation\n if (navigate !== false) {\n this.logger.verbose(\"RedirectHandler.initiateAuthRequest: onRedirectNavigate did not return false, navigating\");\n await params.navigationClient.navigateExternal(requestUrl, navigationOptions);\n return;\n }\n else {\n this.logger.verbose(\"RedirectHandler.initiateAuthRequest: onRedirectNavigate returned false, stopping navigation\");\n return;\n }\n }\n else {\n // Navigate window to request URL\n this.logger.verbose(\"RedirectHandler.initiateAuthRequest: Navigating window to navigate url\");\n await params.navigationClient.navigateExternal(requestUrl, navigationOptions);\n return;\n }\n }\n else {\n // Throw error if request URL is empty.\n this.logger.info(\"RedirectHandler.initiateAuthRequest: Navigate url is empty\");\n throw createBrowserAuthError(emptyNavigateUri);\n }\n }\n /**\n * Handle authorization code response in the window.\n * @param hash\n */\n async handleCodeResponse(response, state) {\n this.logger.verbose(\"RedirectHandler.handleCodeResponse called\");\n // Interaction is completed - remove interaction status.\n this.browserStorage.setInteractionInProgress(false);\n // Handle code response.\n const stateKey = this.browserStorage.generateStateKey(state);\n const requestState = this.browserStorage.getTemporaryCache(stateKey);\n if (!requestState) {\n throw createClientAuthError(ClientAuthErrorCodes.stateNotFound, \"Cached State\");\n }\n let authCodeResponse;\n try {\n authCodeResponse = this.authModule.handleFragmentResponse(response, requestState);\n }\n catch (e) {\n if (e instanceof ServerError &&\n e.subError === userCancelled) {\n // Translate server error caused by user closing native prompt to corresponding first class MSAL error\n throw createBrowserAuthError(userCancelled);\n }\n else {\n throw e;\n }\n }\n // Get cached items\n const nonceKey = this.browserStorage.generateNonceKey(requestState);\n const cachedNonce = this.browserStorage.getTemporaryCache(nonceKey);\n // Assign code to request\n this.authCodeRequest.code = authCodeResponse.code;\n // Check for new cloud instance\n if (authCodeResponse.cloud_instance_host_name) {\n await invokeAsync(this.authModule.updateAuthority.bind(this.authModule), PerformanceEvents.UpdateTokenEndpointAuthority, this.logger, this.performanceClient, this.authCodeRequest.correlationId)(authCodeResponse.cloud_instance_host_name, this.authCodeRequest.correlationId);\n }\n authCodeResponse.nonce = cachedNonce || undefined;\n authCodeResponse.state = requestState;\n // Add CCS parameters if available\n if (authCodeResponse.client_info) {\n this.authCodeRequest.clientInfo = authCodeResponse.client_info;\n }\n else {\n const cachedCcsCred = this.checkCcsCredentials();\n if (cachedCcsCred) {\n this.authCodeRequest.ccsCredential = cachedCcsCred;\n }\n }\n // Acquire token with retrieved code.\n const tokenResponse = (await this.authModule.acquireToken(this.authCodeRequest, authCodeResponse));\n this.browserStorage.cleanRequestByState(state);\n return tokenResponse;\n }\n /**\n * Looks up ccs creds in the cache\n */\n checkCcsCredentials() {\n // Look up ccs credential in temp cache\n const cachedCcsCred = this.browserStorage.getTemporaryCache(TemporaryCacheKeys.CCS_CREDENTIAL, true);\n if (cachedCcsCred) {\n try {\n return JSON.parse(cachedCcsCred);\n }\n catch (e) {\n this.authModule.logger.error(\"Cache credential could not be parsed\");\n this.authModule.logger.errorPii(`Cache credential could not be parsed: ${cachedCcsCred}`);\n }\n }\n return null;\n }\n}\n\nexport { RedirectHandler };\n//# sourceMappingURL=RedirectHandler.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { invokeAsync, PerformanceEvents, AuthError, Constants, UrlString, UrlUtils, ProtocolUtils, ThrottlingUtils, ProtocolMode, ServerResponseType } from '@azure/msal-common';\nimport { StandardInteractionClient } from './StandardInteractionClient.mjs';\nimport { InteractionType, ApiId, TemporaryCacheKeys } from '../utils/BrowserConstants.mjs';\nimport { RedirectHandler } from '../interaction_handler/RedirectHandler.mjs';\nimport { replaceHash, isInIframe, getHomepage, clearHash, getCurrentUri } from '../utils/BrowserUtils.mjs';\nimport { EventType } from '../event/EventType.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { NativeInteractionClient } from './NativeInteractionClient.mjs';\nimport { NativeMessageHandler } from '../broker/nativeBroker/NativeMessageHandler.mjs';\nimport { validateInteractionType } from '../response/ResponseHandler.mjs';\nimport { noStateInHash, nativeConnectionNotEstablished, noCachedAuthorityError } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass RedirectClient extends StandardInteractionClient {\n constructor(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, performanceClient, nativeStorageImpl, nativeMessageHandler, correlationId) {\n super(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, performanceClient, nativeMessageHandler, correlationId);\n this.nativeStorage = nativeStorageImpl;\n }\n /**\n * Redirects the page to the /authorize endpoint of the IDP\n * @param request\n */\n async acquireToken(request) {\n const validRequest = await invokeAsync(this.initializeAuthorizationRequest.bind(this), PerformanceEvents.StandardInteractionClientInitializeAuthorizationRequest, this.logger, this.performanceClient, this.correlationId)(request, InteractionType.Redirect);\n this.browserStorage.updateCacheEntries(validRequest.state, validRequest.nonce, validRequest.authority, validRequest.loginHint || \"\", validRequest.account || null);\n const serverTelemetryManager = this.initializeServerTelemetryManager(ApiId.acquireTokenRedirect);\n const handleBackButton = (event) => {\n // Clear temporary cache if the back button is clicked during the redirect flow.\n if (event.persisted) {\n this.logger.verbose(\"Page was restored from back/forward cache. Clearing temporary cache.\");\n this.browserStorage.cleanRequestByState(validRequest.state);\n this.eventHandler.emitEvent(EventType.RESTORE_FROM_BFCACHE, InteractionType.Redirect);\n }\n };\n try {\n // Create auth code request and generate PKCE params\n const authCodeRequest = await invokeAsync(this.initializeAuthorizationCodeRequest.bind(this), PerformanceEvents.StandardInteractionClientInitializeAuthorizationCodeRequest, this.logger, this.performanceClient, this.correlationId)(validRequest);\n // Initialize the client\n const authClient = await invokeAsync(this.createAuthCodeClient.bind(this), PerformanceEvents.StandardInteractionClientCreateAuthCodeClient, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, validRequest.authority, validRequest.azureCloudOptions, validRequest.account);\n // Create redirect interaction handler.\n const interactionHandler = new RedirectHandler(authClient, this.browserStorage, authCodeRequest, this.logger, this.performanceClient);\n // Create acquire token url.\n const navigateUrl = await authClient.getAuthCodeUrl({\n ...validRequest,\n nativeBroker: NativeMessageHandler.isNativeAvailable(this.config, this.logger, this.nativeMessageHandler, request.authenticationScheme),\n });\n const redirectStartPage = this.getRedirectStartPage(request.redirectStartPage);\n this.logger.verbosePii(`Redirect start page: ${redirectStartPage}`);\n // Clear temporary cache if the back button is clicked during the redirect flow.\n window.addEventListener(\"pageshow\", handleBackButton);\n // Show the UI once the url has been created. Response will come back in the hash, which will be handled in the handleRedirectCallback function.\n return await interactionHandler.initiateAuthRequest(navigateUrl, {\n navigationClient: this.navigationClient,\n redirectTimeout: this.config.system.redirectNavigationTimeout,\n redirectStartPage: redirectStartPage,\n onRedirectNavigate: request.onRedirectNavigate,\n });\n }\n catch (e) {\n if (e instanceof AuthError) {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n }\n window.removeEventListener(\"pageshow\", handleBackButton);\n this.browserStorage.cleanRequestByState(validRequest.state);\n throw e;\n }\n }\n /**\n * Checks if navigateToLoginRequestUrl is set, and:\n * - if true, performs logic to cache and navigate\n * - if false, handles hash string and parses response\n * @param hash {string} url hash\n * @param parentMeasurement {InProgressPerformanceEvent} parent measurement\n */\n async handleRedirectPromise(hash = \"\", parentMeasurement) {\n const serverTelemetryManager = this.initializeServerTelemetryManager(ApiId.handleRedirectPromise);\n try {\n if (!this.browserStorage.isInteractionInProgress(true)) {\n this.logger.info(\"handleRedirectPromise called but there is no interaction in progress, returning null.\");\n return null;\n }\n const [serverParams, responseString] = this.getRedirectResponse(hash || \"\");\n if (!serverParams) {\n // Not a recognized server response hash or hash not associated with a redirect request\n this.logger.info(\"handleRedirectPromise did not detect a response as a result of a redirect. Cleaning temporary cache.\");\n this.browserStorage.cleanRequestByInteractionType(InteractionType.Redirect);\n parentMeasurement.event.errorCode = \"no_server_response\";\n return null;\n }\n // If navigateToLoginRequestUrl is true, get the url where the redirect request was initiated\n const loginRequestUrl = this.browserStorage.getTemporaryCache(TemporaryCacheKeys.ORIGIN_URI, true) || Constants.EMPTY_STRING;\n const loginRequestUrlNormalized = UrlString.removeHashFromUrl(loginRequestUrl);\n const currentUrlNormalized = UrlString.removeHashFromUrl(window.location.href);\n if (loginRequestUrlNormalized === currentUrlNormalized &&\n this.config.auth.navigateToLoginRequestUrl) {\n // We are on the page we need to navigate to - handle hash\n this.logger.verbose(\"Current page is loginRequestUrl, handling response\");\n if (loginRequestUrl.indexOf(\"#\") > -1) {\n // Replace current hash with non-msal hash, if present\n replaceHash(loginRequestUrl);\n }\n const handleHashResult = await this.handleResponse(serverParams, serverTelemetryManager);\n return handleHashResult;\n }\n else if (!this.config.auth.navigateToLoginRequestUrl) {\n this.logger.verbose(\"NavigateToLoginRequestUrl set to false, handling response\");\n return await this.handleResponse(serverParams, serverTelemetryManager);\n }\n else if (!isInIframe() ||\n this.config.system.allowRedirectInIframe) {\n /*\n * Returned from authority using redirect - need to perform navigation before processing response\n * Cache the hash to be retrieved after the next redirect\n */\n this.browserStorage.setTemporaryCache(TemporaryCacheKeys.URL_HASH, responseString, true);\n const navigationOptions = {\n apiId: ApiId.handleRedirectPromise,\n timeout: this.config.system.redirectNavigationTimeout,\n noHistory: true,\n };\n /**\n * Default behavior is to redirect to the start page and not process the hash now.\n * The start page is expected to also call handleRedirectPromise which will process the hash in one of the checks above.\n */\n let processHashOnRedirect = true;\n if (!loginRequestUrl || loginRequestUrl === \"null\") {\n // Redirect to home page if login request url is null (real null or the string null)\n const homepage = getHomepage();\n // Cache the homepage under ORIGIN_URI to ensure cached hash is processed on homepage\n this.browserStorage.setTemporaryCache(TemporaryCacheKeys.ORIGIN_URI, homepage, true);\n this.logger.warning(\"Unable to get valid login request url from cache, redirecting to home page\");\n processHashOnRedirect =\n await this.navigationClient.navigateInternal(homepage, navigationOptions);\n }\n else {\n // Navigate to page that initiated the redirect request\n this.logger.verbose(`Navigating to loginRequestUrl: ${loginRequestUrl}`);\n processHashOnRedirect =\n await this.navigationClient.navigateInternal(loginRequestUrl, navigationOptions);\n }\n // If navigateInternal implementation returns false, handle the hash now\n if (!processHashOnRedirect) {\n return await this.handleResponse(serverParams, serverTelemetryManager);\n }\n }\n return null;\n }\n catch (e) {\n if (e instanceof AuthError) {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n }\n this.browserStorage.cleanRequestByInteractionType(InteractionType.Redirect);\n throw e;\n }\n }\n /**\n * Gets the response hash for a redirect request\n * Returns null if interactionType in the state value is not \"redirect\" or the hash does not contain known properties\n * @param hash\n */\n getRedirectResponse(userProvidedResponse) {\n this.logger.verbose(\"getRedirectResponseHash called\");\n // Get current location hash from window or cache.\n let responseString = userProvidedResponse;\n if (!responseString) {\n if (this.config.auth.OIDCOptions.serverResponseType ===\n ServerResponseType.QUERY) {\n responseString = window.location.search;\n }\n else {\n responseString = window.location.hash;\n }\n }\n let response = UrlUtils.getDeserializedResponse(responseString);\n if (response) {\n try {\n validateInteractionType(response, this.browserCrypto, InteractionType.Redirect);\n }\n catch (e) {\n if (e instanceof AuthError) {\n this.logger.error(`Interaction type validation failed due to ${e.errorCode}: ${e.errorMessage}`);\n }\n return [null, \"\"];\n }\n clearHash(window);\n this.logger.verbose(\"Hash contains known properties, returning response hash\");\n return [response, responseString];\n }\n const cachedHash = this.browserStorage.getTemporaryCache(TemporaryCacheKeys.URL_HASH, true);\n this.browserStorage.removeItem(this.browserStorage.generateCacheKey(TemporaryCacheKeys.URL_HASH));\n if (cachedHash) {\n response = UrlUtils.getDeserializedResponse(cachedHash);\n if (response) {\n this.logger.verbose(\"Hash does not contain known properties, returning cached hash\");\n return [response, cachedHash];\n }\n }\n return [null, \"\"];\n }\n /**\n * Checks if hash exists and handles in window.\n * @param hash\n * @param state\n */\n async handleResponse(serverParams, serverTelemetryManager) {\n const state = serverParams.state;\n if (!state) {\n throw createBrowserAuthError(noStateInHash);\n }\n const cachedRequest = this.browserStorage.getCachedRequest(state);\n this.logger.verbose(\"handleResponse called, retrieved cached request\");\n if (serverParams.accountId) {\n this.logger.verbose(\"Account id found in hash, calling WAM for token\");\n if (!this.nativeMessageHandler) {\n throw createBrowserAuthError(nativeConnectionNotEstablished);\n }\n const nativeInteractionClient = new NativeInteractionClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, ApiId.acquireTokenPopup, this.performanceClient, this.nativeMessageHandler, serverParams.accountId, this.nativeStorage, cachedRequest.correlationId);\n const { userRequestState } = ProtocolUtils.parseRequestState(this.browserCrypto, state);\n return nativeInteractionClient\n .acquireToken({\n ...cachedRequest,\n state: userRequestState,\n prompt: undefined, // Server should handle the prompt, ideally native broker can do this part silently\n })\n .finally(() => {\n this.browserStorage.cleanRequestByState(state);\n });\n }\n // Hash contains known properties - handle and return in callback\n const currentAuthority = this.browserStorage.getCachedAuthority(state);\n if (!currentAuthority) {\n throw createBrowserAuthError(noCachedAuthorityError);\n }\n const authClient = await invokeAsync(this.createAuthCodeClient.bind(this), PerformanceEvents.StandardInteractionClientCreateAuthCodeClient, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, currentAuthority);\n ThrottlingUtils.removeThrottle(this.browserStorage, this.config.auth.clientId, cachedRequest);\n const interactionHandler = new RedirectHandler(authClient, this.browserStorage, cachedRequest, this.logger, this.performanceClient);\n return interactionHandler.handleCodeResponse(serverParams, state);\n }\n /**\n * Use to log out the current user, and redirect the user to the postLogoutRedirectUri.\n * Default behaviour is to redirect the user to `window.location.href`.\n * @param logoutRequest\n */\n async logout(logoutRequest) {\n this.logger.verbose(\"logoutRedirect called\");\n const validLogoutRequest = this.initializeLogoutRequest(logoutRequest);\n const serverTelemetryManager = this.initializeServerTelemetryManager(ApiId.logout);\n try {\n this.eventHandler.emitEvent(EventType.LOGOUT_START, InteractionType.Redirect, logoutRequest);\n // Clear cache on logout\n await this.clearCacheOnLogout(validLogoutRequest.account);\n const navigationOptions = {\n apiId: ApiId.logout,\n timeout: this.config.system.redirectNavigationTimeout,\n noHistory: false,\n };\n const authClient = await invokeAsync(this.createAuthCodeClient.bind(this), PerformanceEvents.StandardInteractionClientCreateAuthCodeClient, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, logoutRequest && logoutRequest.authority, undefined, // AzureCloudOptions\n (logoutRequest && logoutRequest.account) || undefined);\n if (authClient.authority.protocolMode === ProtocolMode.OIDC) {\n try {\n authClient.authority.endSessionEndpoint;\n }\n catch {\n if (validLogoutRequest.account?.homeAccountId) {\n void this.browserStorage.removeAccount(validLogoutRequest.account?.homeAccountId);\n this.eventHandler.emitEvent(EventType.LOGOUT_SUCCESS, InteractionType.Redirect, validLogoutRequest);\n return;\n }\n }\n }\n // Create logout string and navigate user window to logout.\n const logoutUri = authClient.getLogoutUri(validLogoutRequest);\n this.eventHandler.emitEvent(EventType.LOGOUT_SUCCESS, InteractionType.Redirect, validLogoutRequest);\n // Check if onRedirectNavigate is implemented, and invoke it if so\n if (logoutRequest &&\n typeof logoutRequest.onRedirectNavigate === \"function\") {\n const navigate = logoutRequest.onRedirectNavigate(logoutUri);\n if (navigate !== false) {\n this.logger.verbose(\"Logout onRedirectNavigate did not return false, navigating\");\n // Ensure interaction is in progress\n if (!this.browserStorage.getInteractionInProgress()) {\n this.browserStorage.setInteractionInProgress(true);\n }\n await this.navigationClient.navigateExternal(logoutUri, navigationOptions);\n return;\n }\n else {\n // Ensure interaction is not in progress\n this.browserStorage.setInteractionInProgress(false);\n this.logger.verbose(\"Logout onRedirectNavigate returned false, stopping navigation\");\n }\n }\n else {\n // Ensure interaction is in progress\n if (!this.browserStorage.getInteractionInProgress()) {\n this.browserStorage.setInteractionInProgress(true);\n }\n await this.navigationClient.navigateExternal(logoutUri, navigationOptions);\n return;\n }\n }\n catch (e) {\n if (e instanceof AuthError) {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n }\n this.eventHandler.emitEvent(EventType.LOGOUT_FAILURE, InteractionType.Redirect, null, e);\n this.eventHandler.emitEvent(EventType.LOGOUT_END, InteractionType.Redirect);\n throw e;\n }\n this.eventHandler.emitEvent(EventType.LOGOUT_END, InteractionType.Redirect);\n }\n /**\n * Use to get the redirectStartPage either from request or use current window\n * @param requestStartPage\n */\n getRedirectStartPage(requestStartPage) {\n const redirectStartPage = requestStartPage || window.location.href;\n return UrlString.getAbsoluteUrl(redirectStartPage, getCurrentUri());\n }\n}\n\nexport { RedirectClient };\n//# sourceMappingURL=RedirectClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, invokeAsync, invoke, ServerResponseType } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { DEFAULT_IFRAME_TIMEOUT_MS } from '../config/Configuration.mjs';\nimport { emptyNavigateUri, monitorWindowTimeout } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Creates a hidden iframe to given URL using user-requested scopes as an id.\n * @param urlNavigate\n * @param userRequestScopes\n */\nasync function initiateAuthRequest(requestUrl, performanceClient, logger, correlationId, navigateFrameWait) {\n performanceClient.addQueueMeasurement(PerformanceEvents.SilentHandlerInitiateAuthRequest, correlationId);\n if (!requestUrl) {\n // Throw error if request URL is empty.\n logger.info(\"Navigate url is empty\");\n throw createBrowserAuthError(emptyNavigateUri);\n }\n if (navigateFrameWait) {\n return invokeAsync(loadFrame, PerformanceEvents.SilentHandlerLoadFrame, logger, performanceClient, correlationId)(requestUrl, navigateFrameWait, performanceClient, correlationId);\n }\n return invoke(loadFrameSync, PerformanceEvents.SilentHandlerLoadFrameSync, logger, performanceClient, correlationId)(requestUrl);\n}\n/**\n * Monitors an iframe content window until it loads a url with a known hash, or hits a specified timeout.\n * @param iframe\n * @param timeout\n */\nasync function monitorIframeForHash(iframe, timeout, pollIntervalMilliseconds, performanceClient, logger, correlationId, responseType) {\n performanceClient.addQueueMeasurement(PerformanceEvents.SilentHandlerMonitorIframeForHash, correlationId);\n return new Promise((resolve, reject) => {\n if (timeout < DEFAULT_IFRAME_TIMEOUT_MS) {\n logger.warning(`system.loadFrameTimeout or system.iframeHashTimeout set to lower (${timeout}ms) than the default (${DEFAULT_IFRAME_TIMEOUT_MS}ms). This may result in timeouts.`);\n }\n /*\n * Polling for iframes can be purely timing based,\n * since we don't need to account for interaction.\n */\n const timeoutId = window.setTimeout(() => {\n window.clearInterval(intervalId);\n reject(createBrowserAuthError(monitorWindowTimeout));\n }, timeout);\n const intervalId = window.setInterval(() => {\n let href = \"\";\n const contentWindow = iframe.contentWindow;\n try {\n /*\n * Will throw if cross origin,\n * which should be caught and ignored\n * since we need the interval to keep running while on STS UI.\n */\n href = contentWindow ? contentWindow.location.href : \"\";\n }\n catch (e) { }\n if (!href || href === \"about:blank\") {\n return;\n }\n let responseString = \"\";\n if (contentWindow) {\n if (responseType === ServerResponseType.QUERY) {\n responseString = contentWindow.location.search;\n }\n else {\n responseString = contentWindow.location.hash;\n }\n }\n window.clearTimeout(timeoutId);\n window.clearInterval(intervalId);\n resolve(responseString);\n }, pollIntervalMilliseconds);\n }).finally(() => {\n invoke(removeHiddenIframe, PerformanceEvents.RemoveHiddenIframe, logger, performanceClient, correlationId)(iframe);\n });\n}\n/**\n * @hidden\n * Loads iframe with authorization endpoint URL\n * @ignore\n * @deprecated\n */\nfunction loadFrame(urlNavigate, navigateFrameWait, performanceClient, correlationId) {\n performanceClient.addQueueMeasurement(PerformanceEvents.SilentHandlerLoadFrame, correlationId);\n /*\n * This trick overcomes iframe navigation in IE\n * IE does not load the page consistently in iframe\n */\n return new Promise((resolve, reject) => {\n const frameHandle = createHiddenIframe();\n window.setTimeout(() => {\n if (!frameHandle) {\n reject(\"Unable to load iframe\");\n return;\n }\n frameHandle.src = urlNavigate;\n resolve(frameHandle);\n }, navigateFrameWait);\n });\n}\n/**\n * @hidden\n * Loads the iframe synchronously when the navigateTimeFrame is set to `0`\n * @param urlNavigate\n * @param frameName\n * @param logger\n */\nfunction loadFrameSync(urlNavigate) {\n const frameHandle = createHiddenIframe();\n frameHandle.src = urlNavigate;\n return frameHandle;\n}\n/**\n * @hidden\n * Creates a new hidden iframe or gets an existing one for silent token renewal.\n * @ignore\n */\nfunction createHiddenIframe() {\n const authFrame = document.createElement(\"iframe\");\n authFrame.className = \"msalSilentIframe\";\n authFrame.style.visibility = \"hidden\";\n authFrame.style.position = \"absolute\";\n authFrame.style.width = authFrame.style.height = \"0\";\n authFrame.style.border = \"0\";\n authFrame.setAttribute(\"sandbox\", \"allow-scripts allow-same-origin allow-forms\");\n document.body.appendChild(authFrame);\n return authFrame;\n}\n/**\n * @hidden\n * Removes a hidden iframe from the page.\n * @ignore\n */\nfunction removeHiddenIframe(iframe) {\n if (document.body === iframe.parentNode) {\n document.body.removeChild(iframe);\n }\n}\n\nexport { initiateAuthRequest, monitorIframeForHash };\n//# sourceMappingURL=SilentHandler.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { PerformanceEvents, PromptValue, invokeAsync, AuthError, invoke, ProtocolUtils } from '@azure/msal-common';\nimport { StandardInteractionClient } from './StandardInteractionClient.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { InteractionType } from '../utils/BrowserConstants.mjs';\nimport { initiateAuthRequest, monitorIframeForHash } from '../interaction_handler/SilentHandler.mjs';\nimport { NativeMessageHandler } from '../broker/nativeBroker/NativeMessageHandler.mjs';\nimport { NativeInteractionClient } from './NativeInteractionClient.mjs';\nimport { InteractionHandler } from '../interaction_handler/InteractionHandler.mjs';\nimport { preconnect } from '../utils/BrowserUtils.mjs';\nimport { deserializeResponse } from '../response/ResponseHandler.mjs';\nimport { silentLogoutUnsupported, nativeConnectionNotEstablished } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass SilentIframeClient extends StandardInteractionClient {\n constructor(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, apiId, performanceClient, nativeStorageImpl, nativeMessageHandler, correlationId) {\n super(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, performanceClient, nativeMessageHandler, correlationId);\n this.apiId = apiId;\n this.nativeStorage = nativeStorageImpl;\n }\n /**\n * Acquires a token silently by opening a hidden iframe to the /authorize endpoint with prompt=none or prompt=no_session\n * @param request\n */\n async acquireToken(request) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.SilentIframeClientAcquireToken, request.correlationId);\n // Check that we have some SSO data\n if (!request.loginHint &&\n !request.sid &&\n (!request.account || !request.account.username)) {\n this.logger.warning(\"No user hint provided. The authorization server may need more information to complete this request.\");\n }\n // Check the prompt value\n const inputRequest = { ...request };\n if (inputRequest.prompt) {\n if (inputRequest.prompt !== PromptValue.NONE &&\n inputRequest.prompt !== PromptValue.NO_SESSION) {\n this.logger.warning(`SilentIframeClient. Replacing invalid prompt ${inputRequest.prompt} with ${PromptValue.NONE}`);\n inputRequest.prompt = PromptValue.NONE;\n }\n }\n else {\n inputRequest.prompt = PromptValue.NONE;\n }\n // Create silent request\n const silentRequest = await invokeAsync(this.initializeAuthorizationRequest.bind(this), PerformanceEvents.StandardInteractionClientInitializeAuthorizationRequest, this.logger, this.performanceClient, request.correlationId)(inputRequest, InteractionType.Silent);\n preconnect(silentRequest.authority);\n const serverTelemetryManager = this.initializeServerTelemetryManager(this.apiId);\n try {\n // Initialize the client\n const authClient = await invokeAsync(this.createAuthCodeClient.bind(this), PerformanceEvents.StandardInteractionClientCreateAuthCodeClient, this.logger, this.performanceClient, request.correlationId)(serverTelemetryManager, silentRequest.authority, silentRequest.azureCloudOptions, silentRequest.account);\n return await invokeAsync(this.silentTokenHelper.bind(this), PerformanceEvents.SilentIframeClientTokenHelper, this.logger, this.performanceClient, request.correlationId)(authClient, silentRequest);\n }\n catch (e) {\n if (e instanceof AuthError) {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n }\n throw e;\n }\n }\n /**\n * Currently Unsupported\n */\n logout() {\n // Synchronous so we must reject\n return Promise.reject(createBrowserAuthError(silentLogoutUnsupported));\n }\n /**\n * Helper which acquires an authorization code silently using a hidden iframe from given url\n * using the scopes requested as part of the id, and exchanges the code for a set of OAuth tokens.\n * @param navigateUrl\n * @param userRequestScopes\n */\n async silentTokenHelper(authClient, silentRequest) {\n const correlationId = silentRequest.correlationId;\n this.performanceClient.addQueueMeasurement(PerformanceEvents.SilentIframeClientTokenHelper, correlationId);\n // Create auth code request and generate PKCE params\n const authCodeRequest = await invokeAsync(this.initializeAuthorizationCodeRequest.bind(this), PerformanceEvents.StandardInteractionClientInitializeAuthorizationCodeRequest, this.logger, this.performanceClient, correlationId)(silentRequest);\n // Create authorize request url\n const navigateUrl = await invokeAsync(authClient.getAuthCodeUrl.bind(authClient), PerformanceEvents.GetAuthCodeUrl, this.logger, this.performanceClient, correlationId)({\n ...silentRequest,\n nativeBroker: NativeMessageHandler.isNativeAvailable(this.config, this.logger, this.nativeMessageHandler, silentRequest.authenticationScheme),\n });\n // Create silent handler\n const interactionHandler = new InteractionHandler(authClient, this.browserStorage, authCodeRequest, this.logger, this.performanceClient);\n // Get the frame handle for the silent request\n const msalFrame = await invokeAsync(initiateAuthRequest, PerformanceEvents.SilentHandlerInitiateAuthRequest, this.logger, this.performanceClient, correlationId)(navigateUrl, this.performanceClient, this.logger, correlationId, this.config.system.navigateFrameWait);\n const responseType = this.config.auth.OIDCOptions.serverResponseType;\n // Monitor the window for the hash. Return the string value and close the popup when the hash is received. Default timeout is 60 seconds.\n const responseString = await invokeAsync(monitorIframeForHash, PerformanceEvents.SilentHandlerMonitorIframeForHash, this.logger, this.performanceClient, correlationId)(msalFrame, this.config.system.iframeHashTimeout, this.config.system.pollIntervalMilliseconds, this.performanceClient, this.logger, correlationId, responseType);\n const serverParams = invoke(deserializeResponse, PerformanceEvents.DeserializeResponse, this.logger, this.performanceClient, this.correlationId)(responseString, responseType, this.logger);\n if (serverParams.accountId) {\n this.logger.verbose(\"Account id found in hash, calling WAM for token\");\n if (!this.nativeMessageHandler) {\n throw createBrowserAuthError(nativeConnectionNotEstablished);\n }\n const nativeInteractionClient = new NativeInteractionClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, this.apiId, this.performanceClient, this.nativeMessageHandler, serverParams.accountId, this.browserStorage, correlationId);\n const { userRequestState } = ProtocolUtils.parseRequestState(this.browserCrypto, silentRequest.state);\n return invokeAsync(nativeInteractionClient.acquireToken.bind(nativeInteractionClient), PerformanceEvents.NativeInteractionClientAcquireToken, this.logger, this.performanceClient, correlationId)({\n ...silentRequest,\n state: userRequestState,\n prompt: silentRequest.prompt || PromptValue.NONE,\n });\n }\n // Handle response from hash string\n return invokeAsync(interactionHandler.handleCodeResponse.bind(interactionHandler), PerformanceEvents.HandleCodeResponse, this.logger, this.performanceClient, correlationId)(serverParams, silentRequest);\n }\n}\n\nexport { SilentIframeClient };\n//# sourceMappingURL=SilentIframeClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { StandardInteractionClient } from './StandardInteractionClient.mjs';\nimport { PerformanceEvents, invokeAsync, RefreshTokenClient } from '@azure/msal-common';\nimport { ApiId } from '../utils/BrowserConstants.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { initializeBaseRequest } from '../request/RequestHelpers.mjs';\nimport { silentLogoutUnsupported } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass SilentRefreshClient extends StandardInteractionClient {\n /**\n * Exchanges the refresh token for new tokens\n * @param request\n */\n async acquireToken(request) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.SilentRefreshClientAcquireToken, request.correlationId);\n const baseRequest = await invokeAsync(initializeBaseRequest, PerformanceEvents.InitializeBaseRequest, this.logger, this.performanceClient, request.correlationId)(request, this.config, this.performanceClient, this.logger);\n const silentRequest = {\n ...request,\n ...baseRequest,\n };\n if (request.redirectUri) {\n // Make sure any passed redirectUri is converted to an absolute URL - redirectUri is not a required parameter for refresh token redemption so only include if explicitly provided\n silentRequest.redirectUri = this.getRedirectUri(request.redirectUri);\n }\n const serverTelemetryManager = this.initializeServerTelemetryManager(ApiId.acquireTokenSilent_silentFlow);\n const refreshTokenClient = await this.createRefreshTokenClient(serverTelemetryManager, silentRequest.authority, silentRequest.azureCloudOptions, silentRequest.account);\n // Send request to renew token. Auth module will throw errors if token cannot be renewed.\n return invokeAsync(refreshTokenClient.acquireTokenByRefreshToken.bind(refreshTokenClient), PerformanceEvents.RefreshTokenClientAcquireTokenByRefreshToken, this.logger, this.performanceClient, request.correlationId)(silentRequest).catch((e) => {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n throw e;\n });\n }\n /**\n * Currently Unsupported\n */\n logout() {\n // Synchronous so we must reject\n return Promise.reject(createBrowserAuthError(silentLogoutUnsupported));\n }\n /**\n * Creates a Refresh Client with the given authority, or the default authority.\n * @param serverTelemetryManager\n * @param authorityUrl\n */\n async createRefreshTokenClient(serverTelemetryManager, authorityUrl, azureCloudOptions, account) {\n // Create auth module.\n const clientConfig = await invokeAsync(this.getClientConfiguration.bind(this), PerformanceEvents.StandardInteractionClientGetClientConfiguration, this.logger, this.performanceClient, this.correlationId)(serverTelemetryManager, authorityUrl, azureCloudOptions, account);\n return new RefreshTokenClient(clientConfig, this.performanceClient);\n }\n}\n\nexport { SilentRefreshClient };\n//# sourceMappingURL=SilentRefreshClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { AuthToken, Authority, AccountEntity, buildAccountToCache, CacheHelpers, ScopeSet } from '@azure/msal-common';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { base64Decode } from '../encode/Base64Decode.mjs';\nimport { createNewGuid } from '../crypto/BrowserCrypto.mjs';\nimport { nonBrowserEnvironment, unableToLoadToken } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * Token cache manager\n */\nclass TokenCache {\n constructor(configuration, storage, logger, cryptoObj) {\n this.isBrowserEnvironment = typeof window !== \"undefined\";\n this.config = configuration;\n this.storage = storage;\n this.logger = logger;\n this.cryptoObj = cryptoObj;\n }\n // Move getAllAccounts here and cache utility APIs\n /**\n * API to load tokens to msal-browser cache.\n * @param request\n * @param response\n * @param options\n * @returns `AuthenticationResult` for the response that was loaded.\n */\n loadExternalTokens(request, response, options) {\n if (!this.isBrowserEnvironment) {\n throw createBrowserAuthError(nonBrowserEnvironment);\n }\n const idTokenClaims = response.id_token\n ? AuthToken.extractTokenClaims(response.id_token, base64Decode)\n : undefined;\n const authorityOptions = {\n protocolMode: this.config.auth.protocolMode,\n knownAuthorities: this.config.auth.knownAuthorities,\n cloudDiscoveryMetadata: this.config.auth.cloudDiscoveryMetadata,\n authorityMetadata: this.config.auth.authorityMetadata,\n skipAuthorityMetadataCache: this.config.auth.skipAuthorityMetadataCache,\n };\n const authority = request.authority\n ? new Authority(Authority.generateAuthority(request.authority, request.azureCloudOptions), this.config.system.networkClient, this.storage, authorityOptions, this.logger, request.correlationId || createNewGuid())\n : undefined;\n const cacheRecordAccount = this.loadAccount(request, options.clientInfo || response.client_info || \"\", idTokenClaims, authority);\n const idToken = this.loadIdToken(response, cacheRecordAccount.homeAccountId, cacheRecordAccount.environment, cacheRecordAccount.realm);\n const accessToken = this.loadAccessToken(request, response, cacheRecordAccount.homeAccountId, cacheRecordAccount.environment, cacheRecordAccount.realm, options);\n const refreshToken = this.loadRefreshToken(response, cacheRecordAccount.homeAccountId, cacheRecordAccount.environment);\n return this.generateAuthenticationResult(request, {\n account: cacheRecordAccount,\n idToken,\n accessToken,\n refreshToken,\n }, idTokenClaims, authority);\n }\n /**\n * Helper function to load account to msal-browser cache\n * @param idToken\n * @param environment\n * @param clientInfo\n * @param authorityType\n * @param requestHomeAccountId\n * @returns `AccountEntity`\n */\n loadAccount(request, clientInfo, idTokenClaims, authority) {\n this.logger.verbose(\"TokenCache - loading account\");\n if (request.account) {\n const accountEntity = AccountEntity.createFromAccountInfo(request.account);\n this.storage.setAccount(accountEntity);\n return accountEntity;\n }\n else if (!authority || (!clientInfo && !idTokenClaims)) {\n this.logger.error(\"TokenCache - if an account is not provided on the request, authority and either clientInfo or idToken must be provided instead.\");\n throw createBrowserAuthError(unableToLoadToken);\n }\n const homeAccountId = AccountEntity.generateHomeAccountId(clientInfo, authority.authorityType, this.logger, this.cryptoObj, idTokenClaims);\n const claimsTenantId = idTokenClaims?.tid;\n const cachedAccount = buildAccountToCache(this.storage, authority, homeAccountId, base64Decode, idTokenClaims, clientInfo, authority.hostnameAndPort, claimsTenantId, undefined, // authCodePayload\n undefined, // nativeAccountId\n this.logger);\n this.storage.setAccount(cachedAccount);\n return cachedAccount;\n }\n /**\n * Helper function to load id tokens to msal-browser cache\n * @param idToken\n * @param homeAccountId\n * @param environment\n * @param tenantId\n * @returns `IdTokenEntity`\n */\n loadIdToken(response, homeAccountId, environment, tenantId) {\n if (!response.id_token) {\n this.logger.verbose(\"TokenCache - no id token found in response\");\n return null;\n }\n this.logger.verbose(\"TokenCache - loading id token\");\n const idTokenEntity = CacheHelpers.createIdTokenEntity(homeAccountId, environment, response.id_token, this.config.auth.clientId, tenantId);\n this.storage.setIdTokenCredential(idTokenEntity);\n return idTokenEntity;\n }\n /**\n * Helper function to load access tokens to msal-browser cache\n * @param request\n * @param response\n * @param homeAccountId\n * @param environment\n * @param tenantId\n * @returns `AccessTokenEntity`\n */\n loadAccessToken(request, response, homeAccountId, environment, tenantId, options) {\n if (!response.access_token) {\n this.logger.verbose(\"TokenCache - no access token found in response\");\n return null;\n }\n else if (!response.expires_in) {\n this.logger.error(\"TokenCache - no expiration set on the access token. Cannot add it to the cache.\");\n return null;\n }\n else if (!response.scope &&\n (!request.scopes || !request.scopes.length)) {\n this.logger.error(\"TokenCache - scopes not specified in the request or response. Cannot add token to the cache.\");\n return null;\n }\n this.logger.verbose(\"TokenCache - loading access token\");\n const scopes = response.scope\n ? ScopeSet.fromString(response.scope)\n : new ScopeSet(request.scopes);\n const expiresOn = options.expiresOn ||\n response.expires_in + new Date().getTime() / 1000;\n const extendedExpiresOn = options.extendedExpiresOn ||\n (response.ext_expires_in || response.expires_in) +\n new Date().getTime() / 1000;\n const accessTokenEntity = CacheHelpers.createAccessTokenEntity(homeAccountId, environment, response.access_token, this.config.auth.clientId, tenantId, scopes.printScopes(), expiresOn, extendedExpiresOn, base64Decode);\n this.storage.setAccessTokenCredential(accessTokenEntity);\n return accessTokenEntity;\n }\n /**\n * Helper function to load refresh tokens to msal-browser cache\n * @param request\n * @param response\n * @param homeAccountId\n * @param environment\n * @returns `RefreshTokenEntity`\n */\n loadRefreshToken(response, homeAccountId, environment) {\n if (!response.refresh_token) {\n this.logger.verbose(\"TokenCache - no refresh token found in response\");\n return null;\n }\n this.logger.verbose(\"TokenCache - loading refresh token\");\n const refreshTokenEntity = CacheHelpers.createRefreshTokenEntity(homeAccountId, environment, response.refresh_token, this.config.auth.clientId, response.foci, undefined, // userAssertionHash\n response.refresh_token_expires_in);\n this.storage.setRefreshTokenCredential(refreshTokenEntity);\n return refreshTokenEntity;\n }\n /**\n * Helper function to generate an `AuthenticationResult` for the result.\n * @param request\n * @param idTokenObj\n * @param cacheRecord\n * @param authority\n * @returns `AuthenticationResult`\n */\n generateAuthenticationResult(request, cacheRecord, idTokenClaims, authority) {\n let accessToken = \"\";\n let responseScopes = [];\n let expiresOn = null;\n let extExpiresOn;\n if (cacheRecord?.accessToken) {\n accessToken = cacheRecord.accessToken.secret;\n responseScopes = ScopeSet.fromString(cacheRecord.accessToken.target).asArray();\n expiresOn = new Date(Number(cacheRecord.accessToken.expiresOn) * 1000);\n extExpiresOn = new Date(Number(cacheRecord.accessToken.extendedExpiresOn) * 1000);\n }\n const accountEntity = cacheRecord.account;\n return {\n authority: authority ? authority.canonicalAuthority : \"\",\n uniqueId: cacheRecord.account.localAccountId,\n tenantId: cacheRecord.account.realm,\n scopes: responseScopes,\n account: accountEntity.getAccountInfo(),\n idToken: cacheRecord.idToken?.secret || \"\",\n idTokenClaims: idTokenClaims || {},\n accessToken: accessToken,\n fromCache: true,\n expiresOn: expiresOn,\n correlationId: request.correlationId || \"\",\n requestId: \"\",\n extExpiresOn: extExpiresOn,\n familyId: cacheRecord.refreshToken?.familyId || \"\",\n tokenType: cacheRecord?.accessToken?.tokenType || \"\",\n state: request.state || \"\",\n cloudGraphHostName: accountEntity.cloudGraphHostName || \"\",\n msGraphHost: accountEntity.msGraphHost || \"\",\n fromNativeBroker: false,\n };\n }\n}\n\nexport { TokenCache };\n//# sourceMappingURL=TokenCache.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { AuthorizationCodeClient } from '@azure/msal-common';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass HybridSpaAuthorizationCodeClient extends AuthorizationCodeClient {\n constructor(config) {\n super(config);\n this.includeRedirectUri = false;\n }\n}\n\nexport { HybridSpaAuthorizationCodeClient };\n//# sourceMappingURL=HybridSpaAuthorizationCodeClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { invokeAsync, PerformanceEvents, AuthError } from '@azure/msal-common';\nimport { StandardInteractionClient } from './StandardInteractionClient.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { InteractionType } from '../utils/BrowserConstants.mjs';\nimport { HybridSpaAuthorizationCodeClient } from './HybridSpaAuthorizationCodeClient.mjs';\nimport { InteractionHandler } from '../interaction_handler/InteractionHandler.mjs';\nimport { authCodeRequired, silentLogoutUnsupported } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nclass SilentAuthCodeClient extends StandardInteractionClient {\n constructor(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, apiId, performanceClient, nativeMessageHandler, correlationId) {\n super(config, storageImpl, browserCrypto, logger, eventHandler, navigationClient, performanceClient, nativeMessageHandler, correlationId);\n this.apiId = apiId;\n }\n /**\n * Acquires a token silently by redeeming an authorization code against the /token endpoint\n * @param request\n */\n async acquireToken(request) {\n // Auth code payload is required\n if (!request.code) {\n throw createBrowserAuthError(authCodeRequired);\n }\n // Create silent request\n const silentRequest = await invokeAsync(this.initializeAuthorizationRequest.bind(this), PerformanceEvents.StandardInteractionClientInitializeAuthorizationRequest, this.logger, this.performanceClient, request.correlationId)(request, InteractionType.Silent);\n const serverTelemetryManager = this.initializeServerTelemetryManager(this.apiId);\n try {\n // Create auth code request (PKCE not needed)\n const authCodeRequest = {\n ...silentRequest,\n code: request.code,\n };\n // Initialize the client\n const clientConfig = await invokeAsync(this.getClientConfiguration.bind(this), PerformanceEvents.StandardInteractionClientGetClientConfiguration, this.logger, this.performanceClient, request.correlationId)(serverTelemetryManager, silentRequest.authority, silentRequest.azureCloudOptions, silentRequest.account);\n const authClient = new HybridSpaAuthorizationCodeClient(clientConfig);\n this.logger.verbose(\"Auth code client created\");\n // Create silent handler\n const interactionHandler = new InteractionHandler(authClient, this.browserStorage, authCodeRequest, this.logger, this.performanceClient);\n // Handle auth code parameters from request\n return await invokeAsync(interactionHandler.handleCodeResponseFromServer.bind(interactionHandler), PerformanceEvents.HandleCodeResponseFromServer, this.logger, this.performanceClient, request.correlationId)({\n code: request.code,\n msgraph_host: request.msGraphHost,\n cloud_graph_host_name: request.cloudGraphHostName,\n cloud_instance_host_name: request.cloudInstanceHostName,\n }, silentRequest, false);\n }\n catch (e) {\n if (e instanceof AuthError) {\n e.setCorrelationId(this.correlationId);\n serverTelemetryManager.cacheFailedRequest(e);\n }\n throw e;\n }\n }\n /**\n * Currently Unsupported\n */\n logout() {\n // Synchronous so we must reject\n return Promise.reject(createBrowserAuthError(silentLogoutUnsupported));\n }\n}\n\nexport { SilentAuthCodeClient };\n//# sourceMappingURL=SilentAuthCodeClient.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { CryptoOps } from '../crypto/CryptoOps.mjs';\nimport { DEFAULT_CRYPTO_IMPLEMENTATION, buildStaticAuthorityOptions, PerformanceEvents, invokeAsync, InteractionRequiredAuthError, createClientAuthError, ClientAuthErrorCodes, AccountEntity, PromptValue, Constants, InteractionRequiredAuthErrorCodes } from '@azure/msal-common';\nimport { BrowserCacheManager, DEFAULT_BROWSER_CACHE_MANAGER } from '../cache/BrowserCacheManager.mjs';\nimport { getAllAccounts, getAccount, getAccountByUsername, getAccountByHomeId, getAccountByLocalId, setActiveAccount, getActiveAccount } from '../cache/AccountManager.mjs';\nimport { TemporaryCacheKeys, InteractionType, ApiId, CacheLookupPolicy, DEFAULT_REQUEST, BrowserCacheLocation, iFrameRenewalPolicies, BrowserConstants } from '../utils/BrowserConstants.mjs';\nimport { blockAPICallsBeforeInitialize, redirectPreflightCheck, preflightCheck as preflightCheck$1 } from '../utils/BrowserUtils.mjs';\nimport { EventType } from '../event/EventType.mjs';\nimport { EventHandler } from '../event/EventHandler.mjs';\nimport { PopupClient } from '../interaction_client/PopupClient.mjs';\nimport { RedirectClient } from '../interaction_client/RedirectClient.mjs';\nimport { SilentIframeClient } from '../interaction_client/SilentIframeClient.mjs';\nimport { SilentRefreshClient } from '../interaction_client/SilentRefreshClient.mjs';\nimport { TokenCache } from '../cache/TokenCache.mjs';\nimport { NativeInteractionClient } from '../interaction_client/NativeInteractionClient.mjs';\nimport { NativeMessageHandler } from '../broker/nativeBroker/NativeMessageHandler.mjs';\nimport { NativeAuthError, isFatalNativeAuthError } from '../error/NativeAuthError.mjs';\nimport { SilentCacheClient } from '../interaction_client/SilentCacheClient.mjs';\nimport { SilentAuthCodeClient } from '../interaction_client/SilentAuthCodeClient.mjs';\nimport { createBrowserAuthError } from '../error/BrowserAuthError.mjs';\nimport { createNewGuid } from '../crypto/BrowserCrypto.mjs';\nimport { initializeSilentRequest } from '../request/RequestHelpers.mjs';\nimport { spaCodeAndNativeAccountIdPresent, unableToAcquireTokenFromNativePlatform, authCodeOrNativeAccountIdRequired, nativeConnectionNotEstablished, noAccountError } from '../error/BrowserAuthErrorCodes.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nfunction getAccountType(account) {\n const idTokenClaims = account?.idTokenClaims;\n if (idTokenClaims?.tfp || idTokenClaims?.acr) {\n return \"B2C\";\n }\n if (!idTokenClaims?.tid) {\n return undefined;\n }\n else if (idTokenClaims?.tid === \"9188040d-6c67-4c5b-b112-36a304b66dad\") {\n return \"MSA\";\n }\n return \"AAD\";\n}\nfunction preflightCheck(initialized, performanceEvent) {\n try {\n preflightCheck$1(initialized);\n }\n catch (e) {\n performanceEvent.end({ success: false }, e);\n throw e;\n }\n}\nclass StandardController {\n /**\n * @constructor\n * Constructor for the PublicClientApplication used to instantiate the PublicClientApplication object\n *\n * Important attributes in the Configuration object for auth are:\n * - clientID: the application ID of your application. You can obtain one by registering your application with our Application registration portal : https://portal.azure.com/#blade/Microsoft_AAD_IAM/ActiveDirectoryMenuBlade/RegisteredAppsPreview\n * - authority: the authority URL for your application.\n * - redirect_uri: the uri of your application registered in the portal.\n *\n * In Azure AD, authority is a URL indicating the Azure active directory that MSAL uses to obtain tokens.\n * It is of the form https://login.microsoftonline.com/{Enter_the_Tenant_Info_Here}\n * If your application supports Accounts in one organizational directory, replace \"Enter_the_Tenant_Info_Here\" value with the Tenant Id or Tenant name (for example, contoso.microsoft.com).\n * If your application supports Accounts in any organizational directory, replace \"Enter_the_Tenant_Info_Here\" value with organizations.\n * If your application supports Accounts in any organizational directory and personal Microsoft accounts, replace \"Enter_the_Tenant_Info_Here\" value with common.\n * To restrict support to Personal Microsoft accounts only, replace \"Enter_the_Tenant_Info_Here\" value with consumers.\n *\n * In Azure B2C, authority is of the form https://{instance}/tfp/{tenant}/{policyName}/\n * Full B2C functionality will be available in this library in future versions.\n *\n * @param configuration Object for the MSAL PublicClientApplication instance\n */\n constructor(operatingContext) {\n this.operatingContext = operatingContext;\n this.isBrowserEnvironment =\n this.operatingContext.isBrowserEnvironment();\n // Set the configuration.\n this.config = operatingContext.getConfig();\n this.initialized = false;\n // Initialize logger\n this.logger = this.operatingContext.getLogger();\n // Initialize the network module class.\n this.networkClient = this.config.system.networkClient;\n // Initialize the navigation client class.\n this.navigationClient = this.config.system.navigationClient;\n // Initialize redirectResponse Map\n this.redirectResponse = new Map();\n // Initial hybrid spa map\n this.hybridAuthCodeResponses = new Map();\n // Initialize performance client\n this.performanceClient = this.config.telemetry.client;\n // Initialize the crypto class.\n this.browserCrypto = this.isBrowserEnvironment\n ? new CryptoOps(this.logger, this.performanceClient)\n : DEFAULT_CRYPTO_IMPLEMENTATION;\n this.eventHandler = new EventHandler(this.logger, this.browserCrypto);\n // Initialize the browser storage class.\n this.browserStorage = this.isBrowserEnvironment\n ? new BrowserCacheManager(this.config.auth.clientId, this.config.cache, this.browserCrypto, this.logger, buildStaticAuthorityOptions(this.config.auth), this.performanceClient)\n : DEFAULT_BROWSER_CACHE_MANAGER(this.config.auth.clientId, this.logger);\n // initialize in memory storage for native flows\n const nativeCacheOptions = {\n cacheLocation: BrowserCacheLocation.MemoryStorage,\n temporaryCacheLocation: BrowserCacheLocation.MemoryStorage,\n storeAuthStateInCookie: false,\n secureCookies: false,\n cacheMigrationEnabled: false,\n claimsBasedCachingEnabled: false,\n };\n this.nativeInternalStorage = new BrowserCacheManager(this.config.auth.clientId, nativeCacheOptions, this.browserCrypto, this.logger, undefined, this.performanceClient);\n // Initialize the token cache\n this.tokenCache = new TokenCache(this.config, this.browserStorage, this.logger, this.browserCrypto);\n this.activeSilentTokenRequests = new Map();\n // Register listener functions\n this.trackPageVisibility = this.trackPageVisibility.bind(this);\n // Register listener functions\n this.trackPageVisibilityWithMeasurement =\n this.trackPageVisibilityWithMeasurement.bind(this);\n }\n static async createController(operatingContext, request) {\n const controller = new StandardController(operatingContext);\n await controller.initialize(request);\n return controller;\n }\n trackPageVisibility(correlationId) {\n if (!correlationId) {\n return;\n }\n this.logger.info(\"Perf: Visibility change detected\");\n this.performanceClient.incrementFields({ visibilityChangeCount: 1 }, correlationId);\n }\n /**\n * Initializer function to perform async startup tasks such as connecting to WAM extension\n * @param request {?InitializeApplicationRequest} correlation id\n */\n async initialize(request) {\n this.logger.trace(\"initialize called\");\n if (this.initialized) {\n this.logger.info(\"initialize has already been called, exiting early.\");\n return;\n }\n const initCorrelationId = request?.correlationId || this.getRequestCorrelationId();\n const allowNativeBroker = this.config.system.allowNativeBroker;\n const initMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.InitializeClientApplication, initCorrelationId);\n this.eventHandler.emitEvent(EventType.INITIALIZE_START);\n if (allowNativeBroker) {\n try {\n this.nativeExtensionProvider =\n await NativeMessageHandler.createProvider(this.logger, this.config.system.nativeBrokerHandshakeTimeout, this.performanceClient);\n }\n catch (e) {\n this.logger.verbose(e);\n }\n }\n if (!this.config.cache.claimsBasedCachingEnabled) {\n this.logger.verbose(\"Claims-based caching is disabled. Clearing the previous cache with claims\");\n await invokeAsync(this.browserStorage.clearTokensAndKeysWithClaims.bind(this.browserStorage), PerformanceEvents.ClearTokensAndKeysWithClaims, this.logger, this.performanceClient, initCorrelationId)(this.performanceClient, initCorrelationId);\n }\n this.initialized = true;\n this.eventHandler.emitEvent(EventType.INITIALIZE_END);\n initMeasurement.end({ allowNativeBroker, success: true });\n }\n // #region Redirect Flow\n /**\n * Event handler function which allows users to fire events after the PublicClientApplication object\n * has loaded during redirect flows. This should be invoked on all page loads involved in redirect\n * auth flows.\n * @param hash Hash to process. Defaults to the current value of window.location.hash. Only needs to be provided explicitly if the response to be handled is not contained in the current value.\n * @returns Token response or null. If the return value is null, then no auth redirect was detected.\n */\n async handleRedirectPromise(hash) {\n this.logger.verbose(\"handleRedirectPromise called\");\n // Block token acquisition before initialize has been called\n blockAPICallsBeforeInitialize(this.initialized);\n if (this.isBrowserEnvironment) {\n /**\n * Store the promise on the PublicClientApplication instance if this is the first invocation of handleRedirectPromise,\n * otherwise return the promise from the first invocation. Prevents race conditions when handleRedirectPromise is called\n * several times concurrently.\n */\n const redirectResponseKey = hash || \"\";\n let response = this.redirectResponse.get(redirectResponseKey);\n if (typeof response === \"undefined\") {\n response = this.handleRedirectPromiseInternal(hash);\n this.redirectResponse.set(redirectResponseKey, response);\n this.logger.verbose(\"handleRedirectPromise has been called for the first time, storing the promise\");\n }\n else {\n this.logger.verbose(\"handleRedirectPromise has been called previously, returning the result from the first call\");\n }\n return response;\n }\n this.logger.verbose(\"handleRedirectPromise returns null, not browser environment\");\n return null;\n }\n /**\n * The internal details of handleRedirectPromise. This is separated out to a helper to allow handleRedirectPromise to memoize requests\n * @param hash\n * @returns\n */\n async handleRedirectPromiseInternal(hash) {\n const loggedInAccounts = this.getAllAccounts();\n const request = this.browserStorage.getCachedNativeRequest();\n const useNative = request &&\n NativeMessageHandler.isNativeAvailable(this.config, this.logger, this.nativeExtensionProvider) &&\n this.nativeExtensionProvider &&\n !hash;\n const correlationId = useNative\n ? request?.correlationId\n : this.browserStorage.getTemporaryCache(TemporaryCacheKeys.CORRELATION_ID, true) || \"\";\n const rootMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.AcquireTokenRedirect, correlationId);\n this.eventHandler.emitEvent(EventType.HANDLE_REDIRECT_START, InteractionType.Redirect);\n let redirectResponse;\n if (useNative && this.nativeExtensionProvider) {\n this.logger.trace(\"handleRedirectPromise - acquiring token from native platform\");\n const nativeClient = new NativeInteractionClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, ApiId.handleRedirectPromise, this.performanceClient, this.nativeExtensionProvider, request.accountId, this.nativeInternalStorage, request.correlationId);\n redirectResponse = invokeAsync(nativeClient.handleRedirectPromise.bind(nativeClient), PerformanceEvents.HandleNativeRedirectPromiseMeasurement, this.logger, this.performanceClient, rootMeasurement.event.correlationId)(this.performanceClient, rootMeasurement.event.correlationId);\n }\n else {\n this.logger.trace(\"handleRedirectPromise - acquiring token from web flow\");\n const redirectClient = this.createRedirectClient(correlationId);\n redirectResponse = invokeAsync(redirectClient.handleRedirectPromise.bind(redirectClient), PerformanceEvents.HandleRedirectPromiseMeasurement, this.logger, this.performanceClient, rootMeasurement.event.correlationId)(hash, rootMeasurement);\n }\n return redirectResponse\n .then((result) => {\n if (result) {\n // Emit login event if number of accounts change\n const isLoggingIn = loggedInAccounts.length < this.getAllAccounts().length;\n if (isLoggingIn) {\n this.eventHandler.emitEvent(EventType.LOGIN_SUCCESS, InteractionType.Redirect, result);\n this.logger.verbose(\"handleRedirectResponse returned result, login success\");\n }\n else {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_SUCCESS, InteractionType.Redirect, result);\n this.logger.verbose(\"handleRedirectResponse returned result, acquire token success\");\n }\n rootMeasurement.end({\n success: true,\n accountType: getAccountType(result.account),\n });\n }\n else {\n /*\n * Instrument an event only if an error code is set. Otherwise, discard it when the redirect response\n * is empty and the error code is missing.\n */\n if (rootMeasurement.event.errorCode) {\n rootMeasurement.end({ success: false });\n }\n else {\n rootMeasurement.discard();\n }\n }\n this.eventHandler.emitEvent(EventType.HANDLE_REDIRECT_END, InteractionType.Redirect);\n return result;\n })\n .catch((e) => {\n const eventError = e;\n // Emit login event if there is an account\n if (loggedInAccounts.length > 0) {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_FAILURE, InteractionType.Redirect, null, eventError);\n }\n else {\n this.eventHandler.emitEvent(EventType.LOGIN_FAILURE, InteractionType.Redirect, null, eventError);\n }\n this.eventHandler.emitEvent(EventType.HANDLE_REDIRECT_END, InteractionType.Redirect);\n rootMeasurement.end({\n success: false,\n }, eventError);\n throw e;\n });\n }\n /**\n * Use when you want to obtain an access_token for your API by redirecting the user's browser window to the authorization endpoint. This function redirects\n * the page, so any code that follows this function will not execute.\n *\n * IMPORTANT: It is NOT recommended to have code that is dependent on the resolution of the Promise. This function will navigate away from the current\n * browser window. It currently returns a Promise in order to reflect the asynchronous nature of the code running in this function.\n *\n * @param request\n */\n async acquireTokenRedirect(request) {\n // Preflight request\n const correlationId = this.getRequestCorrelationId(request);\n this.logger.verbose(\"acquireTokenRedirect called\", correlationId);\n const atrMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.AcquireTokenPreRedirect, correlationId);\n atrMeasurement.add({\n accountType: getAccountType(request.account),\n scenarioId: request.scenarioId,\n });\n const onRedirectNavigateCb = request.onRedirectNavigate;\n request.onRedirectNavigate = (url) => {\n const navigate = typeof onRedirectNavigateCb === \"function\"\n ? onRedirectNavigateCb(url)\n : undefined;\n if (navigate !== false) {\n atrMeasurement.end({ success: true });\n }\n else {\n atrMeasurement.discard();\n }\n return navigate;\n };\n // If logged in, emit acquire token events\n const isLoggedIn = this.getAllAccounts().length > 0;\n try {\n redirectPreflightCheck(this.initialized, this.config);\n this.browserStorage.setInteractionInProgress(true);\n if (isLoggedIn) {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_START, InteractionType.Redirect, request);\n }\n else {\n this.eventHandler.emitEvent(EventType.LOGIN_START, InteractionType.Redirect, request);\n }\n let result;\n if (this.nativeExtensionProvider && this.canUseNative(request)) {\n const nativeClient = new NativeInteractionClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, ApiId.acquireTokenRedirect, this.performanceClient, this.nativeExtensionProvider, this.getNativeAccountId(request), this.nativeInternalStorage, correlationId);\n result = nativeClient\n .acquireTokenRedirect(request, atrMeasurement)\n .catch((e) => {\n if (e instanceof NativeAuthError &&\n isFatalNativeAuthError(e)) {\n this.nativeExtensionProvider = undefined; // If extension gets uninstalled during session prevent future requests from continuing to attempt\n const redirectClient = this.createRedirectClient(correlationId);\n return redirectClient.acquireToken(request);\n }\n else if (e instanceof InteractionRequiredAuthError) {\n this.logger.verbose(\"acquireTokenRedirect - Resolving interaction required error thrown by native broker by falling back to web flow\");\n const redirectClient = this.createRedirectClient(correlationId);\n return redirectClient.acquireToken(request);\n }\n this.browserStorage.setInteractionInProgress(false);\n throw e;\n });\n }\n else {\n const redirectClient = this.createRedirectClient(correlationId);\n result = redirectClient.acquireToken(request);\n }\n return await result;\n }\n catch (e) {\n atrMeasurement.end({ success: false }, e);\n if (isLoggedIn) {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_FAILURE, InteractionType.Redirect, null, e);\n }\n else {\n this.eventHandler.emitEvent(EventType.LOGIN_FAILURE, InteractionType.Redirect, null, e);\n }\n throw e;\n }\n }\n // #endregion\n // #region Popup Flow\n /**\n * Use when you want to obtain an access_token for your API via opening a popup window in the user's browser\n *\n * @param request\n *\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n acquireTokenPopup(request) {\n const correlationId = this.getRequestCorrelationId(request);\n const atPopupMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.AcquireTokenPopup, correlationId);\n atPopupMeasurement.add({\n scenarioId: request.scenarioId,\n accountType: getAccountType(request.account),\n });\n try {\n this.logger.verbose(\"acquireTokenPopup called\", correlationId);\n preflightCheck(this.initialized, atPopupMeasurement);\n this.browserStorage.setInteractionInProgress(true);\n }\n catch (e) {\n // Since this function is syncronous we need to reject\n return Promise.reject(e);\n }\n // If logged in, emit acquire token events\n const loggedInAccounts = this.getAllAccounts();\n if (loggedInAccounts.length > 0) {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_START, InteractionType.Popup, request);\n }\n else {\n this.eventHandler.emitEvent(EventType.LOGIN_START, InteractionType.Popup, request);\n }\n let result;\n if (this.canUseNative(request)) {\n result = this.acquireTokenNative({\n ...request,\n correlationId,\n }, ApiId.acquireTokenPopup)\n .then((response) => {\n this.browserStorage.setInteractionInProgress(false);\n atPopupMeasurement.end({\n success: true,\n isNativeBroker: true,\n requestId: response.requestId,\n accountType: getAccountType(response.account),\n });\n return response;\n })\n .catch((e) => {\n if (e instanceof NativeAuthError &&\n isFatalNativeAuthError(e)) {\n this.nativeExtensionProvider = undefined; // If extension gets uninstalled during session prevent future requests from continuing to attempt\n const popupClient = this.createPopupClient(correlationId);\n return popupClient.acquireToken(request);\n }\n else if (e instanceof InteractionRequiredAuthError) {\n this.logger.verbose(\"acquireTokenPopup - Resolving interaction required error thrown by native broker by falling back to web flow\");\n const popupClient = this.createPopupClient(correlationId);\n return popupClient.acquireToken(request);\n }\n this.browserStorage.setInteractionInProgress(false);\n throw e;\n });\n }\n else {\n const popupClient = this.createPopupClient(correlationId);\n result = popupClient.acquireToken(request);\n }\n return result\n .then((result) => {\n /*\n * If logged in, emit acquire token events\n */\n const isLoggingIn = loggedInAccounts.length < this.getAllAccounts().length;\n if (isLoggingIn) {\n this.eventHandler.emitEvent(EventType.LOGIN_SUCCESS, InteractionType.Popup, result);\n }\n else {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_SUCCESS, InteractionType.Popup, result);\n }\n atPopupMeasurement.end({\n success: true,\n requestId: result.requestId,\n accessTokenSize: result.accessToken.length,\n idTokenSize: result.idToken.length,\n accountType: getAccountType(result.account),\n });\n return result;\n })\n .catch((e) => {\n if (loggedInAccounts.length > 0) {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_FAILURE, InteractionType.Popup, null, e);\n }\n else {\n this.eventHandler.emitEvent(EventType.LOGIN_FAILURE, InteractionType.Popup, null, e);\n }\n atPopupMeasurement.end({\n success: false,\n }, e);\n // Since this function is syncronous we need to reject\n return Promise.reject(e);\n });\n }\n trackPageVisibilityWithMeasurement() {\n const measurement = this.ssoSilentMeasurement ||\n this.acquireTokenByCodeAsyncMeasurement;\n if (!measurement) {\n return;\n }\n this.logger.info(\"Perf: Visibility change detected in \", measurement.event.name);\n measurement.increment({\n visibilityChangeCount: 1,\n });\n }\n // #endregion\n // #region Silent Flow\n /**\n * This function uses a hidden iframe to fetch an authorization code from the eSTS. There are cases where this may not work:\n * - Any browser using a form of Intelligent Tracking Prevention\n * - If there is not an established session with the service\n *\n * In these cases, the request must be done inside a popup or full frame redirect.\n *\n * For the cases where interaction is required, you cannot send a request with prompt=none.\n *\n * If your refresh token has expired, you can use this function to fetch a new set of tokens silently as long as\n * you session on the server still exists.\n * @param request {@link SsoSilentRequest}\n *\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n async ssoSilent(request) {\n const correlationId = this.getRequestCorrelationId(request);\n const validRequest = {\n ...request,\n // will be PromptValue.NONE or PromptValue.NO_SESSION\n prompt: request.prompt,\n correlationId: correlationId,\n };\n this.ssoSilentMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.SsoSilent, correlationId);\n this.ssoSilentMeasurement?.add({\n scenarioId: request.scenarioId,\n accountType: getAccountType(request.account),\n });\n preflightCheck(this.initialized, this.ssoSilentMeasurement);\n this.ssoSilentMeasurement?.increment({\n visibilityChangeCount: 0,\n });\n document.addEventListener(\"visibilitychange\", this.trackPageVisibilityWithMeasurement);\n this.logger.verbose(\"ssoSilent called\", correlationId);\n this.eventHandler.emitEvent(EventType.SSO_SILENT_START, InteractionType.Silent, validRequest);\n let result;\n if (this.canUseNative(validRequest)) {\n result = this.acquireTokenNative(validRequest, ApiId.ssoSilent).catch((e) => {\n // If native token acquisition fails for availability reasons fallback to standard flow\n if (e instanceof NativeAuthError && isFatalNativeAuthError(e)) {\n this.nativeExtensionProvider = undefined; // If extension gets uninstalled during session prevent future requests from continuing to attempt\n const silentIframeClient = this.createSilentIframeClient(validRequest.correlationId);\n return silentIframeClient.acquireToken(validRequest);\n }\n throw e;\n });\n }\n else {\n const silentIframeClient = this.createSilentIframeClient(validRequest.correlationId);\n result = silentIframeClient.acquireToken(validRequest);\n }\n return result\n .then((response) => {\n this.eventHandler.emitEvent(EventType.SSO_SILENT_SUCCESS, InteractionType.Silent, response);\n this.ssoSilentMeasurement?.end({\n success: true,\n isNativeBroker: response.fromNativeBroker,\n requestId: response.requestId,\n accessTokenSize: response.accessToken.length,\n idTokenSize: response.idToken.length,\n accountType: getAccountType(response.account),\n });\n return response;\n })\n .catch((e) => {\n this.eventHandler.emitEvent(EventType.SSO_SILENT_FAILURE, InteractionType.Silent, null, e);\n this.ssoSilentMeasurement?.end({\n success: false,\n }, e);\n throw e;\n })\n .finally(() => {\n document.removeEventListener(\"visibilitychange\", this.trackPageVisibilityWithMeasurement);\n });\n }\n /**\n * This function redeems an authorization code (passed as code) from the eSTS token endpoint.\n * This authorization code should be acquired server-side using a confidential client to acquire a spa_code.\n * This API is not indended for normal authorization code acquisition and redemption.\n *\n * Redemption of this authorization code will not require PKCE, as it was acquired by a confidential client.\n *\n * @param request {@link AuthorizationCodeRequest}\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n async acquireTokenByCode(request) {\n const correlationId = this.getRequestCorrelationId(request);\n this.logger.trace(\"acquireTokenByCode called\", correlationId);\n const atbcMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.AcquireTokenByCode, correlationId);\n preflightCheck(this.initialized, atbcMeasurement);\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_BY_CODE_START, InteractionType.Silent, request);\n atbcMeasurement.add({ scenarioId: request.scenarioId });\n try {\n if (request.code && request.nativeAccountId) {\n // Throw error in case server returns both spa_code and spa_accountid in exchange for auth code.\n throw createBrowserAuthError(spaCodeAndNativeAccountIdPresent);\n }\n else if (request.code) {\n const hybridAuthCode = request.code;\n let response = this.hybridAuthCodeResponses.get(hybridAuthCode);\n if (!response) {\n this.logger.verbose(\"Initiating new acquireTokenByCode request\", correlationId);\n response = this.acquireTokenByCodeAsync({\n ...request,\n correlationId,\n })\n .then((result) => {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_BY_CODE_SUCCESS, InteractionType.Silent, result);\n this.hybridAuthCodeResponses.delete(hybridAuthCode);\n atbcMeasurement.end({\n success: true,\n isNativeBroker: result.fromNativeBroker,\n requestId: result.requestId,\n accessTokenSize: result.accessToken.length,\n idTokenSize: result.idToken.length,\n accountType: getAccountType(result.account),\n });\n return result;\n })\n .catch((error) => {\n this.hybridAuthCodeResponses.delete(hybridAuthCode);\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_BY_CODE_FAILURE, InteractionType.Silent, null, error);\n atbcMeasurement.end({\n success: false,\n }, error);\n throw error;\n });\n this.hybridAuthCodeResponses.set(hybridAuthCode, response);\n }\n else {\n this.logger.verbose(\"Existing acquireTokenByCode request found\", correlationId);\n atbcMeasurement.discard();\n }\n return await response;\n }\n else if (request.nativeAccountId) {\n if (this.canUseNative(request, request.nativeAccountId)) {\n const result = await this.acquireTokenNative({\n ...request,\n correlationId,\n }, ApiId.acquireTokenByCode, request.nativeAccountId).catch((e) => {\n // If native token acquisition fails for availability reasons fallback to standard flow\n if (e instanceof NativeAuthError &&\n isFatalNativeAuthError(e)) {\n this.nativeExtensionProvider = undefined; // If extension gets uninstalled during session prevent future requests from continuing to attempt\n }\n throw e;\n });\n atbcMeasurement.end({\n accountType: getAccountType(result.account),\n success: true,\n });\n return result;\n }\n else {\n throw createBrowserAuthError(unableToAcquireTokenFromNativePlatform);\n }\n }\n else {\n throw createBrowserAuthError(authCodeOrNativeAccountIdRequired);\n }\n }\n catch (e) {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_BY_CODE_FAILURE, InteractionType.Silent, null, e);\n atbcMeasurement.end({\n success: false,\n }, e);\n throw e;\n }\n }\n /**\n * Creates a SilentAuthCodeClient to redeem an authorization code.\n * @param request\n * @returns Result of the operation to redeem the authorization code\n */\n async acquireTokenByCodeAsync(request) {\n this.logger.trace(\"acquireTokenByCodeAsync called\", request.correlationId);\n this.acquireTokenByCodeAsyncMeasurement =\n this.performanceClient.startMeasurement(PerformanceEvents.AcquireTokenByCodeAsync, request.correlationId);\n this.acquireTokenByCodeAsyncMeasurement?.increment({\n visibilityChangeCount: 0,\n });\n document.addEventListener(\"visibilitychange\", this.trackPageVisibilityWithMeasurement);\n const silentAuthCodeClient = this.createSilentAuthCodeClient(request.correlationId);\n const silentTokenResult = await silentAuthCodeClient\n .acquireToken(request)\n .then((response) => {\n this.acquireTokenByCodeAsyncMeasurement?.end({\n success: true,\n fromCache: response.fromCache,\n isNativeBroker: response.fromNativeBroker,\n requestId: response.requestId,\n });\n return response;\n })\n .catch((tokenRenewalError) => {\n this.acquireTokenByCodeAsyncMeasurement?.end({\n success: false,\n }, tokenRenewalError);\n throw tokenRenewalError;\n })\n .finally(() => {\n document.removeEventListener(\"visibilitychange\", this.trackPageVisibilityWithMeasurement);\n });\n return silentTokenResult;\n }\n /**\n * Attempt to acquire an access token from the cache\n * @param silentCacheClient SilentCacheClient\n * @param commonRequest CommonSilentFlowRequest\n * @param silentRequest SilentRequest\n * @returns A promise that, when resolved, returns the access token\n */\n async acquireTokenFromCache(commonRequest, cacheLookupPolicy) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.AcquireTokenFromCache, commonRequest.correlationId);\n switch (cacheLookupPolicy) {\n case CacheLookupPolicy.Default:\n case CacheLookupPolicy.AccessToken:\n case CacheLookupPolicy.AccessTokenAndRefreshToken:\n const silentCacheClient = this.createSilentCacheClient(commonRequest.correlationId);\n return invokeAsync(silentCacheClient.acquireToken.bind(silentCacheClient), PerformanceEvents.SilentCacheClientAcquireToken, this.logger, this.performanceClient, commonRequest.correlationId)(commonRequest);\n default:\n throw createClientAuthError(ClientAuthErrorCodes.tokenRefreshRequired);\n }\n }\n /**\n * Attempt to acquire an access token via a refresh token\n * @param commonRequest CommonSilentFlowRequest\n * @param cacheLookupPolicy CacheLookupPolicy\n * @returns A promise that, when resolved, returns the access token\n */\n async acquireTokenByRefreshToken(commonRequest, cacheLookupPolicy) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.AcquireTokenByRefreshToken, commonRequest.correlationId);\n switch (cacheLookupPolicy) {\n case CacheLookupPolicy.Default:\n case CacheLookupPolicy.AccessTokenAndRefreshToken:\n case CacheLookupPolicy.RefreshToken:\n case CacheLookupPolicy.RefreshTokenAndNetwork:\n const silentRefreshClient = this.createSilentRefreshClient(commonRequest.correlationId);\n return invokeAsync(silentRefreshClient.acquireToken.bind(silentRefreshClient), PerformanceEvents.SilentRefreshClientAcquireToken, this.logger, this.performanceClient, commonRequest.correlationId)(commonRequest);\n default:\n throw createClientAuthError(ClientAuthErrorCodes.tokenRefreshRequired);\n }\n }\n /**\n * Attempt to acquire an access token via an iframe\n * @param request CommonSilentFlowRequest\n * @returns A promise that, when resolved, returns the access token\n */\n async acquireTokenBySilentIframe(request) {\n this.performanceClient.addQueueMeasurement(PerformanceEvents.AcquireTokenBySilentIframe, request.correlationId);\n const silentIframeClient = this.createSilentIframeClient(request.correlationId);\n return invokeAsync(silentIframeClient.acquireToken.bind(silentIframeClient), PerformanceEvents.SilentIframeClientAcquireToken, this.logger, this.performanceClient, request.correlationId)(request);\n }\n // #endregion\n // #region Logout\n /**\n * Deprecated logout function. Use logoutRedirect or logoutPopup instead\n * @param logoutRequest\n * @deprecated\n */\n async logout(logoutRequest) {\n const correlationId = this.getRequestCorrelationId(logoutRequest);\n this.logger.warning(\"logout API is deprecated and will be removed in msal-browser v3.0.0. Use logoutRedirect instead.\", correlationId);\n return this.logoutRedirect({\n correlationId,\n ...logoutRequest,\n });\n }\n /**\n * Use to log out the current user, and redirect the user to the postLogoutRedirectUri.\n * Default behaviour is to redirect the user to `window.location.href`.\n * @param logoutRequest\n */\n async logoutRedirect(logoutRequest) {\n const correlationId = this.getRequestCorrelationId(logoutRequest);\n redirectPreflightCheck(this.initialized, this.config);\n this.browserStorage.setInteractionInProgress(true);\n const redirectClient = this.createRedirectClient(correlationId);\n return redirectClient.logout(logoutRequest);\n }\n /**\n * Clears local cache for the current user then opens a popup window prompting the user to sign-out of the server\n * @param logoutRequest\n */\n logoutPopup(logoutRequest) {\n try {\n const correlationId = this.getRequestCorrelationId(logoutRequest);\n preflightCheck$1(this.initialized);\n this.browserStorage.setInteractionInProgress(true);\n const popupClient = this.createPopupClient(correlationId);\n return popupClient.logout(logoutRequest);\n }\n catch (e) {\n // Since this function is syncronous we need to reject\n return Promise.reject(e);\n }\n }\n /**\n * Creates a cache interaction client to clear broswer cache.\n * @param logoutRequest\n */\n async clearCache(logoutRequest) {\n const correlationId = this.getRequestCorrelationId(logoutRequest);\n const cacheClient = this.createSilentCacheClient(correlationId);\n return cacheClient.logout(logoutRequest);\n }\n // #endregion\n // #region Account APIs\n /**\n * Returns all the accounts in the cache that match the optional filter. If no filter is provided, all accounts are returned.\n * @param accountFilter - (Optional) filter to narrow down the accounts returned\n * @returns Array of AccountInfo objects in cache\n */\n getAllAccounts(accountFilter) {\n return getAllAccounts(this.logger, this.browserStorage, this.isBrowserEnvironment, accountFilter);\n }\n /**\n * Returns the first account found in the cache that matches the account filter passed in.\n * @param accountFilter\n * @returns The first account found in the cache matching the provided filter or null if no account could be found.\n */\n getAccount(accountFilter) {\n return getAccount(accountFilter, this.logger, this.browserStorage);\n }\n /**\n * Returns the signed in account matching username.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found.\n * This API is provided for convenience but getAccountById should be used for best reliability\n * @param username\n * @returns The account object stored in MSAL\n */\n getAccountByUsername(username) {\n return getAccountByUsername(username, this.logger, this.browserStorage);\n }\n /**\n * Returns the signed in account matching homeAccountId.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found\n * @param homeAccountId\n * @returns The account object stored in MSAL\n */\n getAccountByHomeId(homeAccountId) {\n return getAccountByHomeId(homeAccountId, this.logger, this.browserStorage);\n }\n /**\n * Returns the signed in account matching localAccountId.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found\n * @param localAccountId\n * @returns The account object stored in MSAL\n */\n getAccountByLocalId(localAccountId) {\n return getAccountByLocalId(localAccountId, this.logger, this.browserStorage);\n }\n /**\n * Sets the account to use as the active account. If no account is passed to the acquireToken APIs, then MSAL will use this active account.\n * @param account\n */\n setActiveAccount(account) {\n setActiveAccount(account, this.browserStorage);\n }\n /**\n * Gets the currently active account\n */\n getActiveAccount() {\n return getActiveAccount(this.browserStorage);\n }\n // #endregion\n /**\n * Hydrates the cache with the tokens from an AuthenticationResult\n * @param result\n * @param request\n * @returns\n */\n async hydrateCache(result, request) {\n this.logger.verbose(\"hydrateCache called\");\n // Account gets saved to browser storage regardless of native or not\n const accountEntity = AccountEntity.createFromAccountInfo(result.account, result.cloudGraphHostName, result.msGraphHost);\n this.browserStorage.setAccount(accountEntity);\n if (result.fromNativeBroker) {\n this.logger.verbose(\"Response was from native broker, storing in-memory\");\n // Tokens from native broker are stored in-memory\n return this.nativeInternalStorage.hydrateCache(result, request);\n }\n else {\n return this.browserStorage.hydrateCache(result, request);\n }\n }\n // #region Helpers\n /**\n * Acquire a token from native device (e.g. WAM)\n * @param request\n */\n async acquireTokenNative(request, apiId, accountId) {\n this.logger.trace(\"acquireTokenNative called\");\n if (!this.nativeExtensionProvider) {\n throw createBrowserAuthError(nativeConnectionNotEstablished);\n }\n const nativeClient = new NativeInteractionClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, apiId, this.performanceClient, this.nativeExtensionProvider, accountId || this.getNativeAccountId(request), this.nativeInternalStorage, request.correlationId);\n return nativeClient.acquireToken(request);\n }\n /**\n * Returns boolean indicating if this request can use the native broker\n * @param request\n */\n canUseNative(request, accountId) {\n this.logger.trace(\"canUseNative called\");\n if (!NativeMessageHandler.isNativeAvailable(this.config, this.logger, this.nativeExtensionProvider, request.authenticationScheme)) {\n this.logger.trace(\"canUseNative: isNativeAvailable returned false, returning false\");\n return false;\n }\n if (request.prompt) {\n switch (request.prompt) {\n case PromptValue.NONE:\n case PromptValue.CONSENT:\n case PromptValue.LOGIN:\n this.logger.trace(\"canUseNative: prompt is compatible with native flow\");\n break;\n default:\n this.logger.trace(`canUseNative: prompt = ${request.prompt} is not compatible with native flow, returning false`);\n return false;\n }\n }\n if (!accountId && !this.getNativeAccountId(request)) {\n this.logger.trace(\"canUseNative: nativeAccountId is not available, returning false\");\n return false;\n }\n return true;\n }\n /**\n * Get the native accountId from the account\n * @param request\n * @returns\n */\n getNativeAccountId(request) {\n const account = request.account ||\n this.getAccount({\n loginHint: request.loginHint,\n sid: request.sid,\n }) ||\n this.getActiveAccount();\n return (account && account.nativeAccountId) || \"\";\n }\n /**\n * Returns new instance of the Popup Interaction Client\n * @param correlationId\n */\n createPopupClient(correlationId) {\n return new PopupClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, this.performanceClient, this.nativeInternalStorage, this.nativeExtensionProvider, correlationId);\n }\n /**\n * Returns new instance of the Redirect Interaction Client\n * @param correlationId\n */\n createRedirectClient(correlationId) {\n return new RedirectClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, this.performanceClient, this.nativeInternalStorage, this.nativeExtensionProvider, correlationId);\n }\n /**\n * Returns new instance of the Silent Iframe Interaction Client\n * @param correlationId\n */\n createSilentIframeClient(correlationId) {\n return new SilentIframeClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, ApiId.ssoSilent, this.performanceClient, this.nativeInternalStorage, this.nativeExtensionProvider, correlationId);\n }\n /**\n * Returns new instance of the Silent Cache Interaction Client\n */\n createSilentCacheClient(correlationId) {\n return new SilentCacheClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, this.performanceClient, this.nativeExtensionProvider, correlationId);\n }\n /**\n * Returns new instance of the Silent Refresh Interaction Client\n */\n createSilentRefreshClient(correlationId) {\n return new SilentRefreshClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, this.performanceClient, this.nativeExtensionProvider, correlationId);\n }\n /**\n * Returns new instance of the Silent AuthCode Interaction Client\n */\n createSilentAuthCodeClient(correlationId) {\n return new SilentAuthCodeClient(this.config, this.browserStorage, this.browserCrypto, this.logger, this.eventHandler, this.navigationClient, ApiId.acquireTokenByCode, this.performanceClient, this.nativeExtensionProvider, correlationId);\n }\n /**\n * Adds event callbacks to array\n * @param callback\n */\n addEventCallback(callback) {\n return this.eventHandler.addEventCallback(callback);\n }\n /**\n * Removes callback with provided id from callback array\n * @param callbackId\n */\n removeEventCallback(callbackId) {\n this.eventHandler.removeEventCallback(callbackId);\n }\n /**\n * Registers a callback to receive performance events.\n *\n * @param {PerformanceCallbackFunction} callback\n * @returns {string}\n */\n addPerformanceCallback(callback) {\n return this.performanceClient.addPerformanceCallback(callback);\n }\n /**\n * Removes a callback registered with addPerformanceCallback.\n *\n * @param {string} callbackId\n * @returns {boolean}\n */\n removePerformanceCallback(callbackId) {\n return this.performanceClient.removePerformanceCallback(callbackId);\n }\n /**\n * Adds event listener that emits an event when a user account is added or removed from localstorage in a different browser tab or window\n */\n enableAccountStorageEvents() {\n this.eventHandler.enableAccountStorageEvents();\n }\n /**\n * Removes event listener that emits an event when a user account is added or removed from localstorage in a different browser tab or window\n */\n disableAccountStorageEvents() {\n this.eventHandler.disableAccountStorageEvents();\n }\n /**\n * Gets the token cache for the application.\n */\n getTokenCache() {\n return this.tokenCache;\n }\n /**\n * Returns the logger instance\n */\n getLogger() {\n return this.logger;\n }\n /**\n * Replaces the default logger set in configurations with new Logger with new configurations\n * @param logger Logger instance\n */\n setLogger(logger) {\n this.logger = logger;\n }\n /**\n * Called by wrapper libraries (Angular & React) to set SKU and Version passed down to telemetry, logger, etc.\n * @param sku\n * @param version\n */\n initializeWrapperLibrary(sku, version) {\n // Validate the SKU passed in is one we expect\n this.browserStorage.setWrapperMetadata(sku, version);\n }\n /**\n * Sets navigation client\n * @param navigationClient\n */\n setNavigationClient(navigationClient) {\n this.navigationClient = navigationClient;\n }\n /**\n * Returns the configuration object\n */\n getConfiguration() {\n return this.config;\n }\n /**\n * Returns the performance client\n */\n getPerformanceClient() {\n return this.performanceClient;\n }\n /**\n * Returns the browser env indicator\n */\n isBrowserEnv() {\n return this.isBrowserEnvironment;\n }\n /**\n * Returns the event handler\n */\n getEventHandler() {\n return this.eventHandler;\n }\n /**\n * Generates a correlation id for a request if none is provided.\n *\n * @protected\n * @param {?Partial} [request]\n * @returns {string}\n */\n getRequestCorrelationId(request) {\n if (request?.correlationId) {\n return request.correlationId;\n }\n if (this.isBrowserEnvironment) {\n return createNewGuid();\n }\n /*\n * Included for fallback for non-browser environments,\n * and to ensure this method always returns a string.\n */\n return Constants.EMPTY_STRING;\n }\n // #endregion\n /**\n * Use when initiating the login process by redirecting the user's browser to the authorization endpoint. This function redirects the page, so\n * any code that follows this function will not execute.\n *\n * IMPORTANT: It is NOT recommended to have code that is dependent on the resolution of the Promise. This function will navigate away from the current\n * browser window. It currently returns a Promise in order to reflect the asynchronous nature of the code running in this function.\n *\n * @param request\n */\n async loginRedirect(request) {\n const correlationId = this.getRequestCorrelationId(request);\n this.logger.verbose(\"loginRedirect called\", correlationId);\n return this.acquireTokenRedirect({\n correlationId,\n ...(request || DEFAULT_REQUEST),\n });\n }\n /**\n * Use when initiating the login process via opening a popup window in the user's browser\n *\n * @param request\n *\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n loginPopup(request) {\n const correlationId = this.getRequestCorrelationId(request);\n this.logger.verbose(\"loginPopup called\", correlationId);\n return this.acquireTokenPopup({\n correlationId,\n ...(request || DEFAULT_REQUEST),\n });\n }\n /**\n * Silently acquire an access token for a given set of scopes. Returns currently processing promise if parallel requests are made.\n *\n * @param {@link (SilentRequest:type)}\n * @returns {Promise.} - a promise that is fulfilled when this function has completed, or rejected if an error was raised. Returns the {@link AuthResponse} object\n */\n async acquireTokenSilent(request) {\n const correlationId = this.getRequestCorrelationId(request);\n const atsMeasurement = this.performanceClient.startMeasurement(PerformanceEvents.AcquireTokenSilent, correlationId);\n atsMeasurement.add({\n cacheLookupPolicy: request.cacheLookupPolicy,\n scenarioId: request.scenarioId,\n });\n preflightCheck(this.initialized, atsMeasurement);\n this.logger.verbose(\"acquireTokenSilent called\", correlationId);\n const account = request.account || this.getActiveAccount();\n if (!account) {\n throw createBrowserAuthError(noAccountError);\n }\n atsMeasurement.add({ accountType: getAccountType(account) });\n const thumbprint = {\n clientId: this.config.auth.clientId,\n authority: request.authority || Constants.EMPTY_STRING,\n scopes: request.scopes,\n homeAccountIdentifier: account.homeAccountId,\n claims: request.claims,\n authenticationScheme: request.authenticationScheme,\n resourceRequestMethod: request.resourceRequestMethod,\n resourceRequestUri: request.resourceRequestUri,\n shrClaims: request.shrClaims,\n sshKid: request.sshKid,\n shrOptions: request.shrOptions,\n };\n const silentRequestKey = JSON.stringify(thumbprint);\n const cachedResponse = this.activeSilentTokenRequests.get(silentRequestKey);\n if (typeof cachedResponse === \"undefined\") {\n this.logger.verbose(\"acquireTokenSilent called for the first time, storing active request\", correlationId);\n const response = invokeAsync(this.acquireTokenSilentAsync.bind(this), PerformanceEvents.AcquireTokenSilentAsync, this.logger, this.performanceClient, correlationId)({\n ...request,\n correlationId,\n }, account)\n .then((result) => {\n this.activeSilentTokenRequests.delete(silentRequestKey);\n atsMeasurement.end({\n success: true,\n fromCache: result.fromCache,\n isNativeBroker: result.fromNativeBroker,\n cacheLookupPolicy: request.cacheLookupPolicy,\n requestId: result.requestId,\n accessTokenSize: result.accessToken.length,\n idTokenSize: result.idToken.length,\n });\n return result;\n })\n .catch((error) => {\n this.activeSilentTokenRequests.delete(silentRequestKey);\n atsMeasurement.end({\n success: false,\n }, error);\n throw error;\n });\n this.activeSilentTokenRequests.set(silentRequestKey, response);\n return {\n ...(await response),\n state: request.state,\n };\n }\n else {\n this.logger.verbose(\"acquireTokenSilent has been called previously, returning the result from the first call\", correlationId);\n // Discard measurements for memoized calls, as they are usually only a couple of ms and will artificially deflate metrics\n atsMeasurement.discard();\n return {\n ...(await cachedResponse),\n state: request.state,\n };\n }\n }\n /**\n * Silently acquire an access token for a given set of scopes. Will use cached token if available, otherwise will attempt to acquire a new token from the network via refresh token.\n * @param {@link (SilentRequest:type)}\n * @param {@link (AccountInfo:type)}\n * @returns {Promise.} - a promise that is fulfilled when this function has completed, or rejected if an error was raised. Returns the {@link AuthResponse}\n */\n async acquireTokenSilentAsync(request, account) {\n const trackPageVisibility = () => this.trackPageVisibility(request.correlationId);\n this.performanceClient.addQueueMeasurement(PerformanceEvents.AcquireTokenSilentAsync, request.correlationId);\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_START, InteractionType.Silent, request);\n if (request.correlationId) {\n this.performanceClient.incrementFields({ visibilityChangeCount: 0 }, request.correlationId);\n }\n document.addEventListener(\"visibilitychange\", trackPageVisibility);\n const silentRequest = await invokeAsync(initializeSilentRequest, PerformanceEvents.InitializeSilentRequest, this.logger, this.performanceClient, request.correlationId)(request, account, this.config, this.performanceClient, this.logger);\n const cacheLookupPolicy = request.cacheLookupPolicy || CacheLookupPolicy.Default;\n const result = this.acquireTokenSilentNoIframe(silentRequest, cacheLookupPolicy).catch(async (refreshTokenError) => {\n const shouldTryToResolveSilently = checkIfRefreshTokenErrorCanBeResolvedSilently(refreshTokenError, cacheLookupPolicy);\n if (shouldTryToResolveSilently) {\n if (!this.activeIframeRequest) {\n let _resolve;\n // Always set the active request tracker immediately after checking it to prevent races\n this.activeIframeRequest = [\n new Promise((resolve) => {\n _resolve = resolve;\n }),\n silentRequest.correlationId,\n ];\n this.logger.verbose(\"Refresh token expired/invalid or CacheLookupPolicy is set to Skip, attempting acquire token by iframe.\", silentRequest.correlationId);\n return invokeAsync(this.acquireTokenBySilentIframe.bind(this), PerformanceEvents.AcquireTokenBySilentIframe, this.logger, this.performanceClient, silentRequest.correlationId)(silentRequest)\n .then((iframeResult) => {\n _resolve(true);\n return iframeResult;\n })\n .catch((e) => {\n _resolve(false);\n throw e;\n })\n .finally(() => {\n this.activeIframeRequest = undefined;\n });\n }\n else if (cacheLookupPolicy !== CacheLookupPolicy.Skip) {\n const [activePromise, activeCorrelationId] = this.activeIframeRequest;\n this.logger.verbose(`Iframe request is already in progress, awaiting resolution for request with correlationId: ${activeCorrelationId}`, silentRequest.correlationId);\n const awaitConcurrentIframeMeasure = this.performanceClient.startMeasurement(PerformanceEvents.AwaitConcurrentIframe, silentRequest.correlationId);\n awaitConcurrentIframeMeasure.add({\n awaitIframeCorrelationId: activeCorrelationId,\n });\n const activePromiseResult = await activePromise;\n awaitConcurrentIframeMeasure.end({\n success: activePromiseResult,\n });\n if (activePromiseResult) {\n this.logger.verbose(`Parallel iframe request with correlationId: ${activeCorrelationId} succeeded. Retrying cache and/or RT redemption`, silentRequest.correlationId);\n // Retry cache lookup and/or RT exchange after iframe completes\n return this.acquireTokenSilentNoIframe(silentRequest, cacheLookupPolicy);\n }\n else {\n this.logger.info(`Iframe request with correlationId: ${activeCorrelationId} failed. Interaction is required.`);\n // If previous iframe request failed, it's unlikely to succeed this time. Throw original error.\n throw refreshTokenError;\n }\n }\n else {\n // Cache policy set to skip and another iframe request is already in progress\n this.logger.warning(\"Another iframe request is currently in progress and CacheLookupPolicy is set to Skip. This may result in degraded performance and/or reliability for both calls. Please consider changing the CacheLookupPolicy to take advantage of request queuing and token cache.\", silentRequest.correlationId);\n return invokeAsync(this.acquireTokenBySilentIframe.bind(this), PerformanceEvents.AcquireTokenBySilentIframe, this.logger, this.performanceClient, silentRequest.correlationId)(silentRequest);\n }\n }\n else {\n // Error cannot be silently resolved or iframe renewal is not allowed, interaction required\n throw refreshTokenError;\n }\n });\n return result\n .then((response) => {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_SUCCESS, InteractionType.Silent, response);\n if (request.correlationId) {\n this.performanceClient.addFields({\n fromCache: response.fromCache,\n isNativeBroker: response.fromNativeBroker,\n requestId: response.requestId,\n }, request.correlationId);\n }\n return response;\n })\n .catch((tokenRenewalError) => {\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_FAILURE, InteractionType.Silent, null, tokenRenewalError);\n throw tokenRenewalError;\n })\n .finally(() => {\n document.removeEventListener(\"visibilitychange\", trackPageVisibility);\n });\n }\n /**\n * AcquireTokenSilent without the iframe fallback. This is used to enable the correct fallbacks in cases where there's a potential for multiple silent requests to be made in parallel and prevent those requests from making concurrent iframe requests.\n * @param silentRequest\n * @param cacheLookupPolicy\n * @returns\n */\n async acquireTokenSilentNoIframe(silentRequest, cacheLookupPolicy) {\n if (NativeMessageHandler.isNativeAvailable(this.config, this.logger, this.nativeExtensionProvider, silentRequest.authenticationScheme) &&\n silentRequest.account.nativeAccountId) {\n this.logger.verbose(\"acquireTokenSilent - attempting to acquire token from native platform\");\n return this.acquireTokenNative(silentRequest, ApiId.acquireTokenSilent_silentFlow).catch(async (e) => {\n // If native token acquisition fails for availability reasons fallback to web flow\n if (e instanceof NativeAuthError && isFatalNativeAuthError(e)) {\n this.logger.verbose(\"acquireTokenSilent - native platform unavailable, falling back to web flow\");\n this.nativeExtensionProvider = undefined; // Prevent future requests from continuing to attempt\n // Cache will not contain tokens, given that previous WAM requests succeeded. Skip cache and RT renewal and go straight to iframe renewal\n throw createClientAuthError(ClientAuthErrorCodes.tokenRefreshRequired);\n }\n throw e;\n });\n }\n else {\n this.logger.verbose(\"acquireTokenSilent - attempting to acquire token from web flow\");\n return invokeAsync(this.acquireTokenFromCache.bind(this), PerformanceEvents.AcquireTokenFromCache, this.logger, this.performanceClient, silentRequest.correlationId)(silentRequest, cacheLookupPolicy).catch((cacheError) => {\n if (cacheLookupPolicy === CacheLookupPolicy.AccessToken) {\n throw cacheError;\n }\n this.eventHandler.emitEvent(EventType.ACQUIRE_TOKEN_NETWORK_START, InteractionType.Silent, silentRequest);\n return invokeAsync(this.acquireTokenByRefreshToken.bind(this), PerformanceEvents.AcquireTokenByRefreshToken, this.logger, this.performanceClient, silentRequest.correlationId)(silentRequest, cacheLookupPolicy);\n });\n }\n }\n}\n/**\n * Determines whether an error thrown by the refresh token endpoint can be resolved without interaction\n * @param refreshTokenError\n * @param silentRequest\n * @param cacheLookupPolicy\n * @returns\n */\nfunction checkIfRefreshTokenErrorCanBeResolvedSilently(refreshTokenError, cacheLookupPolicy) {\n const noInteractionRequired = !(refreshTokenError instanceof InteractionRequiredAuthError &&\n // For refresh token errors, bad_token does not always require interaction (silently resolvable)\n refreshTokenError.subError !==\n InteractionRequiredAuthErrorCodes.badToken);\n // Errors that result when the refresh token needs to be replaced\n const refreshTokenRefreshRequired = refreshTokenError.errorCode === BrowserConstants.INVALID_GRANT_ERROR ||\n refreshTokenError.errorCode ===\n ClientAuthErrorCodes.tokenRefreshRequired;\n // Errors that may be resolved before falling back to interaction (through iframe renewal)\n const isSilentlyResolvable = (noInteractionRequired && refreshTokenRefreshRequired) ||\n refreshTokenError.errorCode ===\n InteractionRequiredAuthErrorCodes.noTokensFound ||\n refreshTokenError.errorCode ===\n InteractionRequiredAuthErrorCodes.refreshTokenExpired;\n // Only these policies allow for an iframe renewal attempt\n const tryIframeRenewal = iFrameRenewalPolicies.includes(cacheLookupPolicy);\n return isSilentlyResolvable && tryIframeRenewal;\n}\n\nexport { StandardController };\n//# sourceMappingURL=StandardController.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { NestedAppOperatingContext } from '../operatingcontext/NestedAppOperatingContext.mjs';\nimport { StandardOperatingContext } from '../operatingcontext/StandardOperatingContext.mjs';\nimport { StandardController } from './StandardController.mjs';\nimport { NestedAppAuthController } from './NestedAppAuthController.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\nasync function createV3Controller(config, request) {\n const standard = new StandardOperatingContext(config);\n await standard.initialize();\n return StandardController.createController(standard, request);\n}\nasync function createController(config) {\n const standard = new StandardOperatingContext(config);\n const nestedApp = new NestedAppOperatingContext(config);\n const operatingContexts = [standard.initialize(), nestedApp.initialize()];\n await Promise.all(operatingContexts);\n if (nestedApp.isAvailable() && config.auth.supportsNestedAppAuth) {\n return NestedAppAuthController.createController(nestedApp);\n }\n else if (standard.isAvailable()) {\n return StandardController.createController(standard);\n }\n else {\n // Since neither of the actual operating contexts are available keep the UnknownOperatingContextController\n return null;\n }\n}\n\nexport { createController, createV3Controller };\n//# sourceMappingURL=ControllerFactory.mjs.map\n","/*! @azure/msal-browser v3.19.1 2024-07-16 */\n'use strict';\nimport { createV3Controller } from '../controllers/ControllerFactory.mjs';\nimport { StandardController } from '../controllers/StandardController.mjs';\nimport { StandardOperatingContext } from '../operatingcontext/StandardOperatingContext.mjs';\nimport { NestedAppAuthController } from '../controllers/NestedAppAuthController.mjs';\nimport { NestedAppOperatingContext } from '../operatingcontext/NestedAppOperatingContext.mjs';\n\n/*\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n */\n/**\n * The PublicClientApplication class is the object exposed by the library to perform authentication and authorization functions in Single Page Applications\n * to obtain JWT tokens as described in the OAuth 2.0 Authorization Code Flow with PKCE specification.\n */\nclass PublicClientApplication {\n /**\n * Creates StandardController and passes it to the PublicClientApplication\n *\n * @param configuration {Configuration}\n */\n static async createPublicClientApplication(configuration) {\n const controller = await createV3Controller(configuration);\n const pca = new PublicClientApplication(configuration, controller);\n return pca;\n }\n /**\n * @constructor\n * Constructor for the PublicClientApplication used to instantiate the PublicClientApplication object\n *\n * Important attributes in the Configuration object for auth are:\n * - clientID: the application ID of your application. You can obtain one by registering your application with our Application registration portal : https://portal.azure.com/#blade/Microsoft_AAD_IAM/ActiveDirectoryMenuBlade/RegisteredAppsPreview\n * - authority: the authority URL for your application.\n * - redirect_uri: the uri of your application registered in the portal.\n *\n * In Azure AD, authority is a URL indicating the Azure active directory that MSAL uses to obtain tokens.\n * It is of the form https://login.microsoftonline.com/{Enter_the_Tenant_Info_Here}\n * If your application supports Accounts in one organizational directory, replace \"Enter_the_Tenant_Info_Here\" value with the Tenant Id or Tenant name (for example, contoso.microsoft.com).\n * If your application supports Accounts in any organizational directory, replace \"Enter_the_Tenant_Info_Here\" value with organizations.\n * If your application supports Accounts in any organizational directory and personal Microsoft accounts, replace \"Enter_the_Tenant_Info_Here\" value with common.\n * To restrict support to Personal Microsoft accounts only, replace \"Enter_the_Tenant_Info_Here\" value with consumers.\n *\n * In Azure B2C, authority is of the form https://{instance}/tfp/{tenant}/{policyName}/\n * Full B2C functionality will be available in this library in future versions.\n *\n * @param configuration Object for the MSAL PublicClientApplication instance\n * @param IController Optional parameter to explictly set the controller. (Will be removed when we remove public constructor)\n */\n constructor(configuration, controller) {\n this.controller =\n controller ||\n new StandardController(new StandardOperatingContext(configuration));\n }\n /**\n * Initializer function to perform async startup tasks such as connecting to WAM extension\n * @param request {?InitializeApplicationRequest}\n */\n async initialize(request) {\n return this.controller.initialize(request);\n }\n /**\n * Use when you want to obtain an access_token for your API via opening a popup window in the user's browser\n *\n * @param request\n *\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n async acquireTokenPopup(request) {\n return this.controller.acquireTokenPopup(request);\n }\n /**\n * Use when you want to obtain an access_token for your API by redirecting the user's browser window to the authorization endpoint. This function redirects\n * the page, so any code that follows this function will not execute.\n *\n * IMPORTANT: It is NOT recommended to have code that is dependent on the resolution of the Promise. This function will navigate away from the current\n * browser window. It currently returns a Promise in order to reflect the asynchronous nature of the code running in this function.\n *\n * @param request\n */\n acquireTokenRedirect(request) {\n return this.controller.acquireTokenRedirect(request);\n }\n /**\n * Silently acquire an access token for a given set of scopes. Returns currently processing promise if parallel requests are made.\n *\n * @param {@link (SilentRequest:type)}\n * @returns {Promise.} - a promise that is fulfilled when this function has completed, or rejected if an error was raised. Returns the {@link AuthenticationResult} object\n */\n acquireTokenSilent(silentRequest) {\n return this.controller.acquireTokenSilent(silentRequest);\n }\n /**\n * This function redeems an authorization code (passed as code) from the eSTS token endpoint.\n * This authorization code should be acquired server-side using a confidential client to acquire a spa_code.\n * This API is not indended for normal authorization code acquisition and redemption.\n *\n * Redemption of this authorization code will not require PKCE, as it was acquired by a confidential client.\n *\n * @param request {@link AuthorizationCodeRequest}\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n acquireTokenByCode(request) {\n return this.controller.acquireTokenByCode(request);\n }\n /**\n * Adds event callbacks to array\n * @param callback\n */\n addEventCallback(callback) {\n return this.controller.addEventCallback(callback);\n }\n /**\n * Removes callback with provided id from callback array\n * @param callbackId\n */\n removeEventCallback(callbackId) {\n return this.controller.removeEventCallback(callbackId);\n }\n /**\n * Registers a callback to receive performance events.\n *\n * @param {PerformanceCallbackFunction} callback\n * @returns {string}\n */\n addPerformanceCallback(callback) {\n return this.controller.addPerformanceCallback(callback);\n }\n /**\n * Removes a callback registered with addPerformanceCallback.\n *\n * @param {string} callbackId\n * @returns {boolean}\n */\n removePerformanceCallback(callbackId) {\n return this.controller.removePerformanceCallback(callbackId);\n }\n /**\n * Adds event listener that emits an event when a user account is added or removed from localstorage in a different browser tab or window\n */\n enableAccountStorageEvents() {\n this.controller.enableAccountStorageEvents();\n }\n /**\n * Removes event listener that emits an event when a user account is added or removed from localstorage in a different browser tab or window\n */\n disableAccountStorageEvents() {\n this.controller.disableAccountStorageEvents();\n }\n /**\n * Returns the first account found in the cache that matches the account filter passed in.\n * @param accountFilter\n * @returns The first account found in the cache matching the provided filter or null if no account could be found.\n */\n getAccount(accountFilter) {\n return this.controller.getAccount(accountFilter);\n }\n /**\n * Returns the signed in account matching homeAccountId.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found\n * @param homeAccountId\n * @returns The account object stored in MSAL\n * @deprecated - Use getAccount instead\n */\n getAccountByHomeId(homeAccountId) {\n return this.controller.getAccountByHomeId(homeAccountId);\n }\n /**\n * Returns the signed in account matching localAccountId.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found\n * @param localAccountId\n * @returns The account object stored in MSAL\n * @deprecated - Use getAccount instead\n */\n getAccountByLocalId(localId) {\n return this.controller.getAccountByLocalId(localId);\n }\n /**\n * Returns the signed in account matching username.\n * (the account object is created at the time of successful login)\n * or null when no matching account is found.\n * This API is provided for convenience but getAccountById should be used for best reliability\n * @param userName\n * @returns The account object stored in MSAL\n * @deprecated - Use getAccount instead\n */\n getAccountByUsername(userName) {\n return this.controller.getAccountByUsername(userName);\n }\n /**\n * Returns all the accounts in the cache that match the optional filter. If no filter is provided, all accounts are returned.\n * @param accountFilter - (Optional) filter to narrow down the accounts returned\n * @returns Array of AccountInfo objects in cache\n */\n getAllAccounts(accountFilter) {\n return this.controller.getAllAccounts(accountFilter);\n }\n /**\n * Event handler function which allows users to fire events after the PublicClientApplication object\n * has loaded during redirect flows. This should be invoked on all page loads involved in redirect\n * auth flows.\n * @param hash Hash to process. Defaults to the current value of window.location.hash. Only needs to be provided explicitly if the response to be handled is not contained in the current value.\n * @returns Token response or null. If the return value is null, then no auth redirect was detected.\n */\n handleRedirectPromise(hash) {\n return this.controller.handleRedirectPromise(hash);\n }\n /**\n * Use when initiating the login process via opening a popup window in the user's browser\n *\n * @param request\n *\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n loginPopup(request) {\n return this.controller.loginPopup(request);\n }\n /**\n * Use when initiating the login process by redirecting the user's browser to the authorization endpoint. This function redirects the page, so\n * any code that follows this function will not execute.\n *\n * IMPORTANT: It is NOT recommended to have code that is dependent on the resolution of the Promise. This function will navigate away from the current\n * browser window. It currently returns a Promise in order to reflect the asynchronous nature of the code running in this function.\n *\n * @param request\n */\n loginRedirect(request) {\n return this.controller.loginRedirect(request);\n }\n /**\n * Deprecated logout function. Use logoutRedirect or logoutPopup instead\n * @param logoutRequest\n * @deprecated\n */\n logout(logoutRequest) {\n return this.controller.logout(logoutRequest);\n }\n /**\n * Use to log out the current user, and redirect the user to the postLogoutRedirectUri.\n * Default behaviour is to redirect the user to `window.location.href`.\n * @param logoutRequest\n */\n logoutRedirect(logoutRequest) {\n return this.controller.logoutRedirect(logoutRequest);\n }\n /**\n * Clears local cache for the current user then opens a popup window prompting the user to sign-out of the server\n * @param logoutRequest\n */\n logoutPopup(logoutRequest) {\n return this.controller.logoutPopup(logoutRequest);\n }\n /**\n * This function uses a hidden iframe to fetch an authorization code from the eSTS. There are cases where this may not work:\n * - Any browser using a form of Intelligent Tracking Prevention\n * - If there is not an established session with the service\n *\n * In these cases, the request must be done inside a popup or full frame redirect.\n *\n * For the cases where interaction is required, you cannot send a request with prompt=none.\n *\n * If your refresh token has expired, you can use this function to fetch a new set of tokens silently as long as\n * you session on the server still exists.\n * @param request {@link SsoSilentRequest}\n *\n * @returns A promise that is fulfilled when this function has completed, or rejected if an error was raised.\n */\n ssoSilent(request) {\n return this.controller.ssoSilent(request);\n }\n /**\n * Gets the token cache for the application.\n */\n getTokenCache() {\n return this.controller.getTokenCache();\n }\n /**\n * Returns the logger instance\n */\n getLogger() {\n return this.controller.getLogger();\n }\n /**\n * Replaces the default logger set in configurations with new Logger with new configurations\n * @param logger Logger instance\n */\n setLogger(logger) {\n this.controller.setLogger(logger);\n }\n /**\n * Sets the account to use as the active account. If no account is passed to the acquireToken APIs, then MSAL will use this active account.\n * @param account\n */\n setActiveAccount(account) {\n this.controller.setActiveAccount(account);\n }\n /**\n * Gets the currently active account\n */\n getActiveAccount() {\n return this.controller.getActiveAccount();\n }\n /**\n * Called by wrapper libraries (Angular & React) to set SKU and Version passed down to telemetry, logger, etc.\n * @param sku\n * @param version\n */\n initializeWrapperLibrary(sku, version) {\n return this.controller.initializeWrapperLibrary(sku, version);\n }\n /**\n * Sets navigation client\n * @param navigationClient\n */\n setNavigationClient(navigationClient) {\n this.controller.setNavigationClient(navigationClient);\n }\n /**\n * Returns the configuration object\n * @internal\n */\n getConfiguration() {\n return this.controller.getConfiguration();\n }\n /**\n * Hydrates cache with the tokens and account in the AuthenticationResult object\n * @param result\n * @param request - The request object that was used to obtain the AuthenticationResult\n * @returns\n */\n async hydrateCache(result, request) {\n return this.controller.hydrateCache(result, request);\n }\n /**\n * Clears tokens and account from the browser cache.\n * @param logoutRequest\n */\n clearCache(logoutRequest) {\n return this.controller.clearCache(logoutRequest);\n }\n}\n/**\n * creates NestedAppAuthController and passes it to the PublicClientApplication,\n * falls back to StandardController if NestedAppAuthController is not available\n *\n * @param configuration\n * @returns IPublicClientApplication\n *\n */\nasync function createNestablePublicClientApplication(configuration) {\n const nestedAppAuth = new NestedAppOperatingContext(configuration);\n await nestedAppAuth.initialize();\n if (nestedAppAuth.isAvailable()) {\n const controller = new NestedAppAuthController(nestedAppAuth);\n return new PublicClientApplication(configuration, controller);\n }\n return createStandardPublicClientApplication(configuration);\n}\n/**\n * creates PublicClientApplication using StandardController\n *\n * @param configuration\n * @returns IPublicClientApplication\n *\n */\nasync function createStandardPublicClientApplication(configuration) {\n const pca = new PublicClientApplication(configuration);\n await pca.initialize();\n return pca;\n}\n\nexport { PublicClientApplication, createNestablePublicClientApplication, createStandardPublicClientApplication };\n//# sourceMappingURL=PublicClientApplication.mjs.map\n","import { getGroupper, GroupperTabbabilities } from 'tabster';\nimport { useTabsterAttributes } from './useTabsterAttributes';\nimport { useTabster } from './useTabster';\n/**\n * A hook that returns the necessary tabster attributes to support groupping.\n * @param options - Options to configure keyboard navigation\n */ export const useFocusableGroup = (options)=>{\n const tabster = useTabster();\n if (tabster) {\n getGroupper(tabster);\n }\n return useTabsterAttributes({\n groupper: {\n tabbability: getTabbability(options === null || options === void 0 ? void 0 : options.tabBehavior)\n },\n focusable: {\n ignoreKeydown: options === null || options === void 0 ? void 0 : options.ignoreDefaultKeydown\n }\n });\n};\nconst getTabbability = (tabBehavior)=>{\n switch(tabBehavior){\n case 'unlimited':\n return GroupperTabbabilities.Unlimited;\n case 'limited':\n return GroupperTabbabilities.Limited;\n case 'limited-trap-focus':\n return GroupperTabbabilities.LimitedTrapFocus;\n default:\n return undefined;\n }\n};\n","/**\n * Programmatically generates a tokens to css variables mapping object from the keys in a theme.\n * This helps with ease of use as a user of a custom theme does not have to manually construct this object, but it could\n * affect tree-shaking since bundlers do not know the shape of the output.\n *\n * @param theme - Theme from which to get the keys to generate the tokens to css variables mapping object\n * @returns Tokens to css variables mapping object corresponding to the passed theme\n */ export function themeToTokensObject(theme) {\n const tokens = {};\n const keys = Object.keys(theme);\n for (const key of keys){\n tokens[key] = `var(--${String(key)})`;\n }\n return tokens;\n}\n"," import { jsx as _jsx } from \"@fluentui/react-jsx-runtime/jsx-runtime\";\nimport { assertSlots } from '@fluentui/react-utilities';\n/**\n * Renders a Divider component by passing the slot props (defined in `state`) to the appropriate slots.\n */ export const renderDivider_unstable = (state)=>{\n assertSlots(state);\n return /*#__PURE__*/ _jsx(state.root, {\n children: state.root.children !== undefined && /*#__PURE__*/ _jsx(state.wrapper, {\n children: state.root.children\n })\n });\n};\n","import * as React from 'react';\nimport { getIntrinsicElementProps, useId, slot } from '@fluentui/react-utilities';\n/**\n * Returns the props and state required to render the component\n * @param props - User-provided props to the Divider component.\n * @param ref - User-provided ref to be passed to the Divider component.\n */ export const useDivider_unstable = (props, ref)=>{\n const { alignContent = 'center', appearance = 'default', inset = false, vertical = false, wrapper } = props;\n const dividerId = useId('divider-');\n return {\n // Props passed at the top-level\n alignContent,\n appearance,\n inset,\n vertical,\n // Slots definition\n components: {\n root: 'div',\n wrapper: 'div'\n },\n root: slot.always(getIntrinsicElementProps('div', {\n role: 'separator',\n 'aria-orientation': vertical ? 'vertical' : 'horizontal',\n 'aria-labelledby': props.children ? dividerId : undefined,\n ...props,\n // FIXME:\n // `ref` is wrongly assigned to be `HTMLElement` instead of `HTMLDivElement`\n // but since it would be a breaking change to fix it, we are casting ref to it's proper type\n ref: ref\n }), {\n elementType: 'div'\n }),\n wrapper: slot.always(wrapper, {\n defaultProps: {\n id: dividerId,\n children: props.children\n },\n elementType: 'div'\n })\n };\n};\n","import { mergeClasses, shorthands, __styles } from '@griffel/react';\nimport { tokens } from '@fluentui/react-theme';\nexport const dividerClassNames = {\n root: 'fui-Divider',\n wrapper: 'fui-Divider__wrapper'\n};\nconst contentSpacing = '12px';\nconst insetSpacing = '12px';\nconst maxStartEndLength = '8px';\nconst minStartEndLength = '8px;';\nconst useBaseStyles = /*#__PURE__*/__styles({\n base: {\n Bt984gj: \"f122n59\",\n B7ck84d: \"f1ewtqcl\",\n mc9l5x: \"f22iagw\",\n Beiy3e4: \"f1063pyq\",\n Bh6795r: \"fqerorx\",\n qhf8xq: \"f10pi13n\",\n Bahqtrf: \"fk6fouc\",\n Be2twd7: \"fy9rknc\",\n Bhrd7zp: \"figsok6\",\n Bg96gwp: \"fwrc4pm\",\n fsow6f: \"f17mccla\",\n Bcvre1j: \"fyl8oag\",\n Br0sdwz: \"f16vkdww\",\n Bn78ew0: \"fhsnbul\",\n li1rpt: \"f1gw3sf2\",\n ap17g6: \"f1ly5f7u\",\n B771hl4: \"f1s3tz6t\"\n },\n childless: {\n susq4k: \"f1kyqvp9\",\n Bicfajf: [\"fzynn9s\", \"f1z0ukd1\"],\n jwcpgy: [\"fekrn8e\", \"ftdg338\"],\n B4rk6o: \"fesgyo\"\n },\n start: {\n Bsft5z2: \"f13zj6fq\"\n },\n center: {\n Ftih45: \"f1wl9k8s\",\n Bsft5z2: \"f13zj6fq\"\n },\n end: {\n Ftih45: \"f1wl9k8s\"\n },\n brand: {\n sj55zd: \"f16muhyy\",\n Bq4z7u6: \"fcbuu2a\",\n Bk5zm6e: [\"f1wdw2dr\", \"f1ttio3w\"],\n Bqjgrrk: \"f1582fpk\",\n Bm6vgfq: [\"f1ttio3w\", \"f1wdw2dr\"],\n B0n5ga8: \"f1ahrvm8\",\n s924m2: [\"f1cd3wbc\", \"f17hbk9y\"],\n B1q35kw: \"fvrapl0\",\n Gp14am: [\"f17hbk9y\", \"f1cd3wbc\"]\n },\n \"default\": {\n sj55zd: \"fkfq4zb\",\n Bq4z7u6: \"f1vccso1\",\n Bk5zm6e: [\"f1geml7w\", \"fjml6kk\"],\n Bqjgrrk: \"f1r7kh1m\",\n Bm6vgfq: [\"fjml6kk\", \"f1geml7w\"],\n B0n5ga8: \"f16j7guv\",\n s924m2: [\"fx01ahm\", \"fj1a37q\"],\n B1q35kw: \"fl8d8yv\",\n Gp14am: [\"fj1a37q\", \"fx01ahm\"]\n },\n subtle: {\n sj55zd: \"f11d4kpn\",\n Bq4z7u6: \"f5g06un\",\n Bk5zm6e: [\"f13sxdku\", \"f1n015lb\"],\n Bqjgrrk: \"f1x6bl8t\",\n Bm6vgfq: [\"f1n015lb\", \"f13sxdku\"],\n B0n5ga8: \"fvod1wy\",\n s924m2: [\"fwslg65\", \"flk0e17\"],\n B1q35kw: \"f103fvts\",\n Gp14am: [\"flk0e17\", \"fwslg65\"]\n },\n strong: {\n sj55zd: \"f19n0e5\",\n Bq4z7u6: \"f10tv6oz\",\n Bk5zm6e: [\"f16xp3sf\", \"f1seuxxq\"],\n Bqjgrrk: \"fwrmqbx\",\n Bm6vgfq: [\"f1seuxxq\", \"f16xp3sf\"],\n B0n5ga8: \"ft83z1f\",\n s924m2: [\"f1g4150c\", \"f192dr6e\"],\n B1q35kw: \"f1qnawh6\",\n Gp14am: [\"f192dr6e\", \"f1g4150c\"]\n }\n}, {\n d: [\".f122n59{align-items:center;}\", \".f1ewtqcl{box-sizing:border-box;}\", \".f22iagw{display:flex;}\", \".f1063pyq{flex-direction:row;}\", \".fqerorx{flex-grow:1;}\", \".f10pi13n{position:relative;}\", \".fk6fouc{font-family:var(--fontFamilyBase);}\", \".fy9rknc{font-size:var(--fontSizeBase200);}\", \".figsok6{font-weight:var(--fontWeightRegular);}\", \".fwrc4pm{line-height:var(--lineHeightBase200);}\", \".f17mccla{text-align:center;}\", \".fyl8oag::before{box-sizing:border-box;}\", \".f16vkdww::before{display:flex;}\", \".fhsnbul::before{flex-grow:1;}\", \".f1gw3sf2::after{box-sizing:border-box;}\", \".f1ly5f7u::after{display:flex;}\", \".f1s3tz6t::after{flex-grow:1;}\", \".f1kyqvp9::before{margin-bottom:0;}\", \".fzynn9s::before{margin-right:0;}\", \".f1z0ukd1::before{margin-left:0;}\", \".fekrn8e::after{margin-left:0;}\", \".ftdg338::after{margin-right:0;}\", \".fesgyo::after{margin-top:0;}\", \".f13zj6fq::after{content:\\\"\\\";}\", \".f1wl9k8s::before{content:\\\"\\\";}\", \".f16muhyy{color:var(--colorBrandForeground1);}\", \".fcbuu2a::before{border-top-color:var(--colorBrandStroke1);}\", \".f1wdw2dr::before{border-right-color:var(--colorBrandStroke1);}\", \".f1ttio3w::before{border-left-color:var(--colorBrandStroke1);}\", \".f1582fpk::before{border-bottom-color:var(--colorBrandStroke1);}\", \".f1ahrvm8::after{border-top-color:var(--colorBrandStroke1);}\", \".f1cd3wbc::after{border-right-color:var(--colorBrandStroke1);}\", \".f17hbk9y::after{border-left-color:var(--colorBrandStroke1);}\", \".fvrapl0::after{border-bottom-color:var(--colorBrandStroke1);}\", \".fkfq4zb{color:var(--colorNeutralForeground2);}\", \".f1vccso1::before{border-top-color:var(--colorNeutralStroke2);}\", \".f1geml7w::before{border-right-color:var(--colorNeutralStroke2);}\", \".fjml6kk::before{border-left-color:var(--colorNeutralStroke2);}\", \".f1r7kh1m::before{border-bottom-color:var(--colorNeutralStroke2);}\", \".f16j7guv::after{border-top-color:var(--colorNeutralStroke2);}\", \".fx01ahm::after{border-right-color:var(--colorNeutralStroke2);}\", \".fj1a37q::after{border-left-color:var(--colorNeutralStroke2);}\", \".fl8d8yv::after{border-bottom-color:var(--colorNeutralStroke2);}\", \".f11d4kpn{color:var(--colorNeutralForeground3);}\", \".f5g06un::before{border-top-color:var(--colorNeutralStroke3);}\", \".f13sxdku::before{border-right-color:var(--colorNeutralStroke3);}\", \".f1n015lb::before{border-left-color:var(--colorNeutralStroke3);}\", \".f1x6bl8t::before{border-bottom-color:var(--colorNeutralStroke3);}\", \".fvod1wy::after{border-top-color:var(--colorNeutralStroke3);}\", \".fwslg65::after{border-right-color:var(--colorNeutralStroke3);}\", \".flk0e17::after{border-left-color:var(--colorNeutralStroke3);}\", \".f103fvts::after{border-bottom-color:var(--colorNeutralStroke3);}\", \".f19n0e5{color:var(--colorNeutralForeground1);}\", \".f10tv6oz::before{border-top-color:var(--colorNeutralStroke1);}\", \".f16xp3sf::before{border-right-color:var(--colorNeutralStroke1);}\", \".f1seuxxq::before{border-left-color:var(--colorNeutralStroke1);}\", \".fwrmqbx::before{border-bottom-color:var(--colorNeutralStroke1);}\", \".ft83z1f::after{border-top-color:var(--colorNeutralStroke1);}\", \".f1g4150c::after{border-right-color:var(--colorNeutralStroke1);}\", \".f192dr6e::after{border-left-color:var(--colorNeutralStroke1);}\", \".f1qnawh6::after{border-bottom-color:var(--colorNeutralStroke1);}\"]\n});\nconst useHorizontalStyles = /*#__PURE__*/__styles({\n base: {\n a9b677: \"fly5x3f\",\n Bdkvgpv: \"f163fonl\",\n B0qfbqy: \"f51yk4v\",\n pbipgd: \"f13rof3u\",\n Bm2nyyq: \"f8rth92\",\n xrcqlc: \"f6czdpx\",\n i5u598: \"f1iyka9k\"\n },\n inset: {\n uwmqm3: [\"fjlbh76\", \"f11qrl6u\"],\n z189sj: [\"f11qrl6u\", \"fjlbh76\"]\n },\n start: {\n Ftih45: \"f1wl9k8s\",\n Bicfajf: [\"f1ojjlep\", \"fk1kexq\"],\n Bxwl2t9: \"f1he2m4d\",\n jwcpgy: [\"f12w1bnb\", \"f1558wlj\"]\n },\n center: {\n Bicfajf: [\"f1ojjlep\", \"fk1kexq\"],\n jwcpgy: [\"f12w1bnb\", \"f1558wlj\"]\n },\n end: {\n Bicfajf: [\"f1ojjlep\", \"fk1kexq\"],\n Bsft5z2: \"f13zj6fq\",\n jwcpgy: [\"f12w1bnb\", \"f1558wlj\"],\n Iy66sp: \"f1ayce8x\"\n }\n}, {\n d: [\".fly5x3f{width:100%;}\", \".f163fonl::before{border-top-style:solid;}\", \".f51yk4v::before{border-top-width:var(--strokeWidthThin);}\", \".f13rof3u::before{min-width:8px;}\", \".f8rth92::after{border-top-style:solid;}\", \".f6czdpx::after{border-top-width:var(--strokeWidthThin);}\", \".f1iyka9k::after{min-width:8px;}\", \".fjlbh76{padding-left:12px;}\", \".f11qrl6u{padding-right:12px;}\", \".f1wl9k8s::before{content:\\\"\\\";}\", \".f1ojjlep::before{margin-right:12px;}\", \".fk1kexq::before{margin-left:12px;}\", \".f1he2m4d::before{max-width:8px;}\", \".f12w1bnb::after{margin-left:12px;}\", \".f1558wlj::after{margin-right:12px;}\", \".f13zj6fq::after{content:\\\"\\\";}\", \".f1ayce8x::after{max-width:8px;}\"]\n});\nconst useVerticalStyles = /*#__PURE__*/__styles({\n base: {\n Beiy3e4: \"f1vx9l62\",\n sshi5w: \"f16gbxbe\",\n m598lv: [\"f1yq6w5o\", \"f1jpmc5p\"],\n B4f6apu: [\"f9sc749\", \"f1x8pvcy\"],\n zkzzav: \"fhkwbjy\",\n Barhvk9: [\"flthirb\", \"ftkbnf5\"],\n Ihftqj: [\"f13hvwk3\", \"f1en4csx\"],\n Bde111x: \"f19onpk6\"\n },\n inset: {\n B6of3ja: \"f1xdg43u\",\n jrapky: \"f1jlhsmd\"\n },\n withChildren: {\n sshi5w: \"f1tjaq3g\"\n },\n start: {\n Ftih45: \"f1wl9k8s\",\n susq4k: \"fg2pwug\",\n Bbdr6tz: \"fkjtzyi\",\n B4rk6o: \"f8vk40g\"\n },\n center: {\n susq4k: \"fg2pwug\",\n B4rk6o: \"f8vk40g\"\n },\n end: {\n susq4k: \"fg2pwug\",\n Bsft5z2: \"f13zj6fq\",\n B4rk6o: \"f8vk40g\",\n gn64ia: \"fqg5mu5\"\n }\n}, {\n d: [\".f1vx9l62{flex-direction:column;}\", \".f16gbxbe{min-height:20px;}\", \".f1yq6w5o::before{border-right-style:solid;}\", \".f1jpmc5p::before{border-left-style:solid;}\", \".f9sc749::before{border-right-width:var(--strokeWidthThin);}\", \".f1x8pvcy::before{border-left-width:var(--strokeWidthThin);}\", \".fhkwbjy::before{min-height:8px;}\", \".flthirb::after{border-right-style:solid;}\", \".ftkbnf5::after{border-left-style:solid;}\", \".f13hvwk3::after{border-right-width:var(--strokeWidthThin);}\", \".f1en4csx::after{border-left-width:var(--strokeWidthThin);}\", \".f19onpk6::after{min-height:8px;}\", \".f1xdg43u{margin-top:12px;}\", \".f1jlhsmd{margin-bottom:12px;}\", \".f1tjaq3g{min-height:84px;}\", \".f1wl9k8s::before{content:\\\"\\\";}\", \".fg2pwug::before{margin-bottom:12px;}\", \".fkjtzyi::before{max-height:8px;}\", \".f8vk40g::after{margin-top:12px;}\", \".f13zj6fq::after{content:\\\"\\\";}\", \".fqg5mu5::after{max-height:8px;}\"]\n});\nexport const useDividerStyles_unstable = state => {\n 'use no memo';\n\n const baseStyles = useBaseStyles();\n const horizontalStyles = useHorizontalStyles();\n const verticalStyles = useVerticalStyles();\n const {\n alignContent,\n appearance,\n inset,\n vertical\n } = state;\n state.root.className = mergeClasses(dividerClassNames.root,\n // Base styles\n baseStyles.base, baseStyles[alignContent], appearance && baseStyles[appearance],\n // Horizontal styles\n !vertical && horizontalStyles.base, !vertical && inset && horizontalStyles.inset, !vertical && horizontalStyles[alignContent],\n // Vertical styles\n vertical && verticalStyles.base, vertical && inset && verticalStyles.inset, vertical && verticalStyles[alignContent], vertical && state.root.children !== undefined && verticalStyles.withChildren,\n // Childless styles\n state.root.children === undefined && baseStyles.childless,\n // User provided class name\n state.root.className);\n if (state.wrapper) {\n state.wrapper.className = mergeClasses(dividerClassNames.wrapper, state.wrapper.className);\n }\n return state;\n};","import * as React from 'react';\nimport { renderDivider_unstable } from './renderDivider';\nimport { useDivider_unstable } from './useDivider';\nimport { useDividerStyles_unstable } from './useDividerStyles.styles';\nimport { useCustomStyleHook_unstable } from '@fluentui/react-shared-contexts';\n/**\n * A divider visually segments content into groups.\n */ export const Divider = /*#__PURE__*/ React.forwardRef((props, ref)=>{\n const state = useDivider_unstable(props, ref);\n useDividerStyles_unstable(state);\n useCustomStyleHook_unstable('useDividerStyles_unstable')(state);\n return renderDivider_unstable(state);\n});\nDivider.displayName = 'Divider';\n","import * as React from 'react';\nimport { mergeCallbacks, slot, useControllableState } from '@fluentui/react-utilities';\nimport { Enter } from '@fluentui/keyboard-keys';\nimport { useFocusFinders } from '@fluentui/react-tabster';\n/**\n * @internal\n *\n * Create the state related to selectable cards.\n *\n * This internal hook controls all the logic for selectable cards and is\n * intended to be used alongside with useCard_unstable.\n *\n * @param props - props from this instance of Card\n * @param a11yProps - accessibility props shared between elements of the card\n * @param cardRef - reference to the root element of Card\n */ export const useCardSelectable = (props, { referenceLabel, referenceId }, cardRef)=>{\n const { checkbox = {}, onSelectionChange, floatingAction, onClick, onKeyDown } = props;\n const { findAllFocusable } = useFocusFinders();\n const checkboxRef = React.useRef(null);\n const [selected, setSelected] = useControllableState({\n state: props.selected,\n defaultState: props.defaultSelected,\n initialState: false\n });\n const selectable = [\n props.selected,\n props.defaultSelected,\n onSelectionChange\n ].some((prop)=>typeof prop !== 'undefined');\n const [selectFocused, setSelectFocused] = React.useState(false);\n const shouldRestrictTriggerAction = React.useCallback((event)=>{\n if (!cardRef.current) {\n return false;\n }\n const focusableElements = findAllFocusable(cardRef.current);\n const target = event.target;\n const isElementInFocusableGroup = focusableElements.some((element)=>element.contains(target));\n const isCheckboxSlot = (checkboxRef === null || checkboxRef === void 0 ? void 0 : checkboxRef.current) === target;\n return isElementInFocusableGroup && !isCheckboxSlot;\n }, [\n cardRef,\n findAllFocusable\n ]);\n const onChangeHandler = React.useCallback((event)=>{\n if (shouldRestrictTriggerAction(event)) {\n return;\n }\n const newCheckedValue = !selected;\n setSelected(newCheckedValue);\n if (onSelectionChange) {\n onSelectionChange(event, {\n selected: newCheckedValue\n });\n }\n }, [\n onSelectionChange,\n selected,\n setSelected,\n shouldRestrictTriggerAction\n ]);\n const onKeyDownHandler = React.useCallback((event)=>{\n if ([\n Enter\n ].includes(event.key)) {\n event.preventDefault();\n onChangeHandler(event);\n }\n }, [\n onChangeHandler\n ]);\n const checkboxSlot = React.useMemo(()=>{\n if (!selectable || floatingAction) {\n return;\n }\n const selectableCheckboxProps = {};\n if (referenceId) {\n selectableCheckboxProps['aria-labelledby'] = referenceId;\n } else if (referenceLabel) {\n selectableCheckboxProps['aria-label'] = referenceLabel;\n }\n return slot.optional(checkbox, {\n defaultProps: {\n ref: checkboxRef,\n type: 'checkbox',\n checked: selected,\n onChange: (event)=>onChangeHandler(event),\n onFocus: ()=>setSelectFocused(true),\n onBlur: ()=>setSelectFocused(false),\n ...selectableCheckboxProps\n },\n elementType: 'input'\n });\n }, [\n checkbox,\n floatingAction,\n selected,\n selectable,\n onChangeHandler,\n referenceId,\n referenceLabel\n ]);\n const floatingActionSlot = React.useMemo(()=>{\n if (!floatingAction) {\n return;\n }\n return slot.optional(floatingAction, {\n defaultProps: {\n ref: checkboxRef\n },\n elementType: 'div'\n });\n }, [\n floatingAction\n ]);\n const selectableCardProps = React.useMemo(()=>{\n if (!selectable) {\n return null;\n }\n return {\n onClick: mergeCallbacks(onClick, onChangeHandler),\n onKeyDown: mergeCallbacks(onKeyDown, onKeyDownHandler)\n };\n }, [\n selectable,\n onChangeHandler,\n onClick,\n onKeyDown,\n onKeyDownHandler\n ]);\n return {\n selected,\n selectable,\n selectFocused,\n selectableCardProps,\n checkboxSlot,\n floatingActionSlot\n };\n};\n","import * as React from 'react';\nconst cardContext = React.createContext(undefined);\n/**\n * @internal\n */ export const cardContextDefaultValue = {\n selectableA11yProps: {\n referenceId: undefined,\n setReferenceId () {\n /* Noop */ },\n referenceLabel: undefined,\n setReferenceLabel () {\n /* Noop */ }\n }\n};\n/**\n * @internal\n */ export const CardProvider = cardContext.Provider;\n/**\n * @internal\n */ export const useCardContext_unstable = ()=>{\n var _React_useContext;\n return (_React_useContext = React.useContext(cardContext)) !== null && _React_useContext !== void 0 ? _React_useContext : cardContextDefaultValue;\n};\n","import * as React from 'react';\nimport { getIntrinsicElementProps, useMergedRefs, slot } from '@fluentui/react-utilities';\nimport { useFocusableGroup, useFocusWithin } from '@fluentui/react-tabster';\nimport { useCardSelectable } from './useCardSelectable';\nimport { cardContextDefaultValue } from './CardContext';\nconst focusMap = {\n off: undefined,\n 'no-tab': 'limited-trap-focus',\n 'tab-exit': 'limited',\n 'tab-only': 'unlimited'\n};\n/**\n * Create the state for interactive cards.\n *\n * This internal hook defines if the card is interactive\n * and control focus properties based on that.\n *\n * @param props - props from this instance of Card\n */ const useCardInteractive = ({ focusMode: initialFocusMode, ...props })=>{\n const interactive = [\n 'onClick',\n 'onDoubleClick',\n 'onMouseUp',\n 'onMouseDown',\n 'onPointerUp',\n 'onPointerDown',\n 'onTouchStart',\n 'onTouchEnd',\n 'onDragStart',\n 'onDragEnd'\n ].some((prop)=>props[prop]);\n // default focusMode to tab-only when interactive, and off when not\n const focusMode = initialFocusMode !== null && initialFocusMode !== void 0 ? initialFocusMode : interactive ? 'no-tab' : 'off';\n const groupperAttrs = useFocusableGroup({\n tabBehavior: focusMap[focusMode]\n });\n const interactiveFocusAttributes = {\n ...groupperAttrs,\n tabIndex: 0\n };\n return {\n interactive,\n focusAttributes: focusMode === 'off' ? null : interactiveFocusAttributes\n };\n};\n/**\n * Create the state required to render Card.\n *\n * The returned state can be modified with hooks such as useCardStyles_unstable,\n * before being passed to renderCard_unstable.\n *\n * @param props - props from this instance of Card\n * @param ref - reference to the root element of Card\n */ export const useCard_unstable = (props, ref)=>{\n const { appearance = 'filled', orientation = 'vertical', size = 'medium' } = props;\n const [referenceId, setReferenceId] = React.useState(cardContextDefaultValue.selectableA11yProps.referenceId);\n const [referenceLabel, setReferenceLabel] = React.useState(cardContextDefaultValue.selectableA11yProps.referenceId);\n const cardBaseRef = useFocusWithin();\n const { selectable, selected, selectableCardProps, selectFocused, checkboxSlot, floatingActionSlot } = useCardSelectable(props, {\n referenceId,\n referenceLabel\n }, cardBaseRef);\n const cardRef = useMergedRefs(cardBaseRef, ref);\n const { interactive, focusAttributes } = useCardInteractive(props);\n return {\n appearance,\n orientation,\n size,\n interactive,\n selectable,\n selectFocused,\n selected,\n selectableA11yProps: {\n setReferenceId,\n referenceId,\n referenceLabel,\n setReferenceLabel\n },\n components: {\n root: 'div',\n floatingAction: 'div',\n checkbox: 'input'\n },\n root: slot.always(getIntrinsicElementProps('div', {\n ref: cardRef,\n role: 'group',\n ...!selectable ? focusAttributes : null,\n ...props,\n ...selectableCardProps\n }), {\n elementType: 'div'\n }),\n floatingAction: floatingActionSlot,\n checkbox: checkboxSlot\n };\n};\n"," import { jsx as _jsx, jsxs as _jsxs } from \"@fluentui/react-jsx-runtime/jsx-runtime\";\nimport { assertSlots } from '@fluentui/react-utilities';\nimport { CardProvider } from './CardContext';\n/**\n * Render the final JSX of Card.\n */ export const renderCard_unstable = (state, cardContextValue)=>{\n assertSlots(state);\n return /*#__PURE__*/ _jsx(state.root, {\n children: /*#__PURE__*/ _jsxs(CardProvider, {\n value: cardContextValue,\n children: [\n state.checkbox ? /*#__PURE__*/ _jsx(state.checkbox, {}) : null,\n state.floatingAction ? /*#__PURE__*/ _jsx(state.floatingAction, {}) : null,\n state.root.children\n ]\n })\n });\n};\n","import { __styles, mergeClasses, shorthands } from '@griffel/react';\n/**\n * Static CSS class names used internally for the component slots.\n */\nexport const cardHeaderClassNames = {\n root: 'fui-CardHeader',\n image: 'fui-CardHeader__image',\n header: 'fui-CardHeader__header',\n description: 'fui-CardHeader__description',\n action: 'fui-CardHeader__action'\n};\n/**\n * CSS variable names used internally for uniform styling in CardHeader.\n */\nexport const cardHeaderCSSVars = {\n cardHeaderGapVar: '--fui-CardHeader--gap'\n};\nconst useStyles = /*#__PURE__*/__styles({\n root: {\n Bkc6ea2: \"fkufhic\",\n Bt984gj: \"f122n59\"\n },\n image: {\n mc9l5x: \"ftuwxu6\",\n t21cq0: [\"fql5097\", \"f6yss9k\"]\n },\n header: {\n mc9l5x: \"f22iagw\"\n },\n description: {\n mc9l5x: \"f22iagw\"\n },\n action: {\n Frg6f3: [\"f6yss9k\", \"fql5097\"],\n B7frvx2: \"f1ndzpm5\",\n B06c7xf: [\"f1fkeggc\", \"f1u45u6i\"],\n B8uq84v: \"f16eyofs\",\n snkdo8: [\"f1u45u6i\", \"f1fkeggc\"],\n Bpf22ct: \"f1wkmkig\",\n apjfyd: \"f18alut9\"\n }\n}, {\n d: [\".fkufhic{--fui-CardHeader--gap:12px;}\", \".f122n59{align-items:center;}\", \".ftuwxu6{display:inline-flex;}\", \".fql5097{margin-right:var(--fui-CardHeader--gap);}\", \".f6yss9k{margin-left:var(--fui-CardHeader--gap);}\", \".f22iagw{display:flex;}\"],\n m: [[\"@media (forced-colors: active){.f1ndzpm5 .fui-Button,.f1ndzpm5 .fui-Link{border-top-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1fkeggc .fui-Button,.f1fkeggc .fui-Link{border-right-color:currentColor;}.f1u45u6i .fui-Button,.f1u45u6i .fui-Link{border-left-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f16eyofs .fui-Button,.f16eyofs .fui-Link{border-bottom-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1wkmkig .fui-Button,.f1wkmkig .fui-Link{color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f18alut9 .fui-Button,.f18alut9 .fui-Link{outline-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }]]\n});\nconst useStylesGrid = /*#__PURE__*/__styles({\n root: {\n mc9l5x: \"f13qh94s\",\n t4k1zu: \"f8a668j\"\n },\n image: {\n Br312pm: \"fwpfdsa\",\n Ijaq50: \"fldnz9j\"\n },\n header: {\n Br312pm: \"fd46tj4\",\n Ijaq50: \"f16hsg94\"\n },\n description: {\n Br312pm: \"fd46tj4\",\n Ijaq50: \"faunodf\"\n },\n action: {\n Br312pm: \"fis13di\",\n Ijaq50: \"fldnz9j\"\n }\n}, {\n d: [\".f13qh94s{display:grid;}\", \".f8a668j{grid-auto-columns:min-content 1fr min-content;}\", \".fwpfdsa{grid-column-start:1;}\", \".fldnz9j{grid-row-start:span 2;}\", \".fd46tj4{grid-column-start:2;}\", \".f16hsg94{grid-row-start:1;}\", \".faunodf{grid-row-start:2;}\", \".fis13di{grid-column-start:3;}\"]\n});\nconst useStylesFlex = /*#__PURE__*/__styles({\n root: {\n mc9l5x: \"f22iagw\"\n },\n header: {\n Bh6795r: \"fqerorx\"\n },\n image: {},\n description: {},\n action: {}\n}, {\n d: [\".f22iagw{display:flex;}\", \".fqerorx{flex-grow:1;}\"]\n});\n/**\n * Apply styling to the CardHeader slots based on the state.\n */\nexport const useCardHeaderStyles_unstable = state => {\n 'use no memo';\n\n const styles = useStyles();\n const stylesGrid = useStylesGrid();\n const stylesFlex = useStylesFlex();\n const boxModelStyles = state.description ? stylesGrid : stylesFlex;\n const getSlotStyles = slotName => {\n var _state_slotName;\n return mergeClasses(cardHeaderClassNames[slotName], styles[slotName], boxModelStyles[slotName], (_state_slotName = state[slotName]) === null || _state_slotName === void 0 ? void 0 : _state_slotName.className);\n };\n state.root.className = getSlotStyles('root');\n if (state.image) {\n state.image.className = getSlotStyles('image');\n }\n if (state.header) {\n state.header.className = getSlotStyles('header');\n }\n if (state.description) {\n state.description.className = getSlotStyles('description');\n }\n if (state.action) {\n state.action.className = getSlotStyles('action');\n }\n return state;\n};","import { __styles, mergeClasses, shorthands } from '@griffel/react';\n/**\n * Static CSS class names used internally for the component slots.\n */\nexport const cardFooterClassNames = {\n root: 'fui-CardFooter',\n action: 'fui-CardFooter__action'\n};\nconst useStyles = /*#__PURE__*/__styles({\n root: {\n mc9l5x: \"f22iagw\",\n Beiy3e4: \"f1063pyq\",\n i8kkvl: 0,\n Belr9w4: 0,\n rmohyg: \"fsbu5mz\"\n },\n action: {\n Frg6f3: [\"fcgxt0o\", \"f1ujusj6\"],\n B7frvx2: \"f1ndzpm5\",\n B06c7xf: [\"f1fkeggc\", \"f1u45u6i\"],\n B8uq84v: \"f16eyofs\",\n snkdo8: [\"f1u45u6i\", \"f1fkeggc\"],\n Bpf22ct: \"f1wkmkig\",\n apjfyd: \"f18alut9\"\n }\n}, {\n d: [\".f22iagw{display:flex;}\", \".f1063pyq{flex-direction:row;}\", [\".fsbu5mz{gap:12px;}\", {\n p: -1\n }], \".fcgxt0o{margin-left:auto;}\", \".f1ujusj6{margin-right:auto;}\"],\n m: [[\"@media (forced-colors: active){.f1ndzpm5 .fui-Button,.f1ndzpm5 .fui-Link{border-top-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1fkeggc .fui-Button,.f1fkeggc .fui-Link{border-right-color:currentColor;}.f1u45u6i .fui-Button,.f1u45u6i .fui-Link{border-left-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f16eyofs .fui-Button,.f16eyofs .fui-Link{border-bottom-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1wkmkig .fui-Button,.f1wkmkig .fui-Link{color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f18alut9 .fui-Button,.f18alut9 .fui-Link{outline-color:currentColor;}}\", {\n m: \"(forced-colors: active)\"\n }]]\n});\n/**\n * Apply styling to the CardFooter slots based on the state.\n */\nexport const useCardFooterStyles_unstable = state => {\n 'use no memo';\n\n const styles = useStyles();\n state.root.className = mergeClasses(cardFooterClassNames.root, styles.root, state.root.className);\n if (state.action) {\n state.action.className = mergeClasses(cardFooterClassNames.action, styles.action, state.action.className);\n }\n return state;\n};","import * as React from 'react';\nimport { shorthands, __styles, mergeClasses, __resetStyles } from '@griffel/react';\nimport { tokens } from '@fluentui/react-theme';\nimport { textClassNames } from '@fluentui/react-text';\nimport { createFocusOutlineStyle } from '@fluentui/react-tabster';\nimport { cardPreviewClassNames } from '../CardPreview/useCardPreviewStyles.styles';\nimport { cardHeaderClassNames } from '../CardHeader/useCardHeaderStyles.styles';\nimport { cardFooterClassNames } from '../CardFooter/useCardFooterStyles.styles';\n/**\n * Static CSS class names used internally for the component slots.\n */\nexport const cardClassNames = {\n root: 'fui-Card',\n floatingAction: 'fui-Card__floatingAction',\n checkbox: 'fui-Card__checkbox'\n};\n/**\n * CSS variable names used internally for uniform styling in Card.\n */\nexport const cardCSSVars = {\n cardSizeVar: '--fui-Card--size',\n cardBorderRadiusVar: '--fui-Card--border-radius'\n};\nconst focusOutlineStyle = {\n outlineRadius: `var(${cardCSSVars.cardBorderRadiusVar})`,\n outlineWidth: tokens.strokeWidthThick,\n outlineOffset: '-2px'\n};\nconst useCardResetStyles = /*#__PURE__*/__resetStyles(\"rfxo2k2\", \"rgle7w9\", [\".rfxo2k2{overflow:hidden;border-radius:var(--fui-Card--border-radius);padding:var(--fui-Card--size);gap:var(--fui-Card--size);display:flex;position:relative;box-sizing:border-box;color:var(--colorNeutralForeground1);}\", \".rfxo2k2::after{position:absolute;top:0;left:0;right:0;bottom:0;content:\\\"\\\";pointer-events:none;border-top-style:solid;border-right-style:solid;border-bottom-style:solid;border-left-style:solid;border-top-width:var(--strokeWidthThin);border-right-width:var(--strokeWidthThin);border-bottom-width:var(--strokeWidthThin);border-left-width:var(--strokeWidthThin);border-radius:var(--fui-Card--border-radius);}\", \".rfxo2k2>.fui-CardHeader,.rfxo2k2>.fui-CardFooter{flex-shrink:0;}\", \".rgle7w9{overflow:hidden;border-radius:var(--fui-Card--border-radius);padding:var(--fui-Card--size);gap:var(--fui-Card--size);display:flex;position:relative;box-sizing:border-box;color:var(--colorNeutralForeground1);}\", \".rgle7w9::after{position:absolute;top:0;right:0;left:0;bottom:0;content:\\\"\\\";pointer-events:none;border-top-style:solid;border-left-style:solid;border-bottom-style:solid;border-right-style:solid;border-top-width:var(--strokeWidthThin);border-left-width:var(--strokeWidthThin);border-bottom-width:var(--strokeWidthThin);border-right-width:var(--strokeWidthThin);border-radius:var(--fui-Card--border-radius);}\", \".rgle7w9>.fui-CardHeader,.rgle7w9>.fui-CardFooter{flex-shrink:0;}\"]);\nconst useCardStyles = /*#__PURE__*/__styles({\n focused: {\n Brovlpu: \"ftqa4ok\",\n B486eqv: \"f2hkw1w\",\n B8q5s1w: \"f8hki3x\",\n Bci5o5g: [\"f1d2448m\", \"ffh67wi\"],\n n8qw10: \"f1bjia2o\",\n Bdrgwmp: [\"ffh67wi\", \"f1d2448m\"],\n Bb7d1vk: \"f226i61\",\n zhwhgb: [\"f13kzufm\", \"fsx75g8\"],\n dhy2o1: \"flujwa2\",\n Gfyso: [\"fsx75g8\", \"f13kzufm\"],\n Bm4h7ae: \"f15bsgw9\",\n B7ys5i9: \"f14e48fq\",\n Busjfv9: \"f18yb2kv\",\n Bhk32uz: \"fd6o370\",\n f6g5ot: 0,\n Boxcth7: 0,\n Bhdgwq3: 0,\n hgwjuy: 0,\n Bshpdp8: 0,\n Bsom6fd: 0,\n Blkhhs4: 0,\n Bonggc9: 0,\n Ddfuxk: 0,\n i03rao: 0,\n kclons: 0,\n clg4pj: 0,\n Bpqj9nj: 0,\n B6dhp37: 0,\n Bf4ptjt: 0,\n Bqtpl0w: 0,\n i4rwgc: \"fpqizxz\",\n Dah5zi: 0,\n B1tsrr9: 0,\n qqdqy8: 0,\n Bkh64rk: 0,\n e3fwne: \"fnd8nzh\",\n J0r882: \"f15fr7a0\",\n Bule8hv: [\"fwsq40z\", \"fy0y4wt\"],\n Bjwuhne: \"f34ld9f\",\n Ghsupd: [\"fy0y4wt\", \"fwsq40z\"]\n },\n selectableFocused: {\n Brovlpu: \"ftqa4ok\",\n B486eqv: \"f2hkw1w\",\n Bssx7fj: \"f1b1k54r\",\n uh7if5: [\"f4ne723\", \"fqqcjud\"],\n clntm0: \"fh7aioi\",\n Dlk2r6: [\"fqqcjud\", \"f4ne723\"],\n Bm3wd5j: \"f1k55ka9\",\n Bbrhkcr: [\"fgclinu\", \"f16pcs8n\"],\n f1oku: \"fycbxed\",\n aywvf2: [\"f16pcs8n\", \"fgclinu\"],\n B2j2mmj: \"ffht0p2\",\n wigs8: \"f1p0ul1q\",\n pbfy6t: \"f1c901ms\",\n B0v4ure: \"f1alokd7\",\n Byrf0fs: 0,\n Bsiemmq: 0,\n Bwckmig: 0,\n skfxo0: 0,\n Iidy0u: 0,\n B98u21t: 0,\n Bvwlmkc: 0,\n jo1ztg: 0,\n Ba1iezr: 0,\n Blmvk6g: 0,\n B24cy0v: 0,\n Bil7v7r: 0,\n Br3gin4: 0,\n nr063g: 0,\n ghq09: 0,\n Bbgo44z: 0,\n Bseh09z: \"f1i978nd\",\n az1dzo: 0,\n Ba3ybja: 0,\n B6352mv: 0,\n vppk2z: 0,\n Biaj6j7: \"f1nh8hsq\",\n B2pnrqr: \"f1amxum7\",\n B29w5g4: [\"f1cec8w7\", \"f554mv0\"],\n Bhhzhcn: \"f1sj6kbr\",\n Bec0n69: [\"f554mv0\", \"f1cec8w7\"]\n },\n orientationHorizontal: {\n Beiy3e4: \"f1063pyq\",\n Bt984gj: \"f122n59\",\n Binpb3b: \"ftrw7vg\",\n qrt8p2: \"f18opajm\",\n k6ws3r: [\"f13002it\", \"fqo182t\"],\n Btcwela: [\"f18yna97\", \"f1kd6wh7\"],\n Fer9m8: \"f4i4759\"\n },\n orientationVertical: {\n Beiy3e4: \"f1vx9l62\",\n B5nvv7i: [\"f14k419y\", \"f1fgo9fz\"],\n Baxg94k: [\"f1fgo9fz\", \"f14k419y\"],\n tn21ii: \"fvqmfsm\",\n B0ud6bj: \"f3am6yf\",\n Bgdo4j: \"f1r5wgso\"\n },\n sizeSmall: {\n B7balbw: \"f1pi9uxy\",\n B1h88n7: \"f1h1zgly\"\n },\n sizeMedium: {\n B7balbw: \"frsmuga\",\n B1h88n7: \"fuldkky\"\n },\n sizeLarge: {\n B7balbw: \"f1qua4xo\",\n B1h88n7: \"fimkt6v\"\n },\n interactive: {\n rhjd8f: \"f1epqm3e\"\n },\n filled: {\n De3pzq: \"fxugw4r\",\n E5pizo: \"f1whvlc6\",\n B0n5ga8: \"f16gxe2i\",\n s924m2: [\"fpgykix\", \"fzybk4o\"],\n B1q35kw: \"f1osi826\",\n Gp14am: [\"fzybk4o\", \"fpgykix\"]\n },\n filledInteractive: {\n Bceei9c: \"f1k6fduh\",\n De3pzq: \"fxugw4r\",\n E5pizo: \"f1whvlc6\",\n B0n5ga8: \"f16gxe2i\",\n s924m2: [\"fpgykix\", \"fzybk4o\"],\n B1q35kw: \"f1osi826\",\n Gp14am: [\"fzybk4o\", \"fpgykix\"],\n Bi91k9c: \"feu1g3u\",\n Jwef8y: \"f1knas48\",\n Bvxd0ez: \"f1m145df\",\n ecr2s2: \"fb40n2d\"\n },\n filledInteractiveSelected: {\n De3pzq: \"f1nfm20t\",\n B0n5ga8: \"f16eln5f\",\n s924m2: [\"fa2okxs\", \"fg4zq3l\"],\n B1q35kw: \"ff6932p\",\n Gp14am: [\"fg4zq3l\", \"fa2okxs\"],\n Bi91k9c: \"fx9teim\",\n Jwef8y: \"f1kz6goq\"\n },\n filledAlternative: {\n De3pzq: \"f1dmdbja\",\n E5pizo: \"f1whvlc6\",\n B0n5ga8: \"f16gxe2i\",\n s924m2: [\"fpgykix\", \"fzybk4o\"],\n B1q35kw: \"f1osi826\",\n Gp14am: [\"fzybk4o\", \"fpgykix\"]\n },\n filledAlternativeInteractive: {\n Bceei9c: \"f1k6fduh\",\n De3pzq: \"f1dmdbja\",\n E5pizo: \"f1whvlc6\",\n B0n5ga8: \"f16gxe2i\",\n s924m2: [\"fpgykix\", \"fzybk4o\"],\n B1q35kw: \"f1osi826\",\n Gp14am: [\"fzybk4o\", \"fpgykix\"],\n Bi91k9c: \"fnwyq0v\",\n Jwef8y: \"f1uvynv3\",\n Bvxd0ez: \"f1m145df\",\n ecr2s2: \"f1yhgkbh\"\n },\n filledAlternativeInteractiveSelected: {\n De3pzq: \"fjxa0vh\",\n B0n5ga8: \"f16eln5f\",\n s924m2: [\"fa2okxs\", \"fg4zq3l\"],\n B1q35kw: \"ff6932p\",\n Gp14am: [\"fg4zq3l\", \"fa2okxs\"],\n Bi91k9c: \"f1luvkty\",\n Jwef8y: \"fehi0vp\"\n },\n outline: {\n De3pzq: \"f1c21dwh\",\n E5pizo: \"f1couhl3\",\n B0n5ga8: \"ft83z1f\",\n s924m2: [\"f1g4150c\", \"f192dr6e\"],\n B1q35kw: \"f1qnawh6\",\n Gp14am: [\"f192dr6e\", \"f1g4150c\"]\n },\n outlineInteractive: {\n Bceei9c: \"f1k6fduh\",\n De3pzq: \"f1c21dwh\",\n E5pizo: \"f1couhl3\",\n B0n5ga8: \"ft83z1f\",\n s924m2: [\"f1g4150c\", \"f192dr6e\"],\n B1q35kw: \"f1qnawh6\",\n Gp14am: [\"f192dr6e\", \"f1g4150c\"],\n Bi91k9c: \"feu1g3u\",\n Jwef8y: \"fjxutwb\",\n Be0v6ae: \"f1llr77y\",\n B5kxglz: [\"fzk0khw\", \"fjj8tog\"],\n B3pwyw6: \"fb1u8ub\",\n Bymgtzf: [\"fjj8tog\", \"fzk0khw\"],\n ecr2s2: \"fophhak\",\n dmfk: \"f1uohb70\",\n B4ofi8: [\"f1jm7v1n\", \"f1bus3rq\"],\n jgq6uv: \"f1fbu7rr\",\n Baxewws: [\"f1bus3rq\", \"f1jm7v1n\"]\n },\n outlineInteractiveSelected: {\n De3pzq: \"f1q9pm1r\",\n B0n5ga8: \"f16eln5f\",\n s924m2: [\"fa2okxs\", \"fg4zq3l\"],\n B1q35kw: \"ff6932p\",\n Gp14am: [\"fg4zq3l\", \"fa2okxs\"],\n Bi91k9c: \"fx9teim\",\n Jwef8y: \"fg59vm4\"\n },\n subtle: {\n De3pzq: \"fhovq9v\",\n E5pizo: \"f1couhl3\",\n B0n5ga8: \"f16gxe2i\",\n s924m2: [\"fpgykix\", \"fzybk4o\"],\n B1q35kw: \"f1osi826\",\n Gp14am: [\"fzybk4o\", \"fpgykix\"]\n },\n subtleInteractive: {\n Bceei9c: \"f1k6fduh\",\n De3pzq: \"fhovq9v\",\n E5pizo: \"f1couhl3\",\n B0n5ga8: \"f16gxe2i\",\n s924m2: [\"fpgykix\", \"fzybk4o\"],\n B1q35kw: \"f1osi826\",\n Gp14am: [\"fzybk4o\", \"fpgykix\"],\n Bi91k9c: \"feu1g3u\",\n Jwef8y: \"f1t94bn6\",\n ecr2s2: \"f1wfn5kd\"\n },\n subtleInteractiveSelected: {\n De3pzq: \"fq5gl1p\",\n B0n5ga8: \"f16eln5f\",\n s924m2: [\"fa2okxs\", \"fg4zq3l\"],\n B1q35kw: \"ff6932p\",\n Gp14am: [\"fg4zq3l\", \"fa2okxs\"],\n Bi91k9c: \"fx9teim\",\n Jwef8y: \"f1uqaxdt\"\n },\n highContrastSelected: {\n ycbfsm: \"fkc42ay\",\n Bsw6fvg: \"f1rirnrt\",\n Bbusuzp: \"f1lkg8j3\",\n xgfqdd: \"f1nkj0oa\",\n Bmmdzwq: \"fey3rwa\",\n zkpvhj: [\"f5jhx11\", \"fff9uym\"],\n B20bydw: \"fm7n0jy\",\n Bwwwggl: [\"fff9uym\", \"f5jhx11\"]\n },\n highContrastInteractive: {\n h1vhog: \"fpfvv3l\",\n kslmdy: \"f1oamsm6\",\n Baaf6ca: \"f1il21bs\",\n x9zz3d: \"fnn5dk0\",\n Bmmdzwq: \"fey3rwa\",\n zkpvhj: [\"f5jhx11\", \"fff9uym\"],\n B20bydw: \"fm7n0jy\",\n Bwwwggl: [\"fff9uym\", \"f5jhx11\"]\n },\n select: {\n qhf8xq: \"f1euv43f\",\n Bhzewxz: \"fqclxi7\",\n j35jbq: [\"fiv86kb\", \"f36uhnt\"],\n Bj3rh1h: \"f19g0ac\"\n },\n hiddenCheckbox: {\n B68tc82: 0,\n Bmxbyg5: 0,\n Bpg54ce: \"f1a3p1vp\",\n a9b677: \"frkrog8\",\n Bqenvij: \"f1mpe4l3\",\n qhf8xq: \"f1euv43f\",\n Bh84pgu: \"fmf1zke\",\n Bgl5zvf: \"f1wch0ki\",\n Huce71: \"fz5stix\"\n }\n}, {\n f: [\".ftqa4ok:focus{outline-style:none;}\"],\n i: [\".f2hkw1w:focus-visible{outline-style:none;}\"],\n d: [\".f8hki3x[data-fui-focus-visible]{border-top-color:transparent;}\", \".f1d2448m[data-fui-focus-visible]{border-right-color:transparent;}\", \".ffh67wi[data-fui-focus-visible]{border-left-color:transparent;}\", \".f1bjia2o[data-fui-focus-visible]{border-bottom-color:transparent;}\", \".f15bsgw9[data-fui-focus-visible]::after{content:\\\"\\\";}\", \".f14e48fq[data-fui-focus-visible]::after{position:absolute;}\", \".f18yb2kv[data-fui-focus-visible]::after{pointer-events:none;}\", \".fd6o370[data-fui-focus-visible]::after{z-index:1;}\", [\".fpqizxz[data-fui-focus-visible]::after{border:var(--strokeWidthThick) solid var(--colorStrokeFocus2);}\", {\n p: -2\n }], [\".fnd8nzh[data-fui-focus-visible]::after{border-radius:var(--fui-Card--border-radius);}\", {\n p: -1\n }], \".f15fr7a0[data-fui-focus-visible]::after{top:calc(0px - var(--strokeWidthThick) - -2px);}\", \".fwsq40z[data-fui-focus-visible]::after{right:calc(0px - var(--strokeWidthThick) - -2px);}\", \".fy0y4wt[data-fui-focus-visible]::after{left:calc(0px - var(--strokeWidthThick) - -2px);}\", \".f34ld9f[data-fui-focus-visible]::after{bottom:calc(0px - var(--strokeWidthThick) - -2px);}\", \".f1b1k54r[data-fui-focus-within]:focus-within{border-top-color:transparent;}\", \".f4ne723[data-fui-focus-within]:focus-within{border-right-color:transparent;}\", \".fqqcjud[data-fui-focus-within]:focus-within{border-left-color:transparent;}\", \".fh7aioi[data-fui-focus-within]:focus-within{border-bottom-color:transparent;}\", \".ffht0p2[data-fui-focus-within]:focus-within::after{content:\\\"\\\";}\", \".f1p0ul1q[data-fui-focus-within]:focus-within::after{position:absolute;}\", \".f1c901ms[data-fui-focus-within]:focus-within::after{pointer-events:none;}\", \".f1alokd7[data-fui-focus-within]:focus-within::after{z-index:1;}\", [\".f1i978nd[data-fui-focus-within]:focus-within::after{border:var(--strokeWidthThick) solid var(--colorStrokeFocus2);}\", {\n p: -2\n }], [\".f1nh8hsq[data-fui-focus-within]:focus-within::after{border-radius:var(--fui-Card--border-radius);}\", {\n p: -1\n }], \".f1amxum7[data-fui-focus-within]:focus-within::after{top:calc(0px - var(--strokeWidthThick) - -2px);}\", \".f1cec8w7[data-fui-focus-within]:focus-within::after{right:calc(0px - var(--strokeWidthThick) - -2px);}\", \".f554mv0[data-fui-focus-within]:focus-within::after{left:calc(0px - var(--strokeWidthThick) - -2px);}\", \".f1sj6kbr[data-fui-focus-within]:focus-within::after{bottom:calc(0px - var(--strokeWidthThick) - -2px);}\", \".f1063pyq{flex-direction:row;}\", \".f122n59{align-items:center;}\", \".ftrw7vg>.fui-CardPreview{margin-top:calc(var(--fui-Card--size) * -1);}\", \".f18opajm>.fui-CardPreview{margin-bottom:calc(var(--fui-Card--size) * -1);}\", \".f13002it>:not([aria-hidden=\\\"true\\\"]).fui-CardPreview:first-of-type{margin-left:calc(var(--fui-Card--size) * -1);}\", \".fqo182t>:not([aria-hidden=\\\"true\\\"]).fui-CardPreview:first-of-type{margin-right:calc(var(--fui-Card--size) * -1);}\", \".f18yna97>:not([aria-hidden=\\\"true\\\"]).fui-CardPreview:last-of-type{margin-right:calc(var(--fui-Card--size) * -1);}\", \".f1kd6wh7>:not([aria-hidden=\\\"true\\\"]).fui-CardPreview:last-of-type{margin-left:calc(var(--fui-Card--size) * -1);}\", \".f4i4759>.fui-CardHeader:last-of-type,.f4i4759>.fui-CardFooter:last-of-type{flex-grow:1;}\", \".f1vx9l62{flex-direction:column;}\", \".f14k419y>.fui-CardPreview{margin-left:calc(var(--fui-Card--size) * -1);}\", \".f1fgo9fz>.fui-CardPreview{margin-right:calc(var(--fui-Card--size) * -1);}\", \".fvqmfsm>:not([aria-hidden=\\\"true\\\"]).fui-CardPreview:first-of-type{margin-top:calc(var(--fui-Card--size) * -1);}\", \".f3am6yf>.fui-Card__floatingAction+.fui-CardPreview{margin-top:calc(var(--fui-Card--size) * -1);}\", \".f1r5wgso>:not([aria-hidden=\\\"true\\\"]).fui-CardPreview:last-of-type{margin-bottom:calc(var(--fui-Card--size) * -1);}\", \".f1pi9uxy{--fui-Card--size:8px;}\", \".f1h1zgly{--fui-Card--border-radius:var(--borderRadiusSmall);}\", \".frsmuga{--fui-Card--size:12px;}\", \".fuldkky{--fui-Card--border-radius:var(--borderRadiusMedium);}\", \".f1qua4xo{--fui-Card--size:16px;}\", \".fimkt6v{--fui-Card--border-radius:var(--borderRadiusLarge);}\", \".f1epqm3e .fui-Text{color:currentColor;}\", \".fxugw4r{background-color:var(--colorNeutralBackground1);}\", \".f1whvlc6{box-shadow:var(--shadow4);}\", \".f16gxe2i::after{border-top-color:var(--colorTransparentStroke);}\", \".fpgykix::after{border-right-color:var(--colorTransparentStroke);}\", \".fzybk4o::after{border-left-color:var(--colorTransparentStroke);}\", \".f1osi826::after{border-bottom-color:var(--colorTransparentStroke);}\", \".f1k6fduh{cursor:pointer;}\", \".f1nfm20t{background-color:var(--colorNeutralBackground1Selected);}\", \".f16eln5f::after{border-top-color:var(--colorNeutralStroke1Selected);}\", \".fa2okxs::after{border-right-color:var(--colorNeutralStroke1Selected);}\", \".fg4zq3l::after{border-left-color:var(--colorNeutralStroke1Selected);}\", \".ff6932p::after{border-bottom-color:var(--colorNeutralStroke1Selected);}\", \".f1dmdbja{background-color:var(--colorNeutralBackground2);}\", \".fjxa0vh{background-color:var(--colorNeutralBackground2Selected);}\", \".f1c21dwh{background-color:var(--colorTransparentBackground);}\", \".f1couhl3{box-shadow:none;}\", \".ft83z1f::after{border-top-color:var(--colorNeutralStroke1);}\", \".f1g4150c::after{border-right-color:var(--colorNeutralStroke1);}\", \".f192dr6e::after{border-left-color:var(--colorNeutralStroke1);}\", \".f1qnawh6::after{border-bottom-color:var(--colorNeutralStroke1);}\", \".f1q9pm1r{background-color:var(--colorTransparentBackgroundSelected);}\", \".fhovq9v{background-color:var(--colorSubtleBackground);}\", \".fq5gl1p{background-color:var(--colorSubtleBackgroundSelected);}\", \".f1euv43f{position:absolute;}\", \".fqclxi7{top:4px;}\", \".fiv86kb{right:4px;}\", \".f36uhnt{left:4px;}\", \".f19g0ac{z-index:1;}\", [\".f1a3p1vp{overflow:hidden;}\", {\n p: -1\n }], \".frkrog8{width:1px;}\", \".f1mpe4l3{height:1px;}\", \".fmf1zke{clip:rect(0 0 0 0);}\", \".f1wch0ki{clip-path:inset(50%);}\", \".fz5stix{white-space:nowrap;}\"],\n m: [[\"@media (forced-colors: active){.f226i61[data-fui-focus-visible]::after{border-top-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f13kzufm[data-fui-focus-visible]::after{border-right-color:Highlight;}.fsx75g8[data-fui-focus-visible]::after{border-left-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.flujwa2[data-fui-focus-visible]::after{border-bottom-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1k55ka9[data-fui-focus-within]:focus-within::after{border-top-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f16pcs8n[data-fui-focus-within]:focus-within::after{border-left-color:Highlight;}.fgclinu[data-fui-focus-within]:focus-within::after{border-right-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.fycbxed[data-fui-focus-within]:focus-within::after{border-bottom-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.fkc42ay{forced-color-adjust:none;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1rirnrt{background-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1lkg8j3{color:HighlightText;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1nkj0oa .fui-CardPreview,.f1nkj0oa .fui-CardFooter{forced-color-adjust:auto;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.fey3rwa::after{border-top-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f5jhx11::after{border-right-color:Highlight;}.fff9uym::after{border-left-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.fm7n0jy::after{border-bottom-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.fpfvv3l:hover,.fpfvv3l :active{forced-color-adjust:none;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1oamsm6:hover,.f1oamsm6 :active{background-color:Highlight;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.f1il21bs:hover,.f1il21bs :active{color:HighlightText;}}\", {\n m: \"(forced-colors: active)\"\n }], [\"@media (forced-colors: active){.fnn5dk0:hover .fui-CardPreview,.fnn5dk0 :active .fui-CardPreview,.fnn5dk0:hover .fui-CardFooter,.fnn5dk0 :active .fui-CardFooter{forced-color-adjust:auto;}}\", {\n m: \"(forced-colors: active)\"\n }]],\n h: [\".feu1g3u:hover{color:var(--colorNeutralForeground1Hover);}\", \".f1knas48:hover{background-color:var(--colorNeutralBackground1Hover);}\", \".f1m145df:hover{box-shadow:var(--shadow8);}\", \".fx9teim:hover{color:var(--colorNeutralForeground1Selected);}\", \".f1kz6goq:hover{background-color:var(--colorNeutralBackground1Selected);}\", \".fnwyq0v:hover{color:var(--colorNeutralForeground2Hover);}\", \".f1uvynv3:hover{background-color:var(--colorNeutralBackground2Hover);}\", \".f1luvkty:hover{color:var(--colorNeutralForeground2Selected);}\", \".fehi0vp:hover{background-color:var(--colorNeutralBackground2Selected);}\", \".fjxutwb:hover{background-color:var(--colorTransparentBackgroundHover);}\", \".f1llr77y:hover::after{border-top-color:var(--colorNeutralStroke1Hover);}\", \".fzk0khw:hover::after{border-right-color:var(--colorNeutralStroke1Hover);}\", \".fjj8tog:hover::after{border-left-color:var(--colorNeutralStroke1Hover);}\", \".fb1u8ub:hover::after{border-bottom-color:var(--colorNeutralStroke1Hover);}\", \".fg59vm4:hover{background-color:var(--colorTransparentBackgroundSelected);}\", \".f1t94bn6:hover{background-color:var(--colorSubtleBackgroundHover);}\", \".f1uqaxdt:hover{background-color:var(--colorSubtleBackgroundSelected);}\"],\n a: [\".fb40n2d:active{background-color:var(--colorNeutralBackground1Pressed);}\", \".f1yhgkbh:active{background-color:var(--colorNeutralBackground2Pressed);}\", \".fophhak:active{background-color:var(--colorTransparentBackgroundPressed);}\", \".f1uohb70:active::after{border-top-color:var(--colorNeutralStroke1Pressed);}\", \".f1jm7v1n:active::after{border-right-color:var(--colorNeutralStroke1Pressed);}\", \".f1bus3rq:active::after{border-left-color:var(--colorNeutralStroke1Pressed);}\", \".f1fbu7rr:active::after{border-bottom-color:var(--colorNeutralStroke1Pressed);}\", \".f1wfn5kd:active{background-color:var(--colorSubtleBackgroundPressed);}\"]\n});\n/**\n * Apply styling to the Card slots based on the state.\n */\nexport const useCardStyles_unstable = state => {\n 'use no memo';\n\n const resetStyles = useCardResetStyles();\n const styles = useCardStyles();\n const orientationMap = {\n horizontal: styles.orientationHorizontal,\n vertical: styles.orientationVertical\n };\n const sizeMap = {\n small: styles.sizeSmall,\n medium: styles.sizeMedium,\n large: styles.sizeLarge\n };\n const appearanceMap = {\n filled: styles.filled,\n 'filled-alternative': styles.filledAlternative,\n outline: styles.outline,\n subtle: styles.subtle\n };\n const selectedMap = {\n filled: styles.filledInteractiveSelected,\n 'filled-alternative': styles.filledAlternativeInteractiveSelected,\n outline: styles.outlineInteractiveSelected,\n subtle: styles.subtleInteractiveSelected\n };\n const interactiveMap = {\n filled: styles.filledInteractive,\n 'filled-alternative': styles.filledAlternativeInteractive,\n outline: styles.outlineInteractive,\n subtle: styles.subtleInteractive\n };\n const isSelectableOrInteractive = state.interactive || state.selectable;\n const focusedClassName = React.useMemo(() => {\n if (state.selectable) {\n if (state.selectFocused) {\n return styles.selectableFocused;\n }\n return '';\n }\n return styles.focused;\n }, [state.selectFocused, state.selectable, styles.focused, styles.selectableFocused]);\n state.root.className = mergeClasses(cardClassNames.root, resetStyles, orientationMap[state.orientation], sizeMap[state.size], appearanceMap[state.appearance], isSelectableOrInteractive && styles.interactive, isSelectableOrInteractive && interactiveMap[state.appearance], state.selected && selectedMap[state.appearance], focusedClassName, isSelectableOrInteractive && styles.highContrastInteractive, state.selected && styles.highContrastSelected, state.root.className);\n if (state.floatingAction) {\n state.floatingAction.className = mergeClasses(cardClassNames.floatingAction, styles.select, state.floatingAction.className);\n }\n if (state.checkbox) {\n state.checkbox.className = mergeClasses(cardClassNames.checkbox, styles.hiddenCheckbox, state.checkbox.className);\n }\n return state;\n};","export function useCardContextValue({ selectableA11yProps }) {\n return {\n selectableA11yProps\n };\n}\n","import * as React from 'react';\nimport { useCard_unstable } from './useCard';\nimport { renderCard_unstable } from './renderCard';\nimport { useCardStyles_unstable } from './useCardStyles.styles';\nimport { useCardContextValue } from './useCardContextValue';\n/**\n * A card provides scaffolding for hosting actions and content for a single topic.\n */ export const Card = /*#__PURE__*/ React.forwardRef((props, ref)=>{\n const state = useCard_unstable(props, ref);\n const cardContextValue = useCardContextValue(state);\n useCardStyles_unstable(state);\n return renderCard_unstable(state, cardContextValue);\n});\nCard.displayName = 'Card';\n","import * as React from 'react';\nimport { getIntrinsicElementProps, slot } from '@fluentui/react-utilities';\n/**\n * Create the state required to render CardFooter.\n *\n * The returned state can be modified with hooks such as useCardFooterStyles_unstable,\n * before being passed to renderCardFooter_unstable.\n *\n * @param props - props from this instance of CardFooter\n * @param ref - reference to root HTMLElement of CardFooter\n */ export const useCardFooter_unstable = (props, ref)=>{\n const { action } = props;\n return {\n components: {\n root: 'div',\n action: 'div'\n },\n root: slot.always(getIntrinsicElementProps('div', {\n // FIXME:\n // `ref` is wrongly assigned to be `HTMLElement` instead of `HTMLDivElement`\n // but since it would be a breaking change to fix it, we are casting ref to it's proper type\n ref: ref,\n ...props\n }), {\n elementType: 'div'\n }),\n action: slot.optional(action, {\n elementType: 'div'\n })\n };\n};\n"," import { jsx as _jsx, jsxs as _jsxs } from \"@fluentui/react-jsx-runtime/jsx-runtime\";\nimport { assertSlots } from '@fluentui/react-utilities';\n/**\n * Render the final JSX of CardFooter.\n */ export const renderCardFooter_unstable = (state)=>{\n assertSlots(state);\n return /*#__PURE__*/ _jsxs(state.root, {\n children: [\n state.root.children,\n state.action && /*#__PURE__*/ _jsx(state.action, {})\n ]\n });\n};\n","import * as React from 'react';\nimport { useCardFooter_unstable } from './useCardFooter';\nimport { renderCardFooter_unstable } from './renderCardFooter';\nimport { useCardFooterStyles_unstable } from './useCardFooterStyles.styles';\n/**\n * Component to render Button actions in a Card component.\n */ export const CardFooter = /*#__PURE__*/ React.forwardRef((props, ref)=>{\n const state = useCardFooter_unstable(props, ref);\n useCardFooterStyles_unstable(state);\n return renderCardFooter_unstable(state);\n});\nCardFooter.displayName = 'CardFooter';\n","import * as React from 'react';\nimport { getIntrinsicElementProps, useId, slot } from '@fluentui/react-utilities';\nimport { useCardContext_unstable } from '../Card/CardContext';\nimport { cardHeaderClassNames } from './useCardHeaderStyles.styles';\n/**\n * Finds the first child of CardHeader with an id prop.\n *\n * @param header - the header prop of CardHeader\n */ function getChildWithId(header) {\n function isReactElementWithIdProp(element) {\n return React.isValidElement(element) && Boolean(element.props.id);\n }\n return React.Children.toArray(header).find(isReactElementWithIdProp);\n}\n/**\n * Returns the id to use for the CardHeader root element.\n *\n * @param headerId - the id prop of the CardHeader component\n * @param childWithId - the first child of the CardHeader component with an id prop\n * @param generatedId - a generated id\n *\n * @returns the id to use for the CardHeader root element\n */ function getReferenceId(headerId, childWithId, generatedId) {\n if (headerId) {\n return headerId;\n }\n if (childWithId === null || childWithId === void 0 ? void 0 : childWithId.props.id) {\n return childWithId.props.id;\n }\n return generatedId;\n}\n/**\n * Create the state required to render CardHeader.\n *\n * The returned state can be modified with hooks such as useCardHeaderStyles_unstable,\n * before being passed to renderCardHeader_unstable.\n *\n * @param props - props from this instance of CardHeader\n * @param ref - reference to root HTMLElement of CardHeader\n */ export const useCardHeader_unstable = (props, ref)=>{\n const { image, header, description, action } = props;\n const { selectableA11yProps: { referenceId, setReferenceId } } = useCardContext_unstable();\n const headerRef = React.useRef(null);\n const hasChildId = React.useRef(false);\n const generatedId = useId(cardHeaderClassNames.header, referenceId);\n const headerSlot = slot.optional(header, {\n renderByDefault: true,\n defaultProps: {\n ref: headerRef,\n id: !hasChildId.current ? referenceId : undefined\n },\n elementType: 'div'\n });\n React.useEffect(()=>{\n var _headerRef_current;\n const headerId = !hasChildId.current ? (_headerRef_current = headerRef.current) === null || _headerRef_current === void 0 ? void 0 : _headerRef_current.id : undefined;\n const childWithId = getChildWithId(headerSlot === null || headerSlot === void 0 ? void 0 : headerSlot.children);\n hasChildId.current = Boolean(childWithId);\n setReferenceId(getReferenceId(headerId, childWithId, generatedId));\n }, [\n generatedId,\n header,\n headerSlot,\n setReferenceId\n ]);\n return {\n components: {\n root: 'div',\n image: 'div',\n header: 'div',\n description: 'div',\n action: 'div'\n },\n root: slot.always(getIntrinsicElementProps('div', {\n // FIXME:\n // `ref` is wrongly assigned to be `HTMLElement` instead of `HTMLDivElement`\n // but since it would be a breaking change to fix it, we are casting ref to it's proper type\n ref: ref,\n ...props\n }), {\n elementType: 'div'\n }),\n image: slot.optional(image, {\n elementType: 'div'\n }),\n header: headerSlot,\n description: slot.optional(description, {\n elementType: 'div'\n }),\n action: slot.optional(action, {\n elementType: 'div'\n })\n };\n};\n"," import { jsx as _jsx, jsxs as _jsxs } from \"@fluentui/react-jsx-runtime/jsx-runtime\";\nimport { assertSlots } from '@fluentui/react-utilities';\n/**\n * Render the final JSX of CardHeader.\n */ export const renderCardHeader_unstable = (state)=>{\n assertSlots(state);\n return /*#__PURE__*/ _jsxs(state.root, {\n children: [\n state.image && /*#__PURE__*/ _jsx(state.image, {}),\n state.header && /*#__PURE__*/ _jsx(state.header, {}),\n state.description && /*#__PURE__*/ _jsx(state.description, {}),\n state.action && /*#__PURE__*/ _jsx(state.action, {})\n ]\n });\n};\n","import * as React from 'react';\nimport { useCardHeader_unstable } from './useCardHeader';\nimport { renderCardHeader_unstable } from './renderCardHeader';\nimport { useCardHeaderStyles_unstable } from './useCardHeaderStyles.styles';\n/**\n * Component to render an image, text and an action in a Card component.\n */ export const CardHeader = /*#__PURE__*/ React.forwardRef((props, ref)=>{\n const state = useCardHeader_unstable(props, ref);\n useCardHeaderStyles_unstable(state);\n return renderCardHeader_unstable(state);\n});\nCardHeader.displayName = 'CardHeader';\n","const createStoreImpl = (createState) => {\n let state;\n const listeners = /* @__PURE__ */ new Set();\n const setState = (partial, replace) => {\n const nextState = typeof partial === \"function\" ? partial(state) : partial;\n if (!Object.is(nextState, state)) {\n const previousState = state;\n state = (replace != null ? replace : typeof nextState !== \"object\" || nextState === null) ? nextState : Object.assign({}, state, nextState);\n listeners.forEach((listener) => listener(state, previousState));\n }\n };\n const getState = () => state;\n const getInitialState = () => initialState;\n const subscribe = (listener) => {\n listeners.add(listener);\n return () => listeners.delete(listener);\n };\n const destroy = () => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") {\n console.warn(\n \"[DEPRECATED] The `destroy` method will be unsupported in a future version. Instead use unsubscribe function returned by subscribe. Everything will be garbage-collected if store is garbage-collected.\"\n );\n }\n listeners.clear();\n };\n const api = { setState, getState, getInitialState, subscribe, destroy };\n const initialState = state = createState(setState, getState, api);\n return api;\n};\nconst createStore = (createState) => createState ? createStoreImpl(createState) : createStoreImpl;\nvar vanilla = (createState) => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") {\n console.warn(\n \"[DEPRECATED] Default export is deprecated. Instead use import { createStore } from 'zustand/vanilla'.\"\n );\n }\n return createStore(createState);\n};\n\nexport { createStore, vanilla as default };\n","/**\n * @license React\n * use-sync-external-store-shim.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var e=require(\"react\");function h(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var k=\"function\"===typeof Object.is?Object.is:h,l=e.useState,m=e.useEffect,n=e.useLayoutEffect,p=e.useDebugValue;function q(a,b){var d=b(),f=l({inst:{value:d,getSnapshot:b}}),c=f[0].inst,g=f[1];n(function(){c.value=d;c.getSnapshot=b;r(c)&&g({inst:c})},[a,d,b]);m(function(){r(c)&&g({inst:c});return a(function(){r(c)&&g({inst:c})})},[a]);p(d);return d}\nfunction r(a){var b=a.getSnapshot;a=a.value;try{var d=b();return!k(a,d)}catch(f){return!0}}function t(a,b){return b()}var u=\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement?t:q;exports.useSyncExternalStore=void 0!==e.useSyncExternalStore?e.useSyncExternalStore:u;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","/**\n * @license React\n * use-sync-external-store-shim/with-selector.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var h=require(\"react\"),n=require(\"use-sync-external-store/shim\");function p(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var q=\"function\"===typeof Object.is?Object.is:p,r=n.useSyncExternalStore,t=h.useRef,u=h.useEffect,v=h.useMemo,w=h.useDebugValue;\nexports.useSyncExternalStoreWithSelector=function(a,b,e,l,g){var c=t(null);if(null===c.current){var f={hasValue:!1,value:null};c.current=f}else f=c.current;c=v(function(){function a(a){if(!c){c=!0;d=a;a=l(a);if(void 0!==g&&f.hasValue){var b=f.value;if(g(b,a))return k=b}return k=a}b=k;if(q(d,a))return b;var e=l(a);if(void 0!==g&&g(b,e))return b;d=a;return k=e}var c=!1,d,k,m=void 0===e?null:e;return[function(){return a(b())},null===m?void 0:function(){return a(m())}]},[b,e,l,g]);var d=r(a,c[0],c[1]);\nu(function(){f.hasValue=!0;f.value=d},[d]);w(d);return d};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim/with-selector.development.js');\n}\n","import { createStore } from 'zustand/vanilla';\nexport * from 'zustand/vanilla';\nimport ReactExports from 'react';\nimport useSyncExternalStoreExports from 'use-sync-external-store/shim/with-selector.js';\n\nconst { useDebugValue } = ReactExports;\nconst { useSyncExternalStoreWithSelector } = useSyncExternalStoreExports;\nlet didWarnAboutEqualityFn = false;\nconst identity = (arg) => arg;\nfunction useStore(api, selector = identity, equalityFn) {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\" && equalityFn && !didWarnAboutEqualityFn) {\n console.warn(\n \"[DEPRECATED] Use `createWithEqualityFn` instead of `create` or use `useStoreWithEqualityFn` instead of `useStore`. They can be imported from 'zustand/traditional'. https://github.com/pmndrs/zustand/discussions/1937\"\n );\n didWarnAboutEqualityFn = true;\n }\n const slice = useSyncExternalStoreWithSelector(\n api.subscribe,\n api.getState,\n api.getServerState || api.getInitialState,\n selector,\n equalityFn\n );\n useDebugValue(slice);\n return slice;\n}\nconst createImpl = (createState) => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\" && typeof createState !== \"function\") {\n console.warn(\n \"[DEPRECATED] Passing a vanilla store will be unsupported in a future version. Instead use `import { useStore } from 'zustand'`.\"\n );\n }\n const api = typeof createState === \"function\" ? createStore(createState) : createState;\n const useBoundStore = (selector, equalityFn) => useStore(api, selector, equalityFn);\n Object.assign(useBoundStore, api);\n return useBoundStore;\n};\nconst create = (createState) => createState ? createImpl(createState) : createImpl;\nvar react = (createState) => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") {\n console.warn(\n \"[DEPRECATED] Default export is deprecated. Instead use `import { create } from 'zustand'`.\"\n );\n }\n return create(createState);\n};\n\nexport { create, react as default, useStore };\n","const reduxImpl = (reducer, initial) => (set, _get, api) => {\n api.dispatch = (action) => {\n set((state) => reducer(state, action), false, action);\n return action;\n };\n api.dispatchFromDevtools = true;\n return { dispatch: (...a) => api.dispatch(...a), ...initial };\n};\nconst redux = reduxImpl;\n\nconst trackedConnections = /* @__PURE__ */ new Map();\nconst getTrackedConnectionState = (name) => {\n const api = trackedConnections.get(name);\n if (!api) return {};\n return Object.fromEntries(\n Object.entries(api.stores).map(([key, api2]) => [key, api2.getState()])\n );\n};\nconst extractConnectionInformation = (store, extensionConnector, options) => {\n if (store === void 0) {\n return {\n type: \"untracked\",\n connection: extensionConnector.connect(options)\n };\n }\n const existingConnection = trackedConnections.get(options.name);\n if (existingConnection) {\n return { type: \"tracked\", store, ...existingConnection };\n }\n const newConnection = {\n connection: extensionConnector.connect(options),\n stores: {}\n };\n trackedConnections.set(options.name, newConnection);\n return { type: \"tracked\", store, ...newConnection };\n};\nconst devtoolsImpl = (fn, devtoolsOptions = {}) => (set, get, api) => {\n const { enabled, anonymousActionType, store, ...options } = devtoolsOptions;\n let extensionConnector;\n try {\n extensionConnector = (enabled != null ? enabled : (import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") && window.__REDUX_DEVTOOLS_EXTENSION__;\n } catch (_e) {\n }\n if (!extensionConnector) {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\" && enabled) {\n console.warn(\n \"[zustand devtools middleware] Please install/enable Redux devtools extension\"\n );\n }\n return fn(set, get, api);\n }\n const { connection, ...connectionInformation } = extractConnectionInformation(store, extensionConnector, options);\n let isRecording = true;\n api.setState = (state, replace, nameOrAction) => {\n const r = set(state, replace);\n if (!isRecording) return r;\n const action = nameOrAction === void 0 ? { type: anonymousActionType || \"anonymous\" } : typeof nameOrAction === \"string\" ? { type: nameOrAction } : nameOrAction;\n if (store === void 0) {\n connection == null ? void 0 : connection.send(action, get());\n return r;\n }\n connection == null ? void 0 : connection.send(\n {\n ...action,\n type: `${store}/${action.type}`\n },\n {\n ...getTrackedConnectionState(options.name),\n [store]: api.getState()\n }\n );\n return r;\n };\n const setStateFromDevtools = (...a) => {\n const originalIsRecording = isRecording;\n isRecording = false;\n set(...a);\n isRecording = originalIsRecording;\n };\n const initialState = fn(api.setState, get, api);\n if (connectionInformation.type === \"untracked\") {\n connection == null ? void 0 : connection.init(initialState);\n } else {\n connectionInformation.stores[connectionInformation.store] = api;\n connection == null ? void 0 : connection.init(\n Object.fromEntries(\n Object.entries(connectionInformation.stores).map(([key, store2]) => [\n key,\n key === connectionInformation.store ? initialState : store2.getState()\n ])\n )\n );\n }\n if (api.dispatchFromDevtools && typeof api.dispatch === \"function\") {\n let didWarnAboutReservedActionType = false;\n const originalDispatch = api.dispatch;\n api.dispatch = (...a) => {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\" && a[0].type === \"__setState\" && !didWarnAboutReservedActionType) {\n console.warn(\n '[zustand devtools middleware] \"__setState\" action type is reserved to set state from the devtools. Avoid using it.'\n );\n didWarnAboutReservedActionType = true;\n }\n originalDispatch(...a);\n };\n }\n connection.subscribe((message) => {\n var _a;\n switch (message.type) {\n case \"ACTION\":\n if (typeof message.payload !== \"string\") {\n console.error(\n \"[zustand devtools middleware] Unsupported action format\"\n );\n return;\n }\n return parseJsonThen(\n message.payload,\n (action) => {\n if (action.type === \"__setState\") {\n if (store === void 0) {\n setStateFromDevtools(action.state);\n return;\n }\n if (Object.keys(action.state).length !== 1) {\n console.error(\n `\n [zustand devtools middleware] Unsupported __setState action format. \n When using 'store' option in devtools(), the 'state' should have only one key, which is a value of 'store' that was passed in devtools(),\n and value of this only key should be a state object. Example: { \"type\": \"__setState\", \"state\": { \"abc123Store\": { \"foo\": \"bar\" } } }\n `\n );\n }\n const stateFromDevtools = action.state[store];\n if (stateFromDevtools === void 0 || stateFromDevtools === null) {\n return;\n }\n if (JSON.stringify(api.getState()) !== JSON.stringify(stateFromDevtools)) {\n setStateFromDevtools(stateFromDevtools);\n }\n return;\n }\n if (!api.dispatchFromDevtools) return;\n if (typeof api.dispatch !== \"function\") return;\n api.dispatch(action);\n }\n );\n case \"DISPATCH\":\n switch (message.payload.type) {\n case \"RESET\":\n setStateFromDevtools(initialState);\n if (store === void 0) {\n return connection == null ? void 0 : connection.init(api.getState());\n }\n return connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n case \"COMMIT\":\n if (store === void 0) {\n connection == null ? void 0 : connection.init(api.getState());\n return;\n }\n return connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n case \"ROLLBACK\":\n return parseJsonThen(message.state, (state) => {\n if (store === void 0) {\n setStateFromDevtools(state);\n connection == null ? void 0 : connection.init(api.getState());\n return;\n }\n setStateFromDevtools(state[store]);\n connection == null ? void 0 : connection.init(getTrackedConnectionState(options.name));\n });\n case \"JUMP_TO_STATE\":\n case \"JUMP_TO_ACTION\":\n return parseJsonThen(message.state, (state) => {\n if (store === void 0) {\n setStateFromDevtools(state);\n return;\n }\n if (JSON.stringify(api.getState()) !== JSON.stringify(state[store])) {\n setStateFromDevtools(state[store]);\n }\n });\n case \"IMPORT_STATE\": {\n const { nextLiftedState } = message.payload;\n const lastComputedState = (_a = nextLiftedState.computedStates.slice(-1)[0]) == null ? void 0 : _a.state;\n if (!lastComputedState) return;\n if (store === void 0) {\n setStateFromDevtools(lastComputedState);\n } else {\n setStateFromDevtools(lastComputedState[store]);\n }\n connection == null ? void 0 : connection.send(\n null,\n // FIXME no-any\n nextLiftedState\n );\n return;\n }\n case \"PAUSE_RECORDING\":\n return isRecording = !isRecording;\n }\n return;\n }\n });\n return initialState;\n};\nconst devtools = devtoolsImpl;\nconst parseJsonThen = (stringified, f) => {\n let parsed;\n try {\n parsed = JSON.parse(stringified);\n } catch (e) {\n console.error(\n \"[zustand devtools middleware] Could not parse the received json\",\n e\n );\n }\n if (parsed !== void 0) f(parsed);\n};\n\nconst subscribeWithSelectorImpl = (fn) => (set, get, api) => {\n const origSubscribe = api.subscribe;\n api.subscribe = (selector, optListener, options) => {\n let listener = selector;\n if (optListener) {\n const equalityFn = (options == null ? void 0 : options.equalityFn) || Object.is;\n let currentSlice = selector(api.getState());\n listener = (state) => {\n const nextSlice = selector(state);\n if (!equalityFn(currentSlice, nextSlice)) {\n const previousSlice = currentSlice;\n optListener(currentSlice = nextSlice, previousSlice);\n }\n };\n if (options == null ? void 0 : options.fireImmediately) {\n optListener(currentSlice, currentSlice);\n }\n }\n return origSubscribe(listener);\n };\n const initialState = fn(set, get, api);\n return initialState;\n};\nconst subscribeWithSelector = subscribeWithSelectorImpl;\n\nconst combine = (initialState, create) => (...a) => Object.assign({}, initialState, create(...a));\n\nfunction createJSONStorage(getStorage, options) {\n let storage;\n try {\n storage = getStorage();\n } catch (_e) {\n return;\n }\n const persistStorage = {\n getItem: (name) => {\n var _a;\n const parse = (str2) => {\n if (str2 === null) {\n return null;\n }\n return JSON.parse(str2, options == null ? void 0 : options.reviver);\n };\n const str = (_a = storage.getItem(name)) != null ? _a : null;\n if (str instanceof Promise) {\n return str.then(parse);\n }\n return parse(str);\n },\n setItem: (name, newValue) => storage.setItem(\n name,\n JSON.stringify(newValue, options == null ? void 0 : options.replacer)\n ),\n removeItem: (name) => storage.removeItem(name)\n };\n return persistStorage;\n}\nconst toThenable = (fn) => (input) => {\n try {\n const result = fn(input);\n if (result instanceof Promise) {\n return result;\n }\n return {\n then(onFulfilled) {\n return toThenable(onFulfilled)(result);\n },\n catch(_onRejected) {\n return this;\n }\n };\n } catch (e) {\n return {\n then(_onFulfilled) {\n return this;\n },\n catch(onRejected) {\n return toThenable(onRejected)(e);\n }\n };\n }\n};\nconst oldImpl = (config, baseOptions) => (set, get, api) => {\n let options = {\n getStorage: () => localStorage,\n serialize: JSON.stringify,\n deserialize: JSON.parse,\n partialize: (state) => state,\n version: 0,\n merge: (persistedState, currentState) => ({\n ...currentState,\n ...persistedState\n }),\n ...baseOptions\n };\n let hasHydrated = false;\n const hydrationListeners = /* @__PURE__ */ new Set();\n const finishHydrationListeners = /* @__PURE__ */ new Set();\n let storage;\n try {\n storage = options.getStorage();\n } catch (_e) {\n }\n if (!storage) {\n return config(\n (...args) => {\n console.warn(\n `[zustand persist middleware] Unable to update item '${options.name}', the given storage is currently unavailable.`\n );\n set(...args);\n },\n get,\n api\n );\n }\n const thenableSerialize = toThenable(options.serialize);\n const setItem = () => {\n const state = options.partialize({ ...get() });\n let errorInSync;\n const thenable = thenableSerialize({ state, version: options.version }).then(\n (serializedValue) => storage.setItem(options.name, serializedValue)\n ).catch((e) => {\n errorInSync = e;\n });\n if (errorInSync) {\n throw errorInSync;\n }\n return thenable;\n };\n const savedSetState = api.setState;\n api.setState = (state, replace) => {\n savedSetState(state, replace);\n void setItem();\n };\n const configResult = config(\n (...args) => {\n set(...args);\n void setItem();\n },\n get,\n api\n );\n let stateFromStorage;\n const hydrate = () => {\n var _a;\n if (!storage) return;\n hasHydrated = false;\n hydrationListeners.forEach((cb) => cb(get()));\n const postRehydrationCallback = ((_a = options.onRehydrateStorage) == null ? void 0 : _a.call(options, get())) || void 0;\n return toThenable(storage.getItem.bind(storage))(options.name).then((storageValue) => {\n if (storageValue) {\n return options.deserialize(storageValue);\n }\n }).then((deserializedStorageValue) => {\n if (deserializedStorageValue) {\n if (typeof deserializedStorageValue.version === \"number\" && deserializedStorageValue.version !== options.version) {\n if (options.migrate) {\n return options.migrate(\n deserializedStorageValue.state,\n deserializedStorageValue.version\n );\n }\n console.error(\n `State loaded from storage couldn't be migrated since no migrate function was provided`\n );\n } else {\n return deserializedStorageValue.state;\n }\n }\n }).then((migratedState) => {\n var _a2;\n stateFromStorage = options.merge(\n migratedState,\n (_a2 = get()) != null ? _a2 : configResult\n );\n set(stateFromStorage, true);\n return setItem();\n }).then(() => {\n postRehydrationCallback == null ? void 0 : postRehydrationCallback(stateFromStorage, void 0);\n hasHydrated = true;\n finishHydrationListeners.forEach((cb) => cb(stateFromStorage));\n }).catch((e) => {\n postRehydrationCallback == null ? void 0 : postRehydrationCallback(void 0, e);\n });\n };\n api.persist = {\n setOptions: (newOptions) => {\n options = {\n ...options,\n ...newOptions\n };\n if (newOptions.getStorage) {\n storage = newOptions.getStorage();\n }\n },\n clearStorage: () => {\n storage == null ? void 0 : storage.removeItem(options.name);\n },\n getOptions: () => options,\n rehydrate: () => hydrate(),\n hasHydrated: () => hasHydrated,\n onHydrate: (cb) => {\n hydrationListeners.add(cb);\n return () => {\n hydrationListeners.delete(cb);\n };\n },\n onFinishHydration: (cb) => {\n finishHydrationListeners.add(cb);\n return () => {\n finishHydrationListeners.delete(cb);\n };\n }\n };\n hydrate();\n return stateFromStorage || configResult;\n};\nconst newImpl = (config, baseOptions) => (set, get, api) => {\n let options = {\n storage: createJSONStorage(() => localStorage),\n partialize: (state) => state,\n version: 0,\n merge: (persistedState, currentState) => ({\n ...currentState,\n ...persistedState\n }),\n ...baseOptions\n };\n let hasHydrated = false;\n const hydrationListeners = /* @__PURE__ */ new Set();\n const finishHydrationListeners = /* @__PURE__ */ new Set();\n let storage = options.storage;\n if (!storage) {\n return config(\n (...args) => {\n console.warn(\n `[zustand persist middleware] Unable to update item '${options.name}', the given storage is currently unavailable.`\n );\n set(...args);\n },\n get,\n api\n );\n }\n const setItem = () => {\n const state = options.partialize({ ...get() });\n return storage.setItem(options.name, {\n state,\n version: options.version\n });\n };\n const savedSetState = api.setState;\n api.setState = (state, replace) => {\n savedSetState(state, replace);\n void setItem();\n };\n const configResult = config(\n (...args) => {\n set(...args);\n void setItem();\n },\n get,\n api\n );\n api.getInitialState = () => configResult;\n let stateFromStorage;\n const hydrate = () => {\n var _a, _b;\n if (!storage) return;\n hasHydrated = false;\n hydrationListeners.forEach((cb) => {\n var _a2;\n return cb((_a2 = get()) != null ? _a2 : configResult);\n });\n const postRehydrationCallback = ((_b = options.onRehydrateStorage) == null ? void 0 : _b.call(options, (_a = get()) != null ? _a : configResult)) || void 0;\n return toThenable(storage.getItem.bind(storage))(options.name).then((deserializedStorageValue) => {\n if (deserializedStorageValue) {\n if (typeof deserializedStorageValue.version === \"number\" && deserializedStorageValue.version !== options.version) {\n if (options.migrate) {\n return [\n true,\n options.migrate(\n deserializedStorageValue.state,\n deserializedStorageValue.version\n )\n ];\n }\n console.error(\n `State loaded from storage couldn't be migrated since no migrate function was provided`\n );\n } else {\n return [false, deserializedStorageValue.state];\n }\n }\n return [false, void 0];\n }).then((migrationResult) => {\n var _a2;\n const [migrated, migratedState] = migrationResult;\n stateFromStorage = options.merge(\n migratedState,\n (_a2 = get()) != null ? _a2 : configResult\n );\n set(stateFromStorage, true);\n if (migrated) {\n return setItem();\n }\n }).then(() => {\n postRehydrationCallback == null ? void 0 : postRehydrationCallback(stateFromStorage, void 0);\n stateFromStorage = get();\n hasHydrated = true;\n finishHydrationListeners.forEach((cb) => cb(stateFromStorage));\n }).catch((e) => {\n postRehydrationCallback == null ? void 0 : postRehydrationCallback(void 0, e);\n });\n };\n api.persist = {\n setOptions: (newOptions) => {\n options = {\n ...options,\n ...newOptions\n };\n if (newOptions.storage) {\n storage = newOptions.storage;\n }\n },\n clearStorage: () => {\n storage == null ? void 0 : storage.removeItem(options.name);\n },\n getOptions: () => options,\n rehydrate: () => hydrate(),\n hasHydrated: () => hasHydrated,\n onHydrate: (cb) => {\n hydrationListeners.add(cb);\n return () => {\n hydrationListeners.delete(cb);\n };\n },\n onFinishHydration: (cb) => {\n finishHydrationListeners.add(cb);\n return () => {\n finishHydrationListeners.delete(cb);\n };\n }\n };\n if (!options.skipHydration) {\n hydrate();\n }\n return stateFromStorage || configResult;\n};\nconst persistImpl = (config, baseOptions) => {\n if (\"getStorage\" in baseOptions || \"serialize\" in baseOptions || \"deserialize\" in baseOptions) {\n if ((import.meta.env ? import.meta.env.MODE : void 0) !== \"production\") {\n console.warn(\n \"[DEPRECATED] `getStorage`, `serialize` and `deserialize` options are deprecated. Use `storage` option instead.\"\n );\n }\n return oldImpl(config, baseOptions);\n }\n return newImpl(config, baseOptions);\n};\nconst persist = persistImpl;\n\nexport { combine, createJSONStorage, devtools, persist, redux, subscribeWithSelector };\n","import { create } from \"zustand\";\r\nimport { IZustandState, ScreenSize } from \"documentdrafter-components\";\r\nimport { createJSONStorage, persist } from \"zustand/middleware\";\r\nimport { HubConnection } from \"@microsoft/signalr\";\r\n\r\nexport const useStore = create()(\r\n persist(\r\n (set) => ({\r\n isUserAuthenticated: false,\r\n endpoints: { authenticationAPI: \"\", baseAPI: \"\", questionnaireAPI: \"\", draftMindAPI: \"\" },\r\n availableWorkspaces: [],\r\n workspaceDirectory: { templates: [], clauses: [], styleConfig: null },\r\n screenSize: ScreenSize.fullScreen,\r\n portalConfig: undefined,\r\n signalRUpdate: { userDocumentUpdated: \"\", dirEntriesUpdated: [] },\r\n signalRConnection: undefined,\r\n portalLinks: [],\r\n userObj: undefined,\r\n }),\r\n {\r\n name: \"user-storage\",\r\n storage: createJSONStorage(() => sessionStorage),\r\n },\r\n ),\r\n);\r\nexport default useStore;\r\n","import { create } from \"zustand\";\r\nimport { persist } from \"zustand/middleware\";\r\nimport { Theme, webLightTheme } from \"@fluentui/react-components\";\r\n\r\nimport { IPersistentZustandState } from \"documentdrafter-components\";\r\n\r\nconst usePersistentStore = create()(\r\n persist(\r\n (set) => ({\r\n currentTheme: webLightTheme,\r\n setCurrentTheme: (newTheme: Theme) => set({ currentTheme: newTheme }),\r\n darkMode: false,\r\n recentWorkspaces: [],\r\n setRecentWorkspaces: (newList: string[]) => set({ recentWorkspaces: newList }),\r\n \r\n documentColumnsResizeValues: {\r\n file: { minWidth: 32, idealWidth: 32, defaultWidth: 32 },\r\n name: { minWidth: 100, idealWidth: 350, defaultWidth: 350 },\r\n date: { minWidth: 50, idealWidth: 150, defaultWidth: 150 },\r\n shared: { minWidth: 50, idealWidth: 150, defaultWidth: 150 },\r\n modifiedby: { minWidth: 50, idealWidth: 150, defaultWidth: 150 },\r\n reference: { minWidth: 50, idealWidth: 150, defaultWidth: 150 },\r\n path: { minWidth: 200, idealWidth: 250, defaultWidth: 250 },\r\n },\r\n templateColumnsResizeValues: {\r\n file: { minWidth: 20, idealWidth: 30, defaultWidth: 30 },\r\n name: { minWidth: 200, idealWidth: 250, defaultWidth: 250 },\r\n path: { minWidth: 200, idealWidth: 250, defaultWidth: 250 },\r\n },\r\n }),\r\n {\r\n name: \"user-storage-persist\",\r\n },\r\n ),\r\n);\r\n\r\nexport default usePersistentStore;\r\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = assertString;\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction assertString(input) {\n var isString = typeof input === 'string' || input instanceof String;\n\n if (!isString) {\n var invalidType = _typeof(input);\n\n if (input === null) invalidType = 'null';else if (invalidType === 'object') invalidType = input.constructor.name;\n throw new TypeError(\"Expected a string but received a \".concat(invalidType));\n }\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = toDate;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction toDate(date) {\n (0, _assertString.default)(date);\n date = Date.parse(date);\n return !isNaN(date) ? new Date(date) : null;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.commaDecimal = exports.dotDecimal = exports.bengaliLocales = exports.farsiLocales = exports.arabicLocales = exports.englishLocales = exports.decimal = exports.alphanumeric = exports.alpha = void 0;\nvar alpha = {\n 'en-US': /^[A-Z]+$/i,\n 'az-AZ': /^[A-VXYZÇƏĞİıÖŞÜ]+$/i,\n 'bg-BG': /^[А-Я]+$/i,\n 'cs-CZ': /^[A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,\n 'da-DK': /^[A-ZÆØÅ]+$/i,\n 'de-DE': /^[A-ZÄÖÜß]+$/i,\n 'el-GR': /^[Α-ώ]+$/i,\n 'es-ES': /^[A-ZÁÉÍÑÓÚÜ]+$/i,\n 'fa-IR': /^[ابپتثجچحخدذرزژسشصضطظعغفقکگلمنوهی]+$/i,\n 'fi-FI': /^[A-ZÅÄÖ]+$/i,\n 'fr-FR': /^[A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,\n 'it-IT': /^[A-ZÀÉÈÌÎÓÒÙ]+$/i,\n 'ja-JP': /^[ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,\n 'nb-NO': /^[A-ZÆØÅ]+$/i,\n 'nl-NL': /^[A-ZÁÉËÏÓÖÜÚ]+$/i,\n 'nn-NO': /^[A-ZÆØÅ]+$/i,\n 'hu-HU': /^[A-ZÁÉÍÓÖŐÚÜŰ]+$/i,\n 'pl-PL': /^[A-ZĄĆĘŚŁŃÓŻŹ]+$/i,\n 'pt-PT': /^[A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,\n 'ru-RU': /^[А-ЯЁ]+$/i,\n 'kk-KZ': /^[А-ЯЁ\\u04D8\\u04B0\\u0406\\u04A2\\u0492\\u04AE\\u049A\\u04E8\\u04BA]+$/i,\n 'sl-SI': /^[A-ZČĆĐŠŽ]+$/i,\n 'sk-SK': /^[A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,\n 'sr-RS@latin': /^[A-ZČĆŽŠĐ]+$/i,\n 'sr-RS': /^[А-ЯЂЈЉЊЋЏ]+$/i,\n 'sv-SE': /^[A-ZÅÄÖ]+$/i,\n 'th-TH': /^[ก-๐\\s]+$/i,\n 'tr-TR': /^[A-ZÇĞİıÖŞÜ]+$/i,\n 'uk-UA': /^[А-ЩЬЮЯЄIЇҐі]+$/i,\n 'vi-VN': /^[A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,\n 'ko-KR': /^[ㄱ-ㅎㅏ-ㅣ가-힣]*$/,\n 'ku-IQ': /^[ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,\n ar: /^[ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,\n he: /^[א-ת]+$/,\n fa: /^['آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی']+$/i,\n bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,\n 'hi-IN': /^[\\u0900-\\u0961]+[\\u0972-\\u097F]*$/i,\n 'si-LK': /^[\\u0D80-\\u0DFF]+$/\n};\nexports.alpha = alpha;\nvar alphanumeric = {\n 'en-US': /^[0-9A-Z]+$/i,\n 'az-AZ': /^[0-9A-VXYZÇƏĞİıÖŞÜ]+$/i,\n 'bg-BG': /^[0-9А-Я]+$/i,\n 'cs-CZ': /^[0-9A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,\n 'da-DK': /^[0-9A-ZÆØÅ]+$/i,\n 'de-DE': /^[0-9A-ZÄÖÜß]+$/i,\n 'el-GR': /^[0-9Α-ω]+$/i,\n 'es-ES': /^[0-9A-ZÁÉÍÑÓÚÜ]+$/i,\n 'fi-FI': /^[0-9A-ZÅÄÖ]+$/i,\n 'fr-FR': /^[0-9A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,\n 'it-IT': /^[0-9A-ZÀÉÈÌÎÓÒÙ]+$/i,\n 'ja-JP': /^[0-90-9ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,\n 'hu-HU': /^[0-9A-ZÁÉÍÓÖŐÚÜŰ]+$/i,\n 'nb-NO': /^[0-9A-ZÆØÅ]+$/i,\n 'nl-NL': /^[0-9A-ZÁÉËÏÓÖÜÚ]+$/i,\n 'nn-NO': /^[0-9A-ZÆØÅ]+$/i,\n 'pl-PL': /^[0-9A-ZĄĆĘŚŁŃÓŻŹ]+$/i,\n 'pt-PT': /^[0-9A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,\n 'ru-RU': /^[0-9А-ЯЁ]+$/i,\n 'kk-KZ': /^[0-9А-ЯЁ\\u04D8\\u04B0\\u0406\\u04A2\\u0492\\u04AE\\u049A\\u04E8\\u04BA]+$/i,\n 'sl-SI': /^[0-9A-ZČĆĐŠŽ]+$/i,\n 'sk-SK': /^[0-9A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,\n 'sr-RS@latin': /^[0-9A-ZČĆŽŠĐ]+$/i,\n 'sr-RS': /^[0-9А-ЯЂЈЉЊЋЏ]+$/i,\n 'sv-SE': /^[0-9A-ZÅÄÖ]+$/i,\n 'th-TH': /^[ก-๙\\s]+$/i,\n 'tr-TR': /^[0-9A-ZÇĞİıÖŞÜ]+$/i,\n 'uk-UA': /^[0-9А-ЩЬЮЯЄIЇҐі]+$/i,\n 'ko-KR': /^[0-9ㄱ-ㅎㅏ-ㅣ가-힣]*$/,\n 'ku-IQ': /^[٠١٢٣٤٥٦٧٨٩0-9ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,\n 'vi-VN': /^[0-9A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,\n ar: /^[٠١٢٣٤٥٦٧٨٩0-9ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,\n he: /^[0-9א-ת]+$/,\n fa: /^['0-9آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی۱۲۳۴۵۶۷۸۹۰']+$/i,\n bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣ০১২৩৪৫৬৭৮৯ৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,\n 'hi-IN': /^[\\u0900-\\u0963]+[\\u0966-\\u097F]*$/i,\n 'si-LK': /^[0-9\\u0D80-\\u0DFF]+$/\n};\nexports.alphanumeric = alphanumeric;\nvar decimal = {\n 'en-US': '.',\n ar: '٫'\n};\nexports.decimal = decimal;\nvar englishLocales = ['AU', 'GB', 'HK', 'IN', 'NZ', 'ZA', 'ZM'];\nexports.englishLocales = englishLocales;\n\nfor (var locale, i = 0; i < englishLocales.length; i++) {\n locale = \"en-\".concat(englishLocales[i]);\n alpha[locale] = alpha['en-US'];\n alphanumeric[locale] = alphanumeric['en-US'];\n decimal[locale] = decimal['en-US'];\n} // Source: http://www.localeplanet.com/java/\n\n\nvar arabicLocales = ['AE', 'BH', 'DZ', 'EG', 'IQ', 'JO', 'KW', 'LB', 'LY', 'MA', 'QM', 'QA', 'SA', 'SD', 'SY', 'TN', 'YE'];\nexports.arabicLocales = arabicLocales;\n\nfor (var _locale, _i = 0; _i < arabicLocales.length; _i++) {\n _locale = \"ar-\".concat(arabicLocales[_i]);\n alpha[_locale] = alpha.ar;\n alphanumeric[_locale] = alphanumeric.ar;\n decimal[_locale] = decimal.ar;\n}\n\nvar farsiLocales = ['IR', 'AF'];\nexports.farsiLocales = farsiLocales;\n\nfor (var _locale2, _i2 = 0; _i2 < farsiLocales.length; _i2++) {\n _locale2 = \"fa-\".concat(farsiLocales[_i2]);\n alphanumeric[_locale2] = alphanumeric.fa;\n decimal[_locale2] = decimal.ar;\n}\n\nvar bengaliLocales = ['BD', 'IN'];\nexports.bengaliLocales = bengaliLocales;\n\nfor (var _locale3, _i3 = 0; _i3 < bengaliLocales.length; _i3++) {\n _locale3 = \"bn-\".concat(bengaliLocales[_i3]);\n alpha[_locale3] = alpha.bn;\n alphanumeric[_locale3] = alphanumeric.bn;\n decimal[_locale3] = decimal['en-US'];\n} // Source: https://en.wikipedia.org/wiki/Decimal_mark\n\n\nvar dotDecimal = ['ar-EG', 'ar-LB', 'ar-LY'];\nexports.dotDecimal = dotDecimal;\nvar commaDecimal = ['bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'el-GR', 'en-ZM', 'es-ES', 'fr-CA', 'fr-FR', 'id-ID', 'it-IT', 'ku-IQ', 'hi-IN', 'hu-HU', 'nb-NO', 'nn-NO', 'nl-NL', 'pl-PL', 'pt-PT', 'ru-RU', 'kk-KZ', 'si-LK', 'sl-SI', 'sr-RS@latin', 'sr-RS', 'sv-SE', 'tr-TR', 'uk-UA', 'vi-VN'];\nexports.commaDecimal = commaDecimal;\n\nfor (var _i4 = 0; _i4 < dotDecimal.length; _i4++) {\n decimal[dotDecimal[_i4]] = decimal['en-US'];\n}\n\nfor (var _i5 = 0; _i5 < commaDecimal.length; _i5++) {\n decimal[commaDecimal[_i5]] = ',';\n}\n\nalpha['fr-CA'] = alpha['fr-FR'];\nalphanumeric['fr-CA'] = alphanumeric['fr-FR'];\nalpha['pt-BR'] = alpha['pt-PT'];\nalphanumeric['pt-BR'] = alphanumeric['pt-PT'];\ndecimal['pt-BR'] = decimal['pt-PT']; // see #862\n\nalpha['pl-Pl'] = alpha['pl-PL'];\nalphanumeric['pl-Pl'] = alphanumeric['pl-PL'];\ndecimal['pl-Pl'] = decimal['pl-PL']; // see #1455\n\nalpha['fa-AF'] = alpha.fa;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isFloat;\nexports.locales = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _alpha = require(\"./alpha\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isFloat(str, options) {\n (0, _assertString.default)(str);\n options = options || {};\n var float = new RegExp(\"^(?:[-+])?(?:[0-9]+)?(?:\\\\\".concat(options.locale ? _alpha.decimal[options.locale] : '.', \"[0-9]*)?(?:[eE][\\\\+\\\\-]?(?:[0-9]+))?$\"));\n\n if (str === '' || str === '.' || str === ',' || str === '-' || str === '+') {\n return false;\n }\n\n var value = parseFloat(str.replace(',', '.'));\n return float.test(str) && (!options.hasOwnProperty('min') || value >= options.min) && (!options.hasOwnProperty('max') || value <= options.max) && (!options.hasOwnProperty('lt') || value < options.lt) && (!options.hasOwnProperty('gt') || value > options.gt);\n}\n\nvar locales = Object.keys(_alpha.decimal);\nexports.locales = locales;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = toFloat;\n\nvar _isFloat = _interopRequireDefault(require(\"./isFloat\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction toFloat(str) {\n if (!(0, _isFloat.default)(str)) return NaN;\n return parseFloat(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = toInt;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction toInt(str, radix) {\n (0, _assertString.default)(str);\n return parseInt(str, radix || 10);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = toBoolean;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction toBoolean(str, strict) {\n (0, _assertString.default)(str);\n\n if (strict) {\n return str === '1' || /^true$/i.test(str);\n }\n\n return str !== '0' && !/^false$/i.test(str) && str !== '';\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = equals;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction equals(str, comparison) {\n (0, _assertString.default)(str);\n return str === comparison;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = toString;\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction toString(input) {\n if (_typeof(input) === 'object' && input !== null) {\n if (typeof input.toString === 'function') {\n input = input.toString();\n } else {\n input = '[object Object]';\n }\n } else if (input === null || typeof input === 'undefined' || isNaN(input) && !input.length) {\n input = '';\n }\n\n return String(input);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = merge;\n\nfunction merge() {\n var obj = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var defaults = arguments.length > 1 ? arguments[1] : undefined;\n\n for (var key in defaults) {\n if (typeof obj[key] === 'undefined') {\n obj[key] = defaults[key];\n }\n }\n\n return obj;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = contains;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _toString = _interopRequireDefault(require(\"./util/toString\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar defaulContainsOptions = {\n ignoreCase: false,\n minOccurrences: 1\n};\n\nfunction contains(str, elem, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, defaulContainsOptions);\n\n if (options.ignoreCase) {\n return str.toLowerCase().split((0, _toString.default)(elem).toLowerCase()).length > options.minOccurrences;\n }\n\n return str.split((0, _toString.default)(elem)).length > options.minOccurrences;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = matches;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction matches(str, pattern, modifiers) {\n (0, _assertString.default)(str);\n\n if (Object.prototype.toString.call(pattern) !== '[object RegExp]') {\n pattern = new RegExp(pattern, modifiers);\n }\n\n return !!str.match(pattern);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isByteLength;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/* eslint-disable prefer-rest-params */\nfunction isByteLength(str, options) {\n (0, _assertString.default)(str);\n var min;\n var max;\n\n if (_typeof(options) === 'object') {\n min = options.min || 0;\n max = options.max;\n } else {\n // backwards compatibility: isByteLength(str, min [, max])\n min = arguments[1];\n max = arguments[2];\n }\n\n var len = encodeURI(str).split(/%..|./).length - 1;\n return len >= min && (typeof max === 'undefined' || len <= max);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isFQDN;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar default_fqdn_options = {\n require_tld: true,\n allow_underscores: false,\n allow_trailing_dot: false,\n allow_numeric_tld: false,\n allow_wildcard: false,\n ignore_max_length: false\n};\n\nfunction isFQDN(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, default_fqdn_options);\n /* Remove the optional trailing dot before checking validity */\n\n if (options.allow_trailing_dot && str[str.length - 1] === '.') {\n str = str.substring(0, str.length - 1);\n }\n /* Remove the optional wildcard before checking validity */\n\n\n if (options.allow_wildcard === true && str.indexOf('*.') === 0) {\n str = str.substring(2);\n }\n\n var parts = str.split('.');\n var tld = parts[parts.length - 1];\n\n if (options.require_tld) {\n // disallow fqdns without tld\n if (parts.length < 2) {\n return false;\n }\n\n if (!options.allow_numeric_tld && !/^([a-z\\u00A1-\\u00A8\\u00AA-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF]{2,}|xn[a-z0-9-]{2,})$/i.test(tld)) {\n return false;\n } // disallow spaces\n\n\n if (/\\s/.test(tld)) {\n return false;\n }\n } // reject numeric TLDs\n\n\n if (!options.allow_numeric_tld && /^\\d+$/.test(tld)) {\n return false;\n }\n\n return parts.every(function (part) {\n if (part.length > 63 && !options.ignore_max_length) {\n return false;\n }\n\n if (!/^[a-z_\\u00a1-\\uffff0-9-]+$/i.test(part)) {\n return false;\n } // disallow full-width chars\n\n\n if (/[\\uff01-\\uff5e]/.test(part)) {\n return false;\n } // disallow parts starting or ending with hyphen\n\n\n if (/^-|-$/.test(part)) {\n return false;\n }\n\n if (!options.allow_underscores && /_/.test(part)) {\n return false;\n }\n\n return true;\n });\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isIP;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n11.3. Examples\n\n The following addresses\n\n fe80::1234 (on the 1st link of the node)\n ff02::5678 (on the 5th link of the node)\n ff08::9abc (on the 10th organization of the node)\n\n would be represented as follows:\n\n fe80::1234%1\n ff02::5678%5\n ff08::9abc%10\n\n (Here we assume a natural translation from a zone index to the\n part, where the Nth zone of any scope is translated into\n \"N\".)\n\n If we use interface names as , those addresses could also be\n represented as follows:\n\n fe80::1234%ne0\n ff02::5678%pvc1.3\n ff08::9abc%interface10\n\n where the interface \"ne0\" belongs to the 1st link, \"pvc1.3\" belongs\n to the 5th link, and \"interface10\" belongs to the 10th organization.\n * * */\nvar IPv4SegmentFormat = '(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])';\nvar IPv4AddressFormat = \"(\".concat(IPv4SegmentFormat, \"[.]){3}\").concat(IPv4SegmentFormat);\nvar IPv4AddressRegExp = new RegExp(\"^\".concat(IPv4AddressFormat, \"$\"));\nvar IPv6SegmentFormat = '(?:[0-9a-fA-F]{1,4})';\nvar IPv6AddressRegExp = new RegExp('^(' + \"(?:\".concat(IPv6SegmentFormat, \":){7}(?:\").concat(IPv6SegmentFormat, \"|:)|\") + \"(?:\".concat(IPv6SegmentFormat, \":){6}(?:\").concat(IPv4AddressFormat, \"|:\").concat(IPv6SegmentFormat, \"|:)|\") + \"(?:\".concat(IPv6SegmentFormat, \":){5}(?::\").concat(IPv4AddressFormat, \"|(:\").concat(IPv6SegmentFormat, \"){1,2}|:)|\") + \"(?:\".concat(IPv6SegmentFormat, \":){4}(?:(:\").concat(IPv6SegmentFormat, \"){0,1}:\").concat(IPv4AddressFormat, \"|(:\").concat(IPv6SegmentFormat, \"){1,3}|:)|\") + \"(?:\".concat(IPv6SegmentFormat, \":){3}(?:(:\").concat(IPv6SegmentFormat, \"){0,2}:\").concat(IPv4AddressFormat, \"|(:\").concat(IPv6SegmentFormat, \"){1,4}|:)|\") + \"(?:\".concat(IPv6SegmentFormat, \":){2}(?:(:\").concat(IPv6SegmentFormat, \"){0,3}:\").concat(IPv4AddressFormat, \"|(:\").concat(IPv6SegmentFormat, \"){1,5}|:)|\") + \"(?:\".concat(IPv6SegmentFormat, \":){1}(?:(:\").concat(IPv6SegmentFormat, \"){0,4}:\").concat(IPv4AddressFormat, \"|(:\").concat(IPv6SegmentFormat, \"){1,6}|:)|\") + \"(?::((?::\".concat(IPv6SegmentFormat, \"){0,5}:\").concat(IPv4AddressFormat, \"|(?::\").concat(IPv6SegmentFormat, \"){1,7}|:))\") + ')(%[0-9a-zA-Z-.:]{1,})?$');\n\nfunction isIP(str) {\n var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n (0, _assertString.default)(str);\n version = String(version);\n\n if (!version) {\n return isIP(str, 4) || isIP(str, 6);\n }\n\n if (version === '4') {\n return IPv4AddressRegExp.test(str);\n }\n\n if (version === '6') {\n return IPv6AddressRegExp.test(str);\n }\n\n return false;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isEmail;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isByteLength = _interopRequireDefault(require(\"./isByteLength\"));\n\nvar _isFQDN = _interopRequireDefault(require(\"./isFQDN\"));\n\nvar _isIP = _interopRequireDefault(require(\"./isIP\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar default_email_options = {\n allow_display_name: false,\n allow_underscores: false,\n require_display_name: false,\n allow_utf8_local_part: true,\n require_tld: true,\n blacklisted_chars: '',\n ignore_max_length: false,\n host_blacklist: [],\n host_whitelist: []\n};\n/* eslint-disable max-len */\n\n/* eslint-disable no-control-regex */\n\nvar splitNameAddress = /^([^\\x00-\\x1F\\x7F-\\x9F\\cX]+)]/.test(display_name_without_quotes);\n\n if (contains_illegal) {\n // if contains illegal characters,\n // must to be enclosed in double-quotes, otherwise it's not a valid display name\n if (display_name_without_quotes === display_name) {\n return false;\n } // the quotes in display name must start with character symbol \\\n\n\n var all_start_with_back_slash = display_name_without_quotes.split('\"').length === display_name_without_quotes.split('\\\\\"').length;\n\n if (!all_start_with_back_slash) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction isEmail(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, default_email_options);\n\n if (options.require_display_name || options.allow_display_name) {\n var display_email = str.match(splitNameAddress);\n\n if (display_email) {\n var display_name = display_email[1]; // Remove display name and angle brackets to get email address\n // Can be done in the regex but will introduce a ReDOS (See #1597 for more info)\n\n str = str.replace(display_name, '').replace(/(^<|>$)/g, ''); // sometimes need to trim the last space to get the display name\n // because there may be a space between display name and email address\n // eg. myname \n // the display name is `myname` instead of `myname `, so need to trim the last space\n\n if (display_name.endsWith(' ')) {\n display_name = display_name.slice(0, -1);\n }\n\n if (!validateDisplayName(display_name)) {\n return false;\n }\n } else if (options.require_display_name) {\n return false;\n }\n }\n\n if (!options.ignore_max_length && str.length > defaultMaxEmailLength) {\n return false;\n }\n\n var parts = str.split('@');\n var domain = parts.pop();\n var lower_domain = domain.toLowerCase();\n\n if (options.host_blacklist.includes(lower_domain)) {\n return false;\n }\n\n if (options.host_whitelist.length > 0 && !options.host_whitelist.includes(lower_domain)) {\n return false;\n }\n\n var user = parts.join('@');\n\n if (options.domain_specific_validation && (lower_domain === 'gmail.com' || lower_domain === 'googlemail.com')) {\n /*\n Previously we removed dots for gmail addresses before validating.\n This was removed because it allows `multiple..dots@gmail.com`\n to be reported as valid, but it is not.\n Gmail only normalizes single dots, removing them from here is pointless,\n should be done in normalizeEmail\n */\n user = user.toLowerCase(); // Removing sub-address from username before gmail validation\n\n var username = user.split('+')[0]; // Dots are not included in gmail length restriction\n\n if (!(0, _isByteLength.default)(username.replace(/\\./g, ''), {\n min: 6,\n max: 30\n })) {\n return false;\n }\n\n var _user_parts = username.split('.');\n\n for (var i = 0; i < _user_parts.length; i++) {\n if (!gmailUserPart.test(_user_parts[i])) {\n return false;\n }\n }\n }\n\n if (options.ignore_max_length === false && (!(0, _isByteLength.default)(user, {\n max: 64\n }) || !(0, _isByteLength.default)(domain, {\n max: 254\n }))) {\n return false;\n }\n\n if (!(0, _isFQDN.default)(domain, {\n require_tld: options.require_tld,\n ignore_max_length: options.ignore_max_length,\n allow_underscores: options.allow_underscores\n })) {\n if (!options.allow_ip_domain) {\n return false;\n }\n\n if (!(0, _isIP.default)(domain)) {\n if (!domain.startsWith('[') || !domain.endsWith(']')) {\n return false;\n }\n\n var noBracketdomain = domain.slice(1, -1);\n\n if (noBracketdomain.length === 0 || !(0, _isIP.default)(noBracketdomain)) {\n return false;\n }\n }\n }\n\n if (user[0] === '\"') {\n user = user.slice(1, user.length - 1);\n return options.allow_utf8_local_part ? quotedEmailUserUtf8.test(user) : quotedEmailUser.test(user);\n }\n\n var pattern = options.allow_utf8_local_part ? emailUserUtf8Part : emailUserPart;\n var user_parts = user.split('.');\n\n for (var _i = 0; _i < user_parts.length; _i++) {\n if (!pattern.test(user_parts[_i])) {\n return false;\n }\n }\n\n if (options.blacklisted_chars) {\n if (user.search(new RegExp(\"[\".concat(options.blacklisted_chars, \"]+\"), 'g')) !== -1) return false;\n }\n\n return true;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isURL;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isFQDN = _interopRequireDefault(require(\"./isFQDN\"));\n\nvar _isIP = _interopRequireDefault(require(\"./isIP\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _iterableToArrayLimit(arr, i) { if (typeof Symbol === \"undefined\" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\n/*\noptions for isURL method\n\nrequire_protocol - if set as true isURL will return false if protocol is not present in the URL\nrequire_valid_protocol - isURL will check if the URL's protocol is present in the protocols option\nprotocols - valid protocols can be modified with this option\nrequire_host - if set as false isURL will not check if host is present in the URL\nrequire_port - if set as true isURL will check if port is present in the URL\nallow_protocol_relative_urls - if set as true protocol relative URLs will be allowed\nvalidate_length - if set as false isURL will skip string length validation (IE maximum is 2083)\n\n*/\nvar default_url_options = {\n protocols: ['http', 'https', 'ftp'],\n require_tld: true,\n require_protocol: false,\n require_host: true,\n require_port: false,\n require_valid_protocol: true,\n allow_underscores: false,\n allow_trailing_dot: false,\n allow_protocol_relative_urls: false,\n allow_fragments: true,\n allow_query_components: true,\n validate_length: true\n};\nvar wrapped_ipv6 = /^\\[([^\\]]+)\\](?::([0-9]+))?$/;\n\nfunction isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n}\n\nfunction checkHost(host, matches) {\n for (var i = 0; i < matches.length; i++) {\n var match = matches[i];\n\n if (host === match || isRegExp(match) && match.test(host)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction isURL(url, options) {\n (0, _assertString.default)(url);\n\n if (!url || /[\\s<>]/.test(url)) {\n return false;\n }\n\n if (url.indexOf('mailto:') === 0) {\n return false;\n }\n\n options = (0, _merge.default)(options, default_url_options);\n\n if (options.validate_length && url.length >= 2083) {\n return false;\n }\n\n if (!options.allow_fragments && url.includes('#')) {\n return false;\n }\n\n if (!options.allow_query_components && (url.includes('?') || url.includes('&'))) {\n return false;\n }\n\n var protocol, auth, host, hostname, port, port_str, split, ipv6;\n split = url.split('#');\n url = split.shift();\n split = url.split('?');\n url = split.shift();\n split = url.split('://');\n\n if (split.length > 1) {\n protocol = split.shift().toLowerCase();\n\n if (options.require_valid_protocol && options.protocols.indexOf(protocol) === -1) {\n return false;\n }\n } else if (options.require_protocol) {\n return false;\n } else if (url.slice(0, 2) === '//') {\n if (!options.allow_protocol_relative_urls) {\n return false;\n }\n\n split[0] = url.slice(2);\n }\n\n url = split.join('://');\n\n if (url === '') {\n return false;\n }\n\n split = url.split('/');\n url = split.shift();\n\n if (url === '' && !options.require_host) {\n return true;\n }\n\n split = url.split('@');\n\n if (split.length > 1) {\n if (options.disallow_auth) {\n return false;\n }\n\n if (split[0] === '') {\n return false;\n }\n\n auth = split.shift();\n\n if (auth.indexOf(':') >= 0 && auth.split(':').length > 2) {\n return false;\n }\n\n var _auth$split = auth.split(':'),\n _auth$split2 = _slicedToArray(_auth$split, 2),\n user = _auth$split2[0],\n password = _auth$split2[1];\n\n if (user === '' && password === '') {\n return false;\n }\n }\n\n hostname = split.join('@');\n port_str = null;\n ipv6 = null;\n var ipv6_match = hostname.match(wrapped_ipv6);\n\n if (ipv6_match) {\n host = '';\n ipv6 = ipv6_match[1];\n port_str = ipv6_match[2] || null;\n } else {\n split = hostname.split(':');\n host = split.shift();\n\n if (split.length) {\n port_str = split.join(':');\n }\n }\n\n if (port_str !== null && port_str.length > 0) {\n port = parseInt(port_str, 10);\n\n if (!/^[0-9]+$/.test(port_str) || port <= 0 || port > 65535) {\n return false;\n }\n } else if (options.require_port) {\n return false;\n }\n\n if (options.host_whitelist) {\n return checkHost(host, options.host_whitelist);\n }\n\n if (host === '' && !options.require_host) {\n return true;\n }\n\n if (!(0, _isIP.default)(host) && !(0, _isFQDN.default)(host, options) && (!ipv6 || !(0, _isIP.default)(ipv6, 6))) {\n return false;\n }\n\n host = host || ipv6;\n\n if (options.host_blacklist && checkHost(host, options.host_blacklist)) {\n return false;\n }\n\n return true;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMACAddress;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar macAddress48 = /^(?:[0-9a-fA-F]{2}([-:\\s]))([0-9a-fA-F]{2}\\1){4}([0-9a-fA-F]{2})$/;\nvar macAddress48NoSeparators = /^([0-9a-fA-F]){12}$/;\nvar macAddress48WithDots = /^([0-9a-fA-F]{4}\\.){2}([0-9a-fA-F]{4})$/;\nvar macAddress64 = /^(?:[0-9a-fA-F]{2}([-:\\s]))([0-9a-fA-F]{2}\\1){6}([0-9a-fA-F]{2})$/;\nvar macAddress64NoSeparators = /^([0-9a-fA-F]){16}$/;\nvar macAddress64WithDots = /^([0-9a-fA-F]{4}\\.){3}([0-9a-fA-F]{4})$/;\n\nfunction isMACAddress(str, options) {\n (0, _assertString.default)(str);\n\n if (options !== null && options !== void 0 && options.eui) {\n options.eui = String(options.eui);\n }\n /**\n * @deprecated `no_colons` TODO: remove it in the next major\n */\n\n\n if (options !== null && options !== void 0 && options.no_colons || options !== null && options !== void 0 && options.no_separators) {\n if (options.eui === '48') {\n return macAddress48NoSeparators.test(str);\n }\n\n if (options.eui === '64') {\n return macAddress64NoSeparators.test(str);\n }\n\n return macAddress48NoSeparators.test(str) || macAddress64NoSeparators.test(str);\n }\n\n if ((options === null || options === void 0 ? void 0 : options.eui) === '48') {\n return macAddress48.test(str) || macAddress48WithDots.test(str);\n }\n\n if ((options === null || options === void 0 ? void 0 : options.eui) === '64') {\n return macAddress64.test(str) || macAddress64WithDots.test(str);\n }\n\n return isMACAddress(str, {\n eui: '48'\n }) || isMACAddress(str, {\n eui: '64'\n });\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isIPRange;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isIP = _interopRequireDefault(require(\"./isIP\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar subnetMaybe = /^\\d{1,3}$/;\nvar v4Subnet = 32;\nvar v6Subnet = 128;\n\nfunction isIPRange(str) {\n var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n (0, _assertString.default)(str);\n var parts = str.split('/'); // parts[0] -> ip, parts[1] -> subnet\n\n if (parts.length !== 2) {\n return false;\n }\n\n if (!subnetMaybe.test(parts[1])) {\n return false;\n } // Disallow preceding 0 i.e. 01, 02, ...\n\n\n if (parts[1].length > 1 && parts[1].startsWith('0')) {\n return false;\n }\n\n var isValidIP = (0, _isIP.default)(parts[0], version);\n\n if (!isValidIP) {\n return false;\n } // Define valid subnet according to IP's version\n\n\n var expectedSubnet = null;\n\n switch (String(version)) {\n case '4':\n expectedSubnet = v4Subnet;\n break;\n\n case '6':\n expectedSubnet = v6Subnet;\n break;\n\n default:\n expectedSubnet = (0, _isIP.default)(parts[0], '6') ? v6Subnet : v4Subnet;\n }\n\n return parts[1] <= expectedSubnet && parts[1] >= 0;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isDate;\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _iterableToArrayLimit(arr, i) { if (typeof Symbol === \"undefined\" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nvar default_date_options = {\n format: 'YYYY/MM/DD',\n delimiters: ['/', '-'],\n strictMode: false\n};\n\nfunction isValidFormat(format) {\n return /(^(y{4}|y{2})[.\\/-](m{1,2})[.\\/-](d{1,2})$)|(^(m{1,2})[.\\/-](d{1,2})[.\\/-]((y{4}|y{2})$))|(^(d{1,2})[.\\/-](m{1,2})[.\\/-]((y{4}|y{2})$))/gi.test(format);\n}\n\nfunction zip(date, format) {\n var zippedArr = [],\n len = Math.min(date.length, format.length);\n\n for (var i = 0; i < len; i++) {\n zippedArr.push([date[i], format[i]]);\n }\n\n return zippedArr;\n}\n\nfunction isDate(input, options) {\n if (typeof options === 'string') {\n // Allow backward compatbility for old format isDate(input [, format])\n options = (0, _merge.default)({\n format: options\n }, default_date_options);\n } else {\n options = (0, _merge.default)(options, default_date_options);\n }\n\n if (typeof input === 'string' && isValidFormat(options.format)) {\n var formatDelimiter = options.delimiters.find(function (delimiter) {\n return options.format.indexOf(delimiter) !== -1;\n });\n var dateDelimiter = options.strictMode ? formatDelimiter : options.delimiters.find(function (delimiter) {\n return input.indexOf(delimiter) !== -1;\n });\n var dateAndFormat = zip(input.split(dateDelimiter), options.format.toLowerCase().split(formatDelimiter));\n var dateObj = {};\n\n var _iterator = _createForOfIteratorHelper(dateAndFormat),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var _step$value = _slicedToArray(_step.value, 2),\n dateWord = _step$value[0],\n formatWord = _step$value[1];\n\n if (dateWord.length !== formatWord.length) {\n return false;\n }\n\n dateObj[formatWord.charAt(0)] = dateWord;\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n var fullYear = dateObj.y;\n\n if (dateObj.y.length === 2) {\n var parsedYear = parseInt(dateObj.y, 10);\n\n if (isNaN(parsedYear)) {\n return false;\n }\n\n var currentYearLastTwoDigits = new Date().getFullYear() % 100;\n\n if (parsedYear < currentYearLastTwoDigits) {\n fullYear = \"20\".concat(dateObj.y);\n } else {\n fullYear = \"19\".concat(dateObj.y);\n }\n }\n\n return new Date(\"\".concat(fullYear, \"-\").concat(dateObj.m, \"-\").concat(dateObj.d)).getDate() === +dateObj.d;\n }\n\n if (!options.strictMode) {\n return Object.prototype.toString.call(input) === '[object Date]' && isFinite(input);\n }\n\n return false;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isTime;\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar default_time_options = {\n hourFormat: 'hour24',\n mode: 'default'\n};\nvar formats = {\n hour24: {\n default: /^([01]?[0-9]|2[0-3]):([0-5][0-9])$/,\n withSeconds: /^([01]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$/\n },\n hour12: {\n default: /^(0?[1-9]|1[0-2]):([0-5][0-9]) (A|P)M$/,\n withSeconds: /^(0?[1-9]|1[0-2]):([0-5][0-9]):([0-5][0-9]) (A|P)M$/\n }\n};\n\nfunction isTime(input, options) {\n options = (0, _merge.default)(options, default_time_options);\n if (typeof input !== 'string') return false;\n return formats[options.hourFormat][options.mode].test(input);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isBoolean;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar defaultOptions = {\n loose: false\n};\nvar strictBooleans = ['true', 'false', '1', '0'];\nvar looseBooleans = [].concat(strictBooleans, ['yes', 'no']);\n\nfunction isBoolean(str) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultOptions;\n (0, _assertString.default)(str);\n\n if (options.loose) {\n return looseBooleans.includes(str.toLowerCase());\n }\n\n return strictBooleans.includes(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isLocale;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/*\n = 3ALPHA ; selected ISO 639 codes\n *2(\"-\" 3ALPHA) ; permanently reserved\n */\nvar extlang = '([A-Za-z]{3}(-[A-Za-z]{3}){0,2})';\n/*\n = 2*3ALPHA ; shortest ISO 639 code\n [\"-\" extlang] ; sometimes followed by\n ; extended language subtags\n / 4ALPHA ; or reserved for future use\n / 5*8ALPHA ; or registered language subtag\n */\n\nvar language = \"(([a-zA-Z]{2,3}(-\".concat(extlang, \")?)|([a-zA-Z]{5,8}))\");\n/*\n = 4ALPHA ; ISO 15924 code\n */\n\nvar script = '([A-Za-z]{4})';\n/*\n = 2ALPHA ; ISO 3166-1 code\n / 3DIGIT ; UN M.49 code\n */\n\nvar region = '([A-Za-z]{2}|\\\\d{3})';\n/*\n = 5*8alphanum ; registered variants\n / (DIGIT 3alphanum)\n */\n\nvar variant = '([A-Za-z0-9]{5,8}|(\\\\d[A-Z-a-z0-9]{3}))';\n/*\n = DIGIT ; 0 - 9\n / %x41-57 ; A - W\n / %x59-5A ; Y - Z\n / %x61-77 ; a - w\n / %x79-7A ; y - z\n */\n\nvar singleton = '(\\\\d|[A-W]|[Y-Z]|[a-w]|[y-z])';\n/*\n = singleton 1*(\"-\" (2*8alphanum))\n ; Single alphanumerics\n ; \"x\" reserved for private use\n */\n\nvar extension = \"(\".concat(singleton, \"(-[A-Za-z0-9]{2,8})+)\");\n/*\n = \"x\" 1*(\"-\" (1*8alphanum))\n */\n\nvar privateuse = '(x(-[A-Za-z0-9]{1,8})+)'; // irregular tags do not match the 'langtag' production and would not\n// otherwise be considered 'well-formed'. These tags are all valid, but\n// most are deprecated in favor of more modern subtags or subtag combination\n\nvar irregular = '((en-GB-oed)|(i-ami)|(i-bnn)|(i-default)|(i-enochian)|' + '(i-hak)|(i-klingon)|(i-lux)|(i-mingo)|(i-navajo)|(i-pwn)|(i-tao)|' + '(i-tay)|(i-tsu)|(sgn-BE-FR)|(sgn-BE-NL)|(sgn-CH-DE))'; // regular tags match the 'langtag' production, but their subtags are not\n// extended language or variant subtags: their meaning is defined by\n// their registration and all of these are deprecated in favor of a more\n// modern subtag or sequence of subtags\n\nvar regular = '((art-lojban)|(cel-gaulish)|(no-bok)|(no-nyn)|(zh-guoyu)|' + '(zh-hakka)|(zh-min)|(zh-min-nan)|(zh-xiang))';\n/*\n = irregular ; non-redundant tags registered\n / regular ; during the RFC 3066 era\n\n */\n\nvar grandfathered = \"(\".concat(irregular, \"|\").concat(regular, \")\");\n/*\n RFC 5646 defines delimitation of subtags via a hyphen:\n\n \"Subtag\" refers to a specific section of a tag, delimited by a\n hyphen, such as the subtags 'zh', 'Hant', and 'CN' in the tag \"zh-\n Hant-CN\". Examples of subtags in this document are enclosed in\n single quotes ('Hant')\n\n However, we need to add \"_\" to maintain the existing behaviour.\n */\n\nvar delimiter = '(-|_)';\n/*\n = language\n [\"-\" script]\n [\"-\" region]\n *(\"-\" variant)\n *(\"-\" extension)\n [\"-\" privateuse]\n */\n\nvar langtag = \"\".concat(language, \"(\").concat(delimiter).concat(script, \")?(\").concat(delimiter).concat(region, \")?(\").concat(delimiter).concat(variant, \")*(\").concat(delimiter).concat(extension, \")*(\").concat(delimiter).concat(privateuse, \")?\");\n/*\n Regex implementation based on BCP RFC 5646\n Tags for Identifying Languages\n https://www.rfc-editor.org/rfc/rfc5646.html\n */\n\nvar languageTagRegex = new RegExp(\"(^\".concat(privateuse, \"$)|(^\").concat(grandfathered, \"$)|(^\").concat(langtag, \"$)\"));\n\nfunction isLocale(str) {\n (0, _assertString.default)(str);\n return languageTagRegex.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isAlpha;\nexports.locales = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _alpha = require(\"./alpha\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isAlpha(_str) {\n var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n (0, _assertString.default)(_str);\n var str = _str;\n var ignore = options.ignore;\n\n if (ignore) {\n if (ignore instanceof RegExp) {\n str = str.replace(ignore, '');\n } else if (typeof ignore === 'string') {\n str = str.replace(new RegExp(\"[\".concat(ignore.replace(/[-[\\]{}()*+?.,\\\\^$|#\\\\s]/g, '\\\\$&'), \"]\"), 'g'), ''); // escape regex for ignore\n } else {\n throw new Error('ignore should be instance of a String or RegExp');\n }\n }\n\n if (locale in _alpha.alpha) {\n return _alpha.alpha[locale].test(str);\n }\n\n throw new Error(\"Invalid locale '\".concat(locale, \"'\"));\n}\n\nvar locales = Object.keys(_alpha.alpha);\nexports.locales = locales;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isAlphanumeric;\nexports.locales = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _alpha = require(\"./alpha\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isAlphanumeric(_str) {\n var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n (0, _assertString.default)(_str);\n var str = _str;\n var ignore = options.ignore;\n\n if (ignore) {\n if (ignore instanceof RegExp) {\n str = str.replace(ignore, '');\n } else if (typeof ignore === 'string') {\n str = str.replace(new RegExp(\"[\".concat(ignore.replace(/[-[\\]{}()*+?.,\\\\^$|#\\\\s]/g, '\\\\$&'), \"]\"), 'g'), ''); // escape regex for ignore\n } else {\n throw new Error('ignore should be instance of a String or RegExp');\n }\n }\n\n if (locale in _alpha.alphanumeric) {\n return _alpha.alphanumeric[locale].test(str);\n }\n\n throw new Error(\"Invalid locale '\".concat(locale, \"'\"));\n}\n\nvar locales = Object.keys(_alpha.alphanumeric);\nexports.locales = locales;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isNumeric;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _alpha = require(\"./alpha\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar numericNoSymbols = /^[0-9]+$/;\n\nfunction isNumeric(str, options) {\n (0, _assertString.default)(str);\n\n if (options && options.no_symbols) {\n return numericNoSymbols.test(str);\n }\n\n return new RegExp(\"^[+-]?([0-9]*[\".concat((options || {}).locale ? _alpha.decimal[options.locale] : '.', \"])?[0-9]+$\")).test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isPassportNumber;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Reference:\n * https://en.wikipedia.org/ -- Wikipedia\n * https://docs.microsoft.com/en-us/microsoft-365/compliance/eu-passport-number -- EU Passport Number\n * https://countrycode.org/ -- Country Codes\n */\nvar passportRegexByCountryCode = {\n AM: /^[A-Z]{2}\\d{7}$/,\n // ARMENIA\n AR: /^[A-Z]{3}\\d{6}$/,\n // ARGENTINA\n AT: /^[A-Z]\\d{7}$/,\n // AUSTRIA\n AU: /^[A-Z]\\d{7}$/,\n // AUSTRALIA\n AZ: /^[A-Z]{2,3}\\d{7,8}$/,\n // AZERBAIJAN\n BE: /^[A-Z]{2}\\d{6}$/,\n // BELGIUM\n BG: /^\\d{9}$/,\n // BULGARIA\n BR: /^[A-Z]{2}\\d{6}$/,\n // BRAZIL\n BY: /^[A-Z]{2}\\d{7}$/,\n // BELARUS\n CA: /^[A-Z]{2}\\d{6}$/,\n // CANADA\n CH: /^[A-Z]\\d{7}$/,\n // SWITZERLAND\n CN: /^G\\d{8}$|^E(?![IO])[A-Z0-9]\\d{7}$/,\n // CHINA [G=Ordinary, E=Electronic] followed by 8-digits, or E followed by any UPPERCASE letter (except I and O) followed by 7 digits\n CY: /^[A-Z](\\d{6}|\\d{8})$/,\n // CYPRUS\n CZ: /^\\d{8}$/,\n // CZECH REPUBLIC\n DE: /^[CFGHJKLMNPRTVWXYZ0-9]{9}$/,\n // GERMANY\n DK: /^\\d{9}$/,\n // DENMARK\n DZ: /^\\d{9}$/,\n // ALGERIA\n EE: /^([A-Z]\\d{7}|[A-Z]{2}\\d{7})$/,\n // ESTONIA (K followed by 7-digits), e-passports have 2 UPPERCASE followed by 7 digits\n ES: /^[A-Z0-9]{2}([A-Z0-9]?)\\d{6}$/,\n // SPAIN\n FI: /^[A-Z]{2}\\d{7}$/,\n // FINLAND\n FR: /^\\d{2}[A-Z]{2}\\d{5}$/,\n // FRANCE\n GB: /^\\d{9}$/,\n // UNITED KINGDOM\n GR: /^[A-Z]{2}\\d{7}$/,\n // GREECE\n HR: /^\\d{9}$/,\n // CROATIA\n HU: /^[A-Z]{2}(\\d{6}|\\d{7})$/,\n // HUNGARY\n IE: /^[A-Z0-9]{2}\\d{7}$/,\n // IRELAND\n IN: /^[A-Z]{1}-?\\d{7}$/,\n // INDIA\n ID: /^[A-C]\\d{7}$/,\n // INDONESIA\n IR: /^[A-Z]\\d{8}$/,\n // IRAN\n IS: /^(A)\\d{7}$/,\n // ICELAND\n IT: /^[A-Z0-9]{2}\\d{7}$/,\n // ITALY\n JM: /^[Aa]\\d{7}$/,\n // JAMAICA\n JP: /^[A-Z]{2}\\d{7}$/,\n // JAPAN\n KR: /^[MS]\\d{8}$/,\n // SOUTH KOREA, REPUBLIC OF KOREA, [S=PS Passports, M=PM Passports]\n KZ: /^[a-zA-Z]\\d{7}$/,\n // KAZAKHSTAN\n LI: /^[a-zA-Z]\\d{5}$/,\n // LIECHTENSTEIN\n LT: /^[A-Z0-9]{8}$/,\n // LITHUANIA\n LU: /^[A-Z0-9]{8}$/,\n // LUXEMBURG\n LV: /^[A-Z0-9]{2}\\d{7}$/,\n // LATVIA\n LY: /^[A-Z0-9]{8}$/,\n // LIBYA\n MT: /^\\d{7}$/,\n // MALTA\n MZ: /^([A-Z]{2}\\d{7})|(\\d{2}[A-Z]{2}\\d{5})$/,\n // MOZAMBIQUE\n MY: /^[AHK]\\d{8}$/,\n // MALAYSIA\n MX: /^\\d{10,11}$/,\n // MEXICO\n NL: /^[A-Z]{2}[A-Z0-9]{6}\\d$/,\n // NETHERLANDS\n NZ: /^([Ll]([Aa]|[Dd]|[Ff]|[Hh])|[Ee]([Aa]|[Pp])|[Nn])\\d{6}$/,\n // NEW ZEALAND\n PH: /^([A-Z](\\d{6}|\\d{7}[A-Z]))|([A-Z]{2}(\\d{6}|\\d{7}))$/,\n // PHILIPPINES\n PK: /^[A-Z]{2}\\d{7}$/,\n // PAKISTAN\n PL: /^[A-Z]{2}\\d{7}$/,\n // POLAND\n PT: /^[A-Z]\\d{6}$/,\n // PORTUGAL\n RO: /^\\d{8,9}$/,\n // ROMANIA\n RU: /^\\d{9}$/,\n // RUSSIAN FEDERATION\n SE: /^\\d{8}$/,\n // SWEDEN\n SL: /^(P)[A-Z]\\d{7}$/,\n // SLOVENIA\n SK: /^[0-9A-Z]\\d{7}$/,\n // SLOVAKIA\n TH: /^[A-Z]{1,2}\\d{6,7}$/,\n // THAILAND\n TR: /^[A-Z]\\d{8}$/,\n // TURKEY\n UA: /^[A-Z]{2}\\d{6}$/,\n // UKRAINE\n US: /^\\d{9}$/ // UNITED STATES\n\n};\n/**\n * Check if str is a valid passport number\n * relative to provided ISO Country Code.\n *\n * @param {string} str\n * @param {string} countryCode\n * @return {boolean}\n */\n\nfunction isPassportNumber(str, countryCode) {\n (0, _assertString.default)(str);\n /** Remove All Whitespaces, Convert to UPPERCASE */\n\n var normalizedStr = str.replace(/\\s/g, '').toUpperCase();\n return countryCode.toUpperCase() in passportRegexByCountryCode && passportRegexByCountryCode[countryCode].test(normalizedStr);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isInt;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar int = /^(?:[-+]?(?:0|[1-9][0-9]*))$/;\nvar intLeadingZeroes = /^[-+]?[0-9]+$/;\n\nfunction isInt(str, options) {\n (0, _assertString.default)(str);\n options = options || {}; // Get the regex to use for testing, based on whether\n // leading zeroes are allowed or not.\n\n var regex = options.hasOwnProperty('allow_leading_zeroes') && !options.allow_leading_zeroes ? int : intLeadingZeroes; // Check min/max/lt/gt\n\n var minCheckPassed = !options.hasOwnProperty('min') || str >= options.min;\n var maxCheckPassed = !options.hasOwnProperty('max') || str <= options.max;\n var ltCheckPassed = !options.hasOwnProperty('lt') || str < options.lt;\n var gtCheckPassed = !options.hasOwnProperty('gt') || str > options.gt;\n return regex.test(str) && minCheckPassed && maxCheckPassed && ltCheckPassed && gtCheckPassed;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isPort;\n\nvar _isInt = _interopRequireDefault(require(\"./isInt\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isPort(str) {\n return (0, _isInt.default)(str, {\n min: 0,\n max: 65535\n });\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isLowercase;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isLowercase(str) {\n (0, _assertString.default)(str);\n return str === str.toLowerCase();\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isUppercase;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isUppercase(str) {\n (0, _assertString.default)(str);\n return str === str.toUpperCase();\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isIMEI;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar imeiRegexWithoutHypens = /^[0-9]{15}$/;\nvar imeiRegexWithHypens = /^\\d{2}-\\d{6}-\\d{6}-\\d{1}$/;\n\nfunction isIMEI(str, options) {\n (0, _assertString.default)(str);\n options = options || {}; // default regex for checking imei is the one without hyphens\n\n var imeiRegex = imeiRegexWithoutHypens;\n\n if (options.allow_hyphens) {\n imeiRegex = imeiRegexWithHypens;\n }\n\n if (!imeiRegex.test(str)) {\n return false;\n }\n\n str = str.replace(/-/g, '');\n var sum = 0,\n mul = 2,\n l = 14;\n\n for (var i = 0; i < l; i++) {\n var digit = str.substring(l - i - 1, l - i);\n var tp = parseInt(digit, 10) * mul;\n\n if (tp >= 10) {\n sum += tp % 10 + 1;\n } else {\n sum += tp;\n }\n\n if (mul === 1) {\n mul += 1;\n } else {\n mul -= 1;\n }\n }\n\n var chk = (10 - sum % 10) % 10;\n\n if (chk !== parseInt(str.substring(14, 15), 10)) {\n return false;\n }\n\n return true;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isAscii;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* eslint-disable no-control-regex */\nvar ascii = /^[\\x00-\\x7F]+$/;\n/* eslint-enable no-control-regex */\n\nfunction isAscii(str) {\n (0, _assertString.default)(str);\n return ascii.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isFullWidth;\nexports.fullWidth = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar fullWidth = /[^\\u0020-\\u007E\\uFF61-\\uFF9F\\uFFA0-\\uFFDC\\uFFE8-\\uFFEE0-9a-zA-Z]/;\nexports.fullWidth = fullWidth;\n\nfunction isFullWidth(str) {\n (0, _assertString.default)(str);\n return fullWidth.test(str);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isHalfWidth;\nexports.halfWidth = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar halfWidth = /[\\u0020-\\u007E\\uFF61-\\uFF9F\\uFFA0-\\uFFDC\\uFFE8-\\uFFEE0-9a-zA-Z]/;\nexports.halfWidth = halfWidth;\n\nfunction isHalfWidth(str) {\n (0, _assertString.default)(str);\n return halfWidth.test(str);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isVariableWidth;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isFullWidth = require(\"./isFullWidth\");\n\nvar _isHalfWidth = require(\"./isHalfWidth\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isVariableWidth(str) {\n (0, _assertString.default)(str);\n return _isFullWidth.fullWidth.test(str) && _isHalfWidth.halfWidth.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMultibyte;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* eslint-disable no-control-regex */\nvar multibyte = /[^\\x00-\\x7F]/;\n/* eslint-enable no-control-regex */\n\nfunction isMultibyte(str) {\n (0, _assertString.default)(str);\n return multibyte.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = multilineRegexp;\n\n/**\n * Build RegExp object from an array\n * of multiple/multi-line regexp parts\n *\n * @param {string[]} parts\n * @param {string} flags\n * @return {object} - RegExp object\n */\nfunction multilineRegexp(parts, flags) {\n var regexpAsStringLiteral = parts.join('');\n return new RegExp(regexpAsStringLiteral, flags);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isSemVer;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _multilineRegex = _interopRequireDefault(require(\"./util/multilineRegex\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Regular Expression to match\n * semantic versioning (SemVer)\n * built from multi-line, multi-parts regexp\n * Reference: https://semver.org/\n */\nvar semanticVersioningRegex = (0, _multilineRegex.default)(['^(0|[1-9]\\\\d*)\\\\.(0|[1-9]\\\\d*)\\\\.(0|[1-9]\\\\d*)', '(?:-((?:0|[1-9]\\\\d*|\\\\d*[a-z-][0-9a-z-]*)(?:\\\\.(?:0|[1-9]\\\\d*|\\\\d*[a-z-][0-9a-z-]*))*))', '?(?:\\\\+([0-9a-z-]+(?:\\\\.[0-9a-z-]+)*))?$'], 'i');\n\nfunction isSemVer(str) {\n (0, _assertString.default)(str);\n return semanticVersioningRegex.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isSurrogatePair;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar surrogatePair = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/;\n\nfunction isSurrogatePair(str) {\n (0, _assertString.default)(str);\n return surrogatePair.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar includes = function includes(arr, val) {\n return arr.some(function (arrVal) {\n return val === arrVal;\n });\n};\n\nvar _default = includes;\nexports.default = _default;\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isDecimal;\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _includes = _interopRequireDefault(require(\"./util/includes\"));\n\nvar _alpha = require(\"./alpha\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction decimalRegExp(options) {\n var regExp = new RegExp(\"^[-+]?([0-9]+)?(\\\\\".concat(_alpha.decimal[options.locale], \"[0-9]{\").concat(options.decimal_digits, \"})\").concat(options.force_decimal ? '' : '?', \"$\"));\n return regExp;\n}\n\nvar default_decimal_options = {\n force_decimal: false,\n decimal_digits: '1,',\n locale: 'en-US'\n};\nvar blacklist = ['', '-', '+'];\n\nfunction isDecimal(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, default_decimal_options);\n\n if (options.locale in _alpha.decimal) {\n return !(0, _includes.default)(blacklist, str.replace(/ /g, '')) && decimalRegExp(options).test(str);\n }\n\n throw new Error(\"Invalid locale '\".concat(options.locale, \"'\"));\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isHexadecimal;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar hexadecimal = /^(0x|0h)?[0-9A-F]+$/i;\n\nfunction isHexadecimal(str) {\n (0, _assertString.default)(str);\n return hexadecimal.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isOctal;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar octal = /^(0o)?[0-7]+$/i;\n\nfunction isOctal(str) {\n (0, _assertString.default)(str);\n return octal.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isDivisibleBy;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _toFloat = _interopRequireDefault(require(\"./toFloat\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isDivisibleBy(str, num) {\n (0, _assertString.default)(str);\n return (0, _toFloat.default)(str) % parseInt(num, 10) === 0;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isHexColor;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar hexcolor = /^#?([0-9A-F]{3}|[0-9A-F]{4}|[0-9A-F]{6}|[0-9A-F]{8})$/i;\n\nfunction isHexColor(str) {\n (0, _assertString.default)(str);\n return hexcolor.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isRgbColor;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar rgbColor = /^rgb\\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){2}([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\)$/;\nvar rgbaColor = /^rgba\\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){3}(0?\\.\\d|1(\\.0)?|0(\\.0)?)\\)$/;\nvar rgbColorPercent = /^rgb\\((([0-9]%|[1-9][0-9]%|100%),){2}([0-9]%|[1-9][0-9]%|100%)\\)$/;\nvar rgbaColorPercent = /^rgba\\((([0-9]%|[1-9][0-9]%|100%),){3}(0?\\.\\d|1(\\.0)?|0(\\.0)?)\\)$/;\n\nfunction isRgbColor(str) {\n var includePercentValues = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n (0, _assertString.default)(str);\n\n if (!includePercentValues) {\n return rgbColor.test(str) || rgbaColor.test(str);\n }\n\n return rgbColor.test(str) || rgbaColor.test(str) || rgbColorPercent.test(str) || rgbaColorPercent.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isHSL;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar hslComma = /^hsla?\\(((\\+|\\-)?([0-9]+(\\.[0-9]+)?(e(\\+|\\-)?[0-9]+)?|\\.[0-9]+(e(\\+|\\-)?[0-9]+)?))(deg|grad|rad|turn)?(,(\\+|\\-)?([0-9]+(\\.[0-9]+)?(e(\\+|\\-)?[0-9]+)?|\\.[0-9]+(e(\\+|\\-)?[0-9]+)?)%){2}(,((\\+|\\-)?([0-9]+(\\.[0-9]+)?(e(\\+|\\-)?[0-9]+)?|\\.[0-9]+(e(\\+|\\-)?[0-9]+)?)%?))?\\)$/i;\nvar hslSpace = /^hsla?\\(((\\+|\\-)?([0-9]+(\\.[0-9]+)?(e(\\+|\\-)?[0-9]+)?|\\.[0-9]+(e(\\+|\\-)?[0-9]+)?))(deg|grad|rad|turn)?(\\s(\\+|\\-)?([0-9]+(\\.[0-9]+)?(e(\\+|\\-)?[0-9]+)?|\\.[0-9]+(e(\\+|\\-)?[0-9]+)?)%){2}\\s?(\\/\\s((\\+|\\-)?([0-9]+(\\.[0-9]+)?(e(\\+|\\-)?[0-9]+)?|\\.[0-9]+(e(\\+|\\-)?[0-9]+)?)%?)\\s?)?\\)$/i;\n\nfunction isHSL(str) {\n (0, _assertString.default)(str); // Strip duplicate spaces before calling the validation regex (See #1598 for more info)\n\n var strippedStr = str.replace(/\\s+/g, ' ').replace(/\\s?(hsla?\\(|\\)|,)\\s?/ig, '$1');\n\n if (strippedStr.indexOf(',') !== -1) {\n return hslComma.test(strippedStr);\n }\n\n return hslSpace.test(strippedStr);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISRC;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// see http://isrc.ifpi.org/en/isrc-standard/code-syntax\nvar isrc = /^[A-Z]{2}[0-9A-Z]{3}\\d{2}\\d{5}$/;\n\nfunction isISRC(str) {\n (0, _assertString.default)(str);\n return isrc.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isIBAN;\nexports.locales = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * List of country codes with\n * corresponding IBAN regular expression\n * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number\n */\nvar ibanRegexThroughCountryCode = {\n AD: /^(AD[0-9]{2})\\d{8}[A-Z0-9]{12}$/,\n AE: /^(AE[0-9]{2})\\d{3}\\d{16}$/,\n AL: /^(AL[0-9]{2})\\d{8}[A-Z0-9]{16}$/,\n AT: /^(AT[0-9]{2})\\d{16}$/,\n AZ: /^(AZ[0-9]{2})[A-Z0-9]{4}\\d{20}$/,\n BA: /^(BA[0-9]{2})\\d{16}$/,\n BE: /^(BE[0-9]{2})\\d{12}$/,\n BG: /^(BG[0-9]{2})[A-Z]{4}\\d{6}[A-Z0-9]{8}$/,\n BH: /^(BH[0-9]{2})[A-Z]{4}[A-Z0-9]{14}$/,\n BR: /^(BR[0-9]{2})\\d{23}[A-Z]{1}[A-Z0-9]{1}$/,\n BY: /^(BY[0-9]{2})[A-Z0-9]{4}\\d{20}$/,\n CH: /^(CH[0-9]{2})\\d{5}[A-Z0-9]{12}$/,\n CR: /^(CR[0-9]{2})\\d{18}$/,\n CY: /^(CY[0-9]{2})\\d{8}[A-Z0-9]{16}$/,\n CZ: /^(CZ[0-9]{2})\\d{20}$/,\n DE: /^(DE[0-9]{2})\\d{18}$/,\n DK: /^(DK[0-9]{2})\\d{14}$/,\n DO: /^(DO[0-9]{2})[A-Z]{4}\\d{20}$/,\n EE: /^(EE[0-9]{2})\\d{16}$/,\n EG: /^(EG[0-9]{2})\\d{25}$/,\n ES: /^(ES[0-9]{2})\\d{20}$/,\n FI: /^(FI[0-9]{2})\\d{14}$/,\n FO: /^(FO[0-9]{2})\\d{14}$/,\n FR: /^(FR[0-9]{2})\\d{10}[A-Z0-9]{11}\\d{2}$/,\n GB: /^(GB[0-9]{2})[A-Z]{4}\\d{14}$/,\n GE: /^(GE[0-9]{2})[A-Z0-9]{2}\\d{16}$/,\n GI: /^(GI[0-9]{2})[A-Z]{4}[A-Z0-9]{15}$/,\n GL: /^(GL[0-9]{2})\\d{14}$/,\n GR: /^(GR[0-9]{2})\\d{7}[A-Z0-9]{16}$/,\n GT: /^(GT[0-9]{2})[A-Z0-9]{4}[A-Z0-9]{20}$/,\n HR: /^(HR[0-9]{2})\\d{17}$/,\n HU: /^(HU[0-9]{2})\\d{24}$/,\n IE: /^(IE[0-9]{2})[A-Z0-9]{4}\\d{14}$/,\n IL: /^(IL[0-9]{2})\\d{19}$/,\n IQ: /^(IQ[0-9]{2})[A-Z]{4}\\d{15}$/,\n IR: /^(IR[0-9]{2})0\\d{2}0\\d{18}$/,\n IS: /^(IS[0-9]{2})\\d{22}$/,\n IT: /^(IT[0-9]{2})[A-Z]{1}\\d{10}[A-Z0-9]{12}$/,\n JO: /^(JO[0-9]{2})[A-Z]{4}\\d{22}$/,\n KW: /^(KW[0-9]{2})[A-Z]{4}[A-Z0-9]{22}$/,\n KZ: /^(KZ[0-9]{2})\\d{3}[A-Z0-9]{13}$/,\n LB: /^(LB[0-9]{2})\\d{4}[A-Z0-9]{20}$/,\n LC: /^(LC[0-9]{2})[A-Z]{4}[A-Z0-9]{24}$/,\n LI: /^(LI[0-9]{2})\\d{5}[A-Z0-9]{12}$/,\n LT: /^(LT[0-9]{2})\\d{16}$/,\n LU: /^(LU[0-9]{2})\\d{3}[A-Z0-9]{13}$/,\n LV: /^(LV[0-9]{2})[A-Z]{4}[A-Z0-9]{13}$/,\n MA: /^(MA[0-9]{26})$/,\n MC: /^(MC[0-9]{2})\\d{10}[A-Z0-9]{11}\\d{2}$/,\n MD: /^(MD[0-9]{2})[A-Z0-9]{20}$/,\n ME: /^(ME[0-9]{2})\\d{18}$/,\n MK: /^(MK[0-9]{2})\\d{3}[A-Z0-9]{10}\\d{2}$/,\n MR: /^(MR[0-9]{2})\\d{23}$/,\n MT: /^(MT[0-9]{2})[A-Z]{4}\\d{5}[A-Z0-9]{18}$/,\n MU: /^(MU[0-9]{2})[A-Z]{4}\\d{19}[A-Z]{3}$/,\n MZ: /^(MZ[0-9]{2})\\d{21}$/,\n NL: /^(NL[0-9]{2})[A-Z]{4}\\d{10}$/,\n NO: /^(NO[0-9]{2})\\d{11}$/,\n PK: /^(PK[0-9]{2})[A-Z0-9]{4}\\d{16}$/,\n PL: /^(PL[0-9]{2})\\d{24}$/,\n PS: /^(PS[0-9]{2})[A-Z0-9]{4}\\d{21}$/,\n PT: /^(PT[0-9]{2})\\d{21}$/,\n QA: /^(QA[0-9]{2})[A-Z]{4}[A-Z0-9]{21}$/,\n RO: /^(RO[0-9]{2})[A-Z]{4}[A-Z0-9]{16}$/,\n RS: /^(RS[0-9]{2})\\d{18}$/,\n SA: /^(SA[0-9]{2})\\d{2}[A-Z0-9]{18}$/,\n SC: /^(SC[0-9]{2})[A-Z]{4}\\d{20}[A-Z]{3}$/,\n SE: /^(SE[0-9]{2})\\d{20}$/,\n SI: /^(SI[0-9]{2})\\d{15}$/,\n SK: /^(SK[0-9]{2})\\d{20}$/,\n SM: /^(SM[0-9]{2})[A-Z]{1}\\d{10}[A-Z0-9]{12}$/,\n SV: /^(SV[0-9]{2})[A-Z0-9]{4}\\d{20}$/,\n TL: /^(TL[0-9]{2})\\d{19}$/,\n TN: /^(TN[0-9]{2})\\d{20}$/,\n TR: /^(TR[0-9]{2})\\d{5}[A-Z0-9]{17}$/,\n UA: /^(UA[0-9]{2})\\d{6}[A-Z0-9]{19}$/,\n VA: /^(VA[0-9]{2})\\d{18}$/,\n VG: /^(VG[0-9]{2})[A-Z0-9]{4}\\d{16}$/,\n XK: /^(XK[0-9]{2})\\d{16}$/\n};\n/**\n * Check if the country codes passed are valid using the\n * ibanRegexThroughCountryCode as a reference\n *\n * @param {array} countryCodeArray\n * @return {boolean}\n */\n\nfunction hasOnlyValidCountryCodes(countryCodeArray) {\n var countryCodeArrayFilteredWithObjectIbanCode = countryCodeArray.filter(function (countryCode) {\n return !(countryCode in ibanRegexThroughCountryCode);\n });\n\n if (countryCodeArrayFilteredWithObjectIbanCode.length > 0) {\n return false;\n }\n\n return true;\n}\n/**\n * Check whether string has correct universal IBAN format\n * The IBAN consists of up to 34 alphanumeric characters, as follows:\n * Country Code using ISO 3166-1 alpha-2, two letters\n * check digits, two digits and\n * Basic Bank Account Number (BBAN), up to 30 alphanumeric characters.\n * NOTE: Permitted IBAN characters are: digits [0-9] and the 26 latin alphabetic [A-Z]\n *\n * @param {string} str - string under validation\n * @param {object} options - object to pass the countries to be either whitelisted or blacklisted\n * @return {boolean}\n */\n\n\nfunction hasValidIbanFormat(str, options) {\n // Strip white spaces and hyphens\n var strippedStr = str.replace(/[\\s\\-]+/gi, '').toUpperCase();\n var isoCountryCode = strippedStr.slice(0, 2).toUpperCase();\n var isoCountryCodeInIbanRegexCodeObject = (isoCountryCode in ibanRegexThroughCountryCode);\n\n if (options.whitelist) {\n if (!hasOnlyValidCountryCodes(options.whitelist)) {\n return false;\n }\n\n var isoCountryCodeInWhiteList = options.whitelist.includes(isoCountryCode);\n\n if (!isoCountryCodeInWhiteList) {\n return false;\n }\n }\n\n if (options.blacklist) {\n var isoCountryCodeInBlackList = options.blacklist.includes(isoCountryCode);\n\n if (isoCountryCodeInBlackList) {\n return false;\n }\n }\n\n return isoCountryCodeInIbanRegexCodeObject && ibanRegexThroughCountryCode[isoCountryCode].test(strippedStr);\n}\n/**\n * Check whether string has valid IBAN Checksum\n * by performing basic mod-97 operation and\n * the remainder should equal 1\n * -- Start by rearranging the IBAN by moving the four initial characters to the end of the string\n * -- Replace each letter in the string with two digits, A -> 10, B = 11, Z = 35\n * -- Interpret the string as a decimal integer and\n * -- compute the remainder on division by 97 (mod 97)\n * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number\n *\n * @param {string} str\n * @return {boolean}\n */\n\n\nfunction hasValidIbanChecksum(str) {\n var strippedStr = str.replace(/[^A-Z0-9]+/gi, '').toUpperCase(); // Keep only digits and A-Z latin alphabetic\n\n var rearranged = strippedStr.slice(4) + strippedStr.slice(0, 4);\n var alphaCapsReplacedWithDigits = rearranged.replace(/[A-Z]/g, function (char) {\n return char.charCodeAt(0) - 55;\n });\n var remainder = alphaCapsReplacedWithDigits.match(/\\d{1,7}/g).reduce(function (acc, value) {\n return Number(acc + value) % 97;\n }, '');\n return remainder === 1;\n}\n\nfunction isIBAN(str) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n (0, _assertString.default)(str);\n return hasValidIbanFormat(str, options) && hasValidIbanChecksum(str);\n}\n\nvar locales = Object.keys(ibanRegexThroughCountryCode);\nexports.locales = locales;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISO31661Alpha2;\nexports.CountryCodes = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// from https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2\nvar validISO31661Alpha2CountriesCodes = new Set(['AD', 'AE', 'AF', 'AG', 'AI', 'AL', 'AM', 'AO', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AW', 'AX', 'AZ', 'BA', 'BB', 'BD', 'BE', 'BF', 'BG', 'BH', 'BI', 'BJ', 'BL', 'BM', 'BN', 'BO', 'BQ', 'BR', 'BS', 'BT', 'BV', 'BW', 'BY', 'BZ', 'CA', 'CC', 'CD', 'CF', 'CG', 'CH', 'CI', 'CK', 'CL', 'CM', 'CN', 'CO', 'CR', 'CU', 'CV', 'CW', 'CX', 'CY', 'CZ', 'DE', 'DJ', 'DK', 'DM', 'DO', 'DZ', 'EC', 'EE', 'EG', 'EH', 'ER', 'ES', 'ET', 'FI', 'FJ', 'FK', 'FM', 'FO', 'FR', 'GA', 'GB', 'GD', 'GE', 'GF', 'GG', 'GH', 'GI', 'GL', 'GM', 'GN', 'GP', 'GQ', 'GR', 'GS', 'GT', 'GU', 'GW', 'GY', 'HK', 'HM', 'HN', 'HR', 'HT', 'HU', 'ID', 'IE', 'IL', 'IM', 'IN', 'IO', 'IQ', 'IR', 'IS', 'IT', 'JE', 'JM', 'JO', 'JP', 'KE', 'KG', 'KH', 'KI', 'KM', 'KN', 'KP', 'KR', 'KW', 'KY', 'KZ', 'LA', 'LB', 'LC', 'LI', 'LK', 'LR', 'LS', 'LT', 'LU', 'LV', 'LY', 'MA', 'MC', 'MD', 'ME', 'MF', 'MG', 'MH', 'MK', 'ML', 'MM', 'MN', 'MO', 'MP', 'MQ', 'MR', 'MS', 'MT', 'MU', 'MV', 'MW', 'MX', 'MY', 'MZ', 'NA', 'NC', 'NE', 'NF', 'NG', 'NI', 'NL', 'NO', 'NP', 'NR', 'NU', 'NZ', 'OM', 'PA', 'PE', 'PF', 'PG', 'PH', 'PK', 'PL', 'PM', 'PN', 'PR', 'PS', 'PT', 'PW', 'PY', 'QA', 'RE', 'RO', 'RS', 'RU', 'RW', 'SA', 'SB', 'SC', 'SD', 'SE', 'SG', 'SH', 'SI', 'SJ', 'SK', 'SL', 'SM', 'SN', 'SO', 'SR', 'SS', 'ST', 'SV', 'SX', 'SY', 'SZ', 'TC', 'TD', 'TF', 'TG', 'TH', 'TJ', 'TK', 'TL', 'TM', 'TN', 'TO', 'TR', 'TT', 'TV', 'TW', 'TZ', 'UA', 'UG', 'UM', 'US', 'UY', 'UZ', 'VA', 'VC', 'VE', 'VG', 'VI', 'VN', 'VU', 'WF', 'WS', 'YE', 'YT', 'ZA', 'ZM', 'ZW']);\n\nfunction isISO31661Alpha2(str) {\n (0, _assertString.default)(str);\n return validISO31661Alpha2CountriesCodes.has(str.toUpperCase());\n}\n\nvar CountryCodes = validISO31661Alpha2CountriesCodes;\nexports.CountryCodes = CountryCodes;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isBIC;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isISO31661Alpha = require(\"./isISO31661Alpha2\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// https://en.wikipedia.org/wiki/ISO_9362\nvar isBICReg = /^[A-Za-z]{6}[A-Za-z0-9]{2}([A-Za-z0-9]{3})?$/;\n\nfunction isBIC(str) {\n (0, _assertString.default)(str); // toUpperCase() should be removed when a new major version goes out that changes\n // the regex to [A-Z] (per the spec).\n\n var countryCode = str.slice(4, 6).toUpperCase();\n\n if (!_isISO31661Alpha.CountryCodes.has(countryCode) && countryCode !== 'XK') {\n return false;\n }\n\n return isBICReg.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMD5;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar md5 = /^[a-f0-9]{32}$/;\n\nfunction isMD5(str) {\n (0, _assertString.default)(str);\n return md5.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isHash;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar lengths = {\n md5: 32,\n md4: 32,\n sha1: 40,\n sha256: 64,\n sha384: 96,\n sha512: 128,\n ripemd128: 32,\n ripemd160: 40,\n tiger128: 32,\n tiger160: 40,\n tiger192: 48,\n crc32: 8,\n crc32b: 8\n};\n\nfunction isHash(str, algorithm) {\n (0, _assertString.default)(str);\n var hash = new RegExp(\"^[a-fA-F0-9]{\".concat(lengths[algorithm], \"}$\"));\n return hash.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isBase64;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar notBase64 = /[^A-Z0-9+\\/=]/i;\nvar urlSafeBase64 = /^[A-Z0-9_\\-]*$/i;\nvar defaultBase64Options = {\n urlSafe: false\n};\n\nfunction isBase64(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, defaultBase64Options);\n var len = str.length;\n\n if (options.urlSafe) {\n return urlSafeBase64.test(str);\n }\n\n if (len % 4 !== 0 || notBase64.test(str)) {\n return false;\n }\n\n var firstPaddingChar = str.indexOf('=');\n return firstPaddingChar === -1 || firstPaddingChar === len - 1 || firstPaddingChar === len - 2 && str[len - 1] === '=';\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isJWT;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isBase = _interopRequireDefault(require(\"./isBase64\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isJWT(str) {\n (0, _assertString.default)(str);\n var dotSplit = str.split('.');\n var len = dotSplit.length;\n\n if (len !== 3) {\n return false;\n }\n\n return dotSplit.reduce(function (acc, currElem) {\n return acc && (0, _isBase.default)(currElem, {\n urlSafe: true\n });\n }, true);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isJSON;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nvar default_json_options = {\n allow_primitives: false\n};\n\nfunction isJSON(str, options) {\n (0, _assertString.default)(str);\n\n try {\n options = (0, _merge.default)(options, default_json_options);\n var primitives = [];\n\n if (options.allow_primitives) {\n primitives = [null, false, true];\n }\n\n var obj = JSON.parse(str);\n return primitives.includes(obj) || !!obj && _typeof(obj) === 'object';\n } catch (e) {\n /* ignore */\n }\n\n return false;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isEmpty;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar default_is_empty_options = {\n ignore_whitespace: false\n};\n\nfunction isEmpty(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, default_is_empty_options);\n return (options.ignore_whitespace ? str.trim().length : str.length) === 0;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isLength;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/* eslint-disable prefer-rest-params */\nfunction isLength(str, options) {\n (0, _assertString.default)(str);\n var min;\n var max;\n\n if (_typeof(options) === 'object') {\n min = options.min || 0;\n max = options.max;\n } else {\n // backwards compatibility: isLength(str, min [, max])\n min = arguments[1] || 0;\n max = arguments[2];\n }\n\n var presentationSequences = str.match(/(\\uFE0F|\\uFE0E)/g) || [];\n var surrogatePairs = str.match(/[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g) || [];\n var len = str.length - presentationSequences.length - surrogatePairs.length;\n return len >= min && (typeof max === 'undefined' || len <= max);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isUUID;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar uuid = {\n 1: /^[0-9A-F]{8}-[0-9A-F]{4}-1[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,\n 2: /^[0-9A-F]{8}-[0-9A-F]{4}-2[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,\n 3: /^[0-9A-F]{8}-[0-9A-F]{4}-3[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,\n 4: /^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,\n 5: /^[0-9A-F]{8}-[0-9A-F]{4}-5[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,\n all: /^[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}$/i\n};\n\nfunction isUUID(str, version) {\n (0, _assertString.default)(str);\n var pattern = uuid[![undefined, null].includes(version) ? version : 'all'];\n return !!pattern && pattern.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMongoId;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isHexadecimal = _interopRequireDefault(require(\"./isHexadecimal\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isMongoId(str) {\n (0, _assertString.default)(str);\n return (0, _isHexadecimal.default)(str) && str.length === 24;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isAfter;\n\nvar _toDate = _interopRequireDefault(require(\"./toDate\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isAfter(date, options) {\n // For backwards compatibility:\n // isAfter(str [, date]), i.e. `options` could be used as argument for the legacy `date`\n var comparisonDate = (options === null || options === void 0 ? void 0 : options.comparisonDate) || options || Date().toString();\n var comparison = (0, _toDate.default)(comparisonDate);\n var original = (0, _toDate.default)(date);\n return !!(original && comparison && original > comparison);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isBefore;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _toDate = _interopRequireDefault(require(\"./toDate\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isBefore(str) {\n var date = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : String(new Date());\n (0, _assertString.default)(str);\n var comparison = (0, _toDate.default)(date);\n var original = (0, _toDate.default)(str);\n return !!(original && comparison && original < comparison);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isIn;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _toString = _interopRequireDefault(require(\"./util/toString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction isIn(str, options) {\n (0, _assertString.default)(str);\n var i;\n\n if (Object.prototype.toString.call(options) === '[object Array]') {\n var array = [];\n\n for (i in options) {\n // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes\n // istanbul ignore else\n if ({}.hasOwnProperty.call(options, i)) {\n array[i] = (0, _toString.default)(options[i]);\n }\n }\n\n return array.indexOf(str) >= 0;\n } else if (_typeof(options) === 'object') {\n return options.hasOwnProperty(str);\n } else if (options && typeof options.indexOf === 'function') {\n return options.indexOf(str) >= 0;\n }\n\n return false;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isLuhnNumber;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isLuhnNumber(str) {\n (0, _assertString.default)(str);\n var sanitized = str.replace(/[- ]+/g, '');\n var sum = 0;\n var digit;\n var tmpNum;\n var shouldDouble;\n\n for (var i = sanitized.length - 1; i >= 0; i--) {\n digit = sanitized.substring(i, i + 1);\n tmpNum = parseInt(digit, 10);\n\n if (shouldDouble) {\n tmpNum *= 2;\n\n if (tmpNum >= 10) {\n sum += tmpNum % 10 + 1;\n } else {\n sum += tmpNum;\n }\n } else {\n sum += tmpNum;\n }\n\n shouldDouble = !shouldDouble;\n }\n\n return !!(sum % 10 === 0 ? sanitized : false);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isCreditCard;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isLuhnNumber = _interopRequireDefault(require(\"./isLuhnNumber\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar cards = {\n amex: /^3[47][0-9]{13}$/,\n dinersclub: /^3(?:0[0-5]|[68][0-9])[0-9]{11}$/,\n discover: /^6(?:011|5[0-9][0-9])[0-9]{12,15}$/,\n jcb: /^(?:2131|1800|35\\d{3})\\d{11}$/,\n mastercard: /^5[1-5][0-9]{2}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}$/,\n // /^[25][1-7][0-9]{14}$/;\n unionpay: /^(6[27][0-9]{14}|^(81[0-9]{14,17}))$/,\n visa: /^(?:4[0-9]{12})(?:[0-9]{3,6})?$/\n};\n\nvar allCards = function () {\n var tmpCardsArray = [];\n\n for (var cardProvider in cards) {\n // istanbul ignore else\n if (cards.hasOwnProperty(cardProvider)) {\n tmpCardsArray.push(cards[cardProvider]);\n }\n }\n\n return tmpCardsArray;\n}();\n\nfunction isCreditCard(card) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n (0, _assertString.default)(card);\n var provider = options.provider;\n var sanitized = card.replace(/[- ]+/g, '');\n\n if (provider && provider.toLowerCase() in cards) {\n // specific provider in the list\n if (!cards[provider.toLowerCase()].test(sanitized)) {\n return false;\n }\n } else if (provider && !(provider.toLowerCase() in cards)) {\n /* specific provider not in the list */\n throw new Error(\"\".concat(provider, \" is not a valid credit card provider.\"));\n } else if (!allCards.some(function (cardProvider) {\n return cardProvider.test(sanitized);\n })) {\n // no specific provider\n return false;\n }\n\n return (0, _isLuhnNumber.default)(card);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isIdentityCard;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _isInt = _interopRequireDefault(require(\"./isInt\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar validators = {\n PL: function PL(str) {\n (0, _assertString.default)(str);\n var weightOfDigits = {\n 1: 1,\n 2: 3,\n 3: 7,\n 4: 9,\n 5: 1,\n 6: 3,\n 7: 7,\n 8: 9,\n 9: 1,\n 10: 3,\n 11: 0\n };\n\n if (str != null && str.length === 11 && (0, _isInt.default)(str, {\n allow_leading_zeroes: true\n })) {\n var digits = str.split('').slice(0, -1);\n var sum = digits.reduce(function (acc, digit, index) {\n return acc + Number(digit) * weightOfDigits[index + 1];\n }, 0);\n var modulo = sum % 10;\n var lastDigit = Number(str.charAt(str.length - 1));\n\n if (modulo === 0 && lastDigit === 0 || lastDigit === 10 - modulo) {\n return true;\n }\n }\n\n return false;\n },\n ES: function ES(str) {\n (0, _assertString.default)(str);\n var DNI = /^[0-9X-Z][0-9]{7}[TRWAGMYFPDXBNJZSQVHLCKE]$/;\n var charsValue = {\n X: 0,\n Y: 1,\n Z: 2\n };\n var controlDigits = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E']; // sanitize user input\n\n var sanitized = str.trim().toUpperCase(); // validate the data structure\n\n if (!DNI.test(sanitized)) {\n return false;\n } // validate the control digit\n\n\n var number = sanitized.slice(0, -1).replace(/[X,Y,Z]/g, function (char) {\n return charsValue[char];\n });\n return sanitized.endsWith(controlDigits[number % 23]);\n },\n FI: function FI(str) {\n // https://dvv.fi/en/personal-identity-code#:~:text=control%20character%20for%20a-,personal,-identity%20code%20calculated\n (0, _assertString.default)(str);\n\n if (str.length !== 11) {\n return false;\n }\n\n if (!str.match(/^\\d{6}[\\-A\\+]\\d{3}[0-9ABCDEFHJKLMNPRSTUVWXY]{1}$/)) {\n return false;\n }\n\n var checkDigits = '0123456789ABCDEFHJKLMNPRSTUVWXY';\n var idAsNumber = parseInt(str.slice(0, 6), 10) * 1000 + parseInt(str.slice(7, 10), 10);\n var remainder = idAsNumber % 31;\n var checkDigit = checkDigits[remainder];\n return checkDigit === str.slice(10, 11);\n },\n IN: function IN(str) {\n var DNI = /^[1-9]\\d{3}\\s?\\d{4}\\s?\\d{4}$/; // multiplication table\n\n var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]]; // permutation table\n\n var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // sanitize user input\n\n var sanitized = str.trim(); // validate the data structure\n\n if (!DNI.test(sanitized)) {\n return false;\n }\n\n var c = 0;\n var invertedArray = sanitized.replace(/\\s/g, '').split('').map(Number).reverse();\n invertedArray.forEach(function (val, i) {\n c = d[c][p[i % 8][val]];\n });\n return c === 0;\n },\n IR: function IR(str) {\n if (!str.match(/^\\d{10}$/)) return false;\n str = \"0000\".concat(str).slice(str.length - 6);\n if (parseInt(str.slice(3, 9), 10) === 0) return false;\n var lastNumber = parseInt(str.slice(9, 10), 10);\n var sum = 0;\n\n for (var i = 0; i < 9; i++) {\n sum += parseInt(str.slice(i, i + 1), 10) * (10 - i);\n }\n\n sum %= 11;\n return sum < 2 && lastNumber === sum || sum >= 2 && lastNumber === 11 - sum;\n },\n IT: function IT(str) {\n if (str.length !== 9) return false;\n if (str === 'CA00000AA') return false; // https://it.wikipedia.org/wiki/Carta_d%27identit%C3%A0_elettronica_italiana\n\n return str.search(/C[A-Z][0-9]{5}[A-Z]{2}/i) > -1;\n },\n NO: function NO(str) {\n var sanitized = str.trim();\n if (isNaN(Number(sanitized))) return false;\n if (sanitized.length !== 11) return false;\n if (sanitized === '00000000000') return false; // https://no.wikipedia.org/wiki/F%C3%B8dselsnummer\n\n var f = sanitized.split('').map(Number);\n var k1 = (11 - (3 * f[0] + 7 * f[1] + 6 * f[2] + 1 * f[3] + 8 * f[4] + 9 * f[5] + 4 * f[6] + 5 * f[7] + 2 * f[8]) % 11) % 11;\n var k2 = (11 - (5 * f[0] + 4 * f[1] + 3 * f[2] + 2 * f[3] + 7 * f[4] + 6 * f[5] + 5 * f[6] + 4 * f[7] + 3 * f[8] + 2 * k1) % 11) % 11;\n if (k1 !== f[9] || k2 !== f[10]) return false;\n return true;\n },\n TH: function TH(str) {\n if (!str.match(/^[1-8]\\d{12}$/)) return false; // validate check digit\n\n var sum = 0;\n\n for (var i = 0; i < 12; i++) {\n sum += parseInt(str[i], 10) * (13 - i);\n }\n\n return str[12] === ((11 - sum % 11) % 10).toString();\n },\n LK: function LK(str) {\n var old_nic = /^[1-9]\\d{8}[vx]$/i;\n var new_nic = /^[1-9]\\d{11}$/i;\n if (str.length === 10 && old_nic.test(str)) return true;else if (str.length === 12 && new_nic.test(str)) return true;\n return false;\n },\n 'he-IL': function heIL(str) {\n var DNI = /^\\d{9}$/; // sanitize user input\n\n var sanitized = str.trim(); // validate the data structure\n\n if (!DNI.test(sanitized)) {\n return false;\n }\n\n var id = sanitized;\n var sum = 0,\n incNum;\n\n for (var i = 0; i < id.length; i++) {\n incNum = Number(id[i]) * (i % 2 + 1); // Multiply number by 1 or 2\n\n sum += incNum > 9 ? incNum - 9 : incNum; // Sum the digits up and add to total\n }\n\n return sum % 10 === 0;\n },\n 'ar-LY': function arLY(str) {\n // Libya National Identity Number NIN is 12 digits, the first digit is either 1 or 2\n var NIN = /^(1|2)\\d{11}$/; // sanitize user input\n\n var sanitized = str.trim(); // validate the data structure\n\n if (!NIN.test(sanitized)) {\n return false;\n }\n\n return true;\n },\n 'ar-TN': function arTN(str) {\n var DNI = /^\\d{8}$/; // sanitize user input\n\n var sanitized = str.trim(); // validate the data structure\n\n if (!DNI.test(sanitized)) {\n return false;\n }\n\n return true;\n },\n 'zh-CN': function zhCN(str) {\n var provincesAndCities = ['11', // 北京\n '12', // 天津\n '13', // 河北\n '14', // 山西\n '15', // 内蒙古\n '21', // 辽宁\n '22', // 吉林\n '23', // 黑龙江\n '31', // 上海\n '32', // 江苏\n '33', // 浙江\n '34', // 安徽\n '35', // 福建\n '36', // 江西\n '37', // 山东\n '41', // 河南\n '42', // 湖北\n '43', // 湖南\n '44', // 广东\n '45', // 广西\n '46', // 海南\n '50', // 重庆\n '51', // 四川\n '52', // 贵州\n '53', // 云南\n '54', // 西藏\n '61', // 陕西\n '62', // 甘肃\n '63', // 青海\n '64', // 宁夏\n '65', // 新疆\n '71', // 台湾\n '81', // 香港\n '82', // 澳门\n '91' // 国外\n ];\n var powers = ['7', '9', '10', '5', '8', '4', '2', '1', '6', '3', '7', '9', '10', '5', '8', '4', '2'];\n var parityBit = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'];\n\n var checkAddressCode = function checkAddressCode(addressCode) {\n return provincesAndCities.includes(addressCode);\n };\n\n var checkBirthDayCode = function checkBirthDayCode(birDayCode) {\n var yyyy = parseInt(birDayCode.substring(0, 4), 10);\n var mm = parseInt(birDayCode.substring(4, 6), 10);\n var dd = parseInt(birDayCode.substring(6), 10);\n var xdata = new Date(yyyy, mm - 1, dd);\n\n if (xdata > new Date()) {\n return false; // eslint-disable-next-line max-len\n } else if (xdata.getFullYear() === yyyy && xdata.getMonth() === mm - 1 && xdata.getDate() === dd) {\n return true;\n }\n\n return false;\n };\n\n var getParityBit = function getParityBit(idCardNo) {\n var id17 = idCardNo.substring(0, 17);\n var power = 0;\n\n for (var i = 0; i < 17; i++) {\n power += parseInt(id17.charAt(i), 10) * parseInt(powers[i], 10);\n }\n\n var mod = power % 11;\n return parityBit[mod];\n };\n\n var checkParityBit = function checkParityBit(idCardNo) {\n return getParityBit(idCardNo) === idCardNo.charAt(17).toUpperCase();\n };\n\n var check15IdCardNo = function check15IdCardNo(idCardNo) {\n var check = /^[1-9]\\d{7}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\\d{3}$/.test(idCardNo);\n if (!check) return false;\n var addressCode = idCardNo.substring(0, 2);\n check = checkAddressCode(addressCode);\n if (!check) return false;\n var birDayCode = \"19\".concat(idCardNo.substring(6, 12));\n check = checkBirthDayCode(birDayCode);\n if (!check) return false;\n return true;\n };\n\n var check18IdCardNo = function check18IdCardNo(idCardNo) {\n var check = /^[1-9]\\d{5}[1-9]\\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\\d{3}(\\d|x|X)$/.test(idCardNo);\n if (!check) return false;\n var addressCode = idCardNo.substring(0, 2);\n check = checkAddressCode(addressCode);\n if (!check) return false;\n var birDayCode = idCardNo.substring(6, 14);\n check = checkBirthDayCode(birDayCode);\n if (!check) return false;\n return checkParityBit(idCardNo);\n };\n\n var checkIdCardNo = function checkIdCardNo(idCardNo) {\n var check = /^\\d{15}|(\\d{17}(\\d|x|X))$/.test(idCardNo);\n if (!check) return false;\n\n if (idCardNo.length === 15) {\n return check15IdCardNo(idCardNo);\n }\n\n return check18IdCardNo(idCardNo);\n };\n\n return checkIdCardNo(str);\n },\n 'zh-HK': function zhHK(str) {\n // sanitize user input\n str = str.trim(); // HKID number starts with 1 or 2 letters, followed by 6 digits,\n // then a checksum contained in square / round brackets or nothing\n\n var regexHKID = /^[A-Z]{1,2}[0-9]{6}((\\([0-9A]\\))|(\\[[0-9A]\\])|([0-9A]))$/;\n var regexIsDigit = /^[0-9]$/; // convert the user input to all uppercase and apply regex\n\n str = str.toUpperCase();\n if (!regexHKID.test(str)) return false;\n str = str.replace(/\\[|\\]|\\(|\\)/g, '');\n if (str.length === 8) str = \"3\".concat(str);\n var checkSumVal = 0;\n\n for (var i = 0; i <= 7; i++) {\n var convertedChar = void 0;\n if (!regexIsDigit.test(str[i])) convertedChar = (str[i].charCodeAt(0) - 55) % 11;else convertedChar = str[i];\n checkSumVal += convertedChar * (9 - i);\n }\n\n checkSumVal %= 11;\n var checkSumConverted;\n if (checkSumVal === 0) checkSumConverted = '0';else if (checkSumVal === 1) checkSumConverted = 'A';else checkSumConverted = String(11 - checkSumVal);\n if (checkSumConverted === str[str.length - 1]) return true;\n return false;\n },\n 'zh-TW': function zhTW(str) {\n var ALPHABET_CODES = {\n A: 10,\n B: 11,\n C: 12,\n D: 13,\n E: 14,\n F: 15,\n G: 16,\n H: 17,\n I: 34,\n J: 18,\n K: 19,\n L: 20,\n M: 21,\n N: 22,\n O: 35,\n P: 23,\n Q: 24,\n R: 25,\n S: 26,\n T: 27,\n U: 28,\n V: 29,\n W: 32,\n X: 30,\n Y: 31,\n Z: 33\n };\n var sanitized = str.trim().toUpperCase();\n if (!/^[A-Z][0-9]{9}$/.test(sanitized)) return false;\n return Array.from(sanitized).reduce(function (sum, number, index) {\n if (index === 0) {\n var code = ALPHABET_CODES[number];\n return code % 10 * 9 + Math.floor(code / 10);\n }\n\n if (index === 9) {\n return (10 - sum % 10 - Number(number)) % 10 === 0;\n }\n\n return sum + Number(number) * (9 - index);\n }, 0);\n }\n};\n\nfunction isIdentityCard(str, locale) {\n (0, _assertString.default)(str);\n\n if (locale in validators) {\n return validators[locale](str);\n } else if (locale === 'any') {\n for (var key in validators) {\n // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes\n // istanbul ignore else\n if (validators.hasOwnProperty(key)) {\n var validator = validators[key];\n\n if (validator(str)) {\n return true;\n }\n }\n }\n\n return false;\n }\n\n throw new Error(\"Invalid locale '\".concat(locale, \"'\"));\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isEAN;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * The most commonly used EAN standard is\n * the thirteen-digit EAN-13, while the\n * less commonly used 8-digit EAN-8 barcode was\n * introduced for use on small packages.\n * Also EAN/UCC-14 is used for Grouping of individual\n * trade items above unit level(Intermediate, Carton or Pallet).\n * For more info about EAN-14 checkout: https://www.gtin.info/itf-14-barcodes/\n * EAN consists of:\n * GS1 prefix, manufacturer code, product code and check digit\n * Reference: https://en.wikipedia.org/wiki/International_Article_Number\n * Reference: https://www.gtin.info/\n */\n\n/**\n * Define EAN Lenghts; 8 for EAN-8; 13 for EAN-13; 14 for EAN-14\n * and Regular Expression for valid EANs (EAN-8, EAN-13, EAN-14),\n * with exact numberic matching of 8 or 13 or 14 digits [0-9]\n */\nvar LENGTH_EAN_8 = 8;\nvar LENGTH_EAN_14 = 14;\nvar validEanRegex = /^(\\d{8}|\\d{13}|\\d{14})$/;\n/**\n * Get position weight given:\n * EAN length and digit index/position\n *\n * @param {number} length\n * @param {number} index\n * @return {number}\n */\n\nfunction getPositionWeightThroughLengthAndIndex(length, index) {\n if (length === LENGTH_EAN_8 || length === LENGTH_EAN_14) {\n return index % 2 === 0 ? 3 : 1;\n }\n\n return index % 2 === 0 ? 1 : 3;\n}\n/**\n * Calculate EAN Check Digit\n * Reference: https://en.wikipedia.org/wiki/International_Article_Number#Calculation_of_checksum_digit\n *\n * @param {string} ean\n * @return {number}\n */\n\n\nfunction calculateCheckDigit(ean) {\n var checksum = ean.slice(0, -1).split('').map(function (char, index) {\n return Number(char) * getPositionWeightThroughLengthAndIndex(ean.length, index);\n }).reduce(function (acc, partialSum) {\n return acc + partialSum;\n }, 0);\n var remainder = 10 - checksum % 10;\n return remainder < 10 ? remainder : 0;\n}\n/**\n * Check if string is valid EAN:\n * Matches EAN-8/EAN-13/EAN-14 regex\n * Has valid check digit.\n *\n * @param {string} str\n * @return {boolean}\n */\n\n\nfunction isEAN(str) {\n (0, _assertString.default)(str);\n var actualCheckDigit = Number(str.slice(-1));\n return validEanRegex.test(str) && actualCheckDigit === calculateCheckDigit(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISIN;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar isin = /^[A-Z]{2}[0-9A-Z]{9}[0-9]$/; // this link details how the check digit is calculated:\n// https://www.isin.org/isin-format/. it is a little bit\n// odd in that it works with digits, not numbers. in order\n// to make only one pass through the ISIN characters, the\n// each alpha character is handled as 2 characters within\n// the loop.\n\nfunction isISIN(str) {\n (0, _assertString.default)(str);\n\n if (!isin.test(str)) {\n return false;\n }\n\n var double = true;\n var sum = 0; // convert values\n\n for (var i = str.length - 2; i >= 0; i--) {\n if (str[i] >= 'A' && str[i] <= 'Z') {\n var value = str[i].charCodeAt(0) - 55;\n var lo = value % 10;\n var hi = Math.trunc(value / 10); // letters have two digits, so handle the low order\n // and high order digits separately.\n\n for (var _i = 0, _arr = [lo, hi]; _i < _arr.length; _i++) {\n var digit = _arr[_i];\n\n if (double) {\n if (digit >= 5) {\n sum += 1 + (digit - 5) * 2;\n } else {\n sum += digit * 2;\n }\n } else {\n sum += digit;\n }\n\n double = !double;\n }\n } else {\n var _digit = str[i].charCodeAt(0) - '0'.charCodeAt(0);\n\n if (double) {\n if (_digit >= 5) {\n sum += 1 + (_digit - 5) * 2;\n } else {\n sum += _digit * 2;\n }\n } else {\n sum += _digit;\n }\n\n double = !double;\n }\n }\n\n var check = Math.trunc((sum + 9) / 10) * 10 - sum;\n return +str[str.length - 1] === check;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISBN;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar possibleIsbn10 = /^(?:[0-9]{9}X|[0-9]{10})$/;\nvar possibleIsbn13 = /^(?:[0-9]{13})$/;\nvar factor = [1, 3];\n\nfunction isISBN(isbn, options) {\n (0, _assertString.default)(isbn); // For backwards compatibility:\n // isISBN(str [, version]), i.e. `options` could be used as argument for the legacy `version`\n\n var version = String((options === null || options === void 0 ? void 0 : options.version) || options);\n\n if (!(options !== null && options !== void 0 && options.version || options)) {\n return isISBN(isbn, {\n version: 10\n }) || isISBN(isbn, {\n version: 13\n });\n }\n\n var sanitizedIsbn = isbn.replace(/[\\s-]+/g, '');\n var checksum = 0;\n\n if (version === '10') {\n if (!possibleIsbn10.test(sanitizedIsbn)) {\n return false;\n }\n\n for (var i = 0; i < version - 1; i++) {\n checksum += (i + 1) * sanitizedIsbn.charAt(i);\n }\n\n if (sanitizedIsbn.charAt(9) === 'X') {\n checksum += 10 * 10;\n } else {\n checksum += 10 * sanitizedIsbn.charAt(9);\n }\n\n if (checksum % 11 === 0) {\n return true;\n }\n } else if (version === '13') {\n if (!possibleIsbn13.test(sanitizedIsbn)) {\n return false;\n }\n\n for (var _i = 0; _i < 12; _i++) {\n checksum += factor[_i % 2] * sanitizedIsbn.charAt(_i);\n }\n\n if (sanitizedIsbn.charAt(12) - (10 - checksum % 10) % 10 === 0) {\n return true;\n }\n }\n\n return false;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISSN;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar issn = '^\\\\d{4}-?\\\\d{3}[\\\\dX]$';\n\nfunction isISSN(str) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n (0, _assertString.default)(str);\n var testIssn = issn;\n testIssn = options.require_hyphen ? testIssn.replace('?', '') : testIssn;\n testIssn = options.case_sensitive ? new RegExp(testIssn) : new RegExp(testIssn, 'i');\n\n if (!testIssn.test(str)) {\n return false;\n }\n\n var digits = str.replace('-', '').toUpperCase();\n var checksum = 0;\n\n for (var i = 0; i < digits.length; i++) {\n var digit = digits[i];\n checksum += (digit === 'X' ? 10 : +digit) * (8 - i);\n }\n\n return checksum % 11 === 0;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.iso7064Check = iso7064Check;\nexports.luhnCheck = luhnCheck;\nexports.reverseMultiplyAndSum = reverseMultiplyAndSum;\nexports.verhoeffCheck = verhoeffCheck;\n\n/**\n * Algorithmic validation functions\n * May be used as is or implemented in the workflow of other validators.\n */\n\n/*\n * ISO 7064 validation function\n * Called with a string of numbers (incl. check digit)\n * to validate according to ISO 7064 (MOD 11, 10).\n */\nfunction iso7064Check(str) {\n var checkvalue = 10;\n\n for (var i = 0; i < str.length - 1; i++) {\n checkvalue = (parseInt(str[i], 10) + checkvalue) % 10 === 0 ? 10 * 2 % 11 : (parseInt(str[i], 10) + checkvalue) % 10 * 2 % 11;\n }\n\n checkvalue = checkvalue === 1 ? 0 : 11 - checkvalue;\n return checkvalue === parseInt(str[10], 10);\n}\n/*\n * Luhn (mod 10) validation function\n * Called with a string of numbers (incl. check digit)\n * to validate according to the Luhn algorithm.\n */\n\n\nfunction luhnCheck(str) {\n var checksum = 0;\n var second = false;\n\n for (var i = str.length - 1; i >= 0; i--) {\n if (second) {\n var product = parseInt(str[i], 10) * 2;\n\n if (product > 9) {\n // sum digits of product and add to checksum\n checksum += product.toString().split('').map(function (a) {\n return parseInt(a, 10);\n }).reduce(function (a, b) {\n return a + b;\n }, 0);\n } else {\n checksum += product;\n }\n } else {\n checksum += parseInt(str[i], 10);\n }\n\n second = !second;\n }\n\n return checksum % 10 === 0;\n}\n/*\n * Reverse TIN multiplication and summation helper function\n * Called with an array of single-digit integers and a base multiplier\n * to calculate the sum of the digits multiplied in reverse.\n * Normally used in variations of MOD 11 algorithmic checks.\n */\n\n\nfunction reverseMultiplyAndSum(digits, base) {\n var total = 0;\n\n for (var i = 0; i < digits.length; i++) {\n total += digits[i] * (base - i);\n }\n\n return total;\n}\n/*\n * Verhoeff validation helper function\n * Called with a string of numbers\n * to validate according to the Verhoeff algorithm.\n */\n\n\nfunction verhoeffCheck(str) {\n var d_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];\n var p_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // Copy (to prevent replacement) and reverse\n\n var str_copy = str.split('').reverse().join('');\n var checksum = 0;\n\n for (var i = 0; i < str_copy.length; i++) {\n checksum = d_table[checksum][p_table[i % 8][parseInt(str_copy[i], 10)]];\n }\n\n return checksum === 0;\n}","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isTaxID;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar algorithms = _interopRequireWildcard(require(\"./util/algorithms\"));\n\nvar _isDate = _interopRequireDefault(require(\"./isDate\"));\n\nfunction _getRequireWildcardCache() { if (typeof WeakMap !== \"function\") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\n/**\n * TIN Validation\n * Validates Tax Identification Numbers (TINs) from the US, EU member states and the United Kingdom.\n *\n * EU-UK:\n * National TIN validity is calculated using public algorithms as made available by DG TAXUD.\n *\n * See `https://ec.europa.eu/taxation_customs/tin/specs/FS-TIN%20Algorithms-Public.docx` for more information.\n *\n * US:\n * An Employer Identification Number (EIN), also known as a Federal Tax Identification Number,\n * is used to identify a business entity.\n *\n * NOTES:\n * - Prefix 47 is being reserved for future use\n * - Prefixes 26, 27, 45, 46 and 47 were previously assigned by the Philadelphia campus.\n *\n * See `http://www.irs.gov/Businesses/Small-Businesses-&-Self-Employed/How-EINs-are-Assigned-and-Valid-EIN-Prefixes`\n * for more information.\n */\n// Locale functions\n\n/*\n * bg-BG validation function\n * (Edinen graždanski nomer (EGN/ЕГН), persons only)\n * Checks if birth date (first six digits) is valid and calculates check (last) digit\n */\nfunction bgBgCheck(tin) {\n // Extract full year, normalize month and check birth date validity\n var century_year = tin.slice(0, 2);\n var month = parseInt(tin.slice(2, 4), 10);\n\n if (month > 40) {\n month -= 40;\n century_year = \"20\".concat(century_year);\n } else if (month > 20) {\n month -= 20;\n century_year = \"18\".concat(century_year);\n } else {\n century_year = \"19\".concat(century_year);\n }\n\n if (month < 10) {\n month = \"0\".concat(month);\n }\n\n var date = \"\".concat(century_year, \"/\").concat(month, \"/\").concat(tin.slice(4, 6));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // split digits into an array for further processing\n\n\n var digits = tin.split('').map(function (a) {\n return parseInt(a, 10);\n }); // Calculate checksum by multiplying digits with fixed values\n\n var multip_lookup = [2, 4, 8, 5, 10, 9, 7, 3, 6];\n var checksum = 0;\n\n for (var i = 0; i < multip_lookup.length; i++) {\n checksum += digits[i] * multip_lookup[i];\n }\n\n checksum = checksum % 11 === 10 ? 0 : checksum % 11;\n return checksum === digits[9];\n}\n/**\n * Check if an input is a valid Canadian SIN (Social Insurance Number)\n *\n * The Social Insurance Number (SIN) is a 9 digit number that\n * you need to work in Canada or to have access to government programs and benefits.\n *\n * https://en.wikipedia.org/wiki/Social_Insurance_Number\n * https://www.canada.ca/en/employment-social-development/services/sin.html\n * https://www.codercrunch.com/challenge/819302488/sin-validator\n *\n * @param {string} input\n * @return {boolean}\n */\n\n\nfunction isCanadianSIN(input) {\n var digitsArray = input.split('');\n var even = digitsArray.filter(function (_, idx) {\n return idx % 2;\n }).map(function (i) {\n return Number(i) * 2;\n }).join('').split('');\n var total = digitsArray.filter(function (_, idx) {\n return !(idx % 2);\n }).concat(even).map(function (i) {\n return Number(i);\n }).reduce(function (acc, cur) {\n return acc + cur;\n });\n return total % 10 === 0;\n}\n/*\n * cs-CZ validation function\n * (Rodné číslo (RČ), persons only)\n * Checks if birth date (first six digits) is valid and divisibility by 11\n * Material not in DG TAXUD document sourced from:\n * -`https://lorenc.info/3MA381/overeni-spravnosti-rodneho-cisla.htm`\n * -`https://www.mvcr.cz/clanek/rady-a-sluzby-dokumenty-rodne-cislo.aspx`\n */\n\n\nfunction csCzCheck(tin) {\n tin = tin.replace(/\\W/, ''); // Extract full year from TIN length\n\n var full_year = parseInt(tin.slice(0, 2), 10);\n\n if (tin.length === 10) {\n if (full_year < 54) {\n full_year = \"20\".concat(full_year);\n } else {\n full_year = \"19\".concat(full_year);\n }\n } else {\n if (tin.slice(6) === '000') {\n return false;\n } // Three-zero serial not assigned before 1954\n\n\n if (full_year < 54) {\n full_year = \"19\".concat(full_year);\n } else {\n return false; // No 18XX years seen in any of the resources\n }\n } // Add missing zero if needed\n\n\n if (full_year.length === 3) {\n full_year = [full_year.slice(0, 2), '0', full_year.slice(2)].join('');\n } // Extract month from TIN and normalize\n\n\n var month = parseInt(tin.slice(2, 4), 10);\n\n if (month > 50) {\n month -= 50;\n }\n\n if (month > 20) {\n // Month-plus-twenty was only introduced in 2004\n if (parseInt(full_year, 10) < 2004) {\n return false;\n }\n\n month -= 20;\n }\n\n if (month < 10) {\n month = \"0\".concat(month);\n } // Check date validity\n\n\n var date = \"\".concat(full_year, \"/\").concat(month, \"/\").concat(tin.slice(4, 6));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // Verify divisibility by 11\n\n\n if (tin.length === 10) {\n if (parseInt(tin, 10) % 11 !== 0) {\n // Some numbers up to and including 1985 are still valid if\n // check (last) digit equals 0 and modulo of first 9 digits equals 10\n var checkdigit = parseInt(tin.slice(0, 9), 10) % 11;\n\n if (parseInt(full_year, 10) < 1986 && checkdigit === 10) {\n if (parseInt(tin.slice(9), 10) !== 0) {\n return false;\n }\n } else {\n return false;\n }\n }\n }\n\n return true;\n}\n/*\n * de-AT validation function\n * (Abgabenkontonummer, persons/entities)\n * Verify TIN validity by calling luhnCheck()\n */\n\n\nfunction deAtCheck(tin) {\n return algorithms.luhnCheck(tin);\n}\n/*\n * de-DE validation function\n * (Steueridentifikationsnummer (Steuer-IdNr.), persons only)\n * Tests for single duplicate/triplicate value, then calculates ISO 7064 check (last) digit\n * Partial implementation of spec (same result with both algorithms always)\n */\n\n\nfunction deDeCheck(tin) {\n // Split digits into an array for further processing\n var digits = tin.split('').map(function (a) {\n return parseInt(a, 10);\n }); // Fill array with strings of number positions\n\n var occurences = [];\n\n for (var i = 0; i < digits.length - 1; i++) {\n occurences.push('');\n\n for (var j = 0; j < digits.length - 1; j++) {\n if (digits[i] === digits[j]) {\n occurences[i] += j;\n }\n }\n } // Remove digits with one occurence and test for only one duplicate/triplicate\n\n\n occurences = occurences.filter(function (a) {\n return a.length > 1;\n });\n\n if (occurences.length !== 2 && occurences.length !== 3) {\n return false;\n } // In case of triplicate value only two digits are allowed next to each other\n\n\n if (occurences[0].length === 3) {\n var trip_locations = occurences[0].split('').map(function (a) {\n return parseInt(a, 10);\n });\n var recurrent = 0; // Amount of neighbour occurences\n\n for (var _i = 0; _i < trip_locations.length - 1; _i++) {\n if (trip_locations[_i] + 1 === trip_locations[_i + 1]) {\n recurrent += 1;\n }\n }\n\n if (recurrent === 2) {\n return false;\n }\n }\n\n return algorithms.iso7064Check(tin);\n}\n/*\n * dk-DK validation function\n * (CPR-nummer (personnummer), persons only)\n * Checks if birth date (first six digits) is valid and assigned to century (seventh) digit,\n * and calculates check (last) digit\n */\n\n\nfunction dkDkCheck(tin) {\n tin = tin.replace(/\\W/, ''); // Extract year, check if valid for given century digit and add century\n\n var year = parseInt(tin.slice(4, 6), 10);\n var century_digit = tin.slice(6, 7);\n\n switch (century_digit) {\n case '0':\n case '1':\n case '2':\n case '3':\n year = \"19\".concat(year);\n break;\n\n case '4':\n case '9':\n if (year < 37) {\n year = \"20\".concat(year);\n } else {\n year = \"19\".concat(year);\n }\n\n break;\n\n default:\n if (year < 37) {\n year = \"20\".concat(year);\n } else if (year > 58) {\n year = \"18\".concat(year);\n } else {\n return false;\n }\n\n break;\n } // Add missing zero if needed\n\n\n if (year.length === 3) {\n year = [year.slice(0, 2), '0', year.slice(2)].join('');\n } // Check date validity\n\n\n var date = \"\".concat(year, \"/\").concat(tin.slice(2, 4), \"/\").concat(tin.slice(0, 2));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // Split digits into an array for further processing\n\n\n var digits = tin.split('').map(function (a) {\n return parseInt(a, 10);\n });\n var checksum = 0;\n var weight = 4; // Multiply by weight and add to checksum\n\n for (var i = 0; i < 9; i++) {\n checksum += digits[i] * weight;\n weight -= 1;\n\n if (weight === 1) {\n weight = 7;\n }\n }\n\n checksum %= 11;\n\n if (checksum === 1) {\n return false;\n }\n\n return checksum === 0 ? digits[9] === 0 : digits[9] === 11 - checksum;\n}\n/*\n * el-CY validation function\n * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons only)\n * Verify TIN validity by calculating ASCII value of check (last) character\n */\n\n\nfunction elCyCheck(tin) {\n // split digits into an array for further processing\n var digits = tin.slice(0, 8).split('').map(function (a) {\n return parseInt(a, 10);\n });\n var checksum = 0; // add digits in even places\n\n for (var i = 1; i < digits.length; i += 2) {\n checksum += digits[i];\n } // add digits in odd places\n\n\n for (var _i2 = 0; _i2 < digits.length; _i2 += 2) {\n if (digits[_i2] < 2) {\n checksum += 1 - digits[_i2];\n } else {\n checksum += 2 * (digits[_i2] - 2) + 5;\n\n if (digits[_i2] > 4) {\n checksum += 2;\n }\n }\n }\n\n return String.fromCharCode(checksum % 26 + 65) === tin.charAt(8);\n}\n/*\n * el-GR validation function\n * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons/entities)\n * Verify TIN validity by calculating check (last) digit\n * Algorithm not in DG TAXUD document- sourced from:\n * - `http://epixeirisi.gr/%CE%9A%CE%A1%CE%99%CE%A3%CE%99%CE%9C%CE%91-%CE%98%CE%95%CE%9C%CE%91%CE%A4%CE%91-%CE%A6%CE%9F%CE%A1%CE%9F%CE%9B%CE%9F%CE%93%CE%99%CE%91%CE%A3-%CE%9A%CE%91%CE%99-%CE%9B%CE%9F%CE%93%CE%99%CE%A3%CE%A4%CE%99%CE%9A%CE%97%CE%A3/23791/%CE%91%CF%81%CE%B9%CE%B8%CE%BC%CF%8C%CF%82-%CE%A6%CE%BF%CF%81%CE%BF%CE%BB%CE%BF%CE%B3%CE%B9%CE%BA%CE%BF%CF%8D-%CE%9C%CE%B7%CF%84%CF%81%CF%8E%CE%BF%CF%85`\n */\n\n\nfunction elGrCheck(tin) {\n // split digits into an array for further processing\n var digits = tin.split('').map(function (a) {\n return parseInt(a, 10);\n });\n var checksum = 0;\n\n for (var i = 0; i < 8; i++) {\n checksum += digits[i] * Math.pow(2, 8 - i);\n }\n\n return checksum % 11 % 10 === digits[8];\n}\n/*\n * en-GB validation function (should go here if needed)\n * (National Insurance Number (NINO) or Unique Taxpayer Reference (UTR),\n * persons/entities respectively)\n */\n\n/*\n * en-IE validation function\n * (Personal Public Service Number (PPS No), persons only)\n * Verify TIN validity by calculating check (second to last) character\n */\n\n\nfunction enIeCheck(tin) {\n var checksum = algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {\n return parseInt(a, 10);\n }), 8);\n\n if (tin.length === 9 && tin[8] !== 'W') {\n checksum += (tin[8].charCodeAt(0) - 64) * 9;\n }\n\n checksum %= 23;\n\n if (checksum === 0) {\n return tin[7].toUpperCase() === 'W';\n }\n\n return tin[7].toUpperCase() === String.fromCharCode(64 + checksum);\n} // Valid US IRS campus prefixes\n\n\nvar enUsCampusPrefix = {\n andover: ['10', '12'],\n atlanta: ['60', '67'],\n austin: ['50', '53'],\n brookhaven: ['01', '02', '03', '04', '05', '06', '11', '13', '14', '16', '21', '22', '23', '25', '34', '51', '52', '54', '55', '56', '57', '58', '59', '65'],\n cincinnati: ['30', '32', '35', '36', '37', '38', '61'],\n fresno: ['15', '24'],\n internet: ['20', '26', '27', '45', '46', '47'],\n kansas: ['40', '44'],\n memphis: ['94', '95'],\n ogden: ['80', '90'],\n philadelphia: ['33', '39', '41', '42', '43', '46', '48', '62', '63', '64', '66', '68', '71', '72', '73', '74', '75', '76', '77', '81', '82', '83', '84', '85', '86', '87', '88', '91', '92', '93', '98', '99'],\n sba: ['31']\n}; // Return an array of all US IRS campus prefixes\n\nfunction enUsGetPrefixes() {\n var prefixes = [];\n\n for (var location in enUsCampusPrefix) {\n // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes\n // istanbul ignore else\n if (enUsCampusPrefix.hasOwnProperty(location)) {\n prefixes.push.apply(prefixes, _toConsumableArray(enUsCampusPrefix[location]));\n }\n }\n\n return prefixes;\n}\n/*\n * en-US validation function\n * Verify that the TIN starts with a valid IRS campus prefix\n */\n\n\nfunction enUsCheck(tin) {\n return enUsGetPrefixes().indexOf(tin.slice(0, 2)) !== -1;\n}\n/*\n * es-ES validation function\n * (Documento Nacional de Identidad (DNI)\n * or Número de Identificación de Extranjero (NIE), persons only)\n * Verify TIN validity by calculating check (last) character\n */\n\n\nfunction esEsCheck(tin) {\n // Split characters into an array for further processing\n var chars = tin.toUpperCase().split(''); // Replace initial letter if needed\n\n if (isNaN(parseInt(chars[0], 10)) && chars.length > 1) {\n var lead_replace = 0;\n\n switch (chars[0]) {\n case 'Y':\n lead_replace = 1;\n break;\n\n case 'Z':\n lead_replace = 2;\n break;\n\n default:\n }\n\n chars.splice(0, 1, lead_replace); // Fill with zeros if smaller than proper\n } else {\n while (chars.length < 9) {\n chars.unshift(0);\n }\n } // Calculate checksum and check according to lookup\n\n\n var lookup = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E'];\n chars = chars.join('');\n var checksum = parseInt(chars.slice(0, 8), 10) % 23;\n return chars[8] === lookup[checksum];\n}\n/*\n * et-EE validation function\n * (Isikukood (IK), persons only)\n * Checks if birth date (century digit and six following) is valid and calculates check (last) digit\n * Material not in DG TAXUD document sourced from:\n * - `https://www.oecd.org/tax/automatic-exchange/crs-implementation-and-assistance/tax-identification-numbers/Estonia-TIN.pdf`\n */\n\n\nfunction etEeCheck(tin) {\n // Extract year and add century\n var full_year = tin.slice(1, 3);\n var century_digit = tin.slice(0, 1);\n\n switch (century_digit) {\n case '1':\n case '2':\n full_year = \"18\".concat(full_year);\n break;\n\n case '3':\n case '4':\n full_year = \"19\".concat(full_year);\n break;\n\n default:\n full_year = \"20\".concat(full_year);\n break;\n } // Check date validity\n\n\n var date = \"\".concat(full_year, \"/\").concat(tin.slice(3, 5), \"/\").concat(tin.slice(5, 7));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // Split digits into an array for further processing\n\n\n var digits = tin.split('').map(function (a) {\n return parseInt(a, 10);\n });\n var checksum = 0;\n var weight = 1; // Multiply by weight and add to checksum\n\n for (var i = 0; i < 10; i++) {\n checksum += digits[i] * weight;\n weight += 1;\n\n if (weight === 10) {\n weight = 1;\n }\n } // Do again if modulo 11 of checksum is 10\n\n\n if (checksum % 11 === 10) {\n checksum = 0;\n weight = 3;\n\n for (var _i3 = 0; _i3 < 10; _i3++) {\n checksum += digits[_i3] * weight;\n weight += 1;\n\n if (weight === 10) {\n weight = 1;\n }\n }\n\n if (checksum % 11 === 10) {\n return digits[10] === 0;\n }\n }\n\n return checksum % 11 === digits[10];\n}\n/*\n * fi-FI validation function\n * (Henkilötunnus (HETU), persons only)\n * Checks if birth date (first six digits plus century symbol) is valid\n * and calculates check (last) digit\n */\n\n\nfunction fiFiCheck(tin) {\n // Extract year and add century\n var full_year = tin.slice(4, 6);\n var century_symbol = tin.slice(6, 7);\n\n switch (century_symbol) {\n case '+':\n full_year = \"18\".concat(full_year);\n break;\n\n case '-':\n full_year = \"19\".concat(full_year);\n break;\n\n default:\n full_year = \"20\".concat(full_year);\n break;\n } // Check date validity\n\n\n var date = \"\".concat(full_year, \"/\").concat(tin.slice(2, 4), \"/\").concat(tin.slice(0, 2));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // Calculate check character\n\n\n var checksum = parseInt(tin.slice(0, 6) + tin.slice(7, 10), 10) % 31;\n\n if (checksum < 10) {\n return checksum === parseInt(tin.slice(10), 10);\n }\n\n checksum -= 10;\n var letters_lookup = ['A', 'B', 'C', 'D', 'E', 'F', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y'];\n return letters_lookup[checksum] === tin.slice(10);\n}\n/*\n * fr/nl-BE validation function\n * (Numéro national (N.N.), persons only)\n * Checks if birth date (first six digits) is valid and calculates check (last two) digits\n */\n\n\nfunction frBeCheck(tin) {\n // Zero month/day value is acceptable\n if (tin.slice(2, 4) !== '00' || tin.slice(4, 6) !== '00') {\n // Extract date from first six digits of TIN\n var date = \"\".concat(tin.slice(0, 2), \"/\").concat(tin.slice(2, 4), \"/\").concat(tin.slice(4, 6));\n\n if (!(0, _isDate.default)(date, 'YY/MM/DD')) {\n return false;\n }\n }\n\n var checksum = 97 - parseInt(tin.slice(0, 9), 10) % 97;\n var checkdigits = parseInt(tin.slice(9, 11), 10);\n\n if (checksum !== checkdigits) {\n checksum = 97 - parseInt(\"2\".concat(tin.slice(0, 9)), 10) % 97;\n\n if (checksum !== checkdigits) {\n return false;\n }\n }\n\n return true;\n}\n/*\n * fr-FR validation function\n * (Numéro fiscal de référence (numéro SPI), persons only)\n * Verify TIN validity by calculating check (last three) digits\n */\n\n\nfunction frFrCheck(tin) {\n tin = tin.replace(/\\s/g, '');\n var checksum = parseInt(tin.slice(0, 10), 10) % 511;\n var checkdigits = parseInt(tin.slice(10, 13), 10);\n return checksum === checkdigits;\n}\n/*\n * fr/lb-LU validation function\n * (numéro d’identification personnelle, persons only)\n * Verify birth date validity and run Luhn and Verhoeff checks\n */\n\n\nfunction frLuCheck(tin) {\n // Extract date and check validity\n var date = \"\".concat(tin.slice(0, 4), \"/\").concat(tin.slice(4, 6), \"/\").concat(tin.slice(6, 8));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // Run Luhn check\n\n\n if (!algorithms.luhnCheck(tin.slice(0, 12))) {\n return false;\n } // Remove Luhn check digit and run Verhoeff check\n\n\n return algorithms.verhoeffCheck(\"\".concat(tin.slice(0, 11)).concat(tin[12]));\n}\n/*\n * hr-HR validation function\n * (Osobni identifikacijski broj (OIB), persons/entities)\n * Verify TIN validity by calling iso7064Check(digits)\n */\n\n\nfunction hrHrCheck(tin) {\n return algorithms.iso7064Check(tin);\n}\n/*\n * hu-HU validation function\n * (Adóazonosító jel, persons only)\n * Verify TIN validity by calculating check (last) digit\n */\n\n\nfunction huHuCheck(tin) {\n // split digits into an array for further processing\n var digits = tin.split('').map(function (a) {\n return parseInt(a, 10);\n });\n var checksum = 8;\n\n for (var i = 1; i < 9; i++) {\n checksum += digits[i] * (i + 1);\n }\n\n return checksum % 11 === digits[9];\n}\n/*\n * lt-LT validation function (should go here if needed)\n * (Asmens kodas, persons/entities respectively)\n * Current validation check is alias of etEeCheck- same format applies\n */\n\n/*\n * it-IT first/last name validity check\n * Accepts it-IT TIN-encoded names as a three-element character array and checks their validity\n * Due to lack of clarity between resources (\"Are only Italian consonants used?\n * What happens if a person has X in their name?\" etc.) only two test conditions\n * have been implemented:\n * Vowels may only be followed by other vowels or an X character\n * and X characters after vowels may only be followed by other X characters.\n */\n\n\nfunction itItNameCheck(name) {\n // true at the first occurence of a vowel\n var vowelflag = false; // true at the first occurence of an X AFTER vowel\n // (to properly handle last names with X as consonant)\n\n var xflag = false;\n\n for (var i = 0; i < 3; i++) {\n if (!vowelflag && /[AEIOU]/.test(name[i])) {\n vowelflag = true;\n } else if (!xflag && vowelflag && name[i] === 'X') {\n xflag = true;\n } else if (i > 0) {\n if (vowelflag && !xflag) {\n if (!/[AEIOU]/.test(name[i])) {\n return false;\n }\n }\n\n if (xflag) {\n if (!/X/.test(name[i])) {\n return false;\n }\n }\n }\n }\n\n return true;\n}\n/*\n * it-IT validation function\n * (Codice fiscale (TIN-IT), persons only)\n * Verify name, birth date and codice catastale validity\n * and calculate check character.\n * Material not in DG-TAXUD document sourced from:\n * `https://en.wikipedia.org/wiki/Italian_fiscal_code`\n */\n\n\nfunction itItCheck(tin) {\n // Capitalize and split characters into an array for further processing\n var chars = tin.toUpperCase().split(''); // Check first and last name validity calling itItNameCheck()\n\n if (!itItNameCheck(chars.slice(0, 3))) {\n return false;\n }\n\n if (!itItNameCheck(chars.slice(3, 6))) {\n return false;\n } // Convert letters in number spaces back to numbers if any\n\n\n var number_locations = [6, 7, 9, 10, 12, 13, 14];\n var number_replace = {\n L: '0',\n M: '1',\n N: '2',\n P: '3',\n Q: '4',\n R: '5',\n S: '6',\n T: '7',\n U: '8',\n V: '9'\n };\n\n for (var _i4 = 0, _number_locations = number_locations; _i4 < _number_locations.length; _i4++) {\n var i = _number_locations[_i4];\n\n if (chars[i] in number_replace) {\n chars.splice(i, 1, number_replace[chars[i]]);\n }\n } // Extract month and day, and check date validity\n\n\n var month_replace = {\n A: '01',\n B: '02',\n C: '03',\n D: '04',\n E: '05',\n H: '06',\n L: '07',\n M: '08',\n P: '09',\n R: '10',\n S: '11',\n T: '12'\n };\n var month = month_replace[chars[8]];\n var day = parseInt(chars[9] + chars[10], 10);\n\n if (day > 40) {\n day -= 40;\n }\n\n if (day < 10) {\n day = \"0\".concat(day);\n }\n\n var date = \"\".concat(chars[6]).concat(chars[7], \"/\").concat(month, \"/\").concat(day);\n\n if (!(0, _isDate.default)(date, 'YY/MM/DD')) {\n return false;\n } // Calculate check character by adding up even and odd characters as numbers\n\n\n var checksum = 0;\n\n for (var _i5 = 1; _i5 < chars.length - 1; _i5 += 2) {\n var char_to_int = parseInt(chars[_i5], 10);\n\n if (isNaN(char_to_int)) {\n char_to_int = chars[_i5].charCodeAt(0) - 65;\n }\n\n checksum += char_to_int;\n }\n\n var odd_convert = {\n // Maps of characters at odd places\n A: 1,\n B: 0,\n C: 5,\n D: 7,\n E: 9,\n F: 13,\n G: 15,\n H: 17,\n I: 19,\n J: 21,\n K: 2,\n L: 4,\n M: 18,\n N: 20,\n O: 11,\n P: 3,\n Q: 6,\n R: 8,\n S: 12,\n T: 14,\n U: 16,\n V: 10,\n W: 22,\n X: 25,\n Y: 24,\n Z: 23,\n 0: 1,\n 1: 0\n };\n\n for (var _i6 = 0; _i6 < chars.length - 1; _i6 += 2) {\n var _char_to_int = 0;\n\n if (chars[_i6] in odd_convert) {\n _char_to_int = odd_convert[chars[_i6]];\n } else {\n var multiplier = parseInt(chars[_i6], 10);\n _char_to_int = 2 * multiplier + 1;\n\n if (multiplier > 4) {\n _char_to_int += 2;\n }\n }\n\n checksum += _char_to_int;\n }\n\n if (String.fromCharCode(65 + checksum % 26) !== chars[15]) {\n return false;\n }\n\n return true;\n}\n/*\n * lv-LV validation function\n * (Personas kods (PK), persons only)\n * Check validity of birth date and calculate check (last) digit\n * Support only for old format numbers (not starting with '32', issued before 2017/07/01)\n * Material not in DG TAXUD document sourced from:\n * `https://boot.ritakafija.lv/forums/index.php?/topic/88314-personas-koda-algoritms-%C4%8Deksumma/`\n */\n\n\nfunction lvLvCheck(tin) {\n tin = tin.replace(/\\W/, ''); // Extract date from TIN\n\n var day = tin.slice(0, 2);\n\n if (day !== '32') {\n // No date/checksum check if new format\n var month = tin.slice(2, 4);\n\n if (month !== '00') {\n // No date check if unknown month\n var full_year = tin.slice(4, 6);\n\n switch (tin[6]) {\n case '0':\n full_year = \"18\".concat(full_year);\n break;\n\n case '1':\n full_year = \"19\".concat(full_year);\n break;\n\n default:\n full_year = \"20\".concat(full_year);\n break;\n } // Check date validity\n\n\n var date = \"\".concat(full_year, \"/\").concat(tin.slice(2, 4), \"/\").concat(day);\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n }\n } // Calculate check digit\n\n\n var checksum = 1101;\n var multip_lookup = [1, 6, 3, 7, 9, 10, 5, 8, 4, 2];\n\n for (var i = 0; i < tin.length - 1; i++) {\n checksum -= parseInt(tin[i], 10) * multip_lookup[i];\n }\n\n return parseInt(tin[10], 10) === checksum % 11;\n }\n\n return true;\n}\n/*\n * mt-MT validation function\n * (Identity Card Number or Unique Taxpayer Reference, persons/entities)\n * Verify Identity Card Number structure (no other tests found)\n */\n\n\nfunction mtMtCheck(tin) {\n if (tin.length !== 9) {\n // No tests for UTR\n var chars = tin.toUpperCase().split(''); // Fill with zeros if smaller than proper\n\n while (chars.length < 8) {\n chars.unshift(0);\n } // Validate format according to last character\n\n\n switch (tin[7]) {\n case 'A':\n case 'P':\n if (parseInt(chars[6], 10) === 0) {\n return false;\n }\n\n break;\n\n default:\n {\n var first_part = parseInt(chars.join('').slice(0, 5), 10);\n\n if (first_part > 32000) {\n return false;\n }\n\n var second_part = parseInt(chars.join('').slice(5, 7), 10);\n\n if (first_part === second_part) {\n return false;\n }\n }\n }\n }\n\n return true;\n}\n/*\n * nl-NL validation function\n * (Burgerservicenummer (BSN) or Rechtspersonen Samenwerkingsverbanden Informatie Nummer (RSIN),\n * persons/entities respectively)\n * Verify TIN validity by calculating check (last) digit (variant of MOD 11)\n */\n\n\nfunction nlNlCheck(tin) {\n return algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {\n return parseInt(a, 10);\n }), 9) % 11 === parseInt(tin[8], 10);\n}\n/*\n * pl-PL validation function\n * (Powszechny Elektroniczny System Ewidencji Ludności (PESEL)\n * or Numer identyfikacji podatkowej (NIP), persons/entities)\n * Verify TIN validity by validating birth date (PESEL) and calculating check (last) digit\n */\n\n\nfunction plPlCheck(tin) {\n // NIP\n if (tin.length === 10) {\n // Calculate last digit by multiplying with lookup\n var lookup = [6, 5, 7, 2, 3, 4, 5, 6, 7];\n var _checksum = 0;\n\n for (var i = 0; i < lookup.length; i++) {\n _checksum += parseInt(tin[i], 10) * lookup[i];\n }\n\n _checksum %= 11;\n\n if (_checksum === 10) {\n return false;\n }\n\n return _checksum === parseInt(tin[9], 10);\n } // PESEL\n // Extract full year using month\n\n\n var full_year = tin.slice(0, 2);\n var month = parseInt(tin.slice(2, 4), 10);\n\n if (month > 80) {\n full_year = \"18\".concat(full_year);\n month -= 80;\n } else if (month > 60) {\n full_year = \"22\".concat(full_year);\n month -= 60;\n } else if (month > 40) {\n full_year = \"21\".concat(full_year);\n month -= 40;\n } else if (month > 20) {\n full_year = \"20\".concat(full_year);\n month -= 20;\n } else {\n full_year = \"19\".concat(full_year);\n } // Add leading zero to month if needed\n\n\n if (month < 10) {\n month = \"0\".concat(month);\n } // Check date validity\n\n\n var date = \"\".concat(full_year, \"/\").concat(month, \"/\").concat(tin.slice(4, 6));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // Calculate last digit by mulitplying with odd one-digit numbers except 5\n\n\n var checksum = 0;\n var multiplier = 1;\n\n for (var _i7 = 0; _i7 < tin.length - 1; _i7++) {\n checksum += parseInt(tin[_i7], 10) * multiplier % 10;\n multiplier += 2;\n\n if (multiplier > 10) {\n multiplier = 1;\n } else if (multiplier === 5) {\n multiplier += 2;\n }\n }\n\n checksum = 10 - checksum % 10;\n return checksum === parseInt(tin[10], 10);\n}\n/*\n* pt-BR validation function\n* (Cadastro de Pessoas Físicas (CPF, persons)\n* Cadastro Nacional de Pessoas Jurídicas (CNPJ, entities)\n* Both inputs will be validated\n*/\n\n\nfunction ptBrCheck(tin) {\n if (tin.length === 11) {\n var _sum;\n\n var remainder;\n _sum = 0;\n if ( // Reject known invalid CPFs\n tin === '11111111111' || tin === '22222222222' || tin === '33333333333' || tin === '44444444444' || tin === '55555555555' || tin === '66666666666' || tin === '77777777777' || tin === '88888888888' || tin === '99999999999' || tin === '00000000000') return false;\n\n for (var i = 1; i <= 9; i++) {\n _sum += parseInt(tin.substring(i - 1, i), 10) * (11 - i);\n }\n\n remainder = _sum * 10 % 11;\n if (remainder === 10) remainder = 0;\n if (remainder !== parseInt(tin.substring(9, 10), 10)) return false;\n _sum = 0;\n\n for (var _i8 = 1; _i8 <= 10; _i8++) {\n _sum += parseInt(tin.substring(_i8 - 1, _i8), 10) * (12 - _i8);\n }\n\n remainder = _sum * 10 % 11;\n if (remainder === 10) remainder = 0;\n if (remainder !== parseInt(tin.substring(10, 11), 10)) return false;\n return true;\n }\n\n if ( // Reject know invalid CNPJs\n tin === '00000000000000' || tin === '11111111111111' || tin === '22222222222222' || tin === '33333333333333' || tin === '44444444444444' || tin === '55555555555555' || tin === '66666666666666' || tin === '77777777777777' || tin === '88888888888888' || tin === '99999999999999') {\n return false;\n }\n\n var length = tin.length - 2;\n var identifiers = tin.substring(0, length);\n var verificators = tin.substring(length);\n var sum = 0;\n var pos = length - 7;\n\n for (var _i9 = length; _i9 >= 1; _i9--) {\n sum += identifiers.charAt(length - _i9) * pos;\n pos -= 1;\n\n if (pos < 2) {\n pos = 9;\n }\n }\n\n var result = sum % 11 < 2 ? 0 : 11 - sum % 11;\n\n if (result !== parseInt(verificators.charAt(0), 10)) {\n return false;\n }\n\n length += 1;\n identifiers = tin.substring(0, length);\n sum = 0;\n pos = length - 7;\n\n for (var _i10 = length; _i10 >= 1; _i10--) {\n sum += identifiers.charAt(length - _i10) * pos;\n pos -= 1;\n\n if (pos < 2) {\n pos = 9;\n }\n }\n\n result = sum % 11 < 2 ? 0 : 11 - sum % 11;\n\n if (result !== parseInt(verificators.charAt(1), 10)) {\n return false;\n }\n\n return true;\n}\n/*\n * pt-PT validation function\n * (Número de identificação fiscal (NIF), persons/entities)\n * Verify TIN validity by calculating check (last) digit (variant of MOD 11)\n */\n\n\nfunction ptPtCheck(tin) {\n var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {\n return parseInt(a, 10);\n }), 9) % 11;\n\n if (checksum > 9) {\n return parseInt(tin[8], 10) === 0;\n }\n\n return checksum === parseInt(tin[8], 10);\n}\n/*\n * ro-RO validation function\n * (Cod Numeric Personal (CNP) or Cod de înregistrare fiscală (CIF),\n * persons only)\n * Verify CNP validity by calculating check (last) digit (test not found for CIF)\n * Material not in DG TAXUD document sourced from:\n * `https://en.wikipedia.org/wiki/National_identification_number#Romania`\n */\n\n\nfunction roRoCheck(tin) {\n if (tin.slice(0, 4) !== '9000') {\n // No test found for this format\n // Extract full year using century digit if possible\n var full_year = tin.slice(1, 3);\n\n switch (tin[0]) {\n case '1':\n case '2':\n full_year = \"19\".concat(full_year);\n break;\n\n case '3':\n case '4':\n full_year = \"18\".concat(full_year);\n break;\n\n case '5':\n case '6':\n full_year = \"20\".concat(full_year);\n break;\n\n default:\n } // Check date validity\n\n\n var date = \"\".concat(full_year, \"/\").concat(tin.slice(3, 5), \"/\").concat(tin.slice(5, 7));\n\n if (date.length === 8) {\n if (!(0, _isDate.default)(date, 'YY/MM/DD')) {\n return false;\n }\n } else if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n } // Calculate check digit\n\n\n var digits = tin.split('').map(function (a) {\n return parseInt(a, 10);\n });\n var multipliers = [2, 7, 9, 1, 4, 6, 3, 5, 8, 2, 7, 9];\n var checksum = 0;\n\n for (var i = 0; i < multipliers.length; i++) {\n checksum += digits[i] * multipliers[i];\n }\n\n if (checksum % 11 === 10) {\n return digits[12] === 1;\n }\n\n return digits[12] === checksum % 11;\n }\n\n return true;\n}\n/*\n * sk-SK validation function\n * (Rodné číslo (RČ) or bezvýznamové identifikačné číslo (BIČ), persons only)\n * Checks validity of pre-1954 birth numbers (rodné číslo) only\n * Due to the introduction of the pseudo-random BIČ it is not possible to test\n * post-1954 birth numbers without knowing whether they are BIČ or RČ beforehand\n */\n\n\nfunction skSkCheck(tin) {\n if (tin.length === 9) {\n tin = tin.replace(/\\W/, '');\n\n if (tin.slice(6) === '000') {\n return false;\n } // Three-zero serial not assigned before 1954\n // Extract full year from TIN length\n\n\n var full_year = parseInt(tin.slice(0, 2), 10);\n\n if (full_year > 53) {\n return false;\n }\n\n if (full_year < 10) {\n full_year = \"190\".concat(full_year);\n } else {\n full_year = \"19\".concat(full_year);\n } // Extract month from TIN and normalize\n\n\n var month = parseInt(tin.slice(2, 4), 10);\n\n if (month > 50) {\n month -= 50;\n }\n\n if (month < 10) {\n month = \"0\".concat(month);\n } // Check date validity\n\n\n var date = \"\".concat(full_year, \"/\").concat(month, \"/\").concat(tin.slice(4, 6));\n\n if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n }\n }\n\n return true;\n}\n/*\n * sl-SI validation function\n * (Davčna številka, persons/entities)\n * Verify TIN validity by calculating check (last) digit (variant of MOD 11)\n */\n\n\nfunction slSiCheck(tin) {\n var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {\n return parseInt(a, 10);\n }), 8) % 11;\n\n if (checksum === 10) {\n return parseInt(tin[7], 10) === 0;\n }\n\n return checksum === parseInt(tin[7], 10);\n}\n/*\n * sv-SE validation function\n * (Personnummer or samordningsnummer, persons only)\n * Checks validity of birth date and calls luhnCheck() to validate check (last) digit\n */\n\n\nfunction svSeCheck(tin) {\n // Make copy of TIN and normalize to two-digit year form\n var tin_copy = tin.slice(0);\n\n if (tin.length > 11) {\n tin_copy = tin_copy.slice(2);\n } // Extract date of birth\n\n\n var full_year = '';\n var month = tin_copy.slice(2, 4);\n var day = parseInt(tin_copy.slice(4, 6), 10);\n\n if (tin.length > 11) {\n full_year = tin.slice(0, 4);\n } else {\n full_year = tin.slice(0, 2);\n\n if (tin.length === 11 && day < 60) {\n // Extract full year from centenarian symbol\n // Should work just fine until year 10000 or so\n var current_year = new Date().getFullYear().toString();\n var current_century = parseInt(current_year.slice(0, 2), 10);\n current_year = parseInt(current_year, 10);\n\n if (tin[6] === '-') {\n if (parseInt(\"\".concat(current_century).concat(full_year), 10) > current_year) {\n full_year = \"\".concat(current_century - 1).concat(full_year);\n } else {\n full_year = \"\".concat(current_century).concat(full_year);\n }\n } else {\n full_year = \"\".concat(current_century - 1).concat(full_year);\n\n if (current_year - parseInt(full_year, 10) < 100) {\n return false;\n }\n }\n }\n } // Normalize day and check date validity\n\n\n if (day > 60) {\n day -= 60;\n }\n\n if (day < 10) {\n day = \"0\".concat(day);\n }\n\n var date = \"\".concat(full_year, \"/\").concat(month, \"/\").concat(day);\n\n if (date.length === 8) {\n if (!(0, _isDate.default)(date, 'YY/MM/DD')) {\n return false;\n }\n } else if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {\n return false;\n }\n\n return algorithms.luhnCheck(tin.replace(/\\W/, ''));\n} // Locale lookup objects\n\n/*\n * Tax id regex formats for various locales\n *\n * Where not explicitly specified in DG-TAXUD document both\n * uppercase and lowercase letters are acceptable.\n */\n\n\nvar taxIdFormat = {\n 'bg-BG': /^\\d{10}$/,\n 'cs-CZ': /^\\d{6}\\/{0,1}\\d{3,4}$/,\n 'de-AT': /^\\d{9}$/,\n 'de-DE': /^[1-9]\\d{10}$/,\n 'dk-DK': /^\\d{6}-{0,1}\\d{4}$/,\n 'el-CY': /^[09]\\d{7}[A-Z]$/,\n 'el-GR': /^([0-4]|[7-9])\\d{8}$/,\n 'en-CA': /^\\d{9}$/,\n 'en-GB': /^\\d{10}$|^(?!GB|NK|TN|ZZ)(?![DFIQUV])[A-Z](?![DFIQUVO])[A-Z]\\d{6}[ABCD ]$/i,\n 'en-IE': /^\\d{7}[A-W][A-IW]{0,1}$/i,\n 'en-US': /^\\d{2}[- ]{0,1}\\d{7}$/,\n 'es-ES': /^(\\d{0,8}|[XYZKLM]\\d{7})[A-HJ-NP-TV-Z]$/i,\n 'et-EE': /^[1-6]\\d{6}(00[1-9]|0[1-9][0-9]|[1-6][0-9]{2}|70[0-9]|710)\\d$/,\n 'fi-FI': /^\\d{6}[-+A]\\d{3}[0-9A-FHJ-NPR-Y]$/i,\n 'fr-BE': /^\\d{11}$/,\n 'fr-FR': /^[0-3]\\d{12}$|^[0-3]\\d\\s\\d{2}(\\s\\d{3}){3}$/,\n // Conforms both to official spec and provided example\n 'fr-LU': /^\\d{13}$/,\n 'hr-HR': /^\\d{11}$/,\n 'hu-HU': /^8\\d{9}$/,\n 'it-IT': /^[A-Z]{6}[L-NP-V0-9]{2}[A-EHLMPRST][L-NP-V0-9]{2}[A-ILMZ][L-NP-V0-9]{3}[A-Z]$/i,\n 'lv-LV': /^\\d{6}-{0,1}\\d{5}$/,\n // Conforms both to DG TAXUD spec and original research\n 'mt-MT': /^\\d{3,7}[APMGLHBZ]$|^([1-8])\\1\\d{7}$/i,\n 'nl-NL': /^\\d{9}$/,\n 'pl-PL': /^\\d{10,11}$/,\n 'pt-BR': /(?:^\\d{11}$)|(?:^\\d{14}$)/,\n 'pt-PT': /^\\d{9}$/,\n 'ro-RO': /^\\d{13}$/,\n 'sk-SK': /^\\d{6}\\/{0,1}\\d{3,4}$/,\n 'sl-SI': /^[1-9]\\d{7}$/,\n 'sv-SE': /^(\\d{6}[-+]{0,1}\\d{4}|(18|19|20)\\d{6}[-+]{0,1}\\d{4})$/\n}; // taxIdFormat locale aliases\n\ntaxIdFormat['lb-LU'] = taxIdFormat['fr-LU'];\ntaxIdFormat['lt-LT'] = taxIdFormat['et-EE'];\ntaxIdFormat['nl-BE'] = taxIdFormat['fr-BE'];\ntaxIdFormat['fr-CA'] = taxIdFormat['en-CA']; // Algorithmic tax id check functions for various locales\n\nvar taxIdCheck = {\n 'bg-BG': bgBgCheck,\n 'cs-CZ': csCzCheck,\n 'de-AT': deAtCheck,\n 'de-DE': deDeCheck,\n 'dk-DK': dkDkCheck,\n 'el-CY': elCyCheck,\n 'el-GR': elGrCheck,\n 'en-CA': isCanadianSIN,\n 'en-IE': enIeCheck,\n 'en-US': enUsCheck,\n 'es-ES': esEsCheck,\n 'et-EE': etEeCheck,\n 'fi-FI': fiFiCheck,\n 'fr-BE': frBeCheck,\n 'fr-FR': frFrCheck,\n 'fr-LU': frLuCheck,\n 'hr-HR': hrHrCheck,\n 'hu-HU': huHuCheck,\n 'it-IT': itItCheck,\n 'lv-LV': lvLvCheck,\n 'mt-MT': mtMtCheck,\n 'nl-NL': nlNlCheck,\n 'pl-PL': plPlCheck,\n 'pt-BR': ptBrCheck,\n 'pt-PT': ptPtCheck,\n 'ro-RO': roRoCheck,\n 'sk-SK': skSkCheck,\n 'sl-SI': slSiCheck,\n 'sv-SE': svSeCheck\n}; // taxIdCheck locale aliases\n\ntaxIdCheck['lb-LU'] = taxIdCheck['fr-LU'];\ntaxIdCheck['lt-LT'] = taxIdCheck['et-EE'];\ntaxIdCheck['nl-BE'] = taxIdCheck['fr-BE'];\ntaxIdCheck['fr-CA'] = taxIdCheck['en-CA']; // Regexes for locales where characters should be omitted before checking format\n\nvar allsymbols = /[-\\\\\\/!@#$%\\^&\\*\\(\\)\\+\\=\\[\\]]+/g;\nvar sanitizeRegexes = {\n 'de-AT': allsymbols,\n 'de-DE': /[\\/\\\\]/g,\n 'fr-BE': allsymbols\n}; // sanitizeRegexes locale aliases\n\nsanitizeRegexes['nl-BE'] = sanitizeRegexes['fr-BE'];\n/*\n * Validator function\n * Return true if the passed string is a valid tax identification number\n * for the specified locale.\n * Throw an error exception if the locale is not supported.\n */\n\nfunction isTaxID(str) {\n var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';\n (0, _assertString.default)(str); // Copy TIN to avoid replacement if sanitized\n\n var strcopy = str.slice(0);\n\n if (locale in taxIdFormat) {\n if (locale in sanitizeRegexes) {\n strcopy = strcopy.replace(sanitizeRegexes[locale], '');\n }\n\n if (!taxIdFormat[locale].test(strcopy)) {\n return false;\n }\n\n if (locale in taxIdCheck) {\n return taxIdCheck[locale](strcopy);\n } // Fallthrough; not all locales have algorithmic checks\n\n\n return true;\n }\n\n throw new Error(\"Invalid locale '\".concat(locale, \"'\"));\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMobilePhone;\nexports.locales = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* eslint-disable max-len */\nvar phones = {\n 'am-AM': /^(\\+?374|0)((10|[9|7][0-9])\\d{6}$|[2-4]\\d{7}$)/,\n 'ar-AE': /^((\\+?971)|0)?5[024568]\\d{7}$/,\n 'ar-BH': /^(\\+?973)?(3|6)\\d{7}$/,\n 'ar-DZ': /^(\\+?213|0)(5|6|7)\\d{8}$/,\n 'ar-LB': /^(\\+?961)?((3|81)\\d{6}|7\\d{7})$/,\n 'ar-EG': /^((\\+?20)|0)?1[0125]\\d{8}$/,\n 'ar-IQ': /^(\\+?964|0)?7[0-9]\\d{8}$/,\n 'ar-JO': /^(\\+?962|0)?7[789]\\d{7}$/,\n 'ar-KW': /^(\\+?965)([569]\\d{7}|41\\d{6})$/,\n 'ar-LY': /^((\\+?218)|0)?(9[1-6]\\d{7}|[1-8]\\d{7,9})$/,\n 'ar-MA': /^(?:(?:\\+|00)212|0)[5-7]\\d{8}$/,\n 'ar-OM': /^((\\+|00)968)?(9[1-9])\\d{6}$/,\n 'ar-PS': /^(\\+?970|0)5[6|9](\\d{7})$/,\n 'ar-SA': /^(!?(\\+?966)|0)?5\\d{8}$/,\n 'ar-SD': /^((\\+?249)|0)?(9[012369]|1[012])\\d{7}$/,\n 'ar-SY': /^(!?(\\+?963)|0)?9\\d{8}$/,\n 'ar-TN': /^(\\+?216)?[2459]\\d{7}$/,\n 'az-AZ': /^(\\+994|0)(10|5[015]|7[07]|99)\\d{7}$/,\n 'bs-BA': /^((((\\+|00)3876)|06))((([0-3]|[5-6])\\d{6})|(4\\d{7}))$/,\n 'be-BY': /^(\\+?375)?(24|25|29|33|44)\\d{7}$/,\n 'bg-BG': /^(\\+?359|0)?8[789]\\d{7}$/,\n 'bn-BD': /^(\\+?880|0)1[13456789][0-9]{8}$/,\n 'ca-AD': /^(\\+376)?[346]\\d{5}$/,\n 'cs-CZ': /^(\\+?420)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,\n 'da-DK': /^(\\+?45)?\\s?\\d{2}\\s?\\d{2}\\s?\\d{2}\\s?\\d{2}$/,\n 'de-DE': /^((\\+49|0)1)(5[0-25-9]\\d|6([23]|0\\d?)|7([0-57-9]|6\\d))\\d{7,9}$/,\n 'de-AT': /^(\\+43|0)\\d{1,4}\\d{3,12}$/,\n 'de-CH': /^(\\+41|0)([1-9])\\d{1,9}$/,\n 'de-LU': /^(\\+352)?((6\\d1)\\d{6})$/,\n 'dv-MV': /^(\\+?960)?(7[2-9]|9[1-9])\\d{5}$/,\n 'el-GR': /^(\\+?30|0)?6(8[5-9]|9(?![26])[0-9])\\d{7}$/,\n 'el-CY': /^(\\+?357?)?(9(9|6)\\d{6})$/,\n 'en-AI': /^(\\+?1|0)264(?:2(35|92)|4(?:6[1-2]|76|97)|5(?:3[6-9]|8[1-4])|7(?:2(4|9)|72))\\d{4}$/,\n 'en-AU': /^(\\+?61|0)4\\d{8}$/,\n 'en-AG': /^(?:\\+1|1)268(?:464|7(?:1[3-9]|[28]\\d|3[0246]|64|7[0-689]))\\d{4}$/,\n 'en-BM': /^(\\+?1)?441(((3|7)\\d{6}$)|(5[0-3][0-9]\\d{4}$)|(59\\d{5}$))/,\n 'en-BS': /^(\\+?1[-\\s]?|0)?\\(?242\\)?[-\\s]?\\d{3}[-\\s]?\\d{4}$/,\n 'en-GB': /^(\\+?44|0)7\\d{9}$/,\n 'en-GG': /^(\\+?44|0)1481\\d{6}$/,\n 'en-GH': /^(\\+233|0)(20|50|24|54|27|57|26|56|23|28|55|59)\\d{7}$/,\n 'en-GY': /^(\\+592|0)6\\d{6}$/,\n 'en-HK': /^(\\+?852[-\\s]?)?[456789]\\d{3}[-\\s]?\\d{4}$/,\n 'en-MO': /^(\\+?853[-\\s]?)?[6]\\d{3}[-\\s]?\\d{4}$/,\n 'en-IE': /^(\\+?353|0)8[356789]\\d{7}$/,\n 'en-IN': /^(\\+?91|0)?[6789]\\d{9}$/,\n 'en-JM': /^(\\+?876)?\\d{7}$/,\n 'en-KE': /^(\\+?254|0)(7|1)\\d{8}$/,\n 'fr-CF': /^(\\+?236| ?)(70|75|77|72|21|22)\\d{6}$/,\n 'en-SS': /^(\\+?211|0)(9[1257])\\d{7}$/,\n 'en-KI': /^((\\+686|686)?)?( )?((6|7)(2|3|8)[0-9]{6})$/,\n 'en-KN': /^(?:\\+1|1)869(?:46\\d|48[89]|55[6-8]|66\\d|76[02-7])\\d{4}$/,\n 'en-LS': /^(\\+?266)(22|28|57|58|59|27|52)\\d{6}$/,\n 'en-MT': /^(\\+?356|0)?(99|79|77|21|27|22|25)[0-9]{6}$/,\n 'en-MU': /^(\\+?230|0)?\\d{8}$/,\n 'en-NA': /^(\\+?264|0)(6|8)\\d{7}$/,\n 'en-NG': /^(\\+?234|0)?[789]\\d{9}$/,\n 'en-NZ': /^(\\+?64|0)[28]\\d{7,9}$/,\n 'en-PG': /^(\\+?675|0)?(7\\d|8[18])\\d{6}$/,\n 'en-PK': /^((00|\\+)?92|0)3[0-6]\\d{8}$/,\n 'en-PH': /^(09|\\+639)\\d{9}$/,\n 'en-RW': /^(\\+?250|0)?[7]\\d{8}$/,\n 'en-SG': /^(\\+65)?[3689]\\d{7}$/,\n 'en-SL': /^(\\+?232|0)\\d{8}$/,\n 'en-TZ': /^(\\+?255|0)?[67]\\d{8}$/,\n 'en-UG': /^(\\+?256|0)?[7]\\d{8}$/,\n 'en-US': /^((\\+1|1)?( |-)?)?(\\([2-9][0-9]{2}\\)|[2-9][0-9]{2})( |-)?([2-9][0-9]{2}( |-)?[0-9]{4})$/,\n 'en-ZA': /^(\\+?27|0)\\d{9}$/,\n 'en-ZM': /^(\\+?26)?09[567]\\d{7}$/,\n 'en-ZW': /^(\\+263)[0-9]{9}$/,\n 'en-BW': /^(\\+?267)?(7[1-8]{1})\\d{6}$/,\n 'es-AR': /^\\+?549(11|[2368]\\d)\\d{8}$/,\n 'es-BO': /^(\\+?591)?(6|7)\\d{7}$/,\n 'es-CO': /^(\\+?57)?3(0(0|1|2|4|5)|1\\d|2[0-4]|5(0|1))\\d{7}$/,\n 'es-CL': /^(\\+?56|0)[2-9]\\d{1}\\d{7}$/,\n 'es-CR': /^(\\+506)?[2-8]\\d{7}$/,\n 'es-CU': /^(\\+53|0053)?5\\d{7}$/,\n 'es-DO': /^(\\+?1)?8[024]9\\d{7}$/,\n 'es-HN': /^(\\+?504)?[9|8|3|2]\\d{7}$/,\n 'es-EC': /^(\\+?593|0)([2-7]|9[2-9])\\d{7}$/,\n 'es-ES': /^(\\+?34)?[6|7]\\d{8}$/,\n 'es-PE': /^(\\+?51)?9\\d{8}$/,\n 'es-MX': /^(\\+?52)?(1|01)?\\d{10,11}$/,\n 'es-NI': /^(\\+?505)\\d{7,8}$/,\n 'es-PA': /^(\\+?507)\\d{7,8}$/,\n 'es-PY': /^(\\+?595|0)9[9876]\\d{7}$/,\n 'es-SV': /^(\\+?503)?[67]\\d{7}$/,\n 'es-UY': /^(\\+598|0)9[1-9][\\d]{6}$/,\n 'es-VE': /^(\\+?58)?(2|4)\\d{9}$/,\n 'et-EE': /^(\\+?372)?\\s?(5|8[1-4])\\s?([0-9]\\s?){6,7}$/,\n 'fa-IR': /^(\\+?98[\\-\\s]?|0)9[0-39]\\d[\\-\\s]?\\d{3}[\\-\\s]?\\d{4}$/,\n 'fi-FI': /^(\\+?358|0)\\s?(4[0-6]|50)\\s?(\\d\\s?){4,8}$/,\n 'fj-FJ': /^(\\+?679)?\\s?\\d{3}\\s?\\d{4}$/,\n 'fo-FO': /^(\\+?298)?\\s?\\d{2}\\s?\\d{2}\\s?\\d{2}$/,\n 'fr-BF': /^(\\+226|0)[67]\\d{7}$/,\n 'fr-BJ': /^(\\+229)\\d{8}$/,\n 'fr-CD': /^(\\+?243|0)?(8|9)\\d{8}$/,\n 'fr-CM': /^(\\+?237)6[0-9]{8}$/,\n 'fr-FR': /^(\\+?33|0)[67]\\d{8}$/,\n 'fr-GF': /^(\\+?594|0|00594)[67]\\d{8}$/,\n 'fr-GP': /^(\\+?590|0|00590)[67]\\d{8}$/,\n 'fr-MQ': /^(\\+?596|0|00596)[67]\\d{8}$/,\n 'fr-PF': /^(\\+?689)?8[789]\\d{6}$/,\n 'fr-RE': /^(\\+?262|0|00262)[67]\\d{8}$/,\n 'fr-WF': /^(\\+681)?\\d{6}$/,\n 'he-IL': /^(\\+972|0)([23489]|5[012345689]|77)[1-9]\\d{6}$/,\n 'hu-HU': /^(\\+?36|06)(20|30|31|50|70)\\d{7}$/,\n 'id-ID': /^(\\+?62|0)8(1[123456789]|2[1238]|3[1238]|5[12356789]|7[78]|9[56789]|8[123456789])([\\s?|\\d]{5,11})$/,\n 'ir-IR': /^(\\+98|0)?9\\d{9}$/,\n 'it-IT': /^(\\+?39)?\\s?3\\d{2} ?\\d{6,7}$/,\n 'it-SM': /^((\\+378)|(0549)|(\\+390549)|(\\+3780549))?6\\d{5,9}$/,\n 'ja-JP': /^(\\+81[ \\-]?(\\(0\\))?|0)[6789]0[ \\-]?\\d{4}[ \\-]?\\d{4}$/,\n 'ka-GE': /^(\\+?995)?(79\\d{7}|5\\d{8})$/,\n 'kk-KZ': /^(\\+?7|8)?7\\d{9}$/,\n 'kl-GL': /^(\\+?299)?\\s?\\d{2}\\s?\\d{2}\\s?\\d{2}$/,\n 'ko-KR': /^((\\+?82)[ \\-]?)?0?1([0|1|6|7|8|9]{1})[ \\-]?\\d{3,4}[ \\-]?\\d{4}$/,\n 'ky-KG': /^(\\+?7\\s?\\+?7|0)\\s?\\d{2}\\s?\\d{3}\\s?\\d{4}$/,\n 'lt-LT': /^(\\+370|8)\\d{8}$/,\n 'lv-LV': /^(\\+?371)2\\d{7}$/,\n 'mg-MG': /^((\\+?261|0)(2|3)\\d)?\\d{7}$/,\n 'mn-MN': /^(\\+|00|011)?976(77|81|88|91|94|95|96|99)\\d{6}$/,\n 'my-MM': /^(\\+?959|09|9)(2[5-7]|3[1-2]|4[0-5]|6[6-9]|7[5-9]|9[6-9])[0-9]{7}$/,\n 'ms-MY': /^(\\+?60|0)1(([0145](-|\\s)?\\d{7,8})|([236-9](-|\\s)?\\d{7}))$/,\n 'mz-MZ': /^(\\+?258)?8[234567]\\d{7}$/,\n 'nb-NO': /^(\\+?47)?[49]\\d{7}$/,\n 'ne-NP': /^(\\+?977)?9[78]\\d{8}$/,\n 'nl-BE': /^(\\+?32|0)4\\d{8}$/,\n 'nl-NL': /^(((\\+|00)?31\\(0\\))|((\\+|00)?31)|0)6{1}\\d{8}$/,\n 'nl-AW': /^(\\+)?297(56|59|64|73|74|99)\\d{5}$/,\n 'nn-NO': /^(\\+?47)?[49]\\d{7}$/,\n 'pl-PL': /^(\\+?48)? ?([5-8]\\d|45) ?\\d{3} ?\\d{2} ?\\d{2}$/,\n 'pt-BR': /^((\\+?55\\ ?[1-9]{2}\\ ?)|(\\+?55\\ ?\\([1-9]{2}\\)\\ ?)|(0[1-9]{2}\\ ?)|(\\([1-9]{2}\\)\\ ?)|([1-9]{2}\\ ?))((\\d{4}\\-?\\d{4})|(9[1-9]{1}\\d{3}\\-?\\d{4}))$/,\n 'pt-PT': /^(\\+?351)?9[1236]\\d{7}$/,\n 'pt-AO': /^(\\+244)\\d{9}$/,\n 'ro-MD': /^(\\+?373|0)((6(0|1|2|6|7|8|9))|(7(6|7|8|9)))\\d{6}$/,\n 'ro-RO': /^(\\+?40|0)\\s?7\\d{2}(\\/|\\s|\\.|-)?\\d{3}(\\s|\\.|-)?\\d{3}$/,\n 'ru-RU': /^(\\+?7|8)?9\\d{9}$/,\n 'si-LK': /^(?:0|94|\\+94)?(7(0|1|2|4|5|6|7|8)( |-)?)\\d{7}$/,\n 'sl-SI': /^(\\+386\\s?|0)(\\d{1}\\s?\\d{3}\\s?\\d{2}\\s?\\d{2}|\\d{2}\\s?\\d{3}\\s?\\d{3})$/,\n 'sk-SK': /^(\\+?421)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,\n 'so-SO': /^(\\+?252|0)((6[0-9])\\d{7}|(7[1-9])\\d{7})$/,\n 'sq-AL': /^(\\+355|0)6[789]\\d{6}$/,\n 'sr-RS': /^(\\+3816|06)[- \\d]{5,9}$/,\n 'sv-SE': /^(\\+?46|0)[\\s\\-]?7[\\s\\-]?[02369]([\\s\\-]?\\d){7}$/,\n 'tg-TJ': /^(\\+?992)?[5][5]\\d{7}$/,\n 'th-TH': /^(\\+66|66|0)\\d{9}$/,\n 'tr-TR': /^(\\+?90|0)?5\\d{9}$/,\n 'tk-TM': /^(\\+993|993|8)\\d{8}$/,\n 'uk-UA': /^(\\+?38|8)?0\\d{9}$/,\n 'uz-UZ': /^(\\+?998)?(6[125-79]|7[1-69]|88|9\\d)\\d{7}$/,\n 'vi-VN': /^((\\+?84)|0)((3([2-9]))|(5([25689]))|(7([0|6-9]))|(8([1-9]))|(9([0-9])))([0-9]{7})$/,\n 'zh-CN': /^((\\+|00)86)?(1[3-9]|9[28])\\d{9}$/,\n 'zh-TW': /^(\\+?886\\-?|0)?9\\d{8}$/,\n 'dz-BT': /^(\\+?975|0)?(17|16|77|02)\\d{6}$/,\n 'ar-YE': /^(((\\+|00)9677|0?7)[0137]\\d{7}|((\\+|00)967|0)[1-7]\\d{6})$/,\n 'ar-EH': /^(\\+?212|0)[\\s\\-]?(5288|5289)[\\s\\-]?\\d{5}$/,\n 'fa-AF': /^(\\+93|0)?(2{1}[0-8]{1}|[3-5]{1}[0-4]{1})(\\d{7})$/\n};\n/* eslint-enable max-len */\n// aliases\n\nphones['en-CA'] = phones['en-US'];\nphones['fr-CA'] = phones['en-CA'];\nphones['fr-BE'] = phones['nl-BE'];\nphones['zh-HK'] = phones['en-HK'];\nphones['zh-MO'] = phones['en-MO'];\nphones['ga-IE'] = phones['en-IE'];\nphones['fr-CH'] = phones['de-CH'];\nphones['it-CH'] = phones['fr-CH'];\n\nfunction isMobilePhone(str, locale, options) {\n (0, _assertString.default)(str);\n\n if (options && options.strictMode && !str.startsWith('+')) {\n return false;\n }\n\n if (Array.isArray(locale)) {\n return locale.some(function (key) {\n // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes\n // istanbul ignore else\n if (phones.hasOwnProperty(key)) {\n var phone = phones[key];\n\n if (phone.test(str)) {\n return true;\n }\n }\n\n return false;\n });\n } else if (locale in phones) {\n return phones[locale].test(str); // alias falsey locale as 'any'\n } else if (!locale || locale === 'any') {\n for (var key in phones) {\n // istanbul ignore else\n if (phones.hasOwnProperty(key)) {\n var phone = phones[key];\n\n if (phone.test(str)) {\n return true;\n }\n }\n }\n\n return false;\n }\n\n throw new Error(\"Invalid locale '\".concat(locale, \"'\"));\n}\n\nvar locales = Object.keys(phones);\nexports.locales = locales;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isEthereumAddress;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar eth = /^(0x)[0-9a-f]{40}$/i;\n\nfunction isEthereumAddress(str) {\n (0, _assertString.default)(str);\n return eth.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isCurrency;\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction currencyRegex(options) {\n var decimal_digits = \"\\\\d{\".concat(options.digits_after_decimal[0], \"}\");\n options.digits_after_decimal.forEach(function (digit, index) {\n if (index !== 0) decimal_digits = \"\".concat(decimal_digits, \"|\\\\d{\").concat(digit, \"}\");\n });\n var symbol = \"(\".concat(options.symbol.replace(/\\W/, function (m) {\n return \"\\\\\".concat(m);\n }), \")\").concat(options.require_symbol ? '' : '?'),\n negative = '-?',\n whole_dollar_amount_without_sep = '[1-9]\\\\d*',\n whole_dollar_amount_with_sep = \"[1-9]\\\\d{0,2}(\\\\\".concat(options.thousands_separator, \"\\\\d{3})*\"),\n valid_whole_dollar_amounts = ['0', whole_dollar_amount_without_sep, whole_dollar_amount_with_sep],\n whole_dollar_amount = \"(\".concat(valid_whole_dollar_amounts.join('|'), \")?\"),\n decimal_amount = \"(\\\\\".concat(options.decimal_separator, \"(\").concat(decimal_digits, \"))\").concat(options.require_decimal ? '' : '?');\n var pattern = whole_dollar_amount + (options.allow_decimal || options.require_decimal ? decimal_amount : ''); // default is negative sign before symbol, but there are two other options (besides parens)\n\n if (options.allow_negatives && !options.parens_for_negatives) {\n if (options.negative_sign_after_digits) {\n pattern += negative;\n } else if (options.negative_sign_before_digits) {\n pattern = negative + pattern;\n }\n } // South African Rand, for example, uses R 123 (space) and R-123 (no space)\n\n\n if (options.allow_negative_sign_placeholder) {\n pattern = \"( (?!\\\\-))?\".concat(pattern);\n } else if (options.allow_space_after_symbol) {\n pattern = \" ?\".concat(pattern);\n } else if (options.allow_space_after_digits) {\n pattern += '( (?!$))?';\n }\n\n if (options.symbol_after_digits) {\n pattern += symbol;\n } else {\n pattern = symbol + pattern;\n }\n\n if (options.allow_negatives) {\n if (options.parens_for_negatives) {\n pattern = \"(\\\\(\".concat(pattern, \"\\\\)|\").concat(pattern, \")\");\n } else if (!(options.negative_sign_before_digits || options.negative_sign_after_digits)) {\n pattern = negative + pattern;\n }\n } // ensure there's a dollar and/or decimal amount, and that\n // it doesn't start with a space or a negative sign followed by a space\n\n\n return new RegExp(\"^(?!-? )(?=.*\\\\d)\".concat(pattern, \"$\"));\n}\n\nvar default_currency_options = {\n symbol: '$',\n require_symbol: false,\n allow_space_after_symbol: false,\n symbol_after_digits: false,\n allow_negatives: true,\n parens_for_negatives: false,\n negative_sign_before_digits: false,\n negative_sign_after_digits: false,\n allow_negative_sign_placeholder: false,\n thousands_separator: ',',\n decimal_separator: '.',\n allow_decimal: true,\n require_decimal: false,\n digits_after_decimal: [2],\n allow_space_after_digits: false\n};\n\nfunction isCurrency(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, default_currency_options);\n return currencyRegex(options).test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isBtcAddress;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar bech32 = /^(bc1)[a-z0-9]{25,39}$/;\nvar base58 = /^(1|3)[A-HJ-NP-Za-km-z1-9]{25,39}$/;\n\nfunction isBtcAddress(str) {\n (0, _assertString.default)(str);\n return bech32.test(str) || base58.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isISO6346 = isISO6346;\nexports.isFreightContainerID = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// https://en.wikipedia.org/wiki/ISO_6346\n// according to ISO6346 standard, checksum digit is mandatory for freight container but recommended\n// for other container types (J and Z)\nvar isISO6346Str = /^[A-Z]{3}(U[0-9]{7})|([J,Z][0-9]{6,7})$/;\nvar isDigit = /^[0-9]$/;\n\nfunction isISO6346(str) {\n (0, _assertString.default)(str);\n str = str.toUpperCase();\n if (!isISO6346Str.test(str)) return false;\n\n if (str.length === 11) {\n var sum = 0;\n\n for (var i = 0; i < str.length - 1; i++) {\n if (!isDigit.test(str[i])) {\n var convertedCode = void 0;\n var letterCode = str.charCodeAt(i) - 55;\n if (letterCode < 11) convertedCode = letterCode;else if (letterCode >= 11 && letterCode <= 20) convertedCode = 12 + letterCode % 11;else if (letterCode >= 21 && letterCode <= 30) convertedCode = 23 + letterCode % 21;else convertedCode = 34 + letterCode % 31;\n sum += convertedCode * Math.pow(2, i);\n } else sum += str[i] * Math.pow(2, i);\n }\n\n var checkSumDigit = sum % 11;\n return Number(str[str.length - 1]) === checkSumDigit;\n }\n\n return true;\n}\n\nvar isFreightContainerID = isISO6346;\nexports.isFreightContainerID = isFreightContainerID;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISO6391;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar isISO6391Set = new Set(['aa', 'ab', 'ae', 'af', 'ak', 'am', 'an', 'ar', 'as', 'av', 'ay', 'az', 'az', 'ba', 'be', 'bg', 'bh', 'bi', 'bm', 'bn', 'bo', 'br', 'bs', 'ca', 'ce', 'ch', 'co', 'cr', 'cs', 'cu', 'cv', 'cy', 'da', 'de', 'dv', 'dz', 'ee', 'el', 'en', 'eo', 'es', 'et', 'eu', 'fa', 'ff', 'fi', 'fj', 'fo', 'fr', 'fy', 'ga', 'gd', 'gl', 'gn', 'gu', 'gv', 'ha', 'he', 'hi', 'ho', 'hr', 'ht', 'hu', 'hy', 'hz', 'ia', 'id', 'ie', 'ig', 'ii', 'ik', 'io', 'is', 'it', 'iu', 'ja', 'jv', 'ka', 'kg', 'ki', 'kj', 'kk', 'kl', 'km', 'kn', 'ko', 'kr', 'ks', 'ku', 'kv', 'kw', 'ky', 'la', 'lb', 'lg', 'li', 'ln', 'lo', 'lt', 'lu', 'lv', 'mg', 'mh', 'mi', 'mk', 'ml', 'mn', 'mr', 'ms', 'mt', 'my', 'na', 'nb', 'nd', 'ne', 'ng', 'nl', 'nn', 'no', 'nr', 'nv', 'ny', 'oc', 'oj', 'om', 'or', 'os', 'pa', 'pi', 'pl', 'ps', 'pt', 'qu', 'rm', 'rn', 'ro', 'ru', 'rw', 'sa', 'sc', 'sd', 'se', 'sg', 'si', 'sk', 'sl', 'sm', 'sn', 'so', 'sq', 'sr', 'ss', 'st', 'su', 'sv', 'sw', 'ta', 'te', 'tg', 'th', 'ti', 'tk', 'tl', 'tn', 'to', 'tr', 'ts', 'tt', 'tw', 'ty', 'ug', 'uk', 'ur', 'uz', 've', 'vi', 'vo', 'wa', 'wo', 'xh', 'yi', 'yo', 'za', 'zh', 'zu']);\n\nfunction isISO6391(str) {\n (0, _assertString.default)(str);\n return isISO6391Set.has(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISO8601;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* eslint-disable max-len */\n// from http://goo.gl/0ejHHW\nvar iso8601 = /^([\\+-]?\\d{4}(?!\\d{2}\\b))((-?)((0[1-9]|1[0-2])(\\3([12]\\d|0[1-9]|3[01]))?|W([0-4]\\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\\d|[12]\\d{2}|3([0-5]\\d|6[1-6])))([T\\s]((([01]\\d|2[0-3])((:?)[0-5]\\d)?|24:?00)([\\.,]\\d+(?!:))?)?(\\17[0-5]\\d([\\.,]\\d+)?)?([zZ]|([\\+-])([01]\\d|2[0-3]):?([0-5]\\d)?)?)?)?$/; // same as above, except with a strict 'T' separator between date and time\n\nvar iso8601StrictSeparator = /^([\\+-]?\\d{4}(?!\\d{2}\\b))((-?)((0[1-9]|1[0-2])(\\3([12]\\d|0[1-9]|3[01]))?|W([0-4]\\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\\d|[12]\\d{2}|3([0-5]\\d|6[1-6])))([T]((([01]\\d|2[0-3])((:?)[0-5]\\d)?|24:?00)([\\.,]\\d+(?!:))?)?(\\17[0-5]\\d([\\.,]\\d+)?)?([zZ]|([\\+-])([01]\\d|2[0-3]):?([0-5]\\d)?)?)?)?$/;\n/* eslint-enable max-len */\n\nvar isValidDate = function isValidDate(str) {\n // str must have passed the ISO8601 check\n // this check is meant to catch invalid dates\n // like 2009-02-31\n // first check for ordinal dates\n var ordinalMatch = str.match(/^(\\d{4})-?(\\d{3})([ T]{1}\\.*|$)/);\n\n if (ordinalMatch) {\n var oYear = Number(ordinalMatch[1]);\n var oDay = Number(ordinalMatch[2]); // if is leap year\n\n if (oYear % 4 === 0 && oYear % 100 !== 0 || oYear % 400 === 0) return oDay <= 366;\n return oDay <= 365;\n }\n\n var match = str.match(/(\\d{4})-?(\\d{0,2})-?(\\d*)/).map(Number);\n var year = match[1];\n var month = match[2];\n var day = match[3];\n var monthString = month ? \"0\".concat(month).slice(-2) : month;\n var dayString = day ? \"0\".concat(day).slice(-2) : day; // create a date object and compare\n\n var d = new Date(\"\".concat(year, \"-\").concat(monthString || '01', \"-\").concat(dayString || '01'));\n\n if (month && day) {\n return d.getUTCFullYear() === year && d.getUTCMonth() + 1 === month && d.getUTCDate() === day;\n }\n\n return true;\n};\n\nfunction isISO8601(str) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n (0, _assertString.default)(str);\n var check = options.strictSeparator ? iso8601StrictSeparator.test(str) : iso8601.test(str);\n if (check && options.strict) return isValidDate(str);\n return check;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isRFC3339;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* Based on https://tools.ietf.org/html/rfc3339#section-5.6 */\nvar dateFullYear = /[0-9]{4}/;\nvar dateMonth = /(0[1-9]|1[0-2])/;\nvar dateMDay = /([12]\\d|0[1-9]|3[01])/;\nvar timeHour = /([01][0-9]|2[0-3])/;\nvar timeMinute = /[0-5][0-9]/;\nvar timeSecond = /([0-5][0-9]|60)/;\nvar timeSecFrac = /(\\.[0-9]+)?/;\nvar timeNumOffset = new RegExp(\"[-+]\".concat(timeHour.source, \":\").concat(timeMinute.source));\nvar timeOffset = new RegExp(\"([zZ]|\".concat(timeNumOffset.source, \")\"));\nvar partialTime = new RegExp(\"\".concat(timeHour.source, \":\").concat(timeMinute.source, \":\").concat(timeSecond.source).concat(timeSecFrac.source));\nvar fullDate = new RegExp(\"\".concat(dateFullYear.source, \"-\").concat(dateMonth.source, \"-\").concat(dateMDay.source));\nvar fullTime = new RegExp(\"\".concat(partialTime.source).concat(timeOffset.source));\nvar rfc3339 = new RegExp(\"^\".concat(fullDate.source, \"[ tT]\").concat(fullTime.source, \"$\"));\n\nfunction isRFC3339(str) {\n (0, _assertString.default)(str);\n return rfc3339.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISO31661Alpha3;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// from https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3\nvar validISO31661Alpha3CountriesCodes = new Set(['AFG', 'ALA', 'ALB', 'DZA', 'ASM', 'AND', 'AGO', 'AIA', 'ATA', 'ATG', 'ARG', 'ARM', 'ABW', 'AUS', 'AUT', 'AZE', 'BHS', 'BHR', 'BGD', 'BRB', 'BLR', 'BEL', 'BLZ', 'BEN', 'BMU', 'BTN', 'BOL', 'BES', 'BIH', 'BWA', 'BVT', 'BRA', 'IOT', 'BRN', 'BGR', 'BFA', 'BDI', 'KHM', 'CMR', 'CAN', 'CPV', 'CYM', 'CAF', 'TCD', 'CHL', 'CHN', 'CXR', 'CCK', 'COL', 'COM', 'COG', 'COD', 'COK', 'CRI', 'CIV', 'HRV', 'CUB', 'CUW', 'CYP', 'CZE', 'DNK', 'DJI', 'DMA', 'DOM', 'ECU', 'EGY', 'SLV', 'GNQ', 'ERI', 'EST', 'ETH', 'FLK', 'FRO', 'FJI', 'FIN', 'FRA', 'GUF', 'PYF', 'ATF', 'GAB', 'GMB', 'GEO', 'DEU', 'GHA', 'GIB', 'GRC', 'GRL', 'GRD', 'GLP', 'GUM', 'GTM', 'GGY', 'GIN', 'GNB', 'GUY', 'HTI', 'HMD', 'VAT', 'HND', 'HKG', 'HUN', 'ISL', 'IND', 'IDN', 'IRN', 'IRQ', 'IRL', 'IMN', 'ISR', 'ITA', 'JAM', 'JPN', 'JEY', 'JOR', 'KAZ', 'KEN', 'KIR', 'PRK', 'KOR', 'KWT', 'KGZ', 'LAO', 'LVA', 'LBN', 'LSO', 'LBR', 'LBY', 'LIE', 'LTU', 'LUX', 'MAC', 'MKD', 'MDG', 'MWI', 'MYS', 'MDV', 'MLI', 'MLT', 'MHL', 'MTQ', 'MRT', 'MUS', 'MYT', 'MEX', 'FSM', 'MDA', 'MCO', 'MNG', 'MNE', 'MSR', 'MAR', 'MOZ', 'MMR', 'NAM', 'NRU', 'NPL', 'NLD', 'NCL', 'NZL', 'NIC', 'NER', 'NGA', 'NIU', 'NFK', 'MNP', 'NOR', 'OMN', 'PAK', 'PLW', 'PSE', 'PAN', 'PNG', 'PRY', 'PER', 'PHL', 'PCN', 'POL', 'PRT', 'PRI', 'QAT', 'REU', 'ROU', 'RUS', 'RWA', 'BLM', 'SHN', 'KNA', 'LCA', 'MAF', 'SPM', 'VCT', 'WSM', 'SMR', 'STP', 'SAU', 'SEN', 'SRB', 'SYC', 'SLE', 'SGP', 'SXM', 'SVK', 'SVN', 'SLB', 'SOM', 'ZAF', 'SGS', 'SSD', 'ESP', 'LKA', 'SDN', 'SUR', 'SJM', 'SWZ', 'SWE', 'CHE', 'SYR', 'TWN', 'TJK', 'TZA', 'THA', 'TLS', 'TGO', 'TKL', 'TON', 'TTO', 'TUN', 'TUR', 'TKM', 'TCA', 'TUV', 'UGA', 'UKR', 'ARE', 'GBR', 'USA', 'UMI', 'URY', 'UZB', 'VUT', 'VEN', 'VNM', 'VGB', 'VIR', 'WLF', 'ESH', 'YEM', 'ZMB', 'ZWE']);\n\nfunction isISO31661Alpha3(str) {\n (0, _assertString.default)(str);\n return validISO31661Alpha3CountriesCodes.has(str.toUpperCase());\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isISO4217;\nexports.CurrencyCodes = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// from https://en.wikipedia.org/wiki/ISO_4217\nvar validISO4217CurrencyCodes = new Set(['AED', 'AFN', 'ALL', 'AMD', 'ANG', 'AOA', 'ARS', 'AUD', 'AWG', 'AZN', 'BAM', 'BBD', 'BDT', 'BGN', 'BHD', 'BIF', 'BMD', 'BND', 'BOB', 'BOV', 'BRL', 'BSD', 'BTN', 'BWP', 'BYN', 'BZD', 'CAD', 'CDF', 'CHE', 'CHF', 'CHW', 'CLF', 'CLP', 'CNY', 'COP', 'COU', 'CRC', 'CUC', 'CUP', 'CVE', 'CZK', 'DJF', 'DKK', 'DOP', 'DZD', 'EGP', 'ERN', 'ETB', 'EUR', 'FJD', 'FKP', 'GBP', 'GEL', 'GHS', 'GIP', 'GMD', 'GNF', 'GTQ', 'GYD', 'HKD', 'HNL', 'HRK', 'HTG', 'HUF', 'IDR', 'ILS', 'INR', 'IQD', 'IRR', 'ISK', 'JMD', 'JOD', 'JPY', 'KES', 'KGS', 'KHR', 'KMF', 'KPW', 'KRW', 'KWD', 'KYD', 'KZT', 'LAK', 'LBP', 'LKR', 'LRD', 'LSL', 'LYD', 'MAD', 'MDL', 'MGA', 'MKD', 'MMK', 'MNT', 'MOP', 'MRU', 'MUR', 'MVR', 'MWK', 'MXN', 'MXV', 'MYR', 'MZN', 'NAD', 'NGN', 'NIO', 'NOK', 'NPR', 'NZD', 'OMR', 'PAB', 'PEN', 'PGK', 'PHP', 'PKR', 'PLN', 'PYG', 'QAR', 'RON', 'RSD', 'RUB', 'RWF', 'SAR', 'SBD', 'SCR', 'SDG', 'SEK', 'SGD', 'SHP', 'SLL', 'SOS', 'SRD', 'SSP', 'STN', 'SVC', 'SYP', 'SZL', 'THB', 'TJS', 'TMT', 'TND', 'TOP', 'TRY', 'TTD', 'TWD', 'TZS', 'UAH', 'UGX', 'USD', 'USN', 'UYI', 'UYU', 'UYW', 'UZS', 'VES', 'VND', 'VUV', 'WST', 'XAF', 'XAG', 'XAU', 'XBA', 'XBB', 'XBC', 'XBD', 'XCD', 'XDR', 'XOF', 'XPD', 'XPF', 'XPT', 'XSU', 'XTS', 'XUA', 'XXX', 'YER', 'ZAR', 'ZMW', 'ZWL']);\n\nfunction isISO4217(str) {\n (0, _assertString.default)(str);\n return validISO4217CurrencyCodes.has(str.toUpperCase());\n}\n\nvar CurrencyCodes = validISO4217CurrencyCodes;\nexports.CurrencyCodes = CurrencyCodes;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isBase32;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar base32 = /^[A-Z2-7]+=*$/;\nvar crockfordBase32 = /^[A-HJKMNP-TV-Z0-9]+$/;\nvar defaultBase32Options = {\n crockford: false\n};\n\nfunction isBase32(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, defaultBase32Options);\n\n if (options.crockford) {\n return crockfordBase32.test(str);\n }\n\n var len = str.length;\n\n if (len % 8 === 0 && base32.test(str)) {\n return true;\n }\n\n return false;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isBase58;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// Accepted chars - 123456789ABCDEFGH JKLMN PQRSTUVWXYZabcdefghijk mnopqrstuvwxyz\nvar base58Reg = /^[A-HJ-NP-Za-km-z1-9]*$/;\n\nfunction isBase58(str) {\n (0, _assertString.default)(str);\n\n if (base58Reg.test(str)) {\n return true;\n }\n\n return false;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isDataURI;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar validMediaType = /^[a-z]+\\/[a-z0-9\\-\\+\\._]+$/i;\nvar validAttribute = /^[a-z\\-]+=[a-z0-9\\-]+$/i;\nvar validData = /^[a-z0-9!\\$&'\\(\\)\\*\\+,;=\\-\\._~:@\\/\\?%\\s]*$/i;\n\nfunction isDataURI(str) {\n (0, _assertString.default)(str);\n var data = str.split(',');\n\n if (data.length < 2) {\n return false;\n }\n\n var attributes = data.shift().trim().split(';');\n var schemeAndMediaType = attributes.shift();\n\n if (schemeAndMediaType.slice(0, 5) !== 'data:') {\n return false;\n }\n\n var mediaType = schemeAndMediaType.slice(5);\n\n if (mediaType !== '' && !validMediaType.test(mediaType)) {\n return false;\n }\n\n for (var i = 0; i < attributes.length; i++) {\n if (!(i === attributes.length - 1 && attributes[i].toLowerCase() === 'base64') && !validAttribute.test(attributes[i])) {\n return false;\n }\n }\n\n for (var _i = 0; _i < data.length; _i++) {\n if (!validData.test(data[_i])) {\n return false;\n }\n }\n\n return true;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMagnetURI;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar magnetURIComponent = /(?:^magnet:\\?|[^?&]&)xt(?:\\.1)?=urn:(?:(?:aich|bitprint|btih|ed2k|ed2khash|kzhash|md5|sha1|tree:tiger):[a-z0-9]{32}(?:[a-z0-9]{8})?|btmh:1220[a-z0-9]{64})(?:$|&)/i;\n\nfunction isMagnetURI(url) {\n (0, _assertString.default)(url);\n\n if (url.indexOf('magnet:?') !== 0) {\n return false;\n }\n\n return magnetURIComponent.test(url);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = rtrim;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction rtrim(str, chars) {\n (0, _assertString.default)(str);\n\n if (chars) {\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping\n var pattern = new RegExp(\"[\".concat(chars.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&'), \"]+$\"), 'g');\n return str.replace(pattern, '');\n } // Use a faster and more safe than regex trim method https://blog.stevenlevithan.com/archives/faster-trim-javascript\n\n\n var strIndex = str.length - 1;\n\n while (/\\s/.test(str.charAt(strIndex))) {\n strIndex -= 1;\n }\n\n return str.slice(0, strIndex + 1);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = ltrim;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction ltrim(str, chars) {\n (0, _assertString.default)(str); // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping\n\n var pattern = chars ? new RegExp(\"^[\".concat(chars.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&'), \"]+\"), 'g') : /^\\s+/g;\n return str.replace(pattern, '');\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = trim;\n\nvar _rtrim = _interopRequireDefault(require(\"./rtrim\"));\n\nvar _ltrim = _interopRequireDefault(require(\"./ltrim\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction trim(str, chars) {\n return (0, _rtrim.default)((0, _ltrim.default)(str, chars), chars);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMailtoURI;\n\nvar _trim = _interopRequireDefault(require(\"./trim\"));\n\nvar _isEmail = _interopRequireDefault(require(\"./isEmail\"));\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _iterableToArrayLimit(arr, i) { if (typeof Symbol === \"undefined\" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction parseMailtoQueryString(queryString) {\n var allowedParams = new Set(['subject', 'body', 'cc', 'bcc']),\n query = {\n cc: '',\n bcc: ''\n };\n var isParseFailed = false;\n var queryParams = queryString.split('&');\n\n if (queryParams.length > 4) {\n return false;\n }\n\n var _iterator = _createForOfIteratorHelper(queryParams),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var q = _step.value;\n\n var _q$split = q.split('='),\n _q$split2 = _slicedToArray(_q$split, 2),\n key = _q$split2[0],\n value = _q$split2[1]; // checked for invalid and duplicated query params\n\n\n if (key && !allowedParams.has(key)) {\n isParseFailed = true;\n break;\n }\n\n if (value && (key === 'cc' || key === 'bcc')) {\n query[key] = value;\n }\n\n if (key) {\n allowedParams.delete(key);\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return isParseFailed ? false : query;\n}\n\nfunction isMailtoURI(url, options) {\n (0, _assertString.default)(url);\n\n if (url.indexOf('mailto:') !== 0) {\n return false;\n }\n\n var _url$replace$split = url.replace('mailto:', '').split('?'),\n _url$replace$split2 = _slicedToArray(_url$replace$split, 2),\n _url$replace$split2$ = _url$replace$split2[0],\n to = _url$replace$split2$ === void 0 ? '' : _url$replace$split2$,\n _url$replace$split2$2 = _url$replace$split2[1],\n queryString = _url$replace$split2$2 === void 0 ? '' : _url$replace$split2$2;\n\n if (!to && !queryString) {\n return true;\n }\n\n var query = parseMailtoQueryString(queryString);\n\n if (!query) {\n return false;\n }\n\n return \"\".concat(to, \",\").concat(query.cc, \",\").concat(query.bcc).split(',').every(function (email) {\n email = (0, _trim.default)(email, ' ');\n\n if (email) {\n return (0, _isEmail.default)(email, options);\n }\n\n return true;\n });\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isMimeType;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/*\n Checks if the provided string matches to a correct Media type format (MIME type)\n\n This function only checks is the string format follows the\n etablished rules by the according RFC specifications.\n This function supports 'charset' in textual media types\n (https://tools.ietf.org/html/rfc6657).\n\n This function does not check against all the media types listed\n by the IANA (https://www.iana.org/assignments/media-types/media-types.xhtml)\n because of lightness purposes : it would require to include\n all these MIME types in this librairy, which would weigh it\n significantly. This kind of effort maybe is not worth for the use that\n this function has in this entire librairy.\n\n More informations in the RFC specifications :\n - https://tools.ietf.org/html/rfc2045\n - https://tools.ietf.org/html/rfc2046\n - https://tools.ietf.org/html/rfc7231#section-3.1.1.1\n - https://tools.ietf.org/html/rfc7231#section-3.1.1.5\n*/\n// Match simple MIME types\n// NB :\n// Subtype length must not exceed 100 characters.\n// This rule does not comply to the RFC specs (what is the max length ?).\nvar mimeTypeSimple = /^(application|audio|font|image|message|model|multipart|text|video)\\/[a-zA-Z0-9\\.\\-\\+_]{1,100}$/i; // eslint-disable-line max-len\n// Handle \"charset\" in \"text/*\"\n\nvar mimeTypeText = /^text\\/[a-zA-Z0-9\\.\\-\\+]{1,100};\\s?charset=(\"[a-zA-Z0-9\\.\\-\\+\\s]{0,70}\"|[a-zA-Z0-9\\.\\-\\+]{0,70})(\\s?\\([a-zA-Z0-9\\.\\-\\+\\s]{1,20}\\))?$/i; // eslint-disable-line max-len\n// Handle \"boundary\" in \"multipart/*\"\n\nvar mimeTypeMultipart = /^multipart\\/[a-zA-Z0-9\\.\\-\\+]{1,100}(;\\s?(boundary|charset)=(\"[a-zA-Z0-9\\.\\-\\+\\s]{0,70}\"|[a-zA-Z0-9\\.\\-\\+]{0,70})(\\s?\\([a-zA-Z0-9\\.\\-\\+\\s]{1,20}\\))?){0,2}$/i; // eslint-disable-line max-len\n\nfunction isMimeType(str) {\n (0, _assertString.default)(str);\n return mimeTypeSimple.test(str) || mimeTypeText.test(str) || mimeTypeMultipart.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isLatLong;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar lat = /^\\(?[+-]?(90(\\.0+)?|[1-8]?\\d(\\.\\d+)?)$/;\nvar long = /^\\s?[+-]?(180(\\.0+)?|1[0-7]\\d(\\.\\d+)?|\\d{1,2}(\\.\\d+)?)\\)?$/;\nvar latDMS = /^(([1-8]?\\d)\\D+([1-5]?\\d|60)\\D+([1-5]?\\d|60)(\\.\\d+)?|90\\D+0\\D+0)\\D+[NSns]?$/i;\nvar longDMS = /^\\s*([1-7]?\\d{1,2}\\D+([1-5]?\\d|60)\\D+([1-5]?\\d|60)(\\.\\d+)?|180\\D+0\\D+0)\\D+[EWew]?$/i;\nvar defaultLatLongOptions = {\n checkDMS: false\n};\n\nfunction isLatLong(str, options) {\n (0, _assertString.default)(str);\n options = (0, _merge.default)(options, defaultLatLongOptions);\n if (!str.includes(',')) return false;\n var pair = str.split(',');\n if (pair[0].startsWith('(') && !pair[1].endsWith(')') || pair[1].endsWith(')') && !pair[0].startsWith('(')) return false;\n\n if (options.checkDMS) {\n return latDMS.test(pair[0]) && longDMS.test(pair[1]);\n }\n\n return lat.test(pair[0]) && long.test(pair[1]);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isPostalCode;\nexports.locales = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// common patterns\nvar threeDigit = /^\\d{3}$/;\nvar fourDigit = /^\\d{4}$/;\nvar fiveDigit = /^\\d{5}$/;\nvar sixDigit = /^\\d{6}$/;\nvar patterns = {\n AD: /^AD\\d{3}$/,\n AT: fourDigit,\n AU: fourDigit,\n AZ: /^AZ\\d{4}$/,\n BA: /^([7-8]\\d{4}$)/,\n BE: fourDigit,\n BG: fourDigit,\n BR: /^\\d{5}-\\d{3}$/,\n BY: /^2[1-4]\\d{4}$/,\n CA: /^[ABCEGHJKLMNPRSTVXY]\\d[ABCEGHJ-NPRSTV-Z][\\s\\-]?\\d[ABCEGHJ-NPRSTV-Z]\\d$/i,\n CH: fourDigit,\n CN: /^(0[1-7]|1[012356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[1-5]|8[1345]|9[09])\\d{4}$/,\n CZ: /^\\d{3}\\s?\\d{2}$/,\n DE: fiveDigit,\n DK: fourDigit,\n DO: fiveDigit,\n DZ: fiveDigit,\n EE: fiveDigit,\n ES: /^(5[0-2]{1}|[0-4]{1}\\d{1})\\d{3}$/,\n FI: fiveDigit,\n FR: /^\\d{2}\\s?\\d{3}$/,\n GB: /^(gir\\s?0aa|[a-z]{1,2}\\d[\\da-z]?\\s?(\\d[a-z]{2})?)$/i,\n GR: /^\\d{3}\\s?\\d{2}$/,\n HR: /^([1-5]\\d{4}$)/,\n HT: /^HT\\d{4}$/,\n HU: fourDigit,\n ID: fiveDigit,\n IE: /^(?!.*(?:o))[A-Za-z]\\d[\\dw]\\s\\w{4}$/i,\n IL: /^(\\d{5}|\\d{7})$/,\n IN: /^((?!10|29|35|54|55|65|66|86|87|88|89)[1-9][0-9]{5})$/,\n IR: /^(?!(\\d)\\1{3})[13-9]{4}[1346-9][013-9]{5}$/,\n IS: threeDigit,\n IT: fiveDigit,\n JP: /^\\d{3}\\-\\d{4}$/,\n KE: fiveDigit,\n KR: /^(\\d{5}|\\d{6})$/,\n LI: /^(948[5-9]|949[0-7])$/,\n LT: /^LT\\-\\d{5}$/,\n LU: fourDigit,\n LV: /^LV\\-\\d{4}$/,\n LK: fiveDigit,\n MG: threeDigit,\n MX: fiveDigit,\n MT: /^[A-Za-z]{3}\\s{0,1}\\d{4}$/,\n MY: fiveDigit,\n NL: /^\\d{4}\\s?[a-z]{2}$/i,\n NO: fourDigit,\n NP: /^(10|21|22|32|33|34|44|45|56|57)\\d{3}$|^(977)$/i,\n NZ: fourDigit,\n PL: /^\\d{2}\\-\\d{3}$/,\n PR: /^00[679]\\d{2}([ -]\\d{4})?$/,\n PT: /^\\d{4}\\-\\d{3}?$/,\n RO: sixDigit,\n RU: sixDigit,\n SA: fiveDigit,\n SE: /^[1-9]\\d{2}\\s?\\d{2}$/,\n SG: sixDigit,\n SI: fourDigit,\n SK: /^\\d{3}\\s?\\d{2}$/,\n TH: fiveDigit,\n TN: fourDigit,\n TW: /^\\d{3}(\\d{2})?$/,\n UA: fiveDigit,\n US: /^\\d{5}(-\\d{4})?$/,\n ZA: fourDigit,\n ZM: fiveDigit\n};\nvar locales = Object.keys(patterns);\nexports.locales = locales;\n\nfunction isPostalCode(str, locale) {\n (0, _assertString.default)(str);\n\n if (locale in patterns) {\n return patterns[locale].test(str);\n } else if (locale === 'any') {\n for (var key in patterns) {\n // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes\n // istanbul ignore else\n if (patterns.hasOwnProperty(key)) {\n var pattern = patterns[key];\n\n if (pattern.test(str)) {\n return true;\n }\n }\n }\n\n return false;\n }\n\n throw new Error(\"Invalid locale '\".concat(locale, \"'\"));\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = escape;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction escape(str) {\n (0, _assertString.default)(str);\n return str.replace(/&/g, '&').replace(/\"/g, '"').replace(/'/g, ''').replace(//g, '>').replace(/\\//g, '/').replace(/\\\\/g, '\').replace(/`/g, '`');\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = unescape;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction unescape(str) {\n (0, _assertString.default)(str);\n return str.replace(/"/g, '\"').replace(/'/g, \"'\").replace(/</g, '<').replace(/>/g, '>').replace(///g, '/').replace(/\/g, '\\\\').replace(/`/g, '`').replace(/&/g, '&'); // & replacement has to be the last one to prevent\n // bugs with intermediate strings containing escape sequences\n // See: https://github.com/validatorjs/validator.js/issues/1827\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = blacklist;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction blacklist(str, chars) {\n (0, _assertString.default)(str);\n return str.replace(new RegExp(\"[\".concat(chars, \"]+\"), 'g'), '');\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = stripLow;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar _blacklist = _interopRequireDefault(require(\"./blacklist\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction stripLow(str, keep_new_lines) {\n (0, _assertString.default)(str);\n var chars = keep_new_lines ? '\\\\x00-\\\\x09\\\\x0B\\\\x0C\\\\x0E-\\\\x1F\\\\x7F' : '\\\\x00-\\\\x1F\\\\x7F';\n return (0, _blacklist.default)(str, chars);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = whitelist;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction whitelist(str, chars) {\n (0, _assertString.default)(str);\n return str.replace(new RegExp(\"[^\".concat(chars, \"]+\"), 'g'), '');\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isWhitelisted;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction isWhitelisted(str, chars) {\n (0, _assertString.default)(str);\n\n for (var i = str.length - 1; i >= 0; i--) {\n if (chars.indexOf(str[i]) === -1) {\n return false;\n }\n }\n\n return true;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = normalizeEmail;\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar default_normalize_email_options = {\n // The following options apply to all email addresses\n // Lowercases the local part of the email address.\n // Please note this may violate RFC 5321 as per http://stackoverflow.com/a/9808332/192024).\n // The domain is always lowercased, as per RFC 1035\n all_lowercase: true,\n // The following conversions are specific to GMail\n // Lowercases the local part of the GMail address (known to be case-insensitive)\n gmail_lowercase: true,\n // Removes dots from the local part of the email address, as that's ignored by GMail\n gmail_remove_dots: true,\n // Removes the subaddress (e.g. \"+foo\") from the email address\n gmail_remove_subaddress: true,\n // Conversts the googlemail.com domain to gmail.com\n gmail_convert_googlemaildotcom: true,\n // The following conversions are specific to Outlook.com / Windows Live / Hotmail\n // Lowercases the local part of the Outlook.com address (known to be case-insensitive)\n outlookdotcom_lowercase: true,\n // Removes the subaddress (e.g. \"+foo\") from the email address\n outlookdotcom_remove_subaddress: true,\n // The following conversions are specific to Yahoo\n // Lowercases the local part of the Yahoo address (known to be case-insensitive)\n yahoo_lowercase: true,\n // Removes the subaddress (e.g. \"-foo\") from the email address\n yahoo_remove_subaddress: true,\n // The following conversions are specific to Yandex\n // Lowercases the local part of the Yandex address (known to be case-insensitive)\n yandex_lowercase: true,\n // The following conversions are specific to iCloud\n // Lowercases the local part of the iCloud address (known to be case-insensitive)\n icloud_lowercase: true,\n // Removes the subaddress (e.g. \"+foo\") from the email address\n icloud_remove_subaddress: true\n}; // List of domains used by iCloud\n\nvar icloud_domains = ['icloud.com', 'me.com']; // List of domains used by Outlook.com and its predecessors\n// This list is likely incomplete.\n// Partial reference:\n// https://blogs.office.com/2013/04/17/outlook-com-gets-two-step-verification-sign-in-by-alias-and-new-international-domains/\n\nvar outlookdotcom_domains = ['hotmail.at', 'hotmail.be', 'hotmail.ca', 'hotmail.cl', 'hotmail.co.il', 'hotmail.co.nz', 'hotmail.co.th', 'hotmail.co.uk', 'hotmail.com', 'hotmail.com.ar', 'hotmail.com.au', 'hotmail.com.br', 'hotmail.com.gr', 'hotmail.com.mx', 'hotmail.com.pe', 'hotmail.com.tr', 'hotmail.com.vn', 'hotmail.cz', 'hotmail.de', 'hotmail.dk', 'hotmail.es', 'hotmail.fr', 'hotmail.hu', 'hotmail.id', 'hotmail.ie', 'hotmail.in', 'hotmail.it', 'hotmail.jp', 'hotmail.kr', 'hotmail.lv', 'hotmail.my', 'hotmail.ph', 'hotmail.pt', 'hotmail.sa', 'hotmail.sg', 'hotmail.sk', 'live.be', 'live.co.uk', 'live.com', 'live.com.ar', 'live.com.mx', 'live.de', 'live.es', 'live.eu', 'live.fr', 'live.it', 'live.nl', 'msn.com', 'outlook.at', 'outlook.be', 'outlook.cl', 'outlook.co.il', 'outlook.co.nz', 'outlook.co.th', 'outlook.com', 'outlook.com.ar', 'outlook.com.au', 'outlook.com.br', 'outlook.com.gr', 'outlook.com.pe', 'outlook.com.tr', 'outlook.com.vn', 'outlook.cz', 'outlook.de', 'outlook.dk', 'outlook.es', 'outlook.fr', 'outlook.hu', 'outlook.id', 'outlook.ie', 'outlook.in', 'outlook.it', 'outlook.jp', 'outlook.kr', 'outlook.lv', 'outlook.my', 'outlook.ph', 'outlook.pt', 'outlook.sa', 'outlook.sg', 'outlook.sk', 'passport.com']; // List of domains used by Yahoo Mail\n// This list is likely incomplete\n\nvar yahoo_domains = ['rocketmail.com', 'yahoo.ca', 'yahoo.co.uk', 'yahoo.com', 'yahoo.de', 'yahoo.fr', 'yahoo.in', 'yahoo.it', 'ymail.com']; // List of domains used by yandex.ru\n\nvar yandex_domains = ['yandex.ru', 'yandex.ua', 'yandex.kz', 'yandex.com', 'yandex.by', 'ya.ru']; // replace single dots, but not multiple consecutive dots\n\nfunction dotsReplacer(match) {\n if (match.length > 1) {\n return match;\n }\n\n return '';\n}\n\nfunction normalizeEmail(email, options) {\n options = (0, _merge.default)(options, default_normalize_email_options);\n var raw_parts = email.split('@');\n var domain = raw_parts.pop();\n var user = raw_parts.join('@');\n var parts = [user, domain]; // The domain is always lowercased, as it's case-insensitive per RFC 1035\n\n parts[1] = parts[1].toLowerCase();\n\n if (parts[1] === 'gmail.com' || parts[1] === 'googlemail.com') {\n // Address is GMail\n if (options.gmail_remove_subaddress) {\n parts[0] = parts[0].split('+')[0];\n }\n\n if (options.gmail_remove_dots) {\n // this does not replace consecutive dots like example..email@gmail.com\n parts[0] = parts[0].replace(/\\.+/g, dotsReplacer);\n }\n\n if (!parts[0].length) {\n return false;\n }\n\n if (options.all_lowercase || options.gmail_lowercase) {\n parts[0] = parts[0].toLowerCase();\n }\n\n parts[1] = options.gmail_convert_googlemaildotcom ? 'gmail.com' : parts[1];\n } else if (icloud_domains.indexOf(parts[1]) >= 0) {\n // Address is iCloud\n if (options.icloud_remove_subaddress) {\n parts[0] = parts[0].split('+')[0];\n }\n\n if (!parts[0].length) {\n return false;\n }\n\n if (options.all_lowercase || options.icloud_lowercase) {\n parts[0] = parts[0].toLowerCase();\n }\n } else if (outlookdotcom_domains.indexOf(parts[1]) >= 0) {\n // Address is Outlook.com\n if (options.outlookdotcom_remove_subaddress) {\n parts[0] = parts[0].split('+')[0];\n }\n\n if (!parts[0].length) {\n return false;\n }\n\n if (options.all_lowercase || options.outlookdotcom_lowercase) {\n parts[0] = parts[0].toLowerCase();\n }\n } else if (yahoo_domains.indexOf(parts[1]) >= 0) {\n // Address is Yahoo\n if (options.yahoo_remove_subaddress) {\n var components = parts[0].split('-');\n parts[0] = components.length > 1 ? components.slice(0, -1).join('-') : components[0];\n }\n\n if (!parts[0].length) {\n return false;\n }\n\n if (options.all_lowercase || options.yahoo_lowercase) {\n parts[0] = parts[0].toLowerCase();\n }\n } else if (yandex_domains.indexOf(parts[1]) >= 0) {\n if (options.all_lowercase || options.yandex_lowercase) {\n parts[0] = parts[0].toLowerCase();\n }\n\n parts[1] = 'yandex.ru'; // all yandex domains are equal, 1st preferred\n } else if (options.all_lowercase) {\n // Any other address\n parts[0] = parts[0].toLowerCase();\n }\n\n return parts.join('@');\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isSlug;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar charsetRegex = /^[^\\s-_](?!.*?[-_]{2,})[a-z0-9-\\\\][^\\s]*[^-_\\s]$/;\n\nfunction isSlug(str) {\n (0, _assertString.default)(str);\n return charsetRegex.test(str);\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isLicensePlate;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar validators = {\n 'cs-CZ': function csCZ(str) {\n return /^(([ABCDEFHIJKLMNPRSTUVXYZ]|[0-9])-?){5,8}$/.test(str);\n },\n 'de-DE': function deDE(str) {\n return /^((A|AA|AB|AC|AE|AH|AK|AM|AN|AÖ|AP|AS|AT|AU|AW|AZ|B|BA|BB|BC|BE|BF|BH|BI|BK|BL|BM|BN|BO|BÖ|BS|BT|BZ|C|CA|CB|CE|CO|CR|CW|D|DA|DD|DE|DH|DI|DL|DM|DN|DO|DU|DW|DZ|E|EA|EB|ED|EE|EF|EG|EH|EI|EL|EM|EN|ER|ES|EU|EW|F|FB|FD|FF|FG|FI|FL|FN|FO|FR|FS|FT|FÜ|FW|FZ|G|GA|GC|GD|GE|GF|GG|GI|GK|GL|GM|GN|GÖ|GP|GR|GS|GT|GÜ|GV|GW|GZ|H|HA|HB|HC|HD|HE|HF|HG|HH|HI|HK|HL|HM|HN|HO|HP|HR|HS|HU|HV|HX|HY|HZ|IK|IL|IN|IZ|J|JE|JL|K|KA|KB|KC|KE|KF|KG|KH|KI|KK|KL|KM|KN|KO|KR|KS|KT|KU|KW|KY|L|LA|LB|LC|LD|LF|LG|LH|LI|LL|LM|LN|LÖ|LP|LR|LU|M|MA|MB|MC|MD|ME|MG|MH|MI|MK|ML|MM|MN|MO|MQ|MR|MS|MÜ|MW|MY|MZ|N|NB|ND|NE|NF|NH|NI|NK|NM|NÖ|NP|NR|NT|NU|NW|NY|NZ|OA|OB|OC|OD|OE|OF|OG|OH|OK|OL|OP|OS|OZ|P|PA|PB|PE|PF|PI|PL|PM|PN|PR|PS|PW|PZ|R|RA|RC|RD|RE|RG|RH|RI|RL|RM|RN|RO|RP|RS|RT|RU|RV|RW|RZ|S|SB|SC|SE|SG|SI|SK|SL|SM|SN|SO|SP|SR|ST|SU|SW|SY|SZ|TE|TF|TG|TO|TP|TR|TS|TT|TÜ|ÜB|UE|UH|UL|UM|UN|V|VB|VG|VK|VR|VS|W|WA|WB|WE|WF|WI|WK|WL|WM|WN|WO|WR|WS|WT|WÜ|WW|WZ|Z|ZE|ZI|ZP|ZR|ZW|ZZ)[- ]?[A-Z]{1,2}[- ]?\\d{1,4}|(ABG|ABI|AIB|AIC|ALF|ALZ|ANA|ANG|ANK|APD|ARN|ART|ASL|ASZ|AUR|AZE|BAD|BAR|BBG|BCH|BED|BER|BGD|BGL|BID|BIN|BIR|BIT|BIW|BKS|BLB|BLK|BNA|BOG|BOH|BOR|BOT|BRA|BRB|BRG|BRK|BRL|BRV|BSB|BSK|BTF|BÜD|BUL|BÜR|BÜS|BÜZ|CAS|CHA|CLP|CLZ|COC|COE|CUX|DAH|DAN|DAU|DBR|DEG|DEL|DGF|DIL|DIN|DIZ|DKB|DLG|DON|DUD|DÜW|EBE|EBN|EBS|ECK|EIC|EIL|EIN|EIS|EMD|EMS|ERB|ERH|ERK|ERZ|ESB|ESW|FDB|FDS|FEU|FFB|FKB|FLÖ|FOR|FRG|FRI|FRW|FTL|FÜS|GAN|GAP|GDB|GEL|GEO|GER|GHA|GHC|GLA|GMN|GNT|GOA|GOH|GRA|GRH|GRI|GRM|GRZ|GTH|GUB|GUN|GVM|HAB|HAL|HAM|HAS|HBN|HBS|HCH|HDH|HDL|HEB|HEF|HEI|HER|HET|HGN|HGW|HHM|HIG|HIP|HMÜ|HOG|HOH|HOL|HOM|HOR|HÖS|HOT|HRO|HSK|HST|HVL|HWI|IGB|ILL|JÜL|KEH|KEL|KEM|KIB|KLE|KLZ|KÖN|KÖT|KÖZ|KRU|KÜN|KUS|KYF|LAN|LAU|LBS|LBZ|LDK|LDS|LEO|LER|LEV|LIB|LIF|LIP|LÖB|LOS|LRO|LSZ|LÜN|LUP|LWL|MAB|MAI|MAK|MAL|MED|MEG|MEI|MEK|MEL|MER|MET|MGH|MGN|MHL|MIL|MKK|MOD|MOL|MON|MOS|MSE|MSH|MSP|MST|MTK|MTL|MÜB|MÜR|MYK|MZG|NAB|NAI|NAU|NDH|NEA|NEB|NEC|NEN|NES|NEW|NMB|NMS|NOH|NOL|NOM|NOR|NVP|NWM|OAL|OBB|OBG|OCH|OHA|ÖHR|OHV|OHZ|OPR|OSL|OVI|OVL|OVP|PAF|PAN|PAR|PCH|PEG|PIR|PLÖ|PRÜ|QFT|QLB|RDG|REG|REH|REI|RID|RIE|ROD|ROF|ROK|ROL|ROS|ROT|ROW|RSL|RÜD|RÜG|SAB|SAD|SAN|SAW|SBG|SBK|SCZ|SDH|SDL|SDT|SEB|SEE|SEF|SEL|SFB|SFT|SGH|SHA|SHG|SHK|SHL|SIG|SIM|SLE|SLF|SLK|SLN|SLS|SLÜ|SLZ|SMÜ|SOB|SOG|SOK|SÖM|SON|SPB|SPN|SRB|SRO|STA|STB|STD|STE|STL|SUL|SÜW|SWA|SZB|TBB|TDO|TET|TIR|TÖL|TUT|UEM|UER|UFF|USI|VAI|VEC|VER|VIB|VIE|VIT|VOH|WAF|WAK|WAN|WAR|WAT|WBS|WDA|WEL|WEN|WER|WES|WHV|WIL|WIS|WIT|WIZ|WLG|WMS|WND|WOB|WOH|WOL|WOR|WOS|WRN|WSF|WST|WSW|WTL|WTM|WUG|WÜM|WUN|WUR|WZL|ZEL|ZIG)[- ]?(([A-Z][- ]?\\d{1,4})|([A-Z]{2}[- ]?\\d{1,3})))[- ]?(E|H)?$/.test(str);\n },\n 'de-LI': function deLI(str) {\n return /^FL[- ]?\\d{1,5}[UZ]?$/.test(str);\n },\n 'en-IN': function enIN(str) {\n return /^[A-Z]{2}[ -]?[0-9]{1,2}(?:[ -]?[A-Z])(?:[ -]?[A-Z]*)?[ -]?[0-9]{4}$/.test(str);\n },\n 'es-AR': function esAR(str) {\n return /^(([A-Z]{2} ?[0-9]{3} ?[A-Z]{2})|([A-Z]{3} ?[0-9]{3}))$/.test(str);\n },\n 'fi-FI': function fiFI(str) {\n return /^(?=.{4,7})(([A-Z]{1,3}|[0-9]{1,3})[\\s-]?([A-Z]{1,3}|[0-9]{1,5}))$/.test(str);\n },\n 'hu-HU': function huHU(str) {\n return /^((((?!AAA)(([A-NPRSTVZWXY]{1})([A-PR-Z]{1})([A-HJ-NPR-Z]))|(A[ABC]I)|A[ABC]O|A[A-W]Q|BPI|BPO|UCO|UDO|XAO)-(?!000)\\d{3})|(M\\d{6})|((CK|DT|CD|HC|H[ABEFIKLMNPRSTVX]|MA|OT|R[A-Z]) \\d{2}-\\d{2})|(CD \\d{3}-\\d{3})|(C-(C|X) \\d{4})|(X-(A|B|C) \\d{4})|(([EPVZ]-\\d{5}))|(S A[A-Z]{2} \\d{2})|(SP \\d{2}-\\d{2}))$/.test(str);\n },\n 'pt-BR': function ptBR(str) {\n return /^[A-Z]{3}[ -]?[0-9][A-Z][0-9]{2}|[A-Z]{3}[ -]?[0-9]{4}$/.test(str);\n },\n 'pt-PT': function ptPT(str) {\n return /^([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})$/.test(str);\n },\n 'sq-AL': function sqAL(str) {\n return /^[A-Z]{2}[- ]?((\\d{3}[- ]?(([A-Z]{2})|T))|(R[- ]?\\d{3}))$/.test(str);\n },\n 'sv-SE': function svSE(str) {\n return /^[A-HJ-PR-UW-Z]{3} ?[\\d]{2}[A-HJ-PR-UW-Z1-9]$|(^[A-ZÅÄÖ ]{2,7}$)/.test(str.trim());\n }\n};\n\nfunction isLicensePlate(str, locale) {\n (0, _assertString.default)(str);\n\n if (locale in validators) {\n return validators[locale](str);\n } else if (locale === 'any') {\n for (var key in validators) {\n /* eslint guard-for-in: 0 */\n var validator = validators[key];\n\n if (validator(str)) {\n return true;\n }\n }\n\n return false;\n }\n\n throw new Error(\"Invalid locale '\".concat(locale, \"'\"));\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isStrongPassword;\n\nvar _merge = _interopRequireDefault(require(\"./util/merge\"));\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar upperCaseRegex = /^[A-Z]$/;\nvar lowerCaseRegex = /^[a-z]$/;\nvar numberRegex = /^[0-9]$/;\nvar symbolRegex = /^[-#!$@£%^&*()_+|~=`{}\\[\\]:\";'<>?,.\\/ ]$/;\nvar defaultOptions = {\n minLength: 8,\n minLowercase: 1,\n minUppercase: 1,\n minNumbers: 1,\n minSymbols: 1,\n returnScore: false,\n pointsPerUnique: 1,\n pointsPerRepeat: 0.5,\n pointsForContainingLower: 10,\n pointsForContainingUpper: 10,\n pointsForContainingNumber: 10,\n pointsForContainingSymbol: 10\n};\n/* Counts number of occurrences of each char in a string\n * could be moved to util/ ?\n*/\n\nfunction countChars(str) {\n var result = {};\n Array.from(str).forEach(function (char) {\n var curVal = result[char];\n\n if (curVal) {\n result[char] += 1;\n } else {\n result[char] = 1;\n }\n });\n return result;\n}\n/* Return information about a password */\n\n\nfunction analyzePassword(password) {\n var charMap = countChars(password);\n var analysis = {\n length: password.length,\n uniqueChars: Object.keys(charMap).length,\n uppercaseCount: 0,\n lowercaseCount: 0,\n numberCount: 0,\n symbolCount: 0\n };\n Object.keys(charMap).forEach(function (char) {\n /* istanbul ignore else */\n if (upperCaseRegex.test(char)) {\n analysis.uppercaseCount += charMap[char];\n } else if (lowerCaseRegex.test(char)) {\n analysis.lowercaseCount += charMap[char];\n } else if (numberRegex.test(char)) {\n analysis.numberCount += charMap[char];\n } else if (symbolRegex.test(char)) {\n analysis.symbolCount += charMap[char];\n }\n });\n return analysis;\n}\n\nfunction scorePassword(analysis, scoringOptions) {\n var points = 0;\n points += analysis.uniqueChars * scoringOptions.pointsPerUnique;\n points += (analysis.length - analysis.uniqueChars) * scoringOptions.pointsPerRepeat;\n\n if (analysis.lowercaseCount > 0) {\n points += scoringOptions.pointsForContainingLower;\n }\n\n if (analysis.uppercaseCount > 0) {\n points += scoringOptions.pointsForContainingUpper;\n }\n\n if (analysis.numberCount > 0) {\n points += scoringOptions.pointsForContainingNumber;\n }\n\n if (analysis.symbolCount > 0) {\n points += scoringOptions.pointsForContainingSymbol;\n }\n\n return points;\n}\n\nfunction isStrongPassword(str) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n (0, _assertString.default)(str);\n var analysis = analyzePassword(str);\n options = (0, _merge.default)(options || {}, defaultOptions);\n\n if (options.returnScore) {\n return scorePassword(analysis, options);\n }\n\n return analysis.length >= options.minLength && analysis.lowercaseCount >= options.minLowercase && analysis.uppercaseCount >= options.minUppercase && analysis.numberCount >= options.minNumbers && analysis.symbolCount >= options.minSymbols;\n}\n\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isVAT;\nexports.vatMatchers = void 0;\n\nvar _assertString = _interopRequireDefault(require(\"./util/assertString\"));\n\nvar algorithms = _interopRequireWildcard(require(\"./util/algorithms\"));\n\nfunction _getRequireWildcardCache() { if (typeof WeakMap !== \"function\") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar CH = function CH(str) {\n // @see {@link https://www.ech.ch/de/ech/ech-0097/5.2.0}\n var hasValidCheckNumber = function hasValidCheckNumber(digits) {\n var lastDigit = digits.pop(); // used as check number\n\n var weights = [5, 4, 3, 2, 7, 6, 5, 4];\n var calculatedCheckNumber = (11 - digits.reduce(function (acc, el, idx) {\n return acc + el * weights[idx];\n }, 0) % 11) % 11;\n return lastDigit === calculatedCheckNumber;\n }; // @see {@link https://www.estv.admin.ch/estv/de/home/mehrwertsteuer/uid/mwst-uid-nummer.html}\n\n\n return /^(CHE[- ]?)?(\\d{9}|(\\d{3}\\.\\d{3}\\.\\d{3})|(\\d{3} \\d{3} \\d{3})) ?(TVA|MWST|IVA)?$/.test(str) && hasValidCheckNumber(str.match(/\\d/g).map(function (el) {\n return +el;\n }));\n};\n\nvar PT = function PT(str) {\n var match = str.match(/^(PT)?(\\d{9})$/);\n\n if (!match) {\n return false;\n }\n\n var tin = match[2];\n var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {\n return parseInt(a, 10);\n }), 9) % 11;\n\n if (checksum > 9) {\n return parseInt(tin[8], 10) === 0;\n }\n\n return checksum === parseInt(tin[8], 10);\n};\n\nvar vatMatchers = {\n /**\r\n * European Union VAT identification numbers\r\n */\n AT: function AT(str) {\n return /^(AT)?U\\d{8}$/.test(str);\n },\n BE: function BE(str) {\n return /^(BE)?\\d{10}$/.test(str);\n },\n BG: function BG(str) {\n return /^(BG)?\\d{9,10}$/.test(str);\n },\n HR: function HR(str) {\n return /^(HR)?\\d{11}$/.test(str);\n },\n CY: function CY(str) {\n return /^(CY)?\\w{9}$/.test(str);\n },\n CZ: function CZ(str) {\n return /^(CZ)?\\d{8,10}$/.test(str);\n },\n DK: function DK(str) {\n return /^(DK)?\\d{8}$/.test(str);\n },\n EE: function EE(str) {\n return /^(EE)?\\d{9}$/.test(str);\n },\n FI: function FI(str) {\n return /^(FI)?\\d{8}$/.test(str);\n },\n FR: function FR(str) {\n return /^(FR)?\\w{2}\\d{9}$/.test(str);\n },\n DE: function DE(str) {\n return /^(DE)?\\d{9}$/.test(str);\n },\n EL: function EL(str) {\n return /^(EL)?\\d{9}$/.test(str);\n },\n HU: function HU(str) {\n return /^(HU)?\\d{8}$/.test(str);\n },\n IE: function IE(str) {\n return /^(IE)?\\d{7}\\w{1}(W)?$/.test(str);\n },\n IT: function IT(str) {\n return /^(IT)?\\d{11}$/.test(str);\n },\n LV: function LV(str) {\n return /^(LV)?\\d{11}$/.test(str);\n },\n LT: function LT(str) {\n return /^(LT)?\\d{9,12}$/.test(str);\n },\n LU: function LU(str) {\n return /^(LU)?\\d{8}$/.test(str);\n },\n MT: function MT(str) {\n return /^(MT)?\\d{8}$/.test(str);\n },\n NL: function NL(str) {\n return /^(NL)?\\d{9}B\\d{2}$/.test(str);\n },\n PL: function PL(str) {\n return /^(PL)?(\\d{10}|(\\d{3}-\\d{3}-\\d{2}-\\d{2})|(\\d{3}-\\d{2}-\\d{2}-\\d{3}))$/.test(str);\n },\n PT: PT,\n RO: function RO(str) {\n return /^(RO)?\\d{2,10}$/.test(str);\n },\n SK: function SK(str) {\n return /^(SK)?\\d{10}$/.test(str);\n },\n SI: function SI(str) {\n return /^(SI)?\\d{8}$/.test(str);\n },\n ES: function ES(str) {\n return /^(ES)?\\w\\d{7}[A-Z]$/.test(str);\n },\n SE: function SE(str) {\n return /^(SE)?\\d{12}$/.test(str);\n },\n\n /**\r\n * VAT numbers of non-EU countries\r\n */\n AL: function AL(str) {\n return /^(AL)?\\w{9}[A-Z]$/.test(str);\n },\n MK: function MK(str) {\n return /^(MK)?\\d{13}$/.test(str);\n },\n AU: function AU(str) {\n return /^(AU)?\\d{11}$/.test(str);\n },\n BY: function BY(str) {\n return /^(УНП )?\\d{9}$/.test(str);\n },\n CA: function CA(str) {\n return /^(CA)?\\d{9}$/.test(str);\n },\n IS: function IS(str) {\n return /^(IS)?\\d{5,6}$/.test(str);\n },\n IN: function IN(str) {\n return /^(IN)?\\d{15}$/.test(str);\n },\n ID: function ID(str) {\n return /^(ID)?(\\d{15}|(\\d{2}.\\d{3}.\\d{3}.\\d{1}-\\d{3}.\\d{3}))$/.test(str);\n },\n IL: function IL(str) {\n return /^(IL)?\\d{9}$/.test(str);\n },\n KZ: function KZ(str) {\n return /^(KZ)?\\d{9}$/.test(str);\n },\n NZ: function NZ(str) {\n return /^(NZ)?\\d{9}$/.test(str);\n },\n NG: function NG(str) {\n return /^(NG)?(\\d{12}|(\\d{8}-\\d{4}))$/.test(str);\n },\n NO: function NO(str) {\n return /^(NO)?\\d{9}MVA$/.test(str);\n },\n PH: function PH(str) {\n return /^(PH)?(\\d{12}|\\d{3} \\d{3} \\d{3} \\d{3})$/.test(str);\n },\n RU: function RU(str) {\n return /^(RU)?(\\d{10}|\\d{12})$/.test(str);\n },\n SM: function SM(str) {\n return /^(SM)?\\d{5}$/.test(str);\n },\n SA: function SA(str) {\n return /^(SA)?\\d{15}$/.test(str);\n },\n RS: function RS(str) {\n return /^(RS)?\\d{9}$/.test(str);\n },\n CH: CH,\n TR: function TR(str) {\n return /^(TR)?\\d{10}$/.test(str);\n },\n UA: function UA(str) {\n return /^(UA)?\\d{12}$/.test(str);\n },\n GB: function GB(str) {\n return /^GB((\\d{3} \\d{4} ([0-8][0-9]|9[0-6]))|(\\d{9} \\d{3})|(((GD[0-4])|(HA[5-9]))[0-9]{2}))$/.test(str);\n },\n UZ: function UZ(str) {\n return /^(UZ)?\\d{9}$/.test(str);\n },\n\n /**\r\n * VAT numbers of Latin American countries\r\n */\n AR: function AR(str) {\n return /^(AR)?\\d{11}$/.test(str);\n },\n BO: function BO(str) {\n return /^(BO)?\\d{7}$/.test(str);\n },\n BR: function BR(str) {\n return /^(BR)?((\\d{2}.\\d{3}.\\d{3}\\/\\d{4}-\\d{2})|(\\d{3}.\\d{3}.\\d{3}-\\d{2}))$/.test(str);\n },\n CL: function CL(str) {\n return /^(CL)?\\d{8}-\\d{1}$/.test(str);\n },\n CO: function CO(str) {\n return /^(CO)?\\d{10}$/.test(str);\n },\n CR: function CR(str) {\n return /^(CR)?\\d{9,12}$/.test(str);\n },\n EC: function EC(str) {\n return /^(EC)?\\d{13}$/.test(str);\n },\n SV: function SV(str) {\n return /^(SV)?\\d{4}-\\d{6}-\\d{3}-\\d{1}$/.test(str);\n },\n GT: function GT(str) {\n return /^(GT)?\\d{7}-\\d{1}$/.test(str);\n },\n HN: function HN(str) {\n return /^(HN)?$/.test(str);\n },\n MX: function MX(str) {\n return /^(MX)?\\w{3,4}\\d{6}\\w{3}$/.test(str);\n },\n NI: function NI(str) {\n return /^(NI)?\\d{3}-\\d{6}-\\d{4}\\w{1}$/.test(str);\n },\n PA: function PA(str) {\n return /^(PA)?$/.test(str);\n },\n PY: function PY(str) {\n return /^(PY)?\\d{6,8}-\\d{1}$/.test(str);\n },\n PE: function PE(str) {\n return /^(PE)?\\d{11}$/.test(str);\n },\n DO: function DO(str) {\n return /^(DO)?(\\d{11}|(\\d{3}-\\d{7}-\\d{1})|[1,4,5]{1}\\d{8}|([1,4,5]{1})-\\d{2}-\\d{5}-\\d{1})$/.test(str);\n },\n UY: function UY(str) {\n return /^(UY)?\\d{12}$/.test(str);\n },\n VE: function VE(str) {\n return /^(VE)?[J,G,V,E]{1}-(\\d{9}|(\\d{8}-\\d{1}))$/.test(str);\n }\n};\nexports.vatMatchers = vatMatchers;\n\nfunction isVAT(str, countryCode) {\n (0, _assertString.default)(str);\n (0, _assertString.default)(countryCode);\n\n if (countryCode in vatMatchers) {\n return vatMatchers[countryCode](str);\n }\n\n throw new Error(\"Invalid country code: '\".concat(countryCode, \"'\"));\n}","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _toDate = _interopRequireDefault(require(\"./lib/toDate\"));\n\nvar _toFloat = _interopRequireDefault(require(\"./lib/toFloat\"));\n\nvar _toInt = _interopRequireDefault(require(\"./lib/toInt\"));\n\nvar _toBoolean = _interopRequireDefault(require(\"./lib/toBoolean\"));\n\nvar _equals = _interopRequireDefault(require(\"./lib/equals\"));\n\nvar _contains = _interopRequireDefault(require(\"./lib/contains\"));\n\nvar _matches = _interopRequireDefault(require(\"./lib/matches\"));\n\nvar _isEmail = _interopRequireDefault(require(\"./lib/isEmail\"));\n\nvar _isURL = _interopRequireDefault(require(\"./lib/isURL\"));\n\nvar _isMACAddress = _interopRequireDefault(require(\"./lib/isMACAddress\"));\n\nvar _isIP = _interopRequireDefault(require(\"./lib/isIP\"));\n\nvar _isIPRange = _interopRequireDefault(require(\"./lib/isIPRange\"));\n\nvar _isFQDN = _interopRequireDefault(require(\"./lib/isFQDN\"));\n\nvar _isDate = _interopRequireDefault(require(\"./lib/isDate\"));\n\nvar _isTime = _interopRequireDefault(require(\"./lib/isTime\"));\n\nvar _isBoolean = _interopRequireDefault(require(\"./lib/isBoolean\"));\n\nvar _isLocale = _interopRequireDefault(require(\"./lib/isLocale\"));\n\nvar _isAlpha = _interopRequireWildcard(require(\"./lib/isAlpha\"));\n\nvar _isAlphanumeric = _interopRequireWildcard(require(\"./lib/isAlphanumeric\"));\n\nvar _isNumeric = _interopRequireDefault(require(\"./lib/isNumeric\"));\n\nvar _isPassportNumber = _interopRequireDefault(require(\"./lib/isPassportNumber\"));\n\nvar _isPort = _interopRequireDefault(require(\"./lib/isPort\"));\n\nvar _isLowercase = _interopRequireDefault(require(\"./lib/isLowercase\"));\n\nvar _isUppercase = _interopRequireDefault(require(\"./lib/isUppercase\"));\n\nvar _isIMEI = _interopRequireDefault(require(\"./lib/isIMEI\"));\n\nvar _isAscii = _interopRequireDefault(require(\"./lib/isAscii\"));\n\nvar _isFullWidth = _interopRequireDefault(require(\"./lib/isFullWidth\"));\n\nvar _isHalfWidth = _interopRequireDefault(require(\"./lib/isHalfWidth\"));\n\nvar _isVariableWidth = _interopRequireDefault(require(\"./lib/isVariableWidth\"));\n\nvar _isMultibyte = _interopRequireDefault(require(\"./lib/isMultibyte\"));\n\nvar _isSemVer = _interopRequireDefault(require(\"./lib/isSemVer\"));\n\nvar _isSurrogatePair = _interopRequireDefault(require(\"./lib/isSurrogatePair\"));\n\nvar _isInt = _interopRequireDefault(require(\"./lib/isInt\"));\n\nvar _isFloat = _interopRequireWildcard(require(\"./lib/isFloat\"));\n\nvar _isDecimal = _interopRequireDefault(require(\"./lib/isDecimal\"));\n\nvar _isHexadecimal = _interopRequireDefault(require(\"./lib/isHexadecimal\"));\n\nvar _isOctal = _interopRequireDefault(require(\"./lib/isOctal\"));\n\nvar _isDivisibleBy = _interopRequireDefault(require(\"./lib/isDivisibleBy\"));\n\nvar _isHexColor = _interopRequireDefault(require(\"./lib/isHexColor\"));\n\nvar _isRgbColor = _interopRequireDefault(require(\"./lib/isRgbColor\"));\n\nvar _isHSL = _interopRequireDefault(require(\"./lib/isHSL\"));\n\nvar _isISRC = _interopRequireDefault(require(\"./lib/isISRC\"));\n\nvar _isIBAN = _interopRequireWildcard(require(\"./lib/isIBAN\"));\n\nvar _isBIC = _interopRequireDefault(require(\"./lib/isBIC\"));\n\nvar _isMD = _interopRequireDefault(require(\"./lib/isMD5\"));\n\nvar _isHash = _interopRequireDefault(require(\"./lib/isHash\"));\n\nvar _isJWT = _interopRequireDefault(require(\"./lib/isJWT\"));\n\nvar _isJSON = _interopRequireDefault(require(\"./lib/isJSON\"));\n\nvar _isEmpty = _interopRequireDefault(require(\"./lib/isEmpty\"));\n\nvar _isLength = _interopRequireDefault(require(\"./lib/isLength\"));\n\nvar _isByteLength = _interopRequireDefault(require(\"./lib/isByteLength\"));\n\nvar _isUUID = _interopRequireDefault(require(\"./lib/isUUID\"));\n\nvar _isMongoId = _interopRequireDefault(require(\"./lib/isMongoId\"));\n\nvar _isAfter = _interopRequireDefault(require(\"./lib/isAfter\"));\n\nvar _isBefore = _interopRequireDefault(require(\"./lib/isBefore\"));\n\nvar _isIn = _interopRequireDefault(require(\"./lib/isIn\"));\n\nvar _isLuhnNumber = _interopRequireDefault(require(\"./lib/isLuhnNumber\"));\n\nvar _isCreditCard = _interopRequireDefault(require(\"./lib/isCreditCard\"));\n\nvar _isIdentityCard = _interopRequireDefault(require(\"./lib/isIdentityCard\"));\n\nvar _isEAN = _interopRequireDefault(require(\"./lib/isEAN\"));\n\nvar _isISIN = _interopRequireDefault(require(\"./lib/isISIN\"));\n\nvar _isISBN = _interopRequireDefault(require(\"./lib/isISBN\"));\n\nvar _isISSN = _interopRequireDefault(require(\"./lib/isISSN\"));\n\nvar _isTaxID = _interopRequireDefault(require(\"./lib/isTaxID\"));\n\nvar _isMobilePhone = _interopRequireWildcard(require(\"./lib/isMobilePhone\"));\n\nvar _isEthereumAddress = _interopRequireDefault(require(\"./lib/isEthereumAddress\"));\n\nvar _isCurrency = _interopRequireDefault(require(\"./lib/isCurrency\"));\n\nvar _isBtcAddress = _interopRequireDefault(require(\"./lib/isBtcAddress\"));\n\nvar _isISO = require(\"./lib/isISO6346\");\n\nvar _isISO2 = _interopRequireDefault(require(\"./lib/isISO6391\"));\n\nvar _isISO3 = _interopRequireDefault(require(\"./lib/isISO8601\"));\n\nvar _isRFC = _interopRequireDefault(require(\"./lib/isRFC3339\"));\n\nvar _isISO31661Alpha = _interopRequireDefault(require(\"./lib/isISO31661Alpha2\"));\n\nvar _isISO31661Alpha2 = _interopRequireDefault(require(\"./lib/isISO31661Alpha3\"));\n\nvar _isISO4 = _interopRequireDefault(require(\"./lib/isISO4217\"));\n\nvar _isBase = _interopRequireDefault(require(\"./lib/isBase32\"));\n\nvar _isBase2 = _interopRequireDefault(require(\"./lib/isBase58\"));\n\nvar _isBase3 = _interopRequireDefault(require(\"./lib/isBase64\"));\n\nvar _isDataURI = _interopRequireDefault(require(\"./lib/isDataURI\"));\n\nvar _isMagnetURI = _interopRequireDefault(require(\"./lib/isMagnetURI\"));\n\nvar _isMailtoURI = _interopRequireDefault(require(\"./lib/isMailtoURI\"));\n\nvar _isMimeType = _interopRequireDefault(require(\"./lib/isMimeType\"));\n\nvar _isLatLong = _interopRequireDefault(require(\"./lib/isLatLong\"));\n\nvar _isPostalCode = _interopRequireWildcard(require(\"./lib/isPostalCode\"));\n\nvar _ltrim = _interopRequireDefault(require(\"./lib/ltrim\"));\n\nvar _rtrim = _interopRequireDefault(require(\"./lib/rtrim\"));\n\nvar _trim = _interopRequireDefault(require(\"./lib/trim\"));\n\nvar _escape = _interopRequireDefault(require(\"./lib/escape\"));\n\nvar _unescape = _interopRequireDefault(require(\"./lib/unescape\"));\n\nvar _stripLow = _interopRequireDefault(require(\"./lib/stripLow\"));\n\nvar _whitelist = _interopRequireDefault(require(\"./lib/whitelist\"));\n\nvar _blacklist = _interopRequireDefault(require(\"./lib/blacklist\"));\n\nvar _isWhitelisted = _interopRequireDefault(require(\"./lib/isWhitelisted\"));\n\nvar _normalizeEmail = _interopRequireDefault(require(\"./lib/normalizeEmail\"));\n\nvar _isSlug = _interopRequireDefault(require(\"./lib/isSlug\"));\n\nvar _isLicensePlate = _interopRequireDefault(require(\"./lib/isLicensePlate\"));\n\nvar _isStrongPassword = _interopRequireDefault(require(\"./lib/isStrongPassword\"));\n\nvar _isVAT = _interopRequireDefault(require(\"./lib/isVAT\"));\n\nfunction _getRequireWildcardCache() { if (typeof WeakMap !== \"function\") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar version = '13.11.0';\nvar validator = {\n version: version,\n toDate: _toDate.default,\n toFloat: _toFloat.default,\n toInt: _toInt.default,\n toBoolean: _toBoolean.default,\n equals: _equals.default,\n contains: _contains.default,\n matches: _matches.default,\n isEmail: _isEmail.default,\n isURL: _isURL.default,\n isMACAddress: _isMACAddress.default,\n isIP: _isIP.default,\n isIPRange: _isIPRange.default,\n isFQDN: _isFQDN.default,\n isBoolean: _isBoolean.default,\n isIBAN: _isIBAN.default,\n isBIC: _isBIC.default,\n isAlpha: _isAlpha.default,\n isAlphaLocales: _isAlpha.locales,\n isAlphanumeric: _isAlphanumeric.default,\n isAlphanumericLocales: _isAlphanumeric.locales,\n isNumeric: _isNumeric.default,\n isPassportNumber: _isPassportNumber.default,\n isPort: _isPort.default,\n isLowercase: _isLowercase.default,\n isUppercase: _isUppercase.default,\n isAscii: _isAscii.default,\n isFullWidth: _isFullWidth.default,\n isHalfWidth: _isHalfWidth.default,\n isVariableWidth: _isVariableWidth.default,\n isMultibyte: _isMultibyte.default,\n isSemVer: _isSemVer.default,\n isSurrogatePair: _isSurrogatePair.default,\n isInt: _isInt.default,\n isIMEI: _isIMEI.default,\n isFloat: _isFloat.default,\n isFloatLocales: _isFloat.locales,\n isDecimal: _isDecimal.default,\n isHexadecimal: _isHexadecimal.default,\n isOctal: _isOctal.default,\n isDivisibleBy: _isDivisibleBy.default,\n isHexColor: _isHexColor.default,\n isRgbColor: _isRgbColor.default,\n isHSL: _isHSL.default,\n isISRC: _isISRC.default,\n isMD5: _isMD.default,\n isHash: _isHash.default,\n isJWT: _isJWT.default,\n isJSON: _isJSON.default,\n isEmpty: _isEmpty.default,\n isLength: _isLength.default,\n isLocale: _isLocale.default,\n isByteLength: _isByteLength.default,\n isUUID: _isUUID.default,\n isMongoId: _isMongoId.default,\n isAfter: _isAfter.default,\n isBefore: _isBefore.default,\n isIn: _isIn.default,\n isLuhnNumber: _isLuhnNumber.default,\n isCreditCard: _isCreditCard.default,\n isIdentityCard: _isIdentityCard.default,\n isEAN: _isEAN.default,\n isISIN: _isISIN.default,\n isISBN: _isISBN.default,\n isISSN: _isISSN.default,\n isMobilePhone: _isMobilePhone.default,\n isMobilePhoneLocales: _isMobilePhone.locales,\n isPostalCode: _isPostalCode.default,\n isPostalCodeLocales: _isPostalCode.locales,\n isEthereumAddress: _isEthereumAddress.default,\n isCurrency: _isCurrency.default,\n isBtcAddress: _isBtcAddress.default,\n isISO6346: _isISO.isISO6346,\n isFreightContainerID: _isISO.isFreightContainerID,\n isISO6391: _isISO2.default,\n isISO8601: _isISO3.default,\n isRFC3339: _isRFC.default,\n isISO31661Alpha2: _isISO31661Alpha.default,\n isISO31661Alpha3: _isISO31661Alpha2.default,\n isISO4217: _isISO4.default,\n isBase32: _isBase.default,\n isBase58: _isBase2.default,\n isBase64: _isBase3.default,\n isDataURI: _isDataURI.default,\n isMagnetURI: _isMagnetURI.default,\n isMailtoURI: _isMailtoURI.default,\n isMimeType: _isMimeType.default,\n isLatLong: _isLatLong.default,\n ltrim: _ltrim.default,\n rtrim: _rtrim.default,\n trim: _trim.default,\n escape: _escape.default,\n unescape: _unescape.default,\n stripLow: _stripLow.default,\n whitelist: _whitelist.default,\n blacklist: _blacklist.default,\n isWhitelisted: _isWhitelisted.default,\n normalizeEmail: _normalizeEmail.default,\n toString: toString,\n isSlug: _isSlug.default,\n isStrongPassword: _isStrongPassword.default,\n isTaxID: _isTaxID.default,\n isDate: _isDate.default,\n isTime: _isTime.default,\n isLicensePlate: _isLicensePlate.default,\n isVAT: _isVAT.default,\n ibanLocales: _isIBAN.locales\n};\nvar _default = validator;\nexports.default = _default;\nmodule.exports = exports.default;\nmodule.exports.default = exports.default;","import { GetAntiForgeryToken, getPortalConfigLogin, LoginAAD, LoginNative, VerifyLoginMethod, LoginViaEmail, CreatePasswordResetMail, VerifyPasswordToken, ChangePasswordByToken, setCookieAuth, CheckSSODirect, GetEntraScopes, msalConfig, ResendLoginViaEmail, AcceptLoginViaEmail, LoginMFACode } from '../apiFunctions/authenticateFunctions';\r\nimport { IConfigLogin, ILoginstatus } from './ddentities';\r\nimport { TextField, PrimaryButton, Stack, Link, mergeStyleSets, loadTheme, IPartialTheme, IPalette, ITextField, IButtonStyles, IStackStyles, Icon } from '@fluentui/react';\r\nimport { AccountInfo, AuthenticationResult, EventMessage, EventType, LogLevel, PublicClientApplication } from '@azure/msal-browser';\r\nimport useStore from \"../apiFunctions/store/store\";\r\nimport usePersistentStore from \"../apiFunctions/store/persistentStore\";\r\nimport { getEndpoints, setEndpoints, GetWorkspaces, getTranslation, usedTexts } from \"documentdrafter-components\";\r\nimport { IUserProps } from './entitiesAPI';\r\nimport validator from \"validator\";\r\nimport { FC, useEffect, useState, createRef } from 'react';\r\nimport { getCustomTheme } from \"documentdrafter-components\";\r\nimport {\r\n Button,\r\n Card,\r\n CardPreview,\r\n CardFooter,\r\n CardHeader,\r\n Divider,\r\n Field,\r\n Input,\r\n Spinner,\r\n themeToTokensObject,\r\n tokens,\r\n typographyStyles,\r\n} from \"@fluentui/react-components\";\r\nimport { CheckmarkCircle20Regular, CheckmarkCircle20Filled } from '@fluentui/react-icons';\r\nimport React from 'react';\r\nimport { Session } from 'inspector';\r\n\r\n\r\ninterface loginProps {\r\n ConfigLogin: IConfigLogin;\r\n Token: string;\r\n SSODirect: string;\r\n LoginType: string;\r\n EmailToken: string;\r\n\r\n}\r\nexport const LoginScreen: React.FC = (props) => {\r\n /* const [companyInfo, setCompanyInfo] = useState(null);*/\r\n const theme = usePersistentStore().currentTheme;\r\n const isDark = usePersistentStore().darkMode;\r\n const customTokens = themeToTokensObject(getCustomTheme(!isDark));\r\n const [loginType, setLoginType] = useState(props.LoginType) //0= native, 1 = azure ad, 2 = SSODirect\r\n /*const [loginUser, setLoginUser] = useState(localStorage.getItem(\"loginUser\") || \"\");*/\r\n const [loginObj, setLoginObj] = useState(null);\r\n const [isAuthenticating, setIsAuthenticating] = useState(false);\r\n const [step, setStep] = useState(0);\r\n const [doNavigate, SetDoNavigate] = useState(null);\r\n\r\n const [userEmail, setUserEmail] = useState(localStorage.getItem(\"loginUser\") || \"\");\r\n const [mfaCode, setMfaCode] = useState(\"\");\r\n const [userPassword, setUserPassword] = useState(\"\");\r\n const [newPassword, setNewPassword] = useState(\"\");\r\n const [currentStep, setCurrentStep] = useState(\"init\");\r\n const [loaderMessage, setLoaderMessage] = useState(sessionStorage.getItem(\"loaderMessage\") || \"Loading...\");\r\n const [errorMessage, setErrorMessage] = useState(\"\");\r\n const [addTokenResponse, setAddTokenResponse] = useState(null);\r\n const isIframed = (top.location != window.location);\r\n\r\n const [loginGuid, setLoginGuid] = useState(null);\r\n const [passwordValid, setPasswordValid] = useState(false);\r\n const isUserAuthenticated = useStore().isUserAuthenticated;\r\n const authenticatedUser = useStore().userObj;\r\n const [entraScopes, setEntraScopes] = useState([]);\r\n\r\n var refusername = createRef();\r\n\r\n var authInProcess = false;\r\n var retries = 0; //prevent infinite loop\r\n var loginRedirectInProgress = false;\r\n\r\n const msalInstance: PublicClientApplication = new PublicClientApplication(msalConfig);\r\n\r\n\r\n\r\n useEffect(() => {\r\n if (doNavigate != null) {\r\n\r\n try {\r\n //const navigate = useNavigate();\r\n //navigate(\"/\", { replace: true });\r\n sessionStorage.removeItem(\"nextUrl\");\r\n sessionStorage.setItem(\"loaderMessage\", \"\");\r\n window.location.href = doNavigate;\r\n //console.log(\"navigation to\" + window.location.href);\r\n\r\n } catch (e) {\r\n console.log(e);\r\n\r\n }\r\n\r\n }\r\n\r\n\r\n\r\n }, [doNavigate]);\r\n\r\n useEffect(() => {\r\n const search = window.location.search;\r\n const params = new URLSearchParams(search);\r\n const nextUrl = params.get(\"nextUrl\");\r\n\r\n if (nextUrl != undefined) {\r\n sessionStorage.setItem(\"nextUrl\", nextUrl);\r\n }\r\n\r\n const setup = async () => {\r\n\r\n\r\n if (isUserAuthenticated) {\r\n } else {\r\n //if (sessionStorage.getItem(\"directSSO\") === \"true\") {\r\n\r\n // if (window.location.href.indexOf(\"#code\")===-1) {\r\n // sessionStorage.removeItem(\"directSSO\");\r\n // setLoaderMessage(\"\");\r\n // setCurrentStep(\"ssoerror\");\r\n // }\r\n\r\n // return;\r\n //}\r\n\r\n //if (props.SSODirect != \"\" && (props.Token === \"\" || props.Token === null)) {\r\n // if (props.SSODirect.toLowerCase() == \"true\") {\r\n // sessionStorage.setItem(\"directSSO\", \"true\")\r\n\r\n // } else if (props.SSODirect.length > 1) {\r\n // location.href = \"/user/oidc/\" + props.SSODirect;\r\n // }\r\n //}\r\n //else {\r\n\r\n // if (window.location.href.indexOf(\"#code\") > -1) {\r\n // //SSO redirect login\r\n // setLoaderMessage(\"Signing in via SSO\");\r\n\r\n // }\r\n // else {\r\n // setCurrentStep(\"email\");\r\n // setLoaderMessage(\"\");\r\n // }\r\n //}\r\n\r\n\r\n await GetAntiForgeryToken();\r\n\r\n\r\n }\r\n }\r\n setup();\r\n\r\n\r\n }, [])\r\n\r\n useEffect(() => {\r\n console.info('currentstep:' + currentStep)\r\n\r\n }, [currentStep])\r\n\r\n useEffect(() => {\r\n\r\n if (loginObj == null) return;\r\n\r\n\r\n if (loginObj.status == \"MFA\") {\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"signin\");\r\n return;\r\n }\r\n\r\n if (loginObj.status == \"MFA1\") {\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"mfacode\");\r\n return;\r\n }\r\n\r\n if (loginObj.status == \"mfainprogress\") {\r\n setLoaderMessage(\"\");\r\n setErrorMessage(\"Not able to verify code, please try again\");\r\n return;\r\n }\r\n\r\n\r\n if (loginObj.status == \"lockedoutuser\") {\r\n setLoaderMessage(\"\");\r\n setErrorMessage(\"Sorry, you do not have access to the system - please contact your IT administrator\");\r\n return;\r\n }\r\n\r\n\r\n if (loginObj.status == \"resetuser\") {\r\n\r\n CreatePasswordResetMail(window.location.hostname, userEmail);\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"reset\");\r\n return;\r\n\r\n\r\n }\r\n\r\n if (loginObj.status == 'verified') {\r\n\r\n sessionStorage.removeItem(\"directSSO\");\r\n\r\n //var nexturl = window.location.search;\r\n //if (nexturl.toLowerCase().indexOf(\"/user/\") > -1) {\r\n // nexturl = \"/\";\r\n //}\r\n\r\n var csrfToken = getCookie(\"RequestVerificationToken\");\r\n\r\n\r\n fetch('/api/session', {\r\n method: 'POST',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'RequestVerificationToken': csrfToken\r\n },\r\n body: JSON.stringify(loginObj.session)\r\n }).then(data => {\r\n sessionStorage.setItem(\"user\", JSON.stringify(loginObj.session));\r\n const newUserObj: IUserProps = {\r\n requestToken: \"\",\r\n userid: \"\",\r\n useremail: loginObj.session.portalUser.Description.email,\r\n username: loginObj.session.portalUser.Description.name,\r\n casenumberRequired: false,\r\n customerName: \"\",\r\n rightslist: loginObj.session.rightslist,\r\n permissions: loginObj.session.permissions,\r\n customerid: loginObj.session.customerid,\r\n guestUser: loginObj.session.portalUser.Groups.indexOf(\"55555555\") > -1,\r\n isPublic: loginObj.session.portalUser.IsPublicUser,\r\n mainUrl: loginObj.session.MainUrl\r\n };\r\n newUserObj.requestToken = loginObj.session.requestToken;\r\n newUserObj.userid = loginObj.session.portalUser.id;\r\n newUserObj.casenumberRequired = loginObj.session.casenumberrequired;\r\n newUserObj.customerName = loginObj.session.customername;\r\n\r\n useStore.setState({ isUserAuthenticated: true, portalConfig: loginObj.PortalConfig });\r\n sessionStorage.setItem(\"config\", JSON.stringify(loginObj.PortalConfig));\r\n\r\n\r\n var portalUrl = window.location.hostname.indexOf('localhost') > -1 ? import.meta.env.VITE_APP_LOCALHOST : window.location.hostname;\r\n\r\n setCookieAuth(\"dd.sec.session\", loginObj.authenticationKey, 1);\r\n\r\n /* sessionStorage.setItem(\"loaderMessage\", \"\");*/\r\n\r\n\r\n getEndpoints(portalUrl).then((endpointsResult) => {\r\n\r\n\r\n useStore.setState({ endpoints: endpointsResult });\r\n setEndpoints(endpointsResult);\r\n useStore.setState({ userObj: newUserObj });\r\n\r\n //GetFolderStructure(authResult).then((dirResult) => {\r\n GetWorkspaces(newUserObj).then((workspacesResult) => {\r\n useStore.setState({ availableWorkspaces: workspacesResult });\r\n\r\n const search = window.location.search;\r\n var nextUrl = sessionStorage.getItem(\"nextUrl\");\r\n if (nextUrl === null || nextUrl === undefined || (nextUrl != undefined && nextUrl.length === 0))\r\n nextUrl = \"/\";\r\n //check if querystring contains the word \"addinload\"\"\r\n if (nextUrl.indexOf(\"addinload\") > -1 || search.indexOf('addinload') > -1 || sessionStorage.getItem(\"addinload\")) {\r\n SetDoNavigate(\"/addinstatus?userid=\" + newUserObj.useremail + \"&customerid=\" + newUserObj.customerid);\r\n sessionStorage.removeItem(\"addinload\");\r\n return;\r\n }\r\n SetDoNavigate(nextUrl);\r\n\r\n\r\n });\r\n });\r\n\r\n //});\r\n\r\n\r\n\r\n\r\n }\r\n ).catch(error => {\r\n\r\n });\r\n } else {\r\n setLoaderMessage(\"\");\r\n\r\n if (loginObj.status === \"unverified\") {\r\n setErrorMessage(\"The user ID or password was incorrect\");\r\n }\r\n else\r\n setErrorMessage(loginObj.status);\r\n\r\n if (document.location.search.indexOf(\"addinload\") > -1 || sessionStorage.getItem(\"addinload\") !== null) {\r\n setStep(0);\r\n } else {\r\n setStep(0);\r\n }\r\n\r\n }\r\n\r\n\r\n\r\n\r\n }, [loginObj])\r\n\r\n\r\n useEffect(() => {\r\n async function handleTokenResponse(response: AuthenticationResult) {\r\n // handle token response\r\n await GetAntiForgeryToken();\r\n sessionStorage.setItem(\"accessToken\", response.accessToken);\r\n localStorage.setItem(\"loginUser\", response.account.username.toLowerCase());\r\n\r\n try {\r\n const graphResponse = await fetch(\"https://graph.microsoft.com/v1.0/me?$select=id,userPrincipalName,displayName,mailNickname,proxyAddresses\", {\r\n method: 'GET',\r\n referrerPolicy: \"origin-when-cross-origin\",\r\n headers: { \"Authorization\": \"Bearer \" + response.accessToken }\r\n });\r\n const result = await graphResponse.json();\r\n\r\n let proxymails = result.proxyAddresses;\r\n let mailNickName = result.mailNickname;\r\n var grps: string[] = [];\r\n\r\n var loginobj = {\r\n email: response.account.username,\r\n mailProxies: proxymails,\r\n mailNickname: mailNickName,\r\n userName: response.account.name,\r\n AADGroups: grps,\r\n AADToken: response.accessToken,\r\n PortalUrl: window.location.hostname.indexOf('localhost') > -1 ? import.meta.env.VITE_APP_LOCALHOST : window.location.hostname\r\n }\r\n\r\n\r\n try {\r\n\r\n var loginResult = await LoginAAD(loginobj);\r\n if (loginResult.status === \"unknownuser\" || loginResult.status === \"lockedoutuser\") {\r\n\r\n //user not active\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"ssoerror\");\r\n return;\r\n }\r\n\r\n\r\n setCookie(\"GMo365\", 1, 365);\r\n setLoginObj(loginResult);\r\n setUserEmail(response.account.username.toLowerCase());\r\n\r\n } catch (error) {\r\n\r\n setErrorMessage('Sorry, not able to login');\r\n }\r\n } catch (error) {\r\n setErrorMessage('Sorry, not able to login an error occured' + error);\r\n\r\n }\r\n };\r\n if (addTokenResponse != null)\r\n handleTokenResponse(addTokenResponse);\r\n\r\n\r\n\r\n }, [addTokenResponse])\r\n\r\n\r\n\r\n function validateEmail(email) {\r\n\r\n return validator.isEmail(email);\r\n }\r\n\r\n\r\n\r\n useEffect(() => {\r\n\r\n const check = async () => {\r\n\r\n\r\n if (loginType === \"1\") {\r\n\r\n if (window.location.href.indexOf(\"#code\") > -1)\r\n return; //handle in main\r\n\r\n let _scopes = await GetEntraScopes();\r\n msalInstance.initialize().then(async () => {\r\n\r\n\r\n if (isIframed) {\r\n\r\n try {\r\n var _res = await msalInstance.ssoSilent({ scopes: _scopes, loginHint: userEmail.toLowerCase() });\r\n setAddTokenResponse(_res);\r\n } catch (e) {\r\n try {\r\n var _response = await msalInstance.handleRedirectPromise();\r\n }\r\n catch (e) {\r\n console.info(e);\r\n }\r\n }\r\n\r\n }\r\n else {\r\n try {\r\n var _response = await msalInstance.handleRedirectPromise();\r\n }\r\n catch (e) {\r\n console.info(e);\r\n }\r\n\r\n }\r\n\r\n\r\n const accounts = msalInstance.getAllAccounts();\r\n if (accounts.length === 0) {\r\n // No user is logged in, so redirect to login\r\n console.info('login redirect to Entra');\r\n loginRedirectInProgress = true;\r\n msalInstance.loginRedirect({ scopes: _scopes, loginHint: userEmail.toLowerCase() });\r\n\r\n }\r\n else {\r\n // User is already logged in\r\n\r\n if (userEmail !== \"\") {\r\n let acc: AccountInfo;\r\n\r\n acc = accounts.find(x => x.username.toLowerCase() === userEmail.toLowerCase());\r\n\r\n //console.info('User is already logged in', acc);\r\n var tokenRequest = await msalInstance.acquireTokenSilent({\r\n scopes: _scopes,\r\n account: acc\r\n });\r\n }\r\n else {\r\n //console.info('User is already logged in', accounts[0]);\r\n var tokenRequest = await msalInstance.acquireTokenSilent({\r\n scopes: _scopes,\r\n account: accounts[0]\r\n });\r\n }\r\n\r\n\r\n setAddTokenResponse(tokenRequest);\r\n\r\n }\r\n });\r\n }\r\n }\r\n\r\n check();\r\n\r\n\r\n }, [loginType])\r\n\r\n function handleState() {\r\n\r\n\r\n\r\n if (currentStep == \"email\" && validateEmail(userEmail)) {\r\n //validate user\r\n VerifyLoginMethod(window.location.hostname, userEmail)\r\n .then((result) => {\r\n\r\n\r\n if (result === \"O365\") {\r\n setLoaderMessage(getTranslation(usedTexts.login.loaderSSO));\r\n sessionStorage.setItem(\"loaderMessage\", getTranslation(usedTexts.login.loaderSSO));\r\n setLoginType(\"1\");\r\n }\r\n else if (result === \"GUEST\") {\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"guest\");\r\n }\r\n else if (result === \"NATIVE\") {\r\n setLoaderMessage(\"\");\r\n\r\n setCurrentStep(\"password\");\r\n\r\n }\r\n else if (result.indexOf(\"https//\") > -1) {\r\n location.href = result;\r\n }\r\n else if (result != \"\") {\r\n //var nextUrl = sessionStorage.getItem(\"nextUrl\");\r\n //if (nextUrl != undefined && nextUrl.length > 1)\r\n // result += \"?nextUrl=\" + encodeURIComponent(nextUrl);\r\n location.href = \"/user/oidc/\" + result;\r\n }\r\n\r\n\r\n })\r\n .catch((error) => {\r\n\r\n });\r\n }\r\n else {\r\n\r\n\r\n }\r\n\r\n }\r\n\r\n\r\n\r\n\r\n\r\n useEffect(() => {\r\n\r\n const init = async () => {\r\n\r\n if (loginRedirectInProgress)\r\n return;\r\n\r\n\r\n\r\n await GetAntiForgeryToken();\r\n let _scopes = await GetEntraScopes();\r\n setEntraScopes(_scopes);\r\n\r\n\r\n\r\n let tokenObtained = false;\r\n\r\n //console.info('init....')\r\n\r\n\r\n if (props.Token != null) {\r\n //change password link\r\n var tokenValidation = VerifyPasswordToken(props.Token).then((result) => {\r\n setUserEmail(result);\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"newPassword\");\r\n\r\n })\r\n }\r\n else if (props.EmailToken != null && props.EmailToken != \"\") {\r\n try {\r\n var loginValidation = await AcceptLoginViaEmail(props.EmailToken);\r\n if (loginValidation.status === \"verified\") {\r\n setLoginObj(loginValidation);\r\n return;\r\n }\r\n else {\r\n setCurrentStep(\"emailTokenError\");\r\n setLoaderMessage(\"\");\r\n return;\r\n }\r\n }\r\n catch (e) {\r\n setCurrentStep(\"emailTokenError\");\r\n setLoaderMessage(\"\");\r\n return;\r\n }\r\n\r\n }\r\n else if (doNavigate != null) {\r\n\r\n }\r\n else {\r\n\r\n var directADD = localStorage.getItem(\"directADD\");\r\n if (window.location.href.indexOf(\"directADD\") > -1) {\r\n directADD = \"true\";\r\n }\r\n\r\n\r\n if (directADD !== undefined && directADD === \"true\") {\r\n setLoaderMessage(getTranslation(usedTexts.login.loaderSSO));\r\n localStorage.setItem(\"directADD\", \"true\");\r\n\r\n if (userEmail === \"\") {\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"email\");\r\n return;\r\n }\r\n else {\r\n setLoginType(\"1\");\r\n }\r\n\r\n\r\n }\r\n else {\r\n\r\n if (sessionStorage.getItem(\"directSSO\") === \"true\") {\r\n\r\n if (window.location.href.indexOf(\"#code\") === -1) {\r\n sessionStorage.removeItem(\"directSSO\");\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"ssoerror\");\r\n return;\r\n }\r\n }\r\n\r\n if (props.SSODirect != \"\" && (props.Token === \"\" || props.Token === null)) {\r\n if (props.SSODirect.toLowerCase() == \"true\") {\r\n sessionStorage.setItem(\"directSSO\", \"true\")\r\n\r\n } else if (props.SSODirect.length > 1) {\r\n location.href = \"/user/oidc/\" + props.SSODirect;\r\n return;\r\n }\r\n }\r\n\r\n if (loginType === \"0\" && window.location.href.indexOf(\"#code\") === -1) {\r\n //email login\r\n setLoaderMessage(\"\");\r\n setCurrentStep(\"email\");\r\n return;\r\n }\r\n\r\n }\r\n\r\n\r\n\r\n setLoaderMessage(getTranslation(usedTexts.login.loaderSSO));\r\n msalInstance.initialize().then(async () => {\r\n try {\r\n var _res = await msalInstance.ssoSilent({ scopes: _scopes, loginHint: userEmail.toLowerCase() });\r\n if (_res != null) {\r\n setAddTokenResponse(_res);\r\n return true;\r\n }\r\n } catch (e) {\r\n\r\n var _res = await msalInstance.handleRedirectPromise();\r\n if (_res != null) {\r\n setAddTokenResponse(_res);\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n\r\n\r\n }).then(async (isDone: boolean) => {\r\n try {\r\n if (!isDone)\r\n return;\r\n\r\n const accounts = msalInstance.getAllAccounts();\r\n\r\n if (accounts === undefined || accounts.length === 0) {\r\n console.info('No accounts loaded, redirect');\r\n //redirect to login no accounts loaded\r\n\r\n await msalInstance.loginRedirect({ scopes: _scopes, loginHint: userEmail.toLowerCase() });\r\n\r\n return;\r\n\r\n }\r\n cachedAccount = accounts.find(x => x.username.toLowerCase() === userEmail.toLowerCase());\r\n\r\n var tokenResponse = await msalInstance.acquireTokenSilent({\r\n scopes: _scopes,\r\n account: cachedAccount\r\n });\r\n\r\n if (authInProcess)\r\n return;\r\n\r\n if (tokenResponse !== null && !isAuthenticating) {\r\n tokenObtained = true;\r\n setIsAuthenticating(true);\r\n // handle token response\r\n\r\n setAddTokenResponse(tokenResponse);\r\n /*await handleTokenResponse(tokenResponse);*/\r\n\r\n return;\r\n }\r\n else {\r\n /*setLoaderMessage(\"\");*/\r\n authInProcess = false;\r\n // handle error case\r\n }\r\n\r\n if (tokenObtained)\r\n return;\r\n\r\n if (!authInProcess) {\r\n\r\n if (loginType === \"1\" && accounts.length > 0 && userEmail != \"\" && accounts.find(x => x.username.toLowerCase() === userEmail.toLowerCase() != undefined)) {\r\n var cachedAccount = accounts.find(x => x.username.toLowerCase() === userEmail.toLowerCase());\r\n //user found in cache\r\n //trying to get it from cache \r\n setLoaderMessage(getTranslation(usedTexts.login.loaderSSO));\r\n sessionStorage.setItem(\"loaderMessage\", getTranslation(usedTexts.login.loaderSSO));\r\n\r\n msalInstance.acquireTokenSilent({\r\n scopes: _scopes,\r\n account: cachedAccount\r\n }).then(async response => {\r\n console.info('login silent response', response);\r\n setAddTokenResponse(response);\r\n //authInProcess = true;\r\n ///*await handleTokenResponse(response);*/\r\n // Use the token to call Microsoft Graph API\r\n }).catch(error => {\r\n console.info('login silent error', error);\r\n authInProcess = false;\r\n setLoaderMessage(error);\r\n sessionStorage.setItem(\"loaderMessage\", \"\");\r\n\r\n // Handle failure, possibly invoke interactive method\r\n });\r\n } else if (loginType === \"1\" && userEmail !== \"\") {\r\n //try login using Active Directory\r\n console.info('try login using Active Directory');\r\n setLoaderMessage(getTranslation(usedTexts.login.loaderSSO));\r\n sessionStorage.setItem(\"loaderMessage\", getTranslation(usedTexts.login.loaderSSO));\r\n // No cached user, prompt for login\r\n\r\n msalInstance.loginRedirect().then(fulfilled => {\r\n console.info('login redirect fulfilled', fulfilled);\r\n\r\n }).catch(error => {\r\n if (error.errorCode === \"interaction_in_progress\") {\r\n console.info(\"please wait for current request\")\r\n }\r\n });\r\n\r\n }\r\n else {\r\n\r\n }\r\n }\r\n\r\n } catch (e) {\r\n console.info(e);\r\n if (e.includes(\"interaction_in_progress\")) {\r\n return;\r\n }\r\n try {\r\n retries++;\r\n if (retries < 5) {\r\n\r\n await msalInstance.loginRedirect();\r\n return;\r\n }\r\n } catch (e) {\r\n\r\n }\r\n\r\n\r\n console.log('avs', e);\r\n setLoaderMessage(\"Err:\" + e);\r\n authInProcess = false;\r\n\r\n\r\n }\r\n\r\n })\r\n\r\n\r\n }\r\n }\r\n init();\r\n\r\n\r\n }, []);\r\n\r\n\r\n\r\n\r\n function setCookie(cname, cvalue, exdays) {\r\n var d = new Date();\r\n d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000));\r\n var expires = \"expires=\" + d.toUTCString();\r\n document.cookie = cname + \"=\" + cvalue + \";\" + expires + \";path=/\";\r\n }\r\n\r\n function getCookie(cname) {\r\n var name = cname + \"=\";\r\n var decodedCookie = decodeURIComponent(document.cookie);\r\n var ca = decodedCookie.split(';');\r\n for (var i = 0; i < ca.length; i++) {\r\n var c = ca[i];\r\n while (c.charAt(0) == ' ') {\r\n c = c.substring(1);\r\n }\r\n if (c.indexOf(name) == 0) {\r\n return c.substring(name.length, c.length);\r\n }\r\n }\r\n return \"\";\r\n }\r\n function GetSetLoginState(newState, force) {\r\n var state = \"one\";\r\n\r\n if (force == true) {\r\n setCookie(\"loginState\", newState, 0.1);\r\n state = newState;\r\n }\r\n else {\r\n if (getCookie(\"loginState\") != \"\") {\r\n state = getCookie(\"loginState\");\r\n\r\n }\r\n else {\r\n setCookie(\"loginState\", newState, 0.1);\r\n state = newState;\r\n }\r\n }\r\n\r\n return state;\r\n }\r\n\r\n\r\n\r\n\r\n\r\n const classNames = mergeStyleSets({\r\n container: {\r\n display: 'flex',\r\n justifyContent: 'center',\r\n alignItems: 'center',\r\n height: '100vh',\r\n backgroundColor: '#f3f2f1', // Replace with your theme color\r\n },\r\n box: {\r\n padding: '20px',\r\n backgroundColor: 'white', // Replace with your theme color\r\n boxShadow: '0 4px 8px 0 rgba(0,0,0,0.2)',\r\n borderRadius: '5px',\r\n maxWidth: '400px',\r\n width: '100%',\r\n },\r\n header: {\r\n marginBottom: '20px',\r\n textAlign: 'center',\r\n },\r\n logo: {\r\n width: '100px',\r\n height: '100px',\r\n marginBottom: '20px',\r\n // Add styles for your logo here\r\n },\r\n });\r\n\r\n function isPasswordComplex(complexitypassword: number, pass: string): boolean {\r\n\r\n let isPasswordComplex = false;\r\n const passwithoutSpecials = pass.replace(/[^a-zA-Z0-9 ]/g, \"\");\r\n\r\n switch (complexitypassword) {\r\n case 0:\r\n isPasswordComplex = true;\r\n break;\r\n case 1:\r\n isPasswordComplex = (pass.match(/[a-zA-Z]/g)?.length > 0 && pass.match(/[0-9]/g)?.length > 0);\r\n break;\r\n case 2:\r\n isPasswordComplex = (pass.match(/[a-zA-Z]/g)?.length > 0 && pass.match(/[0-9]/g)?.length > 0 && pass !== passwithoutSpecials);\r\n break;\r\n case 3:\r\n isPasswordComplex = (pass.match(/[a-z]/g)?.length > 0 && pass.match(/[A-Z]/g)?.length > 0 && pass.match(/[0-9]/g)?.length > 0);\r\n break;\r\n case 4:\r\n isPasswordComplex = (pass.match(/[a-z]/g)?.length > 0 && pass.match(/[A-Z]/g)?.length > 0 && pass.match(/[0-9]/g)?.length > 0 && pass !== passwithoutSpecials);\r\n break;\r\n default:\r\n isPasswordComplex = true;\r\n break;\r\n }\r\n return isPasswordComplex;\r\n }\r\n\r\n function getComplexityText(complexitypassword: number): string {\r\n\r\n var returnText = \"\";\r\n\r\n\r\n switch (complexitypassword) {\r\n case 0:\r\n returnText = \"No restrictions\";\r\n break;\r\n case 1:\r\n returnText = \"Numbers and letters\";\r\n\r\n break;\r\n case 2:\r\n returnText = \"Numbers and letters and special characters\";\r\n\r\n break;\r\n case 3:\r\n returnText = \"Numbers and uppercase and lowercase letters\";\r\n break;\r\n case 4:\r\n returnText = \"Numbers and uppercase and lowercase letters and special characters\";\r\n break;\r\n default:\r\n\r\n break;\r\n }\r\n return returnText;\r\n\r\n }\r\n\r\n interface IPasswordChecker {\r\n password: string\r\n }\r\n\r\n\r\n\r\n\r\n\r\n const PasswordChecker: React.FC = (check) => {\r\n var validateComplexity = isPasswordComplex(props.ConfigLogin.config.Security.complexitypassword, check.password);\r\n var validateLength = check.password.length >= props.ConfigLogin.config.Security.minlengthpassword;\r\n\r\n return (\r\n
\r\n
\r\n\r\n\r\n\r\n
\r\n {!validateLength ? :\r\n }\r\n
\r\n
\r\n More than {props.ConfigLogin.config.Security.minlengthpassword} characters\r\n
\r\n
\r\n\r\n\r\n\r\n
\r\n\r\n\r\n
\r\n {!validateComplexity ? :\r\n }\r\n\r\n
\r\n
\r\n {getComplexityText(props.ConfigLogin.config.Security.complexitypassword)}\r\n
\r\n\r\n
\r\n
\r\n )\r\n\r\n {/*}*/ }\r\n {/* iconPosition=\"before\"*/ }\r\n {/* style={{*/ }\r\n {/* paddingLeft: '20px', // Adjust as needed to align icons*/ }\r\n {/* textAlign: 'left', // Aligns text to the left*/ }\r\n {/* }}*/ }\r\n {/*>*/ }\r\n {/* {getComplexityText(props.ConfigLogin.config.Security.complexitypassword)} */ }\r\n {/**/ }\r\n\r\n\r\n\r\n\r\n }\r\n\r\n\r\n useEffect(() => {\r\n\r\n if (newPassword == \"\") setPasswordValid(false);\r\n if (newPassword.length > 0) {\r\n var validateComplexity = isPasswordComplex(props.ConfigLogin.config.Security.complexitypassword, newPassword);\r\n var validateLength = newPassword.length >= props.ConfigLogin.config.Security.minlengthpassword;\r\n\r\n if (validateComplexity && validateLength) setPasswordValid(true);\r\n else setPasswordValid(false);\r\n\r\n }\r\n\r\n }, [newPassword]);\r\n\r\n\r\n\r\n let logoHeight = \"40px\";\r\n if (props.ConfigLogin.config?.loginLogoHeight?.length) {\r\n logoHeight = props.ConfigLogin.config.loginLogoHeight;\r\n if (logoHeight.indexOf(\"px\") < 0)\r\n logoHeight += \"px\";\r\n }\r\n\r\n let logoMarginTop = \"0px\";\r\n if (props.ConfigLogin.config?.loginLogoTopMargin?.length) {\r\n logoMarginTop = props.ConfigLogin.config.loginLogoTopMargin;\r\n if (logoMarginTop.indexOf(\"px\") < 0)\r\n logoMarginTop += \"px\";\r\n }\r\n\r\n function getLogo() {\r\n if (isDark) {\r\n if (props.ConfigLogin.config?.loginLogoPathDark?.length)\r\n return (\r\n \r\n )\r\n\r\n }\r\n else {\r\n if (props.ConfigLogin.config?.loginLogoPath?.length)\r\n return (\r\n \r\n )\r\n }\r\n\r\n return null\r\n }\r\n\r\n\r\n return (\r\n <>\r\n\r\n \r\n \r\n \r\n\r\n {loaderMessage ? (\r\n
\r\n \r\n\r\n \r\n {loaderMessage}\r\n
\r\n \r\n ) : (\r\n\r\n <>\r\n {currentStep === \"init\" && (\r\n <>\r\n
\r\n \r\n\r\n \r\n Please Wait\r\n
\r\n \r\n \r\n )}\r\n {currentStep === \"emailTokenError\" && (\r\n <>\r\n
\r\n
\r\n Link expired\r\n
\r\n
\r\n This is a temporary link and can only be used once. Please click the button below to login again.\r\n
\r\n
\r\n \r\n
\r\n {\r\n setErrorMessage(\"\");\r\n setCurrentStep(\"email\");\r\n handleState();\r\n\r\n }}\r\n >\r\n Login\r\n \r\n\r\n\r\n
\r\n
\r\n\r\n\r\n\r\n \r\n )\r\n }\r\n {currentStep === \"ssoerror\" && (\r\n <>\r\n
\r\n\r\n\r\n \r\n Sorry we could not log you in direct. Please contact your administrator\r\n
\r\n \r\n \r\n )}\r\n\r\n {currentStep === \"email\" && (\r\n <>\r\n\r\n\r\n \r\n {getTranslation(usedTexts.login.signIn)}\r\n \r\n\r\n {\r\n let enteredValue = v.value.trim().toLowerCase();\r\n setUserEmail(enteredValue);\r\n localStorage.setItem(\"loginUser\", enteredValue);\r\n }}\r\n onKeyDown={(e) => {\r\n if (e.key === \"Enter\" && userEmail) {\r\n setLoaderMessage(getTranslation(usedTexts.login.verifySignIn));\r\n handleState();\r\n }\r\n }}\r\n ref={refusername}\r\n defaultValue={userEmail}\r\n placeholder={getTranslation(usedTexts.login.emailPlaceHolder)}\r\n autoFocus={true}\r\n style={{ width: \"100%\" }}\r\n />\r\n\r\n\r\n \r\n {\r\n // This is how we mimic the loader/fetching\r\n setLoaderMessage(getTranslation(usedTexts.login.verifySignIn));\r\n handleState();\r\n }}\r\n >\r\n {getTranslation(usedTexts.shared.next)}\r\n \r\n \r\n \r\n )}\r\n\r\n {currentStep === \"mfacode\" && (\r\n <>\r\n\r\n\r\n \r\n {getTranslation(usedTexts.login.mfaCodeTitle)}\r\n \r\n\r\n {\r\n let enteredValue = v.value.trim().toLowerCase();\r\n setMfaCode(enteredValue);\r\n\r\n }}\r\n onKeyDown={async (e) => {\r\n if (e.key === \"Enter\" && mfaCode) {\r\n setLoaderMessage(\"Verifying MFA code\");\r\n var result = await LoginMFACode(window.location.hostname, userEmail, userPassword, mfaCode);\r\n setErrorMessage(\"\");\r\n setLoginObj(result);\r\n }\r\n }}\r\n ref={refusername}\r\n defaultValue={mfaCode}\r\n placeholder={getTranslation(usedTexts.login.mfaCodePlaceHolder)}\r\n autoFocus={true}\r\n style={{ width: \"100%\" }}\r\n />\r\n {errorMessage && {errorMessage}\r\n \r\n }\r\n\r\n \r\n
\r\n {\r\n // This is how we mimic the loader/fetching\r\n setLoaderMessage(\"Verifying MFA code\");\r\n var result = await LoginMFACode(window.location.hostname, userEmail, userPassword, mfaCode);\r\n setErrorMessage(\"\");\r\n setLoginObj(result);\r\n\r\n }}\r\n >\r\n {getTranslation(usedTexts.shared.next)}\r\n \r\n\r\n {\r\n setUserPassword(\"\");\r\n setErrorMessage(\"\");\r\n setCurrentStep(\"password\");\r\n }}\r\n >\r\n {getTranslation(usedTexts.shared.back)}\r\n \r\n
\r\n
\r\n \r\n )}\r\n\r\n {currentStep === \"password\" && (\r\n <>\r\n
\r\n \r\n {getTranslation(usedTexts.login.enterPasswordTitle)}\r\n
\r\n\r\n {\r\n setUserPassword(v.value);\r\n }}\r\n onKeyDown={async (e) => {\r\n if (e.key === \"Enter\" && userPassword) {\r\n // This is how we mimic the loader/fetching\r\n setLoaderMessage(getTranslation(usedTexts.login.signingIn));\r\n var result = await LoginNative(window.location.hostname, userEmail, userPassword);\r\n setErrorMessage(\"\");\r\n setLoginObj(result);\r\n }\r\n }}\r\n autoFocus={true}\r\n placeholder={getTranslation(usedTexts.login.enterPasswordPlaceHolder)}\r\n style={{ width: \"100%\" }}\r\n\r\n />\r\n \r\n {errorMessage && {errorMessage}\r\n \r\n }\r\n {\r\n var result = await CreatePasswordResetMail(window.location.hostname, userEmail);\r\n setCurrentStep(\"reset\");\r\n setErrorMessage(\"\");\r\n\r\n }}\r\n >\r\n {getTranslation(usedTexts.login.forgotPassword)}\r\n \r\n\r\n \r\n
\r\n {\r\n // This is how we mimic the loader/fetching\r\n\r\n\r\n setLoaderMessage(getTranslation(usedTexts.login.signingIn));\r\n var result = await LoginNative(window.location.hostname, userEmail, userPassword);\r\n setErrorMessage(\"\");\r\n setLoginObj(result);\r\n\r\n\r\n\r\n }}\r\n >\r\n {getTranslation(usedTexts.login.signIn)}\r\n \r\n\r\n {\r\n setUserPassword(\"\");\r\n setErrorMessage(\"\");\r\n setCurrentStep(\"email\");\r\n }}\r\n >\r\n {getTranslation(usedTexts.shared.back)}\r\n \r\n\r\n {!props.ConfigLogin.config.Security.mfa &&
\r\n\r\n \r\n {getTranslation(usedTexts.login.orSignInWithoutPassword)}\r\n \r\n\r\n \r\n
}\r\n
\r\n
\r\n \r\n )}\r\n\r\n {currentStep === \"signin\" && (\r\n <>\r\n
\r\n
\r\n {getTranslation(usedTexts.login.signInTitle)}\r\n
\r\n
\r\n {getTranslation(usedTexts.login.signInText, {userEmail})}\r\n
\r\n
\r\n \r\n
\r\n {/* {*/}\r\n {/* var oldGuid = loginGuid;*/}\r\n {/* setLoginGuid(\"\"); */}\r\n {/* var result = await ResendLoginViaEmail(loginGuid);*/}\r\n {/* if (result.status === \"Ok\")*/}\r\n {/* {*/}\r\n {/* setLoginGuid(oldGuid);*/}\r\n {/* //mail sent*/}\r\n\r\n {/* }*/}\r\n {/* if (result.status === \"UID not present\") {*/}\r\n {/* setCurrentStep(\"email\");*/}\r\n {/* setLoginGuid(\"\");*/}\r\n {/* } */}\r\n {/* if (result.status === \"Key has expired\") {*/}\r\n {/* setCurrentStep(\"email\");*/}\r\n {/* setLoginGuid(\"\");*/}\r\n\r\n {/* }*/}\r\n\r\n\r\n\r\n {/* }}*/}\r\n\r\n {/*>*/}\r\n {/* Resend email*/}\r\n {/**/}\r\n\r\n {\r\n setUserPassword(\"\");\r\n setErrorMessage(\"\");\r\n setCurrentStep(\"password\");\r\n }}\r\n >\r\n Back\r\n \r\n
\r\n
\r\n \r\n )}\r\n\r\n {currentStep === \"reset\" && (\r\n <>\r\n
\r\n
\r\n {getTranslation(usedTexts.login.resetTitle)}\r\n
\r\n
\r\n {getTranslation(usedTexts.login.resetText, {userEmail})}\r\n
\r\n
\r\n \r\n
\r\n {\r\n // handle here\r\n var result = await CreatePasswordResetMail(window.location.hostname, userEmail);\r\n setCurrentStep(\"reset\");\r\n\r\n }}\r\n >\r\n {getTranslation(usedTexts.login.resendEmail)}\r\n \r\n\r\n {\r\n setUserPassword(\"\");\r\n setCurrentStep(\"password\");\r\n }}\r\n >\r\n {getTranslation(usedTexts.shared.back)}\r\n \r\n
\r\n
\r\n \r\n )}\r\n\r\n {currentStep === \"newPassword\" && (\r\n <>\r\n
\r\n \r\n {getTranslation(usedTexts.login.newPasswordTitle)}\r\n
\r\n\r\n {\r\n setNewPassword(v.value);\r\n }}\r\n onKeyDown={async (e) => {\r\n if (e.key === \"Enter\" && newPassword) {\r\n // This is how we mimic the loader/fetching\r\n setLoaderMessage(getTranslation(usedTexts.login.newPassworUpdateText));\r\n try {\r\n var ok = await ChangePasswordByToken(window.location.hostname, userEmail, props.Token, newPassword);\r\n setLoaderMessage(\"\");\r\n setNewPassword(\"\");\r\n setCurrentStep(\"success\");\r\n } catch (e) {\r\n setLoaderMessage(getTranslation(usedTexts.login.newPasswordUpdateError));\r\n }\r\n\r\n }\r\n }}\r\n placeholder={getTranslation(usedTexts.login.newPasswordPlaceHolder)}\r\n style={{ width: \"100%\" }}\r\n />\r\n
\r\n \r\n\r\n\r\n
\r\n\r\n\r\n \r\n\r\n \r\n {\r\n // This is how we mimic the loader/fetching\r\n setLoaderMessage(getTranslation(usedTexts.login.newPassworUpdateText));\r\n try {\r\n var ok = await ChangePasswordByToken(window.location.hostname, userEmail, props.Token, newPassword);\r\n setLoaderMessage(\"\");\r\n setNewPassword(\"\");\r\n setCurrentStep(\"success\");\r\n } catch (e) {\r\n setLoaderMessage(getTranslation(usedTexts.login.newPasswordUpdateError));\r\n }\r\n }}\r\n style={{ width: \"100%\" }}\r\n >\r\n Next\r\n \r\n \r\n \r\n )}\r\n\r\n {currentStep === \"guest\" && (\r\n <>\r\n
{getTranslation(usedTexts.login.signIn)}
\r\n
{getTranslation(usedTexts.login.noUserWithThatName)}
\r\n\r\n \r\n
\r\n {\r\n setCurrentStep(\"email\");\r\n }}\r\n >\r\n {getTranslation(usedTexts.shared.tryAgain)}\r\n \r\n
\r\n
\r\n \r\n )}\r\n\r\n {currentStep === \"success\" && (\r\n <>\r\n
{getTranslation(usedTexts.login.newPasswordUpdateSuccessTitle)}
\r\n
{getTranslation(usedTexts.login.newPasswordUpdateSuccessText)}
\r\n\r\n \r\n
\r\n {\r\n setCurrentStep(\"password\");\r\n }}\r\n >\r\n {getTranslation(usedTexts.login.signIn)}\r\n \r\n
\r\n
\r\n \r\n )}\r\n \r\n )}\r\n \r\n \r\n\r\n\r\n \r\n );\r\n}\r\n\r\n\r\n"],"names":["unexpectedError","postRequestFailed","AuthErrorMessages","AuthError","errorCode","errorMessage","suberror","errorString","Constants","correlationId","createAuthError","code","additionalMessage","clientInfoDecodingError","clientInfoEmptyError","tokenParsingError","nullOrEmptyToken","endpointResolutionError","networkError","openIdConfigError","hashNotDeserialized","invalidState","stateMismatch","stateNotFound","nonceMismatch","authTimeNotFound","maxAgeTranspired","multipleMatchingTokens","multipleMatchingAccounts","multipleMatchingAppMetadata","requestCannotBeMade","cannotRemoveEmptyScope","cannotAppendScopeSet","emptyInputScopeSet","deviceCodePollingCancelled","deviceCodeExpired","deviceCodeUnknownError","noAccountInSilentRequest","invalidCacheRecord","invalidCacheEnvironment","noAccountFound","noCryptoObject","unexpectedCredentialType","invalidAssertion","invalidClientCredential","tokenRefreshRequired","userTimeoutReached","tokenClaimsCnfRequiredForSignedJwt","authorizationCodeMissingFromServerResponse","bindingKeyNotRemoved","endSessionEndpointNotSupported","keyIdMissing","noNetworkConnectivity","userCanceled","missingTenantIdError","methodNotImplemented","nestedAppAuthBridgeDisabled","ClientAuthErrorMessages","ClientAuthError","createClientAuthError","extractTokenClaims","encodedToken","base64Decode","jswPayload","getJWSPayload","base64Decoded","authToken","matches","checkMaxAge","authTime","maxAge","AuthorityType","isOpenIdConfigResponse","response","redirectUriEmpty","claimsRequestParsingError","authorityUriInsecure","urlParseError","urlEmptyError","emptyInputScopesError","invalidPromptValue","invalidClaims","tokenRequestEmpty","logoutRequestEmpty","invalidCodeChallengeMethod","pkceParamsMissing","invalidCloudDiscoveryMetadata","invalidAuthorityMetadata","untrustedAuthority","missingSshJwk","missingSshKid","missingNonceAuthenticationHeader","invalidAuthenticationHeader","cannotSetOIDCOptions","cannotAllowNativeBroker","authorityMismatch","ClientConfigurationErrorMessages","ClientConfigurationError","createClientConfigurationError","StringUtils","strObj","obj","str","search","query","params","decode","s","pair","key","value","arr","entry","pattern","input","stripLeadingHashOrQuery","responseString","getDeserializedResponse","normalizedResponse","deserializedHash","UrlString","url","lowerCaseUrl","components","queryString","tenantId","urlObject","pathArray","AADAuthorityConstants","regEx","match","urlComponents","pathSegments","val","relativeUrl","baseUrl","baseComponents","rawMetdataJSON","EndpointMetadata","InstanceDiscoveryMetadata","InstanceDiscoveryMetadataAliases","metadataEntry","alias","getAliasesFromStaticSources","staticAuthorityOptions","logger","staticAliases","canonicalAuthority","authorityHost","getAliasesFromMetadata","_a","AuthorityMetadataSource","cloudDiscoveryMetadata","source","metadata","getCloudDiscoveryMetadataFromNetworkResponse","getCloudDiscoveryMetadataFromHardcodedValues","i","ProtocolMode","AzureCloudInstance","isCloudInstanceDiscoveryResponse","isCloudInstanceDiscoveryErrorResponse","PerformanceEvents","PerformanceEventStatus","invoke","callback","eventName","telemetryClient","args","inProgressEvent","eventCount","result","e","invokeAsync","RegionDiscovery","networkInterface","performanceClient","environmentRegion","regionDiscoveryMetadata","autodetectedRegionName","RegionDiscoverySources","options","localIMDSVersionResponse","ResponseCodes","currentIMDSVersion","currentIMDSVersionResponse","version","nowSeconds","isTokenExpired","expiresOn","offset","expirationSec","wasClockTurnedBack","cachedAt","generateCredentialKey","credentialEntity","generateAccountId","generateCredentialId","generateTarget","generateClaimsHash","generateScheme","Separators","createIdTokenEntity","homeAccountId","environment","idToken","clientId","CredentialType","createAccessTokenEntity","accessToken","scopes","extExpiresOn","refreshOn","tokenType","userAssertionHash","keyId","requestedClaims","requestedClaimsHash","atEntity","AuthenticationScheme","tokenClaims","_b","createRefreshTokenEntity","refreshToken","familyId","rtEntity","isCredentialEntity","entity","isAccessTokenEntity","isIdTokenEntity","isRefreshTokenEntity","clientOrFamilyId","isServerTelemetryEntity","validateKey","SERVER_TELEM_CONSTANTS","validateEntity","isThrottlingEntity","ThrottlingConstants","generateAppMetadataKey","APP_METADATA","isAppMetadataEntity","isAuthorityMetadataEntity","AUTHORITY_METADATA_CONSTANTS","generateAuthorityMetadataExpiresAt","updateAuthorityEndpointMetadata","authorityMetadata","updatedValues","fromNetwork","updateCloudDiscoveryMetadata","isAuthorityMetadataExpired","Authority","authority","cacheManager","authorityOptions","managedIdentity","authorityUri","urlString","endpoint","cachedAuthorityUrlComponents","cachedAuthorityParts","currentPart","index","cachedPart","canonicalAuthorityHost","metadataEntity","cloudDiscoverySource","endpointSource","endpointMetadataResult","cacheKey","localMetadata","hardcodedMetadata","_c","configMetadata","metadataEntityExpired","openIdConfigurationEndpoint","userConfiguredAzureRegion","RegionDiscoveryOutcomes","localMetadataSource","parsedResponse","instanceDiscoveryEndpoint","typedResponseBody","error","typedError","authorityString","azureCloudOptions","authorityAzureCloudInstance","tenant","host","region","authorityUrlInstance","authorityUrlParts","hostNameAndPort","azureRegion","regionalMetadata","ciamAuthority","authorityUrlComponents","tenantIdOrDomain","getTenantFromAuthorityString","formatAuthorityUri","buildStaticAuthorityOptions","authOptions","rawCloudDiscoveryMetadata","createDiscoveredInstance","networkClient","authorityUriFinal","acquireTokenAuthority","getClientAssertion","clientAssertion","tokenEndpoint","CLIENT_ID","REDIRECT_URI","RESPONSE_TYPE","RESPONSE_MODE","GRANT_TYPE","CLAIMS","SCOPE","REFRESH_TOKEN","STATE","NONCE","PROMPT","CODE","CODE_CHALLENGE","CODE_CHALLENGE_METHOD","CODE_VERIFIER","CLIENT_REQUEST_ID","X_CLIENT_SKU","X_CLIENT_VER","X_CLIENT_OS","X_CLIENT_CPU","X_CLIENT_CURR_TELEM","X_CLIENT_LAST_TELEM","X_MS_LIB_CAPABILITY","X_APP_NAME","X_APP_VER","POST_LOGOUT_URI","ID_TOKEN_HINT","DEVICE_CODE","CLIENT_SECRET","CLIENT_ASSERTION","CLIENT_ASSERTION_TYPE","TOKEN_TYPE","REQ_CNF","OBO_ASSERTION","REQUESTED_TOKEN_USE","RETURN_SPA_CODE","NATIVE_BROKER","LOGOUT_HINT","SID","LOGIN_HINT","DOMAIN_HINT","DEFAULT_CRYPTO_IMPLEMENTATION","name","ScopeSet","inputScopes","scopeArr","filteredInput","scope","inputScopeString","scopeSet","lowerCaseScopes","lowerCaseScopesSet","defaultScopeCount","OIDC_SCOPES","defaultScope","newScope","newScopes","otherScopes","unionScopes","sizeOtherScopes","sizeThisScopes","array","buildClientInfo","rawClientInfo","decodedClientInfo","buildClientInfoFromHomeAccountId","clientInfoParts","tenantIdMatchesHomeTenant","buildTenantProfile","localAccountId","idTokenClaims","oid","sub","tid","tfp","acr","updateAccountTenantProfileData","baseAccountInfo","tenantProfile","idTokenSecret","updatedAccountInfo","isHomeTenant","tenantProfileOverride","claimsSourcedTenantProfile","getTenantIdFromIdTokenClaims","AccountEntity","accountInterface","homeTenantId","accountDetails","account","CacheAccountType","clientInfo","env","preferredUsername","_d","email","_e","_f","accountInfo","cloudGraphHostName","msGraphHost","serverClientInfo","authType","cryptoObj","accountA","accountB","compareClaims","claimsMatch","accountAClaims","accountBClaims","cacheQuotaExceededErrorCode","cacheUnknownErrorCode","CacheErrorMessages","CacheError","message","CacheManager","cryptoImpl","accountFilter","allAccounts","accountEntities","cachedAccounts","accountEntity","tokenKeys","tenantProfileFilter","tenantedAccountInfo","targetTenantId","searchTenantProfiles","matchingTenantProfiles","cacheRecord","storeInCache","credential","accessTokenFilter","currentScopes","removedAccessTokens","tokenEntity","allAccountKeys","matchingAccounts","lowerCaseKey","clientIdValidation","familyIdValidation","THE_FAMILY_ID","filter","allCacheKeys","matchingAppMetadata","matchedEntity","removedAccounts","accountKey","allTokenKeys","accountId","removedCredentials","matchingAccountKeys","accountsToMerge","baseAccount","updatedAccount","newAccountKey","kid","targetRealm","idTokenFilter","idTokenMap","numIdTokens","tokensToBeRemoved","homeIdTokenMap","numHomeIdTokens","idTokenKeys","idTokens","inputKey","request","authScheme","credentialType","accessTokenKeys","accessTokens","numAccessTokens","keyMustContainAllScopes","familyRT","id","refreshTokenFilter","refreshTokenKeys","refreshTokens","numRefreshTokens","appMetadataFilter","appMetadata","appMetadataEntries","numAppMetadata","idTokenLocalAccountId","claims","cachedUsername","filterUsername","cloudMetadata","realm","nativeAccountId","loginHint","sid","authorityType","target","json","propertyName","DefaultStorageClass","DEFAULT_SYSTEM_OPTIONS","DEFAULT_TOKEN_RENEWAL_OFFSET_SEC","DEFAULT_LOGGER_IMPLEMENTATION","LogLevel","DEFAULT_CACHE_OPTIONS","DEFAULT_NETWORK_IMPLEMENTATION","DEFAULT_LIBRARY_INFO","DEFAULT_CLIENT_CREDENTIALS","DEFAULT_AZURE_CLOUD_OPTIONS","DEFAULT_TELEMETRY_OPTIONS","buildClientConfiguration","userAuthOptions","userSystemOptions","userLoggerOption","userCacheOptions","storageImplementation","networkImplementation","cryptoImplementation","clientCredentials","libraryInfo","telemetry","serverTelemetryManager","persistencePlugin","serializableCache","loggerOptions","buildAuthOptions","Logger","isOidcProtocolMode","config","ServerError","subError","errorNo","status","ThrottlingUtils","thumbprint","thumbprintValue","HeaderNames","throttleTime","time","currentSeconds","homeAccountIdentifier","NetworkManager","CcsCredentialType","RequestValidator","redirectUri","prompt","promptValues","PromptValue","codeChallenge","codeChallengeMethod","CodeChallengeMethodValues","RequestParameterBuilder","responseMode","ResponseMode","addOidcScopes","defaultScopes","OIDC_DEFAULT_SCOPES","requestScopes","idTokenHint","domainHint","clientCapabilities","mergedClaims","appTelemetry","state","nonce","codeVerifier","clientSecret","clientAssertionType","oboAssertion","tokenUse","grantType","CLIENT_INFO","eQParams","ClaimsRequestKeys","username","PasswordGrantConstants","password","cnfString","sshJwkString","logoutHint","queryParameterArray","BaseClient","configuration","ccsCred","headers","queuedEvent","cloudInstanceHostname","cloudInstanceAuthorityUri","cloudInstanceAuthority","parameterBuilder","noTokensFound","nativeAccountUnavailable","refreshTokenExpired","interactionRequired","consentRequired","loginRequired","badToken","InteractionRequiredServerErrorMessage","InteractionRequiredAuthSubErrorMessage","InteractionRequiredAuthErrorMessages","InteractionRequiredAuthError","timestamp","traceId","isInteractionRequiredError","isInteractionRequiredErrorCode","isInteractionRequiredSubError","isInteractionRequiredErrorDesc","irErrorCode","createInteractionRequiredAuthError","ProtocolUtils","userState","meta","libraryState","stateObj","stateString","splitState","libraryStateString","libraryStateObj","KeyLocation","PopTokenGenerator","cryptoUtils","reqCnf","reqCnfString","payload","resourceRequestMethod","resourceRequestUri","shrClaims","shrNonce","shrOptions","resourceUrlString","resourceUrlComponents","TokenCacheContext","tokenCache","hasChanged","parseServerErrorNo","serverResponse","errorCodePrefix","errorCodePrefixIndex","ResponseHandler","cacheStorage","requestState","decodedServerResponseState","decodedRequestState","serverErrorNo","refreshAccessToken","errString","serverError","HttpStatus","serverTokenResponse","reqTimestamp","authCodePayload","handlingRefreshTokenResponse","forceCacheRefreshTokenResponse","serverRequestId","requestStateObj","cacheContext","claimsTenantId","cachedIdToken","cachedAccount","buildAccountToCache","cachedAccessToken","responseScopes","expiresIn","extExpiresIn","refreshIn","tokenExpirationSeconds","extendedTokenExpirationSeconds","refreshOnSeconds","cachedRefreshToken","rtExpiresOn","rtExpiresIn","cachedAppMetadata","fromTokenCache","requestId","popTokenGenerator","secret","uid","baseAccountKey","tenantProfiles","newTenantProfile","AuthorizationCodeClient","responseHandler","serverParams","cachedState","logoutRequest","queryParametersString","requestBody","ccsCredential","GrantType","reqCnfData","accountSid","accountLoginHintClaim","DEFAULT_REFRESH_TOKEN_EXPIRATION_OFFSET_SECONDS","RefreshTokenClient","noFamilyRTInCache","clientMismatchErrorWithFamilyRT","Errors","foci","refreshTokenRequest","badRefreshTokenKey","SilentFlowClient","authResponse","cacheOutcome","CacheOutcome","lastCacheOutcome","requestTenantId","StubbedNetworkModule","missingKidError","missingAlgError","JoseHeaderErrorMessages","JoseHeaderError","createJoseHeaderError","JoseHeader","shrHeaderOptions","shrHeader","JsonWebTokenTypes","ServerTelemetryManager","telemetryRequest","platformFields","regionDiscoveryFields","requestWithRegionDiscoveryFields","lastRequests","maxErrors","failedRequests","errors","errorCount","overflow","initialValue","numErrorsFlushed","serverTelemEntity","serverTelemetryEntity","dataSize","apiId","StubPerformanceMeasurement","StubPerformanceClient","measureName","pkceNotCreated","cryptoNonExistent","emptyNavigateUri","hashEmptyError","noStateInHash","hashDoesNotContainKnownProperties","unableToParseState","stateInteractionTypeMismatch","interactionInProgress","popupWindowError","emptyWindowError","userCancelled","monitorPopupTimeout","monitorWindowTimeout","redirectInIframe","blockIframeReload","blockNestedPopups","iframeClosedPrematurely","silentLogoutUnsupported","noAccountError","silentPromptValueError","noTokenRequestCacheError","unableToParseTokenRequestCacheError","noCachedAuthorityError","authRequestNotSetError","invalidCacheType","nonBrowserEnvironment","databaseNotOpen","getRequestFailed","failedToParseResponse","unableToLoadToken","cryptoKeyNotFound","authCodeRequired","authCodeOrNativeAccountIdRequired","spaCodeAndNativeAccountIdPresent","databaseUnavailable","unableToAcquireTokenFromNativePlatform","nativeHandshakeTimeout","nativeExtensionNotInstalled","nativeConnectionNotEstablished","uninitializedPublicClientApplication","nativePromptNotSupported","invalidBase64String","invalidPopTokenRequest","ErrorLink","BrowserAuthErrorMessages","BrowserAuthError","createBrowserAuthError","BrowserConstants","NativeConstants","NativeExtensionMethod","BrowserCacheLocation","HTTP_REQUEST_TYPE","TemporaryCacheKeys","StaticCacheKeys","InMemoryCacheKeys","ApiId","InteractionType","DEFAULT_REQUEST","KEY_FORMAT_JWK","DB_NAME","DB_VERSION","DB_TABLE_NAME","CacheLookupPolicy","iFrameRenewalPolicies","LOG_LEVEL_CACHE_KEY","LOG_PII_CACHE_KEY","urlEncode","base64Encode","urlEncodeArr","inputArr","base64EncArr","aBytes","binString","x","PKCS1_V15_KEYGEN_ALG","S256_HASH_ALG","MODULUS_LENGTH","PUBLIC_EXPONENT","UUID_CHARS","UINT32_ARR","keygenAlgorithmOptions","validateCryptoAvailable","sha256Digest","dataString","data","getRandomValues","dataBuffer","getRandomUint32","createNewGuid","currentTimestamp","baseRand","bytes","randA","randBHi","randBLo","text","generateKeyPair","extractable","usages","exportJwk","importJwk","sign","hashString","plainText","hashBuffer","hashBytes","storageNotSupported","stubbedPublicClientApplicationCalled","inMemRedirectUnavailable","BrowserConfigurationAuthErrorMessages","BrowserConfigurationAuthError","createBrowserConfigurationAuthError","clearHash","contentWindow","replaceHash","urlParts","isInIframe","isInPopup","getCurrentUri","getHomepage","blockReloadInHiddenIframes","blockRedirectInIframe","allowRedirectInIframe","blockAcquireTokenInPopups","blockNonBrowserEnvironment","blockAPICallsBeforeInitialize","initialized","preflightCheck","redirectPreflightCheck","preconnect","link","NavigationClient","resolve","FetchClient","reqBody","optionsHeaders","headerDict","DEFAULT_POPUP_TIMEOUT_MS","DEFAULT_IFRAME_TIMEOUT_MS","DEFAULT_REDIRECT_TIMEOUT_MS","DEFAULT_NATIVE_BROKER_HANDSHAKE_TIMEOUT_MS","buildConfiguration","userInputAuth","userInputCache","userInputSystem","userInputTelemetry","isBrowserEnvironment","DEFAULT_AUTH_OPTIONS","ServerResponseType","DEFAULT_LOGGER_OPTIONS","providedSystemOptions","ClientConfigurationErrorCodes.cannotSetOIDCOptions","ClientConfigurationErrorCodes.cannotAllowNativeBroker","BaseOperatingContext","level","sessionStorage","logLevelKey","piiLoggingKey","piiLoggingEnabled","logLevel","StandardOperatingContext","base64DecToArr","base64String","encodedString","m","DatabaseStorage","reject","openDB","event","db","dbGet","dbPut","dbDelete","dbGetKeys","dbContainsKey","deleteDbRequest","MemoryStorage","cacheKeys","AsyncMemoryStorage","item","containsKey","dbDeleted","CryptoOps","inputKid","publicKeyThumbMeasurement","keyPair","publicKeyJwk","pubKeyThumprintObj","publicJwkString","getSortedObjectString","publicJwkHash","privateKeyJwk","unextractablePrivateKey","signJwtMeasurement","cachedKeyPair","publicKeyJwkString","encodedKeyIdThumbprint","encodedShrHeader","encodedPayload","tokenString","tokenBuffer","signatureBuffer","encodedSignature","signedJwt","BrowserStorage","cacheLocation","extractBrowserRequestState","browserCrypto","ClientAuthErrorCodes.invalidState","BrowserCacheManager","cacheConfig","temporaryCacheLocation","idTokenKey","PersistentCacheKeys","clientInfoKey","errorKey","errorDescKey","idTokenValue","clientInfoValue","errorValue","errorDescValue","values","accountKeys","credObj","CacheHelpers.isIdTokenEntity","idTokenEntity","newKey","CacheHelpers.isAccessTokenEntity","accessTokenEntity","CacheHelpers.isRefreshTokenEntity","refreshTokenEntity","accountObj","jsonValue","parsedJson","serializedAccount","parsedAccount","removalIndex","type","ClientAuthErrorCodes.unexpectedCredentialType","idRemoval","accessRemoval","refreshRemoval","parsedIdToken","CacheHelpers.generateCredentialKey","accessTokenKey","parsedAccessToken","refreshTokenKey","parsedRefreshToken","appMetadataKey","parsedMetadata","CacheHelpers.isAppMetadataEntity","CacheHelpers.generateAppMetadataKey","serverTelemetryKey","parsedEntity","CacheHelpers.isServerTelemetryEntity","serverTelemetry","CacheHelpers.isAuthorityMetadataEntity","wrapperSKU","wrapperVersion","sku","activeAccountKeyFilters","activeAccountValueFilters","activeAccountKeyLocal","activeAccountValueLocal","activeAccount","activeAccountValueObj","activeAccountKey","activeAccountValue","throttlingCacheKey","parsedThrottlingCache","CacheHelpers.isThrottlingEntity","throttlingCache","generateKey","itemCookie","cookieName","cookieValue","expires","cookieStr","expireTime","cookieList","cookie","cookiePrefix","cookieKey","cookieLifeDays","today","stateId","stateCacheKey","authorityCacheKey","authorityInstance","nonceCacheKey","stateKey","interactionType","stateValue","parsedState","authCodeRequest","encodedValue","encodedTokenRequest","parsedRequest","cachedAuthority","cachedRequest","matchClientId","inProgress","adalIdTokenString","msalIdTokenString","cachedIdTokenString","AuthToken.extractTokenClaims","currentCacheKey","updatedCacheKey","cacheItem","CacheHelpers.createIdTokenEntity","claimsHash","CacheHelpers.createAccessTokenEntity","DEFAULT_BROWSER_CACHE_MANAGER","cacheOptions","getAllAccounts","browserStorage","isInBrowser","getAccount","getAccountByUsername","getAccountByHomeId","getAccountByLocalId","setActiveAccount","getActiveAccount","EventType","EventHandler","callbackId","eventType","cacheValue","parsedValue","BaseInteractionClient","storageImpl","eventHandler","navigationClient","nativeMessageHandler","requestRedirectUri","forceRefresh","telemetryPayload","requestAuthority","requestAzureCloudOptions","userAuthority","builtAuthority","discoveredAuthority","AuthorityFactory.createDiscoveredInstance","ClientConfigurationErrorCodes.authorityMismatch","RANDOM_BYTE_ARR_LENGTH","generatePkceCodes","generateCodeVerifier","generateCodeChallengeFromVerifier","buffer","pkceCodeVerifier","pkceHashedCodeVerifier","initializeBaseRequest","validatedRequest","ClientConfigurationErrorCodes.missingSshJwk","ClientConfigurationErrorCodes.missingSshKid","initializeSilentRequest","baseRequest","StandardInteractionClient","generatedPkceParams","validLogoutRequest","authorityUrl","clientConfig","browserState","legacyLoginHint","contentError","userSwitch","USER_INTERACTION_REQUIRED","USER_CANCEL","NO_NETWORK","PERSISTENT_ERROR","DISABLED","ACCOUNT_UNAVAILABLE","INVALID_METHOD_ERROR","NativeAuthErrorMessages","NativeAuthError","description","ext","isFatalNativeAuthError","createNativeAuthError","InteractionRequiredAuthErrorCodes.nativeAccountUnavailable","SilentCacheClient","silentRequest","silentAuthClient","BrokerServerParamKeys","NativeInteractionClient","provider","nativeStorageImpl","nativeATMeasurement","TimeUtils.nowSeconds","nativeRequest","nativeTokenRequest","messageBody","validatedResponse","ClientAuthErrorCodes.noAccountFound","fullAccount","rootMeasurement","remainingParameters","navigationOptions","cachedhomeAccountId","shrParameters","ClientAuthErrorCodes.keyIdMissing","mats","accountProperties","responseAccessToken","nativeCacheRecord","AuthErrorCodes.unexpectedError","remainingProperties","getPrompt","generatedReqCnfData","AADServerParamKeys.CLIENT_ID","child_client_id","child_redirect_uri","brk_redirect_uri","NativeMessageHandler","handshakeTimeoutMs","extensionId","body","req","preferredProvider","backupProvider","handshakeResolver","resolver","method","err","nativeExtensionProvider","authenticationScheme","InteractionHandler","authCodeModule","authCodeResponse","validateNonce","deserializeResponse","responseLocation","UrlUtils.getDeserializedResponse","UrlUtils.stripLeadingHashOrQuery","validateInteractionType","platformStateObj","PopupClient","popupName","popupWindowAttributes","popup","mainWindowRedirectUri","validRequest","authClient","isNativeBroker","fetchNativeAccountIdMeasurement","navigateUrl","interactionHandler","popupParameters","popupWindow","nativeInteractionClient","userRequestState","absoluteUrl","logoutUri","requestUrl","intervalId","href","responseType","urlNavigate","popupParams","winLeft","winTop","winWidth","winHeight","width","height","top","left","RedirectHandler","ClientAuthErrorCodes.stateNotFound","nonceKey","cachedNonce","cachedCcsCred","tokenResponse","RedirectClient","handleBackButton","redirectStartPage","hash","parentMeasurement","loginRequestUrl","loginRequestUrlNormalized","currentUrlNormalized","processHashOnRedirect","homepage","userProvidedResponse","cachedHash","currentAuthority","requestStartPage","initiateAuthRequest","navigateFrameWait","loadFrame","loadFrameSync","monitorIframeForHash","iframe","timeout","pollIntervalMilliseconds","timeoutId","removeHiddenIframe","frameHandle","createHiddenIframe","authFrame","SilentIframeClient","inputRequest","msalFrame","SilentRefreshClient","refreshTokenClient","TokenCache","storage","cacheRecordAccount","extendedExpiresOn","CacheHelpers.createRefreshTokenEntity","HybridSpaAuthorizationCodeClient","SilentAuthCodeClient","getAccountType","performanceEvent","preflightCheck$1","StandardController","operatingContext","nativeCacheOptions","controller","initCorrelationId","allowNativeBroker","initMeasurement","redirectResponseKey","loggedInAccounts","useNative","redirectResponse","nativeClient","redirectClient","eventError","atrMeasurement","onRedirectNavigateCb","navigate","isLoggedIn","atPopupMeasurement","measurement","atbcMeasurement","hybridAuthCode","tokenRenewalError","commonRequest","cacheLookupPolicy","silentCacheClient","ClientAuthErrorCodes.tokenRefreshRequired","silentRefreshClient","silentIframeClient","atsMeasurement","silentRequestKey","cachedResponse","trackPageVisibility","refreshTokenError","checkIfRefreshTokenErrorCanBeResolvedSilently","activePromise","activeCorrelationId","awaitConcurrentIframeMeasure","activePromiseResult","_resolve","iframeResult","cacheError","noInteractionRequired","InteractionRequiredAuthErrorCodes.badToken","refreshTokenRefreshRequired","isSilentlyResolvable","InteractionRequiredAuthErrorCodes.noTokensFound","InteractionRequiredAuthErrorCodes.refreshTokenExpired","tryIframeRenewal","createV3Controller","standard","PublicClientApplication","localId","userName","useFocusableGroup","tabster","useTabster","getGroupper","useTabsterAttributes","getTabbability","tabBehavior","GroupperTabbabilities","themeToTokensObject","theme","tokens","keys","renderDivider_unstable","_jsx","useDivider_unstable","props","ref","alignContent","appearance","inset","vertical","wrapper","dividerId","useId","slot.always","getIntrinsicElementProps","dividerClassNames","useBaseStyles","__styles","useHorizontalStyles","useVerticalStyles","useDividerStyles_unstable","baseStyles","horizontalStyles","verticalStyles","mergeClasses","Divider","React.forwardRef","useCustomStyleHook_unstable","useCardSelectable","referenceLabel","referenceId","cardRef","checkbox","onSelectionChange","floatingAction","onClick","onKeyDown","findAllFocusable","useFocusFinders","checkboxRef","React.useRef","selected","setSelected","useControllableState","selectable","prop","selectFocused","setSelectFocused","React.useState","shouldRestrictTriggerAction","React.useCallback","focusableElements","isElementInFocusableGroup","element","isCheckboxSlot","onChangeHandler","newCheckedValue","onKeyDownHandler","Enter","checkboxSlot","React.useMemo","selectableCheckboxProps","slot.optional","floatingActionSlot","selectableCardProps","mergeCallbacks","cardContext","React.createContext","cardContextDefaultValue","CardProvider","useCardContext_unstable","_React_useContext","React.useContext","focusMap","useCardInteractive","initialFocusMode","interactive","focusMode","interactiveFocusAttributes","useCard_unstable","orientation","size","setReferenceId","setReferenceLabel","cardBaseRef","useFocusWithin","useMergedRefs","focusAttributes","renderCard_unstable","cardContextValue","_jsxs","cardHeaderClassNames","useStyles","useStylesGrid","useStylesFlex","useCardHeaderStyles_unstable","styles","stylesGrid","stylesFlex","boxModelStyles","getSlotStyles","slotName","_state_slotName","cardFooterClassNames","useCardFooterStyles_unstable","cardClassNames","useCardResetStyles","__resetStyles","useCardStyles","useCardStyles_unstable","resetStyles","orientationMap","sizeMap","appearanceMap","selectedMap","interactiveMap","isSelectableOrInteractive","focusedClassName","useCardContextValue","selectableA11yProps","Card","useCardFooter_unstable","action","renderCardFooter_unstable","CardFooter","getChildWithId","header","isReactElementWithIdProp","React.isValidElement","React.Children","getReferenceId","headerId","childWithId","generatedId","useCardHeader_unstable","image","headerRef","hasChildId","headerSlot","React.useEffect","_headerRef_current","renderCardHeader_unstable","CardHeader","createStoreImpl","createState","listeners","setState","partial","replace","nextState","previousState","listener","getState","api","initialState","createStore","require$$0","h","a","b","k","l","n","p","q","d","f","c","g","r","t","u","useSyncExternalStoreShim_production_min","shimModule","require$$1","v","w","withSelector_production_min","withSelectorModule","useDebugValue","ReactExports","useSyncExternalStoreWithSelector","useSyncExternalStoreExports","didWarnAboutEqualityFn","identity","arg","useStore","selector","equalityFn","slice","createImpl","useBoundStore","create","createJSONStorage","getStorage","parse","str2","newValue","toThenable","fn","onFulfilled","_onRejected","_onFulfilled","onRejected","oldImpl","baseOptions","set","get","persistedState","currentState","hasHydrated","hydrationListeners","finishHydrationListeners","thenableSerialize","setItem","errorInSync","thenable","serializedValue","savedSetState","configResult","stateFromStorage","hydrate","cb","postRehydrationCallback","storageValue","deserializedStorageValue","migratedState","_a2","newOptions","newImpl","migrationResult","migrated","persistImpl","persist","ScreenSize","usePersistentStore","webLightTheme","newTheme","newList","exports","assertString","_typeof","isString","invalidType","module","toDate","_assertString","_interopRequireDefault","date","alpha_1","alpha","alphanumeric","decimal","englishLocales","locale","arabicLocales","_locale","_i","farsiLocales","_locale2","_i2","bengaliLocales","_locale3","_i3","dotDecimal","commaDecimal","_i4","_i5","isFloat_1","isFloat","_alpha","float","locales","toFloat","_isFloat","toInt","radix","toBoolean","strict","equals","comparison","toString","merge","defaults","contains","_toString","_merge","require$$2","defaulContainsOptions","elem","modifiers","isByteLength","min","max","len","isFQDN","default_fqdn_options","parts","tld","part","isIP","IPv4SegmentFormat","IPv4AddressFormat","IPv4AddressRegExp","IPv6SegmentFormat","IPv6AddressRegExp","isEmail","_isByteLength","_isFQDN","_isIP","require$$3","require$$4","default_email_options","splitNameAddress","emailUserPart","gmailUserPart","quotedEmailUser","emailUserUtf8Part","quotedEmailUserUtf8","defaultMaxEmailLength","validateDisplayName","display_name","display_name_without_quotes","contains_illegal","all_start_with_back_slash","display_email","domain","lower_domain","user","_user_parts","noBracketdomain","user_parts","isURL","_slicedToArray","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","o","minLen","_arrayLikeToArray","arr2","_arr","_n","_s","default_url_options","wrapped_ipv6","isRegExp","checkHost","protocol","auth","hostname","port","port_str","split","ipv6","_auth$split","_auth$split2","ipv6_match","isMACAddress","macAddress48","macAddress48NoSeparators","macAddress48WithDots","macAddress64","macAddress64NoSeparators","macAddress64WithDots","isIPRange","subnetMaybe","v4Subnet","v6Subnet","isValidIP","expectedSubnet","isDate","_createForOfIteratorHelper","allowArrayLike","it","F","_e2","normalCompletion","didErr","step","_e3","default_date_options","isValidFormat","format","zip","zippedArr","formatDelimiter","delimiter","dateDelimiter","dateAndFormat","dateObj","_iterator","_step","_step$value","dateWord","formatWord","fullYear","parsedYear","currentYearLastTwoDigits","isTime","default_time_options","formats","isBoolean","defaultOptions","strictBooleans","looseBooleans","isLocale","extlang","language","script","variant","singleton","extension","privateuse","irregular","regular","grandfathered","langtag","languageTagRegex","isAlpha_1","isAlpha","_str","ignore","isAlphanumeric_1","isAlphanumeric","isNumeric","numericNoSymbols","isPassportNumber","passportRegexByCountryCode","countryCode","normalizedStr","isInt","int","intLeadingZeroes","regex","minCheckPassed","maxCheckPassed","ltCheckPassed","gtCheckPassed","isPort","_isInt","isLowercase","isUppercase","isIMEI","imeiRegexWithoutHypens","imeiRegexWithHypens","imeiRegex","sum","mul","digit","tp","chk","isAscii","ascii","isFullWidth_1","isFullWidth","fullWidth","isHalfWidth_1","isHalfWidth","halfWidth","isVariableWidth","_isFullWidth","_isHalfWidth","isMultibyte","multibyte","multilineRegexp","flags","regexpAsStringLiteral","isSemVer","_multilineRegex","semanticVersioningRegex","isSurrogatePair","surrogatePair","includes","arrVal","_default","isDecimal","_includes","decimalRegExp","regExp","default_decimal_options","blacklist","isHexadecimal","hexadecimal","isOctal","octal","isDivisibleBy","_toFloat","num","isHexColor","hexcolor","isRgbColor","rgbColor","rgbaColor","rgbColorPercent","rgbaColorPercent","includePercentValues","isHSL","hslComma","hslSpace","strippedStr","isISRC","isrc","isIBAN_1","isIBAN","ibanRegexThroughCountryCode","hasOnlyValidCountryCodes","countryCodeArray","countryCodeArrayFilteredWithObjectIbanCode","hasValidIbanFormat","isoCountryCode","isoCountryCodeInIbanRegexCodeObject","isoCountryCodeInWhiteList","isoCountryCodeInBlackList","hasValidIbanChecksum","rearranged","alphaCapsReplacedWithDigits","char","remainder","acc","isISO31661Alpha2_1","isISO31661Alpha2","validISO31661Alpha2CountriesCodes","CountryCodes","isBIC","_isISO31661Alpha","isBICReg","isMD5","md5","isHash","lengths","algorithm","isBase64","notBase64","urlSafeBase64","defaultBase64Options","firstPaddingChar","isJWT","_isBase","dotSplit","currElem","isJSON","default_json_options","primitives","isEmpty","default_is_empty_options","isLength","presentationSequences","surrogatePairs","isUUID","uuid","isMongoId","_isHexadecimal","isAfter","_toDate","comparisonDate","original","isBefore","isIn","isLuhnNumber","sanitized","tmpNum","shouldDouble","isCreditCard","_isLuhnNumber","cards","allCards","tmpCardsArray","cardProvider","card","isIdentityCard","validators","weightOfDigits","digits","modulo","lastDigit","DNI","charsValue","controlDigits","number","checkDigits","idAsNumber","checkDigit","invertedArray","lastNumber","k1","k2","old_nic","new_nic","incNum","NIN","provincesAndCities","powers","parityBit","checkAddressCode","addressCode","checkBirthDayCode","birDayCode","yyyy","mm","dd","xdata","getParityBit","idCardNo","id17","power","mod","checkParityBit","check15IdCardNo","check","check18IdCardNo","checkIdCardNo","regexHKID","regexIsDigit","checkSumVal","convertedChar","checkSumConverted","ALPHABET_CODES","validator","isEAN","LENGTH_EAN_8","LENGTH_EAN_14","validEanRegex","getPositionWeightThroughLengthAndIndex","length","calculateCheckDigit","ean","checksum","partialSum","actualCheckDigit","isISIN","isin","double","lo","hi","_digit","isISBN","possibleIsbn10","possibleIsbn13","factor","isbn","sanitizedIsbn","isISSN","issn","testIssn","algorithms","iso7064Check","luhnCheck","reverseMultiplyAndSum","verhoeffCheck","checkvalue","second","product","base","total","d_table","p_table","str_copy","isTaxID","_interopRequireWildcard","_isDate","_getRequireWildcardCache","cache","newObj","hasPropertyDescriptor","desc","_toConsumableArray","_arrayWithoutHoles","_iterableToArray","_nonIterableSpread","iter","bgBgCheck","tin","century_year","month","multip_lookup","isCanadianSIN","digitsArray","even","_","idx","cur","csCzCheck","full_year","checkdigit","deAtCheck","deDeCheck","occurences","j","trip_locations","recurrent","dkDkCheck","year","century_digit","weight","elCyCheck","elGrCheck","enIeCheck","enUsCampusPrefix","enUsGetPrefixes","prefixes","location","enUsCheck","esEsCheck","chars","lead_replace","lookup","etEeCheck","fiFiCheck","century_symbol","letters_lookup","frBeCheck","checkdigits","frFrCheck","frLuCheck","hrHrCheck","huHuCheck","itItNameCheck","vowelflag","xflag","itItCheck","number_locations","number_replace","_number_locations","month_replace","day","char_to_int","odd_convert","_i6","_char_to_int","multiplier","lvLvCheck","mtMtCheck","first_part","second_part","nlNlCheck","plPlCheck","_checksum","_i7","ptBrCheck","_sum","_i8","identifiers","verificators","pos","_i9","_i10","ptPtCheck","roRoCheck","multipliers","skSkCheck","slSiCheck","svSeCheck","tin_copy","current_year","current_century","taxIdFormat","taxIdCheck","allsymbols","sanitizeRegexes","strcopy","isMobilePhone_1","isMobilePhone","phones","phone","isEthereumAddress","eth","isCurrency","currencyRegex","decimal_digits","symbol","negative","whole_dollar_amount_without_sep","whole_dollar_amount_with_sep","valid_whole_dollar_amounts","whole_dollar_amount","decimal_amount","default_currency_options","isBtcAddress","bech32","base58","isISO6346_1","isISO6346","isISO6346Str","isDigit","convertedCode","letterCode","checkSumDigit","isFreightContainerID","isISO6391","isISO6391Set","isISO8601","iso8601","iso8601StrictSeparator","isValidDate","ordinalMatch","oYear","oDay","monthString","dayString","isRFC3339","dateFullYear","dateMonth","dateMDay","timeHour","timeMinute","timeSecond","timeSecFrac","timeNumOffset","timeOffset","partialTime","fullDate","fullTime","rfc3339","isISO31661Alpha3","validISO31661Alpha3CountriesCodes","isISO4217_1","isISO4217","validISO4217CurrencyCodes","CurrencyCodes","isBase32","base32","crockfordBase32","defaultBase32Options","isBase58","base58Reg","isDataURI","validMediaType","validAttribute","validData","attributes","schemeAndMediaType","mediaType","isMagnetURI","magnetURIComponent","rtrim","strIndex","ltrim","trim","_rtrim","_ltrim","isMailtoURI","_trim","_isEmail","parseMailtoQueryString","allowedParams","isParseFailed","queryParams","_q$split","_q$split2","_url$replace$split","_url$replace$split2","_url$replace$split2$","to","_url$replace$split2$2","isMimeType","mimeTypeSimple","mimeTypeText","mimeTypeMultipart","isLatLong","lat","long","latDMS","longDMS","defaultLatLongOptions","isPostalCode_1","isPostalCode","threeDigit","fourDigit","fiveDigit","sixDigit","patterns","escape","unescape","stripLow","_blacklist","keep_new_lines","whitelist","isWhitelisted","normalizeEmail","default_normalize_email_options","icloud_domains","outlookdotcom_domains","yahoo_domains","yandex_domains","dotsReplacer","raw_parts","isSlug","charsetRegex","isLicensePlate","isStrongPassword","upperCaseRegex","lowerCaseRegex","numberRegex","symbolRegex","countChars","curVal","analyzePassword","charMap","analysis","scorePassword","scoringOptions","points","isVAT_1","isVAT","CH","hasValidCheckNumber","weights","calculatedCheckNumber","el","PT","vatMatchers","_toInt","_toBoolean","_equals","_contains","require$$5","_matches","require$$6","require$$7","_isURL","require$$8","_isMACAddress","require$$9","require$$10","_isIPRange","require$$11","require$$12","require$$13","_isTime","require$$14","_isBoolean","require$$15","_isLocale","require$$16","_isAlpha","require$$17","_isAlphanumeric","require$$18","_isNumeric","require$$19","_isPassportNumber","require$$20","_isPort","require$$21","_isLowercase","require$$22","_isUppercase","require$$23","_isIMEI","require$$24","_isAscii","require$$25","require$$26","require$$27","_isVariableWidth","require$$28","_isMultibyte","require$$29","_isSemVer","require$$30","_isSurrogatePair","require$$31","require$$32","require$$33","_isDecimal","require$$34","require$$35","_isOctal","require$$36","_isDivisibleBy","require$$37","_isHexColor","require$$38","_isRgbColor","require$$39","_isHSL","require$$40","_isISRC","require$$41","_isIBAN","require$$42","_isBIC","require$$43","_isMD","require$$44","_isHash","require$$45","_isJWT","require$$46","_isJSON","require$$47","_isEmpty","require$$48","_isLength","require$$49","require$$50","_isUUID","require$$51","_isMongoId","require$$52","_isAfter","require$$53","_isBefore","require$$54","_isIn","require$$55","require$$56","_isCreditCard","require$$57","_isIdentityCard","require$$58","_isEAN","require$$59","_isISIN","require$$60","_isISBN","require$$61","_isISSN","require$$62","_isTaxID","require$$63","_isMobilePhone","require$$64","_isEthereumAddress","require$$65","_isCurrency","require$$66","_isBtcAddress","require$$67","_isISO","require$$68","_isISO2","require$$69","_isISO3","require$$70","_isRFC","require$$71","require$$72","_isISO31661Alpha2","require$$73","_isISO4","require$$74","require$$75","_isBase2","require$$76","_isBase3","require$$77","_isDataURI","require$$78","_isMagnetURI","require$$79","_isMailtoURI","require$$80","_isMimeType","require$$81","_isLatLong","require$$82","_isPostalCode","require$$83","require$$84","require$$85","require$$86","_escape","require$$87","_unescape","require$$88","_stripLow","require$$89","_whitelist","require$$90","require$$91","_isWhitelisted","require$$92","_normalizeEmail","require$$93","_isSlug","require$$94","_isLicensePlate","require$$95","_isStrongPassword","require$$96","_isVAT","require$$97","LoginScreen","isDark","customTokens","getCustomTheme","loginType","setLoginType","useState","loginObj","setLoginObj","isAuthenticating","setIsAuthenticating","setStep","doNavigate","SetDoNavigate","userEmail","setUserEmail","mfaCode","setMfaCode","userPassword","setUserPassword","newPassword","setNewPassword","currentStep","setCurrentStep","loaderMessage","setLoaderMessage","setErrorMessage","addTokenResponse","setAddTokenResponse","isIframed","passwordValid","setPasswordValid","isUserAuthenticated","entraScopes","setEntraScopes","refusername","createRef","authInProcess","retries","loginRedirectInProgress","msalInstance","msalConfig","useEffect","nextUrl","GetAntiForgeryToken","CreatePasswordResetMail","csrfToken","getCookie","newUserObj","portalUrl","setCookieAuth","getEndpoints","endpointsResult","setEndpoints","GetWorkspaces","workspacesResult","handleTokenResponse","proxymails","mailNickName","grps","loginobj","loginResult","LoginAAD","setCookie","validateEmail","_scopes","GetEntraScopes","_res","_response","accounts","tokenRequest","handleState","VerifyLoginMethod","getTranslation","usedTexts","tokenObtained","VerifyPasswordToken","loginValidation","AcceptLoginViaEmail","directADD","isDone","fulfilled","cname","cvalue","exdays","decodedCookie","ca","mergeStyleSets","isPasswordComplex","complexitypassword","pass","passwithoutSpecials","_g","_h","_j","getComplexityText","returnText","PasswordChecker","validateComplexity","validateLength","jsxs","jsx","CheckmarkCircle20Filled","CheckmarkCircle20Regular","logoHeight","logoMarginTop","getLogo","Fragment","Spinner","typographyStyles","Button","Input","enteredValue","LoginMFACode","LoginNative","LoginViaEmail","ok","ChangePasswordByToken"],"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,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,214,215,216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,239,240,241,242,243]}