auth0-lock
Version:
Auth0 Lock
296 lines (238 loc) • 9.31 kB
JavaScript
;
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';
}