UNPKG

aws-amplify-react

Version:

AWS Amplify is a JavaScript library for Frontend and mobile developers building cloud-enabled applications.

91 lines 3.67 kB
/* * Copyright 2017-2017 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with * the License. A copy of the License is located at * * http://aws.amazon.com/apache2.0/ * * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions * and limitations under the License. */ var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; import * as React from 'react'; import { isEmpty, ConsoleLogger as Logger } from '@aws-amplify/core'; import { Auth } from '@aws-amplify/auth'; import { AuthPiece } from './AuthPiece'; import { TOTPSetupComp } from '../Widget/TOTPSetupComp'; import { auth } from '../Amplify-UI/data-test-attributes'; var logger = new Logger('TOTPSetup'); var TOTPSetup = /** @class */ (function (_super) { __extends(TOTPSetup, _super); function TOTPSetup(props) { var _this = _super.call(this, props) || this; _this._validAuthStates = ['TOTPSetup']; _this.onTOTPEvent = _this.onTOTPEvent.bind(_this); _this.checkContact = _this.checkContact.bind(_this); return _this; } TOTPSetup.prototype.checkContact = function (user) { var _this = this; if (!Auth || typeof Auth.verifiedContact !== 'function') { throw new Error('No Auth module found, please ensure @aws-amplify/auth is imported'); } Auth.verifiedContact(user).then(function (data) { if (!isEmpty(data.verified)) { _this.changeState('signedIn', user); } else { var newUser = Object.assign(user, data); _this.changeState('verifyContact', newUser); } }); }; TOTPSetup.prototype.onTOTPEvent = function (event, data, user) { logger.debug('on totp event', event, data); // const user = this.props.authData; if (event === 'Setup TOTP') { if (data === 'SUCCESS') { this.checkContact(user); } } }; TOTPSetup.prototype.showComponent = function (theme) { var hide = this.props.hide; if (hide && hide.includes(TOTPSetup)) { return null; } return (React.createElement(TOTPSetupComp, __assign({}, this.props, { onTOTPEvent: this.onTOTPEvent, "data-test": auth.TOTPSetup.component }))); }; return TOTPSetup; }(AuthPiece)); export { TOTPSetup }; /** * @deprecated use named import */ export default TOTPSetup; //# sourceMappingURL=TOTPSetup.js.map