parse-server 9.6.0-alpha.9 → 9.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/lib/AccountLockout.js +14 -42
  2. package/lib/Adapters/Auth/index.js +2 -2
  3. package/lib/Adapters/Auth/oauth2.js +2 -2
  4. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +3 -3
  5. package/lib/Adapters/Storage/Mongo/MongoTransform.js +30 -30
  6. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +53 -16
  7. package/lib/Auth.js +35 -9
  8. package/lib/Config.js +6 -5
  9. package/lib/Controllers/DatabaseController.js +134 -27
  10. package/lib/Controllers/FilesController.js +2 -2
  11. package/lib/Controllers/LiveQueryController.js +2 -2
  12. package/lib/Controllers/ParseGraphQLController.js +3 -2
  13. package/lib/Controllers/SchemaController.js +3 -7
  14. package/lib/Controllers/UserController.js +12 -3
  15. package/lib/Deprecator/Deprecations.js +41 -1
  16. package/lib/GraphQL/ParseGraphQLServer.js +1 -12
  17. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +6 -5
  18. package/lib/GraphQL/loaders/functionsMutations.js +3 -4
  19. package/lib/GraphQL/loaders/parseClassMutations.js +4 -5
  20. package/lib/GraphQL/loaders/parseClassQueries.js +3 -4
  21. package/lib/GraphQL/loaders/schemaMutations.js +4 -5
  22. package/lib/GraphQL/loaders/schemaQueries.js +2 -3
  23. package/lib/GraphQL/loaders/usersMutations.js +5 -5
  24. package/lib/GraphQL/parseGraphQLUtils.js +9 -1
  25. package/lib/GraphQL/transformers/query.js +2 -2
  26. package/lib/LiveQuery/ParseLiveQueryServer.js +165 -14
  27. package/lib/LiveQuery/QueryTools.js +28 -19
  28. package/lib/Options/Definitions.js +40 -16
  29. package/lib/Options/docs.js +14 -10
  30. package/lib/Options/index.js +1 -1
  31. package/lib/ParseServer.js +9 -4
  32. package/lib/Push/PushWorker.js +2 -4
  33. package/lib/Push/utils.js +3 -4
  34. package/lib/RestQuery.js +32 -4
  35. package/lib/RestWrite.js +50 -24
  36. package/lib/Routers/AggregateRouter.js +9 -2
  37. package/lib/Routers/ClassesRouter.js +6 -2
  38. package/lib/Routers/FilesRouter.js +4 -3
  39. package/lib/Routers/PagesRouter.js +44 -20
  40. package/lib/Routers/UsersRouter.js +60 -26
  41. package/lib/Security/Check.js +2 -2
  42. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +2 -2
  43. package/lib/StatusHandler.js +3 -2
  44. package/lib/Utils.js +74 -8
  45. package/lib/batch.js +39 -36
  46. package/lib/cloud-code/Parse.Cloud.js +2 -2
  47. package/lib/middlewares.js +36 -11
  48. package/lib/triggers.js +9 -2
  49. package/package.json +1 -3
@@ -169,30 +169,34 @@ class UsersRouter extends _ClassesRouter.default {
169
169
  });
170
170
  });
171
171
  }
172
- handleMe(req) {
172
+ async handleMe(req) {
173
173
  if (!req.info || !req.info.sessionToken) {
174
174
  throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);
175
175
  }
176
176
  const sessionToken = req.info.sessionToken;
177
- return _rest.default.find(req.config, _Auth.default.master(req.config), '_Session', {
177
+ // Query the session with master key to validate the session token,
178
+ // but do NOT include 'user' to avoid leaking user data via master context
179
+ const sessionResponse = await _rest.default.find(req.config, _Auth.default.master(req.config), '_Session', {
178
180
  sessionToken
179
- }, {
180
- include: 'user'
181
- }, req.info.clientSDK, req.info.context).then(response => {
182
- if (!response.results || response.results.length == 0 || !response.results[0].user) {
183
- throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);
184
- } else {
185
- const user = response.results[0].user;
186
- // Send token back on the login, because SDKs expect that.
187
- user.sessionToken = sessionToken;
188
-
189
- // Remove hidden properties.
190
- UsersRouter.removeHiddenProperties(user);
191
- return {
192
- response: user
193
- };
194
- }
195
- });
181
+ }, {}, req.info.clientSDK, req.info.context);
182
+ if (!sessionResponse.results || sessionResponse.results.length == 0 || !sessionResponse.results[0].user) {
183
+ throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);
184
+ }
185
+ const userId = sessionResponse.results[0].user.objectId;
186
+ // Re-fetch the user with the caller's auth context so that
187
+ // protectedFields, CLP, and auth adapter afterFind apply correctly
188
+ const userResponse = await _rest.default.get(req.config, req.auth, '_User', userId, {}, req.info.clientSDK, req.info.context);
189
+ if (!userResponse.results || userResponse.results.length == 0) {
190
+ throw (0, _Error.createSanitizedError)(_node.default.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);
191
+ }
192
+ const user = userResponse.results[0];
193
+ // Send token back on the login, because SDKs expect that.
194
+ user.sessionToken = sessionToken;
195
+ // Remove hidden properties.
196
+ UsersRouter.removeHiddenProperties(user);
197
+ return {
198
+ response: user
199
+ };
196
200
  }
