parse-server 8.5.0-alpha.14 → 8.5.0-alpha.16

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.
@@ -473,7 +473,7 @@ function handleParseErrors(err, req, res, next) {
473
473
  }
474
474
  function enforceMasterKeyAccess(req, res, next) {
475
475
  if (!req.auth.isMaster) {
476
- const error = (0, _Error.createSanitizedHttpError)(403, 'unauthorized: master key is required');
476
+ const error = (0, _Error.createSanitizedHttpError)(403, 'unauthorized: master key is required', req.config);
477
477
  res.status(error.status);
478
478
  res.end(`{"error":"${error.message}"}`);
479
479
  return;
@@ -482,7 +482,7 @@ function enforceMasterKeyAccess(req, res, next) {
482
482
  }
483
483
  function promiseEnforceMasterKeyAccess(request) {
484
484
  if (!request.auth.isMaster) {
485
- throw (0, _Error.createSanitizedHttpError)(403, 'unauthorized: master key is required');
485
+ throw (0, _Error.createSanitizedHttpError)(403, 'unauthorized: master key is required', request.config);
486
486
  }
487
487
  return Promise.resolve();
488
488
  }
@@ -669,4 +669,4 @@ function allowDoubleForwardSlash(req, res, next) {
669
669
  req.url = req.url.startsWith('//') ? req.url.substring(1) : req.url;
670
670
  next();
671
671
  }
672
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cache","_interopRequireDefault","require","_node","_Auth","_Config","_ClientSDK","_logger","_rest","_MongoStorageAdapter","_PostgresStorageAdapter","_expressRateLimit","_Definitions","_pathToRegexp","_rateLimitRedis","_redis","_net","_Error","e","__esModule","default","DEFAULT_ALLOWED_HEADERS","exports","getMountForRequest","req","mountPathLength","originalUrl","length","url","mountPath","slice","protocol","get","getBlockList","ipRangeList","store","blockList","BlockList","forEach","fullIp","set","ip","mask","split","addAddress","isIPv4","addSubnet","Number","checkIp","incomingIpIsV4","result","check","includes","handleParseHeaders","res","next","mount","context","JSON","parse","Object","prototype","toString","call","malformedContext","info","appId","sessionToken","masterKey","maintenanceKey","installationId","clientKey","javascriptKey","dotNetKey","restAPIKey","clientVersion","basicAuth","httpAuth","basicAuthAppId","AppCache","body","_noBody","fileViaJSON","Buffer","invalidRequest","_RevocableSession","_ApplicationId","_JavaScriptKey","_ClientVersion","_InstallationId","_SessionToken","_MasterKey","_context","_ContentType","headers","clientSDK","ClientSDK","fromString","fileData","base64","from","clientIp","getClientIp","config","Config","state","status","json","code","Parse","Error","INTERNAL_SERVER_ERROR","error","loadKeys","app","isMaintenance","maintenanceKeyIps","maintenanceKeyIpsStore","auth","Auth","log","loggerController","defaultLogger","loadMasterKey","isMaster","masterKeyIps","masterKeyIpsStore","message","handleRateLimit","isReadOnlyMaster","readOnlyMasterKey","isReadOnly","keys","oneKeyConfigured","some","key","undefined","oneKeyMatches","userFromJWT","user","rateLimits","Promise","all","map","limit","pathExp","RegExp","path","test","handler","err","CONNECTION_FAILED","handleParseSession","requestAuth","indexOf","getAuthForLegacySessionToken","getAuthForSessionToken","UNKNOWN_ERROR","authorization","header","authPrefix","match","toLowerCase","encodedAuth","substring","credentials","decodeBase64","jsKeyPrefix","matchKey","str","allowCrossDomain","allowHeaders","join","baseOrigins","allowOrigin","requestOrigin","origin","allowOrigins","method","sendStatus","allowMethodOverride","_method","originalMethod","handleParseErrors","enableExpressErrorHandler","httpStatus","OBJECT_NOT_FOUND","process","env","TESTING","stack","enforceMasterKeyAccess","createSanitizedHttpError","end","promiseEnforceMasterKeyAccess","request","resolve","addRateLimit","route","cloud","RateLimitOptions","redisStore","connectionPromise","redisUrl","client","createClient","on","isOpen","connect","RedisStore","sendCommand","args","transformPath","requestPath","push","pathToRegexp","rateLimit","windowMs","requestTimeWindow","max","requestCount","errorResponseMessage","response","options","skip","includeInternalRequests","includeMasterKey","requestMethods","Array","isArray","regExp","keyGenerator","zone","Server","RateLimitZone","global","token","session","id","put","promiseEnsureIdempotency","database","adapter","MongoStorageAdapter","PostgresStorageAdapter","requestId","paths","ttl","idempotencyOptions","reqPath","replace","regex","charAt","expiryDate","Date","setSeconds","getSeconds","rest","create","master","reqId","expire","_encode","catch","DUPLICATE_VALUE","DUPLICATE_REQUEST","INVALID_JSON","allowDoubleForwardSlash","startsWith"],"sources":["../src/middlewares.js"],"sourcesContent":["import AppCache from './cache';\nimport Parse from 'parse/node';\nimport auth from './Auth';\nimport Config from './Config';\nimport ClientSDK from './ClientSDK';\nimport defaultLogger from './logger';\nimport rest from './rest';\nimport MongoStorageAdapter from './Adapters/Storage/Mongo/MongoStorageAdapter';\nimport PostgresStorageAdapter from './Adapters/Storage/Postgres/PostgresStorageAdapter';\nimport rateLimit from 'express-rate-limit';\nimport { RateLimitOptions } from './Options/Definitions';\nimport { pathToRegexp } from 'path-to-regexp';\nimport RedisStore from 'rate-limit-redis';\nimport { createClient } from 'redis';\nimport { BlockList, isIPv4 } from 'net';\nimport { createSanitizedHttpError } from './Error';\n\nexport const DEFAULT_ALLOWED_HEADERS =\n  'X-Parse-Master-Key, X-Parse-REST-API-Key, X-Parse-Javascript-Key, X-Parse-Application-Id, X-Parse-Client-Version, X-Parse-Session-Token, X-Requested-With, X-Parse-Revocable-Session, X-Parse-Request-Id, Content-Type, Pragma, Cache-Control';\n\nconst getMountForRequest = function (req) {\n  const mountPathLength = req.originalUrl.length - req.url.length;\n  const mountPath = req.originalUrl.slice(0, mountPathLength);\n  return req.protocol + '://' + req.get('host') + mountPath;\n};\n\nconst getBlockList = (ipRangeList, store) => {\n  if (store.get('blockList')) { return store.get('blockList'); }\n  const blockList = new BlockList();\n  ipRangeList.forEach(fullIp => {\n    if (fullIp === '::/0' || fullIp === '::') {\n      store.set('allowAllIpv6', true);\n      return;\n    }\n    if (fullIp === '0.0.0.0/0' || fullIp === '0.0.0.0') {\n      store.set('allowAllIpv4', true);\n      return;\n    }\n    const [ip, mask] = fullIp.split('/');\n    if (!mask) {\n      blockList.addAddress(ip, isIPv4(ip) ? 'ipv4' : 'ipv6');\n    } else {\n      blockList.addSubnet(ip, Number(mask), isIPv4(ip) ? 'ipv4' : 'ipv6');\n    }\n  });\n  store.set('blockList', blockList);\n  return blockList;\n};\n\nexport const checkIp = (ip, ipRangeList, store) => {\n  const incomingIpIsV4 = isIPv4(ip);\n  const blockList = getBlockList(ipRangeList, store);\n\n  if (store.get(ip)) { return true; }\n  if (store.get('allowAllIpv4') && incomingIpIsV4) { return true; }\n  if (store.get('allowAllIpv6') && !incomingIpIsV4) { return true; }\n  const result = blockList.check(ip, incomingIpIsV4 ? 'ipv4' : 'ipv6');\n\n  // If the ip is in the list, we store the result in the store\n  // so we have a optimized path for the next request\n  if (ipRangeList.includes(ip) && result) {\n    store.set(ip, result);\n  }\n  return result;\n};\n\n// Checks that the request is authorized for this app and checks user\n// auth too.\n// The bodyparser should run before this middleware.\n// Adds info to the request:\n// req.config - the Config for this app\n// req.auth - the Auth for this request\nexport async function handleParseHeaders(req, res, next) {\n  var mount = getMountForRequest(req);\n\n  let context = {};\n  if (req.get('X-Parse-Cloud-Context') != null) {\n    try {\n      context = JSON.parse(req.get('X-Parse-Cloud-Context'));\n      if (Object.prototype.toString.call(context) !== '[object Object]') {\n        throw 'Context is not an object';\n      }\n    } catch {\n      return malformedContext(req, res);\n    }\n  }\n  var info = {\n    appId: req.get('X-Parse-Application-Id'),\n    sessionToken: req.get('X-Parse-Session-Token'),\n    masterKey: req.get('X-Parse-Master-Key'),\n    maintenanceKey: req.get('X-Parse-Maintenance-Key'),\n    installationId: req.get('X-Parse-Installation-Id'),\n    clientKey: req.get('X-Parse-Client-Key'),\n    javascriptKey: req.get('X-Parse-Javascript-Key'),\n    dotNetKey: req.get('X-Parse-Windows-Key'),\n    restAPIKey: req.get('X-Parse-REST-API-Key'),\n    clientVersion: req.get('X-Parse-Client-Version'),\n    context: context,\n  };\n\n  var basicAuth = httpAuth(req);\n\n  if (basicAuth) {\n    var basicAuthAppId = basicAuth.appId;\n    if (AppCache.get(basicAuthAppId)) {\n      info.appId = basicAuthAppId;\n      info.masterKey = basicAuth.masterKey || info.masterKey;\n      info.javascriptKey = basicAuth.javascriptKey || info.javascriptKey;\n    }\n  }\n\n  if (req.body) {\n    // Unity SDK sends a _noBody key which needs to be removed.\n    // Unclear at this point if action needs to be taken.\n    delete req.body._noBody;\n  }\n\n  var fileViaJSON = false;\n\n  if (!info.appId || !AppCache.get(info.appId)) {\n    // See if we can find the app id on the body.\n    if (req.body instanceof Buffer) {\n      // The only chance to find the app id is if this is a file\n      // upload that actually is a JSON body. So try to parse it.\n      // https://github.com/parse-community/parse-server/issues/6589\n      // It is also possible that the client is trying to upload a file but forgot\n      // to provide x-parse-app-id in header and parse a binary file will fail\n      try {\n        req.body = JSON.parse(req.body);\n      } catch {\n        return invalidRequest(req, res);\n      }\n      fileViaJSON = true;\n    }\n\n    if (req.body) {\n      delete req.body._RevocableSession;\n    }\n\n    if (\n      req.body &&\n      req.body._ApplicationId &&\n      AppCache.get(req.body._ApplicationId) &&\n      (!info.masterKey || AppCache.get(req.body._ApplicationId).masterKey === info.masterKey)\n    ) {\n      info.appId = req.body._ApplicationId;\n      info.javascriptKey = req.body._JavaScriptKey || '';\n      delete req.body._ApplicationId;\n      delete req.body._JavaScriptKey;\n      // TODO: test that the REST API formats generated by the other\n      // SDKs are handled ok\n      if (req.body._ClientVersion) {\n        info.clientVersion = req.body._ClientVersion;\n        delete req.body._ClientVersion;\n      }\n      if (req.body._InstallationId) {\n        info.installationId = req.body._InstallationId;\n        delete req.body._InstallationId;\n      }\n      if (req.body._SessionToken) {\n        info.sessionToken = req.body._SessionToken;\n        delete req.body._SessionToken;\n      }\n      if (req.body._MasterKey) {\n        info.masterKey = req.body._MasterKey;\n        delete req.body._MasterKey;\n      }\n      if (req.body._context) {\n        if (req.body._context instanceof Object) {\n          info.context = req.body._context;\n        } else {\n          try {\n            info.context = JSON.parse(req.body._context);\n            if (Object.prototype.toString.call(info.context) !== '[object Object]') {\n              throw 'Context is not an object';\n            }\n          } catch {\n            return malformedContext(req, res);\n          }\n        }\n        delete req.body._context;\n      }\n      if (req.body._ContentType) {\n        req.headers['content-type'] = req.body._ContentType;\n        delete req.body._ContentType;\n      }\n    } else {\n      return invalidRequest(req, res);\n    }\n  }\n\n  if (info.sessionToken && typeof info.sessionToken !== 'string') {\n    info.sessionToken = info.sessionToken.toString();\n  }\n\n  if (info.clientVersion) {\n    info.clientSDK = ClientSDK.fromString(info.clientVersion);\n  }\n\n  if (fileViaJSON && req.body) {\n    req.fileData = req.body.fileData;\n    // We need to repopulate req.body with a buffer\n    var base64 = req.body.base64;\n    req.body = Buffer.from(base64, 'base64');\n  }\n\n  const clientIp = getClientIp(req);\n  const config = Config.get(info.appId, mount);\n  if (config.state && config.state !== 'ok') {\n    res.status(500);\n    res.json({\n      code: Parse.Error.INTERNAL_SERVER_ERROR,\n      error: `Invalid server state: ${config.state}`,\n    });\n    return;\n  }\n  await config.loadKeys();\n\n  info.app = AppCache.get(info.appId);\n  req.config = config;\n  req.config.headers = req.headers || {};\n  req.config.ip = clientIp;\n  req.info = info;\n\n  const isMaintenance =\n    req.config.maintenanceKey && info.maintenanceKey === req.config.maintenanceKey;\n  if (isMaintenance) {\n    if (checkIp(clientIp, req.config.maintenanceKeyIps || [], req.config.maintenanceKeyIpsStore)) {\n      req.auth = new auth.Auth({\n        config: req.config,\n        installationId: info.installationId,\n        isMaintenance: true,\n      });\n      next();\n      return;\n    }\n    const log = req.config?.loggerController || defaultLogger;\n    log.error(\n      `Request using maintenance key rejected as the request IP address '${clientIp}' is not set in Parse Server option 'maintenanceKeyIps'.`\n    );\n  }\n\n  const masterKey = await req.config.loadMasterKey();\n  let isMaster = info.masterKey === masterKey;\n\n  if (isMaster && !checkIp(clientIp, req.config.masterKeyIps || [], req.config.masterKeyIpsStore)) {\n    const log = req.config?.loggerController || defaultLogger;\n    log.error(\n      `Request using master key rejected as the request IP address '${clientIp}' is not set in Parse Server option 'masterKeyIps'.`\n    );\n    isMaster = false;\n    const error = new Error();\n    error.status = 403;\n    error.message = `unauthorized`;\n    throw error;\n  }\n\n  if (isMaster) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: true,\n    });\n    return handleRateLimit(req, res, next);\n  }\n\n  var isReadOnlyMaster = info.masterKey === req.config.readOnlyMasterKey;\n  if (\n    typeof req.config.readOnlyMasterKey != 'undefined' &&\n    req.config.readOnlyMasterKey &&\n    isReadOnlyMaster\n  ) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: true,\n      isReadOnly: true,\n    });\n    return handleRateLimit(req, res, next);\n  }\n\n  // Client keys are not required in parse-server, but if any have been configured in the server, validate them\n  //  to preserve original behavior.\n  const keys = ['clientKey', 'javascriptKey', 'dotNetKey', 'restAPIKey'];\n  const oneKeyConfigured = keys.some(function (key) {\n    return req.config[key] !== undefined;\n  });\n  const oneKeyMatches = keys.some(function (key) {\n    return req.config[key] !== undefined && info[key] === req.config[key];\n  });\n\n  if (oneKeyConfigured && !oneKeyMatches) {\n    return invalidRequest(req, res);\n  }\n\n  if (req.url == '/login') {\n    delete info.sessionToken;\n  }\n\n  if (req.userFromJWT) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: false,\n      user: req.userFromJWT,\n    });\n    return handleRateLimit(req, res, next);\n  }\n\n  if (!info.sessionToken) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: false,\n    });\n  }\n  handleRateLimit(req, res, next);\n}\n\nconst handleRateLimit = async (req, res, next) => {\n  const rateLimits = req.config.rateLimits || [];\n  try {\n    await Promise.all(\n      rateLimits.map(async limit => {\n        const pathExp = new RegExp(limit.path);\n        if (pathExp.test(req.url)) {\n          await limit.handler(req, res, err => {\n            if (err) {\n              if (err.code === Parse.Error.CONNECTION_FAILED) {\n                throw err;\n              }\n              req.config.loggerController.error(\n                'An unknown error occured when attempting to apply the rate limiter: ',\n                err\n              );\n            }\n          });\n        }\n      })\n    );\n  } catch (error) {\n    res.status(429);\n    res.json({ code: Parse.Error.CONNECTION_FAILED, error: error.message });\n    return;\n  }\n  next();\n};\n\nexport const handleParseSession = async (req, res, next) => {\n  try {\n    const info = req.info;\n    if (req.auth || req.url === '/sessions/me') {\n      next();\n      return;\n    }\n    let requestAuth = null;\n    if (\n      info.sessionToken &&\n      req.url === '/upgradeToRevocableSession' &&\n      info.sessionToken.indexOf('r:') != 0\n    ) {\n      requestAuth = await auth.getAuthForLegacySessionToken({\n        config: req.config,\n        installationId: info.installationId,\n        sessionToken: info.sessionToken,\n      });\n    } else {\n      requestAuth = await auth.getAuthForSessionToken({\n        config: req.config,\n        installationId: info.installationId,\n        sessionToken: info.sessionToken,\n      });\n    }\n    req.auth = requestAuth;\n    next();\n  } catch (error) {\n    if (error instanceof Parse.Error) {\n      next(error);\n      return;\n    }\n    // TODO: Determine the correct error scenario.\n    req.config.loggerController.error('error getting auth for sessionToken', error);\n    throw new Parse.Error(Parse.Error.UNKNOWN_ERROR, error);\n  }\n};\n\nfunction getClientIp(req) {\n  return req.ip;\n}\n\nfunction httpAuth(req) {\n  if (!(req.req || req).headers.authorization) { return; }\n\n  var header = (req.req || req).headers.authorization;\n  var appId, masterKey, javascriptKey;\n\n  // parse header\n  var authPrefix = 'basic ';\n\n  var match = header.toLowerCase().indexOf(authPrefix);\n\n  if (match == 0) {\n    var encodedAuth = header.substring(authPrefix.length, header.length);\n    var credentials = decodeBase64(encodedAuth).split(':');\n\n    if (credentials.length == 2) {\n      appId = credentials[0];\n      var key = credentials[1];\n\n      var jsKeyPrefix = 'javascript-key=';\n\n      var matchKey = key.indexOf(jsKeyPrefix);\n      if (matchKey == 0) {\n        javascriptKey = key.substring(jsKeyPrefix.length, key.length);\n      } else {\n        masterKey = key;\n      }\n    }\n  }\n\n  return { appId: appId, masterKey: masterKey, javascriptKey: javascriptKey };\n}\n\nfunction decodeBase64(str) {\n  return Buffer.from(str, 'base64').toString();\n}\n\nexport function allowCrossDomain(appId) {\n  return (req, res, next) => {\n    const config = Config.get(appId, getMountForRequest(req));\n    let allowHeaders = DEFAULT_ALLOWED_HEADERS;\n    if (config && config.allowHeaders) {\n      allowHeaders += `, ${config.allowHeaders.join(', ')}`;\n    }\n\n    const baseOrigins =\n      typeof config?.allowOrigin === 'string' ? [config.allowOrigin] : config?.allowOrigin ?? ['*'];\n    const requestOrigin = req.headers.origin;\n    const allowOrigins =\n      requestOrigin && baseOrigins.includes(requestOrigin) ? requestOrigin : baseOrigins[0];\n    res.header('Access-Control-Allow-Origin', allowOrigins);\n    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');\n    res.header('Access-Control-Allow-Headers', allowHeaders);\n    res.header('Access-Control-Expose-Headers', 'X-Parse-Job-Status-Id, X-Parse-Push-Status-Id');\n    // intercept OPTIONS method\n    if ('OPTIONS' == req.method) {\n      res.sendStatus(200);\n    } else {\n      next();\n    }\n  };\n}\n\nexport function allowMethodOverride(req, res, next) {\n  if (req.method === 'POST' && req.body?._method) {\n    req.originalMethod = req.method;\n    req.method = req.body._method;\n    delete req.body._method;\n  }\n  next();\n}\n\nexport function handleParseErrors(err, req, res, next) {\n  const log = (req.config && req.config.loggerController) || defaultLogger;\n  if (err instanceof Parse.Error) {\n    if (req.config && req.config.enableExpressErrorHandler) {\n      return next(err);\n    }\n    let httpStatus;\n    // TODO: fill out this mapping\n    switch (err.code) {\n      case Parse.Error.INTERNAL_SERVER_ERROR:\n        httpStatus = 500;\n        break;\n      case Parse.Error.OBJECT_NOT_FOUND:\n        httpStatus = 404;\n        break;\n      default:\n        httpStatus = 400;\n    }\n    res.status(httpStatus);\n    res.json({ code: err.code, error: err.message });\n    log.error('Parse error: ', err);\n  } else if (err.status && err.message) {\n    res.status(err.status);\n    res.json({ error: err.message });\n    if (!(process && process.env.TESTING)) {\n      next(err);\n    }\n  } else {\n    log.error('Uncaught internal server error.', err, err.stack);\n    res.status(500);\n    res.json({\n      code: Parse.Error.INTERNAL_SERVER_ERROR,\n      message: 'Internal server error.',\n    });\n    if (!(process && process.env.TESTING)) {\n      next(err);\n    }\n  }\n}\n\nexport function enforceMasterKeyAccess(req, res, next) {\n  if (!req.auth.isMaster) {\n    const error = createSanitizedHttpError(403, 'unauthorized: master key is required');\n    res.status(error.status);\n    res.end(`{\"error\":\"${error.message}\"}`);\n    return;\n  }\n  next();\n}\n\nexport function promiseEnforceMasterKeyAccess(request) {\n  if (!request.auth.isMaster) {\n    throw createSanitizedHttpError(403, 'unauthorized: master key is required');\n  }\n  return Promise.resolve();\n}\n\nexport const addRateLimit = (route, config, cloud) => {\n  if (typeof config === 'string') {\n    config = Config.get(config);\n  }\n  for (const key in route) {\n    if (!RateLimitOptions[key]) {\n      throw `Invalid rate limit option \"${key}\"`;\n    }\n  }\n  if (!config.rateLimits) {\n    config.rateLimits = [];\n  }\n  const redisStore = {\n    connectionPromise: Promise.resolve(),\n    store: null,\n  };\n  if (route.redisUrl) {\n    const log = config?.loggerController || defaultLogger;\n    const client = createClient({\n      url: route.redisUrl,\n    });\n    client.on('error', err => { log.error('Middlewares addRateLimit Redis client error', { error: err }) });\n    client.on('connect', () => { });\n    client.on('reconnecting', () => { });\n    client.on('ready', () => { });\n    redisStore.connectionPromise = async () => {\n      if (client.isOpen) {\n        return;\n      }\n      try {\n        await client.connect();\n      } catch (e) {\n        log.error(`Could not connect to redisURL in rate limit: ${e}`);\n      }\n    };\n    redisStore.connectionPromise();\n    redisStore.store = new RedisStore({\n      sendCommand: async (...args) => {\n        await redisStore.connectionPromise();\n        return client.sendCommand(args);\n      },\n    });\n  }\n  let transformPath = route.requestPath.split('/*').join('/(.*)');\n  if (transformPath === '*') {\n    transformPath = '(.*)';\n  }\n  config.rateLimits.push({\n    path: pathToRegexp(transformPath),\n    handler: rateLimit({\n      windowMs: route.requestTimeWindow,\n      max: route.requestCount,\n      message: route.errorResponseMessage || RateLimitOptions.errorResponseMessage.default,\n      handler: (request, response, next, options) => {\n        throw {\n          code: Parse.Error.CONNECTION_FAILED,\n          message: options.message,\n        };\n      },\n      skip: request => {\n        if (request.ip === '127.0.0.1' && !route.includeInternalRequests) {\n          return true;\n        }\n        if (route.includeMasterKey) {\n          return false;\n        }\n        if (route.requestMethods) {\n          if (Array.isArray(route.requestMethods)) {\n            if (!route.requestMethods.includes(request.method)) {\n              return true;\n            }\n          } else {\n            const regExp = new RegExp(route.requestMethods);\n            if (!regExp.test(request.method)) {\n              return true;\n            }\n          }\n        }\n        return request.auth?.isMaster;\n      },\n      keyGenerator: async request => {\n        if (route.zone === Parse.Server.RateLimitZone.global) {\n          return request.config.appId;\n        }\n        const token = request.info.sessionToken;\n        if (route.zone === Parse.Server.RateLimitZone.session && token) {\n          return token;\n        }\n        if (route.zone === Parse.Server.RateLimitZone.user && token) {\n          if (!request.auth) {\n            await new Promise(resolve => handleParseSession(request, null, resolve));\n          }\n          if (request.auth?.user?.id && request.zone === 'user') {\n            return request.auth.user.id;\n          }\n        }\n        return request.config.ip;\n      },\n      store: redisStore.store,\n    }),\n    cloud,\n  });\n  Config.put(config);\n};\n\n/**\n * Deduplicates a request to ensure idempotency. Duplicates are determined by the request ID\n * in the request header. If a request has no request ID, it is executed anyway.\n * @param {*} req The request to evaluate.\n * @returns Promise<{}>\n */\nexport function promiseEnsureIdempotency(req) {\n  // Enable feature only for MongoDB\n  if (\n    !(\n      req.config.database.adapter instanceof MongoStorageAdapter ||\n      req.config.database.adapter instanceof PostgresStorageAdapter\n    )\n  ) {\n    return Promise.resolve();\n  }\n  // Get parameters\n  const config = req.config;\n  const requestId = ((req || {}).headers || {})['x-parse-request-id'];\n  const { paths, ttl } = config.idempotencyOptions;\n  if (!requestId || !config.idempotencyOptions) {\n    return Promise.resolve();\n  }\n  // Request path may contain trailing slashes, depending on the original request, so remove\n  // leading and trailing slashes to make it easier to specify paths in the configuration\n  const reqPath = req.path.replace(/^\\/|\\/$/, '');\n  // Determine whether idempotency is enabled for current request path\n  let match = false;\n  for (const path of paths) {\n    // Assume one wants a path to always match from the beginning to prevent any mistakes\n    const regex = new RegExp(path.charAt(0) === '^' ? path : '^' + path);\n    if (reqPath.match(regex)) {\n      match = true;\n      break;\n    }\n  }\n  if (!match) {\n    return Promise.resolve();\n  }\n  // Try to store request\n  const expiryDate = new Date(new Date().setSeconds(new Date().getSeconds() + ttl));\n  return rest\n    .create(config, auth.master(config), '_Idempotency', {\n      reqId: requestId,\n      expire: Parse._encode(expiryDate),\n    })\n    .catch(e => {\n      if (e.code == Parse.Error.DUPLICATE_VALUE) {\n        throw new Parse.Error(Parse.Error.DUPLICATE_REQUEST, 'Duplicate request');\n      }\n      throw e;\n    });\n}\n\nfunction invalidRequest(req, res) {\n  res.status(403);\n  res.end('{\"error\":\"unauthorized\"}');\n}\n\nfunction malformedContext(req, res) {\n  res.status(400);\n  res.json({ code: Parse.Error.INVALID_JSON, error: 'Invalid object for context.' });\n}\n\n/**\n * Express 4 allowed a double forward slash between a route and router. Although\n * this should be considered an anti-pattern, we need to support it for backwards\n * compatibility.\n *\n * Technically valid URL with double foroward slash:\n * http://localhost:1337/parse//functions/testFunction\n */\nexport function allowDoubleForwardSlash(req, res, next) {\n  req.url = req.url.startsWith('//') ? req.url.substring(1) : req.url;\n  next();\n}\n"],"mappings":"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","ignoreList":[]}
672
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cache","_interopRequireDefault","require","_node","_Auth","_Config","_ClientSDK","_logger","_rest","_MongoStorageAdapter","_PostgresStorageAdapter","_expressRateLimit","_Definitions","_pathToRegexp","_rateLimitRedis","_redis","_net","_Error","e","__esModule","default","DEFAULT_ALLOWED_HEADERS","exports","getMountForRequest","req","mountPathLength","originalUrl","length","url","mountPath","slice","protocol","get","getBlockList","ipRangeList","store","blockList","BlockList","forEach","fullIp","set","ip","mask","split","addAddress","isIPv4","addSubnet","Number","checkIp","incomingIpIsV4","result","check","includes","handleParseHeaders","res","next","mount","context","JSON","parse","Object","prototype","toString","call","malformedContext","info","appId","sessionToken","masterKey","maintenanceKey","installationId","clientKey","javascriptKey","dotNetKey","restAPIKey","clientVersion","basicAuth","httpAuth","basicAuthAppId","AppCache","body","_noBody","fileViaJSON","Buffer","invalidRequest","_RevocableSession","_ApplicationId","_JavaScriptKey","_ClientVersion","_InstallationId","_SessionToken","_MasterKey","_context","_ContentType","headers","clientSDK","ClientSDK","fromString","fileData","base64","from","clientIp","getClientIp","config","Config","state","status","json","code","Parse","Error","INTERNAL_SERVER_ERROR","error","loadKeys","app","isMaintenance","maintenanceKeyIps","maintenanceKeyIpsStore","auth","Auth","log","loggerController","defaultLogger","loadMasterKey","isMaster","masterKeyIps","masterKeyIpsStore","message","handleRateLimit","isReadOnlyMaster","readOnlyMasterKey","isReadOnly","keys","oneKeyConfigured","some","key","undefined","oneKeyMatches","userFromJWT","user","rateLimits","Promise","all","map","limit","pathExp","RegExp","path","test","handler","err","CONNECTION_FAILED","handleParseSession","requestAuth","indexOf","getAuthForLegacySessionToken","getAuthForSessionToken","UNKNOWN_ERROR","authorization","header","authPrefix","match","toLowerCase","encodedAuth","substring","credentials","decodeBase64","jsKeyPrefix","matchKey","str","allowCrossDomain","allowHeaders","join","baseOrigins","allowOrigin","requestOrigin","origin","allowOrigins","method","sendStatus","allowMethodOverride","_method","originalMethod","handleParseErrors","enableExpressErrorHandler","httpStatus","OBJECT_NOT_FOUND","process","env","TESTING","stack","enforceMasterKeyAccess","createSanitizedHttpError","end","promiseEnforceMasterKeyAccess","request","resolve","addRateLimit","route","cloud","RateLimitOptions","redisStore","connectionPromise","redisUrl","client","createClient","on","isOpen","connect","RedisStore","sendCommand","args","transformPath","requestPath","push","pathToRegexp","rateLimit","windowMs","requestTimeWindow","max","requestCount","errorResponseMessage","response","options","skip","includeInternalRequests","includeMasterKey","requestMethods","Array","isArray","regExp","keyGenerator","zone","Server","RateLimitZone","global","token","session","id","put","promiseEnsureIdempotency","database","adapter","MongoStorageAdapter","PostgresStorageAdapter","requestId","paths","ttl","idempotencyOptions","reqPath","replace","regex","charAt","expiryDate","Date","setSeconds","getSeconds","rest","create","master","reqId","expire","_encode","catch","DUPLICATE_VALUE","DUPLICATE_REQUEST","INVALID_JSON","allowDoubleForwardSlash","startsWith"],"sources":["../src/middlewares.js"],"sourcesContent":["import AppCache from './cache';\nimport Parse from 'parse/node';\nimport auth from './Auth';\nimport Config from './Config';\nimport ClientSDK from './ClientSDK';\nimport defaultLogger from './logger';\nimport rest from './rest';\nimport MongoStorageAdapter from './Adapters/Storage/Mongo/MongoStorageAdapter';\nimport PostgresStorageAdapter from './Adapters/Storage/Postgres/PostgresStorageAdapter';\nimport rateLimit from 'express-rate-limit';\nimport { RateLimitOptions } from './Options/Definitions';\nimport { pathToRegexp } from 'path-to-regexp';\nimport RedisStore from 'rate-limit-redis';\nimport { createClient } from 'redis';\nimport { BlockList, isIPv4 } from 'net';\nimport { createSanitizedHttpError } from './Error';\n\nexport const DEFAULT_ALLOWED_HEADERS =\n  'X-Parse-Master-Key, X-Parse-REST-API-Key, X-Parse-Javascript-Key, X-Parse-Application-Id, X-Parse-Client-Version, X-Parse-Session-Token, X-Requested-With, X-Parse-Revocable-Session, X-Parse-Request-Id, Content-Type, Pragma, Cache-Control';\n\nconst getMountForRequest = function (req) {\n  const mountPathLength = req.originalUrl.length - req.url.length;\n  const mountPath = req.originalUrl.slice(0, mountPathLength);\n  return req.protocol + '://' + req.get('host') + mountPath;\n};\n\nconst getBlockList = (ipRangeList, store) => {\n  if (store.get('blockList')) { return store.get('blockList'); }\n  const blockList = new BlockList();\n  ipRangeList.forEach(fullIp => {\n    if (fullIp === '::/0' || fullIp === '::') {\n      store.set('allowAllIpv6', true);\n      return;\n    }\n    if (fullIp === '0.0.0.0/0' || fullIp === '0.0.0.0') {\n      store.set('allowAllIpv4', true);\n      return;\n    }\n    const [ip, mask] = fullIp.split('/');\n    if (!mask) {\n      blockList.addAddress(ip, isIPv4(ip) ? 'ipv4' : 'ipv6');\n    } else {\n      blockList.addSubnet(ip, Number(mask), isIPv4(ip) ? 'ipv4' : 'ipv6');\n    }\n  });\n  store.set('blockList', blockList);\n  return blockList;\n};\n\nexport const checkIp = (ip, ipRangeList, store) => {\n  const incomingIpIsV4 = isIPv4(ip);\n  const blockList = getBlockList(ipRangeList, store);\n\n  if (store.get(ip)) { return true; }\n  if (store.get('allowAllIpv4') && incomingIpIsV4) { return true; }\n  if (store.get('allowAllIpv6') && !incomingIpIsV4) { return true; }\n  const result = blockList.check(ip, incomingIpIsV4 ? 'ipv4' : 'ipv6');\n\n  // If the ip is in the list, we store the result in the store\n  // so we have a optimized path for the next request\n  if (ipRangeList.includes(ip) && result) {\n    store.set(ip, result);\n  }\n  return result;\n};\n\n// Checks that the request is authorized for this app and checks user\n// auth too.\n// The bodyparser should run before this middleware.\n// Adds info to the request:\n// req.config - the Config for this app\n// req.auth - the Auth for this request\nexport async function handleParseHeaders(req, res, next) {\n  var mount = getMountForRequest(req);\n\n  let context = {};\n  if (req.get('X-Parse-Cloud-Context') != null) {\n    try {\n      context = JSON.parse(req.get('X-Parse-Cloud-Context'));\n      if (Object.prototype.toString.call(context) !== '[object Object]') {\n        throw 'Context is not an object';\n      }\n    } catch {\n      return malformedContext(req, res);\n    }\n  }\n  var info = {\n    appId: req.get('X-Parse-Application-Id'),\n    sessionToken: req.get('X-Parse-Session-Token'),\n    masterKey: req.get('X-Parse-Master-Key'),\n    maintenanceKey: req.get('X-Parse-Maintenance-Key'),\n    installationId: req.get('X-Parse-Installation-Id'),\n    clientKey: req.get('X-Parse-Client-Key'),\n    javascriptKey: req.get('X-Parse-Javascript-Key'),\n    dotNetKey: req.get('X-Parse-Windows-Key'),\n    restAPIKey: req.get('X-Parse-REST-API-Key'),\n    clientVersion: req.get('X-Parse-Client-Version'),\n    context: context,\n  };\n\n  var basicAuth = httpAuth(req);\n\n  if (basicAuth) {\n    var basicAuthAppId = basicAuth.appId;\n    if (AppCache.get(basicAuthAppId)) {\n      info.appId = basicAuthAppId;\n      info.masterKey = basicAuth.masterKey || info.masterKey;\n      info.javascriptKey = basicAuth.javascriptKey || info.javascriptKey;\n    }\n  }\n\n  if (req.body) {\n    // Unity SDK sends a _noBody key which needs to be removed.\n    // Unclear at this point if action needs to be taken.\n    delete req.body._noBody;\n  }\n\n  var fileViaJSON = false;\n\n  if (!info.appId || !AppCache.get(info.appId)) {\n    // See if we can find the app id on the body.\n    if (req.body instanceof Buffer) {\n      // The only chance to find the app id is if this is a file\n      // upload that actually is a JSON body. So try to parse it.\n      // https://github.com/parse-community/parse-server/issues/6589\n      // It is also possible that the client is trying to upload a file but forgot\n      // to provide x-parse-app-id in header and parse a binary file will fail\n      try {\n        req.body = JSON.parse(req.body);\n      } catch {\n        return invalidRequest(req, res);\n      }\n      fileViaJSON = true;\n    }\n\n    if (req.body) {\n      delete req.body._RevocableSession;\n    }\n\n    if (\n      req.body &&\n      req.body._ApplicationId &&\n      AppCache.get(req.body._ApplicationId) &&\n      (!info.masterKey || AppCache.get(req.body._ApplicationId).masterKey === info.masterKey)\n    ) {\n      info.appId = req.body._ApplicationId;\n      info.javascriptKey = req.body._JavaScriptKey || '';\n      delete req.body._ApplicationId;\n      delete req.body._JavaScriptKey;\n      // TODO: test that the REST API formats generated by the other\n      // SDKs are handled ok\n      if (req.body._ClientVersion) {\n        info.clientVersion = req.body._ClientVersion;\n        delete req.body._ClientVersion;\n      }\n      if (req.body._InstallationId) {\n        info.installationId = req.body._InstallationId;\n        delete req.body._InstallationId;\n      }\n      if (req.body._SessionToken) {\n        info.sessionToken = req.body._SessionToken;\n        delete req.body._SessionToken;\n      }\n      if (req.body._MasterKey) {\n        info.masterKey = req.body._MasterKey;\n        delete req.body._MasterKey;\n      }\n      if (req.body._context) {\n        if (req.body._context instanceof Object) {\n          info.context = req.body._context;\n        } else {\n          try {\n            info.context = JSON.parse(req.body._context);\n            if (Object.prototype.toString.call(info.context) !== '[object Object]') {\n              throw 'Context is not an object';\n            }\n          } catch {\n            return malformedContext(req, res);\n          }\n        }\n        delete req.body._context;\n      }\n      if (req.body._ContentType) {\n        req.headers['content-type'] = req.body._ContentType;\n        delete req.body._ContentType;\n      }\n    } else {\n      return invalidRequest(req, res);\n    }\n  }\n\n  if (info.sessionToken && typeof info.sessionToken !== 'string') {\n    info.sessionToken = info.sessionToken.toString();\n  }\n\n  if (info.clientVersion) {\n    info.clientSDK = ClientSDK.fromString(info.clientVersion);\n  }\n\n  if (fileViaJSON && req.body) {\n    req.fileData = req.body.fileData;\n    // We need to repopulate req.body with a buffer\n    var base64 = req.body.base64;\n    req.body = Buffer.from(base64, 'base64');\n  }\n\n  const clientIp = getClientIp(req);\n  const config = Config.get(info.appId, mount);\n  if (config.state && config.state !== 'ok') {\n    res.status(500);\n    res.json({\n      code: Parse.Error.INTERNAL_SERVER_ERROR,\n      error: `Invalid server state: ${config.state}`,\n    });\n    return;\n  }\n  await config.loadKeys();\n\n  info.app = AppCache.get(info.appId);\n  req.config = config;\n  req.config.headers = req.headers || {};\n  req.config.ip = clientIp;\n  req.info = info;\n\n  const isMaintenance =\n    req.config.maintenanceKey && info.maintenanceKey === req.config.maintenanceKey;\n  if (isMaintenance) {\n    if (checkIp(clientIp, req.config.maintenanceKeyIps || [], req.config.maintenanceKeyIpsStore)) {\n      req.auth = new auth.Auth({\n        config: req.config,\n        installationId: info.installationId,\n        isMaintenance: true,\n      });\n      next();\n      return;\n    }\n    const log = req.config?.loggerController || defaultLogger;\n    log.error(\n      `Request using maintenance key rejected as the request IP address '${clientIp}' is not set in Parse Server option 'maintenanceKeyIps'.`\n    );\n  }\n\n  const masterKey = await req.config.loadMasterKey();\n  let isMaster = info.masterKey === masterKey;\n\n  if (isMaster && !checkIp(clientIp, req.config.masterKeyIps || [], req.config.masterKeyIpsStore)) {\n    const log = req.config?.loggerController || defaultLogger;\n    log.error(\n      `Request using master key rejected as the request IP address '${clientIp}' is not set in Parse Server option 'masterKeyIps'.`\n    );\n    isMaster = false;\n    const error = new Error();\n    error.status = 403;\n    error.message = `unauthorized`;\n    throw error;\n  }\n\n  if (isMaster) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: true,\n    });\n    return handleRateLimit(req, res, next);\n  }\n\n  var isReadOnlyMaster = info.masterKey === req.config.readOnlyMasterKey;\n  if (\n    typeof req.config.readOnlyMasterKey != 'undefined' &&\n    req.config.readOnlyMasterKey &&\n    isReadOnlyMaster\n  ) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: true,\n      isReadOnly: true,\n    });\n    return handleRateLimit(req, res, next);\n  }\n\n  // Client keys are not required in parse-server, but if any have been configured in the server, validate them\n  //  to preserve original behavior.\n  const keys = ['clientKey', 'javascriptKey', 'dotNetKey', 'restAPIKey'];\n  const oneKeyConfigured = keys.some(function (key) {\n    return req.config[key] !== undefined;\n  });\n  const oneKeyMatches = keys.some(function (key) {\n    return req.config[key] !== undefined && info[key] === req.config[key];\n  });\n\n  if (oneKeyConfigured && !oneKeyMatches) {\n    return invalidRequest(req, res);\n  }\n\n  if (req.url == '/login') {\n    delete info.sessionToken;\n  }\n\n  if (req.userFromJWT) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: false,\n      user: req.userFromJWT,\n    });\n    return handleRateLimit(req, res, next);\n  }\n\n  if (!info.sessionToken) {\n    req.auth = new auth.Auth({\n      config: req.config,\n      installationId: info.installationId,\n      isMaster: false,\n    });\n  }\n  handleRateLimit(req, res, next);\n}\n\nconst handleRateLimit = async (req, res, next) => {\n  const rateLimits = req.config.rateLimits || [];\n  try {\n    await Promise.all(\n      rateLimits.map(async limit => {\n        const pathExp = new RegExp(limit.path);\n        if (pathExp.test(req.url)) {\n          await limit.handler(req, res, err => {\n            if (err) {\n              if (err.code === Parse.Error.CONNECTION_FAILED) {\n                throw err;\n              }\n              req.config.loggerController.error(\n                'An unknown error occured when attempting to apply the rate limiter: ',\n                err\n              );\n            }\n          });\n        }\n      })\n    );\n  } catch (error) {\n    res.status(429);\n    res.json({ code: Parse.Error.CONNECTION_FAILED, error: error.message });\n    return;\n  }\n  next();\n};\n\nexport const handleParseSession = async (req, res, next) => {\n  try {\n    const info = req.info;\n    if (req.auth || req.url === '/sessions/me') {\n      next();\n      return;\n    }\n    let requestAuth = null;\n    if (\n      info.sessionToken &&\n      req.url === '/upgradeToRevocableSession' &&\n      info.sessionToken.indexOf('r:') != 0\n    ) {\n      requestAuth = await auth.getAuthForLegacySessionToken({\n        config: req.config,\n        installationId: info.installationId,\n        sessionToken: info.sessionToken,\n      });\n    } else {\n      requestAuth = await auth.getAuthForSessionToken({\n        config: req.config,\n        installationId: info.installationId,\n        sessionToken: info.sessionToken,\n      });\n    }\n    req.auth = requestAuth;\n    next();\n  } catch (error) {\n    if (error instanceof Parse.Error) {\n      next(error);\n      return;\n    }\n    // TODO: Determine the correct error scenario.\n    req.config.loggerController.error('error getting auth for sessionToken', error);\n    throw new Parse.Error(Parse.Error.UNKNOWN_ERROR, error);\n  }\n};\n\nfunction getClientIp(req) {\n  return req.ip;\n}\n\nfunction httpAuth(req) {\n  if (!(req.req || req).headers.authorization) { return; }\n\n  var header = (req.req || req).headers.authorization;\n  var appId, masterKey, javascriptKey;\n\n  // parse header\n  var authPrefix = 'basic ';\n\n  var match = header.toLowerCase().indexOf(authPrefix);\n\n  if (match == 0) {\n    var encodedAuth = header.substring(authPrefix.length, header.length);\n    var credentials = decodeBase64(encodedAuth).split(':');\n\n    if (credentials.length == 2) {\n      appId = credentials[0];\n      var key = credentials[1];\n\n      var jsKeyPrefix = 'javascript-key=';\n\n      var matchKey = key.indexOf(jsKeyPrefix);\n      if (matchKey == 0) {\n        javascriptKey = key.substring(jsKeyPrefix.length, key.length);\n      } else {\n        masterKey = key;\n      }\n    }\n  }\n\n  return { appId: appId, masterKey: masterKey, javascriptKey: javascriptKey };\n}\n\nfunction decodeBase64(str) {\n  return Buffer.from(str, 'base64').toString();\n}\n\nexport function allowCrossDomain(appId) {\n  return (req, res, next) => {\n    const config = Config.get(appId, getMountForRequest(req));\n    let allowHeaders = DEFAULT_ALLOWED_HEADERS;\n    if (config && config.allowHeaders) {\n      allowHeaders += `, ${config.allowHeaders.join(', ')}`;\n    }\n\n    const baseOrigins =\n      typeof config?.allowOrigin === 'string' ? [config.allowOrigin] : config?.allowOrigin ?? ['*'];\n    const requestOrigin = req.headers.origin;\n    const allowOrigins =\n      requestOrigin && baseOrigins.includes(requestOrigin) ? requestOrigin : baseOrigins[0];\n    res.header('Access-Control-Allow-Origin', allowOrigins);\n    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');\n    res.header('Access-Control-Allow-Headers', allowHeaders);\n    res.header('Access-Control-Expose-Headers', 'X-Parse-Job-Status-Id, X-Parse-Push-Status-Id');\n    // intercept OPTIONS method\n    if ('OPTIONS' == req.method) {\n      res.sendStatus(200);\n    } else {\n      next();\n    }\n  };\n}\n\nexport function allowMethodOverride(req, res, next) {\n  if (req.method === 'POST' && req.body?._method) {\n    req.originalMethod = req.method;\n    req.method = req.body._method;\n    delete req.body._method;\n  }\n  next();\n}\n\nexport function handleParseErrors(err, req, res, next) {\n  const log = (req.config && req.config.loggerController) || defaultLogger;\n  if (err instanceof Parse.Error) {\n    if (req.config && req.config.enableExpressErrorHandler) {\n      return next(err);\n    }\n    let httpStatus;\n    // TODO: fill out this mapping\n    switch (err.code) {\n      case Parse.Error.INTERNAL_SERVER_ERROR:\n        httpStatus = 500;\n        break;\n      case Parse.Error.OBJECT_NOT_FOUND:\n        httpStatus = 404;\n        break;\n      default:\n        httpStatus = 400;\n    }\n    res.status(httpStatus);\n    res.json({ code: err.code, error: err.message });\n    log.error('Parse error: ', err);\n  } else if (err.status && err.message) {\n    res.status(err.status);\n    res.json({ error: err.message });\n    if (!(process && process.env.TESTING)) {\n      next(err);\n    }\n  } else {\n    log.error('Uncaught internal server error.', err, err.stack);\n    res.status(500);\n    res.json({\n      code: Parse.Error.INTERNAL_SERVER_ERROR,\n      message: 'Internal server error.',\n    });\n    if (!(process && process.env.TESTING)) {\n      next(err);\n    }\n  }\n}\n\nexport function enforceMasterKeyAccess(req, res, next) {\n  if (!req.auth.isMaster) {\n    const error = createSanitizedHttpError(403, 'unauthorized: master key is required', req.config);\n    res.status(error.status);\n    res.end(`{\"error\":\"${error.message}\"}`);\n    return;\n  }\n  next();\n}\n\nexport function promiseEnforceMasterKeyAccess(request) {\n  if (!request.auth.isMaster) {\n    throw createSanitizedHttpError(403, 'unauthorized: master key is required', request.config);\n  }\n  return Promise.resolve();\n}\n\nexport const addRateLimit = (route, config, cloud) => {\n  if (typeof config === 'string') {\n    config = Config.get(config);\n  }\n  for (const key in route) {\n    if (!RateLimitOptions[key]) {\n      throw `Invalid rate limit option \"${key}\"`;\n    }\n  }\n  if (!config.rateLimits) {\n    config.rateLimits = [];\n  }\n  const redisStore = {\n    connectionPromise: Promise.resolve(),\n    store: null,\n  };\n  if (route.redisUrl) {\n    const log = config?.loggerController || defaultLogger;\n    const client = createClient({\n      url: route.redisUrl,\n    });\n    client.on('error', err => { log.error('Middlewares addRateLimit Redis client error', { error: err }) });\n    client.on('connect', () => { });\n    client.on('reconnecting', () => { });\n    client.on('ready', () => { });\n    redisStore.connectionPromise = async () => {\n      if (client.isOpen) {\n        return;\n      }\n      try {\n        await client.connect();\n      } catch (e) {\n        log.error(`Could not connect to redisURL in rate limit: ${e}`);\n      }\n    };\n    redisStore.connectionPromise();\n    redisStore.store = new RedisStore({\n      sendCommand: async (...args) => {\n        await redisStore.connectionPromise();\n        return client.sendCommand(args);\n      },\n    });\n  }\n  let transformPath = route.requestPath.split('/*').join('/(.*)');\n  if (transformPath === '*') {\n    transformPath = '(.*)';\n  }\n  config.rateLimits.push({\n    path: pathToRegexp(transformPath),\n    handler: rateLimit({\n      windowMs: route.requestTimeWindow,\n      max: route.requestCount,\n      message: route.errorResponseMessage || RateLimitOptions.errorResponseMessage.default,\n      handler: (request, response, next, options) => {\n        throw {\n          code: Parse.Error.CONNECTION_FAILED,\n          message: options.message,\n        };\n      },\n      skip: request => {\n        if (request.ip === '127.0.0.1' && !route.includeInternalRequests) {\n          return true;\n        }\n        if (route.includeMasterKey) {\n          return false;\n        }\n        if (route.requestMethods) {\n          if (Array.isArray(route.requestMethods)) {\n            if (!route.requestMethods.includes(request.method)) {\n              return true;\n            }\n          } else {\n            const regExp = new RegExp(route.requestMethods);\n            if (!regExp.test(request.method)) {\n              return true;\n            }\n          }\n        }\n        return request.auth?.isMaster;\n      },\n      keyGenerator: async request => {\n        if (route.zone === Parse.Server.RateLimitZone.global) {\n          return request.config.appId;\n        }\n        const token = request.info.sessionToken;\n        if (route.zone === Parse.Server.RateLimitZone.session && token) {\n          return token;\n        }\n        if (route.zone === Parse.Server.RateLimitZone.user && token) {\n          if (!request.auth) {\n            await new Promise(resolve => handleParseSession(request, null, resolve));\n          }\n          if (request.auth?.user?.id && request.zone === 'user') {\n            return request.auth.user.id;\n          }\n        }\n        return request.config.ip;\n      },\n      store: redisStore.store,\n    }),\n    cloud,\n  });\n  Config.put(config);\n};\n\n/**\n * Deduplicates a request to ensure idempotency. Duplicates are determined by the request ID\n * in the request header. If a request has no request ID, it is executed anyway.\n * @param {*} req The request to evaluate.\n * @returns Promise<{}>\n */\nexport function promiseEnsureIdempotency(req) {\n  // Enable feature only for MongoDB\n  if (\n    !(\n      req.config.database.adapter instanceof MongoStorageAdapter ||\n      req.config.database.adapter instanceof PostgresStorageAdapter\n    )\n  ) {\n    return Promise.resolve();\n  }\n  // Get parameters\n  const config = req.config;\n  const requestId = ((req || {}).headers || {})['x-parse-request-id'];\n  const { paths, ttl } = config.idempotencyOptions;\n  if (!requestId || !config.idempotencyOptions) {\n    return Promise.resolve();\n  }\n  // Request path may contain trailing slashes, depending on the original request, so remove\n  // leading and trailing slashes to make it easier to specify paths in the configuration\n  const reqPath = req.path.replace(/^\\/|\\/$/, '');\n  // Determine whether idempotency is enabled for current request path\n  let match = false;\n  for (const path of paths) {\n    // Assume one wants a path to always match from the beginning to prevent any mistakes\n    const regex = new RegExp(path.charAt(0) === '^' ? path : '^' + path);\n    if (reqPath.match(regex)) {\n      match = true;\n      break;\n    }\n  }\n  if (!match) {\n    return Promise.resolve();\n  }\n  // Try to store request\n  const expiryDate = new Date(new Date().setSeconds(new Date().getSeconds() + ttl));\n  return rest\n    .create(config, auth.master(config), '_Idempotency', {\n      reqId: requestId,\n      expire: Parse._encode(expiryDate),\n    })\n    .catch(e => {\n      if (e.code == Parse.Error.DUPLICATE_VALUE) {\n        throw new Parse.Error(Parse.Error.DUPLICATE_REQUEST, 'Duplicate request');\n      }\n      throw e;\n    });\n}\n\nfunction invalidRequest(req, res) {\n  res.status(403);\n  res.end('{\"error\":\"unauthorized\"}');\n}\n\nfunction malformedContext(req, res) {\n  res.status(400);\n  res.json({ code: Parse.Error.INVALID_JSON, error: 'Invalid object for context.' });\n}\n\n/**\n * Express 4 allowed a double forward slash between a route and router. Although\n * this should be considered an anti-pattern, we need to support it for backwards\n * compatibility.\n *\n * Technically valid URL with double foroward slash:\n * http://localhost:1337/parse//functions/testFunction\n */\nexport function allowDoubleForwardSlash(req, res, next) {\n  req.url = req.url.startsWith('//') ? req.url.substring(1) : req.url;\n  next();\n}\n"],"mappings":"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","ignoreList":[]}
package/lib/rest.js CHANGED
@@ -110,7 +110,7 @@ async function runFindTriggers(config, auth, className, restWhere, restOptions,
110
110
 
111
111
  // Returns a promise for an object with optional keys 'results' and 'count'.
112
112
  const find = async (config, auth, className, restWhere, restOptions, clientSDK, context) => {
113
- enforceRoleSecurity('find', className, auth);
113
+ enforceRoleSecurity('find', className, auth, config);
114
114
  return runFindTriggers(config, auth, className, restWhere, restOptions, clientSDK, context, {
115
115
  isGet: false
116
116
  });
@@ -118,7 +118,7 @@ const find = async (config, auth, className, restWhere, restOptions, clientSDK,
118
118
 
119
119
  // get is just like find but only queries an objectId.
120
120
  const get = async (config, auth, className, objectId, restOptions, clientSDK, context) => {
121
- enforceRoleSecurity('get', className, auth);
121
+ enforceRoleSecurity('get', className, auth, config);
122
122
  return runFindTriggers(config, auth, className, {
123
123
  objectId
124
124
  }, restOptions, clientSDK, context, {
@@ -134,7 +134,7 @@ function del(config, auth, className, objectId, context) {
134
134
  if (className === '_User' && auth.isUnauthenticated()) {
135
135
  throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');
136
136
  }
137
- enforceRoleSecurity('delete', className, auth);
137
+ enforceRoleSecurity('delete', className, auth, config);
138
138
  let inflatedObject;
139
139
  let schemaController;
140
140
  return Promise.resolve().then(async () => {
@@ -158,7 +158,7 @@ function del(config, auth, className, objectId, context) {
158
158
  firstResult.className = className;
159
159
  if (className === '_Session' && !auth.isMaster && !auth.isMaintenance) {
160
160
  if (!auth.user || firstResult.user.objectId !== auth.user.id) {
161
- throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
161
+ throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', config);
162
162
  }
163
163
  }
164
164
  var cacheAdapter = config.cacheController;
@@ -195,13 +195,13 @@ function del(config, auth, className, objectId, context) {
195
195
  config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);
196
196
  return triggers.maybeRunTrigger(triggers.Types.afterDelete, auth, inflatedObject, null, config, context);
197
197
  }).catch(error => {
198
- handleSessionMissingError(error, className, auth);
198
+ handleSessionMissingError(error, className, auth, config);
199
199
  });
200
200
  }
201
201
 
202
202
  // Returns a promise for a {response, status, location} object.
203
203
  function create(config, auth, className, restObject, clientSDK, context) {
204
- enforceRoleSecurity('create', className, auth);
204
+ enforceRoleSecurity('create', className, auth, config);
205
205
  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);
206
206
  return write.execute();
207
207
  }
@@ -210,7 +210,7 @@ function create(config, auth, className, restObject, clientSDK, context) {
210
210
  // REST API is supposed to return.
211
211
  // Usually, this is just updatedAt.
212
212
  function update(config, auth, className, restWhere, restObject, clientSDK, context) {
213
- enforceRoleSecurity('update', className, auth);
213
+ enforceRoleSecurity('update', className, auth, config);
214
214
  return Promise.resolve().then(async () => {
215
215
  const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);
216
216
  const hasLiveQuery = checkLiveQuery(className, config);
@@ -240,13 +240,13 @@ function update(config, auth, className, restWhere, restObject, clientSDK, conte
240
240
  }
241
241
  return new RestWrite(config, auth, className, restWhere, restObject, originalRestObject, clientSDK, context, 'update').execute();
242
242
  }).catch(error => {
243
- handleSessionMissingError(error, className, auth);
243
+ handleSessionMissingError(error, className, auth, config);
244
244
  });
245
245
  }
246
- function handleSessionMissingError(error, className, auth) {
246
+ function handleSessionMissingError(error, className, auth, config) {
247
247
  // If we're trying to update a user without / with bad session token
248
248
  if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster && !auth.isMaintenance) {
249
- throw createSanitizedError(Parse.Error.SESSION_MISSING, 'Insufficient auth.');
249
+ throw createSanitizedError(Parse.Error.SESSION_MISSING, 'Insufficient auth.', config);
250
250
  }
251
251
  throw error;
252
252
  }
@@ -257,4 +257,4 @@ module.exports = {
257
257
  get,
258
258
  update
259
259
  };
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);\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 createSanitizedError(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 createSanitizedError(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":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "8.5.0-alpha.14",
3
+ "version": "8.5.0-alpha.16",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {
@@ -21,7 +21,6 @@
21
21
  "license": "Apache-2.0",
22
22
  "dependencies": {
23
23
  "@apollo/server": "4.12.1",
24
- "@babel/eslint-parser": "7.28.0",
25
24
  "@graphql-tools/merge": "9.0.24",
26
25
  "@graphql-tools/schema": "10.0.23",
27
26
  "@graphql-tools/utils": "10.8.6",
@@ -37,7 +36,6 @@
37
36
  "graphql": "16.11.0",
38
37
  "graphql-list-fields": "2.0.4",
39
38
  "graphql-relay": "0.10.2",
40
- "graphql-tag": "2.12.6",
41
39
  "graphql-upload": "15.0.2",
42
40
  "intersect": "1.0.1",
43
41
  "jsonwebtoken": "9.0.2",
@@ -57,7 +55,6 @@
57
55
  "punycode": "2.3.1",
58
56
  "rate-limit-redis": "4.2.0",
59
57
  "redis": "4.7.0",
60
- "router": "2.2.0",
61
58
  "semver": "7.7.2",
62
59
  "subscriptions-transport-ws": "0.11.0",
63
60
  "tv4": "1.3.0",
@@ -67,6 +64,7 @@
67
64
  "ws": "8.18.2"
68
65
  },
69
66
  "devDependencies": {
67
+ "@babel/eslint-parser": "7.28.0",
70
68
  "@actions/core": "1.11.1",
71
69
  "@apollo/client": "3.13.8",
72
70
  "@babel/cli": "7.27.0",
@@ -90,11 +88,9 @@
90
88
  "eslint": "9.27.0",
91
89
  "eslint-plugin-expect-type": "0.6.2",
92
90
  "eslint-plugin-unused-imports": "4.3.0",
93
- "flow-bin": "0.271.0",
94
91
  "form-data": "4.0.4",
95
92
  "globals": "16.2.0",
96
93
  "graphql-tag": "2.12.6",
97
- "husky": "9.1.7",
98
94
  "jasmine": "5.7.1",
99
95
  "jasmine-spec-reporter": "7.0.0",
100
96
  "jsdoc": "4.0.4",