parse-server 8.5.0-alpha.8 → 8.5.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 (53) hide show
  1. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -2
  2. package/lib/Adapters/Auth/AuthAdapter.js +2 -2
  3. package/lib/Adapters/Auth/apple.js +2 -2
  4. package/lib/Adapters/Auth/facebook.js +2 -2
  5. package/lib/Adapters/Cache/CacheAdapter.js +2 -2
  6. package/lib/Adapters/Email/MailAdapter.js +2 -2
  7. package/lib/Adapters/Files/FilesAdapter.js +2 -2
  8. package/lib/Adapters/Files/GridFSBucketAdapter.js +2 -2
  9. package/lib/Adapters/Logger/LoggerAdapter.js +2 -2
  10. package/lib/Adapters/Logger/WinstonLogger.js +3 -3
  11. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -2
  12. package/lib/Adapters/Push/PushAdapter.js +2 -3
  13. package/lib/Adapters/Storage/Mongo/MongoTransform.js +2 -2
  14. package/lib/Adapters/WebSocketServer/WSAdapter.js +2 -2
  15. package/lib/Adapters/WebSocketServer/WSSAdapter.js +2 -2
  16. package/lib/Controllers/HooksController.js +2 -2
  17. package/lib/Controllers/SchemaController.js +7 -5
  18. package/lib/Controllers/index.js +2 -2
  19. package/lib/Deprecator/Deprecator.js +3 -2
  20. package/lib/Error.js +48 -0
  21. package/lib/GraphQL/ParseGraphQLServer.js +36 -19
  22. package/lib/GraphQL/loaders/filesMutations.js +2 -2
  23. package/lib/GraphQL/loaders/schemaMutations.js +8 -7
  24. package/lib/GraphQL/loaders/schemaQueries.js +3 -3
  25. package/lib/GraphQL/loaders/usersQueries.js +4 -3
  26. package/lib/GraphQL/parseGraphQLUtils.js +4 -3
  27. package/lib/Options/Definitions.js +9 -2
  28. package/lib/Options/docs.js +3 -2
  29. package/lib/Options/index.js +1 -1
  30. package/lib/Options/parsers.js +2 -2
  31. package/lib/RestQuery.js +8 -5
  32. package/lib/RestWrite.js +6 -6
  33. package/lib/Routers/ClassesRouter.js +4 -3
  34. package/lib/Routers/FilesRouter.js +4 -5
  35. package/lib/Routers/GlobalConfigRouter.js +3 -2
  36. package/lib/Routers/GraphQLRouter.js +3 -2
  37. package/lib/Routers/PagesRouter.js +4 -4
  38. package/lib/Routers/PurgeRouter.js +3 -2
  39. package/lib/Routers/PushRouter.js +3 -2
  40. package/lib/Routers/SchemasRouter.js +5 -4
  41. package/lib/Routers/UsersRouter.js +39 -7
  42. package/lib/SharedRest.js +9 -8
  43. package/lib/TestUtils.js +1 -1
  44. package/lib/Utils.js +27 -2
  45. package/lib/batch.js +2 -2
  46. package/lib/cli/utils/runner.js +2 -2
  47. package/lib/cloud-code/Parse.Cloud.js +43 -1
  48. package/lib/middlewares.js +9 -10
  49. package/lib/password.js +2 -2
  50. package/lib/request.js +2 -2
  51. package/lib/rest.js +14 -11
  52. package/lib/triggers.js +5 -4
  53. package/package.json +4 -7
package/lib/rest.js CHANGED
@@ -16,6 +16,9 @@ var triggers = require('./triggers');
16
16
  const {
17
17
  enforceRoleSecurity
18
18
  } = require('./SharedRest');
