UNPKG

@aws-amplify/auth

Version:
53 lines (51 loc) 2.35 kB
'use strict'; // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 Object.defineProperty(exports, "__esModule", { value: true }); exports.setUpTOTP = setUpTOTP; const core_1 = require("@aws-amplify/core"); const utils_1 = require("@aws-amplify/core/internals/utils"); const AuthError_1 = require("../../../errors/AuthError"); const errors_1 = require("../types/errors"); const signInHelpers_1 = require("../utils/signInHelpers"); const parsers_1 = require("../../../foundation/parsers"); const types_1 = require("../utils/types"); const utils_2 = require("../../../utils"); const cognitoIdentityProvider_1 = require("../../../foundation/factories/serviceClients/cognitoIdentityProvider"); const factories_1 = require("../factories"); /** * Sets up TOTP for the user. * * @returns SetUpTOTPOutput * @throws -{@link AssociateSoftwareTokenException} * Thrown if a service occurs while setting up TOTP. * @throws AuthTokenConfigException - Thrown when the token provider config is invalid. **/ async function setUpTOTP() { const authConfig = core_1.Amplify.getConfig().Auth?.Cognito; (0, utils_1.assertTokenProviderConfig)(authConfig); const { userPoolEndpoint, userPoolId } = authConfig; const { tokens } = await (0, core_1.fetchAuthSession)({ forceRefresh: false }); (0, types_1.assertAuthTokens)(tokens); const username = tokens.idToken?.payload['cognito:username'] ?? ''; const associateSoftwareToken = (0, cognitoIdentityProvider_1.createAssociateSoftwareTokenClient)({ endpointResolver: (0, factories_1.createCognitoUserPoolEndpointResolver)({ endpointOverride: userPoolEndpoint, }), }); const { SecretCode } = await associateSoftwareToken({ region: (0, parsers_1.getRegionFromUserPoolId)(userPoolId), userAgentValue: (0, utils_2.getAuthUserAgentValue)(utils_1.AuthAction.SetUpTOTP), }, { AccessToken: tokens.accessToken.toString(), }); if (!SecretCode) { // This should never happen. throw new AuthError_1.AuthError({ name: errors_1.SETUP_TOTP_EXCEPTION, message: 'Failed to set up TOTP.', }); } return (0, signInHelpers_1.getTOTPSetupDetails)(SecretCode, JSON.stringify(username)); } //# sourceMappingURL=setUpTOTP.js.map