parse-server 9.5.1-alpha.2 → 9.5.2-alpha.1

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.
@@ -108,7 +108,8 @@ class PagesRouter extends _PromiseRouter.default {
108
108
  resendVerificationEmail(req) {
109
109
  const config = req.config;
110
110
  const username = req.body?.username;
111
- const token = req.body?.token;
111
+ const rawToken = req.body?.token;
112
+ const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
112
113
  if (!config) {
113
114
  this.invalidRequest();
114
115
  }
@@ -648,4 +649,4 @@ module.exports = {
648
649
  pageParams,
649
650
  pages
650
651
  };
651
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","_Config","_express","_path","_fs","_node","_Utils","_mustache","_Page","e","__esModule","default","pages","Object","freeze","passwordReset","Page","id","defaultFile","passwordResetSuccess","passwordResetLinkInvalid","emailVerificationSuccess","emailVerificationSendFail","emailVerificationSendSuccess","emailVerificationLinkInvalid","emailVerificationLinkExpired","pageParams","appName","appId","token","username","error","locale","publicServerUrl","pageParamHeaderPrefix","errors","jsonFailedFileLoading","fileOutsideAllowedScope","PagesRouter","PromiseRouter","constructor","pagesConfig","pagesEndpoint","pagesPath","path","resolve","__dirname","loadJsonResource","mountPagesRoutes","mountCustomRoutes","mountStaticRoute","verifyEmail","req","config","rawToken","query","toString","invalidRequest","goToPage","userController","then","resendVerificationEmail","body","params","publicServerURL","requestResetPassword","checkResetTokenValidity","applicationId","resetPassword","new_password","xhr","Parse","Error","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","Promise","success","err","result","status","response","page","responseType","redirect","forceRedirect","undefined","method","defaultParams","getDefaultParams","values","includes","notFound","assign","getLocale","defaultPath","defaultPagePath","defaultUrl","composePageUrl","customUrl","customUrls","Utils","isPath","redirectResponse","placeholders","enableLocalization","localizationJsonPath","getJsonPlaceholders","getLocalizedPath","subdir","pageResponse","staticRoute","relativePath","absolutePath","endsWith","fileResponse","getJsonTranslation","jsonParameters","localizationFallbackLocale","language","split","resource","translation","JSON","stringify","mustache","render","parse","data","readFile","configPlaceholders","prototype","call","allPlaceholders","paramsAndPlaceholders","encode","encodePageParamHeaders","headers","entries","reduce","m","p","toLowerCase","encodeURIComponent","text","filePath","normalizedPath","normalize","startsWith","sep","fs","json","url","location","URL","forEach","searchParams","set","locationString","file","join","message","setConfig","failGracefully","Config","get","loadKeys","route","customRoutes","handler","expressRouter","router","express","Router","use","exports","_default","module"],"sources":["../../src/Routers/PagesRouter.js"],"sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport Config from '../Config';\nimport express from 'express';\nimport path from 'path';\nimport { promises as fs } from 'fs';\nimport { Parse } from 'parse/node';\nimport Utils from '../Utils';\nimport mustache from 'mustache';\nimport Page from '../Page';\n\n// All pages with custom page key for reference and file name\nconst pages = Object.freeze({\n  passwordReset: new Page({ id: 'passwordReset', defaultFile: 'password_reset.html' }),\n  passwordResetSuccess: new Page({\n    id: 'passwordResetSuccess',\n    defaultFile: 'password_reset_success.html',\n  }),\n  passwordResetLinkInvalid: new Page({\n    id: 'passwordResetLinkInvalid',\n    defaultFile: 'password_reset_link_invalid.html',\n  }),\n  emailVerificationSuccess: new Page({\n    id: 'emailVerificationSuccess',\n    defaultFile: 'email_verification_success.html',\n  }),\n  emailVerificationSendFail: new Page({\n    id: 'emailVerificationSendFail',\n    defaultFile: 'email_verification_send_fail.html',\n  }),\n  emailVerificationSendSuccess: new Page({\n    id: 'emailVerificationSendSuccess',\n    defaultFile: 'email_verification_send_success.html',\n  }),\n  emailVerificationLinkInvalid: new Page({\n    id: 'emailVerificationLinkInvalid',\n    defaultFile: 'email_verification_link_invalid.html',\n  }),\n  emailVerificationLinkExpired: new Page({\n    id: 'emailVerificationLinkExpired',\n    defaultFile: 'email_verification_link_expired.html',\n  }),\n});\n\n// All page parameters for reference to be used as template placeholders or query params\nconst pageParams = Object.freeze({\n  appName: 'appName',\n  appId: 'appId',\n  token: 'token',\n  username: 'username',\n  error: 'error',\n  locale: 'locale',\n  publicServerUrl: 'publicServerUrl',\n});\n\n// The header prefix to add page params as response headers\nconst pageParamHeaderPrefix = 'x-parse-page-param-';\n\n// The errors being thrown\nconst errors = Object.freeze({\n  jsonFailedFileLoading: 'failed to load JSON file',\n  fileOutsideAllowedScope: 'not allowed to read file outside of pages directory',\n});\n\nexport class PagesRouter extends PromiseRouter {\n  /**\n   * Constructs a PagesRouter.\n   * @param {Object} pages The pages options from the Parse Server configuration.\n   */\n  constructor(pages = {}) {\n    super();\n\n    // Set instance properties\n    this.pagesConfig = pages;\n    this.pagesEndpoint = pages.pagesEndpoint ? pages.pagesEndpoint : 'apps';\n    this.pagesPath = pages.pagesPath\n      ? path.resolve('./', pages.pagesPath)\n      : path.resolve(__dirname, '../../public');\n    this.loadJsonResource();\n    this.mountPagesRoutes();\n    this.mountCustomRoutes();\n    this.mountStaticRoute();\n  }\n\n  verifyEmail(req) {\n    const config = req.config;\n    const { token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!token) {\n      return this.goToPage(req, pages.emailVerificationLinkInvalid);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(token).then(\n      () => {\n        return this.goToPage(req, pages.emailVerificationSuccess);\n      },\n      () => {\n        return this.goToPage(req, pages.emailVerificationLinkInvalid);\n      }\n    );\n  }\n\n  resendVerificationEmail(req) {\n    const config = req.config;\n    const username = req.body?.username;\n    const token = req.body?.token;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!username && !token) {\n      return this.goToPage(req, pages.emailVerificationLinkInvalid);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username, req, token).then(\n      () => {\n        return this.goToPage(req, pages.emailVerificationSendSuccess);\n      },\n      () => {\n        return this.goToPage(req, pages.emailVerificationSendFail);\n      }\n    );\n  }\n\n  passwordReset(req) {\n    const config = req.config;\n    const params = {\n      [pageParams.appId]: req.params.appId,\n      [pageParams.appName]: config.appName,\n      [pageParams.token]: req.query.token,\n      [pageParams.username]: req.query.username,\n      [pageParams.publicServerUrl]: config.publicServerURL,\n    };\n    return this.goToPage(req, pages.passwordReset, params);\n  }\n\n  requestResetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    const { token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!token) {\n      return this.goToPage(req, pages.passwordResetLinkInvalid);\n    }\n\n    return config.userController.checkResetTokenValidity(token).then(\n      () => {\n        const params = {\n          [pageParams.token]: token,\n          [pageParams.appId]: config.applicationId,\n          [pageParams.appName]: config.appName,\n        };\n        return this.goToPage(req, pages.passwordReset, params);\n      },\n      () => {\n        return this.goToPage(req, pages.passwordResetLinkInvalid);\n      }\n    );\n  }\n\n  resetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    const { new_password, token: rawToken } = req.body || {};\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!token || !new_password) && req.xhr === false) {\n      return this.goToPage(req, pages.passwordResetLinkInvalid);\n    }\n\n    if (!token) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Missing token');\n    }\n\n    if (!new_password) {\n      throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'Missing password');\n    }\n\n    return config.userController\n      .updatePassword(token, new_password)\n      .then(\n        () => {\n          return Promise.resolve({\n            success: true,\n          });\n        },\n        err => {\n          return Promise.resolve({\n            success: false,\n            err,\n          });\n        }\n      )\n      .then(result => {\n        if (req.xhr) {\n          if (result.success) {\n            return Promise.resolve({\n              status: 200,\n              response: 'Password successfully reset',\n            });\n          }\n          if (result.err) {\n            throw new Parse.Error(Parse.Error.OTHER_CAUSE, `${result.err}`);\n          }\n        }\n\n        const query = result.success\n          ? {}\n          : {\n            [pageParams.token]: token,\n            [pageParams.appId]: config.applicationId,\n            [pageParams.error]: result.err,\n            [pageParams.appName]: config.appName,\n          };\n\n        if (result?.err === 'The password reset link has expired') {\n          delete query[pageParams.token];\n          query[pageParams.token] = token;\n        }\n        const page = result.success ? pages.passwordResetSuccess : pages.passwordReset;\n\n        return this.goToPage(req, page, query, false);\n      });\n  }\n\n  /**\n   * Returns page content if the page is a local file or returns a\n   * redirect to a custom page.\n   * @param {Object} req The express request.\n   * @param {Page} page The page to go to.\n   * @param {Object} [params={}] The query parameters to attach to the URL in case of\n   * HTTP redirect responses for POST requests, or the placeholders to fill into\n   * the response content in case of HTTP content responses for GET requests.\n   * @param {Boolean} [responseType] Is true if a redirect response should be forced,\n   * false if a content response should be forced, undefined if the response type\n   * should depend on the request type by default:\n   * - GET request -> content response\n   * - POST request -> redirect response (PRG pattern)\n   * @returns {Promise<Object>} The PromiseRouter response.\n   */\n  goToPage(req, page, params = {}, responseType) {\n    const config = req.config;\n\n    // Determine redirect either by force, response setting or request method\n    const redirect = config.pages.forceRedirect\n      ? true\n      : responseType !== undefined\n        ? responseType\n        : req.method == 'POST';\n\n    // Include default parameters\n    const defaultParams = this.getDefaultParams(config);\n    if (Object.values(defaultParams).includes(undefined)) {\n      return this.notFound();\n    }\n    params = Object.assign(params, defaultParams);\n\n    // Add locale to params to ensure it is passed on with every request;\n    // that means, once a locale is set, it is passed on to any follow-up page,\n    // e.g. request_password_reset -> password_reset -> password_reset_success\n    const locale = this.getLocale(req);\n    params[pageParams.locale] = locale;\n\n    // Compose paths and URLs\n    const defaultFile = page.defaultFile;\n    const defaultPath = this.defaultPagePath(defaultFile);\n    const defaultUrl = this.composePageUrl(defaultFile, config.publicServerURL);\n\n    // If custom URL is set redirect to it without localization\n    const customUrl = config.pages.customUrls[page.id];\n    if (customUrl && !Utils.isPath(customUrl)) {\n      return this.redirectResponse(customUrl, params);\n    }\n\n    // Get JSON placeholders\n    let placeholders = {};\n    if (config.pages.enableLocalization && config.pages.localizationJsonPath) {\n      placeholders = this.getJsonPlaceholders(locale, params);\n    }\n\n    // Send response\n    if (config.pages.enableLocalization && locale) {\n      return Utils.getLocalizedPath(defaultPath, locale).then(({ path, subdir }) =>\n        redirect\n          ? this.redirectResponse(\n            this.composePageUrl(defaultFile, config.publicServerURL, subdir),\n            params\n          )\n          : this.pageResponse(path, params, placeholders)\n      );\n    } else {\n      return redirect\n        ? this.redirectResponse(defaultUrl, params)\n        : this.pageResponse(defaultPath, params, placeholders);\n    }\n  }\n\n  /**\n   * Serves a request to a static resource and localizes the resource if it\n   * is a HTML file.\n   * @param {Object} req The request object.\n   * @returns {Promise<Object>} The response.\n   */\n  staticRoute(req) {\n    // Get requested path\n    const relativePath = req.params['resource'][0];\n\n    // Resolve requested path to absolute path\n    const absolutePath = path.resolve(this.pagesPath, relativePath);\n\n    // If the requested file is not a HTML file send its raw content\n    if (!absolutePath || !absolutePath.endsWith('.html')) {\n      return this.fileResponse(absolutePath);\n    }\n\n    // Get parameters\n    const params = this.getDefaultParams(req.config);\n    const locale = this.getLocale(req);\n    if (locale) {\n      params.locale = locale;\n    }\n\n    // Get JSON placeholders\n    const placeholders = this.getJsonPlaceholders(locale, params);\n\n    return this.pageResponse(absolutePath, params, placeholders);\n  }\n\n  /**\n   * Returns a translation from the JSON resource for a given locale. The JSON\n   * resource is parsed according to i18next syntax.\n   *\n   * Example JSON content:\n   * ```js\n   *  {\n   *    \"en\": {               // resource for language `en` (English)\n   *      \"translation\": {\n   *        \"greeting\": \"Hello!\"\n   *      }\n   *    },\n   *    \"de\": {               // resource for language `de` (German)\n   *      \"translation\": {\n   *        \"greeting\": \"Hallo!\"\n   *      }\n   *    }\n   *    \"de-CH\": {            // resource for locale `de-CH` (Swiss German)\n   *      \"translation\": {\n   *        \"greeting\": \"Grüezi!\"\n   *      }\n   *    }\n   *  }\n   * ```\n   * @param {String} locale The locale to translate to.\n   * @returns {Object} The translation or an empty object if no matching\n   * translation was found.\n   */\n  getJsonTranslation(locale) {\n    // If there is no JSON resource\n    if (this.jsonParameters === undefined) {\n      return {};\n    }\n\n    // If locale is not set use the fallback locale\n    locale = locale || this.pagesConfig.localizationFallbackLocale;\n\n    // Get matching translation by locale, language or fallback locale\n    const language = locale.split('-')[0];\n    const resource =\n      this.jsonParameters[locale] ||\n      this.jsonParameters[language] ||\n      this.jsonParameters[this.pagesConfig.localizationFallbackLocale] ||\n      {};\n    const translation = resource.translation || {};\n    return translation;\n  }\n\n  /**\n   * Returns a translation from the JSON resource for a given locale with\n   * placeholders filled in by given parameters.\n   * @param {String} locale The locale to translate to.\n   * @param {Object} params The parameters to fill into any placeholders\n   * within the translations.\n   * @returns {Object} The translation or an empty object if no matching\n   * translation was found.\n   */\n  getJsonPlaceholders(locale, params = {}) {\n    // If localization is disabled or there is no JSON resource\n    if (!this.pagesConfig.enableLocalization || !this.pagesConfig.localizationJsonPath) {\n      return {};\n    }\n\n    // Get JSON placeholders\n    let placeholders = this.getJsonTranslation(locale);\n\n    // Fill in any placeholders in the translation; this allows a translation\n    // to contain default placeholders like {{appName}} which are filled here\n    placeholders = JSON.stringify(placeholders);\n    placeholders = mustache.render(placeholders, params);\n    placeholders = JSON.parse(placeholders);\n\n    return placeholders;\n  }\n\n  /**\n   * Creates a response with file content.\n   * @param {String} path The path of the file to return.\n   * @param {Object} [params={}] The parameters to be included in the response\n   * header. These will also be used to fill placeholders.\n   * @param {Object} [placeholders={}] The placeholders to fill in the content.\n   * These will not be included in the response header.\n   * @returns {Object} The Promise Router response.\n   */\n  async pageResponse(path, params = {}, placeholders = {}) {\n    // Get file content\n    let data;\n    try {\n      data = await this.readFile(path);\n    } catch {\n      return this.notFound();\n    }\n\n    // Get config placeholders; can be an object, a function or an async function\n    let configPlaceholders =\n      typeof this.pagesConfig.placeholders === 'function'\n        ? this.pagesConfig.placeholders(params)\n        : Object.prototype.toString.call(this.pagesConfig.placeholders) === '[object Object]'\n          ? this.pagesConfig.placeholders\n          : {};\n    if (configPlaceholders instanceof Promise) {\n      configPlaceholders = await configPlaceholders;\n    }\n\n    // Fill placeholders\n    const allPlaceholders = Object.assign({}, configPlaceholders, placeholders);\n    const paramsAndPlaceholders = Object.assign({}, params, allPlaceholders);\n    data = mustache.render(data, paramsAndPlaceholders);\n\n    // Add placeholders in header to allow parsing for programmatic use\n    // of response, instead of having to parse the HTML content.\n    const encode = this.pagesConfig.encodePageParamHeaders;\n    const headers = Object.entries(params).reduce((m, p) => {\n      if (p[1] !== undefined) {\n        m[`${pageParamHeaderPrefix}${p[0].toLowerCase()}`] = encode ? encodeURIComponent(p[1]) : p[1];\n      }\n      return m;\n    }, {});\n\n    return { text: data, headers: headers };\n  }\n\n  /**\n   * Creates a response with file content.\n   * @param {String} path The path of the file to return.\n   * @returns {Object} The PromiseRouter response.\n   */\n  async fileResponse(path) {\n    // Get file content\n    let data;\n    try {\n      data = await this.readFile(path);\n    } catch {\n      return this.notFound();\n    }\n\n    return { text: data };\n  }\n\n  /**\n   * Reads and returns the content of a file at a given path. File reading to\n   * serve content on the static route is only allowed from the pages\n   * directory on downwards.\n   * -----------------------------------------------------------------------\n   * **WARNING:** All file reads in the PagesRouter must be executed by this\n   * wrapper because it also detects and prevents common exploits.\n   * -----------------------------------------------------------------------\n   * @param {String} filePath The path to the file to read.\n   * @returns {Promise<String>} The file content.\n   */\n  async readFile(filePath) {\n    // Normalize path to prevent it from containing any directory changing\n    // UNIX patterns which could expose the whole file system, e.g.\n    // `http://example.com/parse/apps/../file.txt` requests a file outside\n    // of the pages directory scope.\n    const normalizedPath = path.normalize(filePath);\n\n    // Abort if the path is outside of the path directory scope\n    if (!normalizedPath.startsWith(this.pagesPath + path.sep)) {\n      throw errors.fileOutsideAllowedScope;\n    }\n\n    return await fs.readFile(normalizedPath, 'utf-8');\n  }\n\n  /**\n   * Loads a language resource JSON file that is used for translations.\n   */\n  loadJsonResource() {\n    if (this.pagesConfig.localizationJsonPath === undefined) {\n      return;\n    }\n    try {\n      const json = require(path.resolve('./', this.pagesConfig.localizationJsonPath));\n      this.jsonParameters = json;\n    } catch {\n      throw errors.jsonFailedFileLoading;\n    }\n  }\n\n  /**\n   * Extracts and returns the page default parameters from the Parse Server\n   * configuration. These parameters are made accessible in every page served\n   * by this router.\n   * @param {Object} config The Parse Server configuration.\n   * @returns {Object} The default parameters.\n   */\n  getDefaultParams(config) {\n    return config\n      ? {\n        [pageParams.appId]: config.appId,\n        [pageParams.appName]: config.appName,\n        [pageParams.publicServerUrl]: config.publicServerURL,\n      }\n      : {};\n  }\n\n  /**\n   * Extracts and returns the locale from an express request.\n   * @param {Object} req The express request.\n   * @returns {String|undefined} The locale, or undefined if no locale was set.\n   */\n  getLocale(req) {\n    const locale =\n      (req.query || {})[pageParams.locale] ||\n      (req.body || {})[pageParams.locale] ||\n      (req.params || {})[pageParams.locale] ||\n      (req.headers || {})[pageParamHeaderPrefix + pageParams.locale];\n    return locale;\n  }\n\n  /**\n   * Creates a response with http redirect.\n   * @param {Object} req The express request.\n   * @param {String} path The path of the file to return.\n   * @param {Object} params The query parameters to include.\n   * @returns {Object} The Promise Router response.\n   */\n  async redirectResponse(url, params) {\n    // Remove any parameters with undefined value\n    params = Object.entries(params).reduce((m, p) => {\n      if (p[1] !== undefined) {\n        m[p[0]] = p[1];\n      }\n      return m;\n    }, {});\n\n    // Compose URL with parameters in query\n    const location = new URL(url);\n    Object.entries(params).forEach(p => location.searchParams.set(p[0], p[1]));\n    const locationString = location.toString();\n\n    // Add parameters to header to allow parsing for programmatic use\n    // of response, instead of having to parse the HTML content.\n    const encode = this.pagesConfig.encodePageParamHeaders;\n    const headers = Object.entries(params).reduce((m, p) => {\n      if (p[1] !== undefined) {\n        m[`${pageParamHeaderPrefix}${p[0].toLowerCase()}`] = encode ? encodeURIComponent(p[1]) : p[1];\n      }\n      return m;\n    }, {});\n\n    return {\n      status: 303,\n      location: locationString,\n      headers: headers,\n    };\n  }\n\n  defaultPagePath(file) {\n    return path.join(this.pagesPath, file);\n  }\n\n  composePageUrl(file, publicServerUrl, locale) {\n    let url = publicServerUrl;\n    url += url.endsWith('/') ? '' : '/';\n    url += this.pagesEndpoint + '/';\n    url += locale === undefined ? '' : locale + '/';\n    url += file;\n    return url;\n  }\n\n  notFound() {\n    return {\n      text: 'Not found.',\n      status: 404,\n    };\n  }\n\n  invalidRequest() {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized';\n    throw error;\n  }\n\n  /**\n   * Sets the Parse Server configuration in the request object to make it\n   * easily accessible throughtout request processing.\n   * @param {Object} req The request.\n   * @param {Boolean} failGracefully Is true if failing to set the config should\n   * not result in an invalid request response. Default is `false`.\n   */\n  async setConfig(req, failGracefully = false) {\n    req.config = Config.get(req.params.appId || req.query.appId);\n    if (!req.config && !failGracefully) {\n      this.invalidRequest();\n    }\n    if (req.config) {\n      await req.config.loadKeys();\n    }\n  }\n\n  mountPagesRoutes() {\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/:appId/verify_email`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.verifyEmail(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      `/${this.pagesEndpoint}/:appId/resend_verification_email`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.resendVerificationEmail(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/choose_password`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.passwordReset(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      `/${this.pagesEndpoint}/:appId/request_password_reset`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.resetPassword(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/:appId/request_password_reset`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.requestResetPassword(req);\n      }\n    );\n  }\n\n  mountCustomRoutes() {\n    for (const route of this.pagesConfig.customRoutes || []) {\n      this.route(\n        route.method,\n        `/${this.pagesEndpoint}/:appId/${route.path}`,\n        req => {\n          return this.setConfig(req);\n        },\n        async req => {\n          const { file, query = {} } = (await route.handler(req)) || {};\n\n          // If route handler did not return a page send 404 response\n          if (!file) {\n            return this.notFound();\n          }\n\n          // Send page response\n          const page = new Page({ id: file, defaultFile: file });\n          return this.goToPage(req, page, query, false);\n        }\n      );\n    }\n  }\n\n  mountStaticRoute() {\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/*resource`,\n      req => {\n        return this.setConfig(req, true);\n      },\n      req => {\n        return this.staticRoute(req);\n      }\n    );\n  }\n\n  expressRouter() {\n    const router = express.Router();\n    router.use('/', super.expressRouter());\n    return router;\n  }\n}\n\nexport default PagesRouter;\nmodule.exports = {\n  PagesRouter,\n  pageParamHeaderPrefix,\n  pageParams,\n  pages,\n};\n"],"mappings":"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","ignoreList":[]}
652
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","_Config","_express","_path","_fs","_node","_Utils","_mustache","_Page","e","__esModule","default","pages","Object","freeze","passwordReset","Page","id","defaultFile","passwordResetSuccess","passwordResetLinkInvalid","emailVerificationSuccess","emailVerificationSendFail","emailVerificationSendSuccess","emailVerificationLinkInvalid","emailVerificationLinkExpired","pageParams","appName","appId","token","username","error","locale","publicServerUrl","pageParamHeaderPrefix","errors","jsonFailedFileLoading","fileOutsideAllowedScope","PagesRouter","PromiseRouter","constructor","pagesConfig","pagesEndpoint","pagesPath","path","resolve","__dirname","loadJsonResource","mountPagesRoutes","mountCustomRoutes","mountStaticRoute","verifyEmail","req","config","rawToken","query","toString","invalidRequest","goToPage","userController","then","resendVerificationEmail","body","params","publicServerURL","requestResetPassword","checkResetTokenValidity","applicationId","resetPassword","new_password","xhr","Parse","Error","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","Promise","success","err","result","status","response","page","responseType","redirect","forceRedirect","undefined","method","defaultParams","getDefaultParams","values","includes","notFound","assign","getLocale","defaultPath","defaultPagePath","defaultUrl","composePageUrl","customUrl","customUrls","Utils","isPath","redirectResponse","placeholders","enableLocalization","localizationJsonPath","getJsonPlaceholders","getLocalizedPath","subdir","pageResponse","staticRoute","relativePath","absolutePath","endsWith","fileResponse","getJsonTranslation","jsonParameters","localizationFallbackLocale","language","split","resource","translation","JSON","stringify","mustache","render","parse","data","readFile","configPlaceholders","prototype","call","allPlaceholders","paramsAndPlaceholders","encode","encodePageParamHeaders","headers","entries","reduce","m","p","toLowerCase","encodeURIComponent","text","filePath","normalizedPath","normalize","startsWith","sep","fs","json","url","location","URL","forEach","searchParams","set","locationString","file","join","message","setConfig","failGracefully","Config","get","loadKeys","route","customRoutes","handler","expressRouter","router","express","Router","use","exports","_default","module"],"sources":["../../src/Routers/PagesRouter.js"],"sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport Config from '../Config';\nimport express from 'express';\nimport path from 'path';\nimport { promises as fs } from 'fs';\nimport { Parse } from 'parse/node';\nimport Utils from '../Utils';\nimport mustache from 'mustache';\nimport Page from '../Page';\n\n// All pages with custom page key for reference and file name\nconst pages = Object.freeze({\n  passwordReset: new Page({ id: 'passwordReset', defaultFile: 'password_reset.html' }),\n  passwordResetSuccess: new Page({\n    id: 'passwordResetSuccess',\n    defaultFile: 'password_reset_success.html',\n  }),\n  passwordResetLinkInvalid: new Page({\n    id: 'passwordResetLinkInvalid',\n    defaultFile: 'password_reset_link_invalid.html',\n  }),\n  emailVerificationSuccess: new Page({\n    id: 'emailVerificationSuccess',\n    defaultFile: 'email_verification_success.html',\n  }),\n  emailVerificationSendFail: new Page({\n    id: 'emailVerificationSendFail',\n    defaultFile: 'email_verification_send_fail.html',\n  }),\n  emailVerificationSendSuccess: new Page({\n    id: 'emailVerificationSendSuccess',\n    defaultFile: 'email_verification_send_success.html',\n  }),\n  emailVerificationLinkInvalid: new Page({\n    id: 'emailVerificationLinkInvalid',\n    defaultFile: 'email_verification_link_invalid.html',\n  }),\n  emailVerificationLinkExpired: new Page({\n    id: 'emailVerificationLinkExpired',\n    defaultFile: 'email_verification_link_expired.html',\n  }),\n});\n\n// All page parameters for reference to be used as template placeholders or query params\nconst pageParams = Object.freeze({\n  appName: 'appName',\n  appId: 'appId',\n  token: 'token',\n  username: 'username',\n  error: 'error',\n  locale: 'locale',\n  publicServerUrl: 'publicServerUrl',\n});\n\n// The header prefix to add page params as response headers\nconst pageParamHeaderPrefix = 'x-parse-page-param-';\n\n// The errors being thrown\nconst errors = Object.freeze({\n  jsonFailedFileLoading: 'failed to load JSON file',\n  fileOutsideAllowedScope: 'not allowed to read file outside of pages directory',\n});\n\nexport class PagesRouter extends PromiseRouter {\n  /**\n   * Constructs a PagesRouter.\n   * @param {Object} pages The pages options from the Parse Server configuration.\n   */\n  constructor(pages = {}) {\n    super();\n\n    // Set instance properties\n    this.pagesConfig = pages;\n    this.pagesEndpoint = pages.pagesEndpoint ? pages.pagesEndpoint : 'apps';\n    this.pagesPath = pages.pagesPath\n      ? path.resolve('./', pages.pagesPath)\n      : path.resolve(__dirname, '../../public');\n    this.loadJsonResource();\n    this.mountPagesRoutes();\n    this.mountCustomRoutes();\n    this.mountStaticRoute();\n  }\n\n  verifyEmail(req) {\n    const config = req.config;\n    const { token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!token) {\n      return this.goToPage(req, pages.emailVerificationLinkInvalid);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(token).then(\n      () => {\n        return this.goToPage(req, pages.emailVerificationSuccess);\n      },\n      () => {\n        return this.goToPage(req, pages.emailVerificationLinkInvalid);\n      }\n    );\n  }\n\n  resendVerificationEmail(req) {\n    const config = req.config;\n    const username = req.body?.username;\n    const rawToken = req.body?.token;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!username && !token) {\n      return this.goToPage(req, pages.emailVerificationLinkInvalid);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username, req, token).then(\n      () => {\n        return this.goToPage(req, pages.emailVerificationSendSuccess);\n      },\n      () => {\n        return this.goToPage(req, pages.emailVerificationSendFail);\n      }\n    );\n  }\n\n  passwordReset(req) {\n    const config = req.config;\n    const params = {\n      [pageParams.appId]: req.params.appId,\n      [pageParams.appName]: config.appName,\n      [pageParams.token]: req.query.token,\n      [pageParams.username]: req.query.username,\n      [pageParams.publicServerUrl]: config.publicServerURL,\n    };\n    return this.goToPage(req, pages.passwordReset, params);\n  }\n\n  requestResetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    const { token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!token) {\n      return this.goToPage(req, pages.passwordResetLinkInvalid);\n    }\n\n    return config.userController.checkResetTokenValidity(token).then(\n      () => {\n        const params = {\n          [pageParams.token]: token,\n          [pageParams.appId]: config.applicationId,\n          [pageParams.appName]: config.appName,\n        };\n        return this.goToPage(req, pages.passwordReset, params);\n      },\n      () => {\n        return this.goToPage(req, pages.passwordResetLinkInvalid);\n      }\n    );\n  }\n\n  resetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    const { new_password, token: rawToken } = req.body || {};\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!token || !new_password) && req.xhr === false) {\n      return this.goToPage(req, pages.passwordResetLinkInvalid);\n    }\n\n    if (!token) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Missing token');\n    }\n\n    if (!new_password) {\n      throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'Missing password');\n    }\n\n    return config.userController\n      .updatePassword(token, new_password)\n      .then(\n        () => {\n          return Promise.resolve({\n            success: true,\n          });\n        },\n        err => {\n          return Promise.resolve({\n            success: false,\n            err,\n          });\n        }\n      )\n      .then(result => {\n        if (req.xhr) {\n          if (result.success) {\n            return Promise.resolve({\n              status: 200,\n              response: 'Password successfully reset',\n            });\n          }\n          if (result.err) {\n            throw new Parse.Error(Parse.Error.OTHER_CAUSE, `${result.err}`);\n          }\n        }\n\n        const query = result.success\n          ? {}\n          : {\n            [pageParams.token]: token,\n            [pageParams.appId]: config.applicationId,\n            [pageParams.error]: result.err,\n            [pageParams.appName]: config.appName,\n          };\n\n        if (result?.err === 'The password reset link has expired') {\n          delete query[pageParams.token];\n          query[pageParams.token] = token;\n        }\n        const page = result.success ? pages.passwordResetSuccess : pages.passwordReset;\n\n        return this.goToPage(req, page, query, false);\n      });\n  }\n\n  /**\n   * Returns page content if the page is a local file or returns a\n   * redirect to a custom page.\n   * @param {Object} req The express request.\n   * @param {Page} page The page to go to.\n   * @param {Object} [params={}] The query parameters to attach to the URL in case of\n   * HTTP redirect responses for POST requests, or the placeholders to fill into\n   * the response content in case of HTTP content responses for GET requests.\n   * @param {Boolean} [responseType] Is true if a redirect response should be forced,\n   * false if a content response should be forced, undefined if the response type\n   * should depend on the request type by default:\n   * - GET request -> content response\n   * - POST request -> redirect response (PRG pattern)\n   * @returns {Promise<Object>} The PromiseRouter response.\n   */\n  goToPage(req, page, params = {}, responseType) {\n    const config = req.config;\n\n    // Determine redirect either by force, response setting or request method\n    const redirect = config.pages.forceRedirect\n      ? true\n      : responseType !== undefined\n        ? responseType\n        : req.method == 'POST';\n\n    // Include default parameters\n    const defaultParams = this.getDefaultParams(config);\n    if (Object.values(defaultParams).includes(undefined)) {\n      return this.notFound();\n    }\n    params = Object.assign(params, defaultParams);\n\n    // Add locale to params to ensure it is passed on with every request;\n    // that means, once a locale is set, it is passed on to any follow-up page,\n    // e.g. request_password_reset -> password_reset -> password_reset_success\n    const locale = this.getLocale(req);\n    params[pageParams.locale] = locale;\n\n    // Compose paths and URLs\n    const defaultFile = page.defaultFile;\n    const defaultPath = this.defaultPagePath(defaultFile);\n    const defaultUrl = this.composePageUrl(defaultFile, config.publicServerURL);\n\n    // If custom URL is set redirect to it without localization\n    const customUrl = config.pages.customUrls[page.id];\n    if (customUrl && !Utils.isPath(customUrl)) {\n      return this.redirectResponse(customUrl, params);\n    }\n\n    // Get JSON placeholders\n    let placeholders = {};\n    if (config.pages.enableLocalization && config.pages.localizationJsonPath) {\n      placeholders = this.getJsonPlaceholders(locale, params);\n    }\n\n    // Send response\n    if (config.pages.enableLocalization && locale) {\n      return Utils.getLocalizedPath(defaultPath, locale).then(({ path, subdir }) =>\n        redirect\n          ? this.redirectResponse(\n            this.composePageUrl(defaultFile, config.publicServerURL, subdir),\n            params\n          )\n          : this.pageResponse(path, params, placeholders)\n      );\n    } else {\n      return redirect\n        ? this.redirectResponse(defaultUrl, params)\n        : this.pageResponse(defaultPath, params, placeholders);\n    }\n  }\n\n  /**\n   * Serves a request to a static resource and localizes the resource if it\n   * is a HTML file.\n   * @param {Object} req The request object.\n   * @returns {Promise<Object>} The response.\n   */\n  staticRoute(req) {\n    // Get requested path\n    const relativePath = req.params['resource'][0];\n\n    // Resolve requested path to absolute path\n    const absolutePath = path.resolve(this.pagesPath, relativePath);\n\n    // If the requested file is not a HTML file send its raw content\n    if (!absolutePath || !absolutePath.endsWith('.html')) {\n      return this.fileResponse(absolutePath);\n    }\n\n    // Get parameters\n    const params = this.getDefaultParams(req.config);\n    const locale = this.getLocale(req);\n    if (locale) {\n      params.locale = locale;\n    }\n\n    // Get JSON placeholders\n    const placeholders = this.getJsonPlaceholders(locale, params);\n\n    return this.pageResponse(absolutePath, params, placeholders);\n  }\n\n  /**\n   * Returns a translation from the JSON resource for a given locale. The JSON\n   * resource is parsed according to i18next syntax.\n   *\n   * Example JSON content:\n   * ```js\n   *  {\n   *    \"en\": {               // resource for language `en` (English)\n   *      \"translation\": {\n   *        \"greeting\": \"Hello!\"\n   *      }\n   *    },\n   *    \"de\": {               // resource for language `de` (German)\n   *      \"translation\": {\n   *        \"greeting\": \"Hallo!\"\n   *      }\n   *    }\n   *    \"de-CH\": {            // resource for locale `de-CH` (Swiss German)\n   *      \"translation\": {\n   *        \"greeting\": \"Grüezi!\"\n   *      }\n   *    }\n   *  }\n   * ```\n   * @param {String} locale The locale to translate to.\n   * @returns {Object} The translation or an empty object if no matching\n   * translation was found.\n   */\n  getJsonTranslation(locale) {\n    // If there is no JSON resource\n    if (this.jsonParameters === undefined) {\n      return {};\n    }\n\n    // If locale is not set use the fallback locale\n    locale = locale || this.pagesConfig.localizationFallbackLocale;\n\n    // Get matching translation by locale, language or fallback locale\n    const language = locale.split('-')[0];\n    const resource =\n      this.jsonParameters[locale] ||\n      this.jsonParameters[language] ||\n      this.jsonParameters[this.pagesConfig.localizationFallbackLocale] ||\n      {};\n    const translation = resource.translation || {};\n    return translation;\n  }\n\n  /**\n   * Returns a translation from the JSON resource for a given locale with\n   * placeholders filled in by given parameters.\n   * @param {String} locale The locale to translate to.\n   * @param {Object} params The parameters to fill into any placeholders\n   * within the translations.\n   * @returns {Object} The translation or an empty object if no matching\n   * translation was found.\n   */\n  getJsonPlaceholders(locale, params = {}) {\n    // If localization is disabled or there is no JSON resource\n    if (!this.pagesConfig.enableLocalization || !this.pagesConfig.localizationJsonPath) {\n      return {};\n    }\n\n    // Get JSON placeholders\n    let placeholders = this.getJsonTranslation(locale);\n\n    // Fill in any placeholders in the translation; this allows a translation\n    // to contain default placeholders like {{appName}} which are filled here\n    placeholders = JSON.stringify(placeholders);\n    placeholders = mustache.render(placeholders, params);\n    placeholders = JSON.parse(placeholders);\n\n    return placeholders;\n  }\n\n  /**\n   * Creates a response with file content.\n   * @param {String} path The path of the file to return.\n   * @param {Object} [params={}] The parameters to be included in the response\n   * header. These will also be used to fill placeholders.\n   * @param {Object} [placeholders={}] The placeholders to fill in the content.\n   * These will not be included in the response header.\n   * @returns {Object} The Promise Router response.\n   */\n  async pageResponse(path, params = {}, placeholders = {}) {\n    // Get file content\n    let data;\n    try {\n      data = await this.readFile(path);\n    } catch {\n      return this.notFound();\n    }\n\n    // Get config placeholders; can be an object, a function or an async function\n    let configPlaceholders =\n      typeof this.pagesConfig.placeholders === 'function'\n        ? this.pagesConfig.placeholders(params)\n        : Object.prototype.toString.call(this.pagesConfig.placeholders) === '[object Object]'\n          ? this.pagesConfig.placeholders\n          : {};\n    if (configPlaceholders instanceof Promise) {\n      configPlaceholders = await configPlaceholders;\n    }\n\n    // Fill placeholders\n    const allPlaceholders = Object.assign({}, configPlaceholders, placeholders);\n    const paramsAndPlaceholders = Object.assign({}, params, allPlaceholders);\n    data = mustache.render(data, paramsAndPlaceholders);\n\n    // Add placeholders in header to allow parsing for programmatic use\n    // of response, instead of having to parse the HTML content.\n    const encode = this.pagesConfig.encodePageParamHeaders;\n    const headers = Object.entries(params).reduce((m, p) => {\n      if (p[1] !== undefined) {\n        m[`${pageParamHeaderPrefix}${p[0].toLowerCase()}`] = encode ? encodeURIComponent(p[1]) : p[1];\n      }\n      return m;\n    }, {});\n\n    return { text: data, headers: headers };\n  }\n\n  /**\n   * Creates a response with file content.\n   * @param {String} path The path of the file to return.\n   * @returns {Object} The PromiseRouter response.\n   */\n  async fileResponse(path) {\n    // Get file content\n    let data;\n    try {\n      data = await this.readFile(path);\n    } catch {\n      return this.notFound();\n    }\n\n    return { text: data };\n  }\n\n  /**\n   * Reads and returns the content of a file at a given path. File reading to\n   * serve content on the static route is only allowed from the pages\n   * directory on downwards.\n   * -----------------------------------------------------------------------\n   * **WARNING:** All file reads in the PagesRouter must be executed by this\n   * wrapper because it also detects and prevents common exploits.\n   * -----------------------------------------------------------------------\n   * @param {String} filePath The path to the file to read.\n   * @returns {Promise<String>} The file content.\n   */\n  async readFile(filePath) {\n    // Normalize path to prevent it from containing any directory changing\n    // UNIX patterns which could expose the whole file system, e.g.\n    // `http://example.com/parse/apps/../file.txt` requests a file outside\n    // of the pages directory scope.\n    const normalizedPath = path.normalize(filePath);\n\n    // Abort if the path is outside of the path directory scope\n    if (!normalizedPath.startsWith(this.pagesPath + path.sep)) {\n      throw errors.fileOutsideAllowedScope;\n    }\n\n    return await fs.readFile(normalizedPath, 'utf-8');\n  }\n\n  /**\n   * Loads a language resource JSON file that is used for translations.\n   */\n  loadJsonResource() {\n    if (this.pagesConfig.localizationJsonPath === undefined) {\n      return;\n    }\n    try {\n      const json = require(path.resolve('./', this.pagesConfig.localizationJsonPath));\n      this.jsonParameters = json;\n    } catch {\n      throw errors.jsonFailedFileLoading;\n    }\n  }\n\n  /**\n   * Extracts and returns the page default parameters from the Parse Server\n   * configuration. These parameters are made accessible in every page served\n   * by this router.\n   * @param {Object} config The Parse Server configuration.\n   * @returns {Object} The default parameters.\n   */\n  getDefaultParams(config) {\n    return config\n      ? {\n        [pageParams.appId]: config.appId,\n        [pageParams.appName]: config.appName,\n        [pageParams.publicServerUrl]: config.publicServerURL,\n      }\n      : {};\n  }\n\n  /**\n   * Extracts and returns the locale from an express request.\n   * @param {Object} req The express request.\n   * @returns {String|undefined} The locale, or undefined if no locale was set.\n   */\n  getLocale(req) {\n    const locale =\n      (req.query || {})[pageParams.locale] ||\n      (req.body || {})[pageParams.locale] ||\n      (req.params || {})[pageParams.locale] ||\n      (req.headers || {})[pageParamHeaderPrefix + pageParams.locale];\n    return locale;\n  }\n\n  /**\n   * Creates a response with http redirect.\n   * @param {Object} req The express request.\n   * @param {String} path The path of the file to return.\n   * @param {Object} params The query parameters to include.\n   * @returns {Object} The Promise Router response.\n   */\n  async redirectResponse(url, params) {\n    // Remove any parameters with undefined value\n    params = Object.entries(params).reduce((m, p) => {\n      if (p[1] !== undefined) {\n        m[p[0]] = p[1];\n      }\n      return m;\n    }, {});\n\n    // Compose URL with parameters in query\n    const location = new URL(url);\n    Object.entries(params).forEach(p => location.searchParams.set(p[0], p[1]));\n    const locationString = location.toString();\n\n    // Add parameters to header to allow parsing for programmatic use\n    // of response, instead of having to parse the HTML content.\n    const encode = this.pagesConfig.encodePageParamHeaders;\n    const headers = Object.entries(params).reduce((m, p) => {\n      if (p[1] !== undefined) {\n        m[`${pageParamHeaderPrefix}${p[0].toLowerCase()}`] = encode ? encodeURIComponent(p[1]) : p[1];\n      }\n      return m;\n    }, {});\n\n    return {\n      status: 303,\n      location: locationString,\n      headers: headers,\n    };\n  }\n\n  defaultPagePath(file) {\n    return path.join(this.pagesPath, file);\n  }\n\n  composePageUrl(file, publicServerUrl, locale) {\n    let url = publicServerUrl;\n    url += url.endsWith('/') ? '' : '/';\n    url += this.pagesEndpoint + '/';\n    url += locale === undefined ? '' : locale + '/';\n    url += file;\n    return url;\n  }\n\n  notFound() {\n    return {\n      text: 'Not found.',\n      status: 404,\n    };\n  }\n\n  invalidRequest() {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized';\n    throw error;\n  }\n\n  /**\n   * Sets the Parse Server configuration in the request object to make it\n   * easily accessible throughtout request processing.\n   * @param {Object} req The request.\n   * @param {Boolean} failGracefully Is true if failing to set the config should\n   * not result in an invalid request response. Default is `false`.\n   */\n  async setConfig(req, failGracefully = false) {\n    req.config = Config.get(req.params.appId || req.query.appId);\n    if (!req.config && !failGracefully) {\n      this.invalidRequest();\n    }\n    if (req.config) {\n      await req.config.loadKeys();\n    }\n  }\n\n  mountPagesRoutes() {\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/:appId/verify_email`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.verifyEmail(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      `/${this.pagesEndpoint}/:appId/resend_verification_email`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.resendVerificationEmail(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/choose_password`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.passwordReset(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      `/${this.pagesEndpoint}/:appId/request_password_reset`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.resetPassword(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/:appId/request_password_reset`,\n      req => {\n        return this.setConfig(req);\n      },\n      req => {\n        return this.requestResetPassword(req);\n      }\n    );\n  }\n\n  mountCustomRoutes() {\n    for (const route of this.pagesConfig.customRoutes || []) {\n      this.route(\n        route.method,\n        `/${this.pagesEndpoint}/:appId/${route.path}`,\n        req => {\n          return this.setConfig(req);\n        },\n        async req => {\n          const { file, query = {} } = (await route.handler(req)) || {};\n\n          // If route handler did not return a page send 404 response\n          if (!file) {\n            return this.notFound();\n          }\n\n          // Send page response\n          const page = new Page({ id: file, defaultFile: file });\n          return this.goToPage(req, page, query, false);\n        }\n      );\n    }\n  }\n\n  mountStaticRoute() {\n    this.route(\n      'GET',\n      `/${this.pagesEndpoint}/*resource`,\n      req => {\n        return this.setConfig(req, true);\n      },\n      req => {\n        return this.staticRoute(req);\n      }\n    );\n  }\n\n  expressRouter() {\n    const router = express.Router();\n    router.use('/', super.expressRouter());\n    return router;\n  }\n}\n\nexport default PagesRouter;\nmodule.exports = {\n  PagesRouter,\n  pageParamHeaderPrefix,\n  pageParams,\n  pages,\n};\n"],"mappings":"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","ignoreList":[]}
@@ -379,6 +379,9 @@ class UsersRouter extends _ClassesRouter.default {
379
379
  if (!email && !token) {
380
380
  throw new _node.default.Error(_node.default.Error.EMAIL_MISSING, 'you must provide an email');
381
381
  }
382
+ if (token && typeof token !== 'string') {
383
+ throw new _node.default.Error(_node.default.Error.INVALID_VALUE, 'token must be a string');
384
+ }
382
385
  let userResults = null;
383
386
  let userData = null;
384
387
 
@@ -638,4 +641,4 @@ class UsersRouter extends _ClassesRouter.default {
638
641
  }
639
642
  exports.UsersRouter = UsersRouter;
640
643
  var _default = exports.default = UsersRouter;
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":[]}
644
+ //# 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    if (token && typeof token !== 'string') {\n      throw new Parse.Error(Parse.Error.INVALID_VALUE, 'token must be a string');\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.1-alpha.2",
3
+ "version": "9.5.2-alpha.1",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {