parse-server 9.5.0-alpha.2 → 9.5.0-alpha.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.
|
@@ -268,6 +268,12 @@ class FilesRouter {
|
|
|
268
268
|
};
|
|
269
269
|
}
|
|
270
270
|
async createHandler(req, res, next) {
|
|
271
|
+
if (req.auth.isReadOnly) {
|
|
272
|
+
const error = (0, _Error.createSanitizedHttpError)(403, "read-only masterKey isn't allowed to create a file.", req.config);
|
|
273
|
+
res.status(error.status);
|
|
274
|
+
res.end(`{"error":"${error.message}"}`);
|
|
275
|
+
return;
|
|
276
|
+
}
|
|
271
277
|
const config = req.config;
|
|
272
278
|
const user = req.auth.user;
|
|
273
279
|
const isMaster = req.auth.isMaster;
|
|
@@ -605,6 +611,12 @@ class FilesRouter {
|
|
|
605
611
|
}
|
|
606
612
|
}
|
|
607
613
|
async deleteHandler(req, res, next) {
|
|
614
|
+
if (req.auth.isReadOnly) {
|
|
615
|
+
const error = (0, _Error.createSanitizedHttpError)(403, "read-only masterKey isn't allowed to delete a file.", req.config);
|
|
616
|
+
res.status(error.status);
|
|
617
|
+
res.end(`{"error":"${error.message}"}`);
|
|
618
|
+
return;
|
|
619
|
+
}
|
|
608
620
|
try {
|
|
609
621
|
const {
|
|
610
622
|
filesController
|
|
@@ -657,4 +669,4 @@ function isFileStreamable(req, filesController) {
|
|
|
657
669
|
const end = Number(range[1]);
|
|
658
670
|
return (!isNaN(start) || !isNaN(end)) && typeof filesController.adapter.handleFileStream === 'function';
|
|
659
671
|
}
|
|
660
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_express","_interopRequireDefault","require","Middlewares","_interopRequireWildcard","_node","_Config","_logger","_stream","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","triggers","Utils","createSizeLimitedStream","source","maxBytes","totalBytes","started","sourceEnded","onData","onEnd","onError","output","Readable","read","chunk","length","destroy","Parse","Error","FILE_SAVE_ERROR","push","pause","err","on","resume","callback","removeListener","RESERVED_DIRECTORY_SEGMENTS","exports","FilesRouter","expressRouter","maxUploadSize","router","express","Router","metadataHandler","getHandler","post","req","res","next","INVALID_FILE_NAME","_earlyHeadersMiddleware","_bodyParsingMiddleware","handleParseHeaders","handleParseSession","createHandler","bind","delete","enforceMasterKeyAccess","deleteHandler","_getFilenameFromParams","parts","params","filepath","Array","isArray","join","validateDirectory","directory","includes","startsWith","endsWith","firstSegment","split","dirRegex","test","config","Config","appId","error","createSanitizedHttpError","status","json","message","filename","filesController","mime","contentType","getType","file","File","base64","triggerResult","maybeRunFileTrigger","Types","beforeFind","auth","_name","isFileStreamable","handleFileStream","catch","end","data","getFileData","toString","afterFind","forceDownload","Buffer","from","_data","resolveError","code","SCRIPT_FAILED","maxUploadSizeOverride","undefined","masterKey","loadMasterKey","masterKeyIps","checkIp","ip","masterKeyIpsStore","parsedBytes","parseSizeToBytes","_maxUploadSizeOverride","defaultMaxBytes","_maxUploadSizeBytes","limit","raw","type","user","isMaster","isLinked","AnonymousUtils","fileUpload","enableForAnonymousUser","enableForAuthenticatedUser","enableForPublic","validateFilename","fileExtensions","isValidExtension","extension","some","ext","regex","RegExp","substring","lastIndexOf","fileData","parsed","JSON","parse","metadata","INVALID_JSON","tags","OPERATION_FORBIDDEN","directoryError","body","_handleBufferedUpload","_handleStreamUpload","checkProhibitedKeywords","INVALID_KEY_NAME","setTags","setMetadata","setDirectory","fileSize","byteLength","fileObject","beforeSave","saveResult","url","name","bufferData","_source","format","buffer","fileOptions","_metadata","fileTags","keys","_tags","assign","_directory","createFileResult","createFile","_url","_requestTask","_previousSave","Promise","resolve","afterSave","logger","stream","contentLength","parseInt","hasExtension","sourceType","adapter","getFileLocation","beforeDelete","deleteFile","afterDelete","FILE_DELETE_ERROR","getMetadata","range","start","Number","isNaN"],"sources":["../../src/Routers/FilesRouter.js"],"sourcesContent":["import express from 'express';\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');\nimport { Readable } from 'stream';\nimport { createSanitizedHttpError } from '../Error';\n\n/**\n * Wraps a readable stream in a Readable that enforces a byte size limit.\n * Data flow is lazy: the source is not read until a consumer starts reading\n * from the returned stream (via pipe or 'data' listener). This ensures the\n * consumer's error listener is attached before any data (or error) is emitted.\n */\nexport function createSizeLimitedStream(source, maxBytes) {\n  let totalBytes = 0;\n  let started = false;\n  let sourceEnded = false;\n  let onData, onEnd, onError;\n\n  const output = new Readable({\n    read() {\n      if (!started) {\n        started = true;\n\n        onData = (chunk) => {\n          totalBytes += chunk.length;\n          if (totalBytes > maxBytes) {\n            output.destroy(\n              new Parse.Error(\n                Parse.Error.FILE_SAVE_ERROR,\n                `File size exceeds maximum allowed: ${maxBytes} bytes.`\n              )\n            );\n            return;\n          }\n          if (!output.push(chunk)) {\n            source.pause();\n          }\n        };\n\n        onEnd = () => {\n          sourceEnded = true;\n          output.push(null);\n        };\n\n        onError = (err) => output.destroy(err);\n\n        source.on('data', onData);\n        source.on('end', onEnd);\n        source.on('error', onError);\n      }\n\n      // Resume source in case it was paused due to backpressure\n      if (!sourceEnded) {\n        source.resume();\n      }\n    },\n    destroy(err, callback) {\n      if (onData) {\n        source.removeListener('data', onData);\n      }\n      if (onEnd) {\n        source.removeListener('end', onEnd);\n      }\n      if (onError) {\n        source.removeListener('error', onError);\n      }\n      // Suppress errors emitted during drain (e.g. client disconnect)\n      source.on('error', () => {});\n      if (!sourceEnded) {\n        source.resume();\n      }\n      callback(err);\n    }\n  });\n\n  return output;\n}\n\n// Segments that conflict with sub-routes under GET /files/:appId/*. If a file\n// directory starts with one of these, its URL would match the wrong route\n// handler. Update this list when adding new sub-routes to expressRouter().\nexport const RESERVED_DIRECTORY_SEGMENTS = ['metadata'];\n\nexport class FilesRouter {\n  expressRouter({ maxUploadSize = '20Mb' } = {}) {\n    var router = express.Router();\n    // Metadata route must come before the catch-all GET route\n    router.get('/files/:appId/metadata/*filepath', this.metadataHandler);\n    router.get('/files/:appId/*filepath', this.getHandler);\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      this._earlyHeadersMiddleware(),\n      this._bodyParsingMiddleware(maxUploadSize),\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      this.createHandler.bind(this)\n    );\n\n    router.delete(\n      '/files/*filepath',\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      Middlewares.enforceMasterKeyAccess,\n      this.deleteHandler\n    );\n    return router;\n  }\n\n  static _getFilenameFromParams(req) {\n    const parts = req.params.filepath;\n    return Array.isArray(parts) ? parts.join('/') : parts;\n  }\n\n  static validateDirectory(directory) {\n    if (typeof directory !== 'string') {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory must be a string.');\n    }\n    if (directory.length === 0) {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory must not be empty.');\n    }\n    if (directory.length > 256) {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory path is too long.');\n    }\n    if (directory.includes('..')) {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory must not contain \"..\".');\n    }\n    if (directory.startsWith('/') || directory.endsWith('/')) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        'Directory must not start or end with \"/\".'\n      );\n    }\n    if (directory.includes('//')) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        'Directory must not contain consecutive slashes.'\n      );\n    }\n    const firstSegment = directory.split('/')[0];\n    if (RESERVED_DIRECTORY_SEGMENTS.includes(firstSegment)) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        `Directory must not start with reserved segment \"${firstSegment}\".`\n      );\n    }\n    const dirRegex = /^[a-zA-Z0-9][a-zA-Z0-9_\\-/]*$/;\n    if (!dirRegex.test(directory)) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        'Directory contains invalid characters.'\n      );\n    }\n    return null;\n  }\n\n  async getHandler(req, res) {\n    const config = Config.get(req.params.appId);\n    if (!config) {\n      const error = createSanitizedHttpError(403, 'Invalid application ID.', config);\n      res.status(error.status);\n      res.json({ error: error.message });\n      return;\n    }\n\n    let filename = FilesRouter._getFilenameFromParams(req);\n    try {\n      const filesController = config.filesController;\n      const mime = (await import('mime')).default;\n      let contentType = mime.getType(filename);\n      let file = new Parse.File(filename, { base64: '' }, contentType);\n      const triggerResult = await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeFind,\n        { file },\n        config,\n        req.auth\n      );\n      if (triggerResult?.file?._name) {\n        filename = triggerResult?.file?._name;\n        contentType = mime.getType(filename);\n      }\n\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        return;\n      }\n\n      let data = await filesController.getFileData(config, filename).catch(() => {\n        res.status(404);\n        res.set('Content-Type', 'text/plain');\n        res.end('File not found.');\n      });\n      if (!data) {\n        return;\n      }\n      file = new Parse.File(filename, { base64: data.toString('base64') }, contentType);\n      const afterFind = await triggers.maybeRunFileTrigger(\n        triggers.Types.afterFind,\n        { file, forceDownload: false },\n        config,\n        req.auth\n      );\n\n      if (afterFind?.file) {\n        contentType = mime.getType(afterFind.file._name);\n        data = Buffer.from(afterFind.file._data, 'base64');\n      }\n\n      res.status(200);\n      res.set('Content-Type', contentType);\n      res.set('Content-Length', data.length);\n      if (afterFind.forceDownload) {\n        res.set('Content-Disposition', `attachment;filename=${afterFind.file._name}`);\n      }\n      res.end(data);\n    } catch (e) {\n      const err = triggers.resolveError(e, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: `Could not find file: ${filename}.`,\n      });\n      res.status(403);\n      res.json({ code: err.code, error: err.message });\n    }\n  }\n\n  /**\n   * Middleware that runs before body parsing to handle headers that must be\n   * resolved before the request body is consumed. Currently supports:\n   *\n   * - `X-Parse-File-Max-Upload-Size`: Overrides the server-wide `maxUploadSize`\n   *   for this request. Requires the master key. The value uses the same format\n   *   as the server option (e.g. `'50mb'`, `'1gb'`). Sets `req._maxUploadSizeOverride`\n   *   (in bytes) for `_bodyParsingMiddleware` to use.\n   */\n  _earlyHeadersMiddleware() {\n    return async (req, res, next) => {\n      const maxUploadSizeOverride = req.get('X-Parse-File-Max-Upload-Size');\n      if (!maxUploadSizeOverride) {\n        return next();\n      }\n      const appId = req.get('X-Parse-Application-Id');\n      const config = Config.get(appId);\n      if (!config) {\n        const error = createSanitizedHttpError(403, 'Invalid application ID.', undefined);\n        res.status(error.status);\n        res.json({ error: error.message });\n        return;\n      }\n      const masterKey = await config.loadMasterKey();\n      if (req.get('X-Parse-Master-Key') !== masterKey) {\n        const error = createSanitizedHttpError(403, 'unauthorized: master key is required', config);\n        res.status(error.status);\n        res.json({ error: error.message });\n        return;\n      }\n      if (config.masterKeyIps?.length && !Middlewares.checkIp(req.ip, config.masterKeyIps, config.masterKeyIpsStore)) {\n        const error = createSanitizedHttpError(403, 'unauthorized: master key is required', config);\n        res.status(error.status);\n        res.json({ error: error.message });\n        return;\n      }\n      let parsedBytes;\n      try {\n        parsedBytes = Utils.parseSizeToBytes(maxUploadSizeOverride);\n      } catch {\n        return next(\n          new Parse.Error(\n            Parse.Error.FILE_SAVE_ERROR,\n            `Invalid maxUploadSize override value: ${maxUploadSizeOverride}`\n          )\n        );\n      }\n      req._maxUploadSizeOverride = parsedBytes;\n      next();\n    };\n  }\n\n  _bodyParsingMiddleware(maxUploadSize) {\n    const defaultMaxBytes = Utils.parseSizeToBytes(maxUploadSize);\n    return (req, res, next) => {\n      if (req.get('X-Parse-Upload-Mode') === 'stream') {\n        req._maxUploadSizeBytes = req._maxUploadSizeOverride ?? defaultMaxBytes;\n        return next();\n      }\n      const limit = req._maxUploadSizeOverride ?? maxUploadSize;\n      return express.raw({ type: () => true, limit })(req, res, next);\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    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    // For streaming uploads, read file data from headers since the body is the raw stream\n    if (req.get('X-Parse-Upload-Mode') === 'stream') {\n      req.fileData = {};\n      if (req.get('X-Parse-File-Directory')) {\n        req.fileData.directory = req.get('X-Parse-File-Directory');\n      }\n      if (req.get('X-Parse-File-Metadata')) {\n        try {\n          const parsed = JSON.parse(req.get('X-Parse-File-Metadata'));\n          if (!parsed || typeof parsed !== 'object' || Array.isArray(parsed)) {\n            throw new Error();\n          }\n          req.fileData.metadata = parsed;\n        } catch {\n          next(new Parse.Error(Parse.Error.INVALID_JSON, 'Invalid JSON in X-Parse-File-Metadata header.'));\n          return;\n        }\n      }\n      if (req.get('X-Parse-File-Tags')) {\n        try {\n          const parsed = JSON.parse(req.get('X-Parse-File-Tags'));\n          if (!parsed || typeof parsed !== 'object' || Array.isArray(parsed)) {\n            throw new Error();\n          }\n          req.fileData.tags = parsed;\n        } catch {\n          next(new Parse.Error(Parse.Error.INVALID_JSON, 'Invalid JSON in X-Parse-File-Tags header.'));\n          return;\n        }\n      }\n    }\n\n    // Validate directory option (requires master key)\n    const directory = req.fileData?.directory;\n    if (directory !== undefined) {\n      if (!isMaster) {\n        next(\n          new Parse.Error(\n            Parse.Error.OPERATION_FORBIDDEN,\n            'Directory can only be set using the Master Key.'\n          )\n        );\n        return;\n      }\n      const directoryError = FilesRouter.validateDirectory(directory);\n      if (directoryError) {\n        next(directoryError);\n        return;\n      }\n    }\n\n    // Dispatch to the appropriate handler based on whether the body was buffered\n    if (req.body instanceof Buffer) {\n      return this._handleBufferedUpload(req, res, next);\n    }\n    return this._handleStreamUpload(req, res, next);\n  }\n\n  async _handleBufferedUpload(req, res, next) {\n    const config = req.config;\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 base64 = req.body.toString('base64');\n    const file = new Parse.File(filename, { base64 }, contentType);\n    const { metadata = {}, tags = {}, directory } = 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    if (directory) {\n      file.setDirectory(directory);\n    }\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        let bufferData;\n        if (fileObject.file._source?.format === 'buffer') {\n          bufferData = fileObject.file._source.buffer;\n        } else {\n          bufferData = Buffer.from(fileObject.file._data, 'base64');\n        }\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        // include directory if set (from client request or beforeSaveFile trigger)\n        if (fileObject.file._directory) {\n          fileOptions.directory = fileObject.file._directory;\n        }\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 _handleStreamUpload(req, res, next) {\n    const config = req.config;\n    const filesController = config.filesController;\n    const { filename } = req.params;\n    let contentType = req.get('Content-Type');\n    const maxBytes = req._maxUploadSizeBytes;\n    let stream;\n\n    try {\n      // Early rejection via Content-Length header\n      const contentLength = req.get('Content-Length');\n      if (contentLength && parseInt(contentLength, 10) > maxBytes) {\n        req.resume();\n        next(new Parse.Error(\n          Parse.Error.FILE_SAVE_ERROR,\n          `File size exceeds maximum allowed: ${maxBytes} bytes.`\n        ));\n        return;\n      }\n\n      const mime = (await import('mime')).default;\n\n      // Infer content type from extension or add extension from content type\n      const hasExtension = filename && filename.includes('.');\n      if (hasExtension && !contentType) {\n        contentType = mime.getType(filename);\n      } else if (!hasExtension && contentType) {\n        // extension will be added by filesController.createFile\n      }\n\n      // Create size-limited stream wrapping the request\n      stream = createSizeLimitedStream(req, maxBytes);\n\n      // Build a Parse.File with no _data (streaming mode)\n      const file = new Parse.File(filename, { base64: '' }, contentType);\n      const { metadata = {}, tags = {}, directory } = req.fileData || {};\n\n      // Validate metadata and tags for prohibited keywords\n      try {\n        Utils.checkProhibitedKeywords(config, metadata);\n        Utils.checkProhibitedKeywords(config, tags);\n      } catch (error) {\n        stream.destroy();\n        next(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n        return;\n      }\n\n      file.setTags(tags);\n      file.setMetadata(metadata);\n      if (directory) {\n        file.setDirectory(directory);\n      }\n\n      const fileSize = req.get('Content-Length')\n        ? parseInt(req.get('Content-Length'), 10)\n        : null;\n      const fileObject = { file, fileSize, stream: true };\n\n      // Run beforeSaveFile trigger\n      const triggerResult = await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeSave,\n        fileObject,\n        config,\n        req.auth\n      );\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          fileObject.fileSize = null;\n          saveResult = {\n            url: triggerResult.url(),\n            name: triggerResult._name,\n          };\n          // Destroy stream to remove listeners and drain request\n          stream.destroy();\n        }\n      }\n\n      // If the file returned by the trigger has already been saved, skip saving\n      if (!saveResult) {\n        // Prepare file options\n        const fileOptions = {\n          metadata: fileObject.file._metadata,\n        };\n        const fileTags =\n          Object.keys(fileObject.file._tags).length > 0 ? { tags: fileObject.file._tags } : {};\n        Object.assign(fileOptions, fileTags);\n        // include directory if set (from client request or beforeSaveFile trigger)\n        if (fileObject.file._directory) {\n          fileOptions.directory = fileObject.file._directory;\n        }\n\n        // Pass stream directly to filesController — it will buffer if adapter doesn't support streaming\n        const sourceType = fileObject.file._source?.type || contentType;\n        const createFileResult = await filesController.createFile(\n          config,\n          fileObject.file._name,\n          stream,\n          sourceType,\n          fileOptions\n        );\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\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      // Destroy stream to remove listeners and drain request, or resume directly\n      if (stream) {\n        stream.destroy();\n      } else {\n        req.resume();\n      }\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: ${filename}.`,\n      });\n      next(error);\n    }\n  }\n\n  async deleteHandler(req, res, next) {\n    try {\n      const { filesController } = req.config;\n      const filename = FilesRouter._getFilenameFromParams(req);\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 = FilesRouter._getFilenameFromParams(req);\n      const data = await filesController.getMetadata(filename);\n      res.status(200);\n      res.json(data);\n    } catch {\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":[]}
|
|
672
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_express","_interopRequireDefault","require","Middlewares","_interopRequireWildcard","_node","_Config","_logger","_stream","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","triggers","Utils","createSizeLimitedStream","source","maxBytes","totalBytes","started","sourceEnded","onData","onEnd","onError","output","Readable","read","chunk","length","destroy","Parse","Error","FILE_SAVE_ERROR","push","pause","err","on","resume","callback","removeListener","RESERVED_DIRECTORY_SEGMENTS","exports","FilesRouter","expressRouter","maxUploadSize","router","express","Router","metadataHandler","getHandler","post","req","res","next","INVALID_FILE_NAME","_earlyHeadersMiddleware","_bodyParsingMiddleware","handleParseHeaders","handleParseSession","createHandler","bind","delete","enforceMasterKeyAccess","deleteHandler","_getFilenameFromParams","parts","params","filepath","Array","isArray","join","validateDirectory","directory","includes","startsWith","endsWith","firstSegment","split","dirRegex","test","config","Config","appId","error","createSanitizedHttpError","status","json","message","filename","filesController","mime","contentType","getType","file","File","base64","triggerResult","maybeRunFileTrigger","Types","beforeFind","auth","_name","isFileStreamable","handleFileStream","catch","end","data","getFileData","toString","afterFind","forceDownload","Buffer","from","_data","resolveError","code","SCRIPT_FAILED","maxUploadSizeOverride","undefined","masterKey","loadMasterKey","masterKeyIps","checkIp","ip","masterKeyIpsStore","parsedBytes","parseSizeToBytes","_maxUploadSizeOverride","defaultMaxBytes","_maxUploadSizeBytes","limit","raw","type","isReadOnly","user","isMaster","isLinked","AnonymousUtils","fileUpload","enableForAnonymousUser","enableForAuthenticatedUser","enableForPublic","validateFilename","fileExtensions","isValidExtension","extension","some","ext","regex","RegExp","substring","lastIndexOf","fileData","parsed","JSON","parse","metadata","INVALID_JSON","tags","OPERATION_FORBIDDEN","directoryError","body","_handleBufferedUpload","_handleStreamUpload","checkProhibitedKeywords","INVALID_KEY_NAME","setTags","setMetadata","setDirectory","fileSize","byteLength","fileObject","beforeSave","saveResult","url","name","bufferData","_source","format","buffer","fileOptions","_metadata","fileTags","keys","_tags","assign","_directory","createFileResult","createFile","_url","_requestTask","_previousSave","Promise","resolve","afterSave","logger","stream","contentLength","parseInt","hasExtension","sourceType","adapter","getFileLocation","beforeDelete","deleteFile","afterDelete","FILE_DELETE_ERROR","getMetadata","range","start","Number","isNaN"],"sources":["../../src/Routers/FilesRouter.js"],"sourcesContent":["import express from 'express';\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');\nimport { Readable } from 'stream';\nimport { createSanitizedHttpError } from '../Error';\n\n/**\n * Wraps a readable stream in a Readable that enforces a byte size limit.\n * Data flow is lazy: the source is not read until a consumer starts reading\n * from the returned stream (via pipe or 'data' listener). This ensures the\n * consumer's error listener is attached before any data (or error) is emitted.\n */\nexport function createSizeLimitedStream(source, maxBytes) {\n  let totalBytes = 0;\n  let started = false;\n  let sourceEnded = false;\n  let onData, onEnd, onError;\n\n  const output = new Readable({\n    read() {\n      if (!started) {\n        started = true;\n\n        onData = (chunk) => {\n          totalBytes += chunk.length;\n          if (totalBytes > maxBytes) {\n            output.destroy(\n              new Parse.Error(\n                Parse.Error.FILE_SAVE_ERROR,\n                `File size exceeds maximum allowed: ${maxBytes} bytes.`\n              )\n            );\n            return;\n          }\n          if (!output.push(chunk)) {\n            source.pause();\n          }\n        };\n\n        onEnd = () => {\n          sourceEnded = true;\n          output.push(null);\n        };\n\n        onError = (err) => output.destroy(err);\n\n        source.on('data', onData);\n        source.on('end', onEnd);\n        source.on('error', onError);\n      }\n\n      // Resume source in case it was paused due to backpressure\n      if (!sourceEnded) {\n        source.resume();\n      }\n    },\n    destroy(err, callback) {\n      if (onData) {\n        source.removeListener('data', onData);\n      }\n      if (onEnd) {\n        source.removeListener('end', onEnd);\n      }\n      if (onError) {\n        source.removeListener('error', onError);\n      }\n      // Suppress errors emitted during drain (e.g. client disconnect)\n      source.on('error', () => {});\n      if (!sourceEnded) {\n        source.resume();\n      }\n      callback(err);\n    }\n  });\n\n  return output;\n}\n\n// Segments that conflict with sub-routes under GET /files/:appId/*. If a file\n// directory starts with one of these, its URL would match the wrong route\n// handler. Update this list when adding new sub-routes to expressRouter().\nexport const RESERVED_DIRECTORY_SEGMENTS = ['metadata'];\n\nexport class FilesRouter {\n  expressRouter({ maxUploadSize = '20Mb' } = {}) {\n    var router = express.Router();\n    // Metadata route must come before the catch-all GET route\n    router.get('/files/:appId/metadata/*filepath', this.metadataHandler);\n    router.get('/files/:appId/*filepath', this.getHandler);\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      this._earlyHeadersMiddleware(),\n      this._bodyParsingMiddleware(maxUploadSize),\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      this.createHandler.bind(this)\n    );\n\n    router.delete(\n      '/files/*filepath',\n      Middlewares.handleParseHeaders,\n      Middlewares.handleParseSession,\n      Middlewares.enforceMasterKeyAccess,\n      this.deleteHandler\n    );\n    return router;\n  }\n\n  static _getFilenameFromParams(req) {\n    const parts = req.params.filepath;\n    return Array.isArray(parts) ? parts.join('/') : parts;\n  }\n\n  static validateDirectory(directory) {\n    if (typeof directory !== 'string') {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory must be a string.');\n    }\n    if (directory.length === 0) {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory must not be empty.');\n    }\n    if (directory.length > 256) {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory path is too long.');\n    }\n    if (directory.includes('..')) {\n      return new Parse.Error(Parse.Error.INVALID_FILE_NAME, 'Directory must not contain \"..\".');\n    }\n    if (directory.startsWith('/') || directory.endsWith('/')) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        'Directory must not start or end with \"/\".'\n      );\n    }\n    if (directory.includes('//')) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        'Directory must not contain consecutive slashes.'\n      );\n    }\n    const firstSegment = directory.split('/')[0];\n    if (RESERVED_DIRECTORY_SEGMENTS.includes(firstSegment)) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        `Directory must not start with reserved segment \"${firstSegment}\".`\n      );\n    }\n    const dirRegex = /^[a-zA-Z0-9][a-zA-Z0-9_\\-/]*$/;\n    if (!dirRegex.test(directory)) {\n      return new Parse.Error(\n        Parse.Error.INVALID_FILE_NAME,\n        'Directory contains invalid characters.'\n      );\n    }\n    return null;\n  }\n\n  async getHandler(req, res) {\n    const config = Config.get(req.params.appId);\n    if (!config) {\n      const error = createSanitizedHttpError(403, 'Invalid application ID.', config);\n      res.status(error.status);\n      res.json({ error: error.message });\n      return;\n    }\n\n    let filename = FilesRouter._getFilenameFromParams(req);\n    try {\n      const filesController = config.filesController;\n      const mime = (await import('mime')).default;\n      let contentType = mime.getType(filename);\n      let file = new Parse.File(filename, { base64: '' }, contentType);\n      const triggerResult = await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeFind,\n        { file },\n        config,\n        req.auth\n      );\n      if (triggerResult?.file?._name) {\n        filename = triggerResult?.file?._name;\n        contentType = mime.getType(filename);\n      }\n\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        return;\n      }\n\n      let data = await filesController.getFileData(config, filename).catch(() => {\n        res.status(404);\n        res.set('Content-Type', 'text/plain');\n        res.end('File not found.');\n      });\n      if (!data) {\n        return;\n      }\n      file = new Parse.File(filename, { base64: data.toString('base64') }, contentType);\n      const afterFind = await triggers.maybeRunFileTrigger(\n        triggers.Types.afterFind,\n        { file, forceDownload: false },\n        config,\n        req.auth\n      );\n\n      if (afterFind?.file) {\n        contentType = mime.getType(afterFind.file._name);\n        data = Buffer.from(afterFind.file._data, 'base64');\n      }\n\n      res.status(200);\n      res.set('Content-Type', contentType);\n      res.set('Content-Length', data.length);\n      if (afterFind.forceDownload) {\n        res.set('Content-Disposition', `attachment;filename=${afterFind.file._name}`);\n      }\n      res.end(data);\n    } catch (e) {\n      const err = triggers.resolveError(e, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: `Could not find file: ${filename}.`,\n      });\n      res.status(403);\n      res.json({ code: err.code, error: err.message });\n    }\n  }\n\n  /**\n   * Middleware that runs before body parsing to handle headers that must be\n   * resolved before the request body is consumed. Currently supports:\n   *\n   * - `X-Parse-File-Max-Upload-Size`: Overrides the server-wide `maxUploadSize`\n   *   for this request. Requires the master key. The value uses the same format\n   *   as the server option (e.g. `'50mb'`, `'1gb'`). Sets `req._maxUploadSizeOverride`\n   *   (in bytes) for `_bodyParsingMiddleware` to use.\n   */\n  _earlyHeadersMiddleware() {\n    return async (req, res, next) => {\n      const maxUploadSizeOverride = req.get('X-Parse-File-Max-Upload-Size');\n      if (!maxUploadSizeOverride) {\n        return next();\n      }\n      const appId = req.get('X-Parse-Application-Id');\n      const config = Config.get(appId);\n      if (!config) {\n        const error = createSanitizedHttpError(403, 'Invalid application ID.', undefined);\n        res.status(error.status);\n        res.json({ error: error.message });\n        return;\n      }\n      const masterKey = await config.loadMasterKey();\n      if (req.get('X-Parse-Master-Key') !== masterKey) {\n        const error = createSanitizedHttpError(403, 'unauthorized: master key is required', config);\n        res.status(error.status);\n        res.json({ error: error.message });\n        return;\n      }\n      if (config.masterKeyIps?.length && !Middlewares.checkIp(req.ip, config.masterKeyIps, config.masterKeyIpsStore)) {\n        const error = createSanitizedHttpError(403, 'unauthorized: master key is required', config);\n        res.status(error.status);\n        res.json({ error: error.message });\n        return;\n      }\n      let parsedBytes;\n      try {\n        parsedBytes = Utils.parseSizeToBytes(maxUploadSizeOverride);\n      } catch {\n        return next(\n          new Parse.Error(\n            Parse.Error.FILE_SAVE_ERROR,\n            `Invalid maxUploadSize override value: ${maxUploadSizeOverride}`\n          )\n        );\n      }\n      req._maxUploadSizeOverride = parsedBytes;\n      next();\n    };\n  }\n\n  _bodyParsingMiddleware(maxUploadSize) {\n    const defaultMaxBytes = Utils.parseSizeToBytes(maxUploadSize);\n    return (req, res, next) => {\n      if (req.get('X-Parse-Upload-Mode') === 'stream') {\n        req._maxUploadSizeBytes = req._maxUploadSizeOverride ?? defaultMaxBytes;\n        return next();\n      }\n      const limit = req._maxUploadSizeOverride ?? maxUploadSize;\n      return express.raw({ type: () => true, limit })(req, res, next);\n    };\n  }\n\n  async createHandler(req, res, next) {\n    if (req.auth.isReadOnly) {\n      const error = createSanitizedHttpError(403, \"read-only masterKey isn't allowed to create a file.\", req.config);\n      res.status(error.status);\n      res.end(`{\"error\":\"${error.message}\"}`);\n      return;\n    }\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    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    // For streaming uploads, read file data from headers since the body is the raw stream\n    if (req.get('X-Parse-Upload-Mode') === 'stream') {\n      req.fileData = {};\n      if (req.get('X-Parse-File-Directory')) {\n        req.fileData.directory = req.get('X-Parse-File-Directory');\n      }\n      if (req.get('X-Parse-File-Metadata')) {\n        try {\n          const parsed = JSON.parse(req.get('X-Parse-File-Metadata'));\n          if (!parsed || typeof parsed !== 'object' || Array.isArray(parsed)) {\n            throw new Error();\n          }\n          req.fileData.metadata = parsed;\n        } catch {\n          next(new Parse.Error(Parse.Error.INVALID_JSON, 'Invalid JSON in X-Parse-File-Metadata header.'));\n          return;\n        }\n      }\n      if (req.get('X-Parse-File-Tags')) {\n        try {\n          const parsed = JSON.parse(req.get('X-Parse-File-Tags'));\n          if (!parsed || typeof parsed !== 'object' || Array.isArray(parsed)) {\n            throw new Error();\n          }\n          req.fileData.tags = parsed;\n        } catch {\n          next(new Parse.Error(Parse.Error.INVALID_JSON, 'Invalid JSON in X-Parse-File-Tags header.'));\n          return;\n        }\n      }\n    }\n\n    // Validate directory option (requires master key)\n    const directory = req.fileData?.directory;\n    if (directory !== undefined) {\n      if (!isMaster) {\n        next(\n          new Parse.Error(\n            Parse.Error.OPERATION_FORBIDDEN,\n            'Directory can only be set using the Master Key.'\n          )\n        );\n        return;\n      }\n      const directoryError = FilesRouter.validateDirectory(directory);\n      if (directoryError) {\n        next(directoryError);\n        return;\n      }\n    }\n\n    // Dispatch to the appropriate handler based on whether the body was buffered\n    if (req.body instanceof Buffer) {\n      return this._handleBufferedUpload(req, res, next);\n    }\n    return this._handleStreamUpload(req, res, next);\n  }\n\n  async _handleBufferedUpload(req, res, next) {\n    const config = req.config;\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 base64 = req.body.toString('base64');\n    const file = new Parse.File(filename, { base64 }, contentType);\n    const { metadata = {}, tags = {}, directory } = 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    if (directory) {\n      file.setDirectory(directory);\n    }\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        let bufferData;\n        if (fileObject.file._source?.format === 'buffer') {\n          bufferData = fileObject.file._source.buffer;\n        } else {\n          bufferData = Buffer.from(fileObject.file._data, 'base64');\n        }\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        // include directory if set (from client request or beforeSaveFile trigger)\n        if (fileObject.file._directory) {\n          fileOptions.directory = fileObject.file._directory;\n        }\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 _handleStreamUpload(req, res, next) {\n    const config = req.config;\n    const filesController = config.filesController;\n    const { filename } = req.params;\n    let contentType = req.get('Content-Type');\n    const maxBytes = req._maxUploadSizeBytes;\n    let stream;\n\n    try {\n      // Early rejection via Content-Length header\n      const contentLength = req.get('Content-Length');\n      if (contentLength && parseInt(contentLength, 10) > maxBytes) {\n        req.resume();\n        next(new Parse.Error(\n          Parse.Error.FILE_SAVE_ERROR,\n          `File size exceeds maximum allowed: ${maxBytes} bytes.`\n        ));\n        return;\n      }\n\n      const mime = (await import('mime')).default;\n\n      // Infer content type from extension or add extension from content type\n      const hasExtension = filename && filename.includes('.');\n      if (hasExtension && !contentType) {\n        contentType = mime.getType(filename);\n      } else if (!hasExtension && contentType) {\n        // extension will be added by filesController.createFile\n      }\n\n      // Create size-limited stream wrapping the request\n      stream = createSizeLimitedStream(req, maxBytes);\n\n      // Build a Parse.File with no _data (streaming mode)\n      const file = new Parse.File(filename, { base64: '' }, contentType);\n      const { metadata = {}, tags = {}, directory } = req.fileData || {};\n\n      // Validate metadata and tags for prohibited keywords\n      try {\n        Utils.checkProhibitedKeywords(config, metadata);\n        Utils.checkProhibitedKeywords(config, tags);\n      } catch (error) {\n        stream.destroy();\n        next(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n        return;\n      }\n\n      file.setTags(tags);\n      file.setMetadata(metadata);\n      if (directory) {\n        file.setDirectory(directory);\n      }\n\n      const fileSize = req.get('Content-Length')\n        ? parseInt(req.get('Content-Length'), 10)\n        : null;\n      const fileObject = { file, fileSize, stream: true };\n\n      // Run beforeSaveFile trigger\n      const triggerResult = await triggers.maybeRunFileTrigger(\n        triggers.Types.beforeSave,\n        fileObject,\n        config,\n        req.auth\n      );\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          fileObject.fileSize = null;\n          saveResult = {\n            url: triggerResult.url(),\n            name: triggerResult._name,\n          };\n          // Destroy stream to remove listeners and drain request\n          stream.destroy();\n        }\n      }\n\n      // If the file returned by the trigger has already been saved, skip saving\n      if (!saveResult) {\n        // Prepare file options\n        const fileOptions = {\n          metadata: fileObject.file._metadata,\n        };\n        const fileTags =\n          Object.keys(fileObject.file._tags).length > 0 ? { tags: fileObject.file._tags } : {};\n        Object.assign(fileOptions, fileTags);\n        // include directory if set (from client request or beforeSaveFile trigger)\n        if (fileObject.file._directory) {\n          fileOptions.directory = fileObject.file._directory;\n        }\n\n        // Pass stream directly to filesController — it will buffer if adapter doesn't support streaming\n        const sourceType = fileObject.file._source?.type || contentType;\n        const createFileResult = await filesController.createFile(\n          config,\n          fileObject.file._name,\n          stream,\n          sourceType,\n          fileOptions\n        );\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\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      // Destroy stream to remove listeners and drain request, or resume directly\n      if (stream) {\n        stream.destroy();\n      } else {\n        req.resume();\n      }\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: ${filename}.`,\n      });\n      next(error);\n    }\n  }\n\n  async deleteHandler(req, res, next) {\n    if (req.auth.isReadOnly) {\n      const error = createSanitizedHttpError(403, \"read-only masterKey isn't allowed to delete a file.\", req.config);\n      res.status(error.status);\n      res.end(`{\"error\":\"${error.message}\"}`);\n      return;\n    }\n    try {\n      const { filesController } = req.config;\n      const filename = FilesRouter._getFilenameFromParams(req);\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 = FilesRouter._getFilenameFromParams(req);\n      const data = await filesController.getMetadata(filename);\n      res.status(200);\n      res.json(data);\n    } catch {\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":[]}
|
|
@@ -297,6 +297,9 @@ class UsersRouter extends _ClassesRouter.default {
|
|
|
297
297
|
if (!req.auth.isMaster) {
|
|
298
298
|
throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, 'master key is required', req.config);
|
|
299
299
|
}
|
|
300
|
+
if (req.auth.isReadOnly) {
|
|
301
|
+
throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to login as another user.", req.config);
|
|
302
|
+
}
|
|
300
303
|
const userId = req.body?.userId || req.query.userId;
|
|
301
304
|
if (!userId) {
|
|
302
305
|
throw new _node.default.Error(_node.default.Error.INVALID_VALUE, 'userId must not be empty, null, or undefined');
|
|
@@ -635,4 +638,4 @@ class UsersRouter extends _ClassesRouter.default {
|
|
|
635
638
|
}
|
|
636
639
|
exports.UsersRouter = UsersRouter;
|
|
637
640
|
var _default = exports.default = UsersRouter;
|
|
638
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","_Error","e","__esModule","default","UsersRouter","ClassesRouter","className","removeHiddenProperties","obj","key","Object","prototype","hasOwnProperty","call","test","_sanitizeAuthData","user","password","authData","keys","forEach","provider","length","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","ignoreEmailVerification","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","filter","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","authProvider","join","request","master","ip","installationId","object","User","fromJSON","assign","createdWith","RestWrite","buildCreatedWith","isMaintenance","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","createSanitizedError","INVALID_SESSION_TOKEN","rest","include","clientSDK","context","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","res","handleAuthDataValidation","objectId","passwordPolicy","maxPasswordAge","changedAt","_password_changed_at","Date","update","_encode","__type","iso","expiresAt","getTime","filesController","expandFilesInObject","maybeRunTrigger","TriggerTypes","beforeLogin","sessionData","createSession","userId","afterLoginUser","afterLogin","authDataManager","runAfterFind","handleLogInAs","OPERATION_FORBIDDEN","INVALID_VALUE","queryResults","handleVerifyPassword","handleLogOut","success","records","undefined","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","_publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","INTERNAL_SERVER_ERROR","handleResetRequest","token","EMAIL_MISSING","userResults","userData","_perishable_token","_perishable_token_expires_at","$lt","$exists","limit","INVALID_EMAIL_ADDRESS","inflate","beforePasswordResetRequest","sendPasswordResetEmail","err","code","resetPasswordSuccessOnInvalidEmail","message","handleVerificationEmailRequest","OTHER_CAUSE","send","regenerateEmailVerifyToken","sendVerificationEmail","handleChallenge","challengeData","parseUser","id","findUsersWithAuthData","getRequestObject","isChallenge","validator","getValidatorForProvider","validatorResponse","logger","acc","sort","authAdapter","challenge","providerChallengeResponse","resolveError","SCRIPT_FAILED","userString","JSON","stringify","authenticationStep","mountRoutes","route","handleFind","promiseEnsureIdempotency","handleCreate","handleGet","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/UsersRouter.js"],"sourcesContent":["// These methods handle the User-related routes.\n\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport AccountLockout from '../AccountLockout';\nimport ClassesRouter from './ClassesRouter';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport passwordCrypto from '../password';\nimport {\n  maybeRunTrigger,\n  Types as TriggerTypes,\n  getRequestObject,\n  resolveError,\n  inflate,\n} from '../triggers';\nimport { promiseEnsureIdempotency } from '../middlewares';\nimport RestWrite from '../RestWrite';\nimport { logger } from '../logger';\nimport { createSanitizedError } from '../Error';\n\nexport class UsersRouter extends ClassesRouter {\n  className() {\n    return '_User';\n  }\n\n  /**\n   * Removes all \"_\" prefixed properties from an object, except \"__type\"\n   * @param {Object} obj An object.\n   */\n  static removeHiddenProperties(obj) {\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        // Regexp comes from Parse.Object.prototype.validate\n        if (key !== '__type' && !/^[A-Za-z][0-9A-Za-z_]*$/.test(key)) {\n          delete obj[key];\n        }\n      }\n    }\n  }\n\n  /**\n   * After retrieving a user directly from the database, we need to remove the\n   * password from the object (for security), and fix an issue some SDKs have\n   * with null values\n   */\n  _sanitizeAuthData(user) {\n    delete user.password;\n\n    // Sometimes the authData still has null on that keys\n    // https://github.com/parse-community/parse-server/issues/935\n    if (user.authData) {\n      Object.keys(user.authData).forEach(provider => {\n        if (user.authData[provider] === null) {\n          delete user.authData[provider];\n        }\n      });\n      if (Object.keys(user.authData).length == 0) {\n        delete user.authData;\n      }\n    }\n  }\n\n  /**\n   * Validates a password request in login and verifyPassword\n   * @param {Object} req The request\n   * @returns {Object} User object\n   * @private\n   */\n  _authenticateUserFromRequest(req) {\n    return new Promise((resolve, reject) => {\n      // Use query parameters instead if provided in url\n      let payload = req.body || {};\n      if (\n        (!payload.username && req.query && req.query.username) ||\n        (!payload.email && req.query && req.query.email)\n      ) {\n        payload = req.query;\n      }\n      const { username, email, password, ignoreEmailVerification } = payload;\n\n      // TODO: use the right error codes / descriptions.\n      if (!username && !email) {\n        throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'username/email is required.');\n      }\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'password is required.');\n      }\n      if (\n        typeof password !== 'string' ||\n        (email && typeof email !== 'string') ||\n        (username && typeof username !== 'string')\n      ) {\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n      }\n\n      let user;\n      let isValidPassword = false;\n      let query;\n      if (email && username) {\n        query = { email, username };\n      } else if (email) {\n        query = { email };\n      } else {\n        query = { $or: [{ username }, { email: username }] };\n      }\n      return req.config.database\n        .find('_User', query, {}, Auth.maintenance(req.config))\n        .then(results => {\n          if (!results.length) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n\n          if (results.length > 1) {\n            // corner case where user1 has username == user2 email\n            req.config.loggerController.warn(\n              \"There is a user which email is the same as another user's username, logging in based on username\"\n            );\n            user = results.filter(user => user.username === username)[0];\n          } else {\n            user = results[0];\n          }\n\n          return passwordCrypto.compare(password, user.password);\n        })\n        .then(correct => {\n          isValidPassword = correct;\n          const accountLockoutPolicy = new AccountLockout(user, req.config);\n          return accountLockoutPolicy.handleLoginAttempt(isValidPassword);\n        })\n        .then(async () => {\n          if (!isValidPassword) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Ensure the user isn't locked out\n          // A locked out user won't be able to login\n          // To lock a user out, just set the ACL to `masterKey` only  ({}).\n          // Empty ACL is OK\n          if (!req.auth.isMaster && user.ACL && Object.keys(user.ACL).length == 0) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Create request object for verification functions\n          const authProvider =\n            req.body &&\n            req.body.authData &&\n            Object.keys(req.body.authData).length &&\n            Object.keys(req.body.authData).join(',');\n          const request = {\n            master: req.auth.isMaster,\n            ip: req.config.ip,\n            installationId: req.auth.installationId,\n            object: Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n            createdWith: RestWrite.buildCreatedWith('login', authProvider),\n          };\n\n          // If request doesn't use master or maintenance key with ignoring email verification\n          if (!((req.auth.isMaster || req.auth.isMaintenance) && ignoreEmailVerification)) {\n\n            // Get verification conditions which can be booleans or functions; the purpose of this async/await\n            // structure is to avoid unnecessarily executing subsequent functions if previous ones fail in the\n            // conditional statement below, as a developer may decide to execute expensive operations in them\n            const verifyUserEmails = async () => req.config.verifyUserEmails === true || (typeof req.config.verifyUserEmails === 'function' && await Promise.resolve(req.config.verifyUserEmails(request)) === true);\n            const preventLoginWithUnverifiedEmail = async () => req.config.preventLoginWithUnverifiedEmail === true || (typeof req.config.preventLoginWithUnverifiedEmail === 'function' && await Promise.resolve(req.config.preventLoginWithUnverifiedEmail(request)) === true);\n            if (await verifyUserEmails() && await preventLoginWithUnverifiedEmail() && !user.emailVerified) {\n              throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, 'User email is not verified.');\n            }\n          }\n\n          this._sanitizeAuthData(user);\n\n          return resolve(user);\n        })\n        .catch(error => {\n          return reject(error);\n        });\n    });\n  }\n\n  handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n    }\n    const sessionToken = req.info.sessionToken;\n    return rest\n      .find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken },\n        { include: 'user' },\n        req.info.clientSDK,\n        req.info.context\n      )\n      .then(response => {\n        if (!response.results || response.results.length == 0 || !response.results[0].user) {\n          throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n        } else {\n          const user = response.results[0].user;\n          // Send token back on the login, because SDKs expect that.\n          user.sessionToken = sessionToken;\n\n          // Remove hidden properties.\n          UsersRouter.removeHiddenProperties(user);\n          return { response: user };\n        }\n      });\n  }\n\n  async handleLogIn(req) {\n    const user = await this._authenticateUserFromRequest(req);\n    const authData = req.body && req.body.authData;\n    // Check if user has provided their required auth providers\n    Auth.checkIfUserHasProvidedConfiguredProvidersForLogin(\n      req,\n      authData,\n      user.authData,\n      req.config\n    );\n\n    let authDataResponse;\n    let validatedAuthData;\n    if (authData) {\n      const res = await Auth.handleAuthDataValidation(\n        authData,\n        new RestWrite(\n          req.config,\n          req.auth,\n          '_User',\n          { objectId: user.objectId },\n          req.body || {},\n          user,\n          req.info.clientSDK,\n          req.info.context\n        ),\n        user\n      );\n      authDataResponse = res.authDataResponse;\n      validatedAuthData = res.authData;\n    }\n\n    // handle password expiry policy\n    if (req.config.passwordPolicy && req.config.passwordPolicy.maxPasswordAge) {\n      let changedAt = user._password_changed_at;\n\n      if (!changedAt) {\n        // password was created before expiry policy was enabled.\n        // simply update _User object so that it will start enforcing from now\n        changedAt = new Date();\n        req.config.database.update(\n          '_User',\n          { username: user.username },\n          { _password_changed_at: Parse._encode(changedAt) }\n        );\n      } else {\n        // check whether the password has expired\n        if (changedAt.__type == 'Date') {\n          changedAt = new Date(changedAt.iso);\n        }\n        // Calculate the expiry time.\n        const expiresAt = new Date(\n          changedAt.getTime() + 86400000 * req.config.passwordPolicy.maxPasswordAge\n        );\n        if (expiresAt < new Date())\n        // fail of current time is past password expiry time\n        { throw new Parse.Error(\n          Parse.Error.OBJECT_NOT_FOUND,\n          'Your password has expired. Please reset your password.'\n        ); }\n      }\n    }\n\n    // Remove hidden properties.\n    UsersRouter.removeHiddenProperties(user);\n\n    await req.config.filesController.expandFilesInObject(req.config, user);\n\n    // Before login trigger; throws if failure\n    await maybeRunTrigger(\n      TriggerTypes.beforeLogin,\n      req.auth,\n      Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n      null,\n      req.config,\n      req.info.context\n    );\n\n    // If we have some new validated authData update directly\n    if (validatedAuthData && Object.keys(validatedAuthData).length) {\n      await req.config.database.update(\n        '_User',\n        { objectId: user.objectId },\n        { authData: validatedAuthData },\n        {}\n      );\n    }\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId: user.objectId,\n      createdWith: RestWrite.buildCreatedWith('login'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    const afterLoginUser = Parse.User.fromJSON(Object.assign({ className: '_User' }, user));\n    await maybeRunTrigger(\n      TriggerTypes.afterLogin,\n      { ...req.auth, user: afterLoginUser },\n      afterLoginUser,\n      null,\n      req.config,\n      req.info.context\n    );\n\n    if (authDataResponse) {\n      user.authDataResponse = authDataResponse;\n    }\n    await req.config.authDataManager.runAfterFind(req, user.authData);\n\n    return { response: user };\n  }\n\n  /**\n   * This allows master-key clients to create user sessions without access to\n   * user credentials. This enables systems that can authenticate access another\n   * way (API key, app administrators) to act on a user's behalf.\n   *\n   * We create a new session rather than looking for an existing session; we\n   * want this to work in situations where the user is logged out on all\n   * devices, since this can be used by automated systems acting on the user's\n   * behalf.\n   *\n   * For the moment, we're omitting event hooks and lockout checks, since\n   * immediate use cases suggest /loginAs could be used for semantically\n   * different reasons from /login\n   */\n  async handleLogInAs(req) {\n    if (!req.auth.isMaster) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        'master key is required',\n        req.config\n      );\n    }\n\n    const userId = req.body?.userId || req.query.userId;\n    if (!userId) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_VALUE,\n        'userId must not be empty, null, or undefined'\n      );\n    }\n\n    const queryResults = await req.config.database.find('_User', { objectId: userId });\n    const user = queryResults[0];\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'user not found');\n    }\n\n    this._sanitizeAuthData(user);\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId,\n      createdWith: RestWrite.buildCreatedWith('login', 'masterkey'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    return { response: user };\n  }\n\n  handleVerifyPassword(req) {\n    return this._authenticateUserFromRequest(req)\n      .then(user => {\n        // Remove hidden properties.\n        UsersRouter.removeHiddenProperties(user);\n\n        return { response: user };\n      })\n      .catch(error => {\n        throw error;\n      });\n  }\n\n  async handleLogOut(req) {\n    const success = { response: {} };\n    if (req.info && req.info.sessionToken) {\n      const records = await rest.find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      );\n      if (records.results && records.results.length) {\n        await rest.del(\n          req.config,\n          Auth.master(req.config),\n          '_Session',\n          records.results[0].objectId,\n          req.info.context\n        );\n        await maybeRunTrigger(\n          TriggerTypes.afterLogout,\n          req.auth,\n          Parse.Session.fromJSON(Object.assign({ className: '_Session' }, records.results[0])),\n          null,\n          req.config\n        );\n      }\n    }\n    return success;\n  }\n\n  _throwOnBadEmailConfig(req) {\n    try {\n      Config.validateEmailConfiguration({\n        emailAdapter: req.config.userController.adapter,\n        appName: req.config.appName,\n        publicServerURL: req.config.publicServerURL || req.config._publicServerURL,\n        emailVerifyTokenValidityDuration: req.config.emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid: req.config.emailVerifyTokenReuseIfValid,\n      });\n    } catch (e) {\n      if (typeof e === 'string') {\n        // Maybe we need a Bad Configuration error, but the SDKs won't understand it. For now, Internal Server Error.\n        throw new Parse.Error(\n          Parse.Error.INTERNAL_SERVER_ERROR,\n          'An appName, publicServerURL, and emailAdapter are required for password reset and email verification functionality.'\n        );\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  async handleResetRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    let email = req.body?.email;\n    const token = req.body?.token;\n\n    if (!email && !token) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n\n    let userResults = null;\n    let userData = null;\n\n    // We can find the user using token\n    if (token) {\n      userResults = await req.config.database.find('_User', {\n        _perishable_token: token,\n        _perishable_token_expires_at: { $lt: Parse._encode(new Date()) },\n      });\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n        if (userData.email) {\n          email = userData.email;\n        }\n      }\n    // Or using email if no token provided\n    } else if (typeof email === 'string') {\n      userResults = await req.config.database.find(\n        '_User',\n        { $or: [{ email }, { username: email, email: { $exists: false } }] },\n        { limit: 1 },\n        Auth.maintenance(req.config)\n      );\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n      }\n    }\n\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    if (userData) {\n      this._sanitizeAuthData(userData);\n      // Get files attached to user\n      await req.config.filesController.expandFilesInObject(req.config, userData);\n\n      const user = inflate('_User', userData);\n\n      await maybeRunTrigger(\n        TriggerTypes.beforePasswordResetRequest,\n        req.auth,\n        user,\n        null,\n        req.config,\n        req.info.context\n      );\n    }\n\n    const userController = req.config.userController;\n    try {\n      await userController.sendPasswordResetEmail(email);\n      return {\n        response: {},\n      };\n    } catch (err) {\n      if (err.code === Parse.Error.OBJECT_NOT_FOUND) {\n        if (req.config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail ?? true) {\n          return {\n            response: {},\n          };\n        }\n        err.message = `A user with that email does not exist.`;\n      }\n      throw err;\n    }\n  }\n\n  async handleVerificationEmailRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body || {};\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    const results = await req.config.database.find('_User', { email: email }, {}, Auth.maintenance(req.config));\n    if (!results.length || results.length < 1) {\n      throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, `No user found with email ${email}`);\n    }\n    const user = results[0];\n\n    // remove password field, messes with saving on postgres\n    delete user.password;\n\n    if (user.emailVerified) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Email ${email} is already verified.`);\n    }\n\n    const userController = req.config.userController;\n    const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster, req.auth.installationId, req.ip);\n    if (send) {\n      userController.sendVerificationEmail(user, req);\n    }\n    return { response: {} };\n  }\n\n  async handleChallenge(req) {\n    const { username, email, password, authData, challengeData } = req.body || {};\n\n    // if username or email provided with password try to authenticate the user by username\n    let user;\n    if (username || email) {\n      if (!password) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You provided username or email, you need to also provide password.'\n        );\n      }\n      user = await this._authenticateUserFromRequest(req);\n    }\n\n    if (!challengeData) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Nothing to challenge.');\n    }\n\n    if (typeof challengeData !== 'object') {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'challengeData should be an object.');\n    }\n\n    let request;\n    let parseUser;\n\n    // Try to find user by authData\n    if (authData) {\n      if (typeof authData !== 'object') {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'authData should be an object.');\n      }\n      if (user) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide username/email and authData, only use one identification method.'\n        );\n      }\n\n      if (Object.keys(authData).filter(key => authData[key].id).length > 1) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide more than one authData provider with an id.'\n        );\n      }\n\n      const results = await Auth.findUsersWithAuthData(req.config, authData);\n\n      try {\n        if (!results[0] || results.length > 1) {\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n        }\n        // Find the provider used to find the user\n        const provider = Object.keys(authData).find(key => authData[key].id);\n\n        parseUser = Parse.User.fromJSON({ className: '_User', ...results[0] });\n        request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n        request.isChallenge = true;\n        // Validate authData used to identify the user to avoid brute-force attack on `id`\n        const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n        const validatorResponse = await validator(authData[provider], req, parseUser, request);\n        if (validatorResponse && validatorResponse.validator) {\n          await validatorResponse.validator();\n        }\n      } catch (e) {\n        // Rewrite the error to avoid guess id attack\n        logger.error(e);\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n      }\n    }\n\n    if (!parseUser) {\n      parseUser = user ? Parse.User.fromJSON({ className: '_User', ...user }) : undefined;\n    }\n\n    if (!request) {\n      request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n      request.isChallenge = true;\n    }\n    const acc = {};\n    // Execute challenge step-by-step with consistent order for better error feedback\n    // and to avoid to trigger others challenges if one of them fails\n    for (const provider of Object.keys(challengeData).sort()) {\n      try {\n        const authAdapter = req.config.authDataManager.getValidatorForProvider(provider);\n        if (!authAdapter) {\n          continue;\n        }\n        const {\n          adapter: { challenge },\n        } = authAdapter;\n        if (typeof challenge === 'function') {\n          const providerChallengeResponse = await challenge(\n            challengeData[provider],\n            authData && authData[provider],\n            req.config.auth[provider],\n            request\n          );\n          acc[provider] = providerChallengeResponse || true;\n        }\n      } catch (err) {\n        const e = resolveError(err, {\n          code: Parse.Error.SCRIPT_FAILED,\n          message: 'Challenge failed. Unknown error.',\n        });\n        const userString = req.auth && req.auth.user ? req.auth.user.id : undefined;\n        logger.error(\n          `Failed running auth step challenge for ${provider} for user ${userString} with Error: ` +\n            JSON.stringify(e),\n          {\n            authenticationStep: 'challenge',\n            error: e,\n            user: userString,\n            provider,\n          }\n        );\n        throw e;\n      }\n    }\n    return { response: { challengeData: acc } };\n  }\n\n  mountRoutes() {\n    this.route('GET', '/users', req => {\n      return this.handleFind(req);\n    });\n    this.route('POST', '/users', promiseEnsureIdempotency, req => {\n      return this.handleCreate(req);\n    });\n    this.route('GET', '/users/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/users/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('PUT', '/users/:objectId', promiseEnsureIdempotency, req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/users/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('GET', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/loginAs', req => {\n      return this.handleLogInAs(req);\n    });\n    this.route('POST', '/logout', req => {\n      return this.handleLogOut(req);\n    });\n    this.route('POST', '/requestPasswordReset', req => {\n      return this.handleResetRequest(req);\n    });\n    this.route('POST', '/verificationEmailRequest', req => {\n      return this.handleVerificationEmailRequest(req);\n    });\n    this.route('GET', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/challenge', req => {\n      return this.handleChallenge(req);\n    });\n  }\n}\n\nexport default UsersRouter;\n"],"mappings":"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","ignoreList":[]}
|
|
641
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","_interopRequireDefault","require","_Config","_AccountLockout","_ClassesRouter","_rest","_Auth","_password","_triggers","_middlewares","_RestWrite","_logger","_Error","e","__esModule","default","UsersRouter","ClassesRouter","className","removeHiddenProperties","obj","key","Object","prototype","hasOwnProperty","call","test","_sanitizeAuthData","user","password","authData","keys","forEach","provider","length","_authenticateUserFromRequest","req","Promise","resolve","reject","payload","body","username","query","email","ignoreEmailVerification","Parse","Error","USERNAME_MISSING","PASSWORD_MISSING","OBJECT_NOT_FOUND","isValidPassword","$or","config","database","find","Auth","maintenance","then","results","loggerController","warn","filter","passwordCrypto","compare","correct","accountLockoutPolicy","AccountLockout","handleLoginAttempt","auth","isMaster","ACL","authProvider","join","request","master","ip","installationId","object","User","fromJSON","assign","createdWith","RestWrite","buildCreatedWith","isMaintenance","verifyUserEmails","preventLoginWithUnverifiedEmail","emailVerified","EMAIL_NOT_FOUND","catch","error","handleMe","info","sessionToken","createSanitizedError","INVALID_SESSION_TOKEN","rest","include","clientSDK","context","response","handleLogIn","checkIfUserHasProvidedConfiguredProvidersForLogin","authDataResponse","validatedAuthData","res","handleAuthDataValidation","objectId","passwordPolicy","maxPasswordAge","changedAt","_password_changed_at","Date","update","_encode","__type","iso","expiresAt","getTime","filesController","expandFilesInObject","maybeRunTrigger","TriggerTypes","beforeLogin","sessionData","createSession","userId","afterLoginUser","afterLogin","authDataManager","runAfterFind","handleLogInAs","OPERATION_FORBIDDEN","isReadOnly","INVALID_VALUE","queryResults","handleVerifyPassword","handleLogOut","success","records","undefined","del","afterLogout","Session","_throwOnBadEmailConfig","Config","validateEmailConfiguration","emailAdapter","userController","adapter","appName","publicServerURL","_publicServerURL","emailVerifyTokenValidityDuration","emailVerifyTokenReuseIfValid","INTERNAL_SERVER_ERROR","handleResetRequest","token","EMAIL_MISSING","userResults","userData","_perishable_token","_perishable_token_expires_at","$lt","$exists","limit","INVALID_EMAIL_ADDRESS","inflate","beforePasswordResetRequest","sendPasswordResetEmail","err","code","resetPasswordSuccessOnInvalidEmail","message","handleVerificationEmailRequest","OTHER_CAUSE","send","regenerateEmailVerifyToken","sendVerificationEmail","handleChallenge","challengeData","parseUser","id","findUsersWithAuthData","getRequestObject","isChallenge","validator","getValidatorForProvider","validatorResponse","logger","acc","sort","authAdapter","challenge","providerChallengeResponse","resolveError","SCRIPT_FAILED","userString","JSON","stringify","authenticationStep","mountRoutes","route","handleFind","promiseEnsureIdempotency","handleCreate","handleGet","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/UsersRouter.js"],"sourcesContent":["// These methods handle the User-related routes.\n\nimport Parse from 'parse/node';\nimport Config from '../Config';\nimport AccountLockout from '../AccountLockout';\nimport ClassesRouter from './ClassesRouter';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport passwordCrypto from '../password';\nimport {\n  maybeRunTrigger,\n  Types as TriggerTypes,\n  getRequestObject,\n  resolveError,\n  inflate,\n} from '../triggers';\nimport { promiseEnsureIdempotency } from '../middlewares';\nimport RestWrite from '../RestWrite';\nimport { logger } from '../logger';\nimport { createSanitizedError } from '../Error';\n\nexport class UsersRouter extends ClassesRouter {\n  className() {\n    return '_User';\n  }\n\n  /**\n   * Removes all \"_\" prefixed properties from an object, except \"__type\"\n   * @param {Object} obj An object.\n   */\n  static removeHiddenProperties(obj) {\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        // Regexp comes from Parse.Object.prototype.validate\n        if (key !== '__type' && !/^[A-Za-z][0-9A-Za-z_]*$/.test(key)) {\n          delete obj[key];\n        }\n      }\n    }\n  }\n\n  /**\n   * After retrieving a user directly from the database, we need to remove the\n   * password from the object (for security), and fix an issue some SDKs have\n   * with null values\n   */\n  _sanitizeAuthData(user) {\n    delete user.password;\n\n    // Sometimes the authData still has null on that keys\n    // https://github.com/parse-community/parse-server/issues/935\n    if (user.authData) {\n      Object.keys(user.authData).forEach(provider => {\n        if (user.authData[provider] === null) {\n          delete user.authData[provider];\n        }\n      });\n      if (Object.keys(user.authData).length == 0) {\n        delete user.authData;\n      }\n    }\n  }\n\n  /**\n   * Validates a password request in login and verifyPassword\n   * @param {Object} req The request\n   * @returns {Object} User object\n   * @private\n   */\n  _authenticateUserFromRequest(req) {\n    return new Promise((resolve, reject) => {\n      // Use query parameters instead if provided in url\n      let payload = req.body || {};\n      if (\n        (!payload.username && req.query && req.query.username) ||\n        (!payload.email && req.query && req.query.email)\n      ) {\n        payload = req.query;\n      }\n      const { username, email, password, ignoreEmailVerification } = payload;\n\n      // TODO: use the right error codes / descriptions.\n      if (!username && !email) {\n        throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'username/email is required.');\n      }\n      if (!password) {\n        throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'password is required.');\n      }\n      if (\n        typeof password !== 'string' ||\n        (email && typeof email !== 'string') ||\n        (username && typeof username !== 'string')\n      ) {\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n      }\n\n      let user;\n      let isValidPassword = false;\n      let query;\n      if (email && username) {\n        query = { email, username };\n      } else if (email) {\n        query = { email };\n      } else {\n        query = { $or: [{ username }, { email: username }] };\n      }\n      return req.config.database\n        .find('_User', query, {}, Auth.maintenance(req.config))\n        .then(results => {\n          if (!results.length) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n\n          if (results.length > 1) {\n            // corner case where user1 has username == user2 email\n            req.config.loggerController.warn(\n              \"There is a user which email is the same as another user's username, logging in based on username\"\n            );\n            user = results.filter(user => user.username === username)[0];\n          } else {\n            user = results[0];\n          }\n\n          return passwordCrypto.compare(password, user.password);\n        })\n        .then(correct => {\n          isValidPassword = correct;\n          const accountLockoutPolicy = new AccountLockout(user, req.config);\n          return accountLockoutPolicy.handleLoginAttempt(isValidPassword);\n        })\n        .then(async () => {\n          if (!isValidPassword) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Ensure the user isn't locked out\n          // A locked out user won't be able to login\n          // To lock a user out, just set the ACL to `masterKey` only  ({}).\n          // Empty ACL is OK\n          if (!req.auth.isMaster && user.ACL && Object.keys(user.ACL).length == 0) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Invalid username/password.');\n          }\n          // Create request object for verification functions\n          const authProvider =\n            req.body &&\n            req.body.authData &&\n            Object.keys(req.body.authData).length &&\n            Object.keys(req.body.authData).join(',');\n          const request = {\n            master: req.auth.isMaster,\n            ip: req.config.ip,\n            installationId: req.auth.installationId,\n            object: Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n            createdWith: RestWrite.buildCreatedWith('login', authProvider),\n          };\n\n          // If request doesn't use master or maintenance key with ignoring email verification\n          if (!((req.auth.isMaster || req.auth.isMaintenance) && ignoreEmailVerification)) {\n\n            // Get verification conditions which can be booleans or functions; the purpose of this async/await\n            // structure is to avoid unnecessarily executing subsequent functions if previous ones fail in the\n            // conditional statement below, as a developer may decide to execute expensive operations in them\n            const verifyUserEmails = async () => req.config.verifyUserEmails === true || (typeof req.config.verifyUserEmails === 'function' && await Promise.resolve(req.config.verifyUserEmails(request)) === true);\n            const preventLoginWithUnverifiedEmail = async () => req.config.preventLoginWithUnverifiedEmail === true || (typeof req.config.preventLoginWithUnverifiedEmail === 'function' && await Promise.resolve(req.config.preventLoginWithUnverifiedEmail(request)) === true);\n            if (await verifyUserEmails() && await preventLoginWithUnverifiedEmail() && !user.emailVerified) {\n              throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, 'User email is not verified.');\n            }\n          }\n\n          this._sanitizeAuthData(user);\n\n          return resolve(user);\n        })\n        .catch(error => {\n          return reject(error);\n        });\n    });\n  }\n\n  handleMe(req) {\n    if (!req.info || !req.info.sessionToken) {\n      throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n    }\n    const sessionToken = req.info.sessionToken;\n    return rest\n      .find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken },\n        { include: 'user' },\n        req.info.clientSDK,\n        req.info.context\n      )\n      .then(response => {\n        if (!response.results || response.results.length == 0 || !response.results[0].user) {\n          throw createSanitizedError(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token', req.config);\n        } else {\n          const user = response.results[0].user;\n          // Send token back on the login, because SDKs expect that.\n          user.sessionToken = sessionToken;\n\n          // Remove hidden properties.\n          UsersRouter.removeHiddenProperties(user);\n          return { response: user };\n        }\n      });\n  }\n\n  async handleLogIn(req) {\n    const user = await this._authenticateUserFromRequest(req);\n    const authData = req.body && req.body.authData;\n    // Check if user has provided their required auth providers\n    Auth.checkIfUserHasProvidedConfiguredProvidersForLogin(\n      req,\n      authData,\n      user.authData,\n      req.config\n    );\n\n    let authDataResponse;\n    let validatedAuthData;\n    if (authData) {\n      const res = await Auth.handleAuthDataValidation(\n        authData,\n        new RestWrite(\n          req.config,\n          req.auth,\n          '_User',\n          { objectId: user.objectId },\n          req.body || {},\n          user,\n          req.info.clientSDK,\n          req.info.context\n        ),\n        user\n      );\n      authDataResponse = res.authDataResponse;\n      validatedAuthData = res.authData;\n    }\n\n    // handle password expiry policy\n    if (req.config.passwordPolicy && req.config.passwordPolicy.maxPasswordAge) {\n      let changedAt = user._password_changed_at;\n\n      if (!changedAt) {\n        // password was created before expiry policy was enabled.\n        // simply update _User object so that it will start enforcing from now\n        changedAt = new Date();\n        req.config.database.update(\n          '_User',\n          { username: user.username },\n          { _password_changed_at: Parse._encode(changedAt) }\n        );\n      } else {\n        // check whether the password has expired\n        if (changedAt.__type == 'Date') {\n          changedAt = new Date(changedAt.iso);\n        }\n        // Calculate the expiry time.\n        const expiresAt = new Date(\n          changedAt.getTime() + 86400000 * req.config.passwordPolicy.maxPasswordAge\n        );\n        if (expiresAt < new Date())\n        // fail of current time is past password expiry time\n        { throw new Parse.Error(\n          Parse.Error.OBJECT_NOT_FOUND,\n          'Your password has expired. Please reset your password.'\n        ); }\n      }\n    }\n\n    // Remove hidden properties.\n    UsersRouter.removeHiddenProperties(user);\n\n    await req.config.filesController.expandFilesInObject(req.config, user);\n\n    // Before login trigger; throws if failure\n    await maybeRunTrigger(\n      TriggerTypes.beforeLogin,\n      req.auth,\n      Parse.User.fromJSON(Object.assign({ className: '_User' }, user)),\n      null,\n      req.config,\n      req.info.context\n    );\n\n    // If we have some new validated authData update directly\n    if (validatedAuthData && Object.keys(validatedAuthData).length) {\n      await req.config.database.update(\n        '_User',\n        { objectId: user.objectId },\n        { authData: validatedAuthData },\n        {}\n      );\n    }\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId: user.objectId,\n      createdWith: RestWrite.buildCreatedWith('login'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    const afterLoginUser = Parse.User.fromJSON(Object.assign({ className: '_User' }, user));\n    await maybeRunTrigger(\n      TriggerTypes.afterLogin,\n      { ...req.auth, user: afterLoginUser },\n      afterLoginUser,\n      null,\n      req.config,\n      req.info.context\n    );\n\n    if (authDataResponse) {\n      user.authDataResponse = authDataResponse;\n    }\n    await req.config.authDataManager.runAfterFind(req, user.authData);\n\n    return { response: user };\n  }\n\n  /**\n   * This allows master-key clients to create user sessions without access to\n   * user credentials. This enables systems that can authenticate access another\n   * way (API key, app administrators) to act on a user's behalf.\n   *\n   * We create a new session rather than looking for an existing session; we\n   * want this to work in situations where the user is logged out on all\n   * devices, since this can be used by automated systems acting on the user's\n   * behalf.\n   *\n   * For the moment, we're omitting event hooks and lockout checks, since\n   * immediate use cases suggest /loginAs could be used for semantically\n   * different reasons from /login\n   */\n  async handleLogInAs(req) {\n    if (!req.auth.isMaster) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        'master key is required',\n        req.config\n      );\n    }\n    if (req.auth.isReadOnly) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        \"read-only masterKey isn't allowed to login as another user.\",\n        req.config\n      );\n    }\n\n    const userId = req.body?.userId || req.query.userId;\n    if (!userId) {\n      throw new Parse.Error(\n        Parse.Error.INVALID_VALUE,\n        'userId must not be empty, null, or undefined'\n      );\n    }\n\n    const queryResults = await req.config.database.find('_User', { objectId: userId });\n    const user = queryResults[0];\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'user not found');\n    }\n\n    this._sanitizeAuthData(user);\n\n    const { sessionData, createSession } = RestWrite.createSession(req.config, {\n      userId,\n      createdWith: RestWrite.buildCreatedWith('login', 'masterkey'),\n      installationId: req.info.installationId,\n    });\n\n    user.sessionToken = sessionData.sessionToken;\n\n    await createSession();\n\n    return { response: user };\n  }\n\n  handleVerifyPassword(req) {\n    return this._authenticateUserFromRequest(req)\n      .then(user => {\n        // Remove hidden properties.\n        UsersRouter.removeHiddenProperties(user);\n\n        return { response: user };\n      })\n      .catch(error => {\n        throw error;\n      });\n  }\n\n  async handleLogOut(req) {\n    const success = { response: {} };\n    if (req.info && req.info.sessionToken) {\n      const records = await rest.find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      );\n      if (records.results && records.results.length) {\n        await rest.del(\n          req.config,\n          Auth.master(req.config),\n          '_Session',\n          records.results[0].objectId,\n          req.info.context\n        );\n        await maybeRunTrigger(\n          TriggerTypes.afterLogout,\n          req.auth,\n          Parse.Session.fromJSON(Object.assign({ className: '_Session' }, records.results[0])),\n          null,\n          req.config\n        );\n      }\n    }\n    return success;\n  }\n\n  _throwOnBadEmailConfig(req) {\n    try {\n      Config.validateEmailConfiguration({\n        emailAdapter: req.config.userController.adapter,\n        appName: req.config.appName,\n        publicServerURL: req.config.publicServerURL || req.config._publicServerURL,\n        emailVerifyTokenValidityDuration: req.config.emailVerifyTokenValidityDuration,\n        emailVerifyTokenReuseIfValid: req.config.emailVerifyTokenReuseIfValid,\n      });\n    } catch (e) {\n      if (typeof e === 'string') {\n        // Maybe we need a Bad Configuration error, but the SDKs won't understand it. For now, Internal Server Error.\n        throw new Parse.Error(\n          Parse.Error.INTERNAL_SERVER_ERROR,\n          'An appName, publicServerURL, and emailAdapter are required for password reset and email verification functionality.'\n        );\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  async handleResetRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    let email = req.body?.email;\n    const token = req.body?.token;\n\n    if (!email && !token) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n\n    let userResults = null;\n    let userData = null;\n\n    // We can find the user using token\n    if (token) {\n      userResults = await req.config.database.find('_User', {\n        _perishable_token: token,\n        _perishable_token_expires_at: { $lt: Parse._encode(new Date()) },\n      });\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n        if (userData.email) {\n          email = userData.email;\n        }\n      }\n    // Or using email if no token provided\n    } else if (typeof email === 'string') {\n      userResults = await req.config.database.find(\n        '_User',\n        { $or: [{ email }, { username: email, email: { $exists: false } }] },\n        { limit: 1 },\n        Auth.maintenance(req.config)\n      );\n      if (userResults?.length > 0) {\n        userData = userResults[0];\n      }\n    }\n\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    if (userData) {\n      this._sanitizeAuthData(userData);\n      // Get files attached to user\n      await req.config.filesController.expandFilesInObject(req.config, userData);\n\n      const user = inflate('_User', userData);\n\n      await maybeRunTrigger(\n        TriggerTypes.beforePasswordResetRequest,\n        req.auth,\n        user,\n        null,\n        req.config,\n        req.info.context\n      );\n    }\n\n    const userController = req.config.userController;\n    try {\n      await userController.sendPasswordResetEmail(email);\n      return {\n        response: {},\n      };\n    } catch (err) {\n      if (err.code === Parse.Error.OBJECT_NOT_FOUND) {\n        if (req.config.passwordPolicy?.resetPasswordSuccessOnInvalidEmail ?? true) {\n          return {\n            response: {},\n          };\n        }\n        err.message = `A user with that email does not exist.`;\n      }\n      throw err;\n    }\n  }\n\n  async handleVerificationEmailRequest(req) {\n    this._throwOnBadEmailConfig(req);\n\n    const { email } = req.body || {};\n    if (!email) {\n      throw new Parse.Error(Parse.Error.EMAIL_MISSING, 'you must provide an email');\n    }\n    if (typeof email !== 'string') {\n      throw new Parse.Error(\n        Parse.Error.INVALID_EMAIL_ADDRESS,\n        'you must provide a valid email string'\n      );\n    }\n\n    const results = await req.config.database.find('_User', { email: email }, {}, Auth.maintenance(req.config));\n    if (!results.length || results.length < 1) {\n      throw new Parse.Error(Parse.Error.EMAIL_NOT_FOUND, `No user found with email ${email}`);\n    }\n    const user = results[0];\n\n    // remove password field, messes with saving on postgres\n    delete user.password;\n\n    if (user.emailVerified) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Email ${email} is already verified.`);\n    }\n\n    const userController = req.config.userController;\n    const send = await userController.regenerateEmailVerifyToken(user, req.auth.isMaster, req.auth.installationId, req.ip);\n    if (send) {\n      userController.sendVerificationEmail(user, req);\n    }\n    return { response: {} };\n  }\n\n  async handleChallenge(req) {\n    const { username, email, password, authData, challengeData } = req.body || {};\n\n    // if username or email provided with password try to authenticate the user by username\n    let user;\n    if (username || email) {\n      if (!password) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You provided username or email, you need to also provide password.'\n        );\n      }\n      user = await this._authenticateUserFromRequest(req);\n    }\n\n    if (!challengeData) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Nothing to challenge.');\n    }\n\n    if (typeof challengeData !== 'object') {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'challengeData should be an object.');\n    }\n\n    let request;\n    let parseUser;\n\n    // Try to find user by authData\n    if (authData) {\n      if (typeof authData !== 'object') {\n        throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'authData should be an object.');\n      }\n      if (user) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide username/email and authData, only use one identification method.'\n        );\n      }\n\n      if (Object.keys(authData).filter(key => authData[key].id).length > 1) {\n        throw new Parse.Error(\n          Parse.Error.OTHER_CAUSE,\n          'You cannot provide more than one authData provider with an id.'\n        );\n      }\n\n      const results = await Auth.findUsersWithAuthData(req.config, authData);\n\n      try {\n        if (!results[0] || results.length > 1) {\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n        }\n        // Find the provider used to find the user\n        const provider = Object.keys(authData).find(key => authData[key].id);\n\n        parseUser = Parse.User.fromJSON({ className: '_User', ...results[0] });\n        request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n        request.isChallenge = true;\n        // Validate authData used to identify the user to avoid brute-force attack on `id`\n        const { validator } = req.config.authDataManager.getValidatorForProvider(provider);\n        const validatorResponse = await validator(authData[provider], req, parseUser, request);\n        if (validatorResponse && validatorResponse.validator) {\n          await validatorResponse.validator();\n        }\n      } catch (e) {\n        // Rewrite the error to avoid guess id attack\n        logger.error(e);\n        throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'User not found.');\n      }\n    }\n\n    if (!parseUser) {\n      parseUser = user ? Parse.User.fromJSON({ className: '_User', ...user }) : undefined;\n    }\n\n    if (!request) {\n      request = getRequestObject(undefined, req.auth, parseUser, parseUser, req.config);\n      request.isChallenge = true;\n    }\n    const acc = {};\n    // Execute challenge step-by-step with consistent order for better error feedback\n    // and to avoid to trigger others challenges if one of them fails\n    for (const provider of Object.keys(challengeData).sort()) {\n      try {\n        const authAdapter = req.config.authDataManager.getValidatorForProvider(provider);\n        if (!authAdapter) {\n          continue;\n        }\n        const {\n          adapter: { challenge },\n        } = authAdapter;\n        if (typeof challenge === 'function') {\n          const providerChallengeResponse = await challenge(\n            challengeData[provider],\n            authData && authData[provider],\n            req.config.auth[provider],\n            request\n          );\n          acc[provider] = providerChallengeResponse || true;\n        }\n      } catch (err) {\n        const e = resolveError(err, {\n          code: Parse.Error.SCRIPT_FAILED,\n          message: 'Challenge failed. Unknown error.',\n        });\n        const userString = req.auth && req.auth.user ? req.auth.user.id : undefined;\n        logger.error(\n          `Failed running auth step challenge for ${provider} for user ${userString} with Error: ` +\n            JSON.stringify(e),\n          {\n            authenticationStep: 'challenge',\n            error: e,\n            user: userString,\n            provider,\n          }\n        );\n        throw e;\n      }\n    }\n    return { response: { challengeData: acc } };\n  }\n\n  mountRoutes() {\n    this.route('GET', '/users', req => {\n      return this.handleFind(req);\n    });\n    this.route('POST', '/users', promiseEnsureIdempotency, req => {\n      return this.handleCreate(req);\n    });\n    this.route('GET', '/users/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/users/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('PUT', '/users/:objectId', promiseEnsureIdempotency, req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/users/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('GET', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/login', req => {\n      return this.handleLogIn(req);\n    });\n    this.route('POST', '/loginAs', req => {\n      return this.handleLogInAs(req);\n    });\n    this.route('POST', '/logout', req => {\n      return this.handleLogOut(req);\n    });\n    this.route('POST', '/requestPasswordReset', req => {\n      return this.handleResetRequest(req);\n    });\n    this.route('POST', '/verificationEmailRequest', req => {\n      return this.handleVerificationEmailRequest(req);\n    });\n    this.route('GET', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/verifyPassword', req => {\n      return this.handleVerifyPassword(req);\n    });\n    this.route('POST', '/challenge', req => {\n      return this.handleChallenge(req);\n    });\n  }\n}\n\nexport default UsersRouter;\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "parse-server",
|
|
3
|
-
"version": "9.5.0-alpha.
|
|
3
|
+
"version": "9.5.0-alpha.4",
|
|
4
4
|
"description": "An express module providing a Parse-compatible API server",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"repository": {
|
|
@@ -137,7 +137,7 @@
|
|
|
137
137
|
"postinstall": "node -p 'require(\"./postinstall.js\")()'",
|
|
138
138
|
"madge:circular": "node_modules/.bin/madge ./src --circular",
|
|
139
139
|
"benchmark": "cross-env MONGODB_VERSION=8.0.4 MONGODB_TOPOLOGY=standalone mongodb-runner exec -t standalone --version 8.0.4 -- --port 27017 -- npm run benchmark:only",
|
|
140
|
-
"benchmark:only": "node benchmark/performance.js",
|
|
140
|
+
"benchmark:only": "node --expose-gc benchmark/performance.js",
|
|
141
141
|
"benchmark:quick": "cross-env BENCHMARK_ITERATIONS=10 npm run benchmark:only"
|
|
142
142
|
},
|
|
143
143
|
"types": "types/index.d.ts",
|