aws-amplify-react
Version:
AWS Amplify is a JavaScript library for Frontend and mobile developers building cloud-enabled applications.
91 lines • 3.67 kB
JavaScript
/*
* 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