197
201
  async handleLogIn(req) {
198
202
  const user = await this._authenticateUserFromRequest(req);
@@ -247,11 +251,36 @@ class UsersRouter extends _ClassesRouter.default {
247
251
 
248
252
  // If we have some new validated authData update directly
249
253
  if (validatedAuthData && Object.keys(validatedAuthData).length) {
250
- await req.config.database.update('_User', {
254
+ const query = {
251
255
  objectId: user.objectId
252
- }, {
253
- authData: validatedAuthData
254
- }, {});
256
+ };
257
+ // Optimistic locking: include the original array fields in the WHERE clause
258
+ // for providers whose data is being updated. This prevents concurrent requests
259
+ // from both succeeding when consuming single-use tokens (e.g. MFA recovery codes).
260
+ // Only array fields need locking — element removal is vulnerable to TOCTOU;
261
+ // scalar fields are simply overwritten and don't have concurrency issues.
262
+ if (user.authData) {
263
+ for (const provider of Object.keys(validatedAuthData)) {
264
+ const original = user.authData[provider];
265
+ if (original && typeof original === 'object') {
266
+ for (const [field, value] of Object.entries(original)) {
267
+ if (Array.isArray(value) && JSON.stringify(value) !== JSON.stringify(validatedAuthData[provider]?.[field])) {
268
+ query[`authData.${provider}.${field}`] = value;
269
+ }
270
+ }
271
+ }
272
+ }
273
+ }
274
+ try {
275
+ await req.config.database.update('_User', query, {
276
+ authData: validatedAuthData
277
+ }, {});
278
+ } catch (error) {
279
+ if (error.code === _node.default.Error.OBJECT_NOT_FOUND) {
280
+ throw new _node.default.Error(_node.default.Error.SCRIPT_FAILED, 'Invalid auth data');
281
+ }
282
+ throw error;
283
+ }
255
284
  }
256
285
  const {
257
286
  sessionData,
@@ -523,7 +552,12 @@ class UsersRouter extends _ClassesRouter.default {
523
552
  if (user) {
524
553
  throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, 'You cannot provide username/email and authData, only use one identification method.');
525
554
  }
526
- if (Object.keys(authData).filter(key => authData[key].id).length > 1) {
555
+ for (const key of Object.keys(authData)) {
556
+ if (authData[key] !== null && (typeof authData[key] !== 'object' || Array.isArray(authData[key]))) {
557
+ throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, `authData.${key} should be an object.`);
558
+ }
559
+ }
560
+ if (Object.keys(authData).filter(key => authData[key] && authData[key].id).length > 1) {
527
561
  throw new _node.default.Error(_node.default.Error.OTHER_CAUSE, 'You cannot provide more than one authData provider with an id.');
528
562
  }
529
563
  const results = await _Auth.default.findUsersWithAuthData(req.config, authData);
@@ -532,7 +566,7 @@ class UsersRouter extends _ClassesRouter.default {
532
566
  throw new _node.default.Error(_node.default.Error.OBJECT_NOT_FOUND, 'User not found.');
533
567
  }
534
568
  // Find the provider used to find the user
535
- const provider = Object.keys(authData).find(key => authData[key].id);
569
+ const provider = Object.keys(authData).find(key => authData[key] && authData[key].id);
536
570
  parseUser = _node.default.User.fromJSON({
537
571
  className: '_User',
538
572
  ...results[0]
@@ -652,4 +686,4 @@ class UsersRouter extends _ClassesRouter.default {
652
686
  }
653
687
  exports.UsersRouter = UsersRouter;
654
688
  var _default = exports.default = UsersRouter;
655
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","_Error","e","__esModule","default","UsersRouter","ClassesRouter","className","removeHiddenProperties","obj","key","Object","prototype","hasOwnProperty","call","test","_sanitizeAuthData","user","password","authData","keys","forEach","provider","length","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","ignoreEmailVerification","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","filter","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","authProvider","join","request","master","ip","installationId","object","User","fromJSON","assign","createdWith","RestWrite","buildCreatedWith","isMaintenance","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","createSanitizedError","INVALID_SESSION_TOKEN","rest","include","clientSDK","context","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","res","handleAuthDataValidation","objectId","passwordPolicy","maxPasswordAge","changedAt","_password_changed_at","Date","update","_encode","__type","iso","expiresAt","getTime","filesController","expandFilesInObject","maybeRunTrigger","TriggerTypes","beforeLogin","sessionData","createSession","userId","afterLoginUser","afterLogin","authDataManager","runAfterFind","handleLogInAs","OPERATION_FORBIDDEN","isReadOnly","INVALID_VALUE","queryResults","handleVerifyPassword","handleLogOut","success","records","undefined","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","_publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","INTERNAL_SERVER_ERROR","handleResetRequest","token","EMAIL_MISSING","userResults","userData","_perishable_token","_perishable_token_expires_at","$lt","$exists","limit","INVALID_EMAIL_ADDRESS","inflate","beforePasswordResetRequest","sendPasswordResetEmail","err","code","resetPasswordSuccessOnInvalidEmail","message","handleVerificationEmailRequest","verifyEmailSuccessOnInvalidEmail","emailVerifySuccessOnInvalidEmail","OTHER_CAUSE","send","regenerateEmailVerifyToken","sendVerificationEmail","handleChallenge","challengeData","parseUser","id","findUsersWithAuthData","getRequestObject","isChallenge","validator","getValidatorForProvider","validatorResponse","logger","acc","sort","authAdapter","challenge","providerChallengeResponse","resolveError","SCRIPT_FAILED","userString","JSON","stringify","authenticationStep","mountRoutes","route","handleFind","promiseEnsureIdempotency","handleCreate","handleGet","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/UsersRouter.js"],"sourcesContent":["// These methods handle the User-related routes.\n\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport AccountLockout from '../AccountLockout';\nimport ClassesRouter from './ClassesRouter';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport passwordCrypto from '../password';\nimport {\n  maybeRunTrigger,\n  Types as TriggerTypes,\n  getRequestObject,\n  resolveError,\n  inflate,\n} from '../triggers';\nimport { promiseEnsureIdempotency } from '../middlewares';\nimport RestWrite from '../RestWrite';\nimport { logger } from '../logger';\nimport { createSanitizedError } from '../Error';\n\nexport class UsersRouter extends ClassesRouter {\n  className() {\n    return '_User';\n  }\n\n  /**\n   * Removes all \"_\" prefixed properties from an object, except \"__type\"\n   * @param {Object} obj An object.\n   */\n  static removeHiddenProperties(obj) {\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        // Regexp comes from Parse.Object.prototype.validate\n        if (key !== '__type' && !/^[A-Za-z][0-9A-Za-z_]*$/.test(key)) {\n          delete obj[key];\n        }\n      }\n    }\n  }\n\n  /**\n   * After retrieving a user directly from the database, we need to remove the\n   * password from the object (for security), and fix an issue some SDKs have\n   * with null values\n   */\n  _sanitizeAuthData(user) {\n    delete user.password;\n\n    // Sometimes the authData still has null on that keys\n    // https://github.com/parse-community/parse-server/issues/935\n    if (user.authData) {\n      Object.keys(user.authData).forEach(provider => {\n        if (user.authData[provider] === null) {\n          delete user.authData[provider];\n        }\n      });\n      if (Object.keys(user.authData).length == 0) {\n        delete user.authData;\n      }\n    }\n  }\n\n  /**\n   * Validates a password request in login and verifyPassword\n   * @param {Object} req The request\n   * @returns {Object} User object\n   * @private\n   */\n  _authenticateUserFromRequest(req) {\n    return new Promise((resolve, reject) => {\n      // Use query parameters instead if provided in url\n      let payload = req.body || {};\n      if (\n        (!payload.username && req.query && req.query.username) ||\n        (!payload.email && req.query && req.query.email)\n      ) {\n        payload = req.query;\n      }\n      const { username, email, password, ignoreEmailVerification } = payload;\n\n      // TODO: use the right error codes / descriptions.\n      if (!username && !email) {\n        throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'username/email is required.');\n      }\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'password is required.');\n      }\n      if (\n        typeof password !== 'string' ||\n        (email && typeof email !== 'string') ||\n        (username && typeof username !== 'string')\n      ) {\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n      }\n\n      let user;\n      let isValidPassword = false;\n      let query;\n      if (email && username) {\n        query = { email, username };\n      } else if (email) {\n        query = { email };\n      } else {\n        query = { $or: [{ username }, { email: username }] };\n      }\n      return req.config.database\n        .find('_User', query, {}, Auth.maintenance(req.config))\n        .then(results => {\n          if (!results.length) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n\n          if (results.length > 1) {\n            // corner case where user1 has username == user2 email\n            req.config.loggerController.warn(\n              \"There is a user which email is the same as another user's username, logging in based on username\"\n            );\n            user = results.filter(user => user.username === username)[0];\n          } else {\n            user = results[0];\n          }\n\n          return passwordCrypto.compare(password, user.password);\n        })\n        .then(correct => {\n          isValidPassword = correct;\n          const accountLockoutPolicy = new AccountLockout(user, req.config);\n          return accountLockoutPolicy.handleLoginAttempt(isValidPassword);\n        })\n        .then(async () => {\n          if (!isValidPassword) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // A user with an empty ACL (master key only) is considered locked out and\n          // cannot log in. This only prevents new logins; existing session tokens\n          // remain valid. To immediately revoke access, also destroy the user's\n          // sessions via master key.\n          if (!req.auth.isMaster && user.ACL && Object.keys(user.ACL).length == 0) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Create request object for verification functions\n          const authProvider =\n            req.body &&\n            req.body.authData &&\n            Object.keys(req.body.authData).length &&\n            Object.keys(req.body.authData).join(',');\n          const request = {\n            master: req.auth.isMaster,\n            ip: req.config.ip,\n            installationId: req.auth.installationId,\n            object: Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n            createdWith: RestWrite.buildCreatedWith('login', authProvider),\n          };\n\n          // If request doesn't use master or maintenance key with ignoring email verification\n          if (!((req.auth.isMaster || req.auth.isMaintenance) && ignoreEmailVerification)) {\n\n            // Get verification conditions which can be booleans or functions; the purpose of this async/await\n            // structure is to avoid unnecessarily executing subsequent functions if previous ones fail in the\n            // conditional statement below, as a developer may decide to execute expensive operations in them\n            const verifyUserEmails = async () => req.config.verifyUserEmails === true || (typeof req.config.verifyUserEmails === 'function' && await Promise.resolve(req.config.verifyUserEmails(request)) === true);\n            const preventLoginWithUnverifiedEmail = async () => req.config.preventLoginWithUnverifiedEmail === true || (typeof req.config.preventLoginWithUnverifiedEmail === 'function' && await Promise.resolve(req.config.preventLoginWithUnverifiedEmail(request)) === true);\n            if (await verifyUserEmails() && await preventLoginWithUnverifiedEmail() && !user.emailVerified) {\n              throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, 'User email is not verified.');\n            }\n          }\n\n          this._sanitizeAuthData(user);\n\n          return resolve(user);\n        })\n        .catch(error => {\n          return reject(error);\n        });\n    });\n  }\n\n  handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n    }\n    const sessionToken = req.info.sessionToken;\n    return rest\n      .find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken },\n        { include: 'user' },\n        req.info.clientSDK,\n        req.info.context\n      )\n      .then(response => {\n        if (!response.results || response.results.length == 0 || !response.results[0].user) {\n          throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n        } else {\n          const user = response.results[0].user;\n          // Send token back on the login, because SDKs expect that.\n          user.sessionToken = sessionToken;\n\n          // Remove hidden properties.\n          UsersRouter.removeHiddenProperties(user);\n          return { response: user };\n        }\n      });\n  }\n\n  async handleLogIn(req) {\n    const user = await this._authenticateUserFromRequest(req);\n    const authData = req.body && req.body.authData;\n    // Check if user has provided their required auth providers\n    Auth.checkIfUserHasProvidedConfiguredProvidersForLogin(\n      req,\n      authData,\n      user.authData,\n      req.config\n    );\n\n    let authDataResponse;\n    let validatedAuthData;\n    if (authData) {\n      const res = await Auth.handleAuthDataValidation(\n        authData,\n        new RestWrite(\n          req.config,\n          req.auth,\n          '_User',\n          { objectId: user.objectId },\n          req.body || {},\n          user,\n          req.info.clientSDK,\n          req.info.context\n        ),\n        user\n      );\n      authDataResponse = res.authDataResponse;\n      validatedAuthData = res.authData;\n    }\n\n    // handle password expiry policy\n    if (req.config.passwordPolicy && req.config.passwordPolicy.maxPasswordAge) {\n      let changedAt = user._password_changed_at;\n\n      if (!changedAt) {\n        // password was created before expiry policy was enabled.\n        // simply update _User object so that it will start enforcing from now\n        changedAt = new Date();\n        req.config.database.update(\n          '_User',\n          { username: user.username },\n          { _password_changed_at: Parse._encode(changedAt) }\n        );\n      } else {\n        // check whether the password has expired\n        if (changedAt.__type == 'Date') {\n          changedAt = new Date(changedAt.iso);\n        }\n        // Calculate the expiry time.\n        const expiresAt = new Date(\n          changedAt.getTime() + 86400000 * req.config.passwordPolicy.maxPasswordAge\n        );\n        if (expiresAt < new Date())\n        // fail of current time is past password expiry time\n        { throw new Parse.Error(\n          Parse.Error.OBJECT_NOT_FOUND,\n          'Your password has expired. Please reset your password.'\n        ); }\n      }\n    }\n\n    // Remove hidden properties.\n    UsersRouter.removeHiddenProperties(user);\n\n    await req.config.filesController.expandFilesInObject(req.config, user);\n\n    // Before login trigger; throws if failure\n    await maybeRunTrigger(\n      TriggerTypes.beforeLogin,\n      req.auth,\n      Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n      null,\n      req.config,\n      req.info.context\n    );\n\n    // If we have some new validated authData update directly\n    if (validatedAuthData && Object.keys(validatedAuthData).length) {\n      await req.config.database.update(\n        '_User',\n        { objectId: user.objectId },\n        { authData: validatedAuthData },\n        {}\n      );\n    }\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId: user.objectId,\n      createdWith: RestWrite.buildCreatedWith('login'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    const afterLoginUser = Parse.User.fromJSON(Object.assign({ className: '_User' }, user));\n    await maybeRunTrigger(\n      TriggerTypes.afterLogin,\n      { ...req.auth, user: afterLoginUser },\n      afterLoginUser,\n      null,\n      req.config,\n      req.info.context\n    );\n\n    if (authDataResponse) {\n      user.authDataResponse = authDataResponse;\n    }\n    await req.config.authDataManager.runAfterFind(req, user.authData);\n\n    return { response: user };\n  }\n\n  /**\n   * This allows master-key clients to create user sessions without access to\n   * user credentials. This enables systems that can authenticate access another\n   * way (API key, app administrators) to act on a user's behalf.\n   *\n   * We create a new session rather than looking for an existing session; we\n   * want this to work in situations where the user is logged out on all\n   * devices, since this can be used by automated systems acting on the user's\n   * behalf.\n   *\n   * For the moment, we're omitting event hooks and lockout checks, since\n   * immediate use cases suggest /loginAs could be used for semantically\n   * different reasons from /login\n   */\n  async handleLogInAs(req) {\n    if (!req.auth.isMaster) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        'master key is required',\n        req.config\n      );\n    }\n    if (req.auth.isReadOnly) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        \"read-only masterKey isn't allowed to login as another user.\",\n        req.config\n      );\n    }\n\n    const userId = req.body?.userId || req.query.userId;\n    if (!userId) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_VALUE,\n        'userId must not be empty, null, or undefined'\n      );\n    }\n\n    const queryResults = await req.config.database.find('_User', { objectId: userId });\n    const user = queryResults[0];\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'user not found');\n    }\n\n    this._sanitizeAuthData(user);\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId,\n      createdWith: RestWrite.buildCreatedWith('login', 'masterkey'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    return { response: user };\n  }\n\n  handleVerifyPassword(req) {\n    return this._authenticateUserFromRequest(req)\n      .then(user => {\n        // Remove hidden properties.\n        UsersRouter.removeHiddenProperties(user);\n\n        return { response: user };\n      })\n      .catch(error => {\n        throw error;\n      });\n  }\n\n  async handleLogOut(req) {\n    const success = { response: {} };\n    if (req.info && req.info.sessionToken) {\n      const records = await rest.find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      );\n      if (records.results && records.results.length) {\n        await rest.del(\n          req.config,\n          Auth.master(req.config),\n          '_Session',\n          records.results[0].objectId,\n          req.info.context\n        );\n        await maybeRunTrigger(\n          TriggerTypes.afterLogout,\n          req.auth,\n          Parse.Session.fromJSON(Object.assign({ className: '_Session' }, records.results[0])),\n          null,\n          req.config\n        );\n      }\n    }\n    return success;\n  }\n\n  _throwOnBadEmailConfig(req) {\n    try {\n      Config.validateEmailConfiguration({\n        emailAdapter: req.config.userController.adapter,\n        appName: req.config.appName,\n        publicServerURL: req.config.publicServerURL || req.config._publicServerURL,\n        emailVerifyTokenValidityDuration: req.config.emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid: req.config.emailVerifyTokenReuseIfValid,\n      });\n    } catch (e) {\n      if (typeof e === 'string') {\n        // Maybe we need a Bad Configuration error, but the SDKs won't understand it. For now, Internal Server Error.\n        throw new Parse.Error(\n          Parse.Error.INTERNAL_SERVER_ERROR,\n          'An appName, publicServerURL, and emailAdapter are required for password reset and email verification functionality.'\n        );\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  async handleResetRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    let email = req.body?.email;\n    const token = req.body?.token;\n\n    if (!email && !token) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n\n    if (token && typeof token !== 'string') {\n      throw new Parse.Error(Parse.Error.INVALID_VALUE, 'token must be a string');\n    }\n\n    let userResults = null;\n    let userData = null;\n\n    // We can find the user using token\n    if (token) {\n      userResults = await req.config.database.find('_User', {\n        _perishable_token: token,\n        _perishable_token_expires_at: { $lt: Parse._encode(new Date()) },\n      });\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n        if (userData.email) {\n          email = userData.email;\n        }\n      }\n    // Or using email if no token provided\n    } else if (typeof email === 'string') {\n      userResults = await req.config.database.find(\n        '_User',\n        { $or: [{ email }, { username: email, email: { $exists: false } }] },\n        { limit: 1 },\n        Auth.maintenance(req.config)\n      );\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n      }\n    }\n\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    if (userData) {\n      this._sanitizeAuthData(userData);\n      // Get files attached to user\n      await req.config.filesController.expandFilesInObject(req.config, userData);\n\n      const user = inflate('_User', userData);\n\n      await maybeRunTrigger(\n        TriggerTypes.beforePasswordResetRequest,\n        req.auth,\n        user,\n        null,\n        req.config,\n        req.info.context\n      );\n    }\n\n    const userController = req.config.userController;\n    try {\n      await userController.sendPasswordResetEmail(email);\n      return {\n        response: {},\n      };\n    } catch (err) {\n      if (err.code === Parse.Error.OBJECT_NOT_FOUND) {\n        if (req.config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail ?? true) {\n          return {\n            response: {},\n          };\n        }\n        err.message = `A user with that email does not exist.`;\n      }\n      throw err;\n    }\n  }\n\n  async handleVerificationEmailRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body || {};\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    const verifyEmailSuccessOnInvalidEmail = req.config.emailVerifySuccessOnInvalidEmail ?? true;\n\n    const results = await req.config.database.find('_User', { email: email }, {}, Auth.maintenance(req.config));\n    if (!results.length || results.length < 1) {\n      if (verifyEmailSuccessOnInvalidEmail) {\n        return { response: {} };\n      }\n      throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, `No user found with email ${email}`);\n    }\n    const user = results[0];\n\n    // remove password field, messes with saving on postgres\n    delete user.password;\n\n    if (user.emailVerified) {\n      if (verifyEmailSuccessOnInvalidEmail) {\n        return { response: {} };\n      }\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Email ${email} is already verified.`);\n    }\n\n    const userController = req.config.userController;\n    const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster, req.auth.installationId, req.ip);\n    if (send) {\n      userController.sendVerificationEmail(user, req);\n    }\n    return { response: {} };\n  }\n\n  async handleChallenge(req) {\n    const { username, email, password, authData, challengeData } = req.body || {};\n\n    // if username or email provided with password try to authenticate the user by username\n    let user;\n    if (username || email) {\n      if (!password) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You provided username or email, you need to also provide password.'\n        );\n      }\n      user = await this._authenticateUserFromRequest(req);\n    }\n\n    if (!challengeData) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Nothing to challenge.');\n    }\n\n    if (typeof challengeData !== 'object') {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'challengeData should be an object.');\n    }\n\n    let request;\n    let parseUser;\n\n    // Try to find user by authData\n    if (authData) {\n      if (typeof authData !== 'object') {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'authData should be an object.');\n      }\n      if (user) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide username/email and authData, only use one identification method.'\n        );\n      }\n\n      if (Object.keys(authData).filter(key => authData[key].id).length > 1) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide more than one authData provider with an id.'\n        );\n      }\n\n      const results = await Auth.findUsersWithAuthData(req.config, authData);\n\n      try {\n        if (!results[0] || results.length > 1) {\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n        }\n        // Find the provider used to find the user\n        const provider = Object.keys(authData).find(key => authData[key].id);\n\n        parseUser = Parse.User.fromJSON({ className: '_User', ...results[0] });\n        request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n        request.isChallenge = true;\n        // Validate authData used to identify the user to avoid brute-force attack on `id`\n        const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n        const validatorResponse = await validator(authData[provider], req, parseUser, request);\n        if (validatorResponse && validatorResponse.validator) {\n          await validatorResponse.validator();\n        }\n      } catch (e) {\n        // Rewrite the error to avoid guess id attack\n        logger.error(e);\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n      }\n    }\n\n    if (!parseUser) {\n      parseUser = user ? Parse.User.fromJSON({ className: '_User', ...user }) : undefined;\n    }\n\n    if (!request) {\n      request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n      request.isChallenge = true;\n    }\n    const acc = {};\n    // Execute challenge step-by-step with consistent order for better error feedback\n    // and to avoid to trigger others challenges if one of them fails\n    for (const provider of Object.keys(challengeData).sort()) {\n      try {\n        const authAdapter = req.config.authDataManager.getValidatorForProvider(provider);\n        if (!authAdapter) {\n          continue;\n        }\n        const {\n          adapter: { challenge },\n        } = authAdapter;\n        if (typeof challenge === 'function') {\n          const providerChallengeResponse = await challenge(\n            challengeData[provider],\n            authData && authData[provider],\n            req.config.auth[provider],\n            request\n          );\n          acc[provider] = providerChallengeResponse || true;\n        }\n      } catch (err) {\n        const e = resolveError(err, {\n          code: Parse.Error.SCRIPT_FAILED,\n          message: 'Challenge failed. Unknown error.',\n        });\n        const userString = req.auth && req.auth.user ? req.auth.user.id : undefined;\n        logger.error(\n          `Failed running auth step challenge for ${provider} for user ${userString} with Error: ` +\n            JSON.stringify(e),\n          {\n            authenticationStep: 'challenge',\n            error: e,\n            user: userString,\n            provider,\n          }\n        );\n        throw e;\n      }\n    }\n    return { response: { challengeData: acc } };\n  }\n\n  mountRoutes() {\n    this.route('GET', '/users', req => {\n      return this.handleFind(req);\n    });\n    this.route('POST', '/users', promiseEnsureIdempotency, req => {\n      return this.handleCreate(req);\n    });\n    this.route('GET', '/users/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/users/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('PUT', '/users/:objectId', promiseEnsureIdempotency, req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/users/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('GET', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/loginAs', req => {\n      return this.handleLogInAs(req);\n    });\n    this.route('POST', '/logout', req => {\n      return this.handleLogOut(req);\n    });\n    this.route('POST', '/requestPasswordReset', req => {\n      return this.handleResetRequest(req);\n    });\n    this.route('POST', '/verificationEmailRequest', req => {\n      return this.handleVerificationEmailRequest(req);\n    });\n    this.route('GET', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/challenge', req => {\n      return this.handleChallenge(req);\n    });\n  }\n}\n\nexport default UsersRouter;\n"],"mappings":"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","ignoreList":[]}
689
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","_Error","e","__esModule","default","UsersRouter","ClassesRouter","className","removeHiddenProperties","obj","key","Object","prototype","hasOwnProperty","call","test","_sanitizeAuthData","user","password","authData","keys","forEach","provider","length","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","ignoreEmailVerification","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","filter","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","authProvider","join","request","master","ip","installationId","object","User","fromJSON","assign","createdWith","RestWrite","buildCreatedWith","isMaintenance","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","createSanitizedError","INVALID_SESSION_TOKEN","sessionResponse","rest","clientSDK","context","userId","objectId","userResponse","get","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","res","handleAuthDataValidation","passwordPolicy","maxPasswordAge","changedAt","_password_changed_at","Date","update","_encode","__type","iso","expiresAt","getTime","filesController","expandFilesInObject","maybeRunTrigger","TriggerTypes","beforeLogin","original","field","value","entries","Array","isArray","JSON","stringify","code","SCRIPT_FAILED","sessionData","createSession","afterLoginUser","afterLogin","authDataManager","runAfterFind","handleLogInAs","OPERATION_FORBIDDEN","isReadOnly","INVALID_VALUE","queryResults","handleVerifyPassword","handleLogOut","success","records","undefined","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","_publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","INTERNAL_SERVER_ERROR","handleResetRequest","token","EMAIL_MISSING","userResults","userData","_perishable_token","_perishable_token_expires_at","$lt","$exists","limit","INVALID_EMAIL_ADDRESS","inflate","beforePasswordResetRequest","sendPasswordResetEmail","err","resetPasswordSuccessOnInvalidEmail","message","handleVerificationEmailRequest","verifyEmailSuccessOnInvalidEmail","emailVerifySuccessOnInvalidEmail","OTHER_CAUSE","send","regenerateEmailVerifyToken","sendVerificationEmail","handleChallenge","challengeData","parseUser","id","findUsersWithAuthData","getRequestObject","isChallenge","validator","getValidatorForProvider","validatorResponse","logger","acc","sort","authAdapter","challenge","providerChallengeResponse","resolveError","userString","authenticationStep","mountRoutes","route","handleFind","promiseEnsureIdempotency","handleCreate","handleGet","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/UsersRouter.js"],"sourcesContent":["// These methods handle the User-related routes.\n\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport AccountLockout from '../AccountLockout';\nimport ClassesRouter from './ClassesRouter';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport passwordCrypto from '../password';\nimport {\n  maybeRunTrigger,\n  Types as TriggerTypes,\n  getRequestObject,\n  resolveError,\n  inflate,\n} from '../triggers';\nimport { promiseEnsureIdempotency } from '../middlewares';\nimport RestWrite from '../RestWrite';\nimport { logger } from '../logger';\nimport { createSanitizedError } from '../Error';\n\nexport class UsersRouter extends ClassesRouter {\n  className() {\n    return '_User';\n  }\n\n  /**\n   * Removes all \"_\" prefixed properties from an object, except \"__type\"\n   * @param {Object} obj An object.\n   */\n  static removeHiddenProperties(obj) {\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        // Regexp comes from Parse.Object.prototype.validate\n        if (key !== '__type' && !/^[A-Za-z][0-9A-Za-z_]*$/.test(key)) {\n          delete obj[key];\n        }\n      }\n    }\n  }\n\n  /**\n   * After retrieving a user directly from the database, we need to remove the\n   * password from the object (for security), and fix an issue some SDKs have\n   * with null values\n   */\n  _sanitizeAuthData(user) {\n    delete user.password;\n\n    // Sometimes the authData still has null on that keys\n    // https://github.com/parse-community/parse-server/issues/935\n    if (user.authData) {\n      Object.keys(user.authData).forEach(provider => {\n        if (user.authData[provider] === null) {\n          delete user.authData[provider];\n        }\n      });\n      if (Object.keys(user.authData).length == 0) {\n        delete user.authData;\n      }\n    }\n  }\n\n  /**\n   * Validates a password request in login and verifyPassword\n   * @param {Object} req The request\n   * @returns {Object} User object\n   * @private\n   */\n  _authenticateUserFromRequest(req) {\n    return new Promise((resolve, reject) => {\n      // Use query parameters instead if provided in url\n      let payload = req.body || {};\n      if (\n        (!payload.username && req.query && req.query.username) ||\n        (!payload.email && req.query && req.query.email)\n      ) {\n        payload = req.query;\n      }\n      const { username, email, password, ignoreEmailVerification } = payload;\n\n      // TODO: use the right error codes / descriptions.\n      if (!username && !email) {\n        throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'username/email is required.');\n      }\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'password is required.');\n      }\n      if (\n        typeof password !== 'string' ||\n        (email && typeof email !== 'string') ||\n        (username && typeof username !== 'string')\n      ) {\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n      }\n\n      let user;\n      let isValidPassword = false;\n      let query;\n      if (email && username) {\n        query = { email, username };\n      } else if (email) {\n        query = { email };\n      } else {\n        query = { $or: [{ username }, { email: username }] };\n      }\n      return req.config.database\n        .find('_User', query, {}, Auth.maintenance(req.config))\n        .then(results => {\n          if (!results.length) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n\n          if (results.length > 1) {\n            // corner case where user1 has username == user2 email\n            req.config.loggerController.warn(\n              \"There is a user which email is the same as another user's username, logging in based on username\"\n            );\n            user = results.filter(user => user.username === username)[0];\n          } else {\n            user = results[0];\n          }\n\n          return passwordCrypto.compare(password, user.password);\n        })\n        .then(correct => {\n          isValidPassword = correct;\n          const accountLockoutPolicy = new AccountLockout(user, req.config);\n          return accountLockoutPolicy.handleLoginAttempt(isValidPassword);\n        })\n        .then(async () => {\n          if (!isValidPassword) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // A user with an empty ACL (master key only) is considered locked out and\n          // cannot log in. This only prevents new logins; existing session tokens\n          // remain valid. To immediately revoke access, also destroy the user's\n          // sessions via master key.\n          if (!req.auth.isMaster && user.ACL && Object.keys(user.ACL).length == 0) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Create request object for verification functions\n          const authProvider =\n            req.body &&\n            req.body.authData &&\n            Object.keys(req.body.authData).length &&\n            Object.keys(req.body.authData).join(',');\n          const request = {\n            master: req.auth.isMaster,\n            ip: req.config.ip,\n            installationId: req.auth.installationId,\n            object: Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n            createdWith: RestWrite.buildCreatedWith('login', authProvider),\n          };\n\n          // If request doesn't use master or maintenance key with ignoring email verification\n          if (!((req.auth.isMaster || req.auth.isMaintenance) && ignoreEmailVerification)) {\n\n            // Get verification conditions which can be booleans or functions; the purpose of this async/await\n            // structure is to avoid unnecessarily executing subsequent functions if previous ones fail in the\n            // conditional statement below, as a developer may decide to execute expensive operations in them\n            const verifyUserEmails = async () => req.config.verifyUserEmails === true || (typeof req.config.verifyUserEmails === 'function' && await Promise.resolve(req.config.verifyUserEmails(request)) === true);\n            const preventLoginWithUnverifiedEmail = async () => req.config.preventLoginWithUnverifiedEmail === true || (typeof req.config.preventLoginWithUnverifiedEmail === 'function' && await Promise.resolve(req.config.preventLoginWithUnverifiedEmail(request)) === true);\n            if (await verifyUserEmails() && await preventLoginWithUnverifiedEmail() && !user.emailVerified) {\n              throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, 'User email is not verified.');\n            }\n          }\n\n          this._sanitizeAuthData(user);\n\n          return resolve(user);\n        })\n        .catch(error => {\n          return reject(error);\n        });\n    });\n  }\n\n  async handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n    }\n    const sessionToken = req.info.sessionToken;\n    // Query the session with master key to validate the session token,\n    // but do NOT include 'user' to avoid leaking user data via master context\n    const sessionResponse = await rest.find(\n      req.config,\n      Auth.master(req.config),\n      '_Session',\n      { sessionToken },\n      {},\n      req.info.clientSDK,\n      req.info.context\n    );\n    if (\n      !sessionResponse.results ||\n      sessionResponse.results.length == 0 ||\n      !sessionResponse.results[0].user\n    ) {\n      throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n    }\n    const userId = sessionResponse.results[0].user.objectId;\n    // Re-fetch the user with the caller's auth context so that\n    // protectedFields, CLP, and auth adapter afterFind apply correctly\n    const userResponse = await rest.get(\n      req.config,\n      req.auth,\n      '_User',\n      userId,\n      {},\n      req.info.clientSDK,\n      req.info.context\n    );\n    if (!userResponse.results || userResponse.results.length == 0) {\n      throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n    }\n    const user = userResponse.results[0];\n    // Send token back on the login, because SDKs expect that.\n    user.sessionToken = sessionToken;\n    // Remove hidden properties.\n    UsersRouter.removeHiddenProperties(user);\n    return { response: user };\n  }\n\n  async handleLogIn(req) {\n    const user = await this._authenticateUserFromRequest(req);\n    const authData = req.body && req.body.authData;\n    // Check if user has provided their required auth providers\n    Auth.checkIfUserHasProvidedConfiguredProvidersForLogin(\n      req,\n      authData,\n      user.authData,\n      req.config\n    );\n\n    let authDataResponse;\n    let validatedAuthData;\n    if (authData) {\n      const res = await Auth.handleAuthDataValidation(\n        authData,\n        new RestWrite(\n          req.config,\n          req.auth,\n          '_User',\n          { objectId: user.objectId },\n          req.body || {},\n          user,\n          req.info.clientSDK,\n          req.info.context\n        ),\n        user\n      );\n      authDataResponse = res.authDataResponse;\n      validatedAuthData = res.authData;\n    }\n\n    // handle password expiry policy\n    if (req.config.passwordPolicy && req.config.passwordPolicy.maxPasswordAge) {\n      let changedAt = user._password_changed_at;\n\n      if (!changedAt) {\n        // password was created before expiry policy was enabled.\n        // simply update _User object so that it will start enforcing from now\n        changedAt = new Date();\n        req.config.database.update(\n          '_User',\n          { username: user.username },\n          { _password_changed_at: Parse._encode(changedAt) }\n        );\n      } else {\n        // check whether the password has expired\n        if (changedAt.__type == 'Date') {\n          changedAt = new Date(changedAt.iso);\n        }\n        // Calculate the expiry time.\n        const expiresAt = new Date(\n          changedAt.getTime() + 86400000 * req.config.passwordPolicy.maxPasswordAge\n        );\n        if (expiresAt < new Date())\n        // fail of current time is past password expiry time\n        { throw new Parse.Error(\n          Parse.Error.OBJECT_NOT_FOUND,\n          'Your password has expired. Please reset your password.'\n        ); }\n      }\n    }\n\n    // Remove hidden properties.\n    UsersRouter.removeHiddenProperties(user);\n\n    await req.config.filesController.expandFilesInObject(req.config, user);\n\n    // Before login trigger; throws if failure\n    await maybeRunTrigger(\n      TriggerTypes.beforeLogin,\n      req.auth,\n      Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n      null,\n      req.config,\n      req.info.context\n    );\n\n    // If we have some new validated authData update directly\n    if (validatedAuthData && Object.keys(validatedAuthData).length) {\n      const query = { objectId: user.objectId };\n      // Optimistic locking: include the original array fields in the WHERE clause\n      // for providers whose data is being updated. This prevents concurrent requests\n      // from both succeeding when consuming single-use tokens (e.g. MFA recovery codes).\n      // Only array fields need locking — element removal is vulnerable to TOCTOU;\n      // scalar fields are simply overwritten and don't have concurrency issues.\n      if (user.authData) {\n        for (const provider of Object.keys(validatedAuthData)) {\n          const original = user.authData[provider];\n          if (original && typeof original === 'object') {\n            for (const [field, value] of Object.entries(original)) {\n              if (\n                Array.isArray(value) &&\n                JSON.stringify(value) !== JSON.stringify(validatedAuthData[provider]?.[field])\n              ) {\n                query[`authData.${provider}.${field}`] = value;\n              }\n            }\n          }\n        }\n      }\n      try {\n        await req.config.database.update('_User', query, { authData: validatedAuthData }, {});\n      } catch (error) {\n        if (error.code === Parse.Error.OBJECT_NOT_FOUND) {\n          throw new Parse.Error(Parse.Error.SCRIPT_FAILED, 'Invalid auth data');\n        }\n        throw error;\n      }\n    }\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId: user.objectId,\n      createdWith: RestWrite.buildCreatedWith('login'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    const afterLoginUser = Parse.User.fromJSON(Object.assign({ className: '_User' }, user));\n    await maybeRunTrigger(\n      TriggerTypes.afterLogin,\n      { ...req.auth, user: afterLoginUser },\n      afterLoginUser,\n      null,\n      req.config,\n      req.info.context\n    );\n\n    if (authDataResponse) {\n      user.authDataResponse = authDataResponse;\n    }\n    await req.config.authDataManager.runAfterFind(req, user.authData);\n\n    return { response: user };\n  }\n\n  /**\n   * This allows master-key clients to create user sessions without access to\n   * user credentials. This enables systems that can authenticate access another\n   * way (API key, app administrators) to act on a user's behalf.\n   *\n   * We create a new session rather than looking for an existing session; we\n   * want this to work in situations where the user is logged out on all\n   * devices, since this can be used by automated systems acting on the user's\n   * behalf.\n   *\n   * For the moment, we're omitting event hooks and lockout checks, since\n   * immediate use cases suggest /loginAs could be used for semantically\n   * different reasons from /login\n   */\n  async handleLogInAs(req) {\n    if (!req.auth.isMaster) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        'master key is required',\n        req.config\n      );\n    }\n    if (req.auth.isReadOnly) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        \"read-only masterKey isn't allowed to login as another user.\",\n        req.config\n      );\n    }\n\n    const userId = req.body?.userId || req.query.userId;\n    if (!userId) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_VALUE,\n        'userId must not be empty, null, or undefined'\n      );\n    }\n\n    const queryResults = await req.config.database.find('_User', { objectId: userId });\n    const user = queryResults[0];\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'user not found');\n    }\n\n    this._sanitizeAuthData(user);\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId,\n      createdWith: RestWrite.buildCreatedWith('login', 'masterkey'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    return { response: user };\n  }\n\n  handleVerifyPassword(req) {\n    return this._authenticateUserFromRequest(req)\n      .then(user => {\n        // Remove hidden properties.\n        UsersRouter.removeHiddenProperties(user);\n\n        return { response: user };\n      })\n      .catch(error => {\n        throw error;\n      });\n  }\n\n  async handleLogOut(req) {\n    const success = { response: {} };\n    if (req.info && req.info.sessionToken) {\n      const records = await rest.find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      );\n      if (records.results && records.results.length) {\n        await rest.del(\n          req.config,\n          Auth.master(req.config),\n          '_Session',\n          records.results[0].objectId,\n          req.info.context\n        );\n        await maybeRunTrigger(\n          TriggerTypes.afterLogout,\n          req.auth,\n          Parse.Session.fromJSON(Object.assign({ className: '_Session' }, records.results[0])),\n          null,\n          req.config\n        );\n      }\n    }\n    return success;\n  }\n\n  _throwOnBadEmailConfig(req) {\n    try {\n      Config.validateEmailConfiguration({\n        emailAdapter: req.config.userController.adapter,\n        appName: req.config.appName,\n        publicServerURL: req.config.publicServerURL || req.config._publicServerURL,\n        emailVerifyTokenValidityDuration: req.config.emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid: req.config.emailVerifyTokenReuseIfValid,\n      });\n    } catch (e) {\n      if (typeof e === 'string') {\n        // Maybe we need a Bad Configuration error, but the SDKs won't understand it. For now, Internal Server Error.\n        throw new Parse.Error(\n          Parse.Error.INTERNAL_SERVER_ERROR,\n          'An appName, publicServerURL, and emailAdapter are required for password reset and email verification functionality.'\n        );\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  async handleResetRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    let email = req.body?.email;\n    const token = req.body?.token;\n\n    if (!email && !token) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n\n    if (token && typeof token !== 'string') {\n      throw new Parse.Error(Parse.Error.INVALID_VALUE, 'token must be a string');\n    }\n\n    let userResults = null;\n    let userData = null;\n\n    // We can find the user using token\n    if (token) {\n      userResults = await req.config.database.find('_User', {\n        _perishable_token: token,\n        _perishable_token_expires_at: { $lt: Parse._encode(new Date()) },\n      });\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n        if (userData.email) {\n          email = userData.email;\n        }\n      }\n    // Or using email if no token provided\n    } else if (typeof email === 'string') {\n      userResults = await req.config.database.find(\n        '_User',\n        { $or: [{ email }, { username: email, email: { $exists: false } }] },\n        { limit: 1 },\n        Auth.maintenance(req.config)\n      );\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n      }\n    }\n\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    if (userData) {\n      this._sanitizeAuthData(userData);\n      // Get files attached to user\n      await req.config.filesController.expandFilesInObject(req.config, userData);\n\n      const user = inflate('_User', userData);\n\n      await maybeRunTrigger(\n        TriggerTypes.beforePasswordResetRequest,\n        req.auth,\n        user,\n        null,\n        req.config,\n        req.info.context\n      );\n    }\n\n    const userController = req.config.userController;\n    try {\n      await userController.sendPasswordResetEmail(email);\n      return {\n        response: {},\n      };\n    } catch (err) {\n      if (err.code === Parse.Error.OBJECT_NOT_FOUND) {\n        if (req.config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail ?? true) {\n          return {\n            response: {},\n          };\n        }\n        err.message = `A user with that email does not exist.`;\n      }\n      throw err;\n    }\n  }\n\n  async handleVerificationEmailRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body || {};\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    const verifyEmailSuccessOnInvalidEmail = req.config.emailVerifySuccessOnInvalidEmail ?? true;\n\n    const results = await req.config.database.find('_User', { email: email }, {}, Auth.maintenance(req.config));\n    if (!results.length || results.length < 1) {\n      if (verifyEmailSuccessOnInvalidEmail) {\n        return { response: {} };\n      }\n      throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, `No user found with email ${email}`);\n    }\n    const user = results[0];\n\n    // remove password field, messes with saving on postgres\n    delete user.password;\n\n    if (user.emailVerified) {\n      if (verifyEmailSuccessOnInvalidEmail) {\n        return { response: {} };\n      }\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Email ${email} is already verified.`);\n    }\n\n    const userController = req.config.userController;\n    const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster, req.auth.installationId, req.ip);\n    if (send) {\n      userController.sendVerificationEmail(user, req);\n    }\n    return { response: {} };\n  }\n\n  async handleChallenge(req) {\n    const { username, email, password, authData, challengeData } = req.body || {};\n\n    // if username or email provided with password try to authenticate the user by username\n    let user;\n    if (username || email) {\n      if (!password) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You provided username or email, you need to also provide password.'\n        );\n      }\n      user = await this._authenticateUserFromRequest(req);\n    }\n\n    if (!challengeData) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Nothing to challenge.');\n    }\n\n    if (typeof challengeData !== 'object') {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'challengeData should be an object.');\n    }\n\n    let request;\n    let parseUser;\n\n    // Try to find user by authData\n    if (authData) {\n      if (typeof authData !== 'object') {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'authData should be an object.');\n      }\n      if (user) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide username/email and authData, only use one identification method.'\n        );\n      }\n\n      for (const key of Object.keys(authData)) {\n        if (authData[key] !== null && (typeof authData[key] !== 'object' || Array.isArray(authData[key]))) {\n          throw new Parse.Error(\n            Parse.Error.OTHER_CAUSE,\n            `authData.${key} should be an object.`\n          );\n        }\n      }\n\n      if (Object.keys(authData).filter(key => authData[key] && authData[key].id).length > 1) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide more than one authData provider with an id.'\n        );\n      }\n\n      const results = await Auth.findUsersWithAuthData(req.config, authData);\n\n      try {\n        if (!results[0] || results.length > 1) {\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n        }\n        // Find the provider used to find the user\n        const provider = Object.keys(authData).find(key => authData[key] && authData[key].id);\n\n        parseUser = Parse.User.fromJSON({ className: '_User', ...results[0] });\n        request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n        request.isChallenge = true;\n        // Validate authData used to identify the user to avoid brute-force attack on `id`\n        const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n        const validatorResponse = await validator(authData[provider], req, parseUser, request);\n        if (validatorResponse && validatorResponse.validator) {\n          await validatorResponse.validator();\n        }\n      } catch (e) {\n        // Rewrite the error to avoid guess id attack\n        logger.error(e);\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n      }\n    }\n\n    if (!parseUser) {\n      parseUser = user ? Parse.User.fromJSON({ className: '_User', ...user }) : undefined;\n    }\n\n    if (!request) {\n      request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n      request.isChallenge = true;\n    }\n    const acc = {};\n    // Execute challenge step-by-step with consistent order for better error feedback\n    // and to avoid to trigger others challenges if one of them fails\n    for (const provider of Object.keys(challengeData).sort()) {\n      try {\n        const authAdapter = req.config.authDataManager.getValidatorForProvider(provider);\n        if (!authAdapter) {\n          continue;\n        }\n        const {\n          adapter: { challenge },\n        } = authAdapter;\n        if (typeof challenge === 'function') {\n          const providerChallengeResponse = await challenge(\n            challengeData[provider],\n            authData && authData[provider],\n            req.config.auth[provider],\n            request\n          );\n          acc[provider] = providerChallengeResponse || true;\n        }\n      } catch (err) {\n        const e = resolveError(err, {\n          code: Parse.Error.SCRIPT_FAILED,\n          message: 'Challenge failed. Unknown error.',\n        });\n        const userString = req.auth && req.auth.user ? req.auth.user.id : undefined;\n        logger.error(\n          `Failed running auth step challenge for ${provider} for user ${userString} with Error: ` +\n            JSON.stringify(e),\n          {\n            authenticationStep: 'challenge',\n            error: e,\n            user: userString,\n            provider,\n          }\n        );\n        throw e;\n      }\n    }\n    return { response: { challengeData: acc } };\n  }\n\n  mountRoutes() {\n    this.route('GET', '/users', req => {\n      return this.handleFind(req);\n    });\n    this.route('POST', '/users', promiseEnsureIdempotency, req => {\n      return this.handleCreate(req);\n    });\n    this.route('GET', '/users/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/users/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('PUT', '/users/:objectId', promiseEnsureIdempotency, req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/users/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('GET', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/loginAs', req => {\n      return this.handleLogInAs(req);\n    });\n    this.route('POST', '/logout', req => {\n      return this.handleLogOut(req);\n    });\n    this.route('POST', '/requestPasswordReset', req => {\n      return this.handleResetRequest(req);\n    });\n    this.route('POST', '/verificationEmailRequest', req => {\n      return this.handleVerificationEmailRequest(req);\n    });\n    this.route('GET', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/challenge', req => {\n      return this.handleChallenge(req);\n    });\n  }\n}\n\nexport default UsersRouter;\n"],"mappings":"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","ignoreList":[]}
@@ -51,7 +51,7 @@ class Check {
51
51
  }
52
52
  async run() {
53
53
  // Get check as synchronous or asynchronous function
54
- const check = this.check instanceof Promise ? await this.check : this.check;
54
+ const check = _Utils.default.isPromise(this.check) ? await this.check : this.check;
55
55
 
56
56
  // Run check
57
57
  try {
@@ -106,4 +106,4 @@ module.exports = {
106
106
  Check,
107
107
  CheckState
108
108
  };
109
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfVXRpbHMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9sb2Rhc2giLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJDaGVjayIsImNvbnN0cnVjdG9yIiwicGFyYW1zIiwiX3ZhbGlkYXRlUGFyYW1zIiwidGl0bGUiLCJ3YXJuaW5nIiwic29sdXRpb24iLCJjaGVjayIsIl9jaGVja1N0YXRlIiwiQ2hlY2tTdGF0ZSIsIm5vbmUiLCJlcnJvciIsImNoZWNrU3RhdGUiLCJydW4iLCJQcm9taXNlIiwic3VjY2VzcyIsInN0YXRlRmFpbEVycm9yIiwiZmFpbCIsIlV0aWxzIiwidmFsaWRhdGVQYXJhbXMiLCJncm91cCIsInQiLCJ2IiwiaXNTdHJpbmciLCJpc0Z1bmN0aW9uIiwiT2JqZWN0IiwiZnJlZXplIiwiX2RlZmF1bHQiLCJleHBvcnRzIiwibW9kdWxlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL1NlY3VyaXR5L0NoZWNrLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQG1vZHVsZSBTZWN1cml0eUNoZWNrXG4gKi9cblxuaW1wb3J0IFV0aWxzIGZyb20gJy4uL1V0aWxzJztcbmltcG9ydCB7IGlzRnVuY3Rpb24sIGlzU3RyaW5nIH0gZnJvbSAnbG9kYXNoJztcblxuLyoqXG4gKiBBIHNlY3VyaXR5IGNoZWNrLlxuICogQGNsYXNzXG4gKi9cbmNsYXNzIENoZWNrIHtcbiAgLyoqXG4gICAqIENvbnN0cnVjdHMgYSBuZXcgc2VjdXJpdHkgY2hlY2suXG4gICAqIEBwYXJhbSB7T2JqZWN0fSBwYXJhbXMgVGhlIHBhcmFtZXRlcnMuXG4gICAqIEBwYXJhbSB7U3RyaW5nfSBwYXJhbXMudGl0bGUgVGhlIHRpdGxlLlxuICAgKiBAcGFyYW0ge1N0cmluZ30gcGFyYW1zLndhcm5pbmcgVGhlIHdhcm5pbmcgbWVzc2FnZSBpZiB0aGUgY2hlY2sgZmFpbHMuXG4gICAqIEBwYXJhbSB7U3RyaW5nfSBwYXJhbXMuc29sdXRpb24gVGhlIHNvbHV0aW9uIHRvIGZpeCB0aGUgY2hlY2suXG4gICAqIEBwYXJhbSB7UHJvbWlzZX0gcGFyYW1zLmNoZWNrIFRoZSBjaGVjayBhcyBzeW5jaHJvbm91cyBvciBhc3luY2hyb25vdXMgZnVuY3Rpb24uXG4gICAqL1xuICBjb25zdHJ1Y3RvcihwYXJhbXMpIHtcbiAgICB0aGlzLl92YWxpZGF0ZVBhcmFtcyhwYXJhbXMpO1xuICAgIGNvbnN0IHsgdGl0bGUsIHdhcm5pbmcsIHNvbHV0aW9uLCBjaGVjayB9ID0gcGFyYW1zO1xuXG4gICAgdGhpcy50aXRsZSA9IHRpdGxlO1xuICAgIHRoaXMud2FybmluZyA9IHdhcm5pbmc7XG4gICAgdGhpcy5zb2x1dGlvbiA9IHNvbHV0aW9uO1xuICAgIHRoaXMuY2hlY2sgPSBjaGVjaztcblxuICAgIC8vIFNldCBkZWZhdWx0IHByb3BlcnRpZXNcbiAgICB0aGlzLl9jaGVja1N0YXRlID0gQ2hlY2tTdGF0ZS5ub25lO1xuICAgIHRoaXMuZXJyb3I7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgY3VycmVudCBjaGVjayBzdGF0ZS5cbiAgICogQHJldHVybiB7Q2hlY2tTdGF0ZX0gVGhlIGNoZWNrIHN0YXRlLlxuICAgKi9cbiAgY2hlY2tTdGF0ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fY2hlY2tTdGF0ZTtcbiAgfVxuXG4gIGFzeW5jIHJ1bigpIHtcbiAgICAvLyBHZXQgY2hlY2sgYXMgc3luY2hyb25vdXMgb3IgYXN5bmNocm9ub3VzIGZ1bmN0aW9uXG4gICAgY29uc3QgY2hlY2sgPSB0aGlzLmNoZWNrIGluc3RhbmNlb2YgUHJvbWlzZSA/IGF3YWl0IHRoaXMuY2hlY2sgOiB0aGlzLmNoZWNrO1xuXG4gICAgLy8gUnVuIGNoZWNrXG4gICAgdHJ5IHtcbiAgICAgIGNoZWNrKCk7XG4gICAgICB0aGlzLl9jaGVja1N0YXRlID0gQ2hlY2tTdGF0ZS5zdWNjZXNzO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHRoaXMuc3RhdGVGYWlsRXJyb3IgPSBlO1xuICAgICAgdGhpcy5fY2hlY2tTdGF0ZSA9IENoZWNrU3RhdGUuZmFpbDtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGVzIHRoZSBjb25zdHJ1Y3RvciBwYXJhbWV0ZXJzLlxuICAgKiBAcGFyYW0ge09iamVjdH0gcGFyYW1zIFRoZSBwYXJhbWV0ZXJzIHRvIHZhbGlkYXRlLlxuICAgKi9cbiAgX3ZhbGlkYXRlUGFyYW1zKHBhcmFtcykge1xuICAgIFV0aWxzLnZhbGlkYXRlUGFyYW1zKHBhcmFtcywge1xuICAgICAgZ3JvdXA6IHsgdDogJ3N0cmluZycsIHY6IGlzU3RyaW5nIH0sXG4gICAgICB0aXRsZTogeyB0OiAnc3RyaW5nJywgdjogaXNTdHJpbmcgfSxcbiAgICAgIHdhcm5pbmc6IHsgdDogJ3N0cmluZycsIHY6IGlzU3RyaW5nIH0sXG4gICAgICBzb2x1dGlvbjogeyB0OiAnc3RyaW5nJywgdjogaXNTdHJpbmcgfSxcbiAgICAgIGNoZWNrOiB7IHQ6ICdmdW5jdGlvbicsIHY6IGlzRnVuY3Rpb24gfSxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIFRoZSBjaGVjayBzdGF0ZS5cbiAqL1xuY29uc3QgQ2hlY2tTdGF0ZSA9IE9iamVjdC5mcmVlemUoe1xuICBub25lOiAnbm9uZScsXG4gIGZhaWw6ICdmYWlsJyxcbiAgc3VjY2VzczogJ3N1Y2Nlc3MnLFxufSk7XG5cbmV4cG9ydCBkZWZhdWx0IENoZWNrO1xubW9kdWxlLmV4cG9ydHMgPSB7XG4gIENoZWNrLFxuICBDaGVja1N0YXRlLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBSUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQThDLFNBQUFELHVCQUFBRyxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBTDlDO0FBQ0E7QUFDQTs7QUFLQTtBQUNBO0FBQ0E7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
109
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfVXRpbHMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9sb2Rhc2giLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJDaGVjayIsImNvbnN0cnVjdG9yIiwicGFyYW1zIiwiX3ZhbGlkYXRlUGFyYW1zIiwidGl0bGUiLCJ3YXJuaW5nIiwic29sdXRpb24iLCJjaGVjayIsIl9jaGVja1N0YXRlIiwiQ2hlY2tTdGF0ZSIsIm5vbmUiLCJlcnJvciIsImNoZWNrU3RhdGUiLCJydW4iLCJVdGlscyIsImlzUHJvbWlzZSIsInN1Y2Nlc3MiLCJzdGF0ZUZhaWxFcnJvciIsImZhaWwiLCJ2YWxpZGF0ZVBhcmFtcyIsImdyb3VwIiwidCIsInYiLCJpc1N0cmluZyIsImlzRnVuY3Rpb24iLCJPYmplY3QiLCJmcmVlemUiLCJfZGVmYXVsdCIsImV4cG9ydHMiLCJtb2R1bGUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvU2VjdXJpdHkvQ2hlY2suanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbW9kdWxlIFNlY3VyaXR5Q2hlY2tcbiAqL1xuXG5pbXBvcnQgVXRpbHMgZnJvbSAnLi4vVXRpbHMnO1xuaW1wb3J0IHsgaXNGdW5jdGlvbiwgaXNTdHJpbmcgfSBmcm9tICdsb2Rhc2gnO1xuXG4vKipcbiAqIEEgc2VjdXJpdHkgY2hlY2suXG4gKiBAY2xhc3NcbiAqL1xuY2xhc3MgQ2hlY2sge1xuICAvKipcbiAgICogQ29uc3RydWN0cyBhIG5ldyBzZWN1cml0eSBjaGVjay5cbiAgICogQHBhcmFtIHtPYmplY3R9IHBhcmFtcyBUaGUgcGFyYW1ldGVycy5cbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy50aXRsZSBUaGUgdGl0bGUuXG4gICAqIEBwYXJhbSB7U3RyaW5nfSBwYXJhbXMud2FybmluZyBUaGUgd2FybmluZyBtZXNzYWdlIGlmIHRoZSBjaGVjayBmYWlscy5cbiAgICogQHBhcmFtIHtTdHJpbmd9IHBhcmFtcy5zb2x1dGlvbiBUaGUgc29sdXRpb24gdG8gZml4IHRoZSBjaGVjay5cbiAgICogQHBhcmFtIHtQcm9taXNlfSBwYXJhbXMuY2hlY2sgVGhlIGNoZWNrIGFzIHN5bmNocm9ub3VzIG9yIGFzeW5jaHJvbm91cyBmdW5jdGlvbi5cbiAgICovXG4gIGNvbnN0cnVjdG9yKHBhcmFtcykge1xuICAgIHRoaXMuX3ZhbGlkYXRlUGFyYW1zKHBhcmFtcyk7XG4gICAgY29uc3QgeyB0aXRsZSwgd2FybmluZywgc29sdXRpb24sIGNoZWNrIH0gPSBwYXJhbXM7XG5cbiAgICB0aGlzLnRpdGxlID0gdGl0bGU7XG4gICAgdGhpcy53YXJuaW5nID0gd2FybmluZztcbiAgICB0aGlzLnNvbHV0aW9uID0gc29sdXRpb247XG4gICAgdGhpcy5jaGVjayA9IGNoZWNrO1xuXG4gICAgLy8gU2V0IGRlZmF1bHQgcHJvcGVydGllc1xuICAgIHRoaXMuX2NoZWNrU3RhdGUgPSBDaGVja1N0YXRlLm5vbmU7XG4gICAgdGhpcy5lcnJvcjtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBjdXJyZW50IGNoZWNrIHN0YXRlLlxuICAgKiBAcmV0dXJuIHtDaGVja1N0YXRlfSBUaGUgY2hlY2sgc3RhdGUuXG4gICAqL1xuICBjaGVja1N0YXRlKCkge1xuICAgIHJldHVybiB0aGlzLl9jaGVja1N0YXRlO1xuICB9XG5cbiAgYXN5bmMgcnVuKCkge1xuICAgIC8vIEdldCBjaGVjayBhcyBzeW5jaHJvbm91cyBvciBhc3luY2hyb25vdXMgZnVuY3Rpb25cbiAgICBjb25zdCBjaGVjayA9IFV0aWxzLmlzUHJvbWlzZSh0aGlzLmNoZWNrKSA/IGF3YWl0IHRoaXMuY2hlY2sgOiB0aGlzLmNoZWNrO1xuXG4gICAgLy8gUnVuIGNoZWNrXG4gICAgdHJ5IHtcbiAgICAgIGNoZWNrKCk7XG4gICAgICB0aGlzLl9jaGVja1N0YXRlID0gQ2hlY2tTdGF0ZS5zdWNjZXNzO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHRoaXMuc3RhdGVGYWlsRXJyb3IgPSBlO1xuICAgICAgdGhpcy5fY2hlY2tTdGF0ZSA9IENoZWNrU3RhdGUuZmFpbDtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGVzIHRoZSBjb25zdHJ1Y3RvciBwYXJhbWV0ZXJzLlxuICAgKiBAcGFyYW0ge09iamVjdH0gcGFyYW1zIFRoZSBwYXJhbWV0ZXJzIHRvIHZhbGlkYXRlLlxuICAgKi9cbiAgX3ZhbGlkYXRlUGFyYW1zKHBhcmFtcykge1xuICAgIFV0aWxzLnZhbGlkYXRlUGFyYW1zKHBhcmFtcywge1xuICAgICAgZ3JvdXA6IHsgdDogJ3N0cmluZycsIHY6IGlzU3RyaW5nIH0sXG4gICAgICB0aXRsZTogeyB0OiAnc3RyaW5nJywgdjogaXNTdHJpbmcgfSxcbiAgICAgIHdhcm5pbmc6IHsgdDogJ3N0cmluZycsIHY6IGlzU3RyaW5nIH0sXG4gICAgICBzb2x1dGlvbjogeyB0OiAnc3RyaW5nJywgdjogaXNTdHJpbmcgfSxcbiAgICAgIGNoZWNrOiB7IHQ6ICdmdW5jdGlvbicsIHY6IGlzRnVuY3Rpb24gfSxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIFRoZSBjaGVjayBzdGF0ZS5cbiAqL1xuY29uc3QgQ2hlY2tTdGF0ZSA9IE9iamVjdC5mcmVlemUoe1xuICBub25lOiAnbm9uZScsXG4gIGZhaWw6ICdmYWlsJyxcbiAgc3VjY2VzczogJ3N1Y2Nlc3MnLFxufSk7XG5cbmV4cG9ydCBkZWZhdWx0IENoZWNrO1xubW9kdWxlLmV4cG9ydHMgPSB7XG4gIENoZWNrLFxuICBDaGVja1N0YXRlLFxufTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBSUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsT0FBQSxHQUFBRCxPQUFBO0FBQThDLFNBQUFELHVCQUFBRyxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBTDlDO0FBQ0E7QUFDQTs7QUFLQTtBQUNBO0FBQ0E7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
@@ -121,7 +121,7 @@ class CheckGroupServerConfig extends _CheckGroup.default {
121
121
  if (!rc) {
122
122
  throw 1;
123
123
  }
124
- const values = [rc.includeDepth, rc.includeCount, rc.subqueryDepth, rc.graphQLDepth, rc.graphQLFields];
124
+ const values = [rc.includeDepth, rc.includeCount, rc.subqueryDepth, rc.queryDepth, rc.graphQLDepth, rc.graphQLFields, rc.batchRequestLimit];
125
125
  if (values.some(v => v === -1)) {
126
126
  throw 1;
127
127
  }
@@ -157,4 +157,4 @@ class CheckGroupServerConfig extends _CheckGroup.default {
157
157
  }
158
158
  }
159
159
  module.exports = CheckGroupServerConfig;
160
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_Check","require","_CheckGroup","_interopRequireDefault","_Config","_node","e","__esModule","default","CheckGroupServerConfig","CheckGroup","setName","setChecks","config","Config","get","Parse","applicationId","Check","title","warning","solution","check","masterKey","hasUpperCase","test","hasLowerCase","hasNumbers","hasNonAlphasNumerics","length","security","enableCheckLog","allowClientClassCreation","enforcePrivateUsers","enableInsecureAuthAdapters","graphQLPublicIntrospection","mountPlayground","databaseOptions","allowPublicExplain","readOnlyMasterKey","ips","readOnlyMasterKeyIps","wildcards","some","ip","includes","rc","requestComplexity","values","includeDepth","includeCount","subqueryDepth","graphQLDepth","graphQLFields","v","passwordPolicy","resetPasswordSuccessOnInvalidEmail","emailVerifySuccessOnInvalidEmail","liveQuery","classNames","regexTimeout","module","exports"],"sources":["../../../src/Security/CheckGroups/CheckGroupServerConfig.js"],"sourcesContent":["import { Check } from '../Check';\nimport CheckGroup from '../CheckGroup';\nimport Config from '../../Config';\nimport Parse from 'parse/node';\n\n/**\n * The security checks group for Parse Server configuration.\n * Checks common Parse Server parameters such as access keys.\n * @memberof module:SecurityCheck\n */\nclass CheckGroupServerConfig extends CheckGroup {\n  setName() {\n    return 'Parse Server Configuration';\n  }\n  setChecks() {\n    const config = Config.get(Parse.applicationId);\n    return [\n      new Check({\n        title: 'Secure master key',\n        warning: 'The Parse Server master key is insecure and vulnerable to brute force attacks.',\n        solution:\n          'Choose a longer and/or more complex master key with a combination of upper- and lowercase characters, numbers and special characters.',\n        check: () => {\n          const masterKey = config.masterKey;\n          const hasUpperCase = /[A-Z]/.test(masterKey);\n          const hasLowerCase = /[a-z]/.test(masterKey);\n          const hasNumbers = /\\d/.test(masterKey);\n          const hasNonAlphasNumerics = /\\W/.test(masterKey);\n          // Ensure length\n          if (masterKey.length < 14) {\n            throw 1;\n          }\n          // Ensure at least 3 out of 4 requirements passed\n          if (hasUpperCase + hasLowerCase + hasNumbers + hasNonAlphasNumerics < 3) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Security log disabled',\n        warning:\n          'Security checks in logs may expose vulnerabilities to anyone with access to logs.',\n        solution: \"Change Parse Server configuration to 'security.enableCheckLog: false'.\",\n        check: () => {\n          if (config.security && config.security.enableCheckLog) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Client class creation disabled',\n        warning:\n          'Attackers are allowed to create new classes without restriction and flood the database.',\n        solution: \"Change Parse Server configuration to 'allowClientClassCreation: false'.\",\n        check: () => {\n          if (config.allowClientClassCreation || config.allowClientClassCreation == null) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Users are created without public access',\n        warning:\n          'Users with public read access are exposed to anyone who knows their object IDs, or to anyone who can query the Parse.User class.',\n        solution: \"Change Parse Server configuration to 'enforcePrivateUsers: true'.\",\n        check: () => {\n          if (!config.enforcePrivateUsers) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Insecure auth adapters disabled',\n        warning:\n          \"Attackers may explore insecure auth adapters' vulnerabilities and log in on behalf of another user.\",\n        solution: \"Change Parse Server configuration to 'enableInsecureAuthAdapters: false'.\",\n        check: () => {\n          if (config.enableInsecureAuthAdapters !== false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'GraphQL public introspection disabled',\n        warning: 'GraphQL public introspection is enabled, which allows anyone to access the GraphQL schema.',\n        solution: \"Change Parse Server configuration to 'graphQLPublicIntrospection: false'. You will need to use master key or maintenance key to access the GraphQL schema.\",\n        check: () => {\n          if (config.graphQLPublicIntrospection !== false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'GraphQL Playground disabled',\n        warning:\n          'GraphQL Playground is enabled and exposes the master key in the browser page.',\n        solution:\n          \"Change Parse Server configuration to 'mountPlayground: false'. Use Parse Dashboard for GraphQL exploration in production.\",\n        check: () => {\n          if (config.mountPlayground) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Public database explain disabled',\n        warning:\n          'Database explain queries are publicly accessible, which may expose sensitive database performance information and schema details.',\n        solution:\n          \"Change Parse Server configuration to 'databaseOptions.allowPublicExplain: false'. You will need to use master key to run explain queries.\",\n        check: () => {\n          if (\n            config.databaseOptions?.allowPublicExplain === true ||\n            config.databaseOptions?.allowPublicExplain == null\n          ) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Read-only master key IP range restricted',\n        warning:\n          'The read-only master key can be used from any IP address, which increases the attack surface if the key is compromised.',\n        solution:\n          \"Change Parse Server configuration to 'readOnlyMasterKeyIps: [\\\"127.0.0.1\\\", \\\"::1\\\"]' to restrict access to localhost, or set it to a list of specific IP addresses.\",\n        check: () => {\n          if (!config.readOnlyMasterKey) {\n            return;\n          }\n          const ips = config.readOnlyMasterKeyIps || [];\n          const wildcards = ['0.0.0.0/0', '0.0.0.0', '::/0', '::', '::0'];\n          if (ips.some(ip => wildcards.includes(ip))) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Request complexity limits enabled',\n        warning:\n          'One or more request complexity limits are disabled, which may allow denial-of-service attacks through deeply nested or excessively broad queries.',\n        solution:\n          \"Ensure all properties in 'requestComplexity' are set to positive integers. Set to '-1' only if you have other mitigations in place.\",\n        check: () => {\n          const rc = config.requestComplexity;\n          if (!rc) {\n            throw 1;\n          }\n          const values = [rc.includeDepth, rc.includeCount, rc.subqueryDepth, rc.graphQLDepth, rc.graphQLFields];\n          if (values.some(v => v === -1)) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Password reset endpoint user enumeration mitigated',\n        warning:\n          'The password reset endpoint returns distinct error responses for invalid email addresses, which allows attackers to enumerate registered users.',\n        solution:\n          \"Change Parse Server configuration to 'passwordPolicy.resetPasswordSuccessOnInvalidEmail: true'.\",\n        check: () => {\n          if (config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail === false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Email verification endpoint user enumeration mitigated',\n        warning:\n          'The email verification endpoint returns distinct error responses for invalid email addresses, which allows attackers to enumerate registered users.',\n        solution:\n          \"Change Parse Server configuration to 'emailVerifySuccessOnInvalidEmail: true'.\",\n        check: () => {\n          if (config.emailVerifySuccessOnInvalidEmail === false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'LiveQuery regex timeout enabled',\n        warning:\n          'LiveQuery regex timeout is disabled. A malicious client can subscribe with a crafted $regex pattern that causes catastrophic backtracking, blocking the Node.js event loop and making the server unresponsive.',\n        solution:\n          \"Change Parse Server configuration to 'liveQuery.regexTimeout: 100' to set a 100ms timeout for regex evaluation in LiveQuery.\",\n        check: () => {\n          if (config.liveQuery?.classNames?.length > 0 && config.liveQuery?.regexTimeout === 0) {\n            throw 1;\n          }\n        },\n      }),\n    ];\n  }\n}\n\nmodule.exports = CheckGroupServerConfig;\n"],"mappings":";;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,OAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,KAAA,GAAAF,sBAAA,CAAAF,OAAA;AAA+B,SAAAE,uBAAAG,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAE/B;AACA;AACA;AACA;AACA;AACA,MAAMG,sBAAsB,SAASC,mBAAU,CAAC;EAC9CC,OAAOA,CAAA,EAAG;IACR,OAAO,4BAA4B;EACrC;EACAC,SAASA,CAAA,EAAG;IACV,MAAMC,MAAM,GAAGC,eAAM,CAACC,GAAG,CAACC,aAAK,CAACC,aAAa,CAAC;IAC9C,OAAO,CACL,IAAIC,YAAK,CAAC;MACRC,KAAK,EAAE,mBAAmB;MAC1BC,OAAO,EAAE,gFAAgF;MACzFC,QAAQ,EACN,uIAAuI;MACzIC,KAAK,EAAEA,CAAA,KAAM;QACX,MAAMC,SAAS,GAAGV,MAAM,CAACU,SAAS;QAClC,MAAMC,YAAY,GAAG,OAAO,CAACC,IAAI,CAACF,SAAS,CAAC;QAC5C,MAAMG,YAAY,GAAG,OAAO,CAACD,IAAI,CAACF,SAAS,CAAC;QAC5C,MAAMI,UAAU,GAAG,IAAI,CAACF,IAAI,CAACF,SAAS,CAAC;QACvC,MAAMK,oBAAoB,GAAG,IAAI,CAACH,IAAI,CAACF,SAAS,CAAC;QACjD;QACA,IAAIA,SAAS,CAACM,MAAM,GAAG,EAAE,EAAE;UACzB,MAAM,CAAC;QACT;QACA;QACA,IAAIL,YAAY,GAAGE,YAAY,GAAGC,UAAU,GAAGC,oBAAoB,GAAG,CAAC,EAAE;UACvE,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIV,YAAK,CAAC;MACRC,KAAK,EAAE,uBAAuB;MAC9BC,OAAO,EACL,mFAAmF;MACrFC,QAAQ,EAAE,wEAAwE;MAClFC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAACiB,QAAQ,IAAIjB,MAAM,CAACiB,QAAQ,CAACC,cAAc,EAAE;UACrD,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIb,YAAK,CAAC;MACRC,KAAK,EAAE,gCAAgC;MACvCC,OAAO,EACL,yFAAyF;MAC3FC,QAAQ,EAAE,yEAAyE;MACnFC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAACmB,wBAAwB,IAAInB,MAAM,CAACmB,wBAAwB,IAAI,IAAI,EAAE;UAC9E,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAId,YAAK,CAAC;MACRC,KAAK,EAAE,yCAAyC;MAChDC,OAAO,EACL,kIAAkI;MACpIC,QAAQ,EAAE,mEAAmE;MAC7EC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAI,CAACT,MAAM,CAACoB,mBAAmB,EAAE;UAC/B,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIf,YAAK,CAAC;MACRC,KAAK,EAAE,iCAAiC;MACxCC,OAAO,EACL,qGAAqG;MACvGC,QAAQ,EAAE,2EAA2E;MACrFC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAACqB,0BAA0B,KAAK,KAAK,EAAE;UAC/C,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIhB,YAAK,CAAC;MACRC,KAAK,EAAE,uCAAuC;MAC9CC,OAAO,EAAE,4FAA4F;MACrGC,QAAQ,EAAE,4JAA4J;MACtKC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAACsB,0BAA0B,KAAK,KAAK,EAAE;UAC/C,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIjB,YAAK,CAAC;MACRC,KAAK,EAAE,6BAA6B;MACpCC,OAAO,EACL,+EAA+E;MACjFC,QAAQ,EACN,2HAA2H;MAC7HC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAACuB,eAAe,EAAE;UAC1B,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIlB,YAAK,CAAC;MACRC,KAAK,EAAE,kCAAkC;MACzCC,OAAO,EACL,mIAAmI;MACrIC,QAAQ,EACN,2IAA2I;MAC7IC,KAAK,EAAEA,CAAA,KAAM;QACX,IACET,MAAM,CAACwB,eAAe,EAAEC,kBAAkB,KAAK,IAAI,IACnDzB,MAAM,CAACwB,eAAe,EAAEC,kBAAkB,IAAI,IAAI,EAClD;UACA,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIpB,YAAK,CAAC;MACRC,KAAK,EAAE,0CAA0C;MACjDC,OAAO,EACL,yHAAyH;MAC3HC,QAAQ,EACN,sKAAsK;MACxKC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAI,CAACT,MAAM,CAAC0B,iBAAiB,EAAE;UAC7B;QACF;QACA,MAAMC,GAAG,GAAG3B,MAAM,CAAC4B,oBAAoB,IAAI,EAAE;QAC7C,MAAMC,SAAS,GAAG,CAAC,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC;QAC/D,IAAIF,GAAG,CAACG,IAAI,CAACC,EAAE,IAAIF,SAAS,CAACG,QAAQ,CAACD,EAAE,CAAC,CAAC,EAAE;UAC1C,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAI1B,YAAK,CAAC;MACRC,KAAK,EAAE,mCAAmC;MAC1CC,OAAO,EACL,mJAAmJ;MACrJC,QAAQ,EACN,qIAAqI;MACvIC,KAAK,EAAEA,CAAA,KAAM;QACX,MAAMwB,EAAE,GAAGjC,MAAM,CAACkC,iBAAiB;QACnC,IAAI,CAACD,EAAE,EAAE;UACP,MAAM,CAAC;QACT;QACA,MAAME,MAAM,GAAG,CAACF,EAAE,CAACG,YAAY,EAAEH,EAAE,CAACI,YAAY,EAAEJ,EAAE,CAACK,aAAa,EAAEL,EAAE,CAACM,YAAY,EAAEN,EAAE,CAACO,aAAa,CAAC;QACtG,IAAIL,MAAM,CAACL,IAAI,CAACW,CAAC,IAAIA,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;UAC9B,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIpC,YAAK,CAAC;MACRC,KAAK,EAAE,oDAAoD;MAC3DC,OAAO,EACL,iJAAiJ;MACnJC,QAAQ,EACN,iGAAiG;MACnGC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAAC0C,cAAc,EAAEC,kCAAkC,KAAK,KAAK,EAAE;UACvE,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAItC,YAAK,CAAC;MACRC,KAAK,EAAE,wDAAwD;MAC/DC,OAAO,EACL,qJAAqJ;MACvJC,QAAQ,EACN,gFAAgF;MAClFC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAAC4C,gCAAgC,KAAK,KAAK,EAAE;UACrD,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,EACF,IAAIvC,YAAK,CAAC;MACRC,KAAK,EAAE,iCAAiC;MACxCC,OAAO,EACL,gNAAgN;MAClNC,QAAQ,EACN,8HAA8H;MAChIC,KAAK,EAAEA,CAAA,KAAM;QACX,IAAIT,MAAM,CAAC6C,SAAS,EAAEC,UAAU,EAAE9B,MAAM,GAAG,CAAC,IAAIhB,MAAM,CAAC6C,SAAS,EAAEE,YAAY,KAAK,CAAC,EAAE;UACpF,MAAM,CAAC;QACT;MACF;IACF,CAAC,CAAC,CACH;EACH;AACF;AAEAC,MAAM,CAACC,OAAO,GAAGrD,sBAAsB","ignoreList":[]}
160
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_Check","require","_CheckGroup","_interopRequireDefault","_Config","_node","e","__esModule","default","CheckGroupServerConfig","CheckGroup","setName","setChecks","config","Config","get","Parse","applicationId","Check","title","warning","solution","check","masterKey","hasUpperCase","test","hasLowerCase","hasNumbers","hasNonAlphasNumerics","length","security","enableCheckLog","allowClientClassCreation","enforcePrivateUsers","enableInsecureAuthAdapters","graphQLPublicIntrospection","mountPlayground","databaseOptions","allowPublicExplain","readOnlyMasterKey","ips","readOnlyMasterKeyIps","wildcards","some","ip","includes","rc","requestComplexity","values","includeDepth","includeCount","subqueryDepth","queryDepth","graphQLDepth","graphQLFields","batchRequestLimit","v","passwordPolicy","resetPasswordSuccessOnInvalidEmail","emailVerifySuccessOnInvalidEmail","liveQuery","classNames","regexTimeout","module","exports"],"sources":["../../../src/Security/CheckGroups/CheckGroupServerConfig.js"],"sourcesContent":["import { Check } from '../Check';\nimport CheckGroup from '../CheckGroup';\nimport Config from '../../Config';\nimport Parse from 'parse/node';\n\n/**\n * The security checks group for Parse Server configuration.\n * Checks common Parse Server parameters such as access keys.\n * @memberof module:SecurityCheck\n */\nclass CheckGroupServerConfig extends CheckGroup {\n  setName() {\n    return 'Parse Server Configuration';\n  }\n  setChecks() {\n    const config = Config.get(Parse.applicationId);\n    return [\n      new Check({\n        title: 'Secure master key',\n        warning: 'The Parse Server master key is insecure and vulnerable to brute force attacks.',\n        solution:\n          'Choose a longer and/or more complex master key with a combination of upper- and lowercase characters, numbers and special characters.',\n        check: () => {\n          const masterKey = config.masterKey;\n          const hasUpperCase = /[A-Z]/.test(masterKey);\n          const hasLowerCase = /[a-z]/.test(masterKey);\n          const hasNumbers = /\\d/.test(masterKey);\n          const hasNonAlphasNumerics = /\\W/.test(masterKey);\n          // Ensure length\n          if (masterKey.length < 14) {\n            throw 1;\n          }\n          // Ensure at least 3 out of 4 requirements passed\n          if (hasUpperCase + hasLowerCase + hasNumbers + hasNonAlphasNumerics < 3) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Security log disabled',\n        warning:\n          'Security checks in logs may expose vulnerabilities to anyone with access to logs.',\n        solution: \"Change Parse Server configuration to 'security.enableCheckLog: false'.\",\n        check: () => {\n          if (config.security && config.security.enableCheckLog) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Client class creation disabled',\n        warning:\n          'Attackers are allowed to create new classes without restriction and flood the database.',\n        solution: \"Change Parse Server configuration to 'allowClientClassCreation: false'.\",\n        check: () => {\n          if (config.allowClientClassCreation || config.allowClientClassCreation == null) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Users are created without public access',\n        warning:\n          'Users with public read access are exposed to anyone who knows their object IDs, or to anyone who can query the Parse.User class.',\n        solution: \"Change Parse Server configuration to 'enforcePrivateUsers: true'.\",\n        check: () => {\n          if (!config.enforcePrivateUsers) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Insecure auth adapters disabled',\n        warning:\n          \"Attackers may explore insecure auth adapters' vulnerabilities and log in on behalf of another user.\",\n        solution: \"Change Parse Server configuration to 'enableInsecureAuthAdapters: false'.\",\n        check: () => {\n          if (config.enableInsecureAuthAdapters !== false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'GraphQL public introspection disabled',\n        warning: 'GraphQL public introspection is enabled, which allows anyone to access the GraphQL schema.',\n        solution: \"Change Parse Server configuration to 'graphQLPublicIntrospection: false'. You will need to use master key or maintenance key to access the GraphQL schema.\",\n        check: () => {\n          if (config.graphQLPublicIntrospection !== false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'GraphQL Playground disabled',\n        warning:\n          'GraphQL Playground is enabled and exposes the master key in the browser page.',\n        solution:\n          \"Change Parse Server configuration to 'mountPlayground: false'. Use Parse Dashboard for GraphQL exploration in production.\",\n        check: () => {\n          if (config.mountPlayground) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Public database explain disabled',\n        warning:\n          'Database explain queries are publicly accessible, which may expose sensitive database performance information and schema details.',\n        solution:\n          \"Change Parse Server configuration to 'databaseOptions.allowPublicExplain: false'. You will need to use master key to run explain queries.\",\n        check: () => {\n          if (\n            config.databaseOptions?.allowPublicExplain === true ||\n            config.databaseOptions?.allowPublicExplain == null\n          ) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Read-only master key IP range restricted',\n        warning:\n          'The read-only master key can be used from any IP address, which increases the attack surface if the key is compromised.',\n        solution:\n          \"Change Parse Server configuration to 'readOnlyMasterKeyIps: [\\\"127.0.0.1\\\", \\\"::1\\\"]' to restrict access to localhost, or set it to a list of specific IP addresses.\",\n        check: () => {\n          if (!config.readOnlyMasterKey) {\n            return;\n          }\n          const ips = config.readOnlyMasterKeyIps || [];\n          const wildcards = ['0.0.0.0/0', '0.0.0.0', '::/0', '::', '::0'];\n          if (ips.some(ip => wildcards.includes(ip))) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Request complexity limits enabled',\n        warning:\n          'One or more request complexity limits are disabled, which may allow denial-of-service attacks through deeply nested or excessively broad queries.',\n        solution:\n          \"Ensure all properties in 'requestComplexity' are set to positive integers. Set to '-1' only if you have other mitigations in place.\",\n        check: () => {\n          const rc = config.requestComplexity;\n          if (!rc) {\n            throw 1;\n          }\n          const values = [rc.includeDepth, rc.includeCount, rc.subqueryDepth, rc.queryDepth, rc.graphQLDepth, rc.graphQLFields, rc.batchRequestLimit];\n          if (values.some(v => v === -1)) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Password reset endpoint user enumeration mitigated',\n        warning:\n          'The password reset endpoint returns distinct error responses for invalid email addresses, which allows attackers to enumerate registered users.',\n        solution:\n          \"Change Parse Server configuration to 'passwordPolicy.resetPasswordSuccessOnInvalidEmail: true'.\",\n        check: () => {\n          if (config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail === false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Email verification endpoint user enumeration mitigated',\n        warning:\n          'The email verification endpoint returns distinct error responses for invalid email addresses, which allows attackers to enumerate registered users.',\n        solution:\n          \"Change Parse Server configuration to 'emailVerifySuccessOnInvalidEmail: true'.\",\n        check: () => {\n          if (config.emailVerifySuccessOnInvalidEmail === false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'LiveQuery regex timeout enabled',\n        warning:\n          'LiveQuery regex timeout is disabled. A malicious client can subscribe with a crafted $regex pattern that causes catastrophic backtracking, blocking the Node.js event loop and making the server unresponsive.',\n        solution:\n          \"Change Parse Server configuration to 'liveQuery.regexTimeout: 100' to set a 100ms timeout for regex evaluation in LiveQuery.\",\n        check: () => {\n          if (config.liveQuery?.classNames?.length > 0 && config.liveQuery?.regexTimeout === 0) {\n            throw 1;\n          }\n        },\n      }),\n    ];\n  }\n}\n\nmodule.exports = CheckGroupServerConfig;\n"],"mappings":"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","ignoreList":[]}