UNPKG

auth0-lock

Version:
187 lines (184 loc) 10.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; exports.hasOnlyClassicConnections = hasOnlyClassicConnections; exports.isSSOEnabled = isSSOEnabled; exports.matchesEnterpriseConnection = matchesEnterpriseConnection; exports.usernameStyle = usernameStyle; var _index = _interopRequireDefault(require("../index")); var _login = _interopRequireDefault(require("./classic/login")); var _sign_up_screen = _interopRequireDefault(require("./classic/sign_up_screen")); var _mfa_login_screen = _interopRequireDefault(require("./classic/mfa_login_screen")); var _reset_password = _interopRequireDefault(require("../connection/database/reset_password")); var _index2 = _interopRequireWildcard(require("../core/sso/index")); var sso = _index2; var _index3 = require("../connection/database/index"); var _enterprise = require("../connection/enterprise"); var _tenant = require("../core/tenant"); var _email = require("../field/email"); var _username = require("../field/username"); var l = _interopRequireWildcard(require("../core/index")); var _kerberos_screen = _interopRequireDefault(require("../connection/enterprise/kerberos_screen")); var _hrd_screen = _interopRequireDefault(require("../connection/enterprise/hrd_screen")); var _quick_auth_screen = _interopRequireDefault(require("../connection/enterprise/quick_auth_screen")); var _quick_auth = require("../quick_auth"); var _loading_screen = _interopRequireDefault(require("../core/loading_screen")); var _error_screen = _interopRequireDefault(require("../core/error_screen")); var _last_login_screen = _interopRequireDefault(require("../core/sso/last_login_screen")); var _sync = require("../sync"); var _index5 = require("../field/index"); var _index6 = require("../store/index"); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); } function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function isSSOEnabled(m, options) { return matchesEnterpriseConnection(m, (0, _index3.databaseUsernameValue)(m, options)); } function matchesEnterpriseConnection(m, usernameValue) { return (0, _enterprise.isEnterpriseDomain)(m, usernameValue); } function usernameStyle(m) { return (0, _index3.authWithUsername)(m) && !(0, _enterprise.isADEnabled)(m) ? 'username' : 'email'; } function hasOnlyClassicConnections(m) { var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined; for (var _len = arguments.length, strategies = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { strategies[_key - 2] = arguments[_key]; } return l.hasOnlyConnections.apply(l, [m, type].concat(strategies)) && !l.hasSomeConnections(m, 'passwordless'); } function validateAllowedConnections(m) { var anyDBConnection = l.hasSomeConnections(m, 'database'); var anySocialConnection = l.hasSomeConnections(m, 'social'); var anyEnterpriseConnection = l.hasSomeConnections(m, 'enterprise'); if (!anyDBConnection && !anySocialConnection && !anyEnterpriseConnection) { var error = new Error('At least one database, enterprise or social connection needs to be available.'); error.code = 'no_connection'; m = l.stop(m, error); } else if (!anyDBConnection && (0, _index3.hasInitialScreen)(m, 'forgotPassword')) { var _error = new Error('The `initialScreen` option was set to "forgotPassword" but no database connection is available.'); _error.code = 'unavailable_initial_screen'; m = l.stop(m, _error); } else if (!anyDBConnection && !anySocialConnection && (0, _index3.hasInitialScreen)(m, 'signUp')) { var _error2 = new Error('The `initialScreen` option was set to "signUp" but no database or social connection is available.'); _error2.code = 'unavailable_initial_screen'; m = l.stop(m, _error2); } if ((0, _tenant.defaultDirectoryName)(m) && !(0, _tenant.defaultDirectory)(m)) { l.error(m, "The account's default directory \"".concat((0, _tenant.defaultDirectoryName)(m), "\" is not enabled.")); } if ((0, _index3.defaultDatabaseConnectionName)(m) && !(0, _index3.defaultDatabaseConnection)(m)) { l.warn(m, "The provided default database connection \"".concat((0, _index3.defaultDatabaseConnectionName)(m), "\" is not enabled.")); } if ((0, _enterprise.defaultEnterpriseConnectionName)(m) && !(0, _enterprise.defaultEnterpriseConnection)(m)) { l.warn(m, "The provided default enterprise connection \"".concat((0, _enterprise.defaultEnterpriseConnectionName)(m), "\" is not enabled or does not allow email/password authentication.")); } return m; } var setPrefill = function setPrefill(m) { var _l$prefill$toJS = l.prefill(m).toJS(), email = _l$prefill$toJS.email, username = _l$prefill$toJS.username; if (typeof email === 'string') m = (0, _email.setEmail)(m, email); if (typeof username === 'string') m = (0, _username.setUsername)(m, username, 'username', false); return m; }; function createErrorScreen(m, stopError) { setTimeout(function () { (0, _index6.swap)(_index6.updateEntity, 'lock', l.id(m), l.stop, stopError); }, 0); return new _error_screen.default(); } var Classic = /*#__PURE__*/function () { function Classic() { _classCallCheck(this, Classic); } return _createClass(Classic, [{ key: "didInitialize", value: function didInitialize(model, options) { model = (0, _index3.initDatabase)(model, options); model = (0, _enterprise.initEnterprise)(model, options); return model; } }, { key: "didReceiveClientSettings", value: function didReceiveClientSettings(m) { m = validateAllowedConnections(m); m = setPrefill(m); return m; } }, { key: "willShow", value: function willShow(m, opts) { m = (0, _index3.overrideDatabaseOptions)(m, opts); m = (0, _index3.resolveAdditionalSignUpFields)(m); if ((0, _sync.isSuccess)(m, 'client')) { m = validateAllowedConnections(m); } return m; } }, { key: "render", value: function render(m) { //if there's an error, we should show the error screen no matter what. if (l.hasStopped(m)) { return new _error_screen.default(); } // TODO: remove the detail about the loading pane being pinned, // sticky screens should be handled at the box module. if (!(0, _sync.isDone)(m) || m.get('isLoadingPanePinned')) { return new _loading_screen.default(); } if ((0, _index3.hasScreen)(m, 'login')) { if (!(0, _quick_auth.hasSkippedQuickAuth)(m) && (0, _index3.hasInitialScreen)(m, 'login')) { if ((0, _enterprise.isInCorpNetwork)(m)) { return new _kerberos_screen.default(); } if (l.ui.rememberLastLogin(m)) { var lastUsedConnection = sso.lastUsedConnection(m); var lastUsedUsername = sso.lastUsedUsername(m); if (lastUsedConnection && (0, _sync.isSuccess)(m, 'sso') && l.hasConnection(m, lastUsedConnection.get('name')) && l.findConnection(m, lastUsedConnection.get('name')).get('type') !== 'passwordless') { return new _last_login_screen.default(); } } } if ((0, _enterprise.quickAuthConnection)(m)) { return new _quick_auth_screen.default(); } if ((0, _enterprise.isHRDActive)(m)) { return new _hrd_screen.default(); } } if (!(0, _index3.hasScreen)(m, 'login') && !(0, _index3.hasScreen)(m, 'signUp') && !(0, _index3.hasScreen)(m, 'forgotPassword')) { var errorMessage = 'No available Screen. You have to allow at least one of those screens: `login`, `signUp`or `forgotPassword`.'; var noAvailableScreenError = new Error(errorMessage); noAvailableScreenError.code = 'internal_error'; noAvailableScreenError.description = errorMessage; return createErrorScreen(m, noAvailableScreenError); } var Screen = Classic.SCREENS[(0, _index3.getScreen)(m)]; if (Screen) { return new Screen(); } var noScreenError = new Error('Internal error'); noScreenError.code = 'internal_error'; noScreenError.description = "Couldn't find a screen \"".concat((0, _index3.getScreen)(m), "\""); return createErrorScreen(m, noScreenError); } }]); }(); _defineProperty(Classic, "SCREENS", { login: _login.default, forgotPassword: _reset_password.default, signUp: _sign_up_screen.default, mfaLogin: _mfa_login_screen.default }); var _default = exports.default = new Classic();