auth0-lock
Version:
Auth0 Lock
812 lines (666 loc) • 26.3 kB
JavaScript
;
exports.__esModule = true;
exports.reset = exports.auth = exports.ui = undefined;
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
exports.setup = setup;
exports.id = id;
exports.clientID = clientID;
exports.domain = domain;
exports.clientBaseUrl = clientBaseUrl;
exports.tenantBaseUrl = tenantBaseUrl;
exports.useTenantInfo = useTenantInfo;
exports.connectionResolver = connectionResolver;
exports.setResolvedConnection = setResolvedConnection;
exports.resolvedConnection = resolvedConnection;
exports.languageBaseUrl = languageBaseUrl;
exports.setSubmitting = setSubmitting;
exports.submitting = submitting;
exports.setGlobalError = setGlobalError;
exports.globalError = globalError;
exports.clearGlobalError = clearGlobalError;
exports.setGlobalSuccess = setGlobalSuccess;
exports.globalSuccess = globalSuccess;
exports.clearGlobalSuccess = clearGlobalSuccess;
exports.setGlobalInfo = setGlobalInfo;
exports.globalInfo = globalInfo;
exports.clearGlobalInfo = clearGlobalInfo;
exports.rendering = rendering;
exports.stopRendering = stopRendering;
exports.withAuthOptions = withAuthOptions;
exports.extractTenantBaseUrlOption = extractTenantBaseUrlOption;
exports.render = render;
exports.setLoggedIn = setLoggedIn;
exports.loggedIn = loggedIn;
exports.defaultADUsernameFromEmailPrefix = defaultADUsernameFromEmailPrefix;
exports.prefill = prefill;
exports.warn = warn;
exports.error = error;
exports.allowedConnections = allowedConnections;
exports.connections = connections;
exports.connection = connection;
exports.hasOneConnection = hasOneConnection;
exports.hasOnlyConnections = hasOnlyConnections;
exports.hasSomeConnections = hasSomeConnections;
exports.countConnections = countConnections;
exports.findConnection = findConnection;
exports.hasConnection = hasConnection;
exports.filterConnections = filterConnections;
exports.runHook = runHook;
exports.emitEvent = emitEvent;
exports.loginErrorMessage = loginErrorMessage;
exports.stop = stop;
exports.hasStopped = hasStopped;
exports.hashCleanup = hashCleanup;
exports.emitHashParsedEvent = emitHashParsedEvent;
exports.emitAuthenticatedEvent = emitAuthenticatedEvent;
exports.emitAuthorizationErrorEvent = emitAuthorizationErrorEvent;
exports.emitUnrecoverableErrorEvent = emitUnrecoverableErrorEvent;
exports.showBadge = showBadge;
exports.overrideOptions = overrideOptions;
var _urlJoin = require('url-join');
var _urlJoin2 = _interopRequireDefault(_urlJoin);
var _immutable = require('immutable');
var _immutable2 = _interopRequireDefault(_immutable);
var _media_utils = require('../utils/media_utils');
var _string_utils = require('../utils/string_utils');
var _url_utils = require('../utils/url_utils');
var _i18n = require('../i18n');
var i18n = _interopRequireWildcard(_i18n);
var _trim = require('trim');
var _trim2 = _interopRequireDefault(_trim);
var _gravatar_provider = require('../avatar/gravatar_provider');
var gp = _interopRequireWildcard(_gravatar_provider);
var _data_utils = require('../utils/data_utils');
var _index = require('./client/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 }; }
var _dataFns = (0, _data_utils.dataFns)(['core']),
get = _dataFns.get,
init = _dataFns.init,
remove = _dataFns.remove,
reset = _dataFns.reset,
set = _dataFns.set,
tget = _dataFns.tget,
tset = _dataFns.tset,
tremove = _dataFns.tremove;
function setup(id, clientID, domain, options, hookRunner, emitEventFn) {
var m = init(id, _immutable2.default.fromJS({
clientBaseUrl: extractClientBaseUrlOption(options, domain),
tenantBaseUrl: extractTenantBaseUrlOption(options, domain),
languageBaseUrl: extractLanguageBaseUrlOption(options, domain),
auth: extractAuthOptions(options),
clientID: clientID,
domain: domain,
emitEventFn: emitEventFn,
hookRunner: hookRunner,
useTenantInfo: options.__useTenantInfo || false,
hashCleanup: options.hashCleanup === false ? false : true,
allowedConnections: _immutable2.default.fromJS(options.allowedConnections || []),
ui: extractUIOptions(id, options),
defaultADUsernameFromEmailPrefix: options.defaultADUsernameFromEmailPrefix === false ? false : true,
prefill: options.prefill || {},
connectionResolver: options.connectionResolver
}));
m = i18n.initI18n(m);
return m;
}
function id(m) {
return m.get('id');
}
function clientID(m) {
return get(m, 'clientID');
}
function domain(m) {
return get(m, 'domain');
}
function clientBaseUrl(m) {
return get(m, 'clientBaseUrl');
}
function tenantBaseUrl(m) {
return get(m, 'tenantBaseUrl');
}
function useTenantInfo(m) {
return get(m, 'useTenantInfo');
}
function connectionResolver(m) {
return get(m, 'connectionResolver');
}
function setResolvedConnection(m, resolvedConnection) {
if (!resolvedConnection) {
return set(m, 'resolvedConnection', undefined);
}
if (!resolvedConnection.type || !resolvedConnection.name) {
throw new Error('Invalid connection object. The resolved connection must look like: `{ type: "database", name: "connection name" }`.');
}
if (resolvedConnection.type !== 'database') {
throw new Error('Invalid connection type. Only database connections can be resolved with a custom resolver.');
}
return set(m, 'resolvedConnection', _immutable2.default.fromJS(resolvedConnection));
}
function resolvedConnection(m) {
var resolvedConnection = get(m, 'resolvedConnection');
if (!resolvedConnection) {
return undefined;
}
return findConnection(m, resolvedConnection.get('name'));
}
function languageBaseUrl(m) {
return get(m, 'languageBaseUrl');
}
function setSubmitting(m, value) {
var error = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
m = tset(m, 'submitting', value);
m = clearGlobalSuccess(m);
m = error && !value ? setGlobalError(m, error) : clearGlobalError(m);
return m;
}
function submitting(m) {
return tget(m, 'submitting', false);
}
function setGlobalError(m, str) {
return tset(m, 'globalError', str);
}
function globalError(m) {
return tget(m, 'globalError', '');
}
function clearGlobalError(m) {
return tremove(m, 'globalError');
}
function setGlobalSuccess(m, str) {
return tset(m, 'globalSuccess', str);
}
function globalSuccess(m) {
return tget(m, 'globalSuccess', '');
}
function clearGlobalSuccess(m) {
return tremove(m, 'globalSuccess');
}
function setGlobalInfo(m, str) {
return tset(m, 'globalInfo', str);
}
function globalInfo(m) {
return tget(m, 'globalInfo', '');
}
function clearGlobalInfo(m) {
return tremove(m, 'globalInfo');
}
function rendering(m) {
return tget(m, 'render', false);
}
function stopRendering(m) {
return tremove(m, 'render');
}
function extractUIOptions(id, options) {
var closable = options.container ? false : undefined === options.closable ? true : !!options.closable;
var theme = options.theme || {};
var labeledSubmitButton = theme.labeledSubmitButton,
hideMainScreenTitle = theme.hideMainScreenTitle,
logo = theme.logo,
primaryColor = theme.primaryColor,
authButtons = theme.authButtons;
var avatar = options.avatar !== null;
var customAvatarProvider = options.avatar && typeof options.avatar.url === 'function' && typeof options.avatar.displayName === 'function' && options.avatar;
var avatarProvider = customAvatarProvider || gp;
return new _immutable2.default.fromJS({
containerID: options.container || 'auth0-lock-container-' + id,
appendContainer: !options.container,
autoclose: undefined === options.autoclose ? false : closable && options.autoclose,
autofocus: undefined === options.autofocus ? !(options.container || (0, _media_utils.isSmallScreen)()) : !!options.autofocus,
avatar: avatar,
avatarProvider: avatarProvider,
logo: typeof logo === 'string' ? logo : undefined,
closable: closable,
hideMainScreenTitle: !!hideMainScreenTitle,
labeledSubmitButton: undefined === labeledSubmitButton ? true : !!labeledSubmitButton,
language: undefined === options.language ? 'en' : (0, _trim2.default)(options.language || '').toLowerCase(),
dict: _typeof(options.languageDictionary) === 'object' ? options.languageDictionary : {},
disableWarnings: options.disableWarnings === undefined ? false : !!options.disableWarnings,
mobile: undefined === options.mobile ? false : !!options.mobile,
popupOptions: undefined === options.popupOptions ? {} : options.popupOptions,
primaryColor: typeof primaryColor === 'string' ? primaryColor : undefined,
rememberLastLogin: undefined === options.rememberLastLogin ? true : !!options.rememberLastLogin,
allowAutocomplete: !!options.allowAutocomplete,
authButtonsTheme: (typeof authButtons === 'undefined' ? 'undefined' : _typeof(authButtons)) === 'object' ? authButtons : {},
allowShowPassword: !!options.allowShowPassword,
allowPasswordAutocomplete: !!options.allowPasswordAutocomplete,
scrollGlobalMessagesIntoView: undefined === options.scrollGlobalMessagesIntoView ? true : !!options.scrollGlobalMessagesIntoView
});
}
var _dataFns2 = (0, _data_utils.dataFns)(['core', 'ui']),
getUI = _dataFns2.get,
setUI = _dataFns2.set;
var _dataFns3 = (0, _data_utils.dataFns)(['core', 'transient', 'ui']),
tgetUI = _dataFns3.get,
tsetUI = _dataFns3.set;
var getUIAttribute = function getUIAttribute(m, attribute) {
return tgetUI(m, attribute) || getUI(m, attribute);
};
var ui = exports.ui = {
containerID: function containerID(lock) {
return getUIAttribute(lock, 'containerID');
},
appendContainer: function appendContainer(lock) {
return getUIAttribute(lock, 'appendContainer');
},
autoclose: function autoclose(lock) {
return getUIAttribute(lock, 'autoclose');
},
autofocus: function autofocus(lock) {
return getUIAttribute(lock, 'autofocus');
},
avatar: function avatar(lock) {
return getUIAttribute(lock, 'avatar');
},
avatarProvider: function avatarProvider(lock) {
return getUIAttribute(lock, 'avatarProvider');
},
closable: function closable(lock) {
return getUIAttribute(lock, 'closable');
},
dict: function dict(lock) {
return getUIAttribute(lock, 'dict');
},
disableWarnings: function disableWarnings(lock) {
return getUIAttribute(lock, 'disableWarnings');
},
labeledSubmitButton: function labeledSubmitButton(lock) {
return getUIAttribute(lock, 'labeledSubmitButton');
},
hideMainScreenTitle: function hideMainScreenTitle(lock) {
return getUIAttribute(lock, 'hideMainScreenTitle');
},
language: function language(lock) {
return getUIAttribute(lock, 'language');
},
logo: function logo(lock) {
return getUIAttribute(lock, 'logo');
},
mobile: function mobile(lock) {
return getUIAttribute(lock, 'mobile');
},
popupOptions: function popupOptions(lock) {
return getUIAttribute(lock, 'popupOptions');
},
primaryColor: function primaryColor(lock) {
return getUIAttribute(lock, 'primaryColor');
},
authButtonsTheme: function authButtonsTheme(lock) {
return getUIAttribute(lock, 'authButtonsTheme');
},
rememberLastLogin: function rememberLastLogin(m) {
return tget(m, 'rememberLastLogin', getUIAttribute(m, 'rememberLastLogin'));
},
allowAutocomplete: function allowAutocomplete(m) {
return tget(m, 'allowAutocomplete', getUIAttribute(m, 'allowAutocomplete'));
},
scrollGlobalMessagesIntoView: function scrollGlobalMessagesIntoView(lock) {
return getUIAttribute(lock, 'scrollGlobalMessagesIntoView');
},
allowShowPassword: function allowShowPassword(m) {
return tget(m, 'allowShowPassword', getUIAttribute(m, 'allowShowPassword'));
},
allowPasswordAutocomplete: function allowPasswordAutocomplete(m) {
return tget(m, 'allowPasswordAutocomplete', getUIAttribute(m, 'allowPasswordAutocomplete'));
}
};
var _dataFns4 = (0, _data_utils.dataFns)(['core', 'auth']),
getAuthAttribute = _dataFns4.get;
var auth = exports.auth = {
connectionScopes: function connectionScopes(m) {
return getAuthAttribute(m, 'connectionScopes');
},
params: function params(m) {
return tget(m, 'authParams') || getAuthAttribute(m, 'params');
},
autoParseHash: function autoParseHash(lock) {
return getAuthAttribute(lock, 'autoParseHash');
},
redirect: function redirect(lock) {
return getAuthAttribute(lock, 'redirect');
},
redirectUrl: function redirectUrl(lock) {
return getAuthAttribute(lock, 'redirectUrl');
},
responseType: function responseType(lock) {
return getAuthAttribute(lock, 'responseType');
},
sso: function sso(lock) {
return getAuthAttribute(lock, 'sso');
}
};
function extractAuthOptions(options) {
var _ref = options.auth || {},
audience = _ref.audience,
connectionScopes = _ref.connectionScopes,
params = _ref.params,
autoParseHash = _ref.autoParseHash,
redirect = _ref.redirect,
redirectUrl = _ref.redirectUrl,
responseMode = _ref.responseMode,
responseType = _ref.responseType,
sso = _ref.sso,
state = _ref.state,
nonce = _ref.nonce;
if (options.auth && options.auth.redirectUri) {
console.warn("You're sending an `auth` option named `redirectUri`. This option will be ignored. Use `redirectUrl` instead.");
}
audience = typeof audience === 'string' ? audience : undefined;
connectionScopes = (typeof connectionScopes === 'undefined' ? 'undefined' : _typeof(connectionScopes)) === 'object' ? connectionScopes : {};
params = (typeof params === 'undefined' ? 'undefined' : _typeof(params)) === 'object' ? params : {};
// by default is null because we need to know if it was set when we curate the responseType
redirectUrl = typeof redirectUrl === 'string' && redirectUrl ? redirectUrl : null;
autoParseHash = typeof autoParseHash === 'boolean' ? autoParseHash : true;
redirect = typeof redirect === 'boolean' ? redirect : true;
responseMode = typeof responseMode === 'string' ? responseMode : undefined;
state = typeof state === 'string' ? state : undefined;
nonce = typeof nonce === 'string' ? nonce : undefined;
// if responseType was not set and there is a redirectUrl, it defaults to code. Otherwise token.
responseType = typeof responseType === 'string' ? responseType : redirectUrl ? 'code' : 'token';
// now we set the default because we already did the validation
redirectUrl = redirectUrl || '' + (0, _url_utils.getOriginFromUrl)(window.location.href) + window.location.pathname;
sso = typeof sso === 'boolean' ? sso : true;
if (!params.scope) {
params.scope = 'openid profile email';
}
return _immutable2.default.fromJS({
audience: audience,
connectionScopes: connectionScopes,
params: params,
autoParseHash: autoParseHash,
redirect: redirect,
redirectUrl: redirectUrl,
responseMode: responseMode,
responseType: responseType,
sso: sso,
state: state,
nonce: nonce
});
}
function withAuthOptions(m, opts) {
return _immutable2.default.fromJS(opts).merge(get(m, 'auth')).toJS();
}
function extractClientBaseUrlOption(opts, domain) {
if (opts.clientBaseUrl && typeof opts.clientBaseUrl === 'string') {
return opts.clientBaseUrl;
}
if (opts.configurationBaseUrl && typeof opts.configurationBaseUrl === 'string') {
return opts.configurationBaseUrl;
}
if (opts.assetsUrl && typeof opts.assetsUrl === 'string') {
return opts.assetsUrl;
}
var domainUrl = 'https://' + domain;
var hostname = (0, _url_utils.getLocationFromUrl)(domainUrl).hostname;
var DOT_AUTH0_DOT_COM = '.auth0.com';
var AUTH0_US_CDN_URL = 'https://cdn.auth0.com';
if ((0, _string_utils.endsWith)(hostname, DOT_AUTH0_DOT_COM)) {
var parts = hostname.split('.');
return parts.length > 3 ? 'https://cdn.' + parts[parts.length - 3] + DOT_AUTH0_DOT_COM : AUTH0_US_CDN_URL;
} else {
return domainUrl;
}
}
function extractTenantBaseUrlOption(opts, domain) {
if (opts.configurationBaseUrl && typeof opts.configurationBaseUrl === 'string') {
if (opts.overrides && opts.overrides.__tenant) {
// When using a custom domain and a configuration URL hosted in auth0's cdn
return (0, _urlJoin2.default)(opts.configurationBaseUrl, 'tenants', 'v1', opts.overrides.__tenant + '.js');
}
return (0, _urlJoin2.default)(opts.configurationBaseUrl, 'info-v1.js');
}
if (opts.assetsUrl && typeof opts.assetsUrl === 'string') {
return opts.assetsUrl;
}
var domainUrl = 'https://' + domain;
var hostname = (0, _url_utils.getLocationFromUrl)(domainUrl).hostname;
var DOT_AUTH0_DOT_COM = '.auth0.com';
var AUTH0_US_CDN_URL = 'https://cdn.auth0.com';
var parts = hostname.split('.');
var tenant_name = parts[0];
var domain;
if ((0, _string_utils.endsWith)(hostname, DOT_AUTH0_DOT_COM)) {
domain = parts.length > 3 ? 'https://cdn.' + parts[parts.length - 3] + DOT_AUTH0_DOT_COM : AUTH0_US_CDN_URL;
return (0, _urlJoin2.default)(domain, 'tenants', 'v1', tenant_name + '.js');
} else {
return (0, _urlJoin2.default)(domainUrl, 'info-v1.js');
}
}
function extractLanguageBaseUrlOption(opts, domain) {
if (opts.languageBaseUrl && typeof opts.languageBaseUrl === 'string') {
return opts.languageBaseUrl;
}
if (opts.assetsUrl && typeof opts.assetsUrl === 'string') {
return opts.assetsUrl;
}
return 'https://cdn.auth0.com';
}
function render(m) {
return tset(m, 'render', true);
}
exports.reset = reset;
function setLoggedIn(m, value) {
return tset(m, 'loggedIn', value);
}
function loggedIn(m) {
return tget(m, 'loggedIn', false);
}
function defaultADUsernameFromEmailPrefix(m) {
return get(m, 'defaultADUsernameFromEmailPrefix', true);
}
function prefill(m) {
return get(m, 'prefill', {});
}
function warn(x, str) {
var shouldOutput = _immutable.Map.isMap(x) ? !ui.disableWarnings(x) : !x.disableWarnings;
if (shouldOutput && console && console.warn) {
console.warn(str);
}
}
function error(x, str) {
var shouldOutput = _immutable.Map.isMap(x) ? !ui.disableWarnings(x) : !x.disableWarnings;
if (shouldOutput && console && console.error) {
console.error(str);
}
}
function allowedConnections(m) {
return tget(m, 'allowedConnections') || get(m, 'allowedConnections');
}
function connections(m) {
for (var _len = arguments.length, strategies = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
strategies[_key - 2] = arguments[_key];
}
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
if (arguments.length === 1) {
return tget(m, 'connections', (0, _immutable.Map)()).filter(function (v, k) {
return k !== 'unknown';
}).valueSeq().flatten(true);
}
var xs = tget(m, ['connections', type], (0, _immutable.List)());
return strategies.length > 0 ? xs.filter(function (x) {
return ~strategies.indexOf(x.get('strategy'));
}) : xs;
}
function connection(m) {
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
for (var _len2 = arguments.length, strategies = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {
strategies[_key2 - 2] = arguments[_key2];
}
return connections.apply(undefined, [m, type].concat(strategies)).get(0);
}
function hasOneConnection(m) {
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
var xs = connections(m);
return xs.count() === 1 && (!type || xs.getIn([0, 'type']) === type);
}
function hasOnlyConnections(m) {
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
var all = connections(m).count();
for (var _len3 = arguments.length, strategies = Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {
strategies[_key3 - 2] = arguments[_key3];
}
var filtered = connections.apply(undefined, [m, type].concat(strategies)).count();
return all > 0 && all === filtered;
}
function hasSomeConnections(m) {
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
for (var _len4 = arguments.length, strategies = Array(_len4 > 2 ? _len4 - 2 : 0), _key4 = 2; _key4 < _len4; _key4++) {
strategies[_key4 - 2] = arguments[_key4];
}
return countConnections.apply(undefined, [m, type].concat(strategies)) > 0;
}
function countConnections(m) {
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined;
for (var _len5 = arguments.length, strategies = Array(_len5 > 2 ? _len5 - 2 : 0), _key5 = 2; _key5 < _len5; _key5++) {
strategies[_key5 - 2] = arguments[_key5];
}
return connections.apply(undefined, [m, type].concat(strategies)).count();
}
function findConnection(m, name) {
return connections(m).find(function (m1) {
return m1.get('name') === name;
});
}
function hasConnection(m, name) {
return !!findConnection(m, name);
}
function filterConnections(m) {
var allowed = allowedConnections(m);
var order = allowed.count() === 0 ? function (_) {
return 0;
} : function (c) {
return allowed.indexOf(c.get('name'));
};
return tset(m, 'connections', (0, _index.clientConnections)(m).map(function (cs) {
return cs.filter(function (c) {
return order(c) >= 0;
}).sort(function (c1, c2) {
return order(c1) - order(c2);
});
}));
}
function runHook(m, str) {
for (var _len6 = arguments.length, args = Array(_len6 > 2 ? _len6 - 2 : 0), _key6 = 2; _key6 < _len6; _key6++) {
args[_key6 - 2] = arguments[_key6];
}
return get(m, 'hookRunner').apply(undefined, [str, m].concat(args));
}
function emitEvent(m, str) {
for (var _len7 = arguments.length, args = Array(_len7 > 2 ? _len7 - 2 : 0), _key7 = 2; _key7 < _len7; _key7++) {
args[_key7 - 2] = arguments[_key7];
}
setTimeout(function () {
var emitEventFn = get(m, 'emitEventFn');
var hadListener = emitEventFn.apply(undefined, [str].concat(args));
// Handle uncaught custom error
if (str === 'unrecoverable_error' && !hadListener) {
throw new (Function.prototype.bind.apply(Error, [null].concat(args)))();
}
}, 0);
}
function loginErrorMessage(m, error, type) {
// NOTE: previous version of lock checked for status codes and, at
// some point, if the status code was 401 it defaults to an
// "invalid_user_password" error (actually the
// "wrongEmailPasswordErrorText" dict entry) instead of checking
// explicitly. We should figure out if there was a reason for that.
if (error.status === 0) {
return i18n.html(m, ['error', 'login', 'lock.network']);
}
// Custom rule error (except blocked_user)
if (error.code === 'rule_error') {
return error.description || i18n.html(m, ['error', 'login', 'lock.fallback']);
}
var INVALID_MAP = {
code: 'lock.invalid_code',
email: 'lock.invalid_email_password',
username: 'lock.invalid_username_password'
};
var code = error.error || error.code;
if (code === 'invalid_user_password' && INVALID_MAP[type]) {
code = INVALID_MAP[type];
}
if (code === 'a0.mfa_registration_required') {
code = 'lock.mfa_registration_required';
}
if (code === 'a0.mfa_invalid_code') {
code = 'lock.mfa_invalid_code';
}
if (code === 'password_expired') {
code = 'password_change_required';
}
return i18n.html(m, ['error', 'login', code]) || i18n.html(m, ['error', 'login', 'lock.fallback']);
}
// TODO: rename to something less generic that is easier to grep
function stop(m, error) {
if (error) {
setTimeout(function () {
return emitEvent(m, 'unrecoverable_error', error);
}, 17);
}
return set(m, 'stopped', true);
}
function hasStopped(m) {
return get(m, 'stopped');
}
function hashCleanup(m) {
return get(m, 'hashCleanup');
}
function emitHashParsedEvent(m, parsedHash) {
emitEvent(m, 'hash_parsed', parsedHash);
}
function emitAuthenticatedEvent(m, result) {
emitEvent(m, 'authenticated', result);
}
function emitAuthorizationErrorEvent(m, error) {
emitEvent(m, 'authorization_error', error);
}
function emitUnrecoverableErrorEvent(m, error) {
emitEvent(m, 'unrecoverable_error', error);
}
function showBadge(m) {
return (0, _index.hasFreeSubscription)(m) || false;
}
function overrideOptions(m, opts) {
if (!opts) opts = {};
if (opts.allowedConnections) {
m = tset(m, 'allowedConnections', _immutable2.default.fromJS(opts.allowedConnections));
}
if (opts.flashMessage) {
var type = opts.flashMessage.type;
var typeCapitalized = type.charAt(0).toUpperCase() + type.slice(1);
m = tset(m, 'global' + typeCapitalized, opts.flashMessage.text);
}
if (opts.auth && opts.auth.params) {
m = tset(m, 'authParams', _immutable2.default.fromJS(opts.auth.params));
}
if (opts.theme) {
if (opts.theme.primaryColor) {
m = tset(m, ['ui', 'primaryColor'], opts.theme.primaryColor);
}
if (opts.theme.logo) {
m = tset(m, ['ui', 'logo'], opts.theme.logo);
}
}
if (opts.language || opts.languageDictionary) {
if (opts.language) {
m = tset(m, ['ui', 'language'], opts.language);
}
if (opts.languageDictionary) {
m = tset(m, ['ui', 'dict'], opts.languageDictionary);
}
m = i18n.initI18n(m);
}
if (typeof opts.rememberLastLogin === 'boolean') {
m = tset(m, 'rememberLastLogin', opts.rememberLastLogin);
}
if (typeof opts.allowAutocomplete === 'boolean') {
m = tset(m, 'allowAutocomplete', opts.allowAutocomplete);
}
if (typeof opts.allowShowPassword === 'boolean') {
m = tset(m, 'allowShowPassword', opts.allowShowPassword);
}
if (typeof opts.allowPasswordAutocomplete === 'boolean') {
m = tset(m, 'allowPasswordAutocomplete', opts.allowPasswordAutocomplete);
}
return m;
}