"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.AccountLockout = void 0; var _node = _interopRequireDefault(require("parse/node")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } // This class handles the Account Lockout Policy settings. class AccountLockout { constructor(user, config) { this._user = user; this._config = config; } /** * set _failed_login_count to value */ _setFailedLoginCount(value) { const query = { username: this._user.username }; const updateFields = { _failed_login_count: value }; return this._config.database.update('_User', query, updateFields); } /** * check if the _failed_login_count field has been set */ _isFailedLoginCountSet() { const query = { username: this._user.username, _failed_login_count: { $exists: true } }; return this._config.database.find('_User', query).then(users => { if (Array.isArray(users) && users.length > 0) { return true; } else { return false; } }); } /** * if _failed_login_count is NOT set then set it to 0 * else do nothing */ _initFailedLoginCount() { return this._isFailedLoginCountSet().then(failedLoginCountIsSet => { if (!failedLoginCountIsSet) { return this._setFailedLoginCount(0); } }); } /** * increment _failed_login_count by 1 */ _incrementFailedLoginCount() { const query = { username: this._user.username }; const updateFields = { _failed_login_count: { __op: 'Increment', amount: 1 } }; return this._config.database.update('_User', query, updateFields); } /** * if the failed login count is greater than the threshold * then sets lockout expiration to 'currenttime + accountPolicy.duration', i.e., account is locked out for the next 'accountPolicy.duration' minutes * else do nothing */ _setLockoutExpiration() { const query = { username: this._user.username, _failed_login_count: { $gte: this._config.accountLockout.threshold } }; const now = new Date(); const updateFields = { _account_lockout_expires_at: _node.default._encode(new Date(now.getTime() + this._config.accountLockout.duration * 60 * 1000)) }; return this._config.database.update('_User', query, updateFields).catch(err => { if (err && err.code && err.message && err.code === _node.default.Error.OBJECT_NOT_FOUND && err.message === 'Object not found.') { return; // nothing to update so we are good } else { throw err; // unknown error } }); } /** * if _account_lockout_expires_at > current_time and _failed_login_count > threshold * reject with account locked error * else * resolve */ _notLocked() { const query = { username: this._user.username, _account_lockout_expires_at: { $gt: _node.default._encode(new Date()) }, _failed_login_count: { $gte: this._config.accountLockout.threshold } }; return this._config.database.find('_User', query).then(users => { if (Array.isArray(users) && users.length > 0) { throw new _node.default.Error(_node.default.Error.OBJECT_NOT_FOUND, 'Your account is locked due to multiple failed login attempts. Please try again after ' + this._config.accountLockout.duration + ' minute(s)'); } }); } /** * set and/or increment _failed_login_count * if _failed_login_count > threshold * set the _account_lockout_expires_at to current_time + accountPolicy.duration * else * do nothing */ _handleFailedLoginAttempt() { return this._initFailedLoginCount().then(() => { return this._incrementFailedLoginCount(); }).then(() => { return this._setLockoutExpiration(); }); } /** * handle login attempt if the Account Lockout Policy is enabled */ handleLoginAttempt(loginSuccessful) { if (!this._config.accountLockout) { return Promise.resolve(); } return this._notLocked().then(() => { if (loginSuccessful) { return this._setFailedLoginCount(0); } else { return this._handleFailedLoginAttempt(); } }); } /** * Removes the account lockout. */ unlockAccount() { if (!this._config.accountLockout || !this._config.accountLockout.unlockOnPasswordReset) { return Promise.resolve(); } return this._config.database.update('_User', { username: this._user.username }, { _failed_login_count: { __op: 'Delete' }, _account_lockout_expires_at: { __op: 'Delete' } }); } } exports.AccountLockout = AccountLockout; var _default = exports.default = AccountLockout; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","e","__esModule","default","AccountLockout","constructor","user","config","_user","_config","_setFailedLoginCount","value","query","username","updateFields","_failed_login_count","database","update","_isFailedLoginCountSet","$exists","find","then","users","Array","isArray","length","_initFailedLoginCount","failedLoginCountIsSet","_incrementFailedLoginCount","__op","amount","_setLockoutExpiration","$gte","accountLockout","threshold","now","Date","_account_lockout_expires_at","Parse","_encode","getTime","duration","catch","err","code","message","Error","OBJECT_NOT_FOUND","_notLocked","$gt","_handleFailedLoginAttempt","handleLoginAttempt","loginSuccessful","Promise","resolve","unlockAccount","unlockOnPasswordReset","exports","_default"],"sources":["../src/AccountLockout.js"],"sourcesContent":["// This class handles the Account Lockout Policy settings.\nimport Parse from 'parse/node';\n\nexport class AccountLockout {\n  constructor(user, config) {\n    this._user = user;\n    this._config = config;\n  }\n\n  /**\n   * set _failed_login_count to value\n   */\n  _setFailedLoginCount(value) {\n    const query = {\n      username: this._user.username,\n    };\n\n    const updateFields = {\n      _failed_login_count: value,\n    };\n\n    return this._config.database.update('_User', query, updateFields);\n  }\n\n  /**\n   * check if the _failed_login_count field has been set\n   */\n  _isFailedLoginCountSet() {\n    const query = {\n      username: this._user.username,\n      _failed_login_count: { $exists: true },\n    };\n\n    return this._config.database.find('_User', query).then(users => {\n      if (Array.isArray(users) && users.length > 0) {\n        return true;\n      } else {\n        return false;\n      }\n    });\n  }\n\n  /**\n   * if _failed_login_count is NOT set then set it to 0\n   * else do nothing\n   */\n  _initFailedLoginCount() {\n    return this._isFailedLoginCountSet().then(failedLoginCountIsSet => {\n      if (!failedLoginCountIsSet) {\n        return this._setFailedLoginCount(0);\n      }\n    });\n  }\n\n  /**\n   * increment _failed_login_count by 1\n   */\n  _incrementFailedLoginCount() {\n    const query = {\n      username: this._user.username,\n    };\n\n    const updateFields = {\n      _failed_login_count: { __op: 'Increment', amount: 1 },\n    };\n\n    return this._config.database.update('_User', query, updateFields);\n  }\n\n  /**\n   * if the failed login count is greater than the threshold\n   * then sets lockout expiration to 'currenttime + accountPolicy.duration', i.e., account is locked out for the next 'accountPolicy.duration' minutes\n   * else do nothing\n   */\n  _setLockoutExpiration() {\n    const query = {\n      username: this._user.username,\n      _failed_login_count: { $gte: this._config.accountLockout.threshold },\n    };\n\n    const now = new Date();\n\n    const updateFields = {\n      _account_lockout_expires_at: Parse._encode(\n        new Date(now.getTime() + this._config.accountLockout.duration * 60 * 1000)\n      ),\n    };\n\n    return this._config.database.update('_User', query, updateFields).catch(err => {\n      if (\n        err &&\n        err.code &&\n        err.message &&\n        err.code === Parse.Error.OBJECT_NOT_FOUND &&\n        err.message === 'Object not found.'\n      ) {\n        return; // nothing to update so we are good\n      } else {\n        throw err; // unknown error\n      }\n    });\n  }\n\n  /**\n   * if _account_lockout_expires_at > current_time and _failed_login_count > threshold\n   *   reject with account locked error\n   * else\n   *   resolve\n   */\n  _notLocked() {\n    const query = {\n      username: this._user.username,\n      _account_lockout_expires_at: { $gt: Parse._encode(new Date()) },\n      _failed_login_count: { $gte: this._config.accountLockout.threshold },\n    };\n\n    return this._config.database.find('_User', query).then(users => {\n      if (Array.isArray(users) && users.length > 0) {\n        throw new Parse.Error(\n          Parse.Error.OBJECT_NOT_FOUND,\n          'Your account is locked due to multiple failed login attempts. Please try again after ' +\n            this._config.accountLockout.duration +\n            ' minute(s)'\n        );\n      }\n    });\n  }\n\n  /**\n   * set and/or increment _failed_login_count\n   * if _failed_login_count > threshold\n   *   set the _account_lockout_expires_at to current_time + accountPolicy.duration\n   * else\n   *   do nothing\n   */\n  _handleFailedLoginAttempt() {\n    return this._initFailedLoginCount()\n      .then(() => {\n        return this._incrementFailedLoginCount();\n      })\n      .then(() => {\n        return this._setLockoutExpiration();\n      });\n  }\n\n  /**\n   * handle login attempt if the Account Lockout Policy is enabled\n   */\n  handleLoginAttempt(loginSuccessful) {\n    if (!this._config.accountLockout) {\n      return Promise.resolve();\n    }\n    return this._notLocked().then(() => {\n      if (loginSuccessful) {\n        return this._setFailedLoginCount(0);\n      } else {\n        return this._handleFailedLoginAttempt();\n      }\n    });\n  }\n\n  /**\n   * Removes the account lockout.\n   */\n  unlockAccount() {\n    if (!this._config.accountLockout || !this._config.accountLockout.unlockOnPasswordReset) {\n      return Promise.resolve();\n    }\n    return this._config.database.update(\n      '_User',\n      { username: this._user.username },\n      {\n        _failed_login_count: { __op: 'Delete' },\n        _account_lockout_expires_at: { __op: 'Delete' },\n      }\n    );\n  }\n}\n\nexport default AccountLockout;\n"],"mappings":"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","ignoreList":[]}