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
package/lib/Auth.js CHANGED
@@ -153,8 +153,16 @@ const getAuthForSessionToken = async function ({
153
153
  }) {
154
154
  cacheController = cacheController || config && config.cacheController;
155
155
  if (cacheController) {
156
- const userJSON = await cacheController.user.get(sessionToken);
157
- if (userJSON) {
156
+ const cached = await cacheController.user.get(sessionToken);
157
+ if (cached) {
158
+ const {
159
+ expiresAt: cachedExpiresAt,
160
+ ...userJSON
161
+ } = cached;
162
+ if (cachedExpiresAt && new Date(cachedExpiresAt) < new Date()) {
163
+ cacheController.user.del(sessionToken);
164
+ throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');
165
+ }
158
166
  const cachedUser = Parse.Object.fromJSON(userJSON);
159
167
  renewSessionIfNeeded({
160
168
  config,
@@ -210,7 +218,10 @@ const getAuthForSessionToken = async function ({
210
218
  obj['className'] = '_User';
211
219
  obj['sessionToken'] = sessionToken;
212
220
  if (cacheController) {
213
- cacheController.user.put(sessionToken, obj);
221
+ cacheController.user.put(sessionToken, {
222
+ ...obj,
223
+ expiresAt: expiresAt?.toISOString()
224
+ });
214
225
  }
215
226
  renewSessionIfNeeded({
216
227
  config,
@@ -452,13 +463,22 @@ const findUsersWithAuthData = async (config, authData, beforeFind, currentUserAu
452
463
  const storedProviderData = currentUserAuthData?.[provider];
453
464
  const incomingKeys = Object.keys(providerAuthData || {});
454
465
  const isUnchanged = storedProviderData && incomingKeys.length > 0 && !incomingKeys.some(key => !(0, _util.isDeepStrictEqual)(providerAuthData[key], storedProviderData[key]));
455
- const adapter = config.authDataManager.getValidatorForProvider(provider)?.adapter;
466
+ const validatorConfig = config.authDataManager.getValidatorForProvider(provider);
467
+ // Skip database query for unconfigured providers to avoid unindexed collection scans;
468
+ // the provider will be rejected later in handleAuthDataValidation with UNSUPPORTED_SERVICE
469
+ if (!validatorConfig?.validator) {
470
+ return null;
471
+ }
472
+ const adapter = validatorConfig.adapter;
456
473
  if (beforeFind && typeof adapter?.beforeFind === 'function' && !isUnchanged) {
457
474
  await adapter.beforeFind(providerAuthData);
458
475
  }
459
476
  if (!providerAuthData?.id) {
460
477
  return null;
461
478
  }
479
+ if (typeof providerAuthData.id !== 'string') {
480
+ throw new Parse.Error(Parse.Error.INVALID_VALUE, `Invalid authData id for provider '${provider}'.`);
481
+ }
462
482
  return {
463
483
  [`authData.${provider}.id`]: providerAuthData.id
464
484
  };
@@ -527,10 +547,16 @@ const hasMutatedAuthData = (authData, userAuthData) => {
527
547
  };
528
548
  };
529
549
  const checkIfUserHasProvidedConfiguredProvidersForLogin = (req = {}, authData = {}, userAuthData = {}, config) => {
530
- const savedUserProviders = Object.keys(userAuthData).map(provider => ({
531
- name: provider,
532
- adapter: config.authDataManager.getValidatorForProvider(provider).adapter
533
- }));
550
+ const savedUserProviders = Object.keys(userAuthData).map(provider => {
551
+ const validator = config.authDataManager.getValidatorForProvider(provider);
552
+ if (!validator || !validator.adapter) {
553
+ return null;
554
+ }
555
+ return {
556
+ name: provider,
557
+ adapter: validator.adapter
558
+ };
559
+ }).filter(Boolean);
534
560
  const hasProvidedASoloProvider = savedUserProviders.some(provider => provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]);
535
561
 
536
562
  // Solo providers can be considered as safe, so we do not have to check if the user needs
@@ -658,4 +684,4 @@ module.exports = {
658
684
  checkIfUserHasProvidedConfiguredProvidersForLogin,
659
685
  handleAuthDataValidation
660
686
  };
661
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_util","require","_triggers","_logger","_lruCache","_RestQuery","_interopRequireDefault","_RestWrite","e","__esModule","default","Parse","Auth","config","cacheController","undefined","isMaster","isMaintenance","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","maintenance","readOnly","nobody","throttle","LRU","max","ttl","shouldUpdateSessionExpiry","session","resetAfter","sessionLength","lastUpdated","Date","updatedAt","skipRange","setTime","getTime","renewSessionIfNeeded","sessionToken","extendSessionOnUse","get","set","query","RestQuery","method","Method","auth","runBeforeFind","className","restWhere","restOptions","limit","results","execute","expiresAt","generateSessionExpiresAt","RestWrite","objectId","_encode","code","Error","OBJECT_NOT_FOUND","logger","error","getAuthForSessionToken","userJSON","cachedUser","Object","fromJSON","Promise","resolve","include","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","INVALID_SESSION_TOKEN","now","iso","startsWith","INTERNAL_SERVER_ERROR","password","put","userObject","getAuthForLegacySessionToken","_session_token","then","response","getUserRoles","_loadRoles","getRolesForUser","users","__type","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","del","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","beforeFind","currentUserAuthData","providers","keys","queries","all","provider","providerAuthData","storedProviderData","incomingKeys","isUnchanged","some","key","isDeepStrictEqual","adapter","authDataManager","getValidatorForProvider","validQueries","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","hasChanges","checkIfUserHasProvidedConfiguredProvidersForLogin","req","savedUserProviders","hasProvidedASoloProvider","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","requestObject","ip","call","OTHER_CAUSE","join","handleAuthDataValidation","foundUser","User","getUserId","fetch","updatedObject","buildParseObjects","getRequestObject","acc","authDataResponse","authKeys","sort","validator","authProvider","enabled","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","resolveError","SCRIPT_FAILED","message","userString","data","JSON","stringify","authenticationStep","module","exports"],"sources":["../src/Auth.js"],"sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport { logger } from './logger';\nimport { LRUCache as LRU } from 'lru-cache';\nimport RestQuery from './RestQuery';\nimport RestWrite from './RestWrite';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isMaintenance = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.isMaintenance = isMaintenance;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.isMaintenance) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a maintenance-level Auth object\nfunction maintenance(config) {\n  return new Auth({ config, isMaintenance: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\nconst throttle = new LRU({\n  max: 10000,\n  ttl: 500,\n});\n/**\n * Checks whether session should be updated based on last update time & session length.\n */\nfunction shouldUpdateSessionExpiry(config, session) {\n  const resetAfter = config.sessionLength / 2;\n  const lastUpdated = new Date(session?.updatedAt);\n  const skipRange = new Date();\n  skipRange.setTime(skipRange.getTime() - resetAfter * 1000);\n  return lastUpdated <= skipRange;\n}\n\nconst renewSessionIfNeeded = async ({ config, session, sessionToken }) => {\n  if (!config?.extendSessionOnUse) {\n    return;\n  }\n  if (throttle.get(sessionToken)) {\n    return;\n  }\n  throttle.set(sessionToken, true);\n  try {\n    if (!session) {\n      const query = await RestQuery({\n        method: RestQuery.Method.get,\n        config,\n        auth: master(config),\n        runBeforeFind: false,\n        className: '_Session',\n        restWhere: { sessionToken },\n        restOptions: { limit: 1 },\n      });\n      const { results } = await query.execute();\n      session = results[0];\n    }\n\n    if (!shouldUpdateSessionExpiry(config, session) || !session) {\n      return;\n    }\n    const expiresAt = config.generateSessionExpiresAt();\n    await new RestWrite(\n      config,\n      master(config),\n      '_Session',\n      { objectId: session.objectId },\n      { expiresAt: Parse._encode(expiresAt) }\n    ).execute();\n  } catch (e) {\n    if (e?.code !== Parse.Error.OBJECT_NOT_FOUND) {\n      logger.error('Could not update session expiry: ', e);\n    }\n  }\n};\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const userJSON = await cacheController.user.get(sessionToken);\n    if (userJSON) {\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      renewSessionIfNeeded({ config, sessionToken });\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.get,\n      config,\n      runBeforeFind: false,\n      auth: master(config),\n      className: '_Session',\n      restWhere: { sessionToken },\n      restOptions,\n    });\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const session = results[0];\n  const now = new Date(),\n    expiresAt = session.expiresAt ? new Date(session.expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = session.user;\n\n  if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n    throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n  }\n\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, obj);\n  }\n  renewSessionIfNeeded({ config, session, sessionToken });\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = async function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = await RestQuery({\n    method: RestQuery.Method.get,\n    config,\n    runBeforeFind: false,\n    auth: master(config),\n    className: '_User',\n    restWhere: { _session_token: sessionToken },\n    restOptions,\n  });\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n\n    if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n      throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n    }\n\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || this.isMaintenance || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      runBeforeFind: false,\n      config: this.config,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      config: this.config,\n      runBeforeFind: false,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = async (config, authData, beforeFind, currentUserAuthData) => {\n  const providers = Object.keys(authData);\n\n  const queries = await Promise.all(\n    providers.map(async provider => {\n      const providerAuthData = authData[provider];\n\n      // Skip providers being unlinked (null value)\n      if (providerAuthData === null) {\n        return null;\n      }\n\n      // Skip beforeFind only when incoming data is confirmed unchanged from stored data.\n      // This handles echoed-back authData from afterFind (e.g. client sends back { id: 'x' }\n      // alongside a provider unlink). On login/signup, currentUserAuthData is undefined so\n      // beforeFind always runs, preserving it as the security gate for missing credentials.\n      const storedProviderData = currentUserAuthData?.[provider];\n      const incomingKeys = Object.keys(providerAuthData || {});\n      const isUnchanged = storedProviderData && incomingKeys.length > 0 &&\n        !incomingKeys.some(key => !isDeepStrictEqual(providerAuthData[key], storedProviderData[key]));\n\n      const adapter = config.authDataManager.getValidatorForProvider(provider)?.adapter;\n      if (beforeFind && typeof adapter?.beforeFind === 'function' && !isUnchanged) {\n        await adapter.beforeFind(providerAuthData);\n      }\n\n      if (!providerAuthData?.id) {\n        return null;\n      }\n\n      return { [`authData.${provider}.id`]: providerAuthData.id };\n    })\n  );\n\n  // Filter out null queries\n  const validQueries = queries.filter(query => query !== null);\n\n  if (!validQueries.length) {\n    return [];\n  }\n\n  // Perform database query\n  return config.database.find('_User', { $or: validQueries }, { limit: 2 });\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) { return { hasMutatedAuthData: true, mutatedAuthData: authData }; }\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') { return; }\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n\n    // If unlinking (setting to null), consider it mutated\n    if (providerData === null) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // If provider doesn't exist in stored data, it's new\n    if (!userProviderAuthData) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // Check if incoming data represents actual changes vs just echoing back\n    // what afterFind returned. If incoming data is a subset of stored data\n    // (all incoming fields match stored values), it's not mutated.\n    // If incoming data has different values or fields not in stored data, it's mutated.\n    // This handles the case where afterFind strips sensitive fields like 'code':\n    // - Incoming: { id: 'x' }, Stored: { id: 'x', code: 'secret' } -> NOT mutated (subset)\n    // - Incoming: { id: 'x', token: 'new' }, Stored: { id: 'x', token: 'old' } -> MUTATED\n    const incomingKeys = Object.keys(providerData || {});\n    const hasChanges = incomingKeys.some(key => {\n      return !isDeepStrictEqual(providerData[key], userProviderAuthData[key]);\n    });\n\n    if (hasChanges) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  req = {},\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData).map(provider => ({\n    name: provider,\n    adapter: config.authDataManager.getValidatorForProvider(provider).adapter,\n  }));\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    let policy = provider.adapter.policy;\n    if (typeof policy === 'function') {\n      const requestObject = {\n        ip: req.config.ip,\n        user: req.auth.user,\n        master: req.auth.isMaster,\n      };\n      policy = policy.call(provider.adapter, requestObject, userAuthData[provider.name]);\n    }\n    if (policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(undefined, req.auth, updatedObject, user, req.config);\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider) || {};\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  maintenance,\n  nobody,\n  readOnly,\n  shouldUpdateSessionExpiry,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":"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","ignoreList":[]}
687
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_util","require","_triggers","_logger","_lruCache","_RestQuery","_interopRequireDefault","_RestWrite","e","__esModule","default","Parse","Auth","config","cacheController","undefined","isMaster","isMaintenance","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","maintenance","readOnly","nobody","throttle","LRU","max","ttl","shouldUpdateSessionExpiry","session","resetAfter","sessionLength","lastUpdated","Date","updatedAt","skipRange","setTime","getTime","renewSessionIfNeeded","sessionToken","extendSessionOnUse","get","set","query","RestQuery","method","Method","auth","runBeforeFind","className","restWhere","restOptions","limit","results","execute","expiresAt","generateSessionExpiresAt","RestWrite","objectId","_encode","code","Error","OBJECT_NOT_FOUND","logger","error","getAuthForSessionToken","cached","cachedExpiresAt","userJSON","del","INVALID_SESSION_TOKEN","cachedUser","Object","fromJSON","Promise","resolve","include","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","now","iso","startsWith","INTERNAL_SERVER_ERROR","password","put","toISOString","userObject","getAuthForLegacySessionToken","_session_token","then","response","getUserRoles","_loadRoles","getRolesForUser","users","__type","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","beforeFind","currentUserAuthData","providers","keys","queries","all","provider","providerAuthData","storedProviderData","incomingKeys","isUnchanged","some","key","isDeepStrictEqual","validatorConfig","authDataManager","getValidatorForProvider","validator","adapter","INVALID_VALUE","validQueries","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","hasChanges","checkIfUserHasProvidedConfiguredProvidersForLogin","req","savedUserProviders","Boolean","hasProvidedASoloProvider","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","requestObject","ip","call","OTHER_CAUSE","join","handleAuthDataValidation","foundUser","User","getUserId","fetch","updatedObject","buildParseObjects","getRequestObject","acc","authDataResponse","authKeys","sort","authProvider","enabled","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","resolveError","SCRIPT_FAILED","message","userString","data","JSON","stringify","authenticationStep","module","exports"],"sources":["../src/Auth.js"],"sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport { logger } from './logger';\nimport { LRUCache as LRU } from 'lru-cache';\nimport RestQuery from './RestQuery';\nimport RestWrite from './RestWrite';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isMaintenance = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.isMaintenance = isMaintenance;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.isMaintenance) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a maintenance-level Auth object\nfunction maintenance(config) {\n  return new Auth({ config, isMaintenance: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\nconst throttle = new LRU({\n  max: 10000,\n  ttl: 500,\n});\n/**\n * Checks whether session should be updated based on last update time & session length.\n */\nfunction shouldUpdateSessionExpiry(config, session) {\n  const resetAfter = config.sessionLength / 2;\n  const lastUpdated = new Date(session?.updatedAt);\n  const skipRange = new Date();\n  skipRange.setTime(skipRange.getTime() - resetAfter * 1000);\n  return lastUpdated <= skipRange;\n}\n\nconst renewSessionIfNeeded = async ({ config, session, sessionToken }) => {\n  if (!config?.extendSessionOnUse) {\n    return;\n  }\n  if (throttle.get(sessionToken)) {\n    return;\n  }\n  throttle.set(sessionToken, true);\n  try {\n    if (!session) {\n      const query = await RestQuery({\n        method: RestQuery.Method.get,\n        config,\n        auth: master(config),\n        runBeforeFind: false,\n        className: '_Session',\n        restWhere: { sessionToken },\n        restOptions: { limit: 1 },\n      });\n      const { results } = await query.execute();\n      session = results[0];\n    }\n\n    if (!shouldUpdateSessionExpiry(config, session) || !session) {\n      return;\n    }\n    const expiresAt = config.generateSessionExpiresAt();\n    await new RestWrite(\n      config,\n      master(config),\n      '_Session',\n      { objectId: session.objectId },\n      { expiresAt: Parse._encode(expiresAt) }\n    ).execute();\n  } catch (e) {\n    if (e?.code !== Parse.Error.OBJECT_NOT_FOUND) {\n      logger.error('Could not update session expiry: ', e);\n    }\n  }\n};\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const cached = await cacheController.user.get(sessionToken);\n    if (cached) {\n      const { expiresAt: cachedExpiresAt, ...userJSON } = cached;\n      if (cachedExpiresAt && new Date(cachedExpiresAt) < new Date()) {\n        cacheController.user.del(sessionToken);\n        throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n      }\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      renewSessionIfNeeded({ config, sessionToken });\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.get,\n      config,\n      runBeforeFind: false,\n      auth: master(config),\n      className: '_Session',\n      restWhere: { sessionToken },\n      restOptions,\n    });\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const session = results[0];\n  const now = new Date(),\n    expiresAt = session.expiresAt ? new Date(session.expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = session.user;\n\n  if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n    throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n  }\n\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, { ...obj, expiresAt: expiresAt?.toISOString() });\n  }\n  renewSessionIfNeeded({ config, session, sessionToken });\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = async function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = await RestQuery({\n    method: RestQuery.Method.get,\n    config,\n    runBeforeFind: false,\n    auth: master(config),\n    className: '_User',\n    restWhere: { _session_token: sessionToken },\n    restOptions,\n  });\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n\n    if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n      throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n    }\n\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || this.isMaintenance || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      runBeforeFind: false,\n      config: this.config,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      config: this.config,\n      runBeforeFind: false,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = async (config, authData, beforeFind, currentUserAuthData) => {\n  const providers = Object.keys(authData);\n\n  const queries = await Promise.all(\n    providers.map(async provider => {\n      const providerAuthData = authData[provider];\n\n      // Skip providers being unlinked (null value)\n      if (providerAuthData === null) {\n        return null;\n      }\n\n      // Skip beforeFind only when incoming data is confirmed unchanged from stored data.\n      // This handles echoed-back authData from afterFind (e.g. client sends back { id: 'x' }\n      // alongside a provider unlink). On login/signup, currentUserAuthData is undefined so\n      // beforeFind always runs, preserving it as the security gate for missing credentials.\n      const storedProviderData = currentUserAuthData?.[provider];\n      const incomingKeys = Object.keys(providerAuthData || {});\n      const isUnchanged = storedProviderData && incomingKeys.length > 0 &&\n        !incomingKeys.some(key => !isDeepStrictEqual(providerAuthData[key], storedProviderData[key]));\n\n      const validatorConfig = config.authDataManager.getValidatorForProvider(provider);\n      // Skip database query for unconfigured providers to avoid unindexed collection scans;\n      // the provider will be rejected later in handleAuthDataValidation with UNSUPPORTED_SERVICE\n      if (!validatorConfig?.validator) {\n        return null;\n      }\n      const adapter = validatorConfig.adapter;\n      if (beforeFind && typeof adapter?.beforeFind === 'function' && !isUnchanged) {\n        await adapter.beforeFind(providerAuthData);\n      }\n\n      if (!providerAuthData?.id) {\n        return null;\n      }\n\n      if (typeof providerAuthData.id !== 'string') {\n        throw new Parse.Error(Parse.Error.INVALID_VALUE, `Invalid authData id for provider '${provider}'.`);\n      }\n\n      return { [`authData.${provider}.id`]: providerAuthData.id };\n    })\n  );\n\n  // Filter out null queries\n  const validQueries = queries.filter(query => query !== null);\n\n  if (!validQueries.length) {\n    return [];\n  }\n\n  // Perform database query\n  return config.database.find('_User', { $or: validQueries }, { limit: 2 });\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) { return { hasMutatedAuthData: true, mutatedAuthData: authData }; }\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') { return; }\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n\n    // If unlinking (setting to null), consider it mutated\n    if (providerData === null) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // If provider doesn't exist in stored data, it's new\n    if (!userProviderAuthData) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // Check if incoming data represents actual changes vs just echoing back\n    // what afterFind returned. If incoming data is a subset of stored data\n    // (all incoming fields match stored values), it's not mutated.\n    // If incoming data has different values or fields not in stored data, it's mutated.\n    // This handles the case where afterFind strips sensitive fields like 'code':\n    // - Incoming: { id: 'x' }, Stored: { id: 'x', code: 'secret' } -> NOT mutated (subset)\n    // - Incoming: { id: 'x', token: 'new' }, Stored: { id: 'x', token: 'old' } -> MUTATED\n    const incomingKeys = Object.keys(providerData || {});\n    const hasChanges = incomingKeys.some(key => {\n      return !isDeepStrictEqual(providerData[key], userProviderAuthData[key]);\n    });\n\n    if (hasChanges) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  req = {},\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData)\n    .map(provider => {\n      const validator = config.authDataManager.getValidatorForProvider(provider);\n      if (!validator || !validator.adapter) {\n        return null;\n      }\n      return { name: provider, adapter: validator.adapter };\n    })\n    .filter(Boolean);\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    let policy = provider.adapter.policy;\n    if (typeof policy === 'function') {\n      const requestObject = {\n        ip: req.config.ip,\n        user: req.auth.user,\n        master: req.auth.isMaster,\n      };\n      policy = policy.call(provider.adapter, requestObject, userAuthData[provider.name]);\n    }\n    if (policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(undefined, req.auth, updatedObject, user, req.config);\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider) || {};\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  maintenance,\n  nobody,\n  readOnly,\n  shouldUpdateSessionExpiry,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":"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","ignoreList":[]}