19
+ const {
20
+ createSanitizedError
21
+ } = require('./Error');
19
22
  function checkTriggers(className, config, types) {
20
23
  return types.some(triggerType => {
21
24
  return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);
@@ -107,7 +110,7 @@ async function runFindTriggers(config, auth, className, restWhere, restOptions,
107
110
 
108
111
  // Returns a promise for an object with optional keys 'results' and 'count'.
109
112
  const find = async (config, auth, className, restWhere, restOptions, clientSDK, context) => {
110
- enforceRoleSecurity('find', className, auth);
113
+ enforceRoleSecurity('find', className, auth, config);
111
114
  return runFindTriggers(config, auth, className, restWhere, restOptions, clientSDK, context, {
112
115
  isGet: false
113
116
  });
@@ -115,7 +118,7 @@ const find = async (config, auth, className, restWhere, restOptions, clientSDK,
115
118
 
116
119
  // get is just like find but only queries an objectId.
117
120
  const get = async (config, auth, className, objectId, restOptions, clientSDK, context) => {
118
- enforceRoleSecurity('get', className, auth);
121
+ enforceRoleSecurity('get', className, auth, config);
119
122
  return runFindTriggers(config, auth, className, {
120
123
  objectId
121
124
  }, restOptions, clientSDK, context, {
@@ -131,7 +134,7 @@ function del(config, auth, className, objectId, context) {
131
134
  if (className === '_User' && auth.isUnauthenticated()) {
132
135
  throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');
133
136
  }
134
- enforceRoleSecurity('delete', className, auth);
137
+ enforceRoleSecurity('delete', className, auth, config);
135
138
  let inflatedObject;
136
139
  let schemaController;
137
140
  return Promise.resolve().then(async () => {
@@ -155,7 +158,7 @@ function del(config, auth, className, objectId, context) {
155
158
  firstResult.className = className;
156
159
  if (className === '_Session' && !auth.isMaster && !auth.isMaintenance) {
157
160
  if (!auth.user || firstResult.user.objectId !== auth.user.id) {
158
- throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
161
+ throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
159
162
  }
160
163
  }
161
164
  var cacheAdapter = config.cacheController;
@@ -192,13 +195,13 @@ function del(config, auth, className, objectId, context) {
192
195
  config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);
193
196
  return triggers.maybeRunTrigger(triggers.Types.afterDelete, auth, inflatedObject, null, config, context);
194
197
  }).catch(error => {
195
- handleSessionMissingError(error, className, auth);
198
+ handleSessionMissingError(error, className, auth, config);
196
199
  });
197
200
  }
198
201
 
199
202
  // Returns a promise for a {response, status, location} object.
200
203
  function create(config, auth, className, restObject, clientSDK, context) {
201
- enforceRoleSecurity('create', className, auth);
204
+ enforceRoleSecurity('create', className, auth, config);
202
205
  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);
203
206
  return write.execute();
204
207
  }
@@ -207,7 +210,7 @@ function create(config, auth, className, restObject, clientSDK, context) {
207
210
  // REST API is supposed to return.
208
211
  // Usually, this is just updatedAt.
209
212
  function update(config, auth, className, restWhere, restObject, clientSDK, context) {
210
- enforceRoleSecurity('update', className, auth);
213
+ enforceRoleSecurity('update', className, auth, config);
211
214
  return Promise.resolve().then(async () => {
212
215
  const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);
213
216
  const hasLiveQuery = checkLiveQuery(className, config);
@@ -237,13 +240,13 @@ function update(config, auth, className, restWhere, restObject, clientSDK, conte
237
240
  }
238
241
  return new RestWrite(config, auth, className, restWhere, restObject, originalRestObject, clientSDK, context, 'update').execute();
239
242
  }).catch(error => {
240
- handleSessionMissingError(error, className, auth);
243
+ handleSessionMissingError(error, className, auth, config);
241
244
  });
242
245
  }
243
- function handleSessionMissingError(error, className, auth) {
246
+ function handleSessionMissingError(error, className, auth, config) {
244
247
  // If we're trying to update a user without / with bad session token
245
248
  if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster && !auth.isMaintenance) {
246
- throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');
249
+ throw createSanitizedError(Parse.Error.SESSION_MISSING, 'Insufficient auth.', config);
247
250
  }
248
251
  throw error;
249
252
  }
@@ -254,4 +257,4 @@ module.exports = {
254
257
  get,
255
258
  update
256
259
  };
257
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","RestQuery","RestWrite","triggers","enforceRoleSecurity","checkTriggers","className","config","types","some","triggerType","getTrigger","Types","applicationId","checkLiveQuery","liveQueryController","hasLiveQuery","runFindTriggers","auth","restWhere","restOptions","clientSDK","context","options","isGet","explain","isMaster","allowPublicExplain","databaseOptions","Error","INVALID_QUERY","result","maybeRunQueryTrigger","beforeFind","objects","objectsFromBeforeFind","objectsForAfterFind","isMaintenance","ids","Array","isArray","map","o","id","objectId","filter","Boolean","length","refilterWhere","$in","refilterQuery","method","Method","get","find","runBeforeFind","runAfterFind","refiltered","execute","results","afterFindProcessedObjects","maybeRunAfterFindTrigger","afterFind","Query","withJSON","where","query","del","INVALID_JSON","isUnauthenticated","SESSION_MISSING","inflatedObject","schemaController","Promise","resolve","then","hasTriggers","op","response","firstResult","user","INVALID_SESSION_TOKEN","cacheAdapter","cacheController","sessionToken","Object","fromJSON","maybeRunTrigger","beforeDelete","OBJECT_NOT_FOUND","getUserRoles","database","loadSchema","s","acl","push","concat","userRoles","destroy","perms","getClassLevelPermissions","onAfterDelete","afterDelete","catch","error","handleSessionMissingError","create","restObject","write","update","originalRestObject","code","module","exports"],"sources":["../src/rest.js"],"sourcesContent":["// This file contains helpers for running operations in REST format.\n// The goal is that handlers that explicitly handle an express route\n// should just be shallow wrappers around things in this file, but\n// these functions should not explicitly depend on the request\n// object.\n// This means that one of these handlers can support multiple\n// routes. That's useful for the routes that do really similar\n// things.\n\nvar Parse = require('parse/node').Parse;\n\nvar RestQuery = require('./RestQuery');\nvar RestWrite = require('./RestWrite');\nvar triggers = require('./triggers');\nconst { enforceRoleSecurity } = require('./SharedRest');\n\nfunction checkTriggers(className, config, types) {\n  return types.some(triggerType => {\n    return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);\n  });\n}\n\nfunction checkLiveQuery(className, config) {\n  return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);\n}\nasync function runFindTriggers(\n  config,\n  auth,\n  className,\n  restWhere,\n  restOptions,\n  clientSDK,\n  context,\n  options = {}\n) {\n  const { isGet } = options;\n\n  if (restOptions && restOptions.explain && !auth.isMaster) {\n    const allowPublicExplain = config.databaseOptions?.allowPublicExplain ?? true;\n\n    if (!allowPublicExplain) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_QUERY,\n        'Using the explain query parameter requires the master key'\n      );\n    }\n  }\n\n  // Run beforeFind trigger - may modify query or return objects directly\n  const result = await triggers.maybeRunQueryTrigger(\n    triggers.Types.beforeFind,\n    className,\n    restWhere,\n    restOptions,\n    config,\n    auth,\n    context,\n    isGet\n  );\n\n  restWhere = result.restWhere || restWhere;\n  restOptions = result.restOptions || restOptions;\n\n  // Short-circuit path: beforeFind returned objects directly\n  // Security risk: These objects may have been fetched with master privileges\n  if (result?.objects) {\n    const objectsFromBeforeFind = result.objects;\n\n    let objectsForAfterFind = objectsFromBeforeFind;\n\n    // Security check: Re-filter objects if not master to ensure ACL/CLP compliance\n    if (!auth?.isMaster && !auth?.isMaintenance) {\n      const ids = (Array.isArray(objectsFromBeforeFind) ? objectsFromBeforeFind : [objectsFromBeforeFind])\n        .map(o => (o && (o.id || o.objectId)) || null)\n        .filter(Boolean);\n\n      // Objects without IDs are(normally) unsaved objects\n      // For unsaved objects, the ACL security does not apply, so no need to redo the query.\n      // For saved objects, we need to re-query to ensure proper ACL/CLP enforcement\n      if (ids.length > 0) {\n        const refilterWhere = isGet ? { objectId: ids[0] } : { objectId: { $in: ids } };\n\n        // Re-query with proper security: no triggers to avoid infinite loops\n        const refilterQuery = await RestQuery({\n          method: isGet ? RestQuery.Method.get : RestQuery.Method.find,\n          config,\n          auth,\n          className,\n          restWhere: refilterWhere,\n          restOptions,\n          clientSDK,\n          context,\n          runBeforeFind: false,\n          runAfterFind: false,\n        });\n\n        const refiltered = await refilterQuery.execute();\n        objectsForAfterFind = (refiltered && refiltered.results) || [];\n      }\n    }\n\n    // Run afterFind trigger on security-filtered objects\n    const afterFindProcessedObjects = await triggers.maybeRunAfterFindTrigger(\n      triggers.Types.afterFind,\n      auth,\n      className,\n      objectsForAfterFind,\n      config,\n      new Parse.Query(className).withJSON({ where: restWhere, ...restOptions }),\n      context,\n      isGet\n    );\n\n    return {\n      results: afterFindProcessedObjects,\n    };\n  }\n\n  // Normal path: execute database query with modified conditions\n  const query = await RestQuery({\n    method: isGet ? RestQuery.Method.get : RestQuery.Method.find,\n    config,\n    auth,\n    className,\n    restWhere,\n    restOptions,\n    clientSDK,\n    context,\n    runBeforeFind: false,\n  });\n\n  return query.execute();\n}\n\n// Returns a promise for an object with optional keys 'results' and 'count'.\nconst find = async (config, auth, className, restWhere, restOptions, clientSDK, context) => {\n  enforceRoleSecurity('find', className, auth);\n  return runFindTriggers(\n    config,\n    auth,\n    className,\n    restWhere,\n    restOptions,\n    clientSDK,\n    context,\n    { isGet: false }\n  );\n};\n\n// get is just like find but only queries an objectId.\nconst get = async (config, auth, className, objectId, restOptions, clientSDK, context) => {\n  enforceRoleSecurity('get', className, auth);\n  return runFindTriggers(\n    config,\n    auth,\n    className,\n    { objectId },\n    restOptions,\n    clientSDK,\n    context,\n    { isGet: true }\n  );\n};\n\n// Returns a promise that doesn't resolve to any useful value.\nfunction del(config, auth, className, objectId, context) {\n  if (typeof objectId !== 'string') {\n    throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');\n  }\n\n  if (className === '_User' && auth.isUnauthenticated()) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');\n  }\n\n  enforceRoleSecurity('delete', className, auth);\n\n  let inflatedObject;\n  let schemaController;\n\n  return Promise.resolve()\n    .then(async () => {\n      const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery || className == '_Session') {\n        const query = await RestQuery({\n          method: RestQuery.Method.get,\n          config,\n          auth,\n          className,\n          restWhere: { objectId },\n        });\n        return query.execute({ op: 'delete' }).then(response => {\n          if (response && response.results && response.results.length) {\n            const firstResult = response.results[0];\n            firstResult.className = className;\n            if (className === '_Session' && !auth.isMaster && !auth.isMaintenance) {\n              if (!auth.user || firstResult.user.objectId !== auth.user.id) {\n                throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n              }\n            }\n            var cacheAdapter = config.cacheController;\n            cacheAdapter.user.del(firstResult.sessionToken);\n            inflatedObject = Parse.Object.fromJSON(firstResult);\n            return triggers.maybeRunTrigger(\n              triggers.Types.beforeDelete,\n              auth,\n              inflatedObject,\n              null,\n              config,\n              context\n            );\n          }\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(() => {\n      if (!auth.isMaster && !auth.isMaintenance) {\n        return auth.getUserRoles();\n      } else {\n        return;\n      }\n    })\n    .then(() => config.database.loadSchema())\n    .then(s => {\n      schemaController = s;\n      const options = {};\n      if (!auth.isMaster && !auth.isMaintenance) {\n        options.acl = ['*'];\n        if (auth.user) {\n          options.acl.push(auth.user.id);\n          options.acl = options.acl.concat(auth.userRoles);\n        }\n      }\n\n      return config.database.destroy(\n        className,\n        {\n          objectId: objectId,\n        },\n        options,\n        schemaController\n      );\n    })\n    .then(() => {\n      // Notify LiveQuery server if possible\n      const perms = schemaController.getClassLevelPermissions(className);\n      config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);\n      return triggers.maybeRunTrigger(\n        triggers.Types.afterDelete,\n        auth,\n        inflatedObject,\n        null,\n        config,\n        context\n      );\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\n// Returns a promise for a {response, status, location} object.\nfunction create(config, auth, className, restObject, clientSDK, context) {\n  enforceRoleSecurity('create', className, auth);\n  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);\n  return write.execute();\n}\n\n// Returns a promise that contains the fields of the update that the\n// REST API is supposed to return.\n// Usually, this is just updatedAt.\nfunction update(config, auth, className, restWhere, restObject, clientSDK, context) {\n  enforceRoleSecurity('update', className, auth);\n\n  return Promise.resolve()\n    .then(async () => {\n      const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery) {\n        // Do not use find, as it runs the before finds\n        const query = await RestQuery({\n          method: RestQuery.Method.get,\n          config,\n          auth,\n          className,\n          restWhere,\n          runAfterFind: false,\n          runBeforeFind: false,\n          context,\n        });\n        return query.execute({\n          op: 'update',\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(({ results }) => {\n      var originalRestObject;\n      if (results && results.length) {\n        originalRestObject = results[0];\n      }\n      return new RestWrite(\n        config,\n        auth,\n        className,\n        restWhere,\n        restObject,\n        originalRestObject,\n        clientSDK,\n        context,\n        'update'\n      ).execute();\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\nfunction handleSessionMissingError(error, className, auth) {\n  // If we're trying to update a user without / with bad session token\n  if (\n    className === '_User' &&\n    error.code === Parse.Error.OBJECT_NOT_FOUND &&\n    !auth.isMaster &&\n    !auth.isMaintenance\n  ) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');\n  }\n  throw error;\n}\n\nmodule.exports = {\n  create,\n  del,\n  find,\n  get,\n  update,\n};\n"],"mappings":"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","ignoreList":[]}
260
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Parse","require","RestQuery","RestWrite","triggers","enforceRoleSecurity","createSanitizedError","checkTriggers","className","config","types","some","triggerType","getTrigger","Types","applicationId","checkLiveQuery","liveQueryController","hasLiveQuery","runFindTriggers","auth","restWhere","restOptions","clientSDK","context","options","isGet","explain","isMaster","allowPublicExplain","databaseOptions","Error","INVALID_QUERY","result","maybeRunQueryTrigger","beforeFind","objects","objectsFromBeforeFind","objectsForAfterFind","isMaintenance","ids","Array","isArray","map","o","id","objectId","filter","Boolean","length","refilterWhere","$in","refilterQuery","method","Method","get","find","runBeforeFind","runAfterFind","refiltered","execute","results","afterFindProcessedObjects","maybeRunAfterFindTrigger","afterFind","Query","withJSON","where","query","del","INVALID_JSON","isUnauthenticated","SESSION_MISSING","inflatedObject","schemaController","Promise","resolve","then","hasTriggers","op","response","firstResult","user","INVALID_SESSION_TOKEN","cacheAdapter","cacheController","sessionToken","Object","fromJSON","maybeRunTrigger","beforeDelete","OBJECT_NOT_FOUND","getUserRoles","database","loadSchema","s","acl","push","concat","userRoles","destroy","perms","getClassLevelPermissions","onAfterDelete","afterDelete","catch","error","handleSessionMissingError","create","restObject","write","update","originalRestObject","code","module","exports"],"sources":["../src/rest.js"],"sourcesContent":["// This file contains helpers for running operations in REST format.\n// The goal is that handlers that explicitly handle an express route\n// should just be shallow wrappers around things in this file, but\n// these functions should not explicitly depend on the request\n// object.\n// This means that one of these handlers can support multiple\n// routes. That's useful for the routes that do really similar\n// things.\n\nvar Parse = require('parse/node').Parse;\n\nvar RestQuery = require('./RestQuery');\nvar RestWrite = require('./RestWrite');\nvar triggers = require('./triggers');\nconst { enforceRoleSecurity } = require('./SharedRest');\nconst { createSanitizedError } = require('./Error');\n\nfunction checkTriggers(className, config, types) {\n  return types.some(triggerType => {\n    return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);\n  });\n}\n\nfunction checkLiveQuery(className, config) {\n  return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);\n}\nasync function runFindTriggers(\n  config,\n  auth,\n  className,\n  restWhere,\n  restOptions,\n  clientSDK,\n  context,\n  options = {}\n) {\n  const { isGet } = options;\n\n  if (restOptions && restOptions.explain && !auth.isMaster) {\n    const allowPublicExplain = config.databaseOptions?.allowPublicExplain ?? true;\n\n    if (!allowPublicExplain) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_QUERY,\n        'Using the explain query parameter requires the master key'\n      );\n    }\n  }\n\n  // Run beforeFind trigger - may modify query or return objects directly\n  const result = await triggers.maybeRunQueryTrigger(\n    triggers.Types.beforeFind,\n    className,\n    restWhere,\n    restOptions,\n    config,\n    auth,\n    context,\n    isGet\n  );\n\n  restWhere = result.restWhere || restWhere;\n  restOptions = result.restOptions || restOptions;\n\n  // Short-circuit path: beforeFind returned objects directly\n  // Security risk: These objects may have been fetched with master privileges\n  if (result?.objects) {\n    const objectsFromBeforeFind = result.objects;\n\n    let objectsForAfterFind = objectsFromBeforeFind;\n\n    // Security check: Re-filter objects if not master to ensure ACL/CLP compliance\n    if (!auth?.isMaster && !auth?.isMaintenance) {\n      const ids = (Array.isArray(objectsFromBeforeFind) ? objectsFromBeforeFind : [objectsFromBeforeFind])\n        .map(o => (o && (o.id || o.objectId)) || null)\n        .filter(Boolean);\n\n      // Objects without IDs are(normally) unsaved objects\n      // For unsaved objects, the ACL security does not apply, so no need to redo the query.\n      // For saved objects, we need to re-query to ensure proper ACL/CLP enforcement\n      if (ids.length > 0) {\n        const refilterWhere = isGet ? { objectId: ids[0] } : { objectId: { $in: ids } };\n\n        // Re-query with proper security: no triggers to avoid infinite loops\n        const refilterQuery = await RestQuery({\n          method: isGet ? RestQuery.Method.get : RestQuery.Method.find,\n          config,\n          auth,\n          className,\n          restWhere: refilterWhere,\n          restOptions,\n          clientSDK,\n          context,\n          runBeforeFind: false,\n          runAfterFind: false,\n        });\n\n        const refiltered = await refilterQuery.execute();\n        objectsForAfterFind = (refiltered && refiltered.results) || [];\n      }\n    }\n\n    // Run afterFind trigger on security-filtered objects\n    const afterFindProcessedObjects = await triggers.maybeRunAfterFindTrigger(\n      triggers.Types.afterFind,\n      auth,\n      className,\n      objectsForAfterFind,\n      config,\n      new Parse.Query(className).withJSON({ where: restWhere, ...restOptions }),\n      context,\n      isGet\n    );\n\n    return {\n      results: afterFindProcessedObjects,\n    };\n  }\n\n  // Normal path: execute database query with modified conditions\n  const query = await RestQuery({\n    method: isGet ? RestQuery.Method.get : RestQuery.Method.find,\n    config,\n    auth,\n    className,\n    restWhere,\n    restOptions,\n    clientSDK,\n    context,\n    runBeforeFind: false,\n  });\n\n  return query.execute();\n}\n\n// Returns a promise for an object with optional keys 'results' and 'count'.\nconst find = async (config, auth, className, restWhere, restOptions, clientSDK, context) => {\n  enforceRoleSecurity('find', className, auth, config);\n  return runFindTriggers(\n    config,\n    auth,\n    className,\n    restWhere,\n    restOptions,\n    clientSDK,\n    context,\n    { isGet: false }\n  );\n};\n\n// get is just like find but only queries an objectId.\nconst get = async (config, auth, className, objectId, restOptions, clientSDK, context) => {\n  enforceRoleSecurity('get', className, auth, config);\n  return runFindTriggers(\n    config,\n    auth,\n    className,\n    { objectId },\n    restOptions,\n    clientSDK,\n    context,\n    { isGet: true }\n  );\n};\n\n// Returns a promise that doesn't resolve to any useful value.\nfunction del(config, auth, className, objectId, context) {\n  if (typeof objectId !== 'string') {\n    throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');\n  }\n\n  if (className === '_User' && auth.isUnauthenticated()) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');\n  }\n\n  enforceRoleSecurity('delete', className, auth, config);\n\n  let inflatedObject;\n  let schemaController;\n\n  return Promise.resolve()\n    .then(async () => {\n      const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery || className == '_Session') {\n        const query = await RestQuery({\n          method: RestQuery.Method.get,\n          config,\n          auth,\n          className,\n          restWhere: { objectId },\n        });\n        return query.execute({ op: 'delete' }).then(response => {\n          if (response && response.results && response.results.length) {\n            const firstResult = response.results[0];\n            firstResult.className = className;\n            if (className === '_Session' && !auth.isMaster && !auth.isMaintenance) {\n              if (!auth.user || firstResult.user.objectId !== auth.user.id) {\n                throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);\n              }\n            }\n            var cacheAdapter = config.cacheController;\n            cacheAdapter.user.del(firstResult.sessionToken);\n            inflatedObject = Parse.Object.fromJSON(firstResult);\n            return triggers.maybeRunTrigger(\n              triggers.Types.beforeDelete,\n              auth,\n              inflatedObject,\n              null,\n              config,\n              context\n            );\n          }\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(() => {\n      if (!auth.isMaster && !auth.isMaintenance) {\n        return auth.getUserRoles();\n      } else {\n        return;\n      }\n    })\n    .then(() => config.database.loadSchema())\n    .then(s => {\n      schemaController = s;\n      const options = {};\n      if (!auth.isMaster && !auth.isMaintenance) {\n        options.acl = ['*'];\n        if (auth.user) {\n          options.acl.push(auth.user.id);\n          options.acl = options.acl.concat(auth.userRoles);\n        }\n      }\n\n      return config.database.destroy(\n        className,\n        {\n          objectId: objectId,\n        },\n        options,\n        schemaController\n      );\n    })\n    .then(() => {\n      // Notify LiveQuery server if possible\n      const perms = schemaController.getClassLevelPermissions(className);\n      config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);\n      return triggers.maybeRunTrigger(\n        triggers.Types.afterDelete,\n        auth,\n        inflatedObject,\n        null,\n        config,\n        context\n      );\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth, config);\n    });\n}\n\n// Returns a promise for a {response, status, location} object.\nfunction create(config, auth, className, restObject, clientSDK, context) {\n  enforceRoleSecurity('create', className, auth, config);\n  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);\n  return write.execute();\n}\n\n// Returns a promise that contains the fields of the update that the\n// REST API is supposed to return.\n// Usually, this is just updatedAt.\nfunction update(config, auth, className, restWhere, restObject, clientSDK, context) {\n  enforceRoleSecurity('update', className, auth, config);\n\n  return Promise.resolve()\n    .then(async () => {\n      const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery) {\n        // Do not use find, as it runs the before finds\n        const query = await RestQuery({\n          method: RestQuery.Method.get,\n          config,\n          auth,\n          className,\n          restWhere,\n          runAfterFind: false,\n          runBeforeFind: false,\n          context,\n        });\n        return query.execute({\n          op: 'update',\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(({ results }) => {\n      var originalRestObject;\n      if (results && results.length) {\n        originalRestObject = results[0];\n      }\n      return new RestWrite(\n        config,\n        auth,\n        className,\n        restWhere,\n        restObject,\n        originalRestObject,\n        clientSDK,\n        context,\n        'update'\n      ).execute();\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth, config);\n    });\n}\n\nfunction handleSessionMissingError(error, className, auth, config) {\n  // If we're trying to update a user without / with bad session token\n  if (\n    className === '_User' &&\n    error.code === Parse.Error.OBJECT_NOT_FOUND &&\n    !auth.isMaster &&\n    !auth.isMaintenance\n  ) {\n    throw createSanitizedError(Parse.Error.SESSION_MISSING, 'Insufficient auth.', config);\n  }\n  throw error;\n}\n\nmodule.exports = {\n  create,\n  del,\n  find,\n  get,\n  update,\n};\n"],"mappings":"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","ignoreList":[]}