UNPKG

auth0-lock

Version:
296 lines (238 loc) 9.31 kB
'use strict'; exports.__esModule = true; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; exports.setupLock = setupLock; exports.handleAuthCallback = handleAuthCallback; exports.resumeAuth = resumeAuth; exports.openLock = openLock; exports.closeLock = closeLock; exports.removeLock = removeLock; exports.updateLock = updateLock; exports.pinLoadingPane = pinLoadingPane; exports.unpinLoadingPane = unpinLoadingPane; exports.validateAndSubmit = validateAndSubmit; exports.logIn = logIn; exports.checkSession = checkSession; exports.logInSuccess = logInSuccess; var _immutable = require('immutable'); var _immutable2 = _interopRequireDefault(_immutable); var _web_api = require('./web_api'); var _web_api2 = _interopRequireDefault(_web_api); var _index = require('../store/index'); var _remote_data = require('./remote_data'); var _index2 = require('./index'); var l = _interopRequireWildcard(_index2); var _preload_utils = require('../utils/preload_utils'); var _container = require('../ui/box/container'); var _index3 = require('../field/index'); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function setupLock(id, clientID, domain, options, hookRunner, emitEventFn) { var m = l.setup(id, clientID, domain, options, hookRunner, emitEventFn); m = (0, _remote_data.syncRemoteData)(m); (0, _preload_utils.img)(l.ui.logo(m) || _container.defaultProps.logo); _web_api2.default.setupClient(id, clientID, domain, l.withAuthOptions(m, _extends({}, options, { popupOptions: l.ui.popupOptions(m) }))); m = l.runHook(m, 'didInitialize', options); (0, _index.swap)(_index.setEntity, 'lock', id, m); return m; } function handleAuthCallback() { var ms = (0, _index.read)(_index.getCollection, 'lock'); var keepHash = ms.filter(function (m) { return !l.hashCleanup(m); }).size > 0; var urlWithoutHash = global.location.href.split('#')[0]; var callback = function callback(error, authResult) { var parsed = !!(error || authResult); if (parsed && !keepHash) { global.history.replaceState(null, '', urlWithoutHash); } }; resumeAuth(global.location.hash, callback); } function resumeAuth(hash, callback) { var ms = (0, _index.read)(_index.getCollection, 'lock'); ms.forEach(function (m) { return l.auth.redirect(m) && parseHash(m, hash, callback); }); } function parseHash(m, hash, cb) { _web_api2.default.parseHash(l.id(m), hash, function (error, authResult) { if (error) { l.emitHashParsedEvent(m, error); } else { l.emitHashParsedEvent(m, authResult); } if (error) { l.emitAuthorizationErrorEvent(m, error); } else if (authResult) { l.emitAuthenticatedEvent(m, authResult); } cb(error, authResult); }); } function openLock(id, opts) { var m = (0, _index.read)(_index.getEntity, 'lock', id); if (!m) { throw new Error("The Lock can't be opened again after it has been destroyed"); } if (l.rendering(m)) { return false; } if (opts.flashMessage) { var supportedTypes = ['error', 'success', 'info']; if (!opts.flashMessage.type || supportedTypes.indexOf(opts.flashMessage.type) === -1) { return l.emitUnrecoverableErrorEvent(m, "'flashMessage' must provide a valid type ['error','success','info']"); } if (!opts.flashMessage.text) { return l.emitUnrecoverableErrorEvent(m, "'flashMessage' must provide a text"); } } l.emitEvent(m, 'show'); (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { m = l.overrideOptions(m, opts); m = l.filterConnections(m); m = l.runHook(m, 'willShow', opts); return l.render(m); }); return true; } function closeLock(id) { var force = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var callback = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : function () {}; // Do nothing when the Lock can't be closed, unless closing is forced. var m = (0, _index.read)(_index.getEntity, 'lock', id); if (!l.ui.closable(m) && !force || !l.rendering(m)) { return; } l.emitEvent(m, 'hide'); // If it is a modal, stop rendering an reset after a second, // otherwise just reset. if (l.ui.appendContainer(m)) { (0, _index.swap)(_index.updateEntity, 'lock', id, l.stopRendering); setTimeout(function () { (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { m = (0, _index3.hideInvalidFields)(m); m = l.reset(m); m = (0, _index3.clearFields)(m); return m; }); m = (0, _index.read)(_index.getEntity, 'lock', id); callback(m); }, 1000); } else { (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { m = (0, _index3.hideInvalidFields)(m); m = l.reset(m); m = (0, _index3.clearFields)(m); return m; }); callback(m); } } function removeLock(id) { (0, _index.swap)(_index.updateEntity, 'lock', id, l.stopRendering); (0, _index.swap)(_index.removeEntity, 'lock', id); } function updateLock(id, f) { return (0, _index.swap)(_index.updateEntity, 'lock', id, f); } function pinLoadingPane(id) { var lock = (0, _index.read)(_index.getEntity, 'lock', id); if (!lock.get('isLoadingPanePinned')) { (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { return m.set('isLoadingPanePinned', true); }); } } function unpinLoadingPane(id) { (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { return m.set('isLoadingPanePinned', false); }); } function validateAndSubmit(id) { var fields = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; var f = arguments[2]; (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { var allFieldsValid = fields.reduce(function (r, x) { return r && (0, _index3.isFieldValid)(m, x); }, true); return allFieldsValid ? l.setSubmitting(m, true) : fields.reduce(function (r, x) { return (0, _index3.showInvalidField)(r, x); }, m); }); var m = (0, _index.read)(_index.getEntity, 'lock', id); if (l.submitting(m)) { f(m); } } function logIn(id, fields) { var params = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; var logInErrorHandler = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : function (_id, error, _fields, next) { return next(); }; validateAndSubmit(id, fields, function (m) { _web_api2.default.logIn(id, params, l.auth.params(m).toJS(), function (error, result) { if (error) { setTimeout(function () { return logInError(id, fields, error, logInErrorHandler); }, 250); } else { logInSuccess(id, result); } }); }); } function checkSession(id) { var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var m = (0, _index.read)(_index.getEntity, 'lock', id); (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { return l.setSubmitting(m, true); }); _web_api2.default.checkSession(id, params, function (err, result) { if (err) { return logInError(id, [], err); } return logInSuccess(id, result); }); } function logInSuccess(id, result) { var m = (0, _index.read)(_index.getEntity, 'lock', id); if (!l.ui.autoclose(m)) { (0, _index.swap)(_index.updateEntity, 'lock', id, function (m) { m = l.setSubmitting(m, false); return l.setLoggedIn(m, true); }); l.emitAuthenticatedEvent(m, result); } else { closeLock(id, false, function (m1) { return l.emitAuthenticatedEvent(m1, result); }); } } function logInError(id, fields, error) { var localHandler = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : function (_id, _error, _fields, next) { return next(); }; var errorCode = error.error || error.code; localHandler(id, error, fields, function () { return setTimeout(function () { var m = (0, _index.read)(_index.getEntity, 'lock', id); var errorMessage = l.loginErrorMessage(m, error, loginType(fields)); var errorCodesThatEmitAuthorizationErrorEvent = ['blocked_user', 'rule_error', 'lock.unauthorized', 'invalid_user_password', 'login_required']; if (errorCodesThatEmitAuthorizationErrorEvent.indexOf(errorCode) > -1) { l.emitAuthorizationErrorEvent(m, error); } (0, _index.swap)(_index.updateEntity, 'lock', id, l.setSubmitting, false, errorMessage); }, 0); }); (0, _index.swap)(_index.updateEntity, 'lock', id, l.setSubmitting, false); } function loginType(fields) { if (!fields) return; if (~fields.indexOf('vcode')) return 'code'; if (~fields.indexOf('username')) return 'username'; if (~fields.indexOf('email')) return 'email'; }