123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- "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":[]}
|