parse-server 7.5.2 → 7.5.4

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.
@@ -14,29 +14,7 @@ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return
14
14
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
15
15
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
16
16
  const triggers = require('../triggers');
17
- const http = require('http');
18
17
  const Utils = require('../Utils');
19
- const downloadFileFromURI = uri => {
20
- return new Promise((res, rej) => {
21
- http.get(uri, response => {
22
- response.setDefaultEncoding('base64');
23
- let body = `data:${response.headers['content-type']};base64,`;
24
- response.on('data', data => body += data);
25
- response.on('end', () => res(body));
26
- }).on('error', e => {
27
- rej(`Error downloading file from ${uri}: ${e.message}`);
28
- });
29
- });
30
- };
31
- const addFileDataIfNeeded = async file => {
32
- if (file._source.format === 'uri') {
33
- const base64 = await downloadFileFromURI(file._source.uri);
34
- file._previousSave = file;
35
- file._data = base64;
36
- file._requestTask = null;
37
- }
38
- return file;
39
- };
40
18
  class FilesRouter {
41
19
  expressRouter({
42
20
  maxUploadSize = '20Mb'
@@ -191,8 +169,6 @@ class FilesRouter {
191
169
  }
192
170
  // if the file returned by the trigger has already been saved skip saving anything
193
171
  if (!saveResult) {
194
- // if the ParseFile returned is type uri, download the file before saving it
195
- await addFileDataIfNeeded(fileObject.file);
196
172
  // update fileSize
197
173
  const bufferData = Buffer.from(fileObject.file._data, 'base64');
198
174
  fileObject.fileSize = Buffer.byteLength(bufferData);
@@ -289,4 +265,4 @@ function isFileStreamable(req, filesController) {
289
265
  const end = Number(range[1]);
290
266
  return (!isNaN(start) || !isNaN(end)) && typeof filesController.adapter.handleFileStream === 'function';
291
267
  }
292
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_express","_interopRequireDefault","require","_bodyParser","Middlewares","_interopRequireWildcard","_node","_Config","_logger","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","triggers","http","Utils","downloadFileFromURI","uri","Promise","res","rej","response","setDefaultEncoding","body","headers","on","data","message","addFileDataIfNeeded","file","_source","format","base64","_previousSave","_data","_requestTask","FilesRouter","expressRouter","maxUploadSize","router","express","Router","getHandler","metadataHandler","post","req","next","Parse","Error","INVALID_FILE_NAME","BodyParser","raw","type","limit","handleParseHeaders","handleParseSession","createHandler","delete","enforceMasterKeyAccess","deleteHandler","config","Config","params","appId","status","err","OPERATION_FORBIDDEN","json","code","error","filesController","filename","mime","contentType","getType","isFileStreamable","handleFileStream","catch","end","getFileData","then","length","_config$fileUpload","user","auth","isMaster","isLinked","AnonymousUtils","fileUpload","enableForAnonymousUser","FILE_SAVE_ERROR","enableForAuthenticatedUser","enableForPublic","validateFilename","fileExtensions","_extension","isValidExtension","extension","some","ext","regex","RegExp","test","includes","substring","lastIndexOf","split","join","toString","File","metadata","tags","fileData","checkProhibitedKeywords","INVALID_KEY_NAME","setTags","setMetadata","fileSize","Buffer","byteLength","fileObject","triggerResult","maybeRunFileTrigger","Types","beforeSave","saveResult","url","name","_name","bufferData","from","fileOptions","_metadata","fileTags","keys","_tags","assign","createFileResult","createFile","_url","resolve","afterSave","logger","resolveError","adapter","getFileLocation","beforeDelete","deleteFile","afterDelete","FILE_DELETE_ERROR","getMetadata","exports","range","start","Number","isNaN"],"sources":["../../src/Routers/FilesRouter.js"],"sourcesContent":["import express from 'express';\nimport BodyParser from 'body-parser';\nimport * as Middlewares from '../middlewares';\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport logger from '../logger';\nconst triggers = require('../triggers');\nconst http = require('http');\nconst Utils = require('../Utils');\n\nconst downloadFileFromURI = uri => {\n  return new Promise((res, rej) => {\n    http\n      .get(uri, response => {\n        response.setDefaultEncoding('base64');\n        let body = `data:${response.headers['content-type']};base64,`;\n        response.on('data', data => (body += data));\n        response.on('end', () => res(body));\n      })\n      .on('error', e => {\n        rej(`Error downloading file from ${uri}: ${e.message}`);\n      });\n  });\n};\n\nconst addFileDataIfNeeded = async file => {\n  if (file._source.format === 'uri') {\n    const base64 = await downloadFileFromURI(file._source.uri);\n    file._previousSave = file;\n    file._data = base64;\n    file._requestTask = null;\n  }\n  return file;\n};\n\nexport class FilesRouter {\n  expressRouter({ maxUploadSize = '20Mb' } = {}) {\n    var router = express.Router();\n    router.get('/files/:appId/:filename', this.getHandler);\n    router.get('/files/:appId/metadata/:filename', this.metadataHandler);\n\n    router.post('/files', function (req, res, next) {\n      next(new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Filename not provided.'));\n    });\n\n    router.post(\n      '/files/:filename',\n      BodyParser.raw({\n        type: () => {\n          return true;\n        },\n        limit: maxUploadSize,\n      }), // Allow uploads without Content-Type, or with any Content-Type.\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      this.createHandler\n    );\n\n    router.delete(\n      '/files/:filename',\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      Middlewares.enforceMasterKeyAccess,\n      this.deleteHandler\n    );\n    return router;\n  }\n\n  async getHandler(req, res) {\n    const config = Config.get(req.params.appId);\n    if (!config) {\n      res.status(403);\n      const err = new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'Invalid application ID.');\n      res.json({ code: err.code, error: err.message });\n      return;\n    }\n    const filesController = config.filesController;\n    const filename = req.params.filename;\n    const mime = (await import('mime')).default;\n    const contentType = mime.getType(filename);\n    if (isFileStreamable(req, filesController)) {\n      filesController.handleFileStream(config, filename, req, res, contentType).catch(() => {\n        res.status(404);\n        res.set('Content-Type', 'text/plain');\n        res.end('File not found.');\n      });\n    } else {\n      filesController\n        .getFileData(config, filename)\n        .then(data => {\n          res.status(200);\n          res.set('Content-Type', contentType);\n          res.set('Content-Length', data.length);\n          res.end(data);\n        })\n        .catch(() => {\n          res.status(404);\n          res.set('Content-Type', 'text/plain');\n          res.end('File not found.');\n        });\n    }\n  }\n\n  async createHandler(req, res, next) {\n    const config = req.config;\n    const user = req.auth.user;\n    const isMaster = req.auth.isMaster;\n    const isLinked = user && Parse.AnonymousUtils.isLinked(user);\n    if (!isMaster && !config.fileUpload.enableForAnonymousUser && isLinked) {\n      next(\n        new Parse.Error(Parse.Error.FILE_SAVE_ERROR, 'File upload by anonymous user is disabled.')\n      );\n      return;\n    }\n    if (!isMaster && !config.fileUpload.enableForAuthenticatedUser && !isLinked && user) {\n      next(\n        new Parse.Error(\n          Parse.Error.FILE_SAVE_ERROR,\n          'File upload by authenticated user is disabled.'\n        )\n      );\n      return;\n    }\n    if (!isMaster && !config.fileUpload.enableForPublic && !user) {\n      next(new Parse.Error(Parse.Error.FILE_SAVE_ERROR, 'File upload by public is disabled.'));\n      return;\n    }\n    const filesController = config.filesController;\n    const { filename } = req.params;\n    const contentType = req.get('Content-type');\n\n    if (!req.body || !req.body.length) {\n      next(new Parse.Error(Parse.Error.FILE_SAVE_ERROR, 'Invalid file upload.'));\n      return;\n    }\n\n    const error = filesController.validateFilename(filename);\n    if (error) {\n      next(error);\n      return;\n    }\n\n    const fileExtensions = config.fileUpload?.fileExtensions;\n    if (!isMaster && fileExtensions) {\n      const isValidExtension = extension => {\n        return fileExtensions.some(ext => {\n          if (ext === '*') {\n            return true;\n          }\n          const regex = new RegExp(ext);\n          if (regex.test(extension)) {\n            return true;\n          }\n        });\n      };\n      let extension = contentType;\n      if (filename && filename.includes('.')) {\n        extension = filename.substring(filename.lastIndexOf('.') + 1);\n      } else if (contentType && contentType.includes('/')) {\n        extension = contentType.split('/')[1];\n      }\n      extension = extension?.split(' ')?.join('');\n\n      if (extension && !isValidExtension(extension)) {\n        next(\n          new Parse.Error(\n            Parse.Error.FILE_SAVE_ERROR,\n            `File upload of extension ${extension} is disabled.`\n          )\n        );\n        return;\n      }\n    }\n\n    const base64 = req.body.toString('base64');\n    const file = new Parse.File(filename, { base64 }, contentType);\n    const { metadata = {}, tags = {} } = req.fileData || {};\n    try {\n      // Scan request data for denied keywords\n      Utils.checkProhibitedKeywords(config, metadata);\n      Utils.checkProhibitedKeywords(config, tags);\n    } catch (error) {\n      next(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n      return;\n    }\n    file.setTags(tags);\n    file.setMetadata(metadata);\n    const fileSize = Buffer.byteLength(req.body);\n    const fileObject = { file, fileSize };\n    try {\n      // run beforeSaveFile trigger\n      const triggerResult = await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeSave,\n        fileObject,\n        config,\n        req.auth\n      );\n      let saveResult;\n      // if a new ParseFile is returned check if it's an already saved file\n      if (triggerResult instanceof Parse.File) {\n        fileObject.file = triggerResult;\n        if (triggerResult.url()) {\n          // set fileSize to null because we wont know how big it is here\n          fileObject.fileSize = null;\n          saveResult = {\n            url: triggerResult.url(),\n            name: triggerResult._name,\n          };\n        }\n      }\n      // if the file returned by the trigger has already been saved skip saving anything\n      if (!saveResult) {\n        // if the ParseFile returned is type uri, download the file before saving it\n        await addFileDataIfNeeded(fileObject.file);\n        // update fileSize\n        const bufferData = Buffer.from(fileObject.file._data, 'base64');\n        fileObject.fileSize = Buffer.byteLength(bufferData);\n        // prepare file options\n        const fileOptions = {\n          metadata: fileObject.file._metadata,\n        };\n        // some s3-compatible providers (DigitalOcean, Linode) do not accept tags\n        // so we do not include the tags option if it is empty.\n        const fileTags =\n          Object.keys(fileObject.file._tags).length > 0 ? { tags: fileObject.file._tags } : {};\n        Object.assign(fileOptions, fileTags);\n        // save file\n        const createFileResult = await filesController.createFile(\n          config,\n          fileObject.file._name,\n          bufferData,\n          fileObject.file._source.type,\n          fileOptions\n        );\n        // update file with new data\n        fileObject.file._name = createFileResult.name;\n        fileObject.file._url = createFileResult.url;\n        fileObject.file._requestTask = null;\n        fileObject.file._previousSave = Promise.resolve(fileObject.file);\n        saveResult = {\n          url: createFileResult.url,\n          name: createFileResult.name,\n        };\n      }\n      // run afterSaveFile trigger\n      await triggers.maybeRunFileTrigger(triggers.Types.afterSave, fileObject, config, req.auth);\n      res.status(201);\n      res.set('Location', saveResult.url);\n      res.json(saveResult);\n    } catch (e) {\n      logger.error('Error creating a file: ', e);\n      const error = triggers.resolveError(e, {\n        code: Parse.Error.FILE_SAVE_ERROR,\n        message: `Could not store file: ${fileObject.file._name}.`,\n      });\n      next(error);\n    }\n  }\n\n  async deleteHandler(req, res, next) {\n    try {\n      const { filesController } = req.config;\n      const { filename } = req.params;\n      // run beforeDeleteFile trigger\n      const file = new Parse.File(filename);\n      file._url = await filesController.adapter.getFileLocation(req.config, filename);\n      const fileObject = { file, fileSize: null };\n      await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeDelete,\n        fileObject,\n        req.config,\n        req.auth\n      );\n      // delete file\n      await filesController.deleteFile(req.config, filename);\n      // run afterDeleteFile trigger\n      await triggers.maybeRunFileTrigger(\n        triggers.Types.afterDelete,\n        fileObject,\n        req.config,\n        req.auth\n      );\n      res.status(200);\n      // TODO: return useful JSON here?\n      res.end();\n    } catch (e) {\n      logger.error('Error deleting a file: ', e);\n      const error = triggers.resolveError(e, {\n        code: Parse.Error.FILE_DELETE_ERROR,\n        message: 'Could not delete file.',\n      });\n      next(error);\n    }\n  }\n\n  async metadataHandler(req, res) {\n    try {\n      const config = Config.get(req.params.appId);\n      const { filesController } = config;\n      const { filename } = req.params;\n      const data = await filesController.getMetadata(filename);\n      res.status(200);\n      res.json(data);\n    } catch (e) {\n      res.status(200);\n      res.json({});\n    }\n  }\n}\n\nfunction isFileStreamable(req, filesController) {\n  const range = (req.get('Range') || '/-/').split('-');\n  const start = Number(range[0]);\n  const end = Number(range[1]);\n  return (\n    (!isNaN(start) || !isNaN(end)) && typeof filesController.adapter.handleFileStream === 'function'\n  );\n}\n"],"mappings":"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","ignoreList":[]}
268
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_express","_interopRequireDefault","require","_bodyParser","Middlewares","_interopRequireWildcard","_node","_Config","_logger","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","triggers","Utils","FilesRouter","expressRouter","maxUploadSize","router","express","Router","getHandler","metadataHandler","post","req","res","next","Parse","Error","INVALID_FILE_NAME","BodyParser","raw","type","limit","handleParseHeaders","handleParseSession","createHandler","delete","enforceMasterKeyAccess","deleteHandler","config","Config","params","appId","status","err","OPERATION_FORBIDDEN","json","code","error","message","filesController","filename","mime","contentType","getType","isFileStreamable","handleFileStream","catch","end","getFileData","then","data","length","_config$fileUpload","user","auth","isMaster","isLinked","AnonymousUtils","fileUpload","enableForAnonymousUser","FILE_SAVE_ERROR","enableForAuthenticatedUser","enableForPublic","body","validateFilename","fileExtensions","_extension","isValidExtension","extension","some","ext","regex","RegExp","test","includes","substring","lastIndexOf","split","join","base64","toString","file","File","metadata","tags","fileData","checkProhibitedKeywords","INVALID_KEY_NAME","setTags","setMetadata","fileSize","Buffer","byteLength","fileObject","triggerResult","maybeRunFileTrigger","Types","beforeSave","saveResult","url","name","_name","bufferData","from","_data","fileOptions","_metadata","fileTags","keys","_tags","assign","createFileResult","createFile","_source","_url","_requestTask","_previousSave","Promise","resolve","afterSave","logger","resolveError","adapter","getFileLocation","beforeDelete","deleteFile","afterDelete","FILE_DELETE_ERROR","getMetadata","exports","range","start","Number","isNaN"],"sources":["../../src/Routers/FilesRouter.js"],"sourcesContent":["import express from 'express';\nimport BodyParser from 'body-parser';\nimport * as Middlewares from '../middlewares';\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport logger from '../logger';\nconst triggers = require('../triggers');\nconst Utils = require('../Utils');\n\nexport class FilesRouter {\n  expressRouter({ maxUploadSize = '20Mb' } = {}) {\n    var router = express.Router();\n    router.get('/files/:appId/:filename', this.getHandler);\n    router.get('/files/:appId/metadata/:filename', this.metadataHandler);\n\n    router.post('/files', function (req, res, next) {\n      next(new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Filename not provided.'));\n    });\n\n    router.post(\n      '/files/:filename',\n      BodyParser.raw({\n        type: () => {\n          return true;\n        },\n        limit: maxUploadSize,\n      }), // Allow uploads without Content-Type, or with any Content-Type.\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      this.createHandler\n    );\n\n    router.delete(\n      '/files/:filename',\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      Middlewares.enforceMasterKeyAccess,\n      this.deleteHandler\n    );\n    return router;\n  }\n\n  async getHandler(req, res) {\n    const config = Config.get(req.params.appId);\n    if (!config) {\n      res.status(403);\n      const err = new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'Invalid application ID.');\n      res.json({ code: err.code, error: err.message });\n      return;\n    }\n    const filesController = config.filesController;\n    const filename = req.params.filename;\n    const mime = (await import('mime')).default;\n    const contentType = mime.getType(filename);\n    if (isFileStreamable(req, filesController)) {\n      filesController.handleFileStream(config, filename, req, res, contentType).catch(() => {\n        res.status(404);\n        res.set('Content-Type', 'text/plain');\n        res.end('File not found.');\n      });\n    } else {\n      filesController\n        .getFileData(config, filename)\n        .then(data => {\n          res.status(200);\n          res.set('Content-Type', contentType);\n          res.set('Content-Length', data.length);\n          res.end(data);\n        })\n        .catch(() => {\n          res.status(404);\n          res.set('Content-Type', 'text/plain');\n          res.end('File not found.');\n        });\n    }\n  }\n\n  async createHandler(req, res, next) {\n    const config = req.config;\n    const user = req.auth.user;\n    const isMaster = req.auth.isMaster;\n    const isLinked = user && Parse.AnonymousUtils.isLinked(user);\n    if (!isMaster && !config.fileUpload.enableForAnonymousUser && isLinked) {\n      next(\n        new Parse.Error(Parse.Error.FILE_SAVE_ERROR, 'File upload by anonymous user is disabled.')\n      );\n      return;\n    }\n    if (!isMaster && !config.fileUpload.enableForAuthenticatedUser && !isLinked && user) {\n      next(\n        new Parse.Error(\n          Parse.Error.FILE_SAVE_ERROR,\n          'File upload by authenticated user is disabled.'\n        )\n      );\n      return;\n    }\n    if (!isMaster && !config.fileUpload.enableForPublic && !user) {\n      next(new Parse.Error(Parse.Error.FILE_SAVE_ERROR, 'File upload by public is disabled.'));\n      return;\n    }\n    const filesController = config.filesController;\n    const { filename } = req.params;\n    const contentType = req.get('Content-type');\n\n    if (!req.body || !req.body.length) {\n      next(new Parse.Error(Parse.Error.FILE_SAVE_ERROR, 'Invalid file upload.'));\n      return;\n    }\n\n    const error = filesController.validateFilename(filename);\n    if (error) {\n      next(error);\n      return;\n    }\n\n    const fileExtensions = config.fileUpload?.fileExtensions;\n    if (!isMaster && fileExtensions) {\n      const isValidExtension = extension => {\n        return fileExtensions.some(ext => {\n          if (ext === '*') {\n            return true;\n          }\n          const regex = new RegExp(ext);\n          if (regex.test(extension)) {\n            return true;\n          }\n        });\n      };\n      let extension = contentType;\n      if (filename && filename.includes('.')) {\n        extension = filename.substring(filename.lastIndexOf('.') + 1);\n      } else if (contentType && contentType.includes('/')) {\n        extension = contentType.split('/')[1];\n      }\n      extension = extension?.split(' ')?.join('');\n\n      if (extension && !isValidExtension(extension)) {\n        next(\n          new Parse.Error(\n            Parse.Error.FILE_SAVE_ERROR,\n            `File upload of extension ${extension} is disabled.`\n          )\n        );\n        return;\n      }\n    }\n\n    const base64 = req.body.toString('base64');\n    const file = new Parse.File(filename, { base64 }, contentType);\n    const { metadata = {}, tags = {} } = req.fileData || {};\n    try {\n      // Scan request data for denied keywords\n      Utils.checkProhibitedKeywords(config, metadata);\n      Utils.checkProhibitedKeywords(config, tags);\n    } catch (error) {\n      next(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n      return;\n    }\n    file.setTags(tags);\n    file.setMetadata(metadata);\n    const fileSize = Buffer.byteLength(req.body);\n    const fileObject = { file, fileSize };\n    try {\n      // run beforeSaveFile trigger\n      const triggerResult = await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeSave,\n        fileObject,\n        config,\n        req.auth\n      );\n      let saveResult;\n      // if a new ParseFile is returned check if it's an already saved file\n      if (triggerResult instanceof Parse.File) {\n        fileObject.file = triggerResult;\n        if (triggerResult.url()) {\n          // set fileSize to null because we wont know how big it is here\n          fileObject.fileSize = null;\n          saveResult = {\n            url: triggerResult.url(),\n            name: triggerResult._name,\n          };\n        }\n      }\n      // if the file returned by the trigger has already been saved skip saving anything\n      if (!saveResult) {\n        // update fileSize\n        const bufferData = Buffer.from(fileObject.file._data, 'base64');\n        fileObject.fileSize = Buffer.byteLength(bufferData);\n        // prepare file options\n        const fileOptions = {\n          metadata: fileObject.file._metadata,\n        };\n        // some s3-compatible providers (DigitalOcean, Linode) do not accept tags\n        // so we do not include the tags option if it is empty.\n        const fileTags =\n          Object.keys(fileObject.file._tags).length > 0 ? { tags: fileObject.file._tags } : {};\n        Object.assign(fileOptions, fileTags);\n        // save file\n        const createFileResult = await filesController.createFile(\n          config,\n          fileObject.file._name,\n          bufferData,\n          fileObject.file._source.type,\n          fileOptions\n        );\n        // update file with new data\n        fileObject.file._name = createFileResult.name;\n        fileObject.file._url = createFileResult.url;\n        fileObject.file._requestTask = null;\n        fileObject.file._previousSave = Promise.resolve(fileObject.file);\n        saveResult = {\n          url: createFileResult.url,\n          name: createFileResult.name,\n        };\n      }\n      // run afterSaveFile trigger\n      await triggers.maybeRunFileTrigger(triggers.Types.afterSave, fileObject, config, req.auth);\n      res.status(201);\n      res.set('Location', saveResult.url);\n      res.json(saveResult);\n    } catch (e) {\n      logger.error('Error creating a file: ', e);\n      const error = triggers.resolveError(e, {\n        code: Parse.Error.FILE_SAVE_ERROR,\n        message: `Could not store file: ${fileObject.file._name}.`,\n      });\n      next(error);\n    }\n  }\n\n  async deleteHandler(req, res, next) {\n    try {\n      const { filesController } = req.config;\n      const { filename } = req.params;\n      // run beforeDeleteFile trigger\n      const file = new Parse.File(filename);\n      file._url = await filesController.adapter.getFileLocation(req.config, filename);\n      const fileObject = { file, fileSize: null };\n      await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeDelete,\n        fileObject,\n        req.config,\n        req.auth\n      );\n      // delete file\n      await filesController.deleteFile(req.config, filename);\n      // run afterDeleteFile trigger\n      await triggers.maybeRunFileTrigger(\n        triggers.Types.afterDelete,\n        fileObject,\n        req.config,\n        req.auth\n      );\n      res.status(200);\n      // TODO: return useful JSON here?\n      res.end();\n    } catch (e) {\n      logger.error('Error deleting a file: ', e);\n      const error = triggers.resolveError(e, {\n        code: Parse.Error.FILE_DELETE_ERROR,\n        message: 'Could not delete file.',\n      });\n      next(error);\n    }\n  }\n\n  async metadataHandler(req, res) {\n    try {\n      const config = Config.get(req.params.appId);\n      const { filesController } = config;\n      const { filename } = req.params;\n      const data = await filesController.getMetadata(filename);\n      res.status(200);\n      res.json(data);\n    } catch (e) {\n      res.status(200);\n      res.json({});\n    }\n  }\n}\n\nfunction isFileStreamable(req, filesController) {\n  const range = (req.get('Range') || '/-/').split('-');\n  const start = Number(range[0]);\n  const end = Number(range[1]);\n  return (\n    (!isNaN(start) || !isNaN(end)) && typeof filesController.adapter.handleFileStream === 'function'\n  );\n}\n"],"mappings":"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","ignoreList":[]}
@@ -71,8 +71,17 @@ class CheckGroupServerConfig extends _CheckGroup.default {
71
71
  throw 1;
72
72
  }
73
73
  }
74
+ }), new _Check.Check({
75
+ title: 'GraphQL public introspection disabled',
76
+ warning: 'GraphQL public introspection is enabled, which allows anyone to access the GraphQL schema.',
77
+ solution: "Change Parse Server configuration to 'graphQLPublicIntrospection: false'. You will need to use master key or maintenance key to access the GraphQL schema.",
78
+ check: () => {
79
+ if (config.graphQLPublicIntrospection !== false) {
80
+ throw 1;
81
+ }
82
+ }
74
83
  })];
75
84
  }
76
85
  }
77
86
  module.exports = CheckGroupServerConfig;
78
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfQ2hlY2siLCJyZXF1aXJlIiwiX0NoZWNrR3JvdXAiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX0NvbmZpZyIsIl9ub2RlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiQ2hlY2tHcm91cFNlcnZlckNvbmZpZyIsIkNoZWNrR3JvdXAiLCJzZXROYW1lIiwic2V0Q2hlY2tzIiwiY29uZmlnIiwiQ29uZmlnIiwiZ2V0IiwiUGFyc2UiLCJhcHBsaWNhdGlvbklkIiwiQ2hlY2siLCJ0aXRsZSIsIndhcm5pbmciLCJzb2x1dGlvbiIsImNoZWNrIiwibWFzdGVyS2V5IiwiaGFzVXBwZXJDYXNlIiwidGVzdCIsImhhc0xvd2VyQ2FzZSIsImhhc051bWJlcnMiLCJoYXNOb25BbHBoYXNOdW1lcmljcyIsImxlbmd0aCIsInNlY3VyaXR5IiwiZW5hYmxlQ2hlY2tMb2ciLCJhbGxvd0NsaWVudENsYXNzQ3JlYXRpb24iLCJlbmZvcmNlUHJpdmF0ZVVzZXJzIiwiZW5hYmxlSW5zZWN1cmVBdXRoQWRhcHRlcnMiLCJtb2R1bGUiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL1NlY3VyaXR5L0NoZWNrR3JvdXBzL0NoZWNrR3JvdXBTZXJ2ZXJDb25maWcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hlY2sgfSBmcm9tICcuLi9DaGVjayc7XG5pbXBvcnQgQ2hlY2tHcm91cCBmcm9tICcuLi9DaGVja0dyb3VwJztcbmltcG9ydCBDb25maWcgZnJvbSAnLi4vLi4vQ29uZmlnJztcbmltcG9ydCBQYXJzZSBmcm9tICdwYXJzZS9ub2RlJztcblxuLyoqXG4gKiBUaGUgc2VjdXJpdHkgY2hlY2tzIGdyb3VwIGZvciBQYXJzZSBTZXJ2ZXIgY29uZmlndXJhdGlvbi5cbiAqIENoZWNrcyBjb21tb24gUGFyc2UgU2VydmVyIHBhcmFtZXRlcnMgc3VjaCBhcyBhY2Nlc3Mga2V5cy5cbiAqIEBtZW1iZXJvZiBtb2R1bGU6U2VjdXJpdHlDaGVja1xuICovXG5jbGFzcyBDaGVja0dyb3VwU2VydmVyQ29uZmlnIGV4dGVuZHMgQ2hlY2tHcm91cCB7XG4gIHNldE5hbWUoKSB7XG4gICAgcmV0dXJuICdQYXJzZSBTZXJ2ZXIgQ29uZmlndXJhdGlvbic7XG4gIH1cbiAgc2V0Q2hlY2tzKCkge1xuICAgIGNvbnN0IGNvbmZpZyA9IENvbmZpZy5nZXQoUGFyc2UuYXBwbGljYXRpb25JZCk7XG4gICAgcmV0dXJuIFtcbiAgICAgIG5ldyBDaGVjayh7XG4gICAgICAgIHRpdGxlOiAnU2VjdXJlIG1hc3RlciBrZXknLFxuICAgICAgICB3YXJuaW5nOiAnVGhlIFBhcnNlIFNlcnZlciBtYXN0ZXIga2V5IGlzIGluc2VjdXJlIGFuZCB2dWxuZXJhYmxlIHRvIGJydXRlIGZvcmNlIGF0dGFja3MuJyxcbiAgICAgICAgc29sdXRpb246XG4gICAgICAgICAgJ0Nob29zZSBhIGxvbmdlciBhbmQvb3IgbW9yZSBjb21wbGV4IG1hc3RlciBrZXkgd2l0aCBhIGNvbWJpbmF0aW9uIG9mIHVwcGVyLSBhbmQgbG93ZXJjYXNlIGNoYXJhY3RlcnMsIG51bWJlcnMgYW5kIHNwZWNpYWwgY2hhcmFjdGVycy4nLFxuICAgICAgICBjaGVjazogKCkgPT4ge1xuICAgICAgICAgIGNvbnN0IG1hc3RlcktleSA9IGNvbmZpZy5tYXN0ZXJLZXk7XG4gICAgICAgICAgY29uc3QgaGFzVXBwZXJDYXNlID0gL1tBLVpdLy50ZXN0KG1hc3RlcktleSk7XG4gICAgICAgICAgY29uc3QgaGFzTG93ZXJDYXNlID0gL1thLXpdLy50ZXN0KG1hc3RlcktleSk7XG4gICAgICAgICAgY29uc3QgaGFzTnVtYmVycyA9IC9cXGQvLnRlc3QobWFzdGVyS2V5KTtcbiAgICAgICAgICBjb25zdCBoYXNOb25BbHBoYXNOdW1lcmljcyA9IC9cXFcvLnRlc3QobWFzdGVyS2V5KTtcbiAgICAgICAgICAvLyBFbnN1cmUgbGVuZ3RoXG4gICAgICAgICAgaWYgKG1hc3RlcktleS5sZW5ndGggPCAxNCkge1xuICAgICAgICAgICAgdGhyb3cgMTtcbiAgICAgICAgICB9XG4gICAgICAgICAgLy8gRW5zdXJlIGF0IGxlYXN0IDMgb3V0IG9mIDQgcmVxdWlyZW1lbnRzIHBhc3NlZFxuICAgICAgICAgIGlmIChoYXNVcHBlckNhc2UgKyBoYXNMb3dlckNhc2UgKyBoYXNOdW1iZXJzICsgaGFzTm9uQWxwaGFzTnVtZXJpY3MgPCAzKSB7XG4gICAgICAgICAgICB0aHJvdyAxO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgICAgbmV3IENoZWNrKHtcbiAgICAgICAgdGl0bGU6ICdTZWN1cml0eSBsb2cgZGlzYWJsZWQnLFxuICAgICAgICB3YXJuaW5nOlxuICAgICAgICAgICdTZWN1cml0eSBjaGVja3MgaW4gbG9ncyBtYXkgZXhwb3NlIHZ1bG5lcmFiaWxpdGllcyB0byBhbnlvbmUgd2l0aCBhY2Nlc3MgdG8gbG9ncy4nLFxuICAgICAgICBzb2x1dGlvbjogXCJDaGFuZ2UgUGFyc2UgU2VydmVyIGNvbmZpZ3VyYXRpb24gdG8gJ3NlY3VyaXR5LmVuYWJsZUNoZWNrTG9nOiBmYWxzZScuXCIsXG4gICAgICAgIGNoZWNrOiAoKSA9PiB7XG4gICAgICAgICAgaWYgKGNvbmZpZy5zZWN1cml0eSAmJiBjb25maWcuc2VjdXJpdHkuZW5hYmxlQ2hlY2tMb2cpIHtcbiAgICAgICAgICAgIHRocm93IDE7XG4gICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgfSksXG4gICAgICBuZXcgQ2hlY2soe1xuICAgICAgICB0aXRsZTogJ0NsaWVudCBjbGFzcyBjcmVhdGlvbiBkaXNhYmxlZCcsXG4gICAgICAgIHdhcm5pbmc6XG4gICAgICAgICAgJ0F0dGFja2VycyBhcmUgYWxsb3dlZCB0byBjcmVhdGUgbmV3IGNsYXNzZXMgd2l0aG91dCByZXN0cmljdGlvbiBhbmQgZmxvb2QgdGhlIGRhdGFiYXNlLicsXG4gICAgICAgIHNvbHV0aW9uOiBcIkNoYW5nZSBQYXJzZSBTZXJ2ZXIgY29uZmlndXJhdGlvbiB0byAnYWxsb3dDbGllbnRDbGFzc0NyZWF0aW9uOiBmYWxzZScuXCIsXG4gICAgICAgIGNoZWNrOiAoKSA9PiB7XG4gICAgICAgICAgaWYgKGNvbmZpZy5hbGxvd0NsaWVudENsYXNzQ3JlYXRpb24gfHwgY29uZmlnLmFsbG93Q2xpZW50Q2xhc3NDcmVhdGlvbiA9PSBudWxsKSB7XG4gICAgICAgICAgICB0aHJvdyAxO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgICAgbmV3IENoZWNrKHtcbiAgICAgICAgdGl0bGU6ICdVc2VycyBhcmUgY3JlYXRlZCB3aXRob3V0IHB1YmxpYyBhY2Nlc3MnLFxuICAgICAgICB3YXJuaW5nOlxuICAgICAgICAgICdVc2VycyB3aXRoIHB1YmxpYyByZWFkIGFjY2VzcyBhcmUgZXhwb3NlZCB0byBhbnlvbmUgd2hvIGtub3dzIHRoZWlyIG9iamVjdCBJRHMsIG9yIHRvIGFueW9uZSB3aG8gY2FuIHF1ZXJ5IHRoZSBQYXJzZS5Vc2VyIGNsYXNzLicsXG4gICAgICAgIHNvbHV0aW9uOiBcIkNoYW5nZSBQYXJzZSBTZXJ2ZXIgY29uZmlndXJhdGlvbiB0byAnZW5mb3JjZVByaXZhdGVVc2VyczogdHJ1ZScuXCIsXG4gICAgICAgIGNoZWNrOiAoKSA9PiB7XG4gICAgICAgICAgaWYgKCFjb25maWcuZW5mb3JjZVByaXZhdGVVc2Vycykge1xuICAgICAgICAgICAgdGhyb3cgMTtcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgICAgIG5ldyBDaGVjayh7XG4gICAgICAgIHRpdGxlOiAnSW5zZWN1cmUgYXV0aCBhZGFwdGVycyBkaXNhYmxlZCcsXG4gICAgICAgIHdhcm5pbmc6XG4gICAgICAgICAgXCJBdHRhY2tlcnMgbWF5IGV4cGxvcmUgaW5zZWN1cmUgYXV0aCBhZGFwdGVycycgdnVsbmVyYWJpbGl0aWVzIGFuZCBsb2cgaW4gb24gYmVoYWxmIG9mIGFub3RoZXIgdXNlci5cIixcbiAgICAgICAgc29sdXRpb246IFwiQ2hhbmdlIFBhcnNlIFNlcnZlciBjb25maWd1cmF0aW9uIHRvICdlbmFibGVJbnNlY3VyZUF1dGhBZGFwdGVyczogZmFsc2UnLlwiLFxuICAgICAgICBjaGVjazogKCkgPT4ge1xuICAgICAgICAgIGlmIChjb25maWcuZW5hYmxlSW5zZWN1cmVBdXRoQWRhcHRlcnMgIT09IGZhbHNlKSB7XG4gICAgICAgICAgICB0aHJvdyAxO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgIF07XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBDaGVja0dyb3VwU2VydmVyQ29uZmlnO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLFdBQUEsR0FBQUMsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFHLE9BQUEsR0FBQUQsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFJLEtBQUEsR0FBQUYsc0JBQUEsQ0FBQUYsT0FBQTtBQUErQixTQUFBRSx1QkFBQUcsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUUvQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTUcsc0JBQXNCLFNBQVNDLG1CQUFVLENBQUM7RUFDOUNDLE9BQU9BLENBQUEsRUFBRztJQUNSLE9BQU8sNEJBQTRCO0VBQ3JDO0VBQ0FDLFNBQVNBLENBQUEsRUFBRztJQUNWLE1BQU1DLE1BQU0sR0FBR0MsZUFBTSxDQUFDQyxHQUFHLENBQUNDLGFBQUssQ0FBQ0MsYUFBYSxDQUFDO0lBQzlDLE9BQU8sQ0FDTCxJQUFJQyxZQUFLLENBQUM7TUFDUkMsS0FBSyxFQUFFLG1CQUFtQjtNQUMxQkMsT0FBTyxFQUFFLGdGQUFnRjtNQUN6RkMsUUFBUSxFQUNOLHVJQUF1STtNQUN6SUMsS0FBSyxFQUFFQSxDQUFBLEtBQU07UUFDWCxNQUFNQyxTQUFTLEdBQUdWLE1BQU0sQ0FBQ1UsU0FBUztRQUNsQyxNQUFNQyxZQUFZLEdBQUcsT0FBTyxDQUFDQyxJQUFJLENBQUNGLFNBQVMsQ0FBQztRQUM1QyxNQUFNRyxZQUFZLEdBQUcsT0FBTyxDQUFDRCxJQUFJLENBQUNGLFNBQVMsQ0FBQztRQUM1QyxNQUFNSSxVQUFVLEdBQUcsSUFBSSxDQUFDRixJQUFJLENBQUNGLFNBQVMsQ0FBQztRQUN2QyxNQUFNSyxvQkFBb0IsR0FBRyxJQUFJLENBQUNILElBQUksQ0FBQ0YsU0FBUyxDQUFDO1FBQ2pEO1FBQ0EsSUFBSUEsU0FBUyxDQUFDTSxNQUFNLEdBQUcsRUFBRSxFQUFFO1VBQ3pCLE1BQU0sQ0FBQztRQUNUO1FBQ0E7UUFDQSxJQUFJTCxZQUFZLEdBQUdFLFlBQVksR0FBR0MsVUFBVSxHQUFHQyxvQkFBb0IsR0FBRyxDQUFDLEVBQUU7VUFDdkUsTUFBTSxDQUFDO1FBQ1Q7TUFDRjtJQUNGLENBQUMsQ0FBQyxFQUNGLElBQUlWLFlBQUssQ0FBQztNQUNSQyxLQUFLLEVBQUUsdUJBQXVCO01BQzlCQyxPQUFPLEVBQ0wsbUZBQW1GO01BQ3JGQyxRQUFRLEVBQUUsd0VBQXdFO01BQ2xGQyxLQUFLLEVBQUVBLENBQUEsS0FBTTtRQUNYLElBQUlULE1BQU0sQ0FBQ2lCLFFBQVEsSUFBSWpCLE1BQU0sQ0FBQ2lCLFFBQVEsQ0FBQ0MsY0FBYyxFQUFFO1VBQ3JELE1BQU0sQ0FBQztRQUNUO01BQ0Y7SUFDRixDQUFDLENBQUMsRUFDRixJQUFJYixZQUFLLENBQUM7TUFDUkMsS0FBSyxFQUFFLGdDQUFnQztNQUN2Q0MsT0FBTyxFQUNMLHlGQUF5RjtNQUMzRkMsUUFBUSxFQUFFLHlFQUF5RTtNQUNuRkMsS0FBSyxFQUFFQSxDQUFBLEtBQU07UUFDWCxJQUFJVCxNQUFNLENBQUNtQix3QkFBd0IsSUFBSW5CLE1BQU0sQ0FBQ21CLHdCQUF3QixJQUFJLElBQUksRUFBRTtVQUM5RSxNQUFNLENBQUM7UUFDVDtNQUNGO0lBQ0YsQ0FBQyxDQUFDLEVBQ0YsSUFBSWQsWUFBSyxDQUFDO01BQ1JDLEtBQUssRUFBRSx5Q0FBeUM7TUFDaERDLE9BQU8sRUFDTCxrSUFBa0k7TUFDcElDLFFBQVEsRUFBRSxtRUFBbUU7TUFDN0VDLEtBQUssRUFBRUEsQ0FBQSxLQUFNO1FBQ1gsSUFBSSxDQUFDVCxNQUFNLENBQUNvQixtQkFBbUIsRUFBRTtVQUMvQixNQUFNLENBQUM7UUFDVDtNQUNGO0lBQ0YsQ0FBQyxDQUFDLEVBQ0YsSUFBSWYsWUFBSyxDQUFDO01BQ1JDLEtBQUssRUFBRSxpQ0FBaUM7TUFDeENDLE9BQU8sRUFDTCxxR0FBcUc7TUFDdkdDLFFBQVEsRUFBRSwyRUFBMkU7TUFDckZDLEtBQUssRUFBRUEsQ0FBQSxLQUFNO1FBQ1gsSUFBSVQsTUFBTSxDQUFDcUIsMEJBQTBCLEtBQUssS0FBSyxFQUFFO1VBQy9DLE1BQU0sQ0FBQztRQUNUO01BQ0Y7SUFDRixDQUFDLENBQUMsQ0FDSDtFQUNIO0FBQ0Y7QUFFQUMsTUFBTSxDQUFDQyxPQUFPLEdBQUczQixzQkFBc0IiLCJpZ25vcmVMaXN0IjpbXX0=
87
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_Check","require","_CheckGroup","_interopRequireDefault","_Config","_node","e","__esModule","default","CheckGroupServerConfig","CheckGroup","setName","setChecks","config","Config","get","Parse","applicationId","Check","title","warning","solution","check","masterKey","hasUpperCase","test","hasLowerCase","hasNumbers","hasNonAlphasNumerics","length","security","enableCheckLog","allowClientClassCreation","enforcePrivateUsers","enableInsecureAuthAdapters","graphQLPublicIntrospection","module","exports"],"sources":["../../../src/Security/CheckGroups/CheckGroupServerConfig.js"],"sourcesContent":["import { Check } from '../Check';\nimport CheckGroup from '../CheckGroup';\nimport Config from '../../Config';\nimport Parse from 'parse/node';\n\n/**\n * The security checks group for Parse Server configuration.\n * Checks common Parse Server parameters such as access keys.\n * @memberof module:SecurityCheck\n */\nclass CheckGroupServerConfig extends CheckGroup {\n  setName() {\n    return 'Parse Server Configuration';\n  }\n  setChecks() {\n    const config = Config.get(Parse.applicationId);\n    return [\n      new Check({\n        title: 'Secure master key',\n        warning: 'The Parse Server master key is insecure and vulnerable to brute force attacks.',\n        solution:\n          'Choose a longer and/or more complex master key with a combination of upper- and lowercase characters, numbers and special characters.',\n        check: () => {\n          const masterKey = config.masterKey;\n          const hasUpperCase = /[A-Z]/.test(masterKey);\n          const hasLowerCase = /[a-z]/.test(masterKey);\n          const hasNumbers = /\\d/.test(masterKey);\n          const hasNonAlphasNumerics = /\\W/.test(masterKey);\n          // Ensure length\n          if (masterKey.length < 14) {\n            throw 1;\n          }\n          // Ensure at least 3 out of 4 requirements passed\n          if (hasUpperCase + hasLowerCase + hasNumbers + hasNonAlphasNumerics < 3) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Security log disabled',\n        warning:\n          'Security checks in logs may expose vulnerabilities to anyone with access to logs.',\n        solution: \"Change Parse Server configuration to 'security.enableCheckLog: false'.\",\n        check: () => {\n          if (config.security && config.security.enableCheckLog) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Client class creation disabled',\n        warning:\n          'Attackers are allowed to create new classes without restriction and flood the database.',\n        solution: \"Change Parse Server configuration to 'allowClientClassCreation: false'.\",\n        check: () => {\n          if (config.allowClientClassCreation || config.allowClientClassCreation == null) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Users are created without public access',\n        warning:\n          'Users with public read access are exposed to anyone who knows their object IDs, or to anyone who can query the Parse.User class.',\n        solution: \"Change Parse Server configuration to 'enforcePrivateUsers: true'.\",\n        check: () => {\n          if (!config.enforcePrivateUsers) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'Insecure auth adapters disabled',\n        warning:\n          \"Attackers may explore insecure auth adapters' vulnerabilities and log in on behalf of another user.\",\n        solution: \"Change Parse Server configuration to 'enableInsecureAuthAdapters: false'.\",\n        check: () => {\n          if (config.enableInsecureAuthAdapters !== false) {\n            throw 1;\n          }\n        },\n      }),\n      new Check({\n        title: 'GraphQL public introspection disabled',\n        warning: 'GraphQL public introspection is enabled, which allows anyone to access the GraphQL schema.',\n        solution: \"Change Parse Server configuration to 'graphQLPublicIntrospection: false'. You will need to use master key or maintenance key to access the GraphQL schema.\",\n        check: () => {\n          if (config.graphQLPublicIntrospection !== false) {\n            throw 1;\n          }\n        },\n      }),\n    ];\n  }\n}\n\nmodule.exports = CheckGroupServerConfig;\n"],"mappings":"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","ignoreList":[]}
@@ -659,4 +659,4 @@ function malformedContext(req, res) {
659
659
  error: 'Invalid object for context.'
660
660
  });
661
661
  }
662
- //# 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","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","app","isMaintenance","_req$config","maintenanceKeyIps","maintenanceKeyIpsStore","auth","Auth","log","loggerController","defaultLogger","isMaster","masterKeyIps","masterKeyIpsStore","_req$config2","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","end","promiseEnforceMasterKeyAccess","request","resolve","addRateLimit","route","cloud","RateLimitOptions","redisStore","connectionPromise","redisUrl","_config","client","createClient","on","isOpen","connect","RedisStore","sendCommand","args","transformPath","requestPath","push","pathToRegexp","rateLimit","windowMs","requestTimeWindow","max","requestCount","errorResponseMessage","response","options","skip","_request$auth","includeInternalRequests","includeMasterKey","requestMethods","Array","isArray","regExp","keyGenerator","zone","Server","RateLimitZone","global","token","session","_request$auth2","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"],"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';\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 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 (e) {\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 (e) {\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 (e) {\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) {\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\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  let isMaster = info.masterKey === req.config.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    res.status(403);\n    res.end('{\"error\":\"unauthorized: master key is required\"}');\n    return;\n  }\n  next();\n}\n\nexport function promiseEnforceMasterKeyAccess(request) {\n  if (!request.auth.isMaster) {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized: master key is required';\n    throw error;\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"],"mappings":"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","ignoreList":[]}
662
+ //# 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","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","app","isMaintenance","_req$config","maintenanceKeyIps","maintenanceKeyIpsStore","auth","Auth","log","loggerController","defaultLogger","isMaster","masterKeyIps","masterKeyIpsStore","_req$config2","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","end","promiseEnforceMasterKeyAccess","request","resolve","addRateLimit","route","cloud","RateLimitOptions","redisStore","connectionPromise","redisUrl","_config","client","createClient","on","isOpen","connect","RedisStore","sendCommand","args","transformPath","requestPath","push","pathToRegexp","rateLimit","windowMs","requestTimeWindow","max","requestCount","errorResponseMessage","response","options","skip","_request$auth","includeInternalRequests","includeMasterKey","requestMethods","Array","isArray","regExp","keyGenerator","zone","Server","RateLimitZone","global","token","session","_request$auth2","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"],"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';\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 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 (e) {\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 (e) {\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 (e) {\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) {\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\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  let isMaster = info.masterKey === req.config.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    res.status(403);\n    res.end('{\"error\":\"unauthorized: master key is required\"}');\n    return;\n  }\n  next();\n}\n\nexport function promiseEnforceMasterKeyAccess(request) {\n  if (!request.auth.isMaster) {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized: master key is required';\n    throw error;\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"],"mappings":"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","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "7.5.2",
3
+ "version": "7.5.4",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {
@@ -19,8 +19,8 @@
19
19
  ],
20
20
  "license": "Apache-2.0",
21
21
  "dependencies": {
22
- "@apollo/server": "4.11.2",
23
- "@babel/eslint-parser": "7.26.5",
22
+ "@apollo/server": "4.12.1",
23
+ "@babel/eslint-parser": "7.27.5",
24
24
  "@graphql-tools/merge": "9.0.17",
25
25
  "@graphql-tools/schema": "10.0.18",
26
26
  "@graphql-tools/utils": "10.6.3",
@@ -34,7 +34,7 @@
34
34
  "express": "4.21.2",
35
35
  "express-rate-limit": "7.4.1",
36
36
  "follow-redirects": "1.15.9",
37
- "graphql": "16.10.0",
37
+ "graphql": "16.11.0",
38
38
  "graphql-list-fields": "2.0.4",
39
39
  "graphql-relay": "0.10.2",
40
40
  "graphql-tag": "2.12.6",
@@ -46,24 +46,24 @@
46
46
  "lodash": "4.17.21",
47
47
  "lru-cache": "10.4.0",
48
48
  "mime": "4.0.6",
49
- "mongodb": "6.13.0",
49
+ "mongodb": "6.16.0",
50
50
  "mustache": "4.2.0",
51
51
  "otpauth": "9.3.5",
52
52
  "parse": "5.3.0",
53
53
  "path-to-regexp": "6.3.0",
54
54
  "pg-monitor": "2.1.0",
55
- "pg-promise": "11.10.2",
55
+ "pg-promise": "11.14.0",
56
56
  "pluralize": "8.0.0",
57
57
  "punycode": "2.3.1",
58
58
  "rate-limit-redis": "4.2.0",
59
59
  "redis": "4.7.0",
60
- "semver": "7.7.1",
60
+ "semver": "7.7.2",
61
61
  "subscriptions-transport-ws": "0.11.0",
62
62
  "tv4": "1.3.0",
63
63
  "uuid": "11.0.3",
64
64
  "winston": "3.17.0",
65
65
  "winston-daily-rotate-file": "5.0.0",
66
- "ws": "8.18.0"
66
+ "ws": "8.18.1"
67
67
  },
68
68
  "devDependencies": {
69
69
  "@actions/core": "1.11.1",