parse-server 9.6.0-alpha.29 → 9.6.0-alpha.30

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.
package/lib/Auth.js CHANGED
@@ -541,10 +541,16 @@ const hasMutatedAuthData = (authData, userAuthData) => {
541
541
  };
542
542
  };
543
543
  const checkIfUserHasProvidedConfiguredProvidersForLogin = (req = {}, authData = {}, userAuthData = {}, config) => {
544
- const savedUserProviders = Object.keys(userAuthData).map(provider => ({
545
- name: provider,
546
- adapter: config.authDataManager.getValidatorForProvider(provider).adapter
547
- }));
544
+ const savedUserProviders = Object.keys(userAuthData).map(provider => {
545
+ const validator = config.authDataManager.getValidatorForProvider(provider);
546
+ if (!validator || !validator.adapter) {
547
+ return null;
548
+ }
549
+ return {
550
+ name: provider,
551
+ adapter: validator.adapter
552
+ };
553
+ }).filter(Boolean);
548
554
  const hasProvidedASoloProvider = savedUserProviders.some(provider => provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]);
549
555
 
550
556
  // Solo providers can be considered as safe, so we do not have to check if the user needs
@@ -672,4 +678,4 @@ module.exports = {
672
678
  checkIfUserHasProvidedConfiguredProvidersForLogin,
673
679
  handleAuthDataValidation
674
680
  };
675
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_util","require","_triggers","_logger","_lruCache","_RestQuery","_interopRequireDefault","_RestWrite","e","__esModule","default","Parse","Auth","config","cacheController","undefined","isMaster","isMaintenance","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","maintenance","readOnly","nobody","throttle","LRU","max","ttl","shouldUpdateSessionExpiry","session","resetAfter","sessionLength","lastUpdated","Date","updatedAt","skipRange","setTime","getTime","renewSessionIfNeeded","sessionToken","extendSessionOnUse","get","set","query","RestQuery","method","Method","auth","runBeforeFind","className","restWhere","restOptions","limit","results","execute","expiresAt","generateSessionExpiresAt","RestWrite","objectId","_encode","code","Error","OBJECT_NOT_FOUND","logger","error","getAuthForSessionToken","cached","cachedExpiresAt","userJSON","del","INVALID_SESSION_TOKEN","cachedUser","Object","fromJSON","Promise","resolve","include","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","now","iso","startsWith","INTERNAL_SERVER_ERROR","password","put","toISOString","userObject","getAuthForLegacySessionToken","_session_token","then","response","getUserRoles","_loadRoles","getRolesForUser","users","__type","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","beforeFind","currentUserAuthData","providers","keys","queries","all","provider","providerAuthData","storedProviderData","incomingKeys","isUnchanged","some","key","isDeepStrictEqual","adapter","authDataManager","getValidatorForProvider","INVALID_VALUE","validQueries","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","hasChanges","checkIfUserHasProvidedConfiguredProvidersForLogin","req","savedUserProviders","hasProvidedASoloProvider","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","requestObject","ip","call","OTHER_CAUSE","join","handleAuthDataValidation","foundUser","User","getUserId","fetch","updatedObject","buildParseObjects","getRequestObject","acc","authDataResponse","authKeys","sort","validator","authProvider","enabled","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","resolveError","SCRIPT_FAILED","message","userString","data","JSON","stringify","authenticationStep","module","exports"],"sources":["../src/Auth.js"],"sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport { logger } from './logger';\nimport { LRUCache as LRU } from 'lru-cache';\nimport RestQuery from './RestQuery';\nimport RestWrite from './RestWrite';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isMaintenance = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.isMaintenance = isMaintenance;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.isMaintenance) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a maintenance-level Auth object\nfunction maintenance(config) {\n  return new Auth({ config, isMaintenance: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\nconst throttle = new LRU({\n  max: 10000,\n  ttl: 500,\n});\n/**\n * Checks whether session should be updated based on last update time & session length.\n */\nfunction shouldUpdateSessionExpiry(config, session) {\n  const resetAfter = config.sessionLength / 2;\n  const lastUpdated = new Date(session?.updatedAt);\n  const skipRange = new Date();\n  skipRange.setTime(skipRange.getTime() - resetAfter * 1000);\n  return lastUpdated <= skipRange;\n}\n\nconst renewSessionIfNeeded = async ({ config, session, sessionToken }) => {\n  if (!config?.extendSessionOnUse) {\n    return;\n  }\n  if (throttle.get(sessionToken)) {\n    return;\n  }\n  throttle.set(sessionToken, true);\n  try {\n    if (!session) {\n      const query = await RestQuery({\n        method: RestQuery.Method.get,\n        config,\n        auth: master(config),\n        runBeforeFind: false,\n        className: '_Session',\n        restWhere: { sessionToken },\n        restOptions: { limit: 1 },\n      });\n      const { results } = await query.execute();\n      session = results[0];\n    }\n\n    if (!shouldUpdateSessionExpiry(config, session) || !session) {\n      return;\n    }\n    const expiresAt = config.generateSessionExpiresAt();\n    await new RestWrite(\n      config,\n      master(config),\n      '_Session',\n      { objectId: session.objectId },\n      { expiresAt: Parse._encode(expiresAt) }\n    ).execute();\n  } catch (e) {\n    if (e?.code !== Parse.Error.OBJECT_NOT_FOUND) {\n      logger.error('Could not update session expiry: ', e);\n    }\n  }\n};\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const cached = await cacheController.user.get(sessionToken);\n    if (cached) {\n      const { expiresAt: cachedExpiresAt, ...userJSON } = cached;\n      if (cachedExpiresAt && new Date(cachedExpiresAt) < new Date()) {\n        cacheController.user.del(sessionToken);\n        throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n      }\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      renewSessionIfNeeded({ config, sessionToken });\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.get,\n      config,\n      runBeforeFind: false,\n      auth: master(config),\n      className: '_Session',\n      restWhere: { sessionToken },\n      restOptions,\n    });\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const session = results[0];\n  const now = new Date(),\n    expiresAt = session.expiresAt ? new Date(session.expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = session.user;\n\n  if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n    throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n  }\n\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, { ...obj, expiresAt: expiresAt?.toISOString() });\n  }\n  renewSessionIfNeeded({ config, session, sessionToken });\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = async function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = await RestQuery({\n    method: RestQuery.Method.get,\n    config,\n    runBeforeFind: false,\n    auth: master(config),\n    className: '_User',\n    restWhere: { _session_token: sessionToken },\n    restOptions,\n  });\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n\n    if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n      throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n    }\n\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || this.isMaintenance || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      runBeforeFind: false,\n      config: this.config,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      config: this.config,\n      runBeforeFind: false,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = async (config, authData, beforeFind, currentUserAuthData) => {\n  const providers = Object.keys(authData);\n\n  const queries = await Promise.all(\n    providers.map(async provider => {\n      const providerAuthData = authData[provider];\n\n      // Skip providers being unlinked (null value)\n      if (providerAuthData === null) {\n        return null;\n      }\n\n      // Skip beforeFind only when incoming data is confirmed unchanged from stored data.\n      // This handles echoed-back authData from afterFind (e.g. client sends back { id: 'x' }\n      // alongside a provider unlink). On login/signup, currentUserAuthData is undefined so\n      // beforeFind always runs, preserving it as the security gate for missing credentials.\n      const storedProviderData = currentUserAuthData?.[provider];\n      const incomingKeys = Object.keys(providerAuthData || {});\n      const isUnchanged = storedProviderData && incomingKeys.length > 0 &&\n        !incomingKeys.some(key => !isDeepStrictEqual(providerAuthData[key], storedProviderData[key]));\n\n      const adapter = config.authDataManager.getValidatorForProvider(provider)?.adapter;\n      if (beforeFind && typeof adapter?.beforeFind === 'function' && !isUnchanged) {\n        await adapter.beforeFind(providerAuthData);\n      }\n\n      if (!providerAuthData?.id) {\n        return null;\n      }\n\n      if (typeof providerAuthData.id !== 'string') {\n        throw new Parse.Error(Parse.Error.INVALID_VALUE, `Invalid authData id for provider '${provider}'.`);\n      }\n\n      return { [`authData.${provider}.id`]: providerAuthData.id };\n    })\n  );\n\n  // Filter out null queries\n  const validQueries = queries.filter(query => query !== null);\n\n  if (!validQueries.length) {\n    return [];\n  }\n\n  // Perform database query\n  return config.database.find('_User', { $or: validQueries }, { limit: 2 });\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) { return { hasMutatedAuthData: true, mutatedAuthData: authData }; }\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') { return; }\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n\n    // If unlinking (setting to null), consider it mutated\n    if (providerData === null) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // If provider doesn't exist in stored data, it's new\n    if (!userProviderAuthData) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // Check if incoming data represents actual changes vs just echoing back\n    // what afterFind returned. If incoming data is a subset of stored data\n    // (all incoming fields match stored values), it's not mutated.\n    // If incoming data has different values or fields not in stored data, it's mutated.\n    // This handles the case where afterFind strips sensitive fields like 'code':\n    // - Incoming: { id: 'x' }, Stored: { id: 'x', code: 'secret' } -> NOT mutated (subset)\n    // - Incoming: { id: 'x', token: 'new' }, Stored: { id: 'x', token: 'old' } -> MUTATED\n    const incomingKeys = Object.keys(providerData || {});\n    const hasChanges = incomingKeys.some(key => {\n      return !isDeepStrictEqual(providerData[key], userProviderAuthData[key]);\n    });\n\n    if (hasChanges) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  req = {},\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData).map(provider => ({\n    name: provider,\n    adapter: config.authDataManager.getValidatorForProvider(provider).adapter,\n  }));\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    let policy = provider.adapter.policy;\n    if (typeof policy === 'function') {\n      const requestObject = {\n        ip: req.config.ip,\n        user: req.auth.user,\n        master: req.auth.isMaster,\n      };\n      policy = policy.call(provider.adapter, requestObject, userAuthData[provider.name]);\n    }\n    if (policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(undefined, req.auth, updatedObject, user, req.config);\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider) || {};\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  maintenance,\n  nobody,\n  readOnly,\n  shouldUpdateSessionExpiry,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":"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","ignoreList":[]}
681
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_util","require","_triggers","_logger","_lruCache","_RestQuery","_interopRequireDefault","_RestWrite","e","__esModule","default","Parse","Auth","config","cacheController","undefined","isMaster","isMaintenance","isReadOnly","user","installationId","userRoles","fetchedRoles","rolePromise","prototype","isUnauthenticated","master","maintenance","readOnly","nobody","throttle","LRU","max","ttl","shouldUpdateSessionExpiry","session","resetAfter","sessionLength","lastUpdated","Date","updatedAt","skipRange","setTime","getTime","renewSessionIfNeeded","sessionToken","extendSessionOnUse","get","set","query","RestQuery","method","Method","auth","runBeforeFind","className","restWhere","restOptions","limit","results","execute","expiresAt","generateSessionExpiresAt","RestWrite","objectId","_encode","code","Error","OBJECT_NOT_FOUND","logger","error","getAuthForSessionToken","cached","cachedExpiresAt","userJSON","del","INVALID_SESSION_TOKEN","cachedUser","Object","fromJSON","Promise","resolve","include","Query","Session","equalTo","find","useMasterKey","map","obj","toJSON","length","now","iso","startsWith","INTERNAL_SERVER_ERROR","password","put","toISOString","userObject","getAuthForLegacySessionToken","_session_token","then","response","getUserRoles","_loadRoles","getRolesForUser","users","__type","id","each","result","push","Role","cachedRoles","role","cacheRoles","rolesMap","reduce","m","r","names","name","ids","roleNames","_getAllRolesNamesForRoleIds","Array","clearRoleCache","getRolesByIds","ins","containedIn","roles","$in","roleIDs","queriedRoles","filter","roleID","wasQueried","Set","resultMap","memo","concat","findUsersWithAuthData","authData","beforeFind","currentUserAuthData","providers","keys","queries","all","provider","providerAuthData","storedProviderData","incomingKeys","isUnchanged","some","key","isDeepStrictEqual","adapter","authDataManager","getValidatorForProvider","INVALID_VALUE","validQueries","database","$or","hasMutatedAuthData","userAuthData","mutatedAuthData","forEach","providerData","userProviderAuthData","hasChanges","checkIfUserHasProvidedConfiguredProvidersForLogin","req","savedUserProviders","validator","Boolean","hasProvidedASoloProvider","policy","additionProvidersNotFound","hasProvidedAtLeastOneAdditionalProvider","requestObject","ip","call","OTHER_CAUSE","join","handleAuthDataValidation","foundUser","User","getUserId","fetch","updatedObject","buildParseObjects","getRequestObject","acc","authDataResponse","authKeys","sort","authProvider","enabled","UNSUPPORTED_SERVICE","validationResult","triggerName","doNotSave","save","err","resolveError","SCRIPT_FAILED","message","userString","data","JSON","stringify","authenticationStep","module","exports"],"sources":["../src/Auth.js"],"sourcesContent":["const Parse = require('parse/node');\nimport { isDeepStrictEqual } from 'util';\nimport { getRequestObject, resolveError } from './triggers';\nimport { logger } from './logger';\nimport { LRUCache as LRU } from 'lru-cache';\nimport RestQuery from './RestQuery';\nimport RestWrite from './RestWrite';\n\n// An Auth object tells you who is requesting something and whether\n// the master key was used.\n// userObject is a Parse.User and can be null if there's no user.\nfunction Auth({\n  config,\n  cacheController = undefined,\n  isMaster = false,\n  isMaintenance = false,\n  isReadOnly = false,\n  user,\n  installationId,\n}) {\n  this.config = config;\n  this.cacheController = cacheController || (config && config.cacheController);\n  this.installationId = installationId;\n  this.isMaster = isMaster;\n  this.isMaintenance = isMaintenance;\n  this.user = user;\n  this.isReadOnly = isReadOnly;\n\n  // Assuming a users roles won't change during a single request, we'll\n  // only load them once.\n  this.userRoles = [];\n  this.fetchedRoles = false;\n  this.rolePromise = null;\n}\n\n// Whether this auth could possibly modify the given user id.\n// It still could be forbidden via ACLs even if this returns true.\nAuth.prototype.isUnauthenticated = function () {\n  if (this.isMaster) {\n    return false;\n  }\n  if (this.isMaintenance) {\n    return false;\n  }\n  if (this.user) {\n    return false;\n  }\n  return true;\n};\n\n// A helper to get a master-level Auth object\nfunction master(config) {\n  return new Auth({ config, isMaster: true });\n}\n\n// A helper to get a maintenance-level Auth object\nfunction maintenance(config) {\n  return new Auth({ config, isMaintenance: true });\n}\n\n// A helper to get a master-level Auth object\nfunction readOnly(config) {\n  return new Auth({ config, isMaster: true, isReadOnly: true });\n}\n\n// A helper to get a nobody-level Auth object\nfunction nobody(config) {\n  return new Auth({ config, isMaster: false });\n}\n\nconst throttle = new LRU({\n  max: 10000,\n  ttl: 500,\n});\n/**\n * Checks whether session should be updated based on last update time & session length.\n */\nfunction shouldUpdateSessionExpiry(config, session) {\n  const resetAfter = config.sessionLength / 2;\n  const lastUpdated = new Date(session?.updatedAt);\n  const skipRange = new Date();\n  skipRange.setTime(skipRange.getTime() - resetAfter * 1000);\n  return lastUpdated <= skipRange;\n}\n\nconst renewSessionIfNeeded = async ({ config, session, sessionToken }) => {\n  if (!config?.extendSessionOnUse) {\n    return;\n  }\n  if (throttle.get(sessionToken)) {\n    return;\n  }\n  throttle.set(sessionToken, true);\n  try {\n    if (!session) {\n      const query = await RestQuery({\n        method: RestQuery.Method.get,\n        config,\n        auth: master(config),\n        runBeforeFind: false,\n        className: '_Session',\n        restWhere: { sessionToken },\n        restOptions: { limit: 1 },\n      });\n      const { results } = await query.execute();\n      session = results[0];\n    }\n\n    if (!shouldUpdateSessionExpiry(config, session) || !session) {\n      return;\n    }\n    const expiresAt = config.generateSessionExpiresAt();\n    await new RestWrite(\n      config,\n      master(config),\n      '_Session',\n      { objectId: session.objectId },\n      { expiresAt: Parse._encode(expiresAt) }\n    ).execute();\n  } catch (e) {\n    if (e?.code !== Parse.Error.OBJECT_NOT_FOUND) {\n      logger.error('Could not update session expiry: ', e);\n    }\n  }\n};\n\n// Returns a promise that resolves to an Auth object\nconst getAuthForSessionToken = async function ({\n  config,\n  cacheController,\n  sessionToken,\n  installationId,\n}) {\n  cacheController = cacheController || (config && config.cacheController);\n  if (cacheController) {\n    const cached = await cacheController.user.get(sessionToken);\n    if (cached) {\n      const { expiresAt: cachedExpiresAt, ...userJSON } = cached;\n      if (cachedExpiresAt && new Date(cachedExpiresAt) < new Date()) {\n        cacheController.user.del(sessionToken);\n        throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n      }\n      const cachedUser = Parse.Object.fromJSON(userJSON);\n      renewSessionIfNeeded({ config, sessionToken });\n      return Promise.resolve(\n        new Auth({\n          config,\n          cacheController,\n          isMaster: false,\n          installationId,\n          user: cachedUser,\n        })\n      );\n    }\n  }\n\n  let results;\n  if (config) {\n    const restOptions = {\n      limit: 1,\n      include: 'user',\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.get,\n      config,\n      runBeforeFind: false,\n      auth: master(config),\n      className: '_Session',\n      restWhere: { sessionToken },\n      restOptions,\n    });\n    results = (await query.execute()).results;\n  } else {\n    results = (\n      await new Parse.Query(Parse.Session)\n        .limit(1)\n        .include('user')\n        .equalTo('sessionToken', sessionToken)\n        .find({ useMasterKey: true })\n    ).map(obj => obj.toJSON());\n  }\n\n  if (results.length !== 1 || !results[0]['user']) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n  }\n  const session = results[0];\n  const now = new Date(),\n    expiresAt = session.expiresAt ? new Date(session.expiresAt.iso) : undefined;\n  if (expiresAt < now) {\n    throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token is expired.');\n  }\n  const obj = session.user;\n\n  if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n    throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n  }\n\n  delete obj.password;\n  obj['className'] = '_User';\n  obj['sessionToken'] = sessionToken;\n  if (cacheController) {\n    cacheController.user.put(sessionToken, { ...obj, expiresAt: expiresAt?.toISOString() });\n  }\n  renewSessionIfNeeded({ config, session, sessionToken });\n  const userObject = Parse.Object.fromJSON(obj);\n  return new Auth({\n    config,\n    cacheController,\n    isMaster: false,\n    installationId,\n    user: userObject,\n  });\n};\n\nvar getAuthForLegacySessionToken = async function ({ config, sessionToken, installationId }) {\n  var restOptions = {\n    limit: 1,\n  };\n  const RestQuery = require('./RestQuery');\n  var query = await RestQuery({\n    method: RestQuery.Method.get,\n    config,\n    runBeforeFind: false,\n    auth: master(config),\n    className: '_User',\n    restWhere: { _session_token: sessionToken },\n    restOptions,\n  });\n  return query.execute().then(response => {\n    var results = response.results;\n    if (results.length !== 1) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'invalid legacy session token');\n    }\n    const obj = results[0];\n\n    if (typeof obj['objectId'] === 'string' && obj['objectId'].startsWith('role:')) {\n      throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Invalid object ID.');\n    }\n\n    obj.className = '_User';\n    const userObject = Parse.Object.fromJSON(obj);\n    return new Auth({\n      config,\n      isMaster: false,\n      installationId,\n      user: userObject,\n    });\n  });\n};\n\n// Returns a promise that resolves to an array of role names\nAuth.prototype.getUserRoles = function () {\n  if (this.isMaster || this.isMaintenance || !this.user) {\n    return Promise.resolve([]);\n  }\n  if (this.fetchedRoles) {\n    return Promise.resolve(this.userRoles);\n  }\n  if (this.rolePromise) {\n    return this.rolePromise;\n  }\n  this.rolePromise = this._loadRoles();\n  return this.rolePromise;\n};\n\nAuth.prototype.getRolesForUser = async function () {\n  //Stack all Parse.Role\n  const results = [];\n  if (this.config) {\n    const restWhere = {\n      users: {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: this.user.id,\n      },\n    };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      runBeforeFind: false,\n      config: this.config,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  } else {\n    await new Parse.Query(Parse.Role)\n      .equalTo('users', this.user)\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  }\n  return results;\n};\n\n// Iterates through the role tree and compiles a user's roles\nAuth.prototype._loadRoles = async function () {\n  if (this.cacheController) {\n    const cachedRoles = await this.cacheController.role.get(this.user.id);\n    if (cachedRoles != null) {\n      this.fetchedRoles = true;\n      this.userRoles = cachedRoles;\n      return cachedRoles;\n    }\n  }\n\n  // First get the role ids this user is directly a member of\n  const results = await this.getRolesForUser();\n  if (!results.length) {\n    this.userRoles = [];\n    this.fetchedRoles = true;\n    this.rolePromise = null;\n\n    this.cacheRoles();\n    return this.userRoles;\n  }\n\n  const rolesMap = results.reduce(\n    (m, r) => {\n      m.names.push(r.name);\n      m.ids.push(r.objectId);\n      return m;\n    },\n    { ids: [], names: [] }\n  );\n\n  // run the recursive finding\n  const roleNames = await this._getAllRolesNamesForRoleIds(rolesMap.ids, rolesMap.names);\n  this.userRoles = roleNames.map(r => {\n    return 'role:' + r;\n  });\n  this.fetchedRoles = true;\n  this.rolePromise = null;\n  this.cacheRoles();\n  return this.userRoles;\n};\n\nAuth.prototype.cacheRoles = function () {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.put(this.user.id, Array(...this.userRoles));\n  return true;\n};\n\nAuth.prototype.clearRoleCache = function (sessionToken) {\n  if (!this.cacheController) {\n    return false;\n  }\n  this.cacheController.role.del(this.user.id);\n  this.cacheController.user.del(sessionToken);\n  return true;\n};\n\nAuth.prototype.getRolesByIds = async function (ins) {\n  const results = [];\n  // Build an OR query across all parentRoles\n  if (!this.config) {\n    await new Parse.Query(Parse.Role)\n      .containedIn(\n        'roles',\n        ins.map(id => {\n          const role = new Parse.Object(Parse.Role);\n          role.id = id;\n          return role;\n        })\n      )\n      .each(result => results.push(result.toJSON()), { useMasterKey: true });\n  } else {\n    const roles = ins.map(id => {\n      return {\n        __type: 'Pointer',\n        className: '_Role',\n        objectId: id,\n      };\n    });\n    const restWhere = { roles: { $in: roles } };\n    const RestQuery = require('./RestQuery');\n    const query = await RestQuery({\n      method: RestQuery.Method.find,\n      config: this.config,\n      runBeforeFind: false,\n      auth: master(this.config),\n      className: '_Role',\n      restWhere,\n    });\n    await query.each(result => results.push(result));\n  }\n  return results;\n};\n\n// Given a list of roleIds, find all the parent roles, returns a promise with all names\nAuth.prototype._getAllRolesNamesForRoleIds = function (roleIDs, names = [], queriedRoles = {}) {\n  const ins = roleIDs.filter(roleID => {\n    const wasQueried = queriedRoles[roleID] !== true;\n    queriedRoles[roleID] = true;\n    return wasQueried;\n  });\n\n  // all roles are accounted for, return the names\n  if (ins.length == 0) {\n    return Promise.resolve([...new Set(names)]);\n  }\n\n  return this.getRolesByIds(ins)\n    .then(results => {\n      // Nothing found\n      if (!results.length) {\n        return Promise.resolve(names);\n      }\n      // Map the results with all Ids and names\n      const resultMap = results.reduce(\n        (memo, role) => {\n          memo.names.push(role.name);\n          memo.ids.push(role.objectId);\n          return memo;\n        },\n        { ids: [], names: [] }\n      );\n      // store the new found names\n      names = names.concat(resultMap.names);\n      // find the next ones, circular roles will be cut\n      return this._getAllRolesNamesForRoleIds(resultMap.ids, names, queriedRoles);\n    })\n    .then(names => {\n      return Promise.resolve([...new Set(names)]);\n    });\n};\n\nconst findUsersWithAuthData = async (config, authData, beforeFind, currentUserAuthData) => {\n  const providers = Object.keys(authData);\n\n  const queries = await Promise.all(\n    providers.map(async provider => {\n      const providerAuthData = authData[provider];\n\n      // Skip providers being unlinked (null value)\n      if (providerAuthData === null) {\n        return null;\n      }\n\n      // Skip beforeFind only when incoming data is confirmed unchanged from stored data.\n      // This handles echoed-back authData from afterFind (e.g. client sends back { id: 'x' }\n      // alongside a provider unlink). On login/signup, currentUserAuthData is undefined so\n      // beforeFind always runs, preserving it as the security gate for missing credentials.\n      const storedProviderData = currentUserAuthData?.[provider];\n      const incomingKeys = Object.keys(providerAuthData || {});\n      const isUnchanged = storedProviderData && incomingKeys.length > 0 &&\n        !incomingKeys.some(key => !isDeepStrictEqual(providerAuthData[key], storedProviderData[key]));\n\n      const adapter = config.authDataManager.getValidatorForProvider(provider)?.adapter;\n      if (beforeFind && typeof adapter?.beforeFind === 'function' && !isUnchanged) {\n        await adapter.beforeFind(providerAuthData);\n      }\n\n      if (!providerAuthData?.id) {\n        return null;\n      }\n\n      if (typeof providerAuthData.id !== 'string') {\n        throw new Parse.Error(Parse.Error.INVALID_VALUE, `Invalid authData id for provider '${provider}'.`);\n      }\n\n      return { [`authData.${provider}.id`]: providerAuthData.id };\n    })\n  );\n\n  // Filter out null queries\n  const validQueries = queries.filter(query => query !== null);\n\n  if (!validQueries.length) {\n    return [];\n  }\n\n  // Perform database query\n  return config.database.find('_User', { $or: validQueries }, { limit: 2 });\n};\n\nconst hasMutatedAuthData = (authData, userAuthData) => {\n  if (!userAuthData) { return { hasMutatedAuthData: true, mutatedAuthData: authData }; }\n  const mutatedAuthData = {};\n  Object.keys(authData).forEach(provider => {\n    // Anonymous provider is not handled this way\n    if (provider === 'anonymous') { return; }\n    const providerData = authData[provider];\n    const userProviderAuthData = userAuthData[provider];\n\n    // If unlinking (setting to null), consider it mutated\n    if (providerData === null) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // If provider doesn't exist in stored data, it's new\n    if (!userProviderAuthData) {\n      mutatedAuthData[provider] = providerData;\n      return;\n    }\n\n    // Check if incoming data represents actual changes vs just echoing back\n    // what afterFind returned. If incoming data is a subset of stored data\n    // (all incoming fields match stored values), it's not mutated.\n    // If incoming data has different values or fields not in stored data, it's mutated.\n    // This handles the case where afterFind strips sensitive fields like 'code':\n    // - Incoming: { id: 'x' }, Stored: { id: 'x', code: 'secret' } -> NOT mutated (subset)\n    // - Incoming: { id: 'x', token: 'new' }, Stored: { id: 'x', token: 'old' } -> MUTATED\n    const incomingKeys = Object.keys(providerData || {});\n    const hasChanges = incomingKeys.some(key => {\n      return !isDeepStrictEqual(providerData[key], userProviderAuthData[key]);\n    });\n\n    if (hasChanges) {\n      mutatedAuthData[provider] = providerData;\n    }\n  });\n  const hasMutatedAuthData = Object.keys(mutatedAuthData).length !== 0;\n  return { hasMutatedAuthData, mutatedAuthData };\n};\n\nconst checkIfUserHasProvidedConfiguredProvidersForLogin = (\n  req = {},\n  authData = {},\n  userAuthData = {},\n  config\n) => {\n  const savedUserProviders = Object.keys(userAuthData)\n    .map(provider => {\n      const validator = config.authDataManager.getValidatorForProvider(provider);\n      if (!validator || !validator.adapter) {\n        return null;\n      }\n      return { name: provider, adapter: validator.adapter };\n    })\n    .filter(Boolean);\n\n  const hasProvidedASoloProvider = savedUserProviders.some(\n    provider =>\n      provider && provider.adapter && provider.adapter.policy === 'solo' && authData[provider.name]\n  );\n\n  // Solo providers can be considered as safe, so we do not have to check if the user needs\n  // to provide an additional provider to login. An auth adapter with \"solo\" (like webauthn) means\n  // no \"additional\" auth needs to be provided to login (like OTP, MFA)\n  if (hasProvidedASoloProvider) {\n    return;\n  }\n\n  const additionProvidersNotFound = [];\n  const hasProvidedAtLeastOneAdditionalProvider = savedUserProviders.some(provider => {\n    let policy = provider.adapter.policy;\n    if (typeof policy === 'function') {\n      const requestObject = {\n        ip: req.config.ip,\n        user: req.auth.user,\n        master: req.auth.isMaster,\n      };\n      policy = policy.call(provider.adapter, requestObject, userAuthData[provider.name]);\n    }\n    if (policy === 'additional') {\n      if (authData[provider.name]) {\n        return true;\n      } else {\n        // Push missing provider for error message\n        additionProvidersNotFound.push(provider.name);\n      }\n    }\n  });\n  if (hasProvidedAtLeastOneAdditionalProvider || !additionProvidersNotFound.length) {\n    return;\n  }\n\n  throw new Parse.Error(\n    Parse.Error.OTHER_CAUSE,\n    `Missing additional authData ${additionProvidersNotFound.join(',')}`\n  );\n};\n\n// Validate each authData step-by-step and return the provider responses\nconst handleAuthDataValidation = async (authData, req, foundUser) => {\n  let user;\n  if (foundUser) {\n    user = Parse.User.fromJSON({ className: '_User', ...foundUser });\n    // Find user by session and current objectId; only pass user if it's the current user or master key is provided\n  } else if (\n    (req.auth &&\n      req.auth.user &&\n      typeof req.getUserId === 'function' &&\n      req.getUserId() === req.auth.user.id) ||\n    (req.auth && req.auth.isMaster && typeof req.getUserId === 'function' && req.getUserId())\n  ) {\n    user = new Parse.User();\n    user.id = req.auth.isMaster ? req.getUserId() : req.auth.user.id;\n    await user.fetch({ useMasterKey: true });\n  }\n\n  const { updatedObject } = req.buildParseObjects();\n  const requestObject = getRequestObject(undefined, req.auth, updatedObject, user, req.config);\n  // Perform validation as step-by-step pipeline for better error consistency\n  // and also to avoid to trigger a provider (like OTP SMS) if another one fails\n  const acc = { authData: {}, authDataResponse: {} };\n  const authKeys = Object.keys(authData).sort();\n  for (const provider of authKeys) {\n    let method = '';\n    try {\n      if (authData[provider] === null) {\n        acc.authData[provider] = null;\n        continue;\n      }\n      const { validator } = req.config.authDataManager.getValidatorForProvider(provider) || {};\n      const authProvider = (req.config.auth || {})[provider] || {};\n      if (!validator || authProvider.enabled === false) {\n        throw new Parse.Error(\n          Parse.Error.UNSUPPORTED_SERVICE,\n          'This authentication method is unsupported.'\n        );\n      }\n      let validationResult = await validator(authData[provider], req, user, requestObject);\n      method = validationResult && validationResult.method;\n      requestObject.triggerName = method;\n      if (validationResult && validationResult.validator) {\n        validationResult = await validationResult.validator();\n      }\n      if (!validationResult) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n      if (!Object.keys(validationResult).length) {\n        acc.authData[provider] = authData[provider];\n        continue;\n      }\n\n      if (validationResult.response) {\n        acc.authDataResponse[provider] = validationResult.response;\n      }\n      // Some auth providers after initialization will avoid to replace authData already stored\n      if (!validationResult.doNotSave) {\n        acc.authData[provider] = validationResult.save || authData[provider];\n      }\n    } catch (err) {\n      const e = resolveError(err, {\n        code: Parse.Error.SCRIPT_FAILED,\n        message: 'Auth failed. Unknown error.',\n      });\n      const userString =\n        req.auth && req.auth.user ? req.auth.user.id : req.data.objectId || undefined;\n      logger.error(\n        `Failed running auth step ${method} for ${provider} for user ${userString} with Error: ` +\n          JSON.stringify(e),\n        {\n          authenticationStep: method,\n          error: e,\n          user: userString,\n          provider,\n        }\n      );\n      throw e;\n    }\n  }\n  return acc;\n};\n\nmodule.exports = {\n  Auth,\n  master,\n  maintenance,\n  nobody,\n  readOnly,\n  shouldUpdateSessionExpiry,\n  getAuthForSessionToken,\n  getAuthForLegacySessionToken,\n  findUsersWithAuthData,\n  hasMutatedAuthData,\n  checkIfUserHasProvidedConfiguredProvidersForLogin,\n  handleAuthDataValidation,\n};\n"],"mappings":"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","ignoreList":[]}
@@ -559,7 +559,7 @@ class DatabaseController {
559
559
  throw error;
560
560
  }).then(schema => {
561
561
  Object.keys(update).forEach(fieldName => {
562
- if (fieldName.match(/^authData\.([a-zA-Z0-9_]+)\.id$/)) {
562
+ if (fieldName.match(/^authData\./)) {
563
563
  throw new _node.Parse.Error(_node.Parse.Error.INVALID_KEY_NAME, `Invalid field name for update: ${fieldName}`);
564
564
  }
565
565
  const rootFieldName = getRootFieldName(fieldName);
@@ -1656,4 +1656,4 @@ module.exports = DatabaseController;
1656
1656
  // Expose validateQuery for tests
1657
1657
  module.exports._validateQuery = validateQuery;
1658
1658
  module.exports.filterSensitiveData = filterSensitiveData;
1659
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","require","_lodash","_interopRequireDefault","_intersect","_logger","_Utils","SchemaController","_interopRequireWildcard","_StorageAdapter","_MongoStorageAdapter","_PostgresStorageAdapter","_SchemaCache","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","queryOperators","internalFields","_rperm","clientRead","masterRead","masterWrite","_wperm","_hashed_password","_email_verify_token","_perishable_token","_perishable_token_expires_at","_email_verify_token_expires_at","_failed_login_count","_account_lockout_expires_at","_password_changed_at","_password_history","_tombstone","_session_token","specialQueryKeys","keys","filter","k","specialMasterQueryKeys","addWriteACL","query","acl","newQuery","_","cloneDeep","$in","addReadACL","transformObjectACL","ACL","result","entry","read","push","write","validateQuery","isMaster","isMaintenance","update","options","_depth","rc","requestComplexity","queryDepth","Parse","Error","INVALID_QUERY","$or","Array","forEach","value","$and","$nor","length","key","$regex","$options","match","includes","INVALID_KEY_NAME","filterSensitiveData","aclGroup","auth","operation","schema","className","protectedFields","object","userId","user","id","perms","getClassLevelPermissions","isReadOperation","indexOf","protectedFieldsPointerPerm","startsWith","map","substring","newProtectedFields","overrideProtectedFields","pointerPerm","pointerPermIncludesUser","readUserFieldValue","isArray","some","objectId","fields","v","isUserClass","password","sessionToken","temporaryKeys","charAt","authData","specialKeysForUpdate","isSpecialUpdateKey","joinTableName","flattenUpdateOperatorsForCreate","__op","amount","INVALID_JSON","objects","COMMAND_UNAVAILABLE","transformAuthData","provider","providerData","fieldName","type","untransformObjectACL","output","getRootFieldName","split","relationSchema","relatedId","owningId","convertEmailToLowercase","toLowerCase","convertUsernameToLowercase","DatabaseController","constructor","adapter","idempotencyOptions","schemaPromise","_transactionalSession","collectionExists","classExists","purgeCollection","loadSchema","then","schemaController","getOneSchema","deleteObjectsByQuery","validateClassName","classNameIsValid","Promise","reject","INVALID_CLASS_NAME","resolve","clearCache","load","loadSchemaIfNeeded","redirectClassNameForKey","getExpectedType","targetClass","validateObject","runOptions","maintenance","undefined","s","canAddField","many","upsert","addsField","skipSanitization","validateOnly","validSchemaController","Utils","checkProhibitedKeywords","error","validateFileUrlsInObject","FILE_SAVE_ERROR","message","originalQuery","originalUpdate","structuredClone","relationUpdates","validatePermission","collectRelationUpdates","addPointerPermissions","catch","rootFieldName","fieldNameIsValid","updateOperation","innerKey","INVALID_NESTED_KEY","find","readPreference","OBJECT_NOT_FOUND","updateObjectsByQuery","upsertOneObject","findOneAndUpdate","handleRelationUpdates","_sanitizeDatabaseResult","ops","deleteMe","process","op","x","pending","addRelation","removeRelation","all","fromClassName","fromId","toId","doc","code","destroy","parseFormatSchema","create","originalObject","createdAt","iso","__type","updatedAt","enforceClassExists","createObject","convertSchemaToAdapterSchema","classSchema","schemaData","schemaFields","newKeys","field","action","deleteEverything","fast","SchemaCache","clear","deleteAllClasses","relatedIds","queryOptions","skip","limit","sort","findOptions","canSortOnJoinTables","_id","results","owningIds","reduceInRelation","promises","ors","aQuery","index","ands","otherKeys","queries","constraintKey","isNegation","q","ids","addNotInObjectIdsIds","addInObjectIdsIds","reduceRelationKeys","relatedTo","idsFromString","idsFromEq","idsFromIn","allIds","list","totalLength","reduce","memo","idsIntersection","intersect","big","$eq","idsFromNin","Set","$nin","count","distinct","pipeline","hint","caseInsensitive","explain","comment","_created_at","_updated_at","enableCollationCaseComparison","addProtectedFields","aggregate","detailedMessage","createSanitizedError","INTERNAL_SERVER_ERROR","deleteSchema","deleteClass","wasParseCollection","relationFieldNames","name","del","reloadData","objectToEntriesStrings","entries","a","JSON","stringify","join","reduceOrOperation","repeat","j","shorter","longer","foundEntries","acc","shorterEntries","splice","reduceAndOperation","testPermissionsForClassName","userACL","groupKey","permFields","pointerFields","userPointer","fieldDescriptor","fieldType","prototype","queryClause","$all","assign","preserveKeys","serverOnlyKeys","authenticated","roles","userRoles","protectedKeysSets","protectedKeys","next","createTransactionalSession","transactionalSession","commitTransactionalSession","abortTransactionalSession","performInitialization","VolatileClassesSchemas","requiredUserFields","defaultColumns","_Default","_User","requiredRoleFields","_Role","requiredIdempotencyFields","_Idempotency","databaseOptions","createIndexUserUsername","ensureUniqueness","logger","warn","createIndexUserUsernameCaseInsensitive","ensureIndex","createIndexUserEmailCaseInsensitive","createIndexUserEmail","createIndexUserEmailVerifyToken","createIndexUserPasswordResetToken","createIndexRoleName","isMongoAdapter","MongoStorageAdapter","isPostgresAdapter","PostgresStorageAdapter","ttl","setIdempotencyFunction","createIndexAuthDataUniqueness","ensureAuthDataUniqueness","authProviders","enableAnonymousUsers","updateSchemaWithIndexes","_expandResultOnKeyPath","path","firstKey","nextPath","slice","requestKeywordDenylist","keyword","objectContainsKeyValue","response","keyUpdate","isArrayIndex","from","every","c","module","exports","_validateQuery"],"sources":["../../src/Controllers/DatabaseController.js"],"sourcesContent":["﻿// @flow\n// A database adapter that works with data exported from the hosted\n// Parse database.\n\n// @flow-disable-next\nimport { Parse } from 'parse/node';\n// @flow-disable-next\nimport _ from 'lodash';\n// @flow-disable-next\nimport intersect from 'intersect';\nimport logger from '../logger';\nimport Utils from '../Utils';\nimport * as SchemaController from './SchemaController';\nimport { StorageAdapter } from '../Adapters/Storage/StorageAdapter';\nimport MongoStorageAdapter from '../Adapters/Storage/Mongo/MongoStorageAdapter';\nimport PostgresStorageAdapter from '../Adapters/Storage/Postgres/PostgresStorageAdapter';\nimport SchemaCache from '../Adapters/Cache/SchemaCache';\nimport type { LoadSchemaOptions } from './types';\nimport type { ParseServerOptions } from '../Options';\nimport type { QueryOptions, FullQueryOptions } from '../Adapters/Storage/StorageAdapter';\nimport { createSanitizedError } from '../Error';\n\n// Query operators that always pass validation regardless of auth level.\nconst queryOperators = ['$and', '$or', '$nor'];\n\n// Registry of internal fields with access permissions.\n// Internal fields are never directly writable by clients, so clientWrite is omitted.\n// - clientRead: any client can use this field in queries\n// - masterRead: master key can use this field in queries\n// - masterWrite: master key can use this field in updates\nconst internalFields = {\n  _rperm:                         { clientRead: true,  masterRead: true,  masterWrite: true  },\n  _wperm:                         { clientRead: true,  masterRead: true,  masterWrite: true  },\n  _hashed_password:               { clientRead: false, masterRead: false, masterWrite: true  },\n  _email_verify_token:            { clientRead: false, masterRead: true,  masterWrite: true  },\n  _perishable_token:              { clientRead: false, masterRead: true,  masterWrite: true  },\n  _perishable_token_expires_at:   { clientRead: false, masterRead: true,  masterWrite: true  },\n  _email_verify_token_expires_at: { clientRead: false, masterRead: true,  masterWrite: true  },\n  _failed_login_count:            { clientRead: false, masterRead: true,  masterWrite: true  },\n  _account_lockout_expires_at:    { clientRead: false, masterRead: true,  masterWrite: true  },\n  _password_changed_at:           { clientRead: false, masterRead: true,  masterWrite: true  },\n  _password_history:              { clientRead: false, masterRead: true,  masterWrite: true  },\n  _tombstone:                     { clientRead: false, masterRead: true,  masterWrite: false },\n  _session_token:                 { clientRead: false, masterRead: true,  masterWrite: false },\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // The following fields are not accessed by their _-prefixed name through the API;\n  // they are mapped to REST-level names in the adapter layer or handled through\n  // separate code paths.\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // System fields (mapped to REST-level names):\n  // _id (objectId)\n  // _created_at (createdAt)\n  // _updated_at (updatedAt)\n  // _last_used (lastUsed)\n  // _expiresAt (expiresAt)\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // Legacy ACL format: mapped to/from _rperm/_wperm\n  // _acl\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // Schema metadata: not data fields, used only for schema configuration\n  // _metadata\n  // _client_permissions\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // Dynamic auth data fields: used only in projections and updates, not in queries\n  // _auth_data_<provider>\n};\n\n// Derived access lists\nconst specialQueryKeys = [\n  ...queryOperators,\n  ...Object.keys(internalFields).filter(k => internalFields[k].clientRead),\n];\nconst specialMasterQueryKeys = [\n  ...queryOperators,\n  ...Object.keys(internalFields).filter(k => internalFields[k].masterRead),\n];\n\nfunction addWriteACL(query, acl) {\n  const newQuery = _.cloneDeep(query);\n  //Can't be any existing '_wperm' query, we don't allow client queries on that, no need to $and\n  newQuery._wperm = { $in: [null, ...acl] };\n  return newQuery;\n}\n\nfunction addReadACL(query, acl) {\n  const newQuery = _.cloneDeep(query);\n  //Can't be any existing '_rperm' query, we don't allow client queries on that, no need to $and\n  newQuery._rperm = { $in: [null, '*', ...acl] };\n  return newQuery;\n}\n\n// Transforms a REST API formatted ACL object to our two-field mongo format.\nconst transformObjectACL = ({ ACL, ...result }) => {\n  if (!ACL) {\n    return result;\n  }\n\n  result._wperm = [];\n  result._rperm = [];\n\n  for (const entry in ACL) {\n    if (ACL[entry].read) {\n      result._rperm.push(entry);\n    }\n    if (ACL[entry].write) {\n      result._wperm.push(entry);\n    }\n  }\n  return result;\n};\n\nconst validateQuery = (\n  query: any,\n  isMaster: boolean,\n  isMaintenance: boolean,\n  update: boolean,\n  options: ?ParseServerOptions,\n  _depth: number = 0\n): void => {\n  if (isMaintenance) {\n    isMaster = true;\n  }\n  const rc = options?.requestComplexity;\n  if (!isMaster && rc && rc.queryDepth !== -1 && _depth > rc.queryDepth) {\n    throw new Parse.Error(\n      Parse.Error.INVALID_QUERY,\n      `Query condition nesting depth exceeds maximum allowed depth of ${rc.queryDepth}`\n    );\n  }\n  if (query.ACL) {\n    throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Cannot query on ACL.');\n  }\n\n  if (query.$or) {\n    if (query.$or instanceof Array) {\n      query.$or.forEach(value => validateQuery(value, isMaster, isMaintenance, update, options, _depth + 1));\n    } else {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Bad $or format - use an array value.');\n    }\n  }\n\n  if (query.$and) {\n    if (query.$and instanceof Array) {\n      query.$and.forEach(value => validateQuery(value, isMaster, isMaintenance, update, options, _depth + 1));\n    } else {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Bad $and format - use an array value.');\n    }\n  }\n\n  if (query.$nor) {\n    if (query.$nor instanceof Array && query.$nor.length > 0) {\n      query.$nor.forEach(value => validateQuery(value, isMaster, isMaintenance, update, options, _depth + 1));\n    } else {\n      throw new Parse.Error(\n        Parse.Error.INVALID_QUERY,\n        'Bad $nor format - use an array of at least 1 value.'\n      );\n    }\n  }\n\n  Object.keys(query).forEach(key => {\n    if (query && query[key] && query[key].$regex) {\n      if (typeof query[key].$options === 'string') {\n        if (!query[key].$options.match(/^[imxsu]+$/)) {\n          throw new Parse.Error(\n            Parse.Error.INVALID_QUERY,\n            `Bad $options value for query: ${query[key].$options}`\n          );\n        }\n      }\n    }\n    if (\n      !key.match(/^[a-zA-Z][a-zA-Z0-9_\\.]*$/) &&\n      !specialQueryKeys.includes(key) &&\n      !(isMaster && specialMasterQueryKeys.includes(key))\n    ) {\n      throw new Parse.Error(Parse.Error.INVALID_KEY_NAME, `Invalid key name: ${key}`);\n    }\n  });\n};\n\n// Filters out any data that shouldn't be on this REST-formatted object.\nconst filterSensitiveData = (\n  isMaster: boolean,\n  isMaintenance: boolean,\n  aclGroup: any[],\n  auth: any,\n  operation: any,\n  schema: SchemaController.SchemaController | any,\n  className: string,\n  protectedFields: null | Array<any>,\n  object: any\n) => {\n  let userId = null;\n  if (auth && auth.user) { userId = auth.user.id; }\n\n  // replace protectedFields when using pointer-permissions\n  const perms =\n    schema && schema.getClassLevelPermissions ? schema.getClassLevelPermissions(className) : {};\n  if (perms) {\n    const isReadOperation = ['get', 'find'].indexOf(operation) > -1;\n\n    if (isReadOperation && perms.protectedFields) {\n      // extract protectedFields added with the pointer-permission prefix\n      const protectedFieldsPointerPerm = Object.keys(perms.protectedFields)\n        .filter(key => key.startsWith('userField:'))\n        .map(key => {\n          return { key: key.substring(10), value: perms.protectedFields[key] };\n        });\n\n      const newProtectedFields: Array<string>[] = [];\n      let overrideProtectedFields = false;\n\n      // check if the object grants the current user access based on the extracted fields\n      protectedFieldsPointerPerm.forEach(pointerPerm => {\n        let pointerPermIncludesUser = false;\n        const readUserFieldValue = object[pointerPerm.key];\n        if (readUserFieldValue) {\n          if (Array.isArray(readUserFieldValue)) {\n            pointerPermIncludesUser = readUserFieldValue.some(\n              user => user.objectId && user.objectId === userId\n            );\n          } else {\n            pointerPermIncludesUser =\n              readUserFieldValue.objectId && readUserFieldValue.objectId === userId;\n          }\n        }\n\n        if (pointerPermIncludesUser) {\n          overrideProtectedFields = true;\n          newProtectedFields.push(pointerPerm.value);\n        }\n      });\n\n      // if at least one pointer-permission affected the current user\n      // intersect vs protectedFields from previous stage (@see addProtectedFields)\n      // Sets theory (intersections): A x (B x C) == (A x B) x C\n      if (overrideProtectedFields && protectedFields) {\n        newProtectedFields.push(protectedFields);\n      }\n      // intersect all sets of protectedFields\n      newProtectedFields.forEach(fields => {\n        if (fields) {\n          // if there're no protctedFields by other criteria ( id / role / auth)\n          // then we must intersect each set (per userField)\n          if (!protectedFields) {\n            protectedFields = fields;\n          } else {\n            protectedFields = protectedFields.filter(v => fields.includes(v));\n          }\n        }\n      });\n    }\n  }\n\n  const isUserClass = className === '_User';\n  if (isUserClass) {\n    object.password = object._hashed_password;\n    delete object._hashed_password;\n    delete object.sessionToken;\n  }\n\n  if (isMaintenance) {\n    return object;\n  }\n\n  /* special treat for the user class: don't filter protectedFields if currently loggedin user is\n  the retrieved user */\n  if (!(isUserClass && userId && object.objectId === userId)) {\n    protectedFields && protectedFields.forEach(k => delete object[k]);\n\n    // fields not requested by client (excluded),\n    // but were needed to apply protectedFields\n    perms?.protectedFields?.temporaryKeys?.forEach(k => delete object[k]);\n  }\n\n  for (const key in object) {\n    if (key.charAt(0) === '_') {\n      delete object[key];\n    }\n  }\n\n  if (!isUserClass || isMaster) {\n    return object;\n  }\n\n  if (aclGroup.indexOf(object.objectId) > -1) {\n    return object;\n  }\n  delete object.authData;\n  return object;\n};\n\n// Runs an update on the database.\n// Returns a promise for an object with the new values for field\n// modifications that don't know their results ahead of time, like\n// 'increment'.\n// Options:\n//   acl:  a list of strings. If the object to be updated has an ACL,\n//         one of the provided strings must provide the caller with\n//         write permissions.\nconst specialKeysForUpdate = Object.keys(internalFields).filter(k => internalFields[k].masterWrite);\n\nconst isSpecialUpdateKey = key => {\n  return specialKeysForUpdate.indexOf(key) >= 0;\n};\n\nfunction joinTableName(className, key) {\n  return `_Join:${key}:${className}`;\n}\n\nconst flattenUpdateOperatorsForCreate = object => {\n  for (const key in object) {\n    if (object[key] && object[key].__op) {\n      switch (object[key].__op) {\n        case 'Increment':\n          if (typeof object[key].amount !== 'number') {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = object[key].amount;\n          break;\n        case 'SetOnInsert':\n          object[key] = object[key].amount;\n          break;\n        case 'Add':\n          if (!(object[key].objects instanceof Array)) {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = object[key].objects;\n          break;\n        case 'AddUnique':\n          if (!(object[key].objects instanceof Array)) {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = object[key].objects;\n          break;\n        case 'Remove':\n          if (!(object[key].objects instanceof Array)) {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = [];\n          break;\n        case 'Delete':\n          delete object[key];\n          break;\n        default:\n          throw new Parse.Error(\n            Parse.Error.COMMAND_UNAVAILABLE,\n            `The ${object[key].__op} operator is not supported yet.`\n          );\n      }\n    }\n  }\n};\n\nconst transformAuthData = (className, object, schema) => {\n  if (object.authData && className === '_User') {\n    Object.keys(object.authData).forEach(provider => {\n      const providerData = object.authData[provider];\n      const fieldName = `_auth_data_${provider}`;\n      if (providerData == null) {\n        object[fieldName] = {\n          __op: 'Delete',\n        };\n      } else {\n        object[fieldName] = providerData;\n        schema.fields[fieldName] = { type: 'Object' };\n      }\n    });\n    delete object.authData;\n  }\n};\n// Transforms a Database format ACL to a REST API format ACL\nconst untransformObjectACL = ({ _rperm, _wperm, ...output }) => {\n  if (_rperm || _wperm) {\n    output.ACL = {};\n\n    (_rperm || []).forEach(entry => {\n      if (!output.ACL[entry]) {\n        output.ACL[entry] = { read: true };\n      } else {\n        output.ACL[entry]['read'] = true;\n      }\n    });\n\n    (_wperm || []).forEach(entry => {\n      if (!output.ACL[entry]) {\n        output.ACL[entry] = { write: true };\n      } else {\n        output.ACL[entry]['write'] = true;\n      }\n    });\n  }\n  return output;\n};\n\n/**\n * When querying, the fieldName may be compound, extract the root fieldName\n *     `temperature.celsius` becomes `temperature`\n * @param {string} fieldName that may be a compound field name\n * @returns {string} the root name of the field\n */\nconst getRootFieldName = (fieldName: string): string => {\n  return fieldName.split('.')[0];\n};\n\nconst relationSchema = {\n  fields: { relatedId: { type: 'String' }, owningId: { type: 'String' } },\n};\n\nconst convertEmailToLowercase = (object, className, options) => {\n  if (className === '_User' && options.convertEmailToLowercase) {\n    if (typeof object['email'] === 'string') {\n      object['email'] = object['email'].toLowerCase();\n    }\n  }\n};\n\nconst convertUsernameToLowercase = (object, className, options) => {\n  if (className === '_User' && options.convertUsernameToLowercase) {\n    if (typeof object['username'] === 'string') {\n      object['username'] = object['username'].toLowerCase();\n    }\n  }\n};\n\nclass DatabaseController {\n  adapter: StorageAdapter;\n  schemaCache: any;\n  schemaPromise: ?Promise<SchemaController.SchemaController>;\n  _transactionalSession: ?any;\n  options: ParseServerOptions;\n  idempotencyOptions: any;\n\n  constructor(adapter: StorageAdapter, options: ParseServerOptions) {\n    this.adapter = adapter;\n    this.options = options || {};\n    this.idempotencyOptions = this.options.idempotencyOptions || {};\n    // Prevent mutable this.schema, otherwise one request could use\n    // multiple schemas, so instead use loadSchema to get a schema.\n    this.schemaPromise = null;\n    this._transactionalSession = null;\n    this.options = options;\n  }\n\n  collectionExists(className: string): Promise<boolean> {\n    return this.adapter.classExists(className);\n  }\n\n  purgeCollection(className: string): Promise<void> {\n    return this.loadSchema()\n      .then(schemaController => schemaController.getOneSchema(className))\n      .then(schema => this.adapter.deleteObjectsByQuery(className, schema, {}));\n  }\n\n  validateClassName(className: string): Promise<void> {\n    if (!SchemaController.classNameIsValid(className)) {\n      return Promise.reject(\n        new Parse.Error(Parse.Error.INVALID_CLASS_NAME, 'invalid className: ' + className)\n      );\n    }\n    return Promise.resolve();\n  }\n\n  // Returns a promise for a schemaController.\n  loadSchema(\n    options: LoadSchemaOptions = { clearCache: false }\n  ): Promise<SchemaController.SchemaController> {\n    if (this.schemaPromise != null) {\n      return this.schemaPromise;\n    }\n    this.schemaPromise = SchemaController.load(this.adapter, options);\n    this.schemaPromise.then(\n      () => delete this.schemaPromise,\n      () => delete this.schemaPromise\n    );\n    return this.loadSchema(options);\n  }\n\n  loadSchemaIfNeeded(\n    schemaController: SchemaController.SchemaController,\n    options: LoadSchemaOptions = { clearCache: false }\n  ): Promise<SchemaController.SchemaController> {\n    return schemaController ? Promise.resolve(schemaController) : this.loadSchema(options);\n  }\n\n  // Returns a promise for the classname that is related to the given\n  // classname through the key.\n  // TODO: make this not in the DatabaseController interface\n  redirectClassNameForKey(className: string, key: string): Promise<?string> {\n    return this.loadSchema().then(schema => {\n      var t = schema.getExpectedType(className, key);\n      if (t != null && typeof t !== 'string' && t.type === 'Relation') {\n        return t.targetClass;\n      }\n      return className;\n    });\n  }\n\n  // Uses the schema to validate the object (REST API format).\n  // Returns a promise that resolves to the new schema.\n  // This does not update this.schema, because in a situation like a\n  // batch request, that could confuse other users of the schema.\n  validateObject(\n    className: string,\n    object: any,\n    query: any,\n    runOptions: QueryOptions,\n    maintenance: boolean\n  ): Promise<boolean> {\n    let schema;\n    const acl = runOptions.acl;\n    const isMaster = acl === undefined;\n    var aclGroup: string[] = acl || [];\n    return this.loadSchema()\n      .then(s => {\n        schema = s;\n        if (isMaster) {\n          return Promise.resolve();\n        }\n        return this.canAddField(schema, className, object, aclGroup, runOptions);\n      })\n      .then(() => {\n        return schema.validateObject(className, object, query, maintenance);\n      });\n  }\n\n  update(\n    className: string,\n    query: any,\n    update: any,\n    { acl, many, upsert, addsField }: FullQueryOptions = {},\n    skipSanitization: boolean = false,\n    validateOnly: boolean = false,\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    try {\n      Utils.checkProhibitedKeywords(this.options, update);\n    } catch (error) {\n      return Promise.reject(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n    }\n    try {\n      const { validateFileUrlsInObject } = require('../FileUrlValidator');\n      validateFileUrlsInObject(update, this.options);\n    } catch (error) {\n      return Promise.reject(error instanceof Parse.Error ? error : new Parse.Error(Parse.Error.FILE_SAVE_ERROR, error.message || error));\n    }\n    const originalQuery = query;\n    const originalUpdate = update;\n    // Make a copy of the object, so we don't mutate the incoming data.\n    update = structuredClone(update);\n    var relationUpdates = [];\n    var isMaster = acl === undefined;\n    var aclGroup = acl || [];\n\n    return this.loadSchemaIfNeeded(validSchemaController).then(schemaController => {\n      return (isMaster\n        ? Promise.resolve()\n        : schemaController.validatePermission(className, aclGroup, 'update')\n      )\n        .then(() => {\n          relationUpdates = this.collectRelationUpdates(className, originalQuery.objectId, update);\n          if (!isMaster) {\n            query = this.addPointerPermissions(\n              schemaController,\n              className,\n              'update',\n              query,\n              aclGroup\n            );\n\n            if (addsField) {\n              query = {\n                $and: [\n                  query,\n                  this.addPointerPermissions(\n                    schemaController,\n                    className,\n                    'addField',\n                    query,\n                    aclGroup\n                  ),\n                ],\n              };\n            }\n          }\n          if (!query) {\n            return Promise.resolve();\n          }\n          if (acl) {\n            query = addWriteACL(query, acl);\n          }\n          validateQuery(query, isMaster, false, true, this.options);\n          return schemaController\n            .getOneSchema(className, true)\n            .catch(error => {\n              // If the schema doesn't exist, pretend it exists with no fields. This behavior\n              // will likely need revisiting.\n              if (error === undefined) {\n                return { fields: {} };\n              }\n              throw error;\n            })\n            .then(schema => {\n              Object.keys(update).forEach(fieldName => {\n                if (fieldName.match(/^authData\\.([a-zA-Z0-9_]+)\\.id$/)) {\n                  throw new Parse.Error(\n                    Parse.Error.INVALID_KEY_NAME,\n                    `Invalid field name for update: ${fieldName}`\n                  );\n                }\n                const rootFieldName = getRootFieldName(fieldName);\n                if (\n                  !SchemaController.fieldNameIsValid(rootFieldName, className) &&\n                  !isSpecialUpdateKey(rootFieldName)\n                ) {\n                  throw new Parse.Error(\n                    Parse.Error.INVALID_KEY_NAME,\n                    `Invalid field name for update: ${fieldName}`\n                  );\n                }\n              });\n              for (const updateOperation in update) {\n                if (\n                  update[updateOperation] &&\n                  typeof update[updateOperation] === 'object' &&\n                  Object.keys(update[updateOperation]).some(\n                    innerKey => innerKey.includes('$') || innerKey.includes('.')\n                  )\n                ) {\n                  throw new Parse.Error(\n                    Parse.Error.INVALID_NESTED_KEY,\n                    \"Nested keys should not contain the '$' or '.' characters\"\n                  );\n                }\n              }\n              update = transformObjectACL(update);\n              convertEmailToLowercase(update, className, this.options);\n              convertUsernameToLowercase(update, className, this.options);\n              transformAuthData(className, update, schema);\n              if (validateOnly) {\n                return this.adapter.find(className, schema, query, { readPreference: 'primary' }).then(result => {\n                  if (!result || !result.length) {\n                    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n                  }\n                  return {};\n                });\n              }\n              if (many) {\n                return this.adapter.updateObjectsByQuery(\n                  className,\n                  schema,\n                  query,\n                  update,\n                  this._transactionalSession\n                );\n              } else if (upsert) {\n                return this.adapter.upsertOneObject(\n                  className,\n                  schema,\n                  query,\n                  update,\n                  this._transactionalSession\n                );\n              } else {\n                return this.adapter.findOneAndUpdate(\n                  className,\n                  schema,\n                  query,\n                  update,\n                  this._transactionalSession\n                );\n              }\n            });\n        })\n        .then((result: any) => {\n          if (!result) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n          }\n          if (validateOnly) {\n            return result;\n          }\n          return this.handleRelationUpdates(\n            className,\n            originalQuery.objectId,\n            update,\n            relationUpdates\n          ).then(() => {\n            return result;\n          });\n        })\n        .then(result => {\n          if (skipSanitization) {\n            return Promise.resolve(result);\n          }\n          return this._sanitizeDatabaseResult(originalUpdate, result);\n        });\n    });\n  }\n\n  // Collect all relation-updating operations from a REST-format update.\n  // Returns a list of all relation updates to perform\n  // This mutates update.\n  collectRelationUpdates(className: string, objectId: ?string, update: any) {\n    var ops = [];\n    var deleteMe = [];\n    objectId = update.objectId || objectId;\n\n    var process = (op, key) => {\n      if (!op) {\n        return;\n      }\n      if (op.__op == 'AddRelation') {\n        ops.push({ key, op });\n        deleteMe.push(key);\n      }\n\n      if (op.__op == 'RemoveRelation') {\n        ops.push({ key, op });\n        deleteMe.push(key);\n      }\n\n      if (op.__op == 'Batch') {\n        for (var x of op.ops) {\n          process(x, key);\n        }\n      }\n    };\n\n    for (const key in update) {\n      process(update[key], key);\n    }\n    for (const key of deleteMe) {\n      delete update[key];\n    }\n    return ops;\n  }\n\n  // Processes relation-updating operations from a REST-format update.\n  // Returns a promise that resolves when all updates have been performed\n  handleRelationUpdates(className: string, objectId: string, update: any, ops: any) {\n    var pending = [];\n    objectId = update.objectId || objectId;\n    ops.forEach(({ key, op }) => {\n      if (!op) {\n        return;\n      }\n      if (op.__op == 'AddRelation') {\n        for (const object of op.objects) {\n          pending.push(this.addRelation(key, className, objectId, object.objectId));\n        }\n      }\n\n      if (op.__op == 'RemoveRelation') {\n        for (const object of op.objects) {\n          pending.push(this.removeRelation(key, className, objectId, object.objectId));\n        }\n      }\n    });\n\n    return Promise.all(pending);\n  }\n\n  // Adds a relation.\n  // Returns a promise that resolves successfully iff the add was successful.\n  addRelation(key: string, fromClassName: string, fromId: string, toId: string) {\n    const doc = {\n      relatedId: toId,\n      owningId: fromId,\n    };\n    return this.adapter.upsertOneObject(\n      `_Join:${key}:${fromClassName}`,\n      relationSchema,\n      doc,\n      doc,\n      this._transactionalSession\n    );\n  }\n\n  // Removes a relation.\n  // Returns a promise that resolves successfully iff the remove was\n  // successful.\n  removeRelation(key: string, fromClassName: string, fromId: string, toId: string) {\n    var doc = {\n      relatedId: toId,\n      owningId: fromId,\n    };\n    return this.adapter\n      .deleteObjectsByQuery(\n        `_Join:${key}:${fromClassName}`,\n        relationSchema,\n        doc,\n        this._transactionalSession\n      )\n      .catch(error => {\n        // We don't care if they try to delete a non-existent relation.\n        if (error.code == Parse.Error.OBJECT_NOT_FOUND) {\n          return;\n        }\n        throw error;\n      });\n  }\n\n  // Removes objects matches this query from the database.\n  // Returns a promise that resolves successfully iff the object was\n  // deleted.\n  // Options:\n  //   acl:  a list of strings. If the object to be updated has an ACL,\n  //         one of the provided strings must provide the caller with\n  //         write permissions.\n  destroy(\n    className: string,\n    query: any,\n    { acl }: QueryOptions = {},\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    const isMaster = acl === undefined;\n    const aclGroup = acl || [];\n\n    return this.loadSchemaIfNeeded(validSchemaController).then(schemaController => {\n      return (isMaster\n        ? Promise.resolve()\n        : schemaController.validatePermission(className, aclGroup, 'delete')\n      ).then(() => {\n        if (!isMaster) {\n          query = this.addPointerPermissions(\n            schemaController,\n            className,\n            'delete',\n            query,\n            aclGroup\n          );\n          if (!query) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n          }\n        }\n        // delete by query\n        if (acl) {\n          query = addWriteACL(query, acl);\n        }\n        validateQuery(query, isMaster, false, false, this.options);\n        return schemaController\n          .getOneSchema(className)\n          .catch(error => {\n            // If the schema doesn't exist, pretend it exists with no fields. This behavior\n            // will likely need revisiting.\n            if (error === undefined) {\n              return { fields: {} };\n            }\n            throw error;\n          })\n          .then(parseFormatSchema =>\n            this.adapter.deleteObjectsByQuery(\n              className,\n              parseFormatSchema,\n              query,\n              this._transactionalSession\n            )\n          )\n          .catch(error => {\n            // When deleting sessions while changing passwords, don't throw an error if they don't have any sessions.\n            if (className === '_Session' && error.code === Parse.Error.OBJECT_NOT_FOUND) {\n              return Promise.resolve({});\n            }\n            throw error;\n          });\n      });\n    });\n  }\n\n  // Inserts an object into the database.\n  // Returns a promise that resolves successfully iff the object saved.\n  create(\n    className: string,\n    object: any,\n    { acl }: QueryOptions = {},\n    validateOnly: boolean = false,\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    try {\n      Utils.checkProhibitedKeywords(this.options, object);\n    } catch (error) {\n      return Promise.reject(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n    }\n    try {\n      const { validateFileUrlsInObject } = require('../FileUrlValidator');\n      validateFileUrlsInObject(object, this.options);\n    } catch (error) {\n      return Promise.reject(error instanceof Parse.Error ? error : new Parse.Error(Parse.Error.FILE_SAVE_ERROR, error.message || error));\n    }\n    // Make a copy of the object, so we don't mutate the incoming data.\n    const originalObject = object;\n    object = transformObjectACL(object);\n\n    convertEmailToLowercase(object, className, this.options);\n    convertUsernameToLowercase(object, className, this.options);\n    object.createdAt = { iso: object.createdAt, __type: 'Date' };\n    object.updatedAt = { iso: object.updatedAt, __type: 'Date' };\n\n    var isMaster = acl === undefined;\n    var aclGroup = acl || [];\n    const relationUpdates = this.collectRelationUpdates(className, null, object);\n\n    return this.validateClassName(className)\n      .then(() => this.loadSchemaIfNeeded(validSchemaController))\n      .then(schemaController => {\n        return (isMaster\n          ? Promise.resolve()\n          : schemaController.validatePermission(className, aclGroup, 'create')\n        )\n          .then(() => schemaController.enforceClassExists(className))\n          .then(() => schemaController.getOneSchema(className, true))\n          .then(schema => {\n            transformAuthData(className, object, schema);\n            flattenUpdateOperatorsForCreate(object);\n            if (validateOnly) {\n              return {};\n            }\n            return this.adapter.createObject(\n              className,\n              SchemaController.convertSchemaToAdapterSchema(schema),\n              object,\n              this._transactionalSession\n            );\n          })\n          .then(result => {\n            if (validateOnly) {\n              return originalObject;\n            }\n            return this.handleRelationUpdates(\n              className,\n              object.objectId,\n              object,\n              relationUpdates\n            ).then(() => {\n              return this._sanitizeDatabaseResult(originalObject, result.ops[0]);\n            });\n          });\n      });\n  }\n\n  canAddField(\n    schema: SchemaController.SchemaController,\n    className: string,\n    object: any,\n    aclGroup: string[],\n    runOptions: QueryOptions\n  ): Promise<void> {\n    const classSchema = schema.schemaData[className];\n    if (!classSchema) {\n      return Promise.resolve();\n    }\n    const fields = Object.keys(object);\n    const schemaFields = Object.keys(classSchema.fields);\n    const newKeys = fields.filter(field => {\n      // Skip fields that are unset\n      if (object[field] && object[field].__op && object[field].__op === 'Delete') {\n        return false;\n      }\n      return schemaFields.indexOf(getRootFieldName(field)) < 0;\n    });\n    if (newKeys.length > 0) {\n      // adds a marker that new field is being adding during update\n      runOptions.addsField = true;\n\n      const action = runOptions.action;\n      return schema.validatePermission(className, aclGroup, 'addField', action);\n    }\n    return Promise.resolve();\n  }\n\n  // Won't delete collections in the system namespace\n  /**\n   * Delete all classes and clears the schema cache\n   *\n   * @param {boolean} fast set to true if it's ok to just delete rows and not indexes\n   * @returns {Promise<void>} when the deletions completes\n   */\n  deleteEverything(fast: boolean = false): Promise<any> {\n    this.schemaPromise = null;\n    SchemaCache.clear();\n    return this.adapter.deleteAllClasses(fast);\n  }\n\n  // Returns a promise for a list of related ids given an owning id.\n  // className here is the owning className.\n  relatedIds(\n    className: string,\n    key: string,\n    owningId: string,\n    queryOptions: QueryOptions\n  ): Promise<Array<string>> {\n    const { skip, limit, sort } = queryOptions;\n    const findOptions = {};\n    if (sort && sort.createdAt && this.adapter.canSortOnJoinTables) {\n      findOptions.sort = { _id: sort.createdAt };\n      findOptions.limit = limit;\n      findOptions.skip = skip;\n      queryOptions.skip = 0;\n    }\n    return this.adapter\n      .find(joinTableName(className, key), relationSchema, { owningId }, findOptions)\n      .then(results => results.map(result => result.relatedId));\n  }\n\n  // Returns a promise for a list of owning ids given some related ids.\n  // className here is the owning className.\n  owningIds(className: string, key: string, relatedIds: string[]): Promise<string[]> {\n    return this.adapter\n      .find(\n        joinTableName(className, key),\n        relationSchema,\n        { relatedId: { $in: relatedIds } },\n        { keys: ['owningId'] }\n      )\n      .then(results => results.map(result => result.owningId));\n  }\n\n  // Modifies query so that it no longer has $in on relation fields, or\n  // equal-to-pointer constraints on relation fields.\n  // Returns a promise that resolves when query is mutated\n  reduceInRelation(className: string, query: any, schema: any): Promise<any> {\n    // Search for an in-relation or equal-to-relation\n    // Make it sequential for now, not sure of paralleization side effects\n    const promises = [];\n    if (query['$or']) {\n      const ors = query['$or'];\n      promises.push(\n        ...ors.map((aQuery, index) => {\n          return this.reduceInRelation(className, aQuery, schema).then(aQuery => {\n            query['$or'][index] = aQuery;\n          });\n        })\n      );\n    }\n    if (query['$and']) {\n      const ands = query['$and'];\n      promises.push(\n        ...ands.map((aQuery, index) => {\n          return this.reduceInRelation(className, aQuery, schema).then(aQuery => {\n            query['$and'][index] = aQuery;\n          });\n        })\n      );\n    }\n\n    const otherKeys = Object.keys(query).map(key => {\n      if (key === '$and' || key === '$or') {\n        return;\n      }\n      const t = schema.getExpectedType(className, key);\n      if (!t || t.type !== 'Relation') {\n        return Promise.resolve(query);\n      }\n      let queries: ?(any[]) = null;\n      if (\n        query[key] &&\n        (query[key]['$in'] ||\n          query[key]['$ne'] ||\n          query[key]['$nin'] ||\n          query[key].__type == 'Pointer')\n      ) {\n        // Build the list of queries\n        queries = Object.keys(query[key]).map(constraintKey => {\n          let relatedIds;\n          let isNegation = false;\n          if (constraintKey === 'objectId') {\n            relatedIds = [query[key].objectId];\n          } else if (constraintKey == '$in') {\n            relatedIds = query[key]['$in'].map(r => r.objectId);\n          } else if (constraintKey == '$nin') {\n            isNegation = true;\n            relatedIds = query[key]['$nin'].map(r => r.objectId);\n          } else if (constraintKey == '$ne') {\n            isNegation = true;\n            relatedIds = [query[key]['$ne'].objectId];\n          } else {\n            return;\n          }\n          return {\n            isNegation,\n            relatedIds,\n          };\n        });\n      } else {\n        queries = [{ isNegation: false, relatedIds: [] }];\n      }\n\n      // remove the current queryKey as we don,t need it anymore\n      delete query[key];\n      // execute each query independently to build the list of\n      // $in / $nin\n      const promises = queries.map(q => {\n        if (!q) {\n          return Promise.resolve();\n        }\n        return this.owningIds(className, key, q.relatedIds).then(ids => {\n          if (q.isNegation) {\n            this.addNotInObjectIdsIds(ids, query);\n          } else {\n            this.addInObjectIdsIds(ids, query);\n          }\n          return Promise.resolve();\n        });\n      });\n\n      return Promise.all(promises).then(() => {\n        return Promise.resolve();\n      });\n    });\n\n    return Promise.all([...promises, ...otherKeys]).then(() => {\n      return Promise.resolve(query);\n    });\n  }\n\n  // Modifies query so that it no longer has $relatedTo\n  // Returns a promise that resolves when query is mutated\n  reduceRelationKeys(className: string, query: any, queryOptions: any): ?Promise<void> {\n    if (query['$or']) {\n      return Promise.all(\n        query['$or'].map(aQuery => {\n          return this.reduceRelationKeys(className, aQuery, queryOptions);\n        })\n      );\n    }\n    if (query['$and']) {\n      return Promise.all(\n        query['$and'].map(aQuery => {\n          return this.reduceRelationKeys(className, aQuery, queryOptions);\n        })\n      );\n    }\n    var relatedTo = query['$relatedTo'];\n    if (relatedTo) {\n      return this.relatedIds(\n        relatedTo.object.className,\n        relatedTo.key,\n        relatedTo.object.objectId,\n        queryOptions\n      )\n        .then(ids => {\n          delete query['$relatedTo'];\n          this.addInObjectIdsIds(ids, query);\n          return this.reduceRelationKeys(className, query, queryOptions);\n        })\n        .then(() => {});\n    }\n  }\n\n  addInObjectIdsIds(ids: ?Array<string> = null, query: any) {\n    const idsFromString: ?Array<string> =\n      typeof query.objectId === 'string' ? [query.objectId] : null;\n    const idsFromEq: ?Array<string> =\n      query.objectId && query.objectId['$eq'] ? [query.objectId['$eq']] : null;\n    const idsFromIn: ?Array<string> =\n      query.objectId && query.objectId['$in'] ? query.objectId['$in'] : null;\n\n    // @flow-disable-next\n    const allIds: Array<Array<string>> = [idsFromString, idsFromEq, idsFromIn, ids].filter(\n      list => list !== null\n    );\n    const totalLength = allIds.reduce((memo, list) => memo + list.length, 0);\n\n    let idsIntersection = [];\n    if (totalLength > 125) {\n      idsIntersection = intersect.big(allIds);\n    } else {\n      idsIntersection = intersect(allIds);\n    }\n\n    // Need to make sure we don't clobber existing shorthand $eq constraints on objectId.\n    if (!('objectId' in query)) {\n      query.objectId = {\n        $in: undefined,\n      };\n    } else if (typeof query.objectId === 'string') {\n      query.objectId = {\n        $in: undefined,\n        $eq: query.objectId,\n      };\n    }\n    query.objectId['$in'] = idsIntersection;\n\n    return query;\n  }\n\n  addNotInObjectIdsIds(ids: string[] = [], query: any) {\n    const idsFromNin = query.objectId && query.objectId['$nin'] ? query.objectId['$nin'] : [];\n    let allIds = [...idsFromNin, ...ids].filter(list => list !== null);\n\n    // make a set and spread to remove duplicates\n    allIds = [...new Set(allIds)];\n\n    // Need to make sure we don't clobber existing shorthand $eq constraints on objectId.\n    if (!('objectId' in query)) {\n      query.objectId = {\n        $nin: undefined,\n      };\n    } else if (typeof query.objectId === 'string') {\n      query.objectId = {\n        $nin: undefined,\n        $eq: query.objectId,\n      };\n    }\n\n    query.objectId['$nin'] = allIds;\n    return query;\n  }\n\n  // Runs a query on the database.\n  // Returns a promise that resolves to a list of items.\n  // Options:\n  //   skip    number of results to skip.\n  //   limit   limit to this number of results.\n  //   sort    an object where keys are the fields to sort by.\n  //           the value is +1 for ascending, -1 for descending.\n  //   count   run a count instead of returning results.\n  //   acl     restrict this operation with an ACL for the provided array\n  //           of user objectIds and roles. acl: null means no user.\n  //           when this field is not present, don't do anything regarding ACLs.\n  //  caseInsensitive make string comparisons case insensitive\n  // TODO: make userIds not needed here. The db adapter shouldn't know\n  // anything about users, ideally. Then, improve the format of the ACL\n  // arg to work like the others.\n  find(\n    className: string,\n    query: any,\n    {\n      skip,\n      limit,\n      acl,\n      sort = {},\n      count,\n      keys,\n      op,\n      distinct,\n      pipeline,\n      readPreference,\n      hint,\n      caseInsensitive = false,\n      explain,\n      comment,\n    }: any = {},\n    auth: any = {},\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    const isMaintenance = auth.isMaintenance;\n    const isMaster = acl === undefined || isMaintenance;\n    const aclGroup = acl || [];\n    op =\n      op || (typeof query.objectId == 'string' && Object.keys(query).length === 1 ? 'get' : 'find');\n    // Count operation if counting\n    op = count === true ? 'count' : op;\n\n    let classExists = true;\n    return this.loadSchemaIfNeeded(validSchemaController).then(schemaController => {\n      //Allow volatile classes if querying with Master (for _PushStatus)\n      //TODO: Move volatile classes concept into mongo adapter, postgres adapter shouldn't care\n      //that api.parse.com breaks when _PushStatus exists in mongo.\n      return schemaController\n        .getOneSchema(className, isMaster)\n        .catch(error => {\n          // Behavior for non-existent classes is kinda weird on Parse.com. Probably doesn't matter too much.\n          // For now, pretend the class exists but has no objects,\n          if (error === undefined) {\n            classExists = false;\n            return { fields: {} };\n          }\n          throw error;\n        })\n        .then(schema => {\n          // Parse.com treats queries on _created_at and _updated_at as if they were queries on createdAt and updatedAt,\n          // so duplicate that behavior here. If both are specified, the correct behavior to match Parse.com is to\n          // use the one that appears first in the sort list.\n          if (sort._created_at) {\n            sort.createdAt = sort._created_at;\n            delete sort._created_at;\n          }\n          if (sort._updated_at) {\n            sort.updatedAt = sort._updated_at;\n            delete sort._updated_at;\n          }\n          const queryOptions = {\n            skip,\n            limit,\n            sort,\n            keys,\n            readPreference,\n            hint,\n            caseInsensitive: this.options.enableCollationCaseComparison ? false : caseInsensitive,\n            explain,\n            comment,\n          };\n          Object.keys(sort).forEach(fieldName => {\n            if (fieldName.match(/^authData\\.([a-zA-Z0-9_]+)\\.id$/)) {\n              throw new Parse.Error(Parse.Error.INVALID_KEY_NAME, `Cannot sort by ${fieldName}`);\n            }\n            const rootFieldName = getRootFieldName(fieldName);\n            if (!SchemaController.fieldNameIsValid(rootFieldName, className)) {\n              throw new Parse.Error(\n                Parse.Error.INVALID_KEY_NAME,\n                `Invalid field name: ${fieldName}.`\n              );\n            }\n            if (!schema.fields[fieldName.split('.')[0]] && fieldName !== 'score') {\n              delete sort[fieldName];\n            }\n          });\n          return (isMaster\n            ? Promise.resolve()\n            : schemaController.validatePermission(className, aclGroup, op)\n          )\n            .then(() => this.reduceRelationKeys(className, query, queryOptions))\n            .then(() => this.reduceInRelation(className, query, schemaController))\n            .then(() => {\n              let protectedFields;\n              if (!isMaster) {\n                query = this.addPointerPermissions(\n                  schemaController,\n                  className,\n                  op,\n                  query,\n                  aclGroup\n                );\n                /* Don't use projections to optimize the protectedFields since the protectedFields\n                  based on pointer-permissions are determined after querying. The filtering can\n                  overwrite the protected fields. */\n                protectedFields = this.addProtectedFields(\n                  schemaController,\n                  className,\n                  query,\n                  aclGroup,\n                  auth,\n                  queryOptions\n                );\n              }\n              if (!query) {\n                if (op === 'get') {\n                  throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n                } else {\n                  return [];\n                }\n              }\n              if (!isMaster) {\n                if (op === 'update' || op === 'delete') {\n                  query = addWriteACL(query, aclGroup);\n                } else {\n                  query = addReadACL(query, aclGroup);\n                }\n              }\n              validateQuery(query, isMaster, isMaintenance, false, this.options);\n              if (count) {\n                if (!classExists) {\n                  return 0;\n                } else {\n                  return this.adapter.count(\n                    className,\n                    schema,\n                    query,\n                    readPreference,\n                    undefined,\n                    hint,\n                    comment\n                  );\n                }\n              } else if (distinct) {\n                if (!classExists) {\n                  return [];\n                } else {\n                  return this.adapter.distinct(className, schema, query, distinct);\n                }\n              } else if (pipeline) {\n                if (!classExists) {\n                  return [];\n                } else {\n                  return this.adapter.aggregate(\n                    className,\n                    schema,\n                    pipeline,\n                    readPreference,\n                    hint,\n                    explain,\n                    comment\n                  );\n                }\n              } else if (explain) {\n                return this.adapter.find(className, schema, query, queryOptions);\n              } else {\n                return this.adapter\n                  .find(className, schema, query, queryOptions)\n                  .then(objects =>\n                    objects.map(object => {\n                      object = untransformObjectACL(object);\n                      return filterSensitiveData(\n                        isMaster,\n                        isMaintenance,\n                        aclGroup,\n                        auth,\n                        op,\n                        schemaController,\n                        className,\n                        protectedFields,\n                        object\n                      );\n                    })\n                  )\n                  .catch(error => {\n                    if (error instanceof Parse.Error) {\n                      throw error;\n                    }\n                    const detailedMessage =\n                      typeof error === 'string'\n                        ? error\n                        : error?.message || 'An internal server error occurred';\n                    throw createSanitizedError(\n                      Parse.Error.INTERNAL_SERVER_ERROR,\n                      detailedMessage,\n                      this.options,\n                      'An internal server error occurred'\n                    );\n                  });\n              }\n            });\n        });\n    });\n  }\n\n  deleteSchema(className: string): Promise<void> {\n    let schemaController;\n    return this.loadSchema({ clearCache: true })\n      .then(s => {\n        schemaController = s;\n        return schemaController.getOneSchema(className, true);\n      })\n      .catch(error => {\n        if (error === undefined) {\n          return { fields: {} };\n        } else {\n          throw error;\n        }\n      })\n      .then((schema: any) => {\n        return this.collectionExists(className)\n          .then(() => this.adapter.count(className, { fields: {} }, null, '', false))\n          .then(count => {\n            if (count > 0) {\n              throw new Parse.Error(\n                255,\n                `Class ${className} is not empty, contains ${count} objects, cannot drop schema.`\n              );\n            }\n            return this.adapter.deleteClass(className);\n          })\n          .then(wasParseCollection => {\n            if (wasParseCollection) {\n              const relationFieldNames = Object.keys(schema.fields).filter(\n                fieldName => schema.fields[fieldName].type === 'Relation'\n              );\n              return Promise.all(\n                relationFieldNames.map(name =>\n                  this.adapter.deleteClass(joinTableName(className, name))\n                )\n              ).then(() => {\n                SchemaCache.del(className);\n                return schemaController.reloadData();\n              });\n            } else {\n              return Promise.resolve();\n            }\n          });\n      });\n  }\n\n  // This helps to create intermediate objects for simpler comparison of\n  // key value pairs used in query objects. Each key value pair will represented\n  // in a similar way to json\n  objectToEntriesStrings(query: any): Array<string> {\n    return Object.entries(query).map(a => a.map(s => JSON.stringify(s)).join(':'));\n  }\n\n  // Naive logic reducer for OR operations meant to be used only for pointer permissions.\n  reduceOrOperation(query: { $or: Array<any> }): any {\n    if (!query.$or) {\n      return query;\n    }\n    const queries = query.$or.map(q => this.objectToEntriesStrings(q));\n    let repeat = false;\n    do {\n      repeat = false;\n      for (let i = 0; i < queries.length - 1; i++) {\n        for (let j = i + 1; j < queries.length; j++) {\n          const [shorter, longer] = queries[i].length > queries[j].length ? [j, i] : [i, j];\n          const foundEntries = queries[shorter].reduce(\n            (acc, entry) => acc + (queries[longer].includes(entry) ? 1 : 0),\n            0\n          );\n          const shorterEntries = queries[shorter].length;\n          if (foundEntries === shorterEntries) {\n            // If the shorter query is completely contained in the longer one, we can strike\n            // out the longer query.\n            query.$or.splice(longer, 1);\n            queries.splice(longer, 1);\n            repeat = true;\n            break;\n          }\n        }\n      }\n    } while (repeat);\n    if (query.$or.length === 1) {\n      query = { ...query, ...query.$or[0] };\n      delete query.$or;\n    }\n    return query;\n  }\n\n  // Naive logic reducer for AND operations meant to be used only for pointer permissions.\n  reduceAndOperation(query: { $and: Array<any> }): any {\n    if (!query.$and) {\n      return query;\n    }\n    const queries = query.$and.map(q => this.objectToEntriesStrings(q));\n    let repeat = false;\n    do {\n      repeat = false;\n      for (let i = 0; i < queries.length - 1; i++) {\n        for (let j = i + 1; j < queries.length; j++) {\n          const [shorter, longer] = queries[i].length > queries[j].length ? [j, i] : [i, j];\n          const foundEntries = queries[shorter].reduce(\n            (acc, entry) => acc + (queries[longer].includes(entry) ? 1 : 0),\n            0\n          );\n          const shorterEntries = queries[shorter].length;\n          if (foundEntries === shorterEntries) {\n            // If the shorter query is completely contained in the longer one, we can strike\n            // out the shorter query.\n            query.$and.splice(shorter, 1);\n            queries.splice(shorter, 1);\n            repeat = true;\n            break;\n          }\n        }\n      }\n    } while (repeat);\n    if (query.$and.length === 1) {\n      query = { ...query, ...query.$and[0] };\n      delete query.$and;\n    }\n    return query;\n  }\n\n  // Constraints query using CLP's pointer permissions (PP) if any.\n  // 1. Etract the user id from caller's ACLgroup;\n  // 2. Exctract a list of field names that are PP for target collection and operation;\n  // 3. Constraint the original query so that each PP field must\n  // point to caller's id (or contain it in case of PP field being an array)\n  addPointerPermissions(\n    schema: SchemaController.SchemaController,\n    className: string,\n    operation: string,\n    query: any,\n    aclGroup: any[] = []\n  ): any {\n    // Check if class has public permission for operation\n    // If the BaseCLP pass, let go through\n    if (schema.testPermissionsForClassName(className, aclGroup, operation)) {\n      return query;\n    }\n    const perms = schema.getClassLevelPermissions(className);\n\n    const userACL = aclGroup.filter(acl => {\n      return acl.indexOf('role:') != 0 && acl != '*';\n    });\n\n    const groupKey =\n      ['get', 'find', 'count'].indexOf(operation) > -1 ? 'readUserFields' : 'writeUserFields';\n\n    const permFields = [];\n\n    if (perms[operation] && perms[operation].pointerFields) {\n      permFields.push(...perms[operation].pointerFields);\n    }\n\n    if (perms[groupKey]) {\n      for (const field of perms[groupKey]) {\n        if (!permFields.includes(field)) {\n          permFields.push(field);\n        }\n      }\n    }\n    // the ACL should have exactly 1 user\n    if (permFields.length > 0) {\n      // the ACL should have exactly 1 user\n      // No user set return undefined\n      // If the length is > 1, that means we didn't de-dupe users correctly\n      if (userACL.length != 1) {\n        return;\n      }\n      const userId = userACL[0];\n      const userPointer = {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: userId,\n      };\n\n      const queries = permFields.map(key => {\n        const fieldDescriptor = schema.getExpectedType(className, key);\n        const fieldType =\n          fieldDescriptor &&\n          typeof fieldDescriptor === 'object' &&\n          Object.prototype.hasOwnProperty.call(fieldDescriptor, 'type')\n            ? fieldDescriptor.type\n            : null;\n\n        let queryClause;\n\n        if (fieldType === 'Pointer') {\n          // constraint for single pointer setup\n          queryClause = { [key]: userPointer };\n        } else if (fieldType === 'Array') {\n          // constraint for users-array setup\n          queryClause = { [key]: { $all: [userPointer] } };\n        } else if (fieldType === 'Object') {\n          // constraint for object setup\n          queryClause = { [key]: userPointer };\n        } else {\n          // This means that there is a CLP field of an unexpected type. This condition should not happen, which is\n          // why is being treated as an error.\n          throw Error(\n            `An unexpected condition occurred when resolving pointer permissions: ${className} ${key}`\n          );\n        }\n        // if we already have a constraint on the key, use the $and\n        if (Object.prototype.hasOwnProperty.call(query, key)) {\n          return this.reduceAndOperation({ $and: [queryClause, query] });\n        }\n        // otherwise just add the constaint\n        return Object.assign({}, query, queryClause);\n      });\n\n      return queries.length === 1 ? queries[0] : this.reduceOrOperation({ $or: queries });\n    } else {\n      return query;\n    }\n  }\n\n  addProtectedFields(\n    schema: SchemaController.SchemaController | any,\n    className: string,\n    query: any = {},\n    aclGroup: any[] = [],\n    auth: any = {},\n    queryOptions: FullQueryOptions = {}\n  ): null | string[] {\n    const perms =\n      schema && schema.getClassLevelPermissions\n        ? schema.getClassLevelPermissions(className)\n        : schema;\n    if (!perms) { return null; }\n\n    const protectedFields = perms.protectedFields;\n    if (!protectedFields) { return null; }\n\n    if (aclGroup.indexOf(query.objectId) > -1) { return null; }\n\n    // for queries where \"keys\" are set and do not include all 'userField':{field},\n    // we have to transparently include it, and then remove before returning to client\n    // Because if such key not projected the permission won't be enforced properly\n    // PS this is called when 'excludeKeys' already reduced to 'keys'\n    const preserveKeys = queryOptions.keys;\n\n    // these are keys that need to be included only\n    // to be able to apply protectedFields by pointer\n    // and then unset before returning to client (later in  filterSensitiveFields)\n    const serverOnlyKeys = [];\n\n    const authenticated = auth.user;\n\n    // map to allow check without array search\n    const roles = (auth.userRoles || []).reduce((acc, r) => {\n      acc[r] = protectedFields[r];\n      return acc;\n    }, {});\n\n    // array of sets of protected fields. separate item for each applicable criteria\n    const protectedKeysSets = [];\n\n    for (const key in protectedFields) {\n      // skip userFields\n      if (key.startsWith('userField:')) {\n        if (preserveKeys) {\n          const fieldName = key.substring(10);\n          if (!preserveKeys.includes(fieldName)) {\n            // 1. put it there temporarily\n            queryOptions.keys && queryOptions.keys.push(fieldName);\n            // 2. preserve it delete later\n            serverOnlyKeys.push(fieldName);\n          }\n        }\n        continue;\n      }\n\n      // add public tier\n      if (key === '*') {\n        protectedKeysSets.push(protectedFields[key]);\n        continue;\n      }\n\n      if (authenticated) {\n        if (key === 'authenticated') {\n          // for logged in users\n          protectedKeysSets.push(protectedFields[key]);\n          continue;\n        }\n\n        if (roles[key] && key.startsWith('role:')) {\n          // add applicable roles\n          protectedKeysSets.push(roles[key]);\n        }\n      }\n    }\n\n    // check if there's a rule for current user's id\n    if (authenticated) {\n      const userId = auth.user.id;\n      if (perms.protectedFields[userId]) {\n        protectedKeysSets.push(perms.protectedFields[userId]);\n      }\n    }\n\n    // preserve fields to be removed before sending response to client\n    if (serverOnlyKeys.length > 0) {\n      perms.protectedFields.temporaryKeys = serverOnlyKeys;\n    }\n\n    let protectedKeys = protectedKeysSets.reduce((acc, next) => {\n      if (next) {\n        acc.push(...next);\n      }\n      return acc;\n    }, []);\n\n    // intersect all sets of protectedFields\n    protectedKeysSets.forEach(fields => {\n      if (fields) {\n        protectedKeys = protectedKeys.filter(v => fields.includes(v));\n      }\n    });\n\n    return protectedKeys;\n  }\n\n  createTransactionalSession() {\n    return this.adapter.createTransactionalSession().then(transactionalSession => {\n      this._transactionalSession = transactionalSession;\n    });\n  }\n\n  commitTransactionalSession() {\n    if (!this._transactionalSession) {\n      throw new Error('There is no transactional session to commit');\n    }\n    return this.adapter.commitTransactionalSession(this._transactionalSession).then(() => {\n      this._transactionalSession = null;\n    });\n  }\n\n  abortTransactionalSession() {\n    if (!this._transactionalSession) {\n      throw new Error('There is no transactional session to abort');\n    }\n    return this.adapter.abortTransactionalSession(this._transactionalSession).then(() => {\n      this._transactionalSession = null;\n    });\n  }\n\n  // TODO: create indexes on first creation of a _User object. Otherwise it's impossible to\n  // have a Parse app without it having a _User collection.\n  async performInitialization() {\n    await this.adapter.performInitialization({\n      VolatileClassesSchemas: SchemaController.VolatileClassesSchemas,\n    });\n    const requiredUserFields = {\n      fields: {\n        ...SchemaController.defaultColumns._Default,\n        ...SchemaController.defaultColumns._User,\n      },\n    };\n    const requiredRoleFields = {\n      fields: {\n        ...SchemaController.defaultColumns._Default,\n        ...SchemaController.defaultColumns._Role,\n      },\n    };\n    const requiredIdempotencyFields = {\n      fields: {\n        ...SchemaController.defaultColumns._Default,\n        ...SchemaController.defaultColumns._Idempotency,\n      },\n    };\n    await this.loadSchema().then(schema => schema.enforceClassExists('_User'));\n    await this.loadSchema().then(schema => schema.enforceClassExists('_Role'));\n    await this.loadSchema().then(schema => schema.enforceClassExists('_Idempotency'));\n\n    const databaseOptions = this.options.databaseOptions || {};\n\n    if (databaseOptions.createIndexUserUsername !== false) {\n      await this.adapter.ensureUniqueness('_User', requiredUserFields, ['username']).catch(error => {\n        logger.warn('Unable to ensure uniqueness for usernames: ', error);\n        throw error;\n      });\n    }\n\n    if (!this.options.enableCollationCaseComparison) {\n      if (databaseOptions.createIndexUserUsernameCaseInsensitive !== false) {\n        await this.adapter\n          .ensureIndex('_User', requiredUserFields, ['username'], 'case_insensitive_username', true)\n          .catch(error => {\n            logger.warn('Unable to create case insensitive username index: ', error);\n            throw error;\n          });\n      }\n\n      if (databaseOptions.createIndexUserEmailCaseInsensitive !== false) {\n        await this.adapter\n          .ensureIndex('_User', requiredUserFields, ['email'], 'case_insensitive_email', true)\n          .catch(error => {\n            logger.warn('Unable to create case insensitive email index: ', error);\n            throw error;\n          });\n      }\n    }\n\n    if (databaseOptions.createIndexUserEmail !== false) {\n      await this.adapter.ensureUniqueness('_User', requiredUserFields, ['email']).catch(error => {\n        logger.warn('Unable to ensure uniqueness for user email addresses: ', error);\n        throw error;\n      });\n    }\n\n    if (databaseOptions.createIndexUserEmailVerifyToken !== false) {\n      await this.adapter\n        .ensureIndex('_User', requiredUserFields, ['_email_verify_token'], '_email_verify_token', false)\n        .catch(error => {\n          logger.warn('Unable to create index for email verification token: ', error);\n          throw error;\n        });\n    }\n\n    if (databaseOptions.createIndexUserPasswordResetToken !== false) {\n      await this.adapter\n        .ensureIndex('_User', requiredUserFields, ['_perishable_token'], '_perishable_token', false)\n        .catch(error => {\n          logger.warn('Unable to create index for password reset token: ', error);\n          throw error;\n        });\n    }\n\n    if (databaseOptions.createIndexRoleName !== false) {\n      await this.adapter.ensureUniqueness('_Role', requiredRoleFields, ['name']).catch(error => {\n        logger.warn('Unable to ensure uniqueness for role name: ', error);\n        throw error;\n      });\n    }\n\n    await this.adapter\n      .ensureUniqueness('_Idempotency', requiredIdempotencyFields, ['reqId'])\n      .catch(error => {\n        logger.warn('Unable to ensure uniqueness for idempotency request ID: ', error);\n        throw error;\n      });\n\n    const isMongoAdapter = this.adapter instanceof MongoStorageAdapter;\n    const isPostgresAdapter = this.adapter instanceof PostgresStorageAdapter;\n    if (isMongoAdapter || isPostgresAdapter) {\n      let options = {};\n      if (isMongoAdapter) {\n        options = {\n          ttl: 0,\n        };\n      } else if (isPostgresAdapter) {\n        options = this.idempotencyOptions;\n        options.setIdempotencyFunction = true;\n      }\n      await this.adapter\n        .ensureIndex('_Idempotency', requiredIdempotencyFields, ['expire'], 'ttl', false, options)\n        .catch(error => {\n          logger.warn('Unable to create TTL index for idempotency expire date: ', error);\n          throw error;\n        });\n    }\n    // Create unique indexes for authData providers to prevent race conditions\n    // during concurrent signups with the same authData\n    if (\n      databaseOptions.createIndexAuthDataUniqueness !== false &&\n      typeof this.adapter.ensureAuthDataUniqueness === 'function'\n    ) {\n      const authProviders = Object.keys(this.options.auth || {});\n      if (this.options.enableAnonymousUsers !== false) {\n        if (!authProviders.includes('anonymous')) {\n          authProviders.push('anonymous');\n        }\n      }\n      await Promise.all(\n        authProviders.map(provider =>\n          this.adapter.ensureAuthDataUniqueness(provider).catch(error => {\n            logger.warn(\n              `Unable to ensure uniqueness for auth data provider \"${provider}\": `,\n              error\n            );\n          })\n        )\n      );\n    }\n\n    await this.adapter.updateSchemaWithIndexes();\n  }\n\n  _expandResultOnKeyPath(object: any, key: string, value: any): any {\n    if (key.indexOf('.') < 0) {\n      object[key] = value[key];\n      return object;\n    }\n    const path = key.split('.');\n    const firstKey = path[0];\n    const nextPath = path.slice(1).join('.');\n\n    // Scan request data for denied keywords\n    if (this.options && this.options.requestKeywordDenylist) {\n      // Scan request data for denied keywords\n      for (const keyword of this.options.requestKeywordDenylist) {\n        const match = Utils.objectContainsKeyValue(\n          { [firstKey]: true, [nextPath]: true },\n          keyword.key,\n          true\n        );\n        if (match) {\n          throw new Parse.Error(\n            Parse.Error.INVALID_KEY_NAME,\n            `Prohibited keyword in request data: ${JSON.stringify(keyword)}.`\n          );\n        }\n      }\n    }\n\n    object[firstKey] = this._expandResultOnKeyPath(\n      object[firstKey] || {},\n      nextPath,\n      value[firstKey]\n    );\n    delete object[key];\n    return object;\n  }\n\n  _sanitizeDatabaseResult(originalObject: any, result: any): Promise<any> {\n    const response = {};\n    if (!result) {\n      return Promise.resolve(response);\n    }\n    Object.keys(originalObject).forEach(key => {\n      const keyUpdate = originalObject[key];\n      // determine if that was an op\n      if (\n        keyUpdate &&\n        typeof keyUpdate === 'object' &&\n        keyUpdate.__op &&\n        ['Add', 'AddUnique', 'Remove', 'Increment', 'SetOnInsert'].indexOf(keyUpdate.__op) > -1\n      ) {\n        // only valid ops that produce an actionable result\n        // the op may have happened on a keypath\n        this._expandResultOnKeyPath(response, key, result);\n        // Revert array to object conversion on dot notation for arrays (e.g. \"field.0.key\")\n        if (key.includes('.')) {\n          const [field, index] = key.split('.');\n          const isArrayIndex = Array.from(index).every(c => c >= '0' && c <= '9');\n          if (isArrayIndex && Array.isArray(result[field]) && !Array.isArray(response[field])) {\n            response[field] = result[field];\n          }\n        }\n      }\n    });\n    return Promise.resolve(response);\n  }\n\n  static _validateQuery: (any, boolean, boolean, boolean) => void;\n  static filterSensitiveData: (boolean, boolean, any[], any, any, any, string, any[], any) => void;\n}\n\nmodule.exports = DatabaseController;\n// Expose validateQuery for tests\nmodule.exports._validateQuery = validateQuery;\nmodule.exports.filterSensitiveData = filterSensitiveData;\n"],"mappings":";;AAKA,IAAAA,KAAA,GAAAC,OAAA;AAEA,IAAAC,OAAA,GAAAC,sBAAA,CAAAF,OAAA;AAEA,IAAAG,UAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,OAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,MAAA,GAAAH,sBAAA,CAAAF,OAAA;AACA,IAAAM,gBAAA,GAAAC,uBAAA,CAAAP,OAAA;AACA,IAAAQ,eAAA,GAAAR,OAAA;AACA,IAAAS,oBAAA,GAAAP,sBAAA,CAAAF,OAAA;AACA,IAAAU,uBAAA,GAAAR,sBAAA,CAAAF,OAAA;AACA,IAAAW,YAAA,GAAAT,sBAAA,CAAAF,OAAA;AAIA,IAAAY,MAAA,GAAAZ,OAAA;AAAgD,SAAAO,wBAAAM,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAR,uBAAA,YAAAA,CAAAM,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,QAAAC,OAAA,EAAAV,CAAA,iBAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,gBAAAP,CAAA,IAAAD,CAAA,gBAAAC,CAAA,OAAAa,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAC,CAAA,OAAAM,CAAA,IAAAD,CAAA,GAAAU,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAlB,CAAA,EAAAC,CAAA,OAAAM,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAP,CAAA,EAAAM,CAAA,IAAAC,CAAA,CAAAP,CAAA,IAAAD,CAAA,CAAAC,CAAA,WAAAO,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAAA,SAAAZ,uBAAAW,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAK,UAAA,GAAAL,CAAA,KAAAU,OAAA,EAAAV,CAAA;AAnBhD;AACA;AAEA;AAEA;AAEA;AAcA;AACA,MAAMmB,cAAc,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC;;AAE9C;AACA;AACA;AACA;AACA;AACA,MAAMC,cAAc,GAAG;EACrBC,MAAM,EAA0B;IAAEC,UAAU,EAAE,IAAI;IAAGC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FC,MAAM,EAA0B;IAAEH,UAAU,EAAE,IAAI;IAAGC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FE,gBAAgB,EAAgB;IAAEJ,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,KAAK;IAAEC,WAAW,EAAE;EAAM,CAAC;EAC5FG,mBAAmB,EAAa;IAAEL,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FI,iBAAiB,EAAe;IAAEN,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FK,4BAA4B,EAAI;IAAEP,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FM,8BAA8B,EAAE;IAAER,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FO,mBAAmB,EAAa;IAAET,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FQ,2BAA2B,EAAK;IAAEV,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FS,oBAAoB,EAAY;IAAEX,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FU,iBAAiB,EAAe;IAAEZ,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FW,UAAU,EAAsB;IAAEb,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM,CAAC;EAC5FY,cAAc,EAAkB;IAAEd,UAAU,EAAE,KAAK;IAAEC,UAAU,EAAE,IAAI;IAAGC,WAAW,EAAE;EAAM;EAC3F;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACF,CAAC;;AAED;AACA,MAAMa,gBAAgB,GAAG,CACvB,GAAGlB,cAAc,EACjB,GAAGH,MAAM,CAACsB,IAAI,CAAClB,cAAc,CAAC,CAACmB,MAAM,CAACC,CAAC,IAAIpB,cAAc,CAACoB,CAAC,CAAC,CAAClB,UAAU,CAAC,CACzE;AACD,MAAMmB,sBAAsB,GAAG,CAC7B,GAAGtB,cAAc,EACjB,GAAGH,MAAM,CAACsB,IAAI,CAAClB,cAAc,CAAC,CAACmB,MAAM,CAACC,CAAC,IAAIpB,cAAc,CAACoB,CAAC,CAAC,CAACjB,UAAU,CAAC,CACzE;AAED,SAASmB,WAAWA,CAACC,KAAK,EAAEC,GAAG,EAAE;EAC/B,MAAMC,QAAQ,GAAGC,eAAC,CAACC,SAAS,CAACJ,KAAK,CAAC;EACnC;EACAE,QAAQ,CAACpB,MAAM,GAAG;IAAEuB,GAAG,EAAE,CAAC,IAAI,EAAE,GAAGJ,GAAG;EAAE,CAAC;EACzC,OAAOC,QAAQ;AACjB;AAEA,SAASI,UAAUA,CAACN,KAAK,EAAEC,GAAG,EAAE;EAC9B,MAAMC,QAAQ,GAAGC,eAAC,CAACC,SAAS,CAACJ,KAAK,CAAC;EACnC;EACAE,QAAQ,CAACxB,MAAM,GAAG;IAAE2B,GAAG,EAAE,CAAC,IAAI,EAAE,GAAG,EAAE,GAAGJ,GAAG;EAAE,CAAC;EAC9C,OAAOC,QAAQ;AACjB;;AAEA;AACA,MAAMK,kBAAkB,GAAGA,CAAC;EAAEC,GAAG;EAAE,GAAGC;AAAO,CAAC,KAAK;EACjD,IAAI,CAACD,GAAG,EAAE;IACR,OAAOC,MAAM;EACf;EAEAA,MAAM,CAAC3B,MAAM,GAAG,EAAE;EAClB2B,MAAM,CAAC/B,MAAM,GAAG,EAAE;EAElB,KAAK,MAAMgC,KAAK,IAAIF,GAAG,EAAE;IACvB,IAAIA,GAAG,CAACE,KAAK,CAAC,CAACC,IAAI,EAAE;MACnBF,MAAM,CAAC/B,MAAM,CAACkC,IAAI,CAACF,KAAK,CAAC;IAC3B;IACA,IAAIF,GAAG,CAACE,KAAK,CAAC,CAACG,KAAK,EAAE;MACpBJ,MAAM,CAAC3B,MAAM,CAAC8B,IAAI,CAACF,KAAK,CAAC;IAC3B;EACF;EACA,OAAOD,MAAM;AACf,CAAC;AAED,MAAMK,aAAa,GAAGA,CACpBd,KAAU,EACVe,QAAiB,EACjBC,aAAsB,EACtBC,MAAe,EACfC,OAA4B,EAC5BC,MAAc,GAAG,CAAC,KACT;EACT,IAAIH,aAAa,EAAE;IACjBD,QAAQ,GAAG,IAAI;EACjB;EACA,MAAMK,EAAE,GAAGF,OAAO,EAAEG,iBAAiB;EACrC,IAAI,CAACN,QAAQ,IAAIK,EAAE,IAAIA,EAAE,CAACE,UAAU,KAAK,CAAC,CAAC,IAAIH,MAAM,GAAGC,EAAE,CAACE,UAAU,EAAE;IACrE,MAAM,IAAIC,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACC,aAAa,EACzB,kEAAkEL,EAAE,CAACE,UAAU,EACjF,CAAC;EACH;EACA,IAAItB,KAAK,CAACQ,GAAG,EAAE;IACb,MAAM,IAAIe,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACC,aAAa,EAAE,sBAAsB,CAAC;EAC1E;EAEA,IAAIzB,KAAK,CAAC0B,GAAG,EAAE;IACb,IAAI1B,KAAK,CAAC0B,GAAG,YAAYC,KAAK,EAAE;MAC9B3B,KAAK,CAAC0B,GAAG,CAACE,OAAO,CAACC,KAAK,IAAIf,aAAa,CAACe,KAAK,EAAEd,QAAQ,EAAEC,aAAa,EAAEC,MAAM,EAAEC,OAAO,EAAEC,MAAM,GAAG,CAAC,CAAC,CAAC;IACxG,CAAC,MAAM;MACL,MAAM,IAAII,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACC,aAAa,EAAE,sCAAsC,CAAC;IAC1F;EACF;EAEA,IAAIzB,KAAK,CAAC8B,IAAI,EAAE;IACd,IAAI9B,KAAK,CAAC8B,IAAI,YAAYH,KAAK,EAAE;MAC/B3B,KAAK,CAAC8B,IAAI,CAACF,OAAO,CAACC,KAAK,IAAIf,aAAa,CAACe,KAAK,EAAEd,QAAQ,EAAEC,aAAa,EAAEC,MAAM,EAAEC,OAAO,EAAEC,MAAM,GAAG,CAAC,CAAC,CAAC;IACzG,CAAC,MAAM;MACL,MAAM,IAAII,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACC,aAAa,EAAE,uCAAuC,CAAC;IAC3F;EACF;EAEA,IAAIzB,KAAK,CAAC+B,IAAI,EAAE;IACd,IAAI/B,KAAK,CAAC+B,IAAI,YAAYJ,KAAK,IAAI3B,KAAK,CAAC+B,IAAI,CAACC,MAAM,GAAG,CAAC,EAAE;MACxDhC,KAAK,CAAC+B,IAAI,CAACH,OAAO,CAACC,KAAK,IAAIf,aAAa,CAACe,KAAK,EAAEd,QAAQ,EAAEC,aAAa,EAAEC,MAAM,EAAEC,OAAO,EAAEC,MAAM,GAAG,CAAC,CAAC,CAAC;IACzG,CAAC,MAAM;MACL,MAAM,IAAII,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACC,aAAa,EACzB,qDACF,CAAC;IACH;EACF;EAEApD,MAAM,CAACsB,IAAI,CAACK,KAAK,CAAC,CAAC4B,OAAO,CAACK,GAAG,IAAI;IAChC,IAAIjC,KAAK,IAAIA,KAAK,CAACiC,GAAG,CAAC,IAAIjC,KAAK,CAACiC,GAAG,CAAC,CAACC,MAAM,EAAE;MAC5C,IAAI,OAAOlC,KAAK,CAACiC,GAAG,CAAC,CAACE,QAAQ,KAAK,QAAQ,EAAE;QAC3C,IAAI,CAACnC,KAAK,CAACiC,GAAG,CAAC,CAACE,QAAQ,CAACC,KAAK,CAAC,YAAY,CAAC,EAAE;UAC5C,MAAM,IAAIb,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACC,aAAa,EACzB,iCAAiCzB,KAAK,CAACiC,GAAG,CAAC,CAACE,QAAQ,EACtD,CAAC;QACH;MACF;IACF;IACA,IACE,CAACF,GAAG,CAACG,KAAK,CAAC,2BAA2B,CAAC,IACvC,CAAC1C,gBAAgB,CAAC2C,QAAQ,CAACJ,GAAG,CAAC,IAC/B,EAAElB,QAAQ,IAAIjB,sBAAsB,CAACuC,QAAQ,CAACJ,GAAG,CAAC,CAAC,EACnD;MACA,MAAM,IAAIV,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAAE,qBAAqBL,GAAG,EAAE,CAAC;IACjF;EACF,CAAC,CAAC;AACJ,CAAC;;AAED;AACA,MAAMM,mBAAmB,GAAGA,CAC1BxB,QAAiB,EACjBC,aAAsB,EACtBwB,QAAe,EACfC,IAAS,EACTC,SAAc,EACdC,MAA+C,EAC/CC,SAAiB,EACjBC,eAAkC,EAClCC,MAAW,KACR;EACH,IAAIC,MAAM,GAAG,IAAI;EACjB,IAAIN,IAAI,IAAIA,IAAI,CAACO,IAAI,EAAE;IAAED,MAAM,GAAGN,IAAI,CAACO,IAAI,CAACC,EAAE;EAAE;;EAEhD;EACA,MAAMC,KAAK,GACTP,MAAM,IAAIA,MAAM,CAACQ,wBAAwB,GAAGR,MAAM,CAACQ,wBAAwB,CAACP,SAAS,CAAC,GAAG,CAAC,CAAC;EAC7F,IAAIM,KAAK,EAAE;IACT,MAAME,eAAe,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAACC,OAAO,CAACX,SAAS,CAAC,GAAG,CAAC,CAAC;IAE/D,IAAIU,eAAe,IAAIF,KAAK,CAACL,eAAe,EAAE;MAC5C;MACA,MAAMS,0BAA0B,GAAGjF,MAAM,CAACsB,IAAI,CAACuD,KAAK,CAACL,eAAe,CAAC,CAClEjD,MAAM,CAACqC,GAAG,IAAIA,GAAG,CAACsB,UAAU,CAAC,YAAY,CAAC,CAAC,CAC3CC,GAAG,CAACvB,GAAG,IAAI;QACV,OAAO;UAAEA,GAAG,EAAEA,GAAG,CAACwB,SAAS,CAAC,EAAE,CAAC;UAAE5B,KAAK,EAAEqB,KAAK,CAACL,eAAe,CAACZ,GAAG;QAAE,CAAC;MACtE,CAAC,CAAC;MAEJ,MAAMyB,kBAAmC,GAAG,EAAE;MAC9C,IAAIC,uBAAuB,GAAG,KAAK;;MAEnC;MACAL,0BAA0B,CAAC1B,OAAO,CAACgC,WAAW,IAAI;QAChD,IAAIC,uBAAuB,GAAG,KAAK;QACnC,MAAMC,kBAAkB,GAAGhB,MAAM,CAACc,WAAW,CAAC3B,GAAG,CAAC;QAClD,IAAI6B,kBAAkB,EAAE;UACtB,IAAInC,KAAK,CAACoC,OAAO,CAACD,kBAAkB,CAAC,EAAE;YACrCD,uBAAuB,GAAGC,kBAAkB,CAACE,IAAI,CAC/ChB,IAAI,IAAIA,IAAI,CAACiB,QAAQ,IAAIjB,IAAI,CAACiB,QAAQ,KAAKlB,MAC7C,CAAC;UACH,CAAC,MAAM;YACLc,uBAAuB,GACrBC,kBAAkB,CAACG,QAAQ,IAAIH,kBAAkB,CAACG,QAAQ,KAAKlB,MAAM;UACzE;QACF;QAEA,IAAIc,uBAAuB,EAAE;UAC3BF,uBAAuB,GAAG,IAAI;UAC9BD,kBAAkB,CAAC9C,IAAI,CAACgD,WAAW,CAAC/B,KAAK,CAAC;QAC5C;MACF,CAAC,CAAC;;MAEF;MACA;MACA;MACA,IAAI8B,uBAAuB,IAAId,eAAe,EAAE;QAC9Ca,kBAAkB,CAAC9C,IAAI,CAACiC,eAAe,CAAC;MAC1C;MACA;MACAa,kBAAkB,CAAC9B,OAAO,CAACsC,MAAM,IAAI;QACnC,IAAIA,MAAM,EAAE;UACV;UACA;UACA,IAAI,CAACrB,eAAe,EAAE;YACpBA,eAAe,GAAGqB,MAAM;UAC1B,CAAC,MAAM;YACLrB,eAAe,GAAGA,eAAe,CAACjD,MAAM,CAACuE,CAAC,IAAID,MAAM,CAAC7B,QAAQ,CAAC8B,CAAC,CAAC,CAAC;UACnE;QACF;MACF,CAAC,CAAC;IACJ;EACF;EAEA,MAAMC,WAAW,GAAGxB,SAAS,KAAK,OAAO;EACzC,IAAIwB,WAAW,EAAE;IACftB,MAAM,CAACuB,QAAQ,GAAGvB,MAAM,CAAC/D,gBAAgB;IACzC,OAAO+D,MAAM,CAAC/D,gBAAgB;IAC9B,OAAO+D,MAAM,CAACwB,YAAY;EAC5B;EAEA,IAAItD,aAAa,EAAE;IACjB,OAAO8B,MAAM;EACf;;EAEA;AACF;EACE,IAAI,EAAEsB,WAAW,IAAIrB,MAAM,IAAID,MAAM,CAACmB,QAAQ,KAAKlB,MAAM,CAAC,EAAE;IAC1DF,eAAe,IAAIA,eAAe,CAACjB,OAAO,CAAC/B,CAAC,IAAI,OAAOiD,MAAM,CAACjD,CAAC,CAAC,CAAC;;IAEjE;IACA;IACAqD,KAAK,EAAEL,eAAe,EAAE0B,aAAa,EAAE3C,OAAO,CAAC/B,CAAC,IAAI,OAAOiD,MAAM,CAACjD,CAAC,CAAC,CAAC;EACvE;EAEA,KAAK,MAAMoC,GAAG,IAAIa,MAAM,EAAE;IACxB,IAAIb,GAAG,CAACuC,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;MACzB,OAAO1B,MAAM,CAACb,GAAG,CAAC;IACpB;EACF;EAEA,IAAI,CAACmC,WAAW,IAAIrD,QAAQ,EAAE;IAC5B,OAAO+B,MAAM;EACf;EAEA,IAAIN,QAAQ,CAACa,OAAO,CAACP,MAAM,CAACmB,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE;IAC1C,OAAOnB,MAAM;EACf;EACA,OAAOA,MAAM,CAAC2B,QAAQ;EACtB,OAAO3B,MAAM;AACf,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM4B,oBAAoB,GAAGrG,MAAM,CAACsB,IAAI,CAAClB,cAAc,CAAC,CAACmB,MAAM,CAACC,CAAC,IAAIpB,cAAc,CAACoB,CAAC,CAAC,CAAChB,WAAW,CAAC;AAEnG,MAAM8F,kBAAkB,GAAG1C,GAAG,IAAI;EAChC,OAAOyC,oBAAoB,CAACrB,OAAO,CAACpB,GAAG,CAAC,IAAI,CAAC;AAC/C,CAAC;AAED,SAAS2C,aAAaA,CAAChC,SAAS,EAAEX,GAAG,EAAE;EACrC,OAAO,SAASA,GAAG,IAAIW,SAAS,EAAE;AACpC;AAEA,MAAMiC,+BAA+B,GAAG/B,MAAM,IAAI;EAChD,KAAK,MAAMb,GAAG,IAAIa,MAAM,EAAE;IACxB,IAAIA,MAAM,CAACb,GAAG,CAAC,IAAIa,MAAM,CAACb,GAAG,CAAC,CAAC6C,IAAI,EAAE;MACnC,QAAQhC,MAAM,CAACb,GAAG,CAAC,CAAC6C,IAAI;QACtB,KAAK,WAAW;UACd,IAAI,OAAOhC,MAAM,CAACb,GAAG,CAAC,CAAC8C,MAAM,KAAK,QAAQ,EAAE;YAC1C,MAAM,IAAIxD,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACwD,YAAY,EAAE,iCAAiC,CAAC;UACpF;UACAlC,MAAM,CAACb,GAAG,CAAC,GAAGa,MAAM,CAACb,GAAG,CAAC,CAAC8C,MAAM;UAChC;QACF,KAAK,aAAa;UAChBjC,MAAM,CAACb,GAAG,CAAC,GAAGa,MAAM,CAACb,GAAG,CAAC,CAAC8C,MAAM;UAChC;QACF,KAAK,KAAK;UACR,IAAI,EAAEjC,MAAM,CAACb,GAAG,CAAC,CAACgD,OAAO,YAAYtD,KAAK,CAAC,EAAE;YAC3C,MAAM,IAAIJ,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACwD,YAAY,EAAE,iCAAiC,CAAC;UACpF;UACAlC,MAAM,CAACb,GAAG,CAAC,GAAGa,MAAM,CAACb,GAAG,CAAC,CAACgD,OAAO;UACjC;QACF,KAAK,WAAW;UACd,IAAI,EAAEnC,MAAM,CAACb,GAAG,CAAC,CAACgD,OAAO,YAAYtD,KAAK,CAAC,EAAE;YAC3C,MAAM,IAAIJ,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACwD,YAAY,EAAE,iCAAiC,CAAC;UACpF;UACAlC,MAAM,CAACb,GAAG,CAAC,GAAGa,MAAM,CAACb,GAAG,CAAC,CAACgD,OAAO;UACjC;QACF,KAAK,QAAQ;UACX,IAAI,EAAEnC,MAAM,CAACb,GAAG,CAAC,CAACgD,OAAO,YAAYtD,KAAK,CAAC,EAAE;YAC3C,MAAM,IAAIJ,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACwD,YAAY,EAAE,iCAAiC,CAAC;UACpF;UACAlC,MAAM,CAACb,GAAG,CAAC,GAAG,EAAE;UAChB;QACF,KAAK,QAAQ;UACX,OAAOa,MAAM,CAACb,GAAG,CAAC;UAClB;QACF;UACE,MAAM,IAAIV,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAAC0D,mBAAmB,EAC/B,OAAOpC,MAAM,CAACb,GAAG,CAAC,CAAC6C,IAAI,iCACzB,CAAC;MACL;IACF;EACF;AACF,CAAC;AAED,MAAMK,iBAAiB,GAAGA,CAACvC,SAAS,EAAEE,MAAM,EAAEH,MAAM,KAAK;EACvD,IAAIG,MAAM,CAAC2B,QAAQ,IAAI7B,SAAS,KAAK,OAAO,EAAE;IAC5CvE,MAAM,CAACsB,IAAI,CAACmD,MAAM,CAAC2B,QAAQ,CAAC,CAAC7C,OAAO,CAACwD,QAAQ,IAAI;MAC/C,MAAMC,YAAY,GAAGvC,MAAM,CAAC2B,QAAQ,CAACW,QAAQ,CAAC;MAC9C,MAAME,SAAS,GAAG,cAAcF,QAAQ,EAAE;MAC1C,IAAIC,YAAY,IAAI,IAAI,EAAE;QACxBvC,MAAM,CAACwC,SAAS,CAAC,GAAG;UAClBR,IAAI,EAAE;QACR,CAAC;MACH,CAAC,MAAM;QACLhC,MAAM,CAACwC,SAAS,CAAC,GAAGD,YAAY;QAChC1C,MAAM,CAACuB,MAAM,CAACoB,SAAS,CAAC,GAAG;UAAEC,IAAI,EAAE;QAAS,CAAC;MAC/C;IACF,CAAC,CAAC;IACF,OAAOzC,MAAM,CAAC2B,QAAQ;EACxB;AACF,CAAC;AACD;AACA,MAAMe,oBAAoB,GAAGA,CAAC;EAAE9G,MAAM;EAAEI,MAAM;EAAE,GAAG2G;AAAO,CAAC,KAAK;EAC9D,IAAI/G,MAAM,IAAII,MAAM,EAAE;IACpB2G,MAAM,CAACjF,GAAG,GAAG,CAAC,CAAC;IAEf,CAAC9B,MAAM,IAAI,EAAE,EAAEkD,OAAO,CAAClB,KAAK,IAAI;MAC9B,IAAI,CAAC+E,MAAM,CAACjF,GAAG,CAACE,KAAK,CAAC,EAAE;QACtB+E,MAAM,CAACjF,GAAG,CAACE,KAAK,CAAC,GAAG;UAAEC,IAAI,EAAE;QAAK,CAAC;MACpC,CAAC,MAAM;QACL8E,MAAM,CAACjF,GAAG,CAACE,KAAK,CAAC,CAAC,MAAM,CAAC,GAAG,IAAI;MAClC;IACF,CAAC,CAAC;IAEF,CAAC5B,MAAM,IAAI,EAAE,EAAE8C,OAAO,CAAClB,KAAK,IAAI;MAC9B,IAAI,CAAC+E,MAAM,CAACjF,GAAG,CAACE,KAAK,CAAC,EAAE;QACtB+E,MAAM,CAACjF,GAAG,CAACE,KAAK,CAAC,GAAG;UAAEG,KAAK,EAAE;QAAK,CAAC;MACrC,CAAC,MAAM;QACL4E,MAAM,CAACjF,GAAG,CAACE,KAAK,CAAC,CAAC,OAAO,CAAC,GAAG,IAAI;MACnC;IACF,CAAC,CAAC;EACJ;EACA,OAAO+E,MAAM;AACf,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA,MAAMC,gBAAgB,GAAIJ,SAAiB,IAAa;EACtD,OAAOA,SAAS,CAACK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChC,CAAC;AAED,MAAMC,cAAc,GAAG;EACrB1B,MAAM,EAAE;IAAE2B,SAAS,EAAE;MAAEN,IAAI,EAAE;IAAS,CAAC;IAAEO,QAAQ,EAAE;MAAEP,IAAI,EAAE;IAAS;EAAE;AACxE,CAAC;AAED,MAAMQ,uBAAuB,GAAGA,CAACjD,MAAM,EAAEF,SAAS,EAAE1B,OAAO,KAAK;EAC9D,IAAI0B,SAAS,KAAK,OAAO,IAAI1B,OAAO,CAAC6E,uBAAuB,EAAE;IAC5D,IAAI,OAAOjD,MAAM,CAAC,OAAO,CAAC,KAAK,QAAQ,EAAE;MACvCA,MAAM,CAAC,OAAO,CAAC,GAAGA,MAAM,CAAC,OAAO,CAAC,CAACkD,WAAW,CAAC,CAAC;IACjD;EACF;AACF,CAAC;AAED,MAAMC,0BAA0B,GAAGA,CAACnD,MAAM,EAAEF,SAAS,EAAE1B,OAAO,KAAK;EACjE,IAAI0B,SAAS,KAAK,OAAO,IAAI1B,OAAO,CAAC+E,0BAA0B,EAAE;IAC/D,IAAI,OAAOnD,MAAM,CAAC,UAAU,CAAC,KAAK,QAAQ,EAAE;MAC1CA,MAAM,CAAC,UAAU,CAAC,GAAGA,MAAM,CAAC,UAAU,CAAC,CAACkD,WAAW,CAAC,CAAC;IACvD;EACF;AACF,CAAC;AAED,MAAME,kBAAkB,CAAC;EAQvBC,WAAWA,CAACC,OAAuB,EAAElF,OAA2B,EAAE;IAChE,IAAI,CAACkF,OAAO,GAAGA,OAAO;IACtB,IAAI,CAAClF,OAAO,GAAGA,OAAO,IAAI,CAAC,CAAC;IAC5B,IAAI,CAACmF,kBAAkB,GAAG,IAAI,CAACnF,OAAO,CAACmF,kBAAkB,IAAI,CAAC,CAAC;IAC/D;IACA;IACA,IAAI,CAACC,aAAa,GAAG,IAAI;IACzB,IAAI,CAACC,qBAAqB,GAAG,IAAI;IACjC,IAAI,CAACrF,OAAO,GAAGA,OAAO;EACxB;EAEAsF,gBAAgBA,CAAC5D,SAAiB,EAAoB;IACpD,OAAO,IAAI,CAACwD,OAAO,CAACK,WAAW,CAAC7D,SAAS,CAAC;EAC5C;EAEA8D,eAAeA,CAAC9D,SAAiB,EAAiB;IAChD,OAAO,IAAI,CAAC+D,UAAU,CAAC,CAAC,CACrBC,IAAI,CAACC,gBAAgB,IAAIA,gBAAgB,CAACC,YAAY,CAAClE,SAAS,CAAC,CAAC,CAClEgE,IAAI,CAACjE,MAAM,IAAI,IAAI,CAACyD,OAAO,CAACW,oBAAoB,CAACnE,SAAS,EAAED,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;EAC7E;EAEAqE,iBAAiBA,CAACpE,SAAiB,EAAiB;IAClD,IAAI,CAAC9F,gBAAgB,CAACmK,gBAAgB,CAACrE,SAAS,CAAC,EAAE;MACjD,OAAOsE,OAAO,CAACC,MAAM,CACnB,IAAI5F,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAAC4F,kBAAkB,EAAE,qBAAqB,GAAGxE,SAAS,CACnF,CAAC;IACH;IACA,OAAOsE,OAAO,CAACG,OAAO,CAAC,CAAC;EAC1B;;EAEA;EACAV,UAAUA,CACRzF,OAA0B,GAAG;IAAEoG,UAAU,EAAE;EAAM,CAAC,EACN;IAC5C,IAAI,IAAI,CAAChB,aAAa,IAAI,IAAI,EAAE;MAC9B,OAAO,IAAI,CAACA,aAAa;IAC3B;IACA,IAAI,CAACA,aAAa,GAAGxJ,gBAAgB,CAACyK,IAAI,CAAC,IAAI,CAACnB,OAAO,EAAElF,OAAO,CAAC;IACjE,IAAI,CAACoF,aAAa,CAACM,IAAI,CACrB,MAAM,OAAO,IAAI,CAACN,aAAa,EAC/B,MAAM,OAAO,IAAI,CAACA,aACpB,CAAC;IACD,OAAO,IAAI,CAACK,UAAU,CAACzF,OAAO,CAAC;EACjC;EAEAsG,kBAAkBA,CAChBX,gBAAmD,EACnD3F,OAA0B,GAAG;IAAEoG,UAAU,EAAE;EAAM,CAAC,EACN;IAC5C,OAAOT,gBAAgB,GAAGK,OAAO,CAACG,OAAO,CAACR,gBAAgB,CAAC,GAAG,IAAI,CAACF,UAAU,CAACzF,OAAO,CAAC;EACxF;;EAEA;EACA;EACA;EACAuG,uBAAuBA,CAAC7E,SAAiB,EAAEX,GAAW,EAAoB;IACxE,OAAO,IAAI,CAAC0E,UAAU,CAAC,CAAC,CAACC,IAAI,CAACjE,MAAM,IAAI;MACtC,IAAIrF,CAAC,GAAGqF,MAAM,CAAC+E,eAAe,CAAC9E,SAAS,EAAEX,GAAG,CAAC;MAC9C,IAAI3E,CAAC,IAAI,IAAI,IAAI,OAAOA,CAAC,KAAK,QAAQ,IAAIA,CAAC,CAACiI,IAAI,KAAK,UAAU,EAAE;QAC/D,OAAOjI,CAAC,CAACqK,WAAW;MACtB;MACA,OAAO/E,SAAS;IAClB,CAAC,CAAC;EACJ;;EAEA;EACA;EACA;EACA;EACAgF,cAAcA,CACZhF,SAAiB,EACjBE,MAAW,EACX9C,KAAU,EACV6H,UAAwB,EACxBC,WAAoB,EACF;IAClB,IAAInF,MAAM;IACV,MAAM1C,GAAG,GAAG4H,UAAU,CAAC5H,GAAG;IAC1B,MAAMc,QAAQ,GAAGd,GAAG,KAAK8H,SAAS;IAClC,IAAIvF,QAAkB,GAAGvC,GAAG,IAAI,EAAE;IAClC,OAAO,IAAI,CAAC0G,UAAU,CAAC,CAAC,CACrBC,IAAI,CAACoB,CAAC,IAAI;MACTrF,MAAM,GAAGqF,CAAC;MACV,IAAIjH,QAAQ,EAAE;QACZ,OAAOmG,OAAO,CAACG,OAAO,CAAC,CAAC;MAC1B;MACA,OAAO,IAAI,CAACY,WAAW,CAACtF,MAAM,EAAEC,SAAS,EAAEE,MAAM,EAAEN,QAAQ,EAAEqF,UAAU,CAAC;IAC1E,CAAC,CAAC,CACDjB,IAAI,CAAC,MAAM;MACV,OAAOjE,MAAM,CAACiF,cAAc,CAAChF,SAAS,EAAEE,MAAM,EAAE9C,KAAK,EAAE8H,WAAW,CAAC;IACrE,CAAC,CAAC;EACN;EAEA7G,MAAMA,CACJ2B,SAAiB,EACjB5C,KAAU,EACViB,MAAW,EACX;IAAEhB,GAAG;IAAEiI,IAAI;IAAEC,MAAM;IAAEC;EAA4B,CAAC,GAAG,CAAC,CAAC,EACvDC,gBAAyB,GAAG,KAAK,EACjCC,YAAqB,GAAG,KAAK,EAC7BC,qBAAwD,EAC1C;IACd,IAAI;MACFC,cAAK,CAACC,uBAAuB,CAAC,IAAI,CAACvH,OAAO,EAAED,MAAM,CAAC;IACrD,CAAC,CAAC,OAAOyH,KAAK,EAAE;MACd,OAAOxB,OAAO,CAACC,MAAM,CAAC,IAAI5F,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAAEoG,KAAK,CAAC,CAAC;IAC7E;IACA,IAAI;MACF,MAAM;QAAEC;MAAyB,CAAC,GAAGnM,OAAO,CAAC,qBAAqB,CAAC;MACnEmM,wBAAwB,CAAC1H,MAAM,EAAE,IAAI,CAACC,OAAO,CAAC;IAChD,CAAC,CAAC,OAAOwH,KAAK,EAAE;MACd,OAAOxB,OAAO,CAACC,MAAM,CAACuB,KAAK,YAAYnH,WAAK,CAACC,KAAK,GAAGkH,KAAK,GAAG,IAAInH,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACoH,eAAe,EAAEF,KAAK,CAACG,OAAO,IAAIH,KAAK,CAAC,CAAC;IACpI;IACA,MAAMI,aAAa,GAAG9I,KAAK;IAC3B,MAAM+I,cAAc,GAAG9H,MAAM;IAC7B;IACAA,MAAM,GAAG+H,eAAe,CAAC/H,MAAM,CAAC;IAChC,IAAIgI,eAAe,GAAG,EAAE;IACxB,IAAIlI,QAAQ,GAAGd,GAAG,KAAK8H,SAAS;IAChC,IAAIvF,QAAQ,GAAGvC,GAAG,IAAI,EAAE;IAExB,OAAO,IAAI,CAACuH,kBAAkB,CAACe,qBAAqB,CAAC,CAAC3B,IAAI,CAACC,gBAAgB,IAAI;MAC7E,OAAO,CAAC9F,QAAQ,GACZmG,OAAO,CAACG,OAAO,CAAC,CAAC,GACjBR,gBAAgB,CAACqC,kBAAkB,CAACtG,SAAS,EAAEJ,QAAQ,EAAE,QAAQ,CAAC,EAEnEoE,IAAI,CAAC,MAAM;QACVqC,eAAe,GAAG,IAAI,CAACE,sBAAsB,CAACvG,SAAS,EAAEkG,aAAa,CAAC7E,QAAQ,EAAEhD,MAAM,CAAC;QACxF,IAAI,CAACF,QAAQ,EAAE;UACbf,KAAK,GAAG,IAAI,CAACoJ,qBAAqB,CAChCvC,gBAAgB,EAChBjE,SAAS,EACT,QAAQ,EACR5C,KAAK,EACLwC,QACF,CAAC;UAED,IAAI4F,SAAS,EAAE;YACbpI,KAAK,GAAG;cACN8B,IAAI,EAAE,CACJ9B,KAAK,EACL,IAAI,CAACoJ,qBAAqB,CACxBvC,gBAAgB,EAChBjE,SAAS,EACT,UAAU,EACV5C,KAAK,EACLwC,QACF,CAAC;YAEL,CAAC;UACH;QACF;QACA,IAAI,CAACxC,KAAK,EAAE;UACV,OAAOkH,OAAO,CAACG,OAAO,CAAC,CAAC;QAC1B;QACA,IAAIpH,GAAG,EAAE;UACPD,KAAK,GAAGD,WAAW,CAACC,KAAK,EAAEC,GAAG,CAAC;QACjC;QACAa,aAAa,CAACd,KAAK,EAAEe,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAACG,OAAO,CAAC;QACzD,OAAO2F,gBAAgB,CACpBC,YAAY,CAAClE,SAAS,EAAE,IAAI,CAAC,CAC7ByG,KAAK,CAACX,KAAK,IAAI;UACd;UACA;UACA,IAAIA,KAAK,KAAKX,SAAS,EAAE;YACvB,OAAO;cAAE7D,MAAM,EAAE,CAAC;YAAE,CAAC;UACvB;UACA,MAAMwE,KAAK;QACb,CAAC,CAAC,CACD9B,IAAI,CAACjE,MAAM,IAAI;UACdtE,MAAM,CAACsB,IAAI,CAACsB,MAAM,CAAC,CAACW,OAAO,CAAC0D,SAAS,IAAI;YACvC,IAAIA,SAAS,CAAClD,KAAK,CAAC,iCAAiC,CAAC,EAAE;cACtD,MAAM,IAAIb,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAC5B,kCAAkCgD,SAAS,EAC7C,CAAC;YACH;YACA,MAAMgE,aAAa,GAAG5D,gBAAgB,CAACJ,SAAS,CAAC;YACjD,IACE,CAACxI,gBAAgB,CAACyM,gBAAgB,CAACD,aAAa,EAAE1G,SAAS,CAAC,IAC5D,CAAC+B,kBAAkB,CAAC2E,aAAa,CAAC,EAClC;cACA,MAAM,IAAI/H,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAC5B,kCAAkCgD,SAAS,EAC7C,CAAC;YACH;UACF,CAAC,CAAC;UACF,KAAK,MAAMkE,eAAe,IAAIvI,MAAM,EAAE;YACpC,IACEA,MAAM,CAACuI,eAAe,CAAC,IACvB,OAAOvI,MAAM,CAACuI,eAAe,CAAC,KAAK,QAAQ,IAC3CnL,MAAM,CAACsB,IAAI,CAACsB,MAAM,CAACuI,eAAe,CAAC,CAAC,CAACxF,IAAI,CACvCyF,QAAQ,IAAIA,QAAQ,CAACpH,QAAQ,CAAC,GAAG,CAAC,IAAIoH,QAAQ,CAACpH,QAAQ,CAAC,GAAG,CAC7D,CAAC,EACD;cACA,MAAM,IAAId,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACkI,kBAAkB,EAC9B,0DACF,CAAC;YACH;UACF;UACAzI,MAAM,GAAGV,kBAAkB,CAACU,MAAM,CAAC;UACnC8E,uBAAuB,CAAC9E,MAAM,EAAE2B,SAAS,EAAE,IAAI,CAAC1B,OAAO,CAAC;UACxD+E,0BAA0B,CAAChF,MAAM,EAAE2B,SAAS,EAAE,IAAI,CAAC1B,OAAO,CAAC;UAC3DiE,iBAAiB,CAACvC,SAAS,EAAE3B,MAAM,EAAE0B,MAAM,CAAC;UAC5C,IAAI2F,YAAY,EAAE;YAChB,OAAO,IAAI,CAAClC,OAAO,CAACuD,IAAI,CAAC/G,SAAS,EAAED,MAAM,EAAE3C,KAAK,EAAE;cAAE4J,cAAc,EAAE;YAAU,CAAC,CAAC,CAAChD,IAAI,CAACnG,MAAM,IAAI;cAC/F,IAAI,CAACA,MAAM,IAAI,CAACA,MAAM,CAACuB,MAAM,EAAE;gBAC7B,MAAM,IAAIT,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACqI,gBAAgB,EAAE,mBAAmB,CAAC;cAC1E;cACA,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;UACJ;UACA,IAAI3B,IAAI,EAAE;YACR,OAAO,IAAI,CAAC9B,OAAO,CAAC0D,oBAAoB,CACtClH,SAAS,EACTD,MAAM,EACN3C,KAAK,EACLiB,MAAM,EACN,IAAI,CAACsF,qBACP,CAAC;UACH,CAAC,MAAM,IAAI4B,MAAM,EAAE;YACjB,OAAO,IAAI,CAAC/B,OAAO,CAAC2D,eAAe,CACjCnH,SAAS,EACTD,MAAM,EACN3C,KAAK,EACLiB,MAAM,EACN,IAAI,CAACsF,qBACP,CAAC;UACH,CAAC,MAAM;YACL,OAAO,IAAI,CAACH,OAAO,CAAC4D,gBAAgB,CAClCpH,SAAS,EACTD,MAAM,EACN3C,KAAK,EACLiB,MAAM,EACN,IAAI,CAACsF,qBACP,CAAC;UACH;QACF,CAAC,CAAC;MACN,CAAC,CAAC,CACDK,IAAI,CAAEnG,MAAW,IAAK;QACrB,IAAI,CAACA,MAAM,EAAE;UACX,MAAM,IAAIc,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACqI,gBAAgB,EAAE,mBAAmB,CAAC;QAC1E;QACA,IAAIvB,YAAY,EAAE;UAChB,OAAO7H,MAAM;QACf;QACA,OAAO,IAAI,CAACwJ,qBAAqB,CAC/BrH,SAAS,EACTkG,aAAa,CAAC7E,QAAQ,EACtBhD,MAAM,EACNgI,eACF,CAAC,CAACrC,IAAI,CAAC,MAAM;UACX,OAAOnG,MAAM;QACf,CAAC,CAAC;MACJ,CAAC,CAAC,CACDmG,IAAI,CAACnG,MAAM,IAAI;QACd,IAAI4H,gBAAgB,EAAE;UACpB,OAAOnB,OAAO,CAACG,OAAO,CAAC5G,MAAM,CAAC;QAChC;QACA,OAAO,IAAI,CAACyJ,uBAAuB,CAACnB,cAAc,EAAEtI,MAAM,CAAC;MAC7D,CAAC,CAAC;IACN,CAAC,CAAC;EACJ;;EAEA;EACA;EACA;EACA0I,sBAAsBA,CAACvG,SAAiB,EAAEqB,QAAiB,EAAEhD,MAAW,EAAE;IACxE,IAAIkJ,GAAG,GAAG,EAAE;IACZ,IAAIC,QAAQ,GAAG,EAAE;IACjBnG,QAAQ,GAAGhD,MAAM,CAACgD,QAAQ,IAAIA,QAAQ;IAEtC,IAAIoG,OAAO,GAAGA,CAACC,EAAE,EAAErI,GAAG,KAAK;MACzB,IAAI,CAACqI,EAAE,EAAE;QACP;MACF;MACA,IAAIA,EAAE,CAACxF,IAAI,IAAI,aAAa,EAAE;QAC5BqF,GAAG,CAACvJ,IAAI,CAAC;UAAEqB,GAAG;UAAEqI;QAAG,CAAC,CAAC;QACrBF,QAAQ,CAACxJ,IAAI,CAACqB,GAAG,CAAC;MACpB;MAEA,IAAIqI,EAAE,CAACxF,IAAI,IAAI,gBAAgB,EAAE;QAC/BqF,GAAG,CAACvJ,IAAI,CAAC;UAAEqB,GAAG;UAAEqI;QAAG,CAAC,CAAC;QACrBF,QAAQ,CAACxJ,IAAI,CAACqB,GAAG,CAAC;MACpB;MAEA,IAAIqI,EAAE,CAACxF,IAAI,IAAI,OAAO,EAAE;QACtB,KAAK,IAAIyF,CAAC,IAAID,EAAE,CAACH,GAAG,EAAE;UACpBE,OAAO,CAACE,CAAC,EAAEtI,GAAG,CAAC;QACjB;MACF;IACF,CAAC;IAED,KAAK,MAAMA,GAAG,IAAIhB,MAAM,EAAE;MACxBoJ,OAAO,CAACpJ,MAAM,CAACgB,GAAG,CAAC,EAAEA,GAAG,CAAC;IAC3B;IACA,KAAK,MAAMA,GAAG,IAAImI,QAAQ,EAAE;MAC1B,OAAOnJ,MAAM,CAACgB,GAAG,CAAC;IACpB;IACA,OAAOkI,GAAG;EACZ;;EAEA;EACA;EACAF,qBAAqBA,CAACrH,SAAiB,EAAEqB,QAAgB,EAAEhD,MAAW,EAAEkJ,GAAQ,EAAE;IAChF,IAAIK,OAAO,GAAG,EAAE;IAChBvG,QAAQ,GAAGhD,MAAM,CAACgD,QAAQ,IAAIA,QAAQ;IACtCkG,GAAG,CAACvI,OAAO,CAAC,CAAC;MAAEK,GAAG;MAAEqI;IAAG,CAAC,KAAK;MAC3B,IAAI,CAACA,EAAE,EAAE;QACP;MACF;MACA,IAAIA,EAAE,CAACxF,IAAI,IAAI,aAAa,EAAE;QAC5B,KAAK,MAAMhC,MAAM,IAAIwH,EAAE,CAACrF,OAAO,EAAE;UAC/BuF,OAAO,CAAC5J,IAAI,CAAC,IAAI,CAAC6J,WAAW,CAACxI,GAAG,EAAEW,SAAS,EAAEqB,QAAQ,EAAEnB,MAAM,CAACmB,QAAQ,CAAC,CAAC;QAC3E;MACF;MAEA,IAAIqG,EAAE,CAACxF,IAAI,IAAI,gBAAgB,EAAE;QAC/B,KAAK,MAAMhC,MAAM,IAAIwH,EAAE,CAACrF,OAAO,EAAE;UAC/BuF,OAAO,CAAC5J,IAAI,CAAC,IAAI,CAAC8J,cAAc,CAACzI,GAAG,EAAEW,SAAS,EAAEqB,QAAQ,EAAEnB,MAAM,CAACmB,QAAQ,CAAC,CAAC;QAC9E;MACF;IACF,CAAC,CAAC;IAEF,OAAOiD,OAAO,CAACyD,GAAG,CAACH,OAAO,CAAC;EAC7B;;EAEA;EACA;EACAC,WAAWA,CAACxI,GAAW,EAAE2I,aAAqB,EAAEC,MAAc,EAAEC,IAAY,EAAE;IAC5E,MAAMC,GAAG,GAAG;MACVlF,SAAS,EAAEiF,IAAI;MACfhF,QAAQ,EAAE+E;IACZ,CAAC;IACD,OAAO,IAAI,CAACzE,OAAO,CAAC2D,eAAe,CACjC,SAAS9H,GAAG,IAAI2I,aAAa,EAAE,EAC/BhF,cAAc,EACdmF,GAAG,EACHA,GAAG,EACH,IAAI,CAACxE,qBACP,CAAC;EACH;;EAEA;EACA;EACA;EACAmE,cAAcA,CAACzI,GAAW,EAAE2I,aAAqB,EAAEC,MAAc,EAAEC,IAAY,EAAE;IAC/E,IAAIC,GAAG,GAAG;MACRlF,SAAS,EAAEiF,IAAI;MACfhF,QAAQ,EAAE+E;IACZ,CAAC;IACD,OAAO,IAAI,CAACzE,OAAO,CAChBW,oBAAoB,CACnB,SAAS9E,GAAG,IAAI2I,aAAa,EAAE,EAC/BhF,cAAc,EACdmF,GAAG,EACH,IAAI,CAACxE,qBACP,CAAC,CACA8C,KAAK,CAACX,KAAK,IAAI;MACd;MACA,IAAIA,KAAK,CAACsC,IAAI,IAAIzJ,WAAK,CAACC,KAAK,CAACqI,gBAAgB,EAAE;QAC9C;MACF;MACA,MAAMnB,KAAK;IACb,CAAC,CAAC;EACN;;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACAuC,OAAOA,CACLrI,SAAiB,EACjB5C,KAAU,EACV;IAAEC;EAAkB,CAAC,GAAG,CAAC,CAAC,EAC1BsI,qBAAwD,EAC1C;IACd,MAAMxH,QAAQ,GAAGd,GAAG,KAAK8H,SAAS;IAClC,MAAMvF,QAAQ,GAAGvC,GAAG,IAAI,EAAE;IAE1B,OAAO,IAAI,CAACuH,kBAAkB,CAACe,qBAAqB,CAAC,CAAC3B,IAAI,CAACC,gBAAgB,IAAI;MAC7E,OAAO,CAAC9F,QAAQ,GACZmG,OAAO,CAACG,OAAO,CAAC,CAAC,GACjBR,gBAAgB,CAACqC,kBAAkB,CAACtG,SAAS,EAAEJ,QAAQ,EAAE,QAAQ,CAAC,EACpEoE,IAAI,CAAC,MAAM;QACX,IAAI,CAAC7F,QAAQ,EAAE;UACbf,KAAK,GAAG,IAAI,CAACoJ,qBAAqB,CAChCvC,gBAAgB,EAChBjE,SAAS,EACT,QAAQ,EACR5C,KAAK,EACLwC,QACF,CAAC;UACD,IAAI,CAACxC,KAAK,EAAE;YACV,MAAM,IAAIuB,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACqI,gBAAgB,EAAE,mBAAmB,CAAC;UAC1E;QACF;QACA;QACA,IAAI5J,GAAG,EAAE;UACPD,KAAK,GAAGD,WAAW,CAACC,KAAK,EAAEC,GAAG,CAAC;QACjC;QACAa,aAAa,CAACd,KAAK,EAAEe,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAACG,OAAO,CAAC;QAC1D,OAAO2F,gBAAgB,CACpBC,YAAY,CAAClE,SAAS,CAAC,CACvByG,KAAK,CAACX,KAAK,IAAI;UACd;UACA;UACA,IAAIA,KAAK,KAAKX,SAAS,EAAE;YACvB,OAAO;cAAE7D,MAAM,EAAE,CAAC;YAAE,CAAC;UACvB;UACA,MAAMwE,KAAK;QACb,CAAC,CAAC,CACD9B,IAAI,CAACsE,iBAAiB,IACrB,IAAI,CAAC9E,OAAO,CAACW,oBAAoB,CAC/BnE,SAAS,EACTsI,iBAAiB,EACjBlL,KAAK,EACL,IAAI,CAACuG,qBACP,CACF,CAAC,CACA8C,KAAK,CAACX,KAAK,IAAI;UACd;UACA,IAAI9F,SAAS,KAAK,UAAU,IAAI8F,KAAK,CAACsC,IAAI,KAAKzJ,WAAK,CAACC,KAAK,CAACqI,gBAAgB,EAAE;YAC3E,OAAO3C,OAAO,CAACG,OAAO,CAAC,CAAC,CAAC,CAAC;UAC5B;UACA,MAAMqB,KAAK;QACb,CAAC,CAAC;MACN,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ;;EAEA;EACA;EACAyC,MAAMA,CACJvI,SAAiB,EACjBE,MAAW,EACX;IAAE7C;EAAkB,CAAC,GAAG,CAAC,CAAC,EAC1BqI,YAAqB,GAAG,KAAK,EAC7BC,qBAAwD,EAC1C;IACd,IAAI;MACFC,cAAK,CAACC,uBAAuB,CAAC,IAAI,CAACvH,OAAO,EAAE4B,MAAM,CAAC;IACrD,CAAC,CAAC,OAAO4F,KAAK,EAAE;MACd,OAAOxB,OAAO,CAACC,MAAM,CAAC,IAAI5F,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAAEoG,KAAK,CAAC,CAAC;IAC7E;IACA,IAAI;MACF,MAAM;QAAEC;MAAyB,CAAC,GAAGnM,OAAO,CAAC,qBAAqB,CAAC;MACnEmM,wBAAwB,CAAC7F,MAAM,EAAE,IAAI,CAAC5B,OAAO,CAAC;IAChD,CAAC,CAAC,OAAOwH,KAAK,EAAE;MACd,OAAOxB,OAAO,CAACC,MAAM,CAACuB,KAAK,YAAYnH,WAAK,CAACC,KAAK,GAAGkH,KAAK,GAAG,IAAInH,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACoH,eAAe,EAAEF,KAAK,CAACG,OAAO,IAAIH,KAAK,CAAC,CAAC;IACpI;IACA;IACA,MAAM0C,cAAc,GAAGtI,MAAM;IAC7BA,MAAM,GAAGvC,kBAAkB,CAACuC,MAAM,CAAC;IAEnCiD,uBAAuB,CAACjD,MAAM,EAAEF,SAAS,EAAE,IAAI,CAAC1B,OAAO,CAAC;IACxD+E,0BAA0B,CAACnD,MAAM,EAAEF,SAAS,EAAE,IAAI,CAAC1B,OAAO,CAAC;IAC3D4B,MAAM,CAACuI,SAAS,GAAG;MAAEC,GAAG,EAAExI,MAAM,CAACuI,SAAS;MAAEE,MAAM,EAAE;IAAO,CAAC;IAC5DzI,MAAM,CAAC0I,SAAS,GAAG;MAAEF,GAAG,EAAExI,MAAM,CAAC0I,SAAS;MAAED,MAAM,EAAE;IAAO,CAAC;IAE5D,IAAIxK,QAAQ,GAAGd,GAAG,KAAK8H,SAAS;IAChC,IAAIvF,QAAQ,GAAGvC,GAAG,IAAI,EAAE;IACxB,MAAMgJ,eAAe,GAAG,IAAI,CAACE,sBAAsB,CAACvG,SAAS,EAAE,IAAI,EAAEE,MAAM,CAAC;IAE5E,OAAO,IAAI,CAACkE,iBAAiB,CAACpE,SAAS,CAAC,CACrCgE,IAAI,CAAC,MAAM,IAAI,CAACY,kBAAkB,CAACe,qBAAqB,CAAC,CAAC,CAC1D3B,IAAI,CAACC,gBAAgB,IAAI;MACxB,OAAO,CAAC9F,QAAQ,GACZmG,OAAO,CAACG,OAAO,CAAC,CAAC,GACjBR,gBAAgB,CAACqC,kBAAkB,CAACtG,SAAS,EAAEJ,QAAQ,EAAE,QAAQ,CAAC,EAEnEoE,IAAI,CAAC,MAAMC,gBAAgB,CAAC4E,kBAAkB,CAAC7I,SAAS,CAAC,CAAC,CAC1DgE,IAAI,CAAC,MAAMC,gBAAgB,CAACC,YAAY,CAAClE,SAAS,EAAE,IAAI,CAAC,CAAC,CAC1DgE,IAAI,CAACjE,MAAM,IAAI;QACdwC,iBAAiB,CAACvC,SAAS,EAAEE,MAAM,EAAEH,MAAM,CAAC;QAC5CkC,+BAA+B,CAAC/B,MAAM,CAAC;QACvC,IAAIwF,YAAY,EAAE;UAChB,OAAO,CAAC,CAAC;QACX;QACA,OAAO,IAAI,CAAClC,OAAO,CAACsF,YAAY,CAC9B9I,SAAS,EACT9F,gBAAgB,CAAC6O,4BAA4B,CAAChJ,MAAM,CAAC,EACrDG,MAAM,EACN,IAAI,CAACyD,qBACP,CAAC;MACH,CAAC,CAAC,CACDK,IAAI,CAACnG,MAAM,IAAI;QACd,IAAI6H,YAAY,EAAE;UAChB,OAAO8C,cAAc;QACvB;QACA,OAAO,IAAI,CAACnB,qBAAqB,CAC/BrH,SAAS,EACTE,MAAM,CAACmB,QAAQ,EACfnB,MAAM,EACNmG,eACF,CAAC,CAACrC,IAAI,CAAC,MAAM;UACX,OAAO,IAAI,CAACsD,uBAAuB,CAACkB,cAAc,EAAE3K,MAAM,CAAC0J,GAAG,CAAC,CAAC,CAAC,CAAC;QACpE,CAAC,CAAC;MACJ,CAAC,CAAC;IACN,CAAC,CAAC;EACN;EAEAlC,WAAWA,CACTtF,MAAyC,EACzCC,SAAiB,EACjBE,MAAW,EACXN,QAAkB,EAClBqF,UAAwB,EACT;IACf,MAAM+D,WAAW,GAAGjJ,MAAM,CAACkJ,UAAU,CAACjJ,SAAS,CAAC;IAChD,IAAI,CAACgJ,WAAW,EAAE;MAChB,OAAO1E,OAAO,CAACG,OAAO,CAAC,CAAC;IAC1B;IACA,MAAMnD,MAAM,GAAG7F,MAAM,CAACsB,IAAI,CAACmD,MAAM,CAAC;IAClC,MAAMgJ,YAAY,GAAGzN,MAAM,CAACsB,IAAI,CAACiM,WAAW,CAAC1H,MAAM,CAAC;IACpD,MAAM6H,OAAO,GAAG7H,MAAM,CAACtE,MAAM,CAACoM,KAAK,IAAI;MACrC;MACA,IAAIlJ,MAAM,CAACkJ,KAAK,CAAC,IAAIlJ,MAAM,CAACkJ,KAAK,CAAC,CAAClH,IAAI,IAAIhC,MAAM,CAACkJ,KAAK,CAAC,CAAClH,IAAI,KAAK,QAAQ,EAAE;QAC1E,OAAO,KAAK;MACd;MACA,OAAOgH,YAAY,CAACzI,OAAO,CAACqC,gBAAgB,CAACsG,KAAK,CAAC,CAAC,GAAG,CAAC;IAC1D,CAAC,CAAC;IACF,IAAID,OAAO,CAAC/J,MAAM,GAAG,CAAC,EAAE;MACtB;MACA6F,UAAU,CAACO,SAAS,GAAG,IAAI;MAE3B,MAAM6D,MAAM,GAAGpE,UAAU,CAACoE,MAAM;MAChC,OAAOtJ,MAAM,CAACuG,kBAAkB,CAACtG,SAAS,EAAEJ,QAAQ,EAAE,UAAU,EAAEyJ,MAAM,CAAC;IAC3E;IACA,OAAO/E,OAAO,CAACG,OAAO,CAAC,CAAC;EAC1B;;EAEA;EACA;AACF;AACA;AACA;AACA;AACA;EACE6E,gBAAgBA,CAACC,IAAa,GAAG,KAAK,EAAgB;IACpD,IAAI,CAAC7F,aAAa,GAAG,IAAI;IACzB8F,oBAAW,CAACC,KAAK,CAAC,CAAC;IACnB,OAAO,IAAI,CAACjG,OAAO,CAACkG,gBAAgB,CAACH,IAAI,CAAC;EAC5C;;EAEA;EACA;EACAI,UAAUA,CACR3J,SAAiB,EACjBX,GAAW,EACX6D,QAAgB,EAChB0G,YAA0B,EACF;IACxB,MAAM;MAAEC,IAAI;MAAEC,KAAK;MAAEC;IAAK,CAAC,GAAGH,YAAY;IAC1C,MAAMI,WAAW,GAAG,CAAC,CAAC;IACtB,IAAID,IAAI,IAAIA,IAAI,CAACtB,SAAS,IAAI,IAAI,CAACjF,OAAO,CAACyG,mBAAmB,EAAE;MAC9DD,WAAW,CAACD,IAAI,GAAG;QAAEG,GAAG,EAAEH,IAAI,CAACtB;MAAU,CAAC;MAC1CuB,WAAW,CAACF,KAAK,GAAGA,KAAK;MACzBE,WAAW,CAACH,IAAI,GAAGA,IAAI;MACvBD,YAAY,CAACC,IAAI,GAAG,CAAC;IACvB;IACA,OAAO,IAAI,CAACrG,OAAO,CAChBuD,IAAI,CAAC/E,aAAa,CAAChC,SAAS,EAAEX,GAAG,CAAC,EAAE2D,cAAc,EAAE;MAAEE;IAAS,CAAC,EAAE8G,WAAW,CAAC,CAC9EhG,IAAI,CAACmG,OAAO,IAAIA,OAAO,CAACvJ,GAAG,CAAC/C,MAAM,IAAIA,MAAM,CAACoF,SAAS,CAAC,CAAC;EAC7D;;EAEA;EACA;EACAmH,SAASA,CAACpK,SAAiB,EAAEX,GAAW,EAAEsK,UAAoB,EAAqB;IACjF,OAAO,IAAI,CAACnG,OAAO,CAChBuD,IAAI,CACH/E,aAAa,CAAChC,SAAS,EAAEX,GAAG,CAAC,EAC7B2D,cAAc,EACd;MAAEC,SAAS,EAAE;QAAExF,GAAG,EAAEkM;MAAW;IAAE,CAAC,EAClC;MAAE5M,IAAI,EAAE,CAAC,UAAU;IAAE,CACvB,CAAC,CACAiH,IAAI,CAACmG,OAAO,IAAIA,OAAO,CAACvJ,GAAG,CAAC/C,MAAM,IAAIA,MAAM,CAACqF,QAAQ,CAAC,CAAC;EAC5D;;EAEA;EACA;EACA;EACAmH,gBAAgBA,CAACrK,SAAiB,EAAE5C,KAAU,EAAE2C,MAAW,EAAgB;IACzE;IACA;IACA,MAAMuK,QAAQ,GAAG,EAAE;IACnB,IAAIlN,KAAK,CAAC,KAAK,CAAC,EAAE;MAChB,MAAMmN,GAAG,GAAGnN,KAAK,CAAC,KAAK,CAAC;MACxBkN,QAAQ,CAACtM,IAAI,CACX,GAAGuM,GAAG,CAAC3J,GAAG,CAAC,CAAC4J,MAAM,EAAEC,KAAK,KAAK;QAC5B,OAAO,IAAI,CAACJ,gBAAgB,CAACrK,SAAS,EAAEwK,MAAM,EAAEzK,MAAM,CAAC,CAACiE,IAAI,CAACwG,MAAM,IAAI;UACrEpN,KAAK,CAAC,KAAK,CAAC,CAACqN,KAAK,CAAC,GAAGD,MAAM;QAC9B,CAAC,CAAC;MACJ,CAAC,CACH,CAAC;IACH;IACA,IAAIpN,KAAK,CAAC,MAAM,CAAC,EAAE;MACjB,MAAMsN,IAAI,GAAGtN,KAAK,CAAC,MAAM,CAAC;MAC1BkN,QAAQ,CAACtM,IAAI,CACX,GAAG0M,IAAI,CAAC9J,GAAG,CAAC,CAAC4J,MAAM,EAAEC,KAAK,KAAK;QAC7B,OAAO,IAAI,CAACJ,gBAAgB,CAACrK,SAAS,EAAEwK,MAAM,EAAEzK,MAAM,CAAC,CAACiE,IAAI,CAACwG,MAAM,IAAI;UACrEpN,KAAK,CAAC,MAAM,CAAC,CAACqN,KAAK,CAAC,GAAGD,MAAM;QAC/B,CAAC,CAAC;MACJ,CAAC,CACH,CAAC;IACH;IAEA,MAAMG,SAAS,GAAGlP,MAAM,CAACsB,IAAI,CAACK,KAAK,CAAC,CAACwD,GAAG,CAACvB,GAAG,IAAI;MAC9C,IAAIA,GAAG,KAAK,MAAM,IAAIA,GAAG,KAAK,KAAK,EAAE;QACnC;MACF;MACA,MAAM3E,CAAC,GAAGqF,MAAM,CAAC+E,eAAe,CAAC9E,SAAS,EAAEX,GAAG,CAAC;MAChD,IAAI,CAAC3E,CAAC,IAAIA,CAAC,CAACiI,IAAI,KAAK,UAAU,EAAE;QAC/B,OAAO2B,OAAO,CAACG,OAAO,CAACrH,KAAK,CAAC;MAC/B;MACA,IAAIwN,OAAiB,GAAG,IAAI;MAC5B,IACExN,KAAK,CAACiC,GAAG,CAAC,KACTjC,KAAK,CAACiC,GAAG,CAAC,CAAC,KAAK,CAAC,IAChBjC,KAAK,CAACiC,GAAG,CAAC,CAAC,KAAK,CAAC,IACjBjC,KAAK,CAACiC,GAAG,CAAC,CAAC,MAAM,CAAC,IAClBjC,KAAK,CAACiC,GAAG,CAAC,CAACsJ,MAAM,IAAI,SAAS,CAAC,EACjC;QACA;QACAiC,OAAO,GAAGnP,MAAM,CAACsB,IAAI,CAACK,KAAK,CAACiC,GAAG,CAAC,CAAC,CAACuB,GAAG,CAACiK,aAAa,IAAI;UACrD,IAAIlB,UAAU;UACd,IAAImB,UAAU,GAAG,KAAK;UACtB,IAAID,aAAa,KAAK,UAAU,EAAE;YAChClB,UAAU,GAAG,CAACvM,KAAK,CAACiC,GAAG,CAAC,CAACgC,QAAQ,CAAC;UACpC,CAAC,MAAM,IAAIwJ,aAAa,IAAI,KAAK,EAAE;YACjClB,UAAU,GAAGvM,KAAK,CAACiC,GAAG,CAAC,CAAC,KAAK,CAAC,CAACuB,GAAG,CAAChG,CAAC,IAAIA,CAAC,CAACyG,QAAQ,CAAC;UACrD,CAAC,MAAM,IAAIwJ,aAAa,IAAI,MAAM,EAAE;YAClCC,UAAU,GAAG,IAAI;YACjBnB,UAAU,GAAGvM,KAAK,CAACiC,GAAG,CAAC,CAAC,MAAM,CAAC,CAACuB,GAAG,CAAChG,CAAC,IAAIA,CAAC,CAACyG,QAAQ,CAAC;UACtD,CAAC,MAAM,IAAIwJ,aAAa,IAAI,KAAK,EAAE;YACjCC,UAAU,GAAG,IAAI;YACjBnB,UAAU,GAAG,CAACvM,KAAK,CAACiC,GAAG,CAAC,CAAC,KAAK,CAAC,CAACgC,QAAQ,CAAC;UAC3C,CAAC,MAAM;YACL;UACF;UACA,OAAO;YACLyJ,UAAU;YACVnB;UACF,CAAC;QACH,CAAC,CAAC;MACJ,CAAC,MAAM;QACLiB,OAAO,GAAG,CAAC;UAAEE,UAAU,EAAE,KAAK;UAAEnB,UAAU,EAAE;QAAG,CAAC,CAAC;MACnD;;MAEA;MACA,OAAOvM,KAAK,CAACiC,GAAG,CAAC;MACjB;MACA;MACA,MAAMiL,QAAQ,GAAGM,OAAO,CAAChK,GAAG,CAACmK,CAAC,IAAI;QAChC,IAAI,CAACA,CAAC,EAAE;UACN,OAAOzG,OAAO,CAACG,OAAO,CAAC,CAAC;QAC1B;QACA,OAAO,IAAI,CAAC2F,SAAS,CAACpK,SAAS,EAAEX,GAAG,EAAE0L,CAAC,CAACpB,UAAU,CAAC,CAAC3F,IAAI,CAACgH,GAAG,IAAI;UAC9D,IAAID,CAAC,CAACD,UAAU,EAAE;YAChB,IAAI,CAACG,oBAAoB,CAACD,GAAG,EAAE5N,KAAK,CAAC;UACvC,CAAC,MAAM;YACL,IAAI,CAAC8N,iBAAiB,CAACF,GAAG,EAAE5N,KAAK,CAAC;UACpC;UACA,OAAOkH,OAAO,CAACG,OAAO,CAAC,CAAC;QAC1B,CAAC,CAAC;MACJ,CAAC,CAAC;MAEF,OAAOH,OAAO,CAACyD,GAAG,CAACuC,QAAQ,CAAC,CAACtG,IAAI,CAAC,MAAM;QACtC,OAAOM,OAAO,CAACG,OAAO,CAAC,CAAC;MAC1B,CAAC,CAAC;IACJ,CAAC,CAAC;IAEF,OAAOH,OAAO,CAACyD,GAAG,CAAC,CAAC,GAAGuC,QAAQ,EAAE,GAAGK,SAAS,CAAC,CAAC,CAAC3G,IAAI,CAAC,MAAM;MACzD,OAAOM,OAAO,CAACG,OAAO,CAACrH,KAAK,CAAC;IAC/B,CAAC,CAAC;EACJ;;EAEA;EACA;EACA+N,kBAAkBA,CAACnL,SAAiB,EAAE5C,KAAU,EAAEwM,YAAiB,EAAkB;IACnF,IAAIxM,KAAK,CAAC,KAAK,CAAC,EAAE;MAChB,OAAOkH,OAAO,CAACyD,GAAG,CAChB3K,KAAK,CAAC,KAAK,CAAC,CAACwD,GAAG,CAAC4J,MAAM,IAAI;QACzB,OAAO,IAAI,CAACW,kBAAkB,CAACnL,SAAS,EAAEwK,MAAM,EAAEZ,YAAY,CAAC;MACjE,CAAC,CACH,CAAC;IACH;IACA,IAAIxM,KAAK,CAAC,MAAM,CAAC,EAAE;MACjB,OAAOkH,OAAO,CAACyD,GAAG,CAChB3K,KAAK,CAAC,MAAM,CAAC,CAACwD,GAAG,CAAC4J,MAAM,IAAI;QAC1B,OAAO,IAAI,CAACW,kBAAkB,CAACnL,SAAS,EAAEwK,MAAM,EAAEZ,YAAY,CAAC;MACjE,CAAC,CACH,CAAC;IACH;IACA,IAAIwB,SAAS,GAAGhO,KAAK,CAAC,YAAY,CAAC;IACnC,IAAIgO,SAAS,EAAE;MACb,OAAO,IAAI,CAACzB,UAAU,CACpByB,SAAS,CAAClL,MAAM,CAACF,SAAS,EAC1BoL,SAAS,CAAC/L,GAAG,EACb+L,SAAS,CAAClL,MAAM,CAACmB,QAAQ,EACzBuI,YACF,CAAC,CACE5F,IAAI,CAACgH,GAAG,IAAI;QACX,OAAO5N,KAAK,CAAC,YAAY,CAAC;QAC1B,IAAI,CAAC8N,iBAAiB,CAACF,GAAG,EAAE5N,KAAK,CAAC;QAClC,OAAO,IAAI,CAAC+N,kBAAkB,CAACnL,SAAS,EAAE5C,KAAK,EAAEwM,YAAY,CAAC;MAChE,CAAC,CAAC,CACD5F,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IACnB;EACF;EAEAkH,iBAAiBA,CAACF,GAAmB,GAAG,IAAI,EAAE5N,KAAU,EAAE;IACxD,MAAMiO,aAA6B,GACjC,OAAOjO,KAAK,CAACiE,QAAQ,KAAK,QAAQ,GAAG,CAACjE,KAAK,CAACiE,QAAQ,CAAC,GAAG,IAAI;IAC9D,MAAMiK,SAAyB,GAC7BlO,KAAK,CAACiE,QAAQ,IAAIjE,KAAK,CAACiE,QAAQ,CAAC,KAAK,CAAC,GAAG,CAACjE,KAAK,CAACiE,QAAQ,CAAC,KAAK,CAAC,CAAC,GAAG,IAAI;IAC1E,MAAMkK,SAAyB,GAC7BnO,KAAK,CAACiE,QAAQ,IAAIjE,KAAK,CAACiE,QAAQ,CAAC,KAAK,CAAC,GAAGjE,KAAK,CAACiE,QAAQ,CAAC,KAAK,CAAC,GAAG,IAAI;;IAExE;IACA,MAAMmK,MAA4B,GAAG,CAACH,aAAa,EAAEC,SAAS,EAAEC,SAAS,EAAEP,GAAG,CAAC,CAAChO,MAAM,CACpFyO,IAAI,IAAIA,IAAI,KAAK,IACnB,CAAC;IACD,MAAMC,WAAW,GAAGF,MAAM,CAACG,MAAM,CAAC,CAACC,IAAI,EAAEH,IAAI,KAAKG,IAAI,GAAGH,IAAI,CAACrM,MAAM,EAAE,CAAC,CAAC;IAExE,IAAIyM,eAAe,GAAG,EAAE;IACxB,IAAIH,WAAW,GAAG,GAAG,EAAE;MACrBG,eAAe,GAAGC,kBAAS,CAACC,GAAG,CAACP,MAAM,CAAC;IACzC,CAAC,MAAM;MACLK,eAAe,GAAG,IAAAC,kBAAS,EAACN,MAAM,CAAC;IACrC;;IAEA;IACA,IAAI,EAAE,UAAU,IAAIpO,KAAK,CAAC,EAAE;MAC1BA,KAAK,CAACiE,QAAQ,GAAG;QACf5D,GAAG,EAAE0H;MACP,CAAC;IACH,CAAC,MAAM,IAAI,OAAO/H,KAAK,CAACiE,QAAQ,KAAK,QAAQ,EAAE;MAC7CjE,KAAK,CAACiE,QAAQ,GAAG;QACf5D,GAAG,EAAE0H,SAAS;QACd6G,GAAG,EAAE5O,KAAK,CAACiE;MACb,CAAC;IACH;IACAjE,KAAK,CAACiE,QAAQ,CAAC,KAAK,CAAC,GAAGwK,eAAe;IAEvC,OAAOzO,KAAK;EACd;EAEA6N,oBAAoBA,CAACD,GAAa,GAAG,EAAE,EAAE5N,KAAU,EAAE;IACnD,MAAM6O,UAAU,GAAG7O,KAAK,CAACiE,QAAQ,IAAIjE,KAAK,CAACiE,QAAQ,CAAC,MAAM,CAAC,GAAGjE,KAAK,CAACiE,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE;IACzF,IAAImK,MAAM,GAAG,CAAC,GAAGS,UAAU,EAAE,GAAGjB,GAAG,CAAC,CAAChO,MAAM,CAACyO,IAAI,IAAIA,IAAI,KAAK,IAAI,CAAC;;IAElE;IACAD,MAAM,GAAG,CAAC,GAAG,IAAIU,GAAG,CAACV,MAAM,CAAC,CAAC;;IAE7B;IACA,IAAI,EAAE,UAAU,IAAIpO,KAAK,CAAC,EAAE;MAC1BA,KAAK,CAACiE,QAAQ,GAAG;QACf8K,IAAI,EAAEhH;MACR,CAAC;IACH,CAAC,MAAM,IAAI,OAAO/H,KAAK,CAACiE,QAAQ,KAAK,QAAQ,EAAE;MAC7CjE,KAAK,CAACiE,QAAQ,GAAG;QACf8K,IAAI,EAAEhH,SAAS;QACf6G,GAAG,EAAE5O,KAAK,CAACiE;MACb,CAAC;IACH;IAEAjE,KAAK,CAACiE,QAAQ,CAAC,MAAM,CAAC,GAAGmK,MAAM;IAC/B,OAAOpO,KAAK;EACd;;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA2J,IAAIA,CACF/G,SAAiB,EACjB5C,KAAU,EACV;IACEyM,IAAI;IACJC,KAAK;IACLzM,GAAG;IACH0M,IAAI,GAAG,CAAC,CAAC;IACTqC,KAAK;IACLrP,IAAI;IACJ2K,EAAE;IACF2E,QAAQ;IACRC,QAAQ;IACRtF,cAAc;IACduF,IAAI;IACJC,eAAe,GAAG,KAAK;IACvBC,OAAO;IACPC;EACG,CAAC,GAAG,CAAC,CAAC,EACX7M,IAAS,GAAG,CAAC,CAAC,EACd8F,qBAAwD,EAC1C;IACd,MAAMvH,aAAa,GAAGyB,IAAI,CAACzB,aAAa;IACxC,MAAMD,QAAQ,GAAGd,GAAG,KAAK8H,SAAS,IAAI/G,aAAa;IACnD,MAAMwB,QAAQ,GAAGvC,GAAG,IAAI,EAAE;IAC1BqK,EAAE,GACAA,EAAE,KAAK,OAAOtK,KAAK,CAACiE,QAAQ,IAAI,QAAQ,IAAI5F,MAAM,CAACsB,IAAI,CAACK,KAAK,CAAC,CAACgC,MAAM,KAAK,CAAC,GAAG,KAAK,GAAG,MAAM,CAAC;IAC/F;IACAsI,EAAE,GAAG0E,KAAK,KAAK,IAAI,GAAG,OAAO,GAAG1E,EAAE;IAElC,IAAI7D,WAAW,GAAG,IAAI;IACtB,OAAO,IAAI,CAACe,kBAAkB,CAACe,qBAAqB,CAAC,CAAC3B,IAAI,CAACC,gBAAgB,IAAI;MAC7E;MACA;MACA;MACA,OAAOA,gBAAgB,CACpBC,YAAY,CAAClE,SAAS,EAAE7B,QAAQ,CAAC,CACjCsI,KAAK,CAACX,KAAK,IAAI;QACd;QACA;QACA,IAAIA,KAAK,KAAKX,SAAS,EAAE;UACvBtB,WAAW,GAAG,KAAK;UACnB,OAAO;YAAEvC,MAAM,EAAE,CAAC;UAAE,CAAC;QACvB;QACA,MAAMwE,KAAK;MACb,CAAC,CAAC,CACD9B,IAAI,CAACjE,MAAM,IAAI;QACd;QACA;QACA;QACA,IAAIgK,IAAI,CAAC4C,WAAW,EAAE;UACpB5C,IAAI,CAACtB,SAAS,GAAGsB,IAAI,CAAC4C,WAAW;UACjC,OAAO5C,IAAI,CAAC4C,WAAW;QACzB;QACA,IAAI5C,IAAI,CAAC6C,WAAW,EAAE;UACpB7C,IAAI,CAACnB,SAAS,GAAGmB,IAAI,CAAC6C,WAAW;UACjC,OAAO7C,IAAI,CAAC6C,WAAW;QACzB;QACA,MAAMhD,YAAY,GAAG;UACnBC,IAAI;UACJC,KAAK;UACLC,IAAI;UACJhN,IAAI;UACJiK,cAAc;UACduF,IAAI;UACJC,eAAe,EAAE,IAAI,CAAClO,OAAO,CAACuO,6BAA6B,GAAG,KAAK,GAAGL,eAAe;UACrFC,OAAO;UACPC;QACF,CAAC;QACDjR,MAAM,CAACsB,IAAI,CAACgN,IAAI,CAAC,CAAC/K,OAAO,CAAC0D,SAAS,IAAI;UACrC,IAAIA,SAAS,CAAClD,KAAK,CAAC,iCAAiC,CAAC,EAAE;YACtD,MAAM,IAAIb,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAAE,kBAAkBgD,SAAS,EAAE,CAAC;UACpF;UACA,MAAMgE,aAAa,GAAG5D,gBAAgB,CAACJ,SAAS,CAAC;UACjD,IAAI,CAACxI,gBAAgB,CAACyM,gBAAgB,CAACD,aAAa,EAAE1G,SAAS,CAAC,EAAE;YAChE,MAAM,IAAIrB,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAC5B,uBAAuBgD,SAAS,GAClC,CAAC;UACH;UACA,IAAI,CAAC3C,MAAM,CAACuB,MAAM,CAACoB,SAAS,CAACK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAIL,SAAS,KAAK,OAAO,EAAE;YACpE,OAAOqH,IAAI,CAACrH,SAAS,CAAC;UACxB;QACF,CAAC,CAAC;QACF,OAAO,CAACvE,QAAQ,GACZmG,OAAO,CAACG,OAAO,CAAC,CAAC,GACjBR,gBAAgB,CAACqC,kBAAkB,CAACtG,SAAS,EAAEJ,QAAQ,EAAE8H,EAAE,CAAC,EAE7D1D,IAAI,CAAC,MAAM,IAAI,CAACmH,kBAAkB,CAACnL,SAAS,EAAE5C,KAAK,EAAEwM,YAAY,CAAC,CAAC,CACnE5F,IAAI,CAAC,MAAM,IAAI,CAACqG,gBAAgB,CAACrK,SAAS,EAAE5C,KAAK,EAAE6G,gBAAgB,CAAC,CAAC,CACrED,IAAI,CAAC,MAAM;UACV,IAAI/D,eAAe;UACnB,IAAI,CAAC9B,QAAQ,EAAE;YACbf,KAAK,GAAG,IAAI,CAACoJ,qBAAqB,CAChCvC,gBAAgB,EAChBjE,SAAS,EACT0H,EAAE,EACFtK,KAAK,EACLwC,QACF,CAAC;YACD;AAChB;AACA;YACgBK,eAAe,GAAG,IAAI,CAAC6M,kBAAkB,CACvC7I,gBAAgB,EAChBjE,SAAS,EACT5C,KAAK,EACLwC,QAAQ,EACRC,IAAI,EACJ+J,YACF,CAAC;UACH;UACA,IAAI,CAACxM,KAAK,EAAE;YACV,IAAIsK,EAAE,KAAK,KAAK,EAAE;cAChB,MAAM,IAAI/I,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACqI,gBAAgB,EAAE,mBAAmB,CAAC;YAC1E,CAAC,MAAM;cACL,OAAO,EAAE;YACX;UACF;UACA,IAAI,CAAC9I,QAAQ,EAAE;YACb,IAAIuJ,EAAE,KAAK,QAAQ,IAAIA,EAAE,KAAK,QAAQ,EAAE;cACtCtK,KAAK,GAAGD,WAAW,CAACC,KAAK,EAAEwC,QAAQ,CAAC;YACtC,CAAC,MAAM;cACLxC,KAAK,GAAGM,UAAU,CAACN,KAAK,EAAEwC,QAAQ,CAAC;YACrC;UACF;UACA1B,aAAa,CAACd,KAAK,EAAEe,QAAQ,EAAEC,aAAa,EAAE,KAAK,EAAE,IAAI,CAACE,OAAO,CAAC;UAClE,IAAI8N,KAAK,EAAE;YACT,IAAI,CAACvI,WAAW,EAAE;cAChB,OAAO,CAAC;YACV,CAAC,MAAM;cACL,OAAO,IAAI,CAACL,OAAO,CAAC4I,KAAK,CACvBpM,SAAS,EACTD,MAAM,EACN3C,KAAK,EACL4J,cAAc,EACd7B,SAAS,EACToH,IAAI,EACJG,OACF,CAAC;YACH;UACF,CAAC,MAAM,IAAIL,QAAQ,EAAE;YACnB,IAAI,CAACxI,WAAW,EAAE;cAChB,OAAO,EAAE;YACX,CAAC,MAAM;cACL,OAAO,IAAI,CAACL,OAAO,CAAC6I,QAAQ,CAACrM,SAAS,EAAED,MAAM,EAAE3C,KAAK,EAAEiP,QAAQ,CAAC;YAClE;UACF,CAAC,MAAM,IAAIC,QAAQ,EAAE;YACnB,IAAI,CAACzI,WAAW,EAAE;cAChB,OAAO,EAAE;YACX,CAAC,MAAM;cACL,OAAO,IAAI,CAACL,OAAO,CAACuJ,SAAS,CAC3B/M,SAAS,EACTD,MAAM,EACNuM,QAAQ,EACRtF,cAAc,EACduF,IAAI,EACJE,OAAO,EACPC,OACF,CAAC;YACH;UACF,CAAC,MAAM,IAAID,OAAO,EAAE;YAClB,OAAO,IAAI,CAACjJ,OAAO,CAACuD,IAAI,CAAC/G,SAAS,EAAED,MAAM,EAAE3C,KAAK,EAAEwM,YAAY,CAAC;UAClE,CAAC,MAAM;YACL,OAAO,IAAI,CAACpG,OAAO,CAChBuD,IAAI,CAAC/G,SAAS,EAAED,MAAM,EAAE3C,KAAK,EAAEwM,YAAY,CAAC,CAC5C5F,IAAI,CAAC3B,OAAO,IACXA,OAAO,CAACzB,GAAG,CAACV,MAAM,IAAI;cACpBA,MAAM,GAAG0C,oBAAoB,CAAC1C,MAAM,CAAC;cACrC,OAAOP,mBAAmB,CACxBxB,QAAQ,EACRC,aAAa,EACbwB,QAAQ,EACRC,IAAI,EACJ6H,EAAE,EACFzD,gBAAgB,EAChBjE,SAAS,EACTC,eAAe,EACfC,MACF,CAAC;YACH,CAAC,CACH,CAAC,CACAuG,KAAK,CAACX,KAAK,IAAI;cACd,IAAIA,KAAK,YAAYnH,WAAK,CAACC,KAAK,EAAE;gBAChC,MAAMkH,KAAK;cACb;cACA,MAAMkH,eAAe,GACnB,OAAOlH,KAAK,KAAK,QAAQ,GACrBA,KAAK,GACLA,KAAK,EAAEG,OAAO,IAAI,mCAAmC;cAC3D,MAAM,IAAAgH,2BAAoB,EACxBtO,WAAK,CAACC,KAAK,CAACsO,qBAAqB,EACjCF,eAAe,EACf,IAAI,CAAC1O,OAAO,EACZ,mCACF,CAAC;YACH,CAAC,CAAC;UACN;QACF,CAAC,CAAC;MACN,CAAC,CAAC;IACN,CAAC,CAAC;EACJ;EAEA6O,YAAYA,CAACnN,SAAiB,EAAiB;IAC7C,IAAIiE,gBAAgB;IACpB,OAAO,IAAI,CAACF,UAAU,CAAC;MAAEW,UAAU,EAAE;IAAK,CAAC,CAAC,CACzCV,IAAI,CAACoB,CAAC,IAAI;MACTnB,gBAAgB,GAAGmB,CAAC;MACpB,OAAOnB,gBAAgB,CAACC,YAAY,CAAClE,SAAS,EAAE,IAAI,CAAC;IACvD,CAAC,CAAC,CACDyG,KAAK,CAACX,KAAK,IAAI;MACd,IAAIA,KAAK,KAAKX,SAAS,EAAE;QACvB,OAAO;UAAE7D,MAAM,EAAE,CAAC;QAAE,CAAC;MACvB,CAAC,MAAM;QACL,MAAMwE,KAAK;MACb;IACF,CAAC,CAAC,CACD9B,IAAI,CAAEjE,MAAW,IAAK;MACrB,OAAO,IAAI,CAAC6D,gBAAgB,CAAC5D,SAAS,CAAC,CACpCgE,IAAI,CAAC,MAAM,IAAI,CAACR,OAAO,CAAC4I,KAAK,CAACpM,SAAS,EAAE;QAAEsB,MAAM,EAAE,CAAC;MAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC,CAC1E0C,IAAI,CAACoI,KAAK,IAAI;QACb,IAAIA,KAAK,GAAG,CAAC,EAAE;UACb,MAAM,IAAIzN,WAAK,CAACC,KAAK,CACnB,GAAG,EACH,SAASoB,SAAS,2BAA2BoM,KAAK,+BACpD,CAAC;QACH;QACA,OAAO,IAAI,CAAC5I,OAAO,CAAC4J,WAAW,CAACpN,SAAS,CAAC;MAC5C,CAAC,CAAC,CACDgE,IAAI,CAACqJ,kBAAkB,IAAI;QAC1B,IAAIA,kBAAkB,EAAE;UACtB,MAAMC,kBAAkB,GAAG7R,MAAM,CAACsB,IAAI,CAACgD,MAAM,CAACuB,MAAM,CAAC,CAACtE,MAAM,CAC1D0F,SAAS,IAAI3C,MAAM,CAACuB,MAAM,CAACoB,SAAS,CAAC,CAACC,IAAI,KAAK,UACjD,CAAC;UACD,OAAO2B,OAAO,CAACyD,GAAG,CAChBuF,kBAAkB,CAAC1M,GAAG,CAAC2M,IAAI,IACzB,IAAI,CAAC/J,OAAO,CAAC4J,WAAW,CAACpL,aAAa,CAAChC,SAAS,EAAEuN,IAAI,CAAC,CACzD,CACF,CAAC,CAACvJ,IAAI,CAAC,MAAM;YACXwF,oBAAW,CAACgE,GAAG,CAACxN,SAAS,CAAC;YAC1B,OAAOiE,gBAAgB,CAACwJ,UAAU,CAAC,CAAC;UACtC,CAAC,CAAC;QACJ,CAAC,MAAM;UACL,OAAOnJ,OAAO,CAACG,OAAO,CAAC,CAAC;QAC1B;MACF,CAAC,CAAC;IACN,CAAC,CAAC;EACN;;EAEA;EACA;EACA;EACAiJ,sBAAsBA,CAACtQ,KAAU,EAAiB;IAChD,OAAO3B,MAAM,CAACkS,OAAO,CAACvQ,KAAK,CAAC,CAACwD,GAAG,CAACgN,CAAC,IAAIA,CAAC,CAAChN,GAAG,CAACwE,CAAC,IAAIyI,IAAI,CAACC,SAAS,CAAC1I,CAAC,CAAC,CAAC,CAAC2I,IAAI,CAAC,GAAG,CAAC,CAAC;EAChF;;EAEA;EACAC,iBAAiBA,CAAC5Q,KAA0B,EAAO;IACjD,IAAI,CAACA,KAAK,CAAC0B,GAAG,EAAE;MACd,OAAO1B,KAAK;IACd;IACA,MAAMwN,OAAO,GAAGxN,KAAK,CAAC0B,GAAG,CAAC8B,GAAG,CAACmK,CAAC,IAAI,IAAI,CAAC2C,sBAAsB,CAAC3C,CAAC,CAAC,CAAC;IAClE,IAAIkD,MAAM,GAAG,KAAK;IAClB,GAAG;MACDA,MAAM,GAAG,KAAK;MACd,KAAK,IAAIjT,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG4P,OAAO,CAACxL,MAAM,GAAG,CAAC,EAAEpE,CAAC,EAAE,EAAE;QAC3C,KAAK,IAAIkT,CAAC,GAAGlT,CAAC,GAAG,CAAC,EAAEkT,CAAC,GAAGtD,OAAO,CAACxL,MAAM,EAAE8O,CAAC,EAAE,EAAE;UAC3C,MAAM,CAACC,OAAO,EAAEC,MAAM,CAAC,GAAGxD,OAAO,CAAC5P,CAAC,CAAC,CAACoE,MAAM,GAAGwL,OAAO,CAACsD,CAAC,CAAC,CAAC9O,MAAM,GAAG,CAAC8O,CAAC,EAAElT,CAAC,CAAC,GAAG,CAACA,CAAC,EAAEkT,CAAC,CAAC;UACjF,MAAMG,YAAY,GAAGzD,OAAO,CAACuD,OAAO,CAAC,CAACxC,MAAM,CAC1C,CAAC2C,GAAG,EAAExQ,KAAK,KAAKwQ,GAAG,IAAI1D,OAAO,CAACwD,MAAM,CAAC,CAAC3O,QAAQ,CAAC3B,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAC/D,CACF,CAAC;UACD,MAAMyQ,cAAc,GAAG3D,OAAO,CAACuD,OAAO,CAAC,CAAC/O,MAAM;UAC9C,IAAIiP,YAAY,KAAKE,cAAc,EAAE;YACnC;YACA;YACAnR,KAAK,CAAC0B,GAAG,CAAC0P,MAAM,CAACJ,MAAM,EAAE,CAAC,CAAC;YAC3BxD,OAAO,CAAC4D,MAAM,CAACJ,MAAM,EAAE,CAAC,CAAC;YACzBH,MAAM,GAAG,IAAI;YACb;UACF;QACF;MACF;IACF,CAAC,QAAQA,MAAM;IACf,IAAI7Q,KAAK,CAAC0B,GAAG,CAACM,MAAM,KAAK,CAAC,EAAE;MAC1BhC,KAAK,GAAG;QAAE,GAAGA,KAAK;QAAE,GAAGA,KAAK,CAAC0B,GAAG,CAAC,CAAC;MAAE,CAAC;MACrC,OAAO1B,KAAK,CAAC0B,GAAG;IAClB;IACA,OAAO1B,KAAK;EACd;;EAEA;EACAqR,kBAAkBA,CAACrR,KAA2B,EAAO;IACnD,IAAI,CAACA,KAAK,CAAC8B,IAAI,EAAE;MACf,OAAO9B,KAAK;IACd;IACA,MAAMwN,OAAO,GAAGxN,KAAK,CAAC8B,IAAI,CAAC0B,GAAG,CAACmK,CAAC,IAAI,IAAI,CAAC2C,sBAAsB,CAAC3C,CAAC,CAAC,CAAC;IACnE,IAAIkD,MAAM,GAAG,KAAK;IAClB,GAAG;MACDA,MAAM,GAAG,KAAK;MACd,KAAK,IAAIjT,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG4P,OAAO,CAACxL,MAAM,GAAG,CAAC,EAAEpE,CAAC,EAAE,EAAE;QAC3C,KAAK,IAAIkT,CAAC,GAAGlT,CAAC,GAAG,CAAC,EAAEkT,CAAC,GAAGtD,OAAO,CAACxL,MAAM,EAAE8O,CAAC,EAAE,EAAE;UAC3C,MAAM,CAACC,OAAO,EAAEC,MAAM,CAAC,GAAGxD,OAAO,CAAC5P,CAAC,CAAC,CAACoE,MAAM,GAAGwL,OAAO,CAACsD,CAAC,CAAC,CAAC9O,MAAM,GAAG,CAAC8O,CAAC,EAAElT,CAAC,CAAC,GAAG,CAACA,CAAC,EAAEkT,CAAC,CAAC;UACjF,MAAMG,YAAY,GAAGzD,OAAO,CAACuD,OAAO,CAAC,CAACxC,MAAM,CAC1C,CAAC2C,GAAG,EAAExQ,KAAK,KAAKwQ,GAAG,IAAI1D,OAAO,CAACwD,MAAM,CAAC,CAAC3O,QAAQ,CAAC3B,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAC/D,CACF,CAAC;UACD,MAAMyQ,cAAc,GAAG3D,OAAO,CAACuD,OAAO,CAAC,CAAC/O,MAAM;UAC9C,IAAIiP,YAAY,KAAKE,cAAc,EAAE;YACnC;YACA;YACAnR,KAAK,CAAC8B,IAAI,CAACsP,MAAM,CAACL,OAAO,EAAE,CAAC,CAAC;YAC7BvD,OAAO,CAAC4D,MAAM,CAACL,OAAO,EAAE,CAAC,CAAC;YAC1BF,MAAM,GAAG,IAAI;YACb;UACF;QACF;MACF;IACF,CAAC,QAAQA,MAAM;IACf,IAAI7Q,KAAK,CAAC8B,IAAI,CAACE,MAAM,KAAK,CAAC,EAAE;MAC3BhC,KAAK,GAAG;QAAE,GAAGA,KAAK;QAAE,GAAGA,KAAK,CAAC8B,IAAI,CAAC,CAAC;MAAE,CAAC;MACtC,OAAO9B,KAAK,CAAC8B,IAAI;IACnB;IACA,OAAO9B,KAAK;EACd;;EAEA;EACA;EACA;EACA;EACA;EACAoJ,qBAAqBA,CACnBzG,MAAyC,EACzCC,SAAiB,EACjBF,SAAiB,EACjB1C,KAAU,EACVwC,QAAe,GAAG,EAAE,EACf;IACL;IACA;IACA,IAAIG,MAAM,CAAC2O,2BAA2B,CAAC1O,SAAS,EAAEJ,QAAQ,EAAEE,SAAS,CAAC,EAAE;MACtE,OAAO1C,KAAK;IACd;IACA,MAAMkD,KAAK,GAAGP,MAAM,CAACQ,wBAAwB,CAACP,SAAS,CAAC;IAExD,MAAM2O,OAAO,GAAG/O,QAAQ,CAAC5C,MAAM,CAACK,GAAG,IAAI;MACrC,OAAOA,GAAG,CAACoD,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,IAAIpD,GAAG,IAAI,GAAG;IAChD,CAAC,CAAC;IAEF,MAAMuR,QAAQ,GACZ,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,CAACnO,OAAO,CAACX,SAAS,CAAC,GAAG,CAAC,CAAC,GAAG,gBAAgB,GAAG,iBAAiB;IAEzF,MAAM+O,UAAU,GAAG,EAAE;IAErB,IAAIvO,KAAK,CAACR,SAAS,CAAC,IAAIQ,KAAK,CAACR,SAAS,CAAC,CAACgP,aAAa,EAAE;MACtDD,UAAU,CAAC7Q,IAAI,CAAC,GAAGsC,KAAK,CAACR,SAAS,CAAC,CAACgP,aAAa,CAAC;IACpD;IAEA,IAAIxO,KAAK,CAACsO,QAAQ,CAAC,EAAE;MACnB,KAAK,MAAMxF,KAAK,IAAI9I,KAAK,CAACsO,QAAQ,CAAC,EAAE;QACnC,IAAI,CAACC,UAAU,CAACpP,QAAQ,CAAC2J,KAAK,CAAC,EAAE;UAC/ByF,UAAU,CAAC7Q,IAAI,CAACoL,KAAK,CAAC;QACxB;MACF;IACF;IACA;IACA,IAAIyF,UAAU,CAACzP,MAAM,GAAG,CAAC,EAAE;MACzB;MACA;MACA;MACA,IAAIuP,OAAO,CAACvP,MAAM,IAAI,CAAC,EAAE;QACvB;MACF;MACA,MAAMe,MAAM,GAAGwO,OAAO,CAAC,CAAC,CAAC;MACzB,MAAMI,WAAW,GAAG;QAClBpG,MAAM,EAAE,SAAS;QACjB3I,SAAS,EAAE,OAAO;QAClBqB,QAAQ,EAAElB;MACZ,CAAC;MAED,MAAMyK,OAAO,GAAGiE,UAAU,CAACjO,GAAG,CAACvB,GAAG,IAAI;QACpC,MAAM2P,eAAe,GAAGjP,MAAM,CAAC+E,eAAe,CAAC9E,SAAS,EAAEX,GAAG,CAAC;QAC9D,MAAM4P,SAAS,GACbD,eAAe,IACf,OAAOA,eAAe,KAAK,QAAQ,IACnCvT,MAAM,CAACyT,SAAS,CAAC3T,cAAc,CAACC,IAAI,CAACwT,eAAe,EAAE,MAAM,CAAC,GACzDA,eAAe,CAACrM,IAAI,GACpB,IAAI;QAEV,IAAIwM,WAAW;QAEf,IAAIF,SAAS,KAAK,SAAS,EAAE;UAC3B;UACAE,WAAW,GAAG;YAAE,CAAC9P,GAAG,GAAG0P;UAAY,CAAC;QACtC,CAAC,MAAM,IAAIE,SAAS,KAAK,OAAO,EAAE;UAChC;UACAE,WAAW,GAAG;YAAE,CAAC9P,GAAG,GAAG;cAAE+P,IAAI,EAAE,CAACL,WAAW;YAAE;UAAE,CAAC;QAClD,CAAC,MAAM,IAAIE,SAAS,KAAK,QAAQ,EAAE;UACjC;UACAE,WAAW,GAAG;YAAE,CAAC9P,GAAG,GAAG0P;UAAY,CAAC;QACtC,CAAC,MAAM;UACL;UACA;UACA,MAAMnQ,KAAK,CACT,wEAAwEoB,SAAS,IAAIX,GAAG,EAC1F,CAAC;QACH;QACA;QACA,IAAI5D,MAAM,CAACyT,SAAS,CAAC3T,cAAc,CAACC,IAAI,CAAC4B,KAAK,EAAEiC,GAAG,CAAC,EAAE;UACpD,OAAO,IAAI,CAACoP,kBAAkB,CAAC;YAAEvP,IAAI,EAAE,CAACiQ,WAAW,EAAE/R,KAAK;UAAE,CAAC,CAAC;QAChE;QACA;QACA,OAAO3B,MAAM,CAAC4T,MAAM,CAAC,CAAC,CAAC,EAAEjS,KAAK,EAAE+R,WAAW,CAAC;MAC9C,CAAC,CAAC;MAEF,OAAOvE,OAAO,CAACxL,MAAM,KAAK,CAAC,GAAGwL,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAACoD,iBAAiB,CAAC;QAAElP,GAAG,EAAE8L;MAAQ,CAAC,CAAC;IACrF,CAAC,MAAM;MACL,OAAOxN,KAAK;IACd;EACF;EAEA0P,kBAAkBA,CAChB/M,MAA+C,EAC/CC,SAAiB,EACjB5C,KAAU,GAAG,CAAC,CAAC,EACfwC,QAAe,GAAG,EAAE,EACpBC,IAAS,GAAG,CAAC,CAAC,EACd+J,YAA8B,GAAG,CAAC,CAAC,EAClB;IACjB,MAAMtJ,KAAK,GACTP,MAAM,IAAIA,MAAM,CAACQ,wBAAwB,GACrCR,MAAM,CAACQ,wBAAwB,CAACP,SAAS,CAAC,GAC1CD,MAAM;IACZ,IAAI,CAACO,KAAK,EAAE;MAAE,OAAO,IAAI;IAAE;IAE3B,MAAML,eAAe,GAAGK,KAAK,CAACL,eAAe;IAC7C,IAAI,CAACA,eAAe,EAAE;MAAE,OAAO,IAAI;IAAE;IAErC,IAAIL,QAAQ,CAACa,OAAO,CAACrD,KAAK,CAACiE,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE;MAAE,OAAO,IAAI;IAAE;;IAE1D;IACA;IACA;IACA;IACA,MAAMiO,YAAY,GAAG1F,YAAY,CAAC7M,IAAI;;IAEtC;IACA;IACA;IACA,MAAMwS,cAAc,GAAG,EAAE;IAEzB,MAAMC,aAAa,GAAG3P,IAAI,CAACO,IAAI;;IAE/B;IACA,MAAMqP,KAAK,GAAG,CAAC5P,IAAI,CAAC6P,SAAS,IAAI,EAAE,EAAE/D,MAAM,CAAC,CAAC2C,GAAG,EAAE1T,CAAC,KAAK;MACtD0T,GAAG,CAAC1T,CAAC,CAAC,GAAGqF,eAAe,CAACrF,CAAC,CAAC;MAC3B,OAAO0T,GAAG;IACZ,CAAC,EAAE,CAAC,CAAC,CAAC;;IAEN;IACA,MAAMqB,iBAAiB,GAAG,EAAE;IAE5B,KAAK,MAAMtQ,GAAG,IAAIY,eAAe,EAAE;MACjC;MACA,IAAIZ,GAAG,CAACsB,UAAU,CAAC,YAAY,CAAC,EAAE;QAChC,IAAI2O,YAAY,EAAE;UAChB,MAAM5M,SAAS,GAAGrD,GAAG,CAACwB,SAAS,CAAC,EAAE,CAAC;UACnC,IAAI,CAACyO,YAAY,CAAC7P,QAAQ,CAACiD,SAAS,CAAC,EAAE;YACrC;YACAkH,YAAY,CAAC7M,IAAI,IAAI6M,YAAY,CAAC7M,IAAI,CAACiB,IAAI,CAAC0E,SAAS,CAAC;YACtD;YACA6M,cAAc,CAACvR,IAAI,CAAC0E,SAAS,CAAC;UAChC;QACF;QACA;MACF;;MAEA;MACA,IAAIrD,GAAG,KAAK,GAAG,EAAE;QACfsQ,iBAAiB,CAAC3R,IAAI,CAACiC,eAAe,CAACZ,GAAG,CAAC,CAAC;QAC5C;MACF;MAEA,IAAImQ,aAAa,EAAE;QACjB,IAAInQ,GAAG,KAAK,eAAe,EAAE;UAC3B;UACAsQ,iBAAiB,CAAC3R,IAAI,CAACiC,eAAe,CAACZ,GAAG,CAAC,CAAC;UAC5C;QACF;QAEA,IAAIoQ,KAAK,CAACpQ,GAAG,CAAC,IAAIA,GAAG,CAACsB,UAAU,CAAC,OAAO,CAAC,EAAE;UACzC;UACAgP,iBAAiB,CAAC3R,IAAI,CAACyR,KAAK,CAACpQ,GAAG,CAAC,CAAC;QACpC;MACF;IACF;;IAEA;IACA,IAAImQ,aAAa,EAAE;MACjB,MAAMrP,MAAM,GAAGN,IAAI,CAACO,IAAI,CAACC,EAAE;MAC3B,IAAIC,KAAK,CAACL,eAAe,CAACE,MAAM,CAAC,EAAE;QACjCwP,iBAAiB,CAAC3R,IAAI,CAACsC,KAAK,CAACL,eAAe,CAACE,MAAM,CAAC,CAAC;MACvD;IACF;;IAEA;IACA,IAAIoP,cAAc,CAACnQ,MAAM,GAAG,CAAC,EAAE;MAC7BkB,KAAK,CAACL,eAAe,CAAC0B,aAAa,GAAG4N,cAAc;IACtD;IAEA,IAAIK,aAAa,GAAGD,iBAAiB,CAAChE,MAAM,CAAC,CAAC2C,GAAG,EAAEuB,IAAI,KAAK;MAC1D,IAAIA,IAAI,EAAE;QACRvB,GAAG,CAACtQ,IAAI,CAAC,GAAG6R,IAAI,CAAC;MACnB;MACA,OAAOvB,GAAG;IACZ,CAAC,EAAE,EAAE,CAAC;;IAEN;IACAqB,iBAAiB,CAAC3Q,OAAO,CAACsC,MAAM,IAAI;MAClC,IAAIA,MAAM,EAAE;QACVsO,aAAa,GAAGA,aAAa,CAAC5S,MAAM,CAACuE,CAAC,IAAID,MAAM,CAAC7B,QAAQ,CAAC8B,CAAC,CAAC,CAAC;MAC/D;IACF,CAAC,CAAC;IAEF,OAAOqO,aAAa;EACtB;EAEAE,0BAA0BA,CAAA,EAAG;IAC3B,OAAO,IAAI,CAACtM,OAAO,CAACsM,0BAA0B,CAAC,CAAC,CAAC9L,IAAI,CAAC+L,oBAAoB,IAAI;MAC5E,IAAI,CAACpM,qBAAqB,GAAGoM,oBAAoB;IACnD,CAAC,CAAC;EACJ;EAEAC,0BAA0BA,CAAA,EAAG;IAC3B,IAAI,CAAC,IAAI,CAACrM,qBAAqB,EAAE;MAC/B,MAAM,IAAI/E,KAAK,CAAC,6CAA6C,CAAC;IAChE;IACA,OAAO,IAAI,CAAC4E,OAAO,CAACwM,0BAA0B,CAAC,IAAI,CAACrM,qBAAqB,CAAC,CAACK,IAAI,CAAC,MAAM;MACpF,IAAI,CAACL,qBAAqB,GAAG,IAAI;IACnC,CAAC,CAAC;EACJ;EAEAsM,yBAAyBA,CAAA,EAAG;IAC1B,IAAI,CAAC,IAAI,CAACtM,qBAAqB,EAAE;MAC/B,MAAM,IAAI/E,KAAK,CAAC,4CAA4C,CAAC;IAC/D;IACA,OAAO,IAAI,CAAC4E,OAAO,CAACyM,yBAAyB,CAAC,IAAI,CAACtM,qBAAqB,CAAC,CAACK,IAAI,CAAC,MAAM;MACnF,IAAI,CAACL,qBAAqB,GAAG,IAAI;IACnC,CAAC,CAAC;EACJ;;EAEA;EACA;EACA,MAAMuM,qBAAqBA,CAAA,EAAG;IAC5B,MAAM,IAAI,CAAC1M,OAAO,CAAC0M,qBAAqB,CAAC;MACvCC,sBAAsB,EAAEjW,gBAAgB,CAACiW;IAC3C,CAAC,CAAC;IACF,MAAMC,kBAAkB,GAAG;MACzB9O,MAAM,EAAE;QACN,GAAGpH,gBAAgB,CAACmW,cAAc,CAACC,QAAQ;QAC3C,GAAGpW,gBAAgB,CAACmW,cAAc,CAACE;MACrC;IACF,CAAC;IACD,MAAMC,kBAAkB,GAAG;MACzBlP,MAAM,EAAE;QACN,GAAGpH,gBAAgB,CAACmW,cAAc,CAACC,QAAQ;QAC3C,GAAGpW,gBAAgB,CAACmW,cAAc,CAACI;MACrC;IACF,CAAC;IACD,MAAMC,yBAAyB,GAAG;MAChCpP,MAAM,EAAE;QACN,GAAGpH,gBAAgB,CAACmW,cAAc,CAACC,QAAQ;QAC3C,GAAGpW,gBAAgB,CAACmW,cAAc,CAACM;MACrC;IACF,CAAC;IACD,MAAM,IAAI,CAAC5M,UAAU,CAAC,CAAC,CAACC,IAAI,CAACjE,MAAM,IAAIA,MAAM,CAAC8I,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC1E,MAAM,IAAI,CAAC9E,UAAU,CAAC,CAAC,CAACC,IAAI,CAACjE,MAAM,IAAIA,MAAM,CAAC8I,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC1E,MAAM,IAAI,CAAC9E,UAAU,CAAC,CAAC,CAACC,IAAI,CAACjE,MAAM,IAAIA,MAAM,CAAC8I,kBAAkB,CAAC,cAAc,CAAC,CAAC;IAEjF,MAAM+H,eAAe,GAAG,IAAI,CAACtS,OAAO,CAACsS,eAAe,IAAI,CAAC,CAAC;IAE1D,IAAIA,eAAe,CAACC,uBAAuB,KAAK,KAAK,EAAE;MACrD,MAAM,IAAI,CAACrN,OAAO,CAACsN,gBAAgB,CAAC,OAAO,EAAEV,kBAAkB,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC3J,KAAK,CAACX,KAAK,IAAI;QAC5FiL,eAAM,CAACC,IAAI,CAAC,6CAA6C,EAAElL,KAAK,CAAC;QACjE,MAAMA,KAAK;MACb,CAAC,CAAC;IACJ;IAEA,IAAI,CAAC,IAAI,CAACxH,OAAO,CAACuO,6BAA6B,EAAE;MAC/C,IAAI+D,eAAe,CAACK,sCAAsC,KAAK,KAAK,EAAE;QACpE,MAAM,IAAI,CAACzN,OAAO,CACf0N,WAAW,CAAC,OAAO,EAAEd,kBAAkB,EAAE,CAAC,UAAU,CAAC,EAAE,2BAA2B,EAAE,IAAI,CAAC,CACzF3J,KAAK,CAACX,KAAK,IAAI;UACdiL,eAAM,CAACC,IAAI,CAAC,oDAAoD,EAAElL,KAAK,CAAC;UACxE,MAAMA,KAAK;QACb,CAAC,CAAC;MACN;MAEA,IAAI8K,eAAe,CAACO,mCAAmC,KAAK,KAAK,EAAE;QACjE,MAAM,IAAI,CAAC3N,OAAO,CACf0N,WAAW,CAAC,OAAO,EAAEd,kBAAkB,EAAE,CAAC,OAAO,CAAC,EAAE,wBAAwB,EAAE,IAAI,CAAC,CACnF3J,KAAK,CAACX,KAAK,IAAI;UACdiL,eAAM,CAACC,IAAI,CAAC,iDAAiD,EAAElL,KAAK,CAAC;UACrE,MAAMA,KAAK;QACb,CAAC,CAAC;MACN;IACF;IAEA,IAAI8K,eAAe,CAACQ,oBAAoB,KAAK,KAAK,EAAE;MAClD,MAAM,IAAI,CAAC5N,OAAO,CAACsN,gBAAgB,CAAC,OAAO,EAAEV,kBAAkB,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC3J,KAAK,CAACX,KAAK,IAAI;QACzFiL,eAAM,CAACC,IAAI,CAAC,wDAAwD,EAAElL,KAAK,CAAC;QAC5E,MAAMA,KAAK;MACb,CAAC,CAAC;IACJ;IAEA,IAAI8K,eAAe,CAACS,+BAA+B,KAAK,KAAK,EAAE;MAC7D,MAAM,IAAI,CAAC7N,OAAO,CACf0N,WAAW,CAAC,OAAO,EAAEd,kBAAkB,EAAE,CAAC,qBAAqB,CAAC,EAAE,qBAAqB,EAAE,KAAK,CAAC,CAC/F3J,KAAK,CAACX,KAAK,IAAI;QACdiL,eAAM,CAACC,IAAI,CAAC,uDAAuD,EAAElL,KAAK,CAAC;QAC3E,MAAMA,KAAK;MACb,CAAC,CAAC;IACN;IAEA,IAAI8K,eAAe,CAACU,iCAAiC,KAAK,KAAK,EAAE;MAC/D,MAAM,IAAI,CAAC9N,OAAO,CACf0N,WAAW,CAAC,OAAO,EAAEd,kBAAkB,EAAE,CAAC,mBAAmB,CAAC,EAAE,mBAAmB,EAAE,KAAK,CAAC,CAC3F3J,KAAK,CAACX,KAAK,IAAI;QACdiL,eAAM,CAACC,IAAI,CAAC,mDAAmD,EAAElL,KAAK,CAAC;QACvE,MAAMA,KAAK;MACb,CAAC,CAAC;IACN;IAEA,IAAI8K,eAAe,CAACW,mBAAmB,KAAK,KAAK,EAAE;MACjD,MAAM,IAAI,CAAC/N,OAAO,CAACsN,gBAAgB,CAAC,OAAO,EAAEN,kBAAkB,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC/J,KAAK,CAACX,KAAK,IAAI;QACxFiL,eAAM,CAACC,IAAI,CAAC,6CAA6C,EAAElL,KAAK,CAAC;QACjE,MAAMA,KAAK;MACb,CAAC,CAAC;IACJ;IAEA,MAAM,IAAI,CAACtC,OAAO,CACfsN,gBAAgB,CAAC,cAAc,EAAEJ,yBAAyB,EAAE,CAAC,OAAO,CAAC,CAAC,CACtEjK,KAAK,CAACX,KAAK,IAAI;MACdiL,eAAM,CAACC,IAAI,CAAC,0DAA0D,EAAElL,KAAK,CAAC;MAC9E,MAAMA,KAAK;IACb,CAAC,CAAC;IAEJ,MAAM0L,cAAc,GAAG,IAAI,CAAChO,OAAO,YAAYiO,4BAAmB;IAClE,MAAMC,iBAAiB,GAAG,IAAI,CAAClO,OAAO,YAAYmO,+BAAsB;IACxE,IAAIH,cAAc,IAAIE,iBAAiB,EAAE;MACvC,IAAIpT,OAAO,GAAG,CAAC,CAAC;MAChB,IAAIkT,cAAc,EAAE;QAClBlT,OAAO,GAAG;UACRsT,GAAG,EAAE;QACP,CAAC;MACH,CAAC,MAAM,IAAIF,iBAAiB,EAAE;QAC5BpT,OAAO,GAAG,IAAI,CAACmF,kBAAkB;QACjCnF,OAAO,CAACuT,sBAAsB,GAAG,IAAI;MACvC;MACA,MAAM,IAAI,CAACrO,OAAO,CACf0N,WAAW,CAAC,cAAc,EAAER,yBAAyB,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,KAAK,EAAEpS,OAAO,CAAC,CACzFmI,KAAK,CAACX,KAAK,IAAI;QACdiL,eAAM,CAACC,IAAI,CAAC,0DAA0D,EAAElL,KAAK,CAAC;QAC9E,MAAMA,KAAK;MACb,CAAC,CAAC;IACN;IACA;IACA;IACA,IACE8K,eAAe,CAACkB,6BAA6B,KAAK,KAAK,IACvD,OAAO,IAAI,CAACtO,OAAO,CAACuO,wBAAwB,KAAK,UAAU,EAC3D;MACA,MAAMC,aAAa,GAAGvW,MAAM,CAACsB,IAAI,CAAC,IAAI,CAACuB,OAAO,CAACuB,IAAI,IAAI,CAAC,CAAC,CAAC;MAC1D,IAAI,IAAI,CAACvB,OAAO,CAAC2T,oBAAoB,KAAK,KAAK,EAAE;QAC/C,IAAI,CAACD,aAAa,CAACvS,QAAQ,CAAC,WAAW,CAAC,EAAE;UACxCuS,aAAa,CAAChU,IAAI,CAAC,WAAW,CAAC;QACjC;MACF;MACA,MAAMsG,OAAO,CAACyD,GAAG,CACfiK,aAAa,CAACpR,GAAG,CAAC4B,QAAQ,IACxB,IAAI,CAACgB,OAAO,CAACuO,wBAAwB,CAACvP,QAAQ,CAAC,CAACiE,KAAK,CAACX,KAAK,IAAI;QAC7DiL,eAAM,CAACC,IAAI,CACT,uDAAuDxO,QAAQ,KAAK,EACpEsD,KACF,CAAC;MACH,CAAC,CACH,CACF,CAAC;IACH;IAEA,MAAM,IAAI,CAACtC,OAAO,CAAC0O,uBAAuB,CAAC,CAAC;EAC9C;EAEAC,sBAAsBA,CAACjS,MAAW,EAAEb,GAAW,EAAEJ,KAAU,EAAO;IAChE,IAAII,GAAG,CAACoB,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;MACxBP,MAAM,CAACb,GAAG,CAAC,GAAGJ,KAAK,CAACI,GAAG,CAAC;MACxB,OAAOa,MAAM;IACf;IACA,MAAMkS,IAAI,GAAG/S,GAAG,CAAC0D,KAAK,CAAC,GAAG,CAAC;IAC3B,MAAMsP,QAAQ,GAAGD,IAAI,CAAC,CAAC,CAAC;IACxB,MAAME,QAAQ,GAAGF,IAAI,CAACG,KAAK,CAAC,CAAC,CAAC,CAACxE,IAAI,CAAC,GAAG,CAAC;;IAExC;IACA,IAAI,IAAI,CAACzP,OAAO,IAAI,IAAI,CAACA,OAAO,CAACkU,sBAAsB,EAAE;MACvD;MACA,KAAK,MAAMC,OAAO,IAAI,IAAI,CAACnU,OAAO,CAACkU,sBAAsB,EAAE;QACzD,MAAMhT,KAAK,GAAGoG,cAAK,CAAC8M,sBAAsB,CACxC;UAAE,CAACL,QAAQ,GAAG,IAAI;UAAE,CAACC,QAAQ,GAAG;QAAK,CAAC,EACtCG,OAAO,CAACpT,GAAG,EACX,IACF,CAAC;QACD,IAAIG,KAAK,EAAE;UACT,MAAM,IAAIb,WAAK,CAACC,KAAK,CACnBD,WAAK,CAACC,KAAK,CAACc,gBAAgB,EAC5B,uCAAuCmO,IAAI,CAACC,SAAS,CAAC2E,OAAO,CAAC,GAChE,CAAC;QACH;MACF;IACF;IAEAvS,MAAM,CAACmS,QAAQ,CAAC,GAAG,IAAI,CAACF,sBAAsB,CAC5CjS,MAAM,CAACmS,QAAQ,CAAC,IAAI,CAAC,CAAC,EACtBC,QAAQ,EACRrT,KAAK,CAACoT,QAAQ,CAChB,CAAC;IACD,OAAOnS,MAAM,CAACb,GAAG,CAAC;IAClB,OAAOa,MAAM;EACf;EAEAoH,uBAAuBA,CAACkB,cAAmB,EAAE3K,MAAW,EAAgB;IACtE,MAAM8U,QAAQ,GAAG,CAAC,CAAC;IACnB,IAAI,CAAC9U,MAAM,EAAE;MACX,OAAOyG,OAAO,CAACG,OAAO,CAACkO,QAAQ,CAAC;IAClC;IACAlX,MAAM,CAACsB,IAAI,CAACyL,cAAc,CAAC,CAACxJ,OAAO,CAACK,GAAG,IAAI;MACzC,MAAMuT,SAAS,GAAGpK,cAAc,CAACnJ,GAAG,CAAC;MACrC;MACA,IACEuT,SAAS,IACT,OAAOA,SAAS,KAAK,QAAQ,IAC7BA,SAAS,CAAC1Q,IAAI,IACd,CAAC,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,CAAC,CAACzB,OAAO,CAACmS,SAAS,CAAC1Q,IAAI,CAAC,GAAG,CAAC,CAAC,EACvF;QACA;QACA;QACA,IAAI,CAACiQ,sBAAsB,CAACQ,QAAQ,EAAEtT,GAAG,EAAExB,MAAM,CAAC;QAClD;QACA,IAAIwB,GAAG,CAACI,QAAQ,CAAC,GAAG,CAAC,EAAE;UACrB,MAAM,CAAC2J,KAAK,EAAEqB,KAAK,CAAC,GAAGpL,GAAG,CAAC0D,KAAK,CAAC,GAAG,CAAC;UACrC,MAAM8P,YAAY,GAAG9T,KAAK,CAAC+T,IAAI,CAACrI,KAAK,CAAC,CAACsI,KAAK,CAACC,CAAC,IAAIA,CAAC,IAAI,GAAG,IAAIA,CAAC,IAAI,GAAG,CAAC;UACvE,IAAIH,YAAY,IAAI9T,KAAK,CAACoC,OAAO,CAACtD,MAAM,CAACuL,KAAK,CAAC,CAAC,IAAI,CAACrK,KAAK,CAACoC,OAAO,CAACwR,QAAQ,CAACvJ,KAAK,CAAC,CAAC,EAAE;YACnFuJ,QAAQ,CAACvJ,KAAK,CAAC,GAAGvL,MAAM,CAACuL,KAAK,CAAC;UACjC;QACF;MACF;IACF,CAAC,CAAC;IACF,OAAO9E,OAAO,CAACG,OAAO,CAACkO,QAAQ,CAAC;EAClC;AAIF;AAEAM,MAAM,CAACC,OAAO,GAAG5P,kBAAkB;AACnC;AACA2P,MAAM,CAACC,OAAO,CAACC,cAAc,GAAGjV,aAAa;AAC7C+U,MAAM,CAACC,OAAO,CAACvT,mBAAmB,GAAGA,mBAAmB","ignoreList":[]}
1659
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_node","require","_lodash","_interopRequireDefault","_intersect","_logger","_Utils","SchemaController","_interopRequireWildcard","_StorageAdapter","_MongoStorageAdapter","_PostgresStorageAdapter","_SchemaCache","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","queryOperators","internalFields","_rperm","clientRead","masterRead","masterWrite","_wperm","_hashed_password","_email_verify_token","_perishable_token","_perishable_token_expires_at","_email_verify_token_expires_at","_failed_login_count","_account_lockout_expires_at","_password_changed_at","_password_history","_tombstone","_session_token","specialQueryKeys","keys","filter","k","specialMasterQueryKeys","addWriteACL","query","acl","newQuery","_","cloneDeep","$in","addReadACL","transformObjectACL","ACL","result","entry","read","push","write","validateQuery","isMaster","isMaintenance","update","options","_depth","rc","requestComplexity","queryDepth","Parse","Error","INVALID_QUERY","$or","Array","forEach","value","$and","$nor","length","key","$regex","$options","match","includes","INVALID_KEY_NAME","filterSensitiveData","aclGroup","auth","operation","schema","className","protectedFields","object","userId","user","id","perms","getClassLevelPermissions","isReadOperation","indexOf","protectedFieldsPointerPerm","startsWith","map","substring","newProtectedFields","overrideProtectedFields","pointerPerm","pointerPermIncludesUser","readUserFieldValue","isArray","some","objectId","fields","v","isUserClass","password","sessionToken","temporaryKeys","charAt","authData","specialKeysForUpdate","isSpecialUpdateKey","joinTableName","flattenUpdateOperatorsForCreate","__op","amount","INVALID_JSON","objects","COMMAND_UNAVAILABLE","transformAuthData","provider","providerData","fieldName","type","untransformObjectACL","output","getRootFieldName","split","relationSchema","relatedId","owningId","convertEmailToLowercase","toLowerCase","convertUsernameToLowercase","DatabaseController","constructor","adapter","idempotencyOptions","schemaPromise","_transactionalSession","collectionExists","classExists","purgeCollection","loadSchema","then","schemaController","getOneSchema","deleteObjectsByQuery","validateClassName","classNameIsValid","Promise","reject","INVALID_CLASS_NAME","resolve","clearCache","load","loadSchemaIfNeeded","redirectClassNameForKey","getExpectedType","targetClass","validateObject","runOptions","maintenance","undefined","s","canAddField","many","upsert","addsField","skipSanitization","validateOnly","validSchemaController","Utils","checkProhibitedKeywords","error","validateFileUrlsInObject","FILE_SAVE_ERROR","message","originalQuery","originalUpdate","structuredClone","relationUpdates","validatePermission","collectRelationUpdates","addPointerPermissions","catch","rootFieldName","fieldNameIsValid","updateOperation","innerKey","INVALID_NESTED_KEY","find","readPreference","OBJECT_NOT_FOUND","updateObjectsByQuery","upsertOneObject","findOneAndUpdate","handleRelationUpdates","_sanitizeDatabaseResult","ops","deleteMe","process","op","x","pending","addRelation","removeRelation","all","fromClassName","fromId","toId","doc","code","destroy","parseFormatSchema","create","originalObject","createdAt","iso","__type","updatedAt","enforceClassExists","createObject","convertSchemaToAdapterSchema","classSchema","schemaData","schemaFields","newKeys","field","action","deleteEverything","fast","SchemaCache","clear","deleteAllClasses","relatedIds","queryOptions","skip","limit","sort","findOptions","canSortOnJoinTables","_id","results","owningIds","reduceInRelation","promises","ors","aQuery","index","ands","otherKeys","queries","constraintKey","isNegation","q","ids","addNotInObjectIdsIds","addInObjectIdsIds","reduceRelationKeys","relatedTo","idsFromString","idsFromEq","idsFromIn","allIds","list","totalLength","reduce","memo","idsIntersection","intersect","big","$eq","idsFromNin","Set","$nin","count","distinct","pipeline","hint","caseInsensitive","explain","comment","_created_at","_updated_at","enableCollationCaseComparison","addProtectedFields","aggregate","detailedMessage","createSanitizedError","INTERNAL_SERVER_ERROR","deleteSchema","deleteClass","wasParseCollection","relationFieldNames","name","del","reloadData","objectToEntriesStrings","entries","a","JSON","stringify","join","reduceOrOperation","repeat","j","shorter","longer","foundEntries","acc","shorterEntries","splice","reduceAndOperation","testPermissionsForClassName","userACL","groupKey","permFields","pointerFields","userPointer","fieldDescriptor","fieldType","prototype","queryClause","$all","assign","preserveKeys","serverOnlyKeys","authenticated","roles","userRoles","protectedKeysSets","protectedKeys","next","createTransactionalSession","transactionalSession","commitTransactionalSession","abortTransactionalSession","performInitialization","VolatileClassesSchemas","requiredUserFields","defaultColumns","_Default","_User","requiredRoleFields","_Role","requiredIdempotencyFields","_Idempotency","databaseOptions","createIndexUserUsername","ensureUniqueness","logger","warn","createIndexUserUsernameCaseInsensitive","ensureIndex","createIndexUserEmailCaseInsensitive","createIndexUserEmail","createIndexUserEmailVerifyToken","createIndexUserPasswordResetToken","createIndexRoleName","isMongoAdapter","MongoStorageAdapter","isPostgresAdapter","PostgresStorageAdapter","ttl","setIdempotencyFunction","createIndexAuthDataUniqueness","ensureAuthDataUniqueness","authProviders","enableAnonymousUsers","updateSchemaWithIndexes","_expandResultOnKeyPath","path","firstKey","nextPath","slice","requestKeywordDenylist","keyword","objectContainsKeyValue","response","keyUpdate","isArrayIndex","from","every","c","module","exports","_validateQuery"],"sources":["../../src/Controllers/DatabaseController.js"],"sourcesContent":["﻿// @flow\n// A database adapter that works with data exported from the hosted\n// Parse database.\n\n// @flow-disable-next\nimport { Parse } from 'parse/node';\n// @flow-disable-next\nimport _ from 'lodash';\n// @flow-disable-next\nimport intersect from 'intersect';\nimport logger from '../logger';\nimport Utils from '../Utils';\nimport * as SchemaController from './SchemaController';\nimport { StorageAdapter } from '../Adapters/Storage/StorageAdapter';\nimport MongoStorageAdapter from '../Adapters/Storage/Mongo/MongoStorageAdapter';\nimport PostgresStorageAdapter from '../Adapters/Storage/Postgres/PostgresStorageAdapter';\nimport SchemaCache from '../Adapters/Cache/SchemaCache';\nimport type { LoadSchemaOptions } from './types';\nimport type { ParseServerOptions } from '../Options';\nimport type { QueryOptions, FullQueryOptions } from '../Adapters/Storage/StorageAdapter';\nimport { createSanitizedError } from '../Error';\n\n// Query operators that always pass validation regardless of auth level.\nconst queryOperators = ['$and', '$or', '$nor'];\n\n// Registry of internal fields with access permissions.\n// Internal fields are never directly writable by clients, so clientWrite is omitted.\n// - clientRead: any client can use this field in queries\n// - masterRead: master key can use this field in queries\n// - masterWrite: master key can use this field in updates\nconst internalFields = {\n  _rperm:                         { clientRead: true,  masterRead: true,  masterWrite: true  },\n  _wperm:                         { clientRead: true,  masterRead: true,  masterWrite: true  },\n  _hashed_password:               { clientRead: false, masterRead: false, masterWrite: true  },\n  _email_verify_token:            { clientRead: false, masterRead: true,  masterWrite: true  },\n  _perishable_token:              { clientRead: false, masterRead: true,  masterWrite: true  },\n  _perishable_token_expires_at:   { clientRead: false, masterRead: true,  masterWrite: true  },\n  _email_verify_token_expires_at: { clientRead: false, masterRead: true,  masterWrite: true  },\n  _failed_login_count:            { clientRead: false, masterRead: true,  masterWrite: true  },\n  _account_lockout_expires_at:    { clientRead: false, masterRead: true,  masterWrite: true  },\n  _password_changed_at:           { clientRead: false, masterRead: true,  masterWrite: true  },\n  _password_history:              { clientRead: false, masterRead: true,  masterWrite: true  },\n  _tombstone:                     { clientRead: false, masterRead: true,  masterWrite: false },\n  _session_token:                 { clientRead: false, masterRead: true,  masterWrite: false },\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // The following fields are not accessed by their _-prefixed name through the API;\n  // they are mapped to REST-level names in the adapter layer or handled through\n  // separate code paths.\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // System fields (mapped to REST-level names):\n  // _id (objectId)\n  // _created_at (createdAt)\n  // _updated_at (updatedAt)\n  // _last_used (lastUsed)\n  // _expiresAt (expiresAt)\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // Legacy ACL format: mapped to/from _rperm/_wperm\n  // _acl\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // Schema metadata: not data fields, used only for schema configuration\n  // _metadata\n  // _client_permissions\n  /////////////////////////////////////////////////////////////////////////////////////////////\n  // Dynamic auth data fields: used only in projections and updates, not in queries\n  // _auth_data_<provider>\n};\n\n// Derived access lists\nconst specialQueryKeys = [\n  ...queryOperators,\n  ...Object.keys(internalFields).filter(k => internalFields[k].clientRead),\n];\nconst specialMasterQueryKeys = [\n  ...queryOperators,\n  ...Object.keys(internalFields).filter(k => internalFields[k].masterRead),\n];\n\nfunction addWriteACL(query, acl) {\n  const newQuery = _.cloneDeep(query);\n  //Can't be any existing '_wperm' query, we don't allow client queries on that, no need to $and\n  newQuery._wperm = { $in: [null, ...acl] };\n  return newQuery;\n}\n\nfunction addReadACL(query, acl) {\n  const newQuery = _.cloneDeep(query);\n  //Can't be any existing '_rperm' query, we don't allow client queries on that, no need to $and\n  newQuery._rperm = { $in: [null, '*', ...acl] };\n  return newQuery;\n}\n\n// Transforms a REST API formatted ACL object to our two-field mongo format.\nconst transformObjectACL = ({ ACL, ...result }) => {\n  if (!ACL) {\n    return result;\n  }\n\n  result._wperm = [];\n  result._rperm = [];\n\n  for (const entry in ACL) {\n    if (ACL[entry].read) {\n      result._rperm.push(entry);\n    }\n    if (ACL[entry].write) {\n      result._wperm.push(entry);\n    }\n  }\n  return result;\n};\n\nconst validateQuery = (\n  query: any,\n  isMaster: boolean,\n  isMaintenance: boolean,\n  update: boolean,\n  options: ?ParseServerOptions,\n  _depth: number = 0\n): void => {\n  if (isMaintenance) {\n    isMaster = true;\n  }\n  const rc = options?.requestComplexity;\n  if (!isMaster && rc && rc.queryDepth !== -1 && _depth > rc.queryDepth) {\n    throw new Parse.Error(\n      Parse.Error.INVALID_QUERY,\n      `Query condition nesting depth exceeds maximum allowed depth of ${rc.queryDepth}`\n    );\n  }\n  if (query.ACL) {\n    throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Cannot query on ACL.');\n  }\n\n  if (query.$or) {\n    if (query.$or instanceof Array) {\n      query.$or.forEach(value => validateQuery(value, isMaster, isMaintenance, update, options, _depth + 1));\n    } else {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Bad $or format - use an array value.');\n    }\n  }\n\n  if (query.$and) {\n    if (query.$and instanceof Array) {\n      query.$and.forEach(value => validateQuery(value, isMaster, isMaintenance, update, options, _depth + 1));\n    } else {\n      throw new Parse.Error(Parse.Error.INVALID_QUERY, 'Bad $and format - use an array value.');\n    }\n  }\n\n  if (query.$nor) {\n    if (query.$nor instanceof Array && query.$nor.length > 0) {\n      query.$nor.forEach(value => validateQuery(value, isMaster, isMaintenance, update, options, _depth + 1));\n    } else {\n      throw new Parse.Error(\n        Parse.Error.INVALID_QUERY,\n        'Bad $nor format - use an array of at least 1 value.'\n      );\n    }\n  }\n\n  Object.keys(query).forEach(key => {\n    if (query && query[key] && query[key].$regex) {\n      if (typeof query[key].$options === 'string') {\n        if (!query[key].$options.match(/^[imxsu]+$/)) {\n          throw new Parse.Error(\n            Parse.Error.INVALID_QUERY,\n            `Bad $options value for query: ${query[key].$options}`\n          );\n        }\n      }\n    }\n    if (\n      !key.match(/^[a-zA-Z][a-zA-Z0-9_\\.]*$/) &&\n      !specialQueryKeys.includes(key) &&\n      !(isMaster && specialMasterQueryKeys.includes(key))\n    ) {\n      throw new Parse.Error(Parse.Error.INVALID_KEY_NAME, `Invalid key name: ${key}`);\n    }\n  });\n};\n\n// Filters out any data that shouldn't be on this REST-formatted object.\nconst filterSensitiveData = (\n  isMaster: boolean,\n  isMaintenance: boolean,\n  aclGroup: any[],\n  auth: any,\n  operation: any,\n  schema: SchemaController.SchemaController | any,\n  className: string,\n  protectedFields: null | Array<any>,\n  object: any\n) => {\n  let userId = null;\n  if (auth && auth.user) { userId = auth.user.id; }\n\n  // replace protectedFields when using pointer-permissions\n  const perms =\n    schema && schema.getClassLevelPermissions ? schema.getClassLevelPermissions(className) : {};\n  if (perms) {\n    const isReadOperation = ['get', 'find'].indexOf(operation) > -1;\n\n    if (isReadOperation && perms.protectedFields) {\n      // extract protectedFields added with the pointer-permission prefix\n      const protectedFieldsPointerPerm = Object.keys(perms.protectedFields)\n        .filter(key => key.startsWith('userField:'))\n        .map(key => {\n          return { key: key.substring(10), value: perms.protectedFields[key] };\n        });\n\n      const newProtectedFields: Array<string>[] = [];\n      let overrideProtectedFields = false;\n\n      // check if the object grants the current user access based on the extracted fields\n      protectedFieldsPointerPerm.forEach(pointerPerm => {\n        let pointerPermIncludesUser = false;\n        const readUserFieldValue = object[pointerPerm.key];\n        if (readUserFieldValue) {\n          if (Array.isArray(readUserFieldValue)) {\n            pointerPermIncludesUser = readUserFieldValue.some(\n              user => user.objectId && user.objectId === userId\n            );\n          } else {\n            pointerPermIncludesUser =\n              readUserFieldValue.objectId && readUserFieldValue.objectId === userId;\n          }\n        }\n\n        if (pointerPermIncludesUser) {\n          overrideProtectedFields = true;\n          newProtectedFields.push(pointerPerm.value);\n        }\n      });\n\n      // if at least one pointer-permission affected the current user\n      // intersect vs protectedFields from previous stage (@see addProtectedFields)\n      // Sets theory (intersections): A x (B x C) == (A x B) x C\n      if (overrideProtectedFields && protectedFields) {\n        newProtectedFields.push(protectedFields);\n      }\n      // intersect all sets of protectedFields\n      newProtectedFields.forEach(fields => {\n        if (fields) {\n          // if there're no protctedFields by other criteria ( id / role / auth)\n          // then we must intersect each set (per userField)\n          if (!protectedFields) {\n            protectedFields = fields;\n          } else {\n            protectedFields = protectedFields.filter(v => fields.includes(v));\n          }\n        }\n      });\n    }\n  }\n\n  const isUserClass = className === '_User';\n  if (isUserClass) {\n    object.password = object._hashed_password;\n    delete object._hashed_password;\n    delete object.sessionToken;\n  }\n\n  if (isMaintenance) {\n    return object;\n  }\n\n  /* special treat for the user class: don't filter protectedFields if currently loggedin user is\n  the retrieved user */\n  if (!(isUserClass && userId && object.objectId === userId)) {\n    protectedFields && protectedFields.forEach(k => delete object[k]);\n\n    // fields not requested by client (excluded),\n    // but were needed to apply protectedFields\n    perms?.protectedFields?.temporaryKeys?.forEach(k => delete object[k]);\n  }\n\n  for (const key in object) {\n    if (key.charAt(0) === '_') {\n      delete object[key];\n    }\n  }\n\n  if (!isUserClass || isMaster) {\n    return object;\n  }\n\n  if (aclGroup.indexOf(object.objectId) > -1) {\n    return object;\n  }\n  delete object.authData;\n  return object;\n};\n\n// Runs an update on the database.\n// Returns a promise for an object with the new values for field\n// modifications that don't know their results ahead of time, like\n// 'increment'.\n// Options:\n//   acl:  a list of strings. If the object to be updated has an ACL,\n//         one of the provided strings must provide the caller with\n//         write permissions.\nconst specialKeysForUpdate = Object.keys(internalFields).filter(k => internalFields[k].masterWrite);\n\nconst isSpecialUpdateKey = key => {\n  return specialKeysForUpdate.indexOf(key) >= 0;\n};\n\nfunction joinTableName(className, key) {\n  return `_Join:${key}:${className}`;\n}\n\nconst flattenUpdateOperatorsForCreate = object => {\n  for (const key in object) {\n    if (object[key] && object[key].__op) {\n      switch (object[key].__op) {\n        case 'Increment':\n          if (typeof object[key].amount !== 'number') {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = object[key].amount;\n          break;\n        case 'SetOnInsert':\n          object[key] = object[key].amount;\n          break;\n        case 'Add':\n          if (!(object[key].objects instanceof Array)) {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = object[key].objects;\n          break;\n        case 'AddUnique':\n          if (!(object[key].objects instanceof Array)) {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = object[key].objects;\n          break;\n        case 'Remove':\n          if (!(object[key].objects instanceof Array)) {\n            throw new Parse.Error(Parse.Error.INVALID_JSON, 'objects to add must be an array');\n          }\n          object[key] = [];\n          break;\n        case 'Delete':\n          delete object[key];\n          break;\n        default:\n          throw new Parse.Error(\n            Parse.Error.COMMAND_UNAVAILABLE,\n            `The ${object[key].__op} operator is not supported yet.`\n          );\n      }\n    }\n  }\n};\n\nconst transformAuthData = (className, object, schema) => {\n  if (object.authData && className === '_User') {\n    Object.keys(object.authData).forEach(provider => {\n      const providerData = object.authData[provider];\n      const fieldName = `_auth_data_${provider}`;\n      if (providerData == null) {\n        object[fieldName] = {\n          __op: 'Delete',\n        };\n      } else {\n        object[fieldName] = providerData;\n        schema.fields[fieldName] = { type: 'Object' };\n      }\n    });\n    delete object.authData;\n  }\n};\n// Transforms a Database format ACL to a REST API format ACL\nconst untransformObjectACL = ({ _rperm, _wperm, ...output }) => {\n  if (_rperm || _wperm) {\n    output.ACL = {};\n\n    (_rperm || []).forEach(entry => {\n      if (!output.ACL[entry]) {\n        output.ACL[entry] = { read: true };\n      } else {\n        output.ACL[entry]['read'] = true;\n      }\n    });\n\n    (_wperm || []).forEach(entry => {\n      if (!output.ACL[entry]) {\n        output.ACL[entry] = { write: true };\n      } else {\n        output.ACL[entry]['write'] = true;\n      }\n    });\n  }\n  return output;\n};\n\n/**\n * When querying, the fieldName may be compound, extract the root fieldName\n *     `temperature.celsius` becomes `temperature`\n * @param {string} fieldName that may be a compound field name\n * @returns {string} the root name of the field\n */\nconst getRootFieldName = (fieldName: string): string => {\n  return fieldName.split('.')[0];\n};\n\nconst relationSchema = {\n  fields: { relatedId: { type: 'String' }, owningId: { type: 'String' } },\n};\n\nconst convertEmailToLowercase = (object, className, options) => {\n  if (className === '_User' && options.convertEmailToLowercase) {\n    if (typeof object['email'] === 'string') {\n      object['email'] = object['email'].toLowerCase();\n    }\n  }\n};\n\nconst convertUsernameToLowercase = (object, className, options) => {\n  if (className === '_User' && options.convertUsernameToLowercase) {\n    if (typeof object['username'] === 'string') {\n      object['username'] = object['username'].toLowerCase();\n    }\n  }\n};\n\nclass DatabaseController {\n  adapter: StorageAdapter;\n  schemaCache: any;\n  schemaPromise: ?Promise<SchemaController.SchemaController>;\n  _transactionalSession: ?any;\n  options: ParseServerOptions;\n  idempotencyOptions: any;\n\n  constructor(adapter: StorageAdapter, options: ParseServerOptions) {\n    this.adapter = adapter;\n    this.options = options || {};\n    this.idempotencyOptions = this.options.idempotencyOptions || {};\n    // Prevent mutable this.schema, otherwise one request could use\n    // multiple schemas, so instead use loadSchema to get a schema.\n    this.schemaPromise = null;\n    this._transactionalSession = null;\n    this.options = options;\n  }\n\n  collectionExists(className: string): Promise<boolean> {\n    return this.adapter.classExists(className);\n  }\n\n  purgeCollection(className: string): Promise<void> {\n    return this.loadSchema()\n      .then(schemaController => schemaController.getOneSchema(className))\n      .then(schema => this.adapter.deleteObjectsByQuery(className, schema, {}));\n  }\n\n  validateClassName(className: string): Promise<void> {\n    if (!SchemaController.classNameIsValid(className)) {\n      return Promise.reject(\n        new Parse.Error(Parse.Error.INVALID_CLASS_NAME, 'invalid className: ' + className)\n      );\n    }\n    return Promise.resolve();\n  }\n\n  // Returns a promise for a schemaController.\n  loadSchema(\n    options: LoadSchemaOptions = { clearCache: false }\n  ): Promise<SchemaController.SchemaController> {\n    if (this.schemaPromise != null) {\n      return this.schemaPromise;\n    }\n    this.schemaPromise = SchemaController.load(this.adapter, options);\n    this.schemaPromise.then(\n      () => delete this.schemaPromise,\n      () => delete this.schemaPromise\n    );\n    return this.loadSchema(options);\n  }\n\n  loadSchemaIfNeeded(\n    schemaController: SchemaController.SchemaController,\n    options: LoadSchemaOptions = { clearCache: false }\n  ): Promise<SchemaController.SchemaController> {\n    return schemaController ? Promise.resolve(schemaController) : this.loadSchema(options);\n  }\n\n  // Returns a promise for the classname that is related to the given\n  // classname through the key.\n  // TODO: make this not in the DatabaseController interface\n  redirectClassNameForKey(className: string, key: string): Promise<?string> {\n    return this.loadSchema().then(schema => {\n      var t = schema.getExpectedType(className, key);\n      if (t != null && typeof t !== 'string' && t.type === 'Relation') {\n        return t.targetClass;\n      }\n      return className;\n    });\n  }\n\n  // Uses the schema to validate the object (REST API format).\n  // Returns a promise that resolves to the new schema.\n  // This does not update this.schema, because in a situation like a\n  // batch request, that could confuse other users of the schema.\n  validateObject(\n    className: string,\n    object: any,\n    query: any,\n    runOptions: QueryOptions,\n    maintenance: boolean\n  ): Promise<boolean> {\n    let schema;\n    const acl = runOptions.acl;\n    const isMaster = acl === undefined;\n    var aclGroup: string[] = acl || [];\n    return this.loadSchema()\n      .then(s => {\n        schema = s;\n        if (isMaster) {\n          return Promise.resolve();\n        }\n        return this.canAddField(schema, className, object, aclGroup, runOptions);\n      })\n      .then(() => {\n        return schema.validateObject(className, object, query, maintenance);\n      });\n  }\n\n  update(\n    className: string,\n    query: any,\n    update: any,\n    { acl, many, upsert, addsField }: FullQueryOptions = {},\n    skipSanitization: boolean = false,\n    validateOnly: boolean = false,\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    try {\n      Utils.checkProhibitedKeywords(this.options, update);\n    } catch (error) {\n      return Promise.reject(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n    }\n    try {\n      const { validateFileUrlsInObject } = require('../FileUrlValidator');\n      validateFileUrlsInObject(update, this.options);\n    } catch (error) {\n      return Promise.reject(error instanceof Parse.Error ? error : new Parse.Error(Parse.Error.FILE_SAVE_ERROR, error.message || error));\n    }\n    const originalQuery = query;\n    const originalUpdate = update;\n    // Make a copy of the object, so we don't mutate the incoming data.\n    update = structuredClone(update);\n    var relationUpdates = [];\n    var isMaster = acl === undefined;\n    var aclGroup = acl || [];\n\n    return this.loadSchemaIfNeeded(validSchemaController).then(schemaController => {\n      return (isMaster\n        ? Promise.resolve()\n        : schemaController.validatePermission(className, aclGroup, 'update')\n      )\n        .then(() => {\n          relationUpdates = this.collectRelationUpdates(className, originalQuery.objectId, update);\n          if (!isMaster) {\n            query = this.addPointerPermissions(\n              schemaController,\n              className,\n              'update',\n              query,\n              aclGroup\n            );\n\n            if (addsField) {\n              query = {\n                $and: [\n                  query,\n                  this.addPointerPermissions(\n                    schemaController,\n                    className,\n                    'addField',\n                    query,\n                    aclGroup\n                  ),\n                ],\n              };\n            }\n          }\n          if (!query) {\n            return Promise.resolve();\n          }\n          if (acl) {\n            query = addWriteACL(query, acl);\n          }\n          validateQuery(query, isMaster, false, true, this.options);\n          return schemaController\n            .getOneSchema(className, true)\n            .catch(error => {\n              // If the schema doesn't exist, pretend it exists with no fields. This behavior\n              // will likely need revisiting.\n              if (error === undefined) {\n                return { fields: {} };\n              }\n              throw error;\n            })\n            .then(schema => {\n              Object.keys(update).forEach(fieldName => {\n                if (fieldName.match(/^authData\\./)) {\n                  throw new Parse.Error(\n                    Parse.Error.INVALID_KEY_NAME,\n                    `Invalid field name for update: ${fieldName}`\n                  );\n                }\n                const rootFieldName = getRootFieldName(fieldName);\n                if (\n                  !SchemaController.fieldNameIsValid(rootFieldName, className) &&\n                  !isSpecialUpdateKey(rootFieldName)\n                ) {\n                  throw new Parse.Error(\n                    Parse.Error.INVALID_KEY_NAME,\n                    `Invalid field name for update: ${fieldName}`\n                  );\n                }\n              });\n              for (const updateOperation in update) {\n                if (\n                  update[updateOperation] &&\n                  typeof update[updateOperation] === 'object' &&\n                  Object.keys(update[updateOperation]).some(\n                    innerKey => innerKey.includes('$') || innerKey.includes('.')\n                  )\n                ) {\n                  throw new Parse.Error(\n                    Parse.Error.INVALID_NESTED_KEY,\n                    \"Nested keys should not contain the '$' or '.' characters\"\n                  );\n                }\n              }\n              update = transformObjectACL(update);\n              convertEmailToLowercase(update, className, this.options);\n              convertUsernameToLowercase(update, className, this.options);\n              transformAuthData(className, update, schema);\n              if (validateOnly) {\n                return this.adapter.find(className, schema, query, { readPreference: 'primary' }).then(result => {\n                  if (!result || !result.length) {\n                    throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n                  }\n                  return {};\n                });\n              }\n              if (many) {\n                return this.adapter.updateObjectsByQuery(\n                  className,\n                  schema,\n                  query,\n                  update,\n                  this._transactionalSession\n                );\n              } else if (upsert) {\n                return this.adapter.upsertOneObject(\n                  className,\n                  schema,\n                  query,\n                  update,\n                  this._transactionalSession\n                );\n              } else {\n                return this.adapter.findOneAndUpdate(\n                  className,\n                  schema,\n                  query,\n                  update,\n                  this._transactionalSession\n                );\n              }\n            });\n        })\n        .then((result: any) => {\n          if (!result) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n          }\n          if (validateOnly) {\n            return result;\n          }\n          return this.handleRelationUpdates(\n            className,\n            originalQuery.objectId,\n            update,\n            relationUpdates\n          ).then(() => {\n            return result;\n          });\n        })\n        .then(result => {\n          if (skipSanitization) {\n            return Promise.resolve(result);\n          }\n          return this._sanitizeDatabaseResult(originalUpdate, result);\n        });\n    });\n  }\n\n  // Collect all relation-updating operations from a REST-format update.\n  // Returns a list of all relation updates to perform\n  // This mutates update.\n  collectRelationUpdates(className: string, objectId: ?string, update: any) {\n    var ops = [];\n    var deleteMe = [];\n    objectId = update.objectId || objectId;\n\n    var process = (op, key) => {\n      if (!op) {\n        return;\n      }\n      if (op.__op == 'AddRelation') {\n        ops.push({ key, op });\n        deleteMe.push(key);\n      }\n\n      if (op.__op == 'RemoveRelation') {\n        ops.push({ key, op });\n        deleteMe.push(key);\n      }\n\n      if (op.__op == 'Batch') {\n        for (var x of op.ops) {\n          process(x, key);\n        }\n      }\n    };\n\n    for (const key in update) {\n      process(update[key], key);\n    }\n    for (const key of deleteMe) {\n      delete update[key];\n    }\n    return ops;\n  }\n\n  // Processes relation-updating operations from a REST-format update.\n  // Returns a promise that resolves when all updates have been performed\n  handleRelationUpdates(className: string, objectId: string, update: any, ops: any) {\n    var pending = [];\n    objectId = update.objectId || objectId;\n    ops.forEach(({ key, op }) => {\n      if (!op) {\n        return;\n      }\n      if (op.__op == 'AddRelation') {\n        for (const object of op.objects) {\n          pending.push(this.addRelation(key, className, objectId, object.objectId));\n        }\n      }\n\n      if (op.__op == 'RemoveRelation') {\n        for (const object of op.objects) {\n          pending.push(this.removeRelation(key, className, objectId, object.objectId));\n        }\n      }\n    });\n\n    return Promise.all(pending);\n  }\n\n  // Adds a relation.\n  // Returns a promise that resolves successfully iff the add was successful.\n  addRelation(key: string, fromClassName: string, fromId: string, toId: string) {\n    const doc = {\n      relatedId: toId,\n      owningId: fromId,\n    };\n    return this.adapter.upsertOneObject(\n      `_Join:${key}:${fromClassName}`,\n      relationSchema,\n      doc,\n      doc,\n      this._transactionalSession\n    );\n  }\n\n  // Removes a relation.\n  // Returns a promise that resolves successfully iff the remove was\n  // successful.\n  removeRelation(key: string, fromClassName: string, fromId: string, toId: string) {\n    var doc = {\n      relatedId: toId,\n      owningId: fromId,\n    };\n    return this.adapter\n      .deleteObjectsByQuery(\n        `_Join:${key}:${fromClassName}`,\n        relationSchema,\n        doc,\n        this._transactionalSession\n      )\n      .catch(error => {\n        // We don't care if they try to delete a non-existent relation.\n        if (error.code == Parse.Error.OBJECT_NOT_FOUND) {\n          return;\n        }\n        throw error;\n      });\n  }\n\n  // Removes objects matches this query from the database.\n  // Returns a promise that resolves successfully iff the object was\n  // deleted.\n  // Options:\n  //   acl:  a list of strings. If the object to be updated has an ACL,\n  //         one of the provided strings must provide the caller with\n  //         write permissions.\n  destroy(\n    className: string,\n    query: any,\n    { acl }: QueryOptions = {},\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    const isMaster = acl === undefined;\n    const aclGroup = acl || [];\n\n    return this.loadSchemaIfNeeded(validSchemaController).then(schemaController => {\n      return (isMaster\n        ? Promise.resolve()\n        : schemaController.validatePermission(className, aclGroup, 'delete')\n      ).then(() => {\n        if (!isMaster) {\n          query = this.addPointerPermissions(\n            schemaController,\n            className,\n            'delete',\n            query,\n            aclGroup\n          );\n          if (!query) {\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n          }\n        }\n        // delete by query\n        if (acl) {\n          query = addWriteACL(query, acl);\n        }\n        validateQuery(query, isMaster, false, false, this.options);\n        return schemaController\n          .getOneSchema(className)\n          .catch(error => {\n            // If the schema doesn't exist, pretend it exists with no fields. This behavior\n            // will likely need revisiting.\n            if (error === undefined) {\n              return { fields: {} };\n            }\n            throw error;\n          })\n          .then(parseFormatSchema =>\n            this.adapter.deleteObjectsByQuery(\n              className,\n              parseFormatSchema,\n              query,\n              this._transactionalSession\n            )\n          )\n          .catch(error => {\n            // When deleting sessions while changing passwords, don't throw an error if they don't have any sessions.\n            if (className === '_Session' && error.code === Parse.Error.OBJECT_NOT_FOUND) {\n              return Promise.resolve({});\n            }\n            throw error;\n          });\n      });\n    });\n  }\n\n  // Inserts an object into the database.\n  // Returns a promise that resolves successfully iff the object saved.\n  create(\n    className: string,\n    object: any,\n    { acl }: QueryOptions = {},\n    validateOnly: boolean = false,\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    try {\n      Utils.checkProhibitedKeywords(this.options, object);\n    } catch (error) {\n      return Promise.reject(new Parse.Error(Parse.Error.INVALID_KEY_NAME, error));\n    }\n    try {\n      const { validateFileUrlsInObject } = require('../FileUrlValidator');\n      validateFileUrlsInObject(object, this.options);\n    } catch (error) {\n      return Promise.reject(error instanceof Parse.Error ? error : new Parse.Error(Parse.Error.FILE_SAVE_ERROR, error.message || error));\n    }\n    // Make a copy of the object, so we don't mutate the incoming data.\n    const originalObject = object;\n    object = transformObjectACL(object);\n\n    convertEmailToLowercase(object, className, this.options);\n    convertUsernameToLowercase(object, className, this.options);\n    object.createdAt = { iso: object.createdAt, __type: 'Date' };\n    object.updatedAt = { iso: object.updatedAt, __type: 'Date' };\n\n    var isMaster = acl === undefined;\n    var aclGroup = acl || [];\n    const relationUpdates = this.collectRelationUpdates(className, null, object);\n\n    return this.validateClassName(className)\n      .then(() => this.loadSchemaIfNeeded(validSchemaController))\n      .then(schemaController => {\n        return (isMaster\n          ? Promise.resolve()\n          : schemaController.validatePermission(className, aclGroup, 'create')\n        )\n          .then(() => schemaController.enforceClassExists(className))\n          .then(() => schemaController.getOneSchema(className, true))\n          .then(schema => {\n            transformAuthData(className, object, schema);\n            flattenUpdateOperatorsForCreate(object);\n            if (validateOnly) {\n              return {};\n            }\n            return this.adapter.createObject(\n              className,\n              SchemaController.convertSchemaToAdapterSchema(schema),\n              object,\n              this._transactionalSession\n            );\n          })\n          .then(result => {\n            if (validateOnly) {\n              return originalObject;\n            }\n            return this.handleRelationUpdates(\n              className,\n              object.objectId,\n              object,\n              relationUpdates\n            ).then(() => {\n              return this._sanitizeDatabaseResult(originalObject, result.ops[0]);\n            });\n          });\n      });\n  }\n\n  canAddField(\n    schema: SchemaController.SchemaController,\n    className: string,\n    object: any,\n    aclGroup: string[],\n    runOptions: QueryOptions\n  ): Promise<void> {\n    const classSchema = schema.schemaData[className];\n    if (!classSchema) {\n      return Promise.resolve();\n    }\n    const fields = Object.keys(object);\n    const schemaFields = Object.keys(classSchema.fields);\n    const newKeys = fields.filter(field => {\n      // Skip fields that are unset\n      if (object[field] && object[field].__op && object[field].__op === 'Delete') {\n        return false;\n      }\n      return schemaFields.indexOf(getRootFieldName(field)) < 0;\n    });\n    if (newKeys.length > 0) {\n      // adds a marker that new field is being adding during update\n      runOptions.addsField = true;\n\n      const action = runOptions.action;\n      return schema.validatePermission(className, aclGroup, 'addField', action);\n    }\n    return Promise.resolve();\n  }\n\n  // Won't delete collections in the system namespace\n  /**\n   * Delete all classes and clears the schema cache\n   *\n   * @param {boolean} fast set to true if it's ok to just delete rows and not indexes\n   * @returns {Promise<void>} when the deletions completes\n   */\n  deleteEverything(fast: boolean = false): Promise<any> {\n    this.schemaPromise = null;\n    SchemaCache.clear();\n    return this.adapter.deleteAllClasses(fast);\n  }\n\n  // Returns a promise for a list of related ids given an owning id.\n  // className here is the owning className.\n  relatedIds(\n    className: string,\n    key: string,\n    owningId: string,\n    queryOptions: QueryOptions\n  ): Promise<Array<string>> {\n    const { skip, limit, sort } = queryOptions;\n    const findOptions = {};\n    if (sort && sort.createdAt && this.adapter.canSortOnJoinTables) {\n      findOptions.sort = { _id: sort.createdAt };\n      findOptions.limit = limit;\n      findOptions.skip = skip;\n      queryOptions.skip = 0;\n    }\n    return this.adapter\n      .find(joinTableName(className, key), relationSchema, { owningId }, findOptions)\n      .then(results => results.map(result => result.relatedId));\n  }\n\n  // Returns a promise for a list of owning ids given some related ids.\n  // className here is the owning className.\n  owningIds(className: string, key: string, relatedIds: string[]): Promise<string[]> {\n    return this.adapter\n      .find(\n        joinTableName(className, key),\n        relationSchema,\n        { relatedId: { $in: relatedIds } },\n        { keys: ['owningId'] }\n      )\n      .then(results => results.map(result => result.owningId));\n  }\n\n  // Modifies query so that it no longer has $in on relation fields, or\n  // equal-to-pointer constraints on relation fields.\n  // Returns a promise that resolves when query is mutated\n  reduceInRelation(className: string, query: any, schema: any): Promise<any> {\n    // Search for an in-relation or equal-to-relation\n    // Make it sequential for now, not sure of paralleization side effects\n    const promises = [];\n    if (query['$or']) {\n      const ors = query['$or'];\n      promises.push(\n        ...ors.map((aQuery, index) => {\n          return this.reduceInRelation(className, aQuery, schema).then(aQuery => {\n            query['$or'][index] = aQuery;\n          });\n        })\n      );\n    }\n    if (query['$and']) {\n      const ands = query['$and'];\n      promises.push(\n        ...ands.map((aQuery, index) => {\n          return this.reduceInRelation(className, aQuery, schema).then(aQuery => {\n            query['$and'][index] = aQuery;\n          });\n        })\n      );\n    }\n\n    const otherKeys = Object.keys(query).map(key => {\n      if (key === '$and' || key === '$or') {\n        return;\n      }\n      const t = schema.getExpectedType(className, key);\n      if (!t || t.type !== 'Relation') {\n        return Promise.resolve(query);\n      }\n      let queries: ?(any[]) = null;\n      if (\n        query[key] &&\n        (query[key]['$in'] ||\n          query[key]['$ne'] ||\n          query[key]['$nin'] ||\n          query[key].__type == 'Pointer')\n      ) {\n        // Build the list of queries\n        queries = Object.keys(query[key]).map(constraintKey => {\n          let relatedIds;\n          let isNegation = false;\n          if (constraintKey === 'objectId') {\n            relatedIds = [query[key].objectId];\n          } else if (constraintKey == '$in') {\n            relatedIds = query[key]['$in'].map(r => r.objectId);\n          } else if (constraintKey == '$nin') {\n            isNegation = true;\n            relatedIds = query[key]['$nin'].map(r => r.objectId);\n          } else if (constraintKey == '$ne') {\n            isNegation = true;\n            relatedIds = [query[key]['$ne'].objectId];\n          } else {\n            return;\n          }\n          return {\n            isNegation,\n            relatedIds,\n          };\n        });\n      } else {\n        queries = [{ isNegation: false, relatedIds: [] }];\n      }\n\n      // remove the current queryKey as we don,t need it anymore\n      delete query[key];\n      // execute each query independently to build the list of\n      // $in / $nin\n      const promises = queries.map(q => {\n        if (!q) {\n          return Promise.resolve();\n        }\n        return this.owningIds(className, key, q.relatedIds).then(ids => {\n          if (q.isNegation) {\n            this.addNotInObjectIdsIds(ids, query);\n          } else {\n            this.addInObjectIdsIds(ids, query);\n          }\n          return Promise.resolve();\n        });\n      });\n\n      return Promise.all(promises).then(() => {\n        return Promise.resolve();\n      });\n    });\n\n    return Promise.all([...promises, ...otherKeys]).then(() => {\n      return Promise.resolve(query);\n    });\n  }\n\n  // Modifies query so that it no longer has $relatedTo\n  // Returns a promise that resolves when query is mutated\n  reduceRelationKeys(className: string, query: any, queryOptions: any): ?Promise<void> {\n    if (query['$or']) {\n      return Promise.all(\n        query['$or'].map(aQuery => {\n          return this.reduceRelationKeys(className, aQuery, queryOptions);\n        })\n      );\n    }\n    if (query['$and']) {\n      return Promise.all(\n        query['$and'].map(aQuery => {\n          return this.reduceRelationKeys(className, aQuery, queryOptions);\n        })\n      );\n    }\n    var relatedTo = query['$relatedTo'];\n    if (relatedTo) {\n      return this.relatedIds(\n        relatedTo.object.className,\n        relatedTo.key,\n        relatedTo.object.objectId,\n        queryOptions\n      )\n        .then(ids => {\n          delete query['$relatedTo'];\n          this.addInObjectIdsIds(ids, query);\n          return this.reduceRelationKeys(className, query, queryOptions);\n        })\n        .then(() => {});\n    }\n  }\n\n  addInObjectIdsIds(ids: ?Array<string> = null, query: any) {\n    const idsFromString: ?Array<string> =\n      typeof query.objectId === 'string' ? [query.objectId] : null;\n    const idsFromEq: ?Array<string> =\n      query.objectId && query.objectId['$eq'] ? [query.objectId['$eq']] : null;\n    const idsFromIn: ?Array<string> =\n      query.objectId && query.objectId['$in'] ? query.objectId['$in'] : null;\n\n    // @flow-disable-next\n    const allIds: Array<Array<string>> = [idsFromString, idsFromEq, idsFromIn, ids].filter(\n      list => list !== null\n    );\n    const totalLength = allIds.reduce((memo, list) => memo + list.length, 0);\n\n    let idsIntersection = [];\n    if (totalLength > 125) {\n      idsIntersection = intersect.big(allIds);\n    } else {\n      idsIntersection = intersect(allIds);\n    }\n\n    // Need to make sure we don't clobber existing shorthand $eq constraints on objectId.\n    if (!('objectId' in query)) {\n      query.objectId = {\n        $in: undefined,\n      };\n    } else if (typeof query.objectId === 'string') {\n      query.objectId = {\n        $in: undefined,\n        $eq: query.objectId,\n      };\n    }\n    query.objectId['$in'] = idsIntersection;\n\n    return query;\n  }\n\n  addNotInObjectIdsIds(ids: string[] = [], query: any) {\n    const idsFromNin = query.objectId && query.objectId['$nin'] ? query.objectId['$nin'] : [];\n    let allIds = [...idsFromNin, ...ids].filter(list => list !== null);\n\n    // make a set and spread to remove duplicates\n    allIds = [...new Set(allIds)];\n\n    // Need to make sure we don't clobber existing shorthand $eq constraints on objectId.\n    if (!('objectId' in query)) {\n      query.objectId = {\n        $nin: undefined,\n      };\n    } else if (typeof query.objectId === 'string') {\n      query.objectId = {\n        $nin: undefined,\n        $eq: query.objectId,\n      };\n    }\n\n    query.objectId['$nin'] = allIds;\n    return query;\n  }\n\n  // Runs a query on the database.\n  // Returns a promise that resolves to a list of items.\n  // Options:\n  //   skip    number of results to skip.\n  //   limit   limit to this number of results.\n  //   sort    an object where keys are the fields to sort by.\n  //           the value is +1 for ascending, -1 for descending.\n  //   count   run a count instead of returning results.\n  //   acl     restrict this operation with an ACL for the provided array\n  //           of user objectIds and roles. acl: null means no user.\n  //           when this field is not present, don't do anything regarding ACLs.\n  //  caseInsensitive make string comparisons case insensitive\n  // TODO: make userIds not needed here. The db adapter shouldn't know\n  // anything about users, ideally. Then, improve the format of the ACL\n  // arg to work like the others.\n  find(\n    className: string,\n    query: any,\n    {\n      skip,\n      limit,\n      acl,\n      sort = {},\n      count,\n      keys,\n      op,\n      distinct,\n      pipeline,\n      readPreference,\n      hint,\n      caseInsensitive = false,\n      explain,\n      comment,\n    }: any = {},\n    auth: any = {},\n    validSchemaController: SchemaController.SchemaController\n  ): Promise<any> {\n    const isMaintenance = auth.isMaintenance;\n    const isMaster = acl === undefined || isMaintenance;\n    const aclGroup = acl || [];\n    op =\n      op || (typeof query.objectId == 'string' && Object.keys(query).length === 1 ? 'get' : 'find');\n    // Count operation if counting\n    op = count === true ? 'count' : op;\n\n    let classExists = true;\n    return this.loadSchemaIfNeeded(validSchemaController).then(schemaController => {\n      //Allow volatile classes if querying with Master (for _PushStatus)\n      //TODO: Move volatile classes concept into mongo adapter, postgres adapter shouldn't care\n      //that api.parse.com breaks when _PushStatus exists in mongo.\n      return schemaController\n        .getOneSchema(className, isMaster)\n        .catch(error => {\n          // Behavior for non-existent classes is kinda weird on Parse.com. Probably doesn't matter too much.\n          // For now, pretend the class exists but has no objects,\n          if (error === undefined) {\n            classExists = false;\n            return { fields: {} };\n          }\n          throw error;\n        })\n        .then(schema => {\n          // Parse.com treats queries on _created_at and _updated_at as if they were queries on createdAt and updatedAt,\n          // so duplicate that behavior here. If both are specified, the correct behavior to match Parse.com is to\n          // use the one that appears first in the sort list.\n          if (sort._created_at) {\n            sort.createdAt = sort._created_at;\n            delete sort._created_at;\n          }\n          if (sort._updated_at) {\n            sort.updatedAt = sort._updated_at;\n            delete sort._updated_at;\n          }\n          const queryOptions = {\n            skip,\n            limit,\n            sort,\n            keys,\n            readPreference,\n            hint,\n            caseInsensitive: this.options.enableCollationCaseComparison ? false : caseInsensitive,\n            explain,\n            comment,\n          };\n          Object.keys(sort).forEach(fieldName => {\n            if (fieldName.match(/^authData\\.([a-zA-Z0-9_]+)\\.id$/)) {\n              throw new Parse.Error(Parse.Error.INVALID_KEY_NAME, `Cannot sort by ${fieldName}`);\n            }\n            const rootFieldName = getRootFieldName(fieldName);\n            if (!SchemaController.fieldNameIsValid(rootFieldName, className)) {\n              throw new Parse.Error(\n                Parse.Error.INVALID_KEY_NAME,\n                `Invalid field name: ${fieldName}.`\n              );\n            }\n            if (!schema.fields[fieldName.split('.')[0]] && fieldName !== 'score') {\n              delete sort[fieldName];\n            }\n          });\n          return (isMaster\n            ? Promise.resolve()\n            : schemaController.validatePermission(className, aclGroup, op)\n          )\n            .then(() => this.reduceRelationKeys(className, query, queryOptions))\n            .then(() => this.reduceInRelation(className, query, schemaController))\n            .then(() => {\n              let protectedFields;\n              if (!isMaster) {\n                query = this.addPointerPermissions(\n                  schemaController,\n                  className,\n                  op,\n                  query,\n                  aclGroup\n                );\n                /* Don't use projections to optimize the protectedFields since the protectedFields\n                  based on pointer-permissions are determined after querying. The filtering can\n                  overwrite the protected fields. */\n                protectedFields = this.addProtectedFields(\n                  schemaController,\n                  className,\n                  query,\n                  aclGroup,\n                  auth,\n                  queryOptions\n                );\n              }\n              if (!query) {\n                if (op === 'get') {\n                  throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found.');\n                } else {\n                  return [];\n                }\n              }\n              if (!isMaster) {\n                if (op === 'update' || op === 'delete') {\n                  query = addWriteACL(query, aclGroup);\n                } else {\n                  query = addReadACL(query, aclGroup);\n                }\n              }\n              validateQuery(query, isMaster, isMaintenance, false, this.options);\n              if (count) {\n                if (!classExists) {\n                  return 0;\n                } else {\n                  return this.adapter.count(\n                    className,\n                    schema,\n                    query,\n                    readPreference,\n                    undefined,\n                    hint,\n                    comment\n                  );\n                }\n              } else if (distinct) {\n                if (!classExists) {\n                  return [];\n                } else {\n                  return this.adapter.distinct(className, schema, query, distinct);\n                }\n              } else if (pipeline) {\n                if (!classExists) {\n                  return [];\n                } else {\n                  return this.adapter.aggregate(\n                    className,\n                    schema,\n                    pipeline,\n                    readPreference,\n                    hint,\n                    explain,\n                    comment\n                  );\n                }\n              } else if (explain) {\n                return this.adapter.find(className, schema, query, queryOptions);\n              } else {\n                return this.adapter\n                  .find(className, schema, query, queryOptions)\n                  .then(objects =>\n                    objects.map(object => {\n                      object = untransformObjectACL(object);\n                      return filterSensitiveData(\n                        isMaster,\n                        isMaintenance,\n                        aclGroup,\n                        auth,\n                        op,\n                        schemaController,\n                        className,\n                        protectedFields,\n                        object\n                      );\n                    })\n                  )\n                  .catch(error => {\n                    if (error instanceof Parse.Error) {\n                      throw error;\n                    }\n                    const detailedMessage =\n                      typeof error === 'string'\n                        ? error\n                        : error?.message || 'An internal server error occurred';\n                    throw createSanitizedError(\n                      Parse.Error.INTERNAL_SERVER_ERROR,\n                      detailedMessage,\n                      this.options,\n                      'An internal server error occurred'\n                    );\n                  });\n              }\n            });\n        });\n    });\n  }\n\n  deleteSchema(className: string): Promise<void> {\n    let schemaController;\n    return this.loadSchema({ clearCache: true })\n      .then(s => {\n        schemaController = s;\n        return schemaController.getOneSchema(className, true);\n      })\n      .catch(error => {\n        if (error === undefined) {\n          return { fields: {} };\n        } else {\n          throw error;\n        }\n      })\n      .then((schema: any) => {\n        return this.collectionExists(className)\n          .then(() => this.adapter.count(className, { fields: {} }, null, '', false))\n          .then(count => {\n            if (count > 0) {\n              throw new Parse.Error(\n                255,\n                `Class ${className} is not empty, contains ${count} objects, cannot drop schema.`\n              );\n            }\n            return this.adapter.deleteClass(className);\n          })\n          .then(wasParseCollection => {\n            if (wasParseCollection) {\n              const relationFieldNames = Object.keys(schema.fields).filter(\n                fieldName => schema.fields[fieldName].type === 'Relation'\n              );\n              return Promise.all(\n                relationFieldNames.map(name =>\n                  this.adapter.deleteClass(joinTableName(className, name))\n                )\n              ).then(() => {\n                SchemaCache.del(className);\n                return schemaController.reloadData();\n              });\n            } else {\n              return Promise.resolve();\n            }\n          });\n      });\n  }\n\n  // This helps to create intermediate objects for simpler comparison of\n  // key value pairs used in query objects. Each key value pair will represented\n  // in a similar way to json\n  objectToEntriesStrings(query: any): Array<string> {\n    return Object.entries(query).map(a => a.map(s => JSON.stringify(s)).join(':'));\n  }\n\n  // Naive logic reducer for OR operations meant to be used only for pointer permissions.\n  reduceOrOperation(query: { $or: Array<any> }): any {\n    if (!query.$or) {\n      return query;\n    }\n    const queries = query.$or.map(q => this.objectToEntriesStrings(q));\n    let repeat = false;\n    do {\n      repeat = false;\n      for (let i = 0; i < queries.length - 1; i++) {\n        for (let j = i + 1; j < queries.length; j++) {\n          const [shorter, longer] = queries[i].length > queries[j].length ? [j, i] : [i, j];\n          const foundEntries = queries[shorter].reduce(\n            (acc, entry) => acc + (queries[longer].includes(entry) ? 1 : 0),\n            0\n          );\n          const shorterEntries = queries[shorter].length;\n          if (foundEntries === shorterEntries) {\n            // If the shorter query is completely contained in the longer one, we can strike\n            // out the longer query.\n            query.$or.splice(longer, 1);\n            queries.splice(longer, 1);\n            repeat = true;\n            break;\n          }\n        }\n      }\n    } while (repeat);\n    if (query.$or.length === 1) {\n      query = { ...query, ...query.$or[0] };\n      delete query.$or;\n    }\n    return query;\n  }\n\n  // Naive logic reducer for AND operations meant to be used only for pointer permissions.\n  reduceAndOperation(query: { $and: Array<any> }): any {\n    if (!query.$and) {\n      return query;\n    }\n    const queries = query.$and.map(q => this.objectToEntriesStrings(q));\n    let repeat = false;\n    do {\n      repeat = false;\n      for (let i = 0; i < queries.length - 1; i++) {\n        for (let j = i + 1; j < queries.length; j++) {\n          const [shorter, longer] = queries[i].length > queries[j].length ? [j, i] : [i, j];\n          const foundEntries = queries[shorter].reduce(\n            (acc, entry) => acc + (queries[longer].includes(entry) ? 1 : 0),\n            0\n          );\n          const shorterEntries = queries[shorter].length;\n          if (foundEntries === shorterEntries) {\n            // If the shorter query is completely contained in the longer one, we can strike\n            // out the shorter query.\n            query.$and.splice(shorter, 1);\n            queries.splice(shorter, 1);\n            repeat = true;\n            break;\n          }\n        }\n      }\n    } while (repeat);\n    if (query.$and.length === 1) {\n      query = { ...query, ...query.$and[0] };\n      delete query.$and;\n    }\n    return query;\n  }\n\n  // Constraints query using CLP's pointer permissions (PP) if any.\n  // 1. Etract the user id from caller's ACLgroup;\n  // 2. Exctract a list of field names that are PP for target collection and operation;\n  // 3. Constraint the original query so that each PP field must\n  // point to caller's id (or contain it in case of PP field being an array)\n  addPointerPermissions(\n    schema: SchemaController.SchemaController,\n    className: string,\n    operation: string,\n    query: any,\n    aclGroup: any[] = []\n  ): any {\n    // Check if class has public permission for operation\n    // If the BaseCLP pass, let go through\n    if (schema.testPermissionsForClassName(className, aclGroup, operation)) {\n      return query;\n    }\n    const perms = schema.getClassLevelPermissions(className);\n\n    const userACL = aclGroup.filter(acl => {\n      return acl.indexOf('role:') != 0 && acl != '*';\n    });\n\n    const groupKey =\n      ['get', 'find', 'count'].indexOf(operation) > -1 ? 'readUserFields' : 'writeUserFields';\n\n    const permFields = [];\n\n    if (perms[operation] && perms[operation].pointerFields) {\n      permFields.push(...perms[operation].pointerFields);\n    }\n\n    if (perms[groupKey]) {\n      for (const field of perms[groupKey]) {\n        if (!permFields.includes(field)) {\n          permFields.push(field);\n        }\n      }\n    }\n    // the ACL should have exactly 1 user\n    if (permFields.length > 0) {\n      // the ACL should have exactly 1 user\n      // No user set return undefined\n      // If the length is > 1, that means we didn't de-dupe users correctly\n      if (userACL.length != 1) {\n        return;\n      }\n      const userId = userACL[0];\n      const userPointer = {\n        __type: 'Pointer',\n        className: '_User',\n        objectId: userId,\n      };\n\n      const queries = permFields.map(key => {\n        const fieldDescriptor = schema.getExpectedType(className, key);\n        const fieldType =\n          fieldDescriptor &&\n          typeof fieldDescriptor === 'object' &&\n          Object.prototype.hasOwnProperty.call(fieldDescriptor, 'type')\n            ? fieldDescriptor.type\n            : null;\n\n        let queryClause;\n\n        if (fieldType === 'Pointer') {\n          // constraint for single pointer setup\n          queryClause = { [key]: userPointer };\n        } else if (fieldType === 'Array') {\n          // constraint for users-array setup\n          queryClause = { [key]: { $all: [userPointer] } };\n        } else if (fieldType === 'Object') {\n          // constraint for object setup\n          queryClause = { [key]: userPointer };\n        } else {\n          // This means that there is a CLP field of an unexpected type. This condition should not happen, which is\n          // why is being treated as an error.\n          throw Error(\n            `An unexpected condition occurred when resolving pointer permissions: ${className} ${key}`\n          );\n        }\n        // if we already have a constraint on the key, use the $and\n        if (Object.prototype.hasOwnProperty.call(query, key)) {\n          return this.reduceAndOperation({ $and: [queryClause, query] });\n        }\n        // otherwise just add the constaint\n        return Object.assign({}, query, queryClause);\n      });\n\n      return queries.length === 1 ? queries[0] : this.reduceOrOperation({ $or: queries });\n    } else {\n      return query;\n    }\n  }\n\n  addProtectedFields(\n    schema: SchemaController.SchemaController | any,\n    className: string,\n    query: any = {},\n    aclGroup: any[] = [],\n    auth: any = {},\n    queryOptions: FullQueryOptions = {}\n  ): null | string[] {\n    const perms =\n      schema && schema.getClassLevelPermissions\n        ? schema.getClassLevelPermissions(className)\n        : schema;\n    if (!perms) { return null; }\n\n    const protectedFields = perms.protectedFields;\n    if (!protectedFields) { return null; }\n\n    if (aclGroup.indexOf(query.objectId) > -1) { return null; }\n\n    // for queries where \"keys\" are set and do not include all 'userField':{field},\n    // we have to transparently include it, and then remove before returning to client\n    // Because if such key not projected the permission won't be enforced properly\n    // PS this is called when 'excludeKeys' already reduced to 'keys'\n    const preserveKeys = queryOptions.keys;\n\n    // these are keys that need to be included only\n    // to be able to apply protectedFields by pointer\n    // and then unset before returning to client (later in  filterSensitiveFields)\n    const serverOnlyKeys = [];\n\n    const authenticated = auth.user;\n\n    // map to allow check without array search\n    const roles = (auth.userRoles || []).reduce((acc, r) => {\n      acc[r] = protectedFields[r];\n      return acc;\n    }, {});\n\n    // array of sets of protected fields. separate item for each applicable criteria\n    const protectedKeysSets = [];\n\n    for (const key in protectedFields) {\n      // skip userFields\n      if (key.startsWith('userField:')) {\n        if (preserveKeys) {\n          const fieldName = key.substring(10);\n          if (!preserveKeys.includes(fieldName)) {\n            // 1. put it there temporarily\n            queryOptions.keys && queryOptions.keys.push(fieldName);\n            // 2. preserve it delete later\n            serverOnlyKeys.push(fieldName);\n          }\n        }\n        continue;\n      }\n\n      // add public tier\n      if (key === '*') {\n        protectedKeysSets.push(protectedFields[key]);\n        continue;\n      }\n\n      if (authenticated) {\n        if (key === 'authenticated') {\n          // for logged in users\n          protectedKeysSets.push(protectedFields[key]);\n          continue;\n        }\n\n        if (roles[key] && key.startsWith('role:')) {\n          // add applicable roles\n          protectedKeysSets.push(roles[key]);\n        }\n      }\n    }\n\n    // check if there's a rule for current user's id\n    if (authenticated) {\n      const userId = auth.user.id;\n      if (perms.protectedFields[userId]) {\n        protectedKeysSets.push(perms.protectedFields[userId]);\n      }\n    }\n\n    // preserve fields to be removed before sending response to client\n    if (serverOnlyKeys.length > 0) {\n      perms.protectedFields.temporaryKeys = serverOnlyKeys;\n    }\n\n    let protectedKeys = protectedKeysSets.reduce((acc, next) => {\n      if (next) {\n        acc.push(...next);\n      }\n      return acc;\n    }, []);\n\n    // intersect all sets of protectedFields\n    protectedKeysSets.forEach(fields => {\n      if (fields) {\n        protectedKeys = protectedKeys.filter(v => fields.includes(v));\n      }\n    });\n\n    return protectedKeys;\n  }\n\n  createTransactionalSession() {\n    return this.adapter.createTransactionalSession().then(transactionalSession => {\n      this._transactionalSession = transactionalSession;\n    });\n  }\n\n  commitTransactionalSession() {\n    if (!this._transactionalSession) {\n      throw new Error('There is no transactional session to commit');\n    }\n    return this.adapter.commitTransactionalSession(this._transactionalSession).then(() => {\n      this._transactionalSession = null;\n    });\n  }\n\n  abortTransactionalSession() {\n    if (!this._transactionalSession) {\n      throw new Error('There is no transactional session to abort');\n    }\n    return this.adapter.abortTransactionalSession(this._transactionalSession).then(() => {\n      this._transactionalSession = null;\n    });\n  }\n\n  // TODO: create indexes on first creation of a _User object. Otherwise it's impossible to\n  // have a Parse app without it having a _User collection.\n  async performInitialization() {\n    await this.adapter.performInitialization({\n      VolatileClassesSchemas: SchemaController.VolatileClassesSchemas,\n    });\n    const requiredUserFields = {\n      fields: {\n        ...SchemaController.defaultColumns._Default,\n        ...SchemaController.defaultColumns._User,\n      },\n    };\n    const requiredRoleFields = {\n      fields: {\n        ...SchemaController.defaultColumns._Default,\n        ...SchemaController.defaultColumns._Role,\n      },\n    };\n    const requiredIdempotencyFields = {\n      fields: {\n        ...SchemaController.defaultColumns._Default,\n        ...SchemaController.defaultColumns._Idempotency,\n      },\n    };\n    await this.loadSchema().then(schema => schema.enforceClassExists('_User'));\n    await this.loadSchema().then(schema => schema.enforceClassExists('_Role'));\n    await this.loadSchema().then(schema => schema.enforceClassExists('_Idempotency'));\n\n    const databaseOptions = this.options.databaseOptions || {};\n\n    if (databaseOptions.createIndexUserUsername !== false) {\n      await this.adapter.ensureUniqueness('_User', requiredUserFields, ['username']).catch(error => {\n        logger.warn('Unable to ensure uniqueness for usernames: ', error);\n        throw error;\n      });\n    }\n\n    if (!this.options.enableCollationCaseComparison) {\n      if (databaseOptions.createIndexUserUsernameCaseInsensitive !== false) {\n        await this.adapter\n          .ensureIndex('_User', requiredUserFields, ['username'], 'case_insensitive_username', true)\n          .catch(error => {\n            logger.warn('Unable to create case insensitive username index: ', error);\n            throw error;\n          });\n      }\n\n      if (databaseOptions.createIndexUserEmailCaseInsensitive !== false) {\n        await this.adapter\n          .ensureIndex('_User', requiredUserFields, ['email'], 'case_insensitive_email', true)\n          .catch(error => {\n            logger.warn('Unable to create case insensitive email index: ', error);\n            throw error;\n          });\n      }\n    }\n\n    if (databaseOptions.createIndexUserEmail !== false) {\n      await this.adapter.ensureUniqueness('_User', requiredUserFields, ['email']).catch(error => {\n        logger.warn('Unable to ensure uniqueness for user email addresses: ', error);\n        throw error;\n      });\n    }\n\n    if (databaseOptions.createIndexUserEmailVerifyToken !== false) {\n      await this.adapter\n        .ensureIndex('_User', requiredUserFields, ['_email_verify_token'], '_email_verify_token', false)\n        .catch(error => {\n          logger.warn('Unable to create index for email verification token: ', error);\n          throw error;\n        });\n    }\n\n    if (databaseOptions.createIndexUserPasswordResetToken !== false) {\n      await this.adapter\n        .ensureIndex('_User', requiredUserFields, ['_perishable_token'], '_perishable_token', false)\n        .catch(error => {\n          logger.warn('Unable to create index for password reset token: ', error);\n          throw error;\n        });\n    }\n\n    if (databaseOptions.createIndexRoleName !== false) {\n      await this.adapter.ensureUniqueness('_Role', requiredRoleFields, ['name']).catch(error => {\n        logger.warn('Unable to ensure uniqueness for role name: ', error);\n        throw error;\n      });\n    }\n\n    await this.adapter\n      .ensureUniqueness('_Idempotency', requiredIdempotencyFields, ['reqId'])\n      .catch(error => {\n        logger.warn('Unable to ensure uniqueness for idempotency request ID: ', error);\n        throw error;\n      });\n\n    const isMongoAdapter = this.adapter instanceof MongoStorageAdapter;\n    const isPostgresAdapter = this.adapter instanceof PostgresStorageAdapter;\n    if (isMongoAdapter || isPostgresAdapter) {\n      let options = {};\n      if (isMongoAdapter) {\n        options = {\n          ttl: 0,\n        };\n      } else if (isPostgresAdapter) {\n        options = this.idempotencyOptions;\n        options.setIdempotencyFunction = true;\n      }\n      await this.adapter\n        .ensureIndex('_Idempotency', requiredIdempotencyFields, ['expire'], 'ttl', false, options)\n        .catch(error => {\n          logger.warn('Unable to create TTL index for idempotency expire date: ', error);\n          throw error;\n        });\n    }\n    // Create unique indexes for authData providers to prevent race conditions\n    // during concurrent signups with the same authData\n    if (\n      databaseOptions.createIndexAuthDataUniqueness !== false &&\n      typeof this.adapter.ensureAuthDataUniqueness === 'function'\n    ) {\n      const authProviders = Object.keys(this.options.auth || {});\n      if (this.options.enableAnonymousUsers !== false) {\n        if (!authProviders.includes('anonymous')) {\n          authProviders.push('anonymous');\n        }\n      }\n      await Promise.all(\n        authProviders.map(provider =>\n          this.adapter.ensureAuthDataUniqueness(provider).catch(error => {\n            logger.warn(\n              `Unable to ensure uniqueness for auth data provider \"${provider}\": `,\n              error\n            );\n          })\n        )\n      );\n    }\n\n    await this.adapter.updateSchemaWithIndexes();\n  }\n\n  _expandResultOnKeyPath(object: any, key: string, value: any): any {\n    if (key.indexOf('.') < 0) {\n      object[key] = value[key];\n      return object;\n    }\n    const path = key.split('.');\n    const firstKey = path[0];\n    const nextPath = path.slice(1).join('.');\n\n    // Scan request data for denied keywords\n    if (this.options && this.options.requestKeywordDenylist) {\n      // Scan request data for denied keywords\n      for (const keyword of this.options.requestKeywordDenylist) {\n        const match = Utils.objectContainsKeyValue(\n          { [firstKey]: true, [nextPath]: true },\n          keyword.key,\n          true\n        );\n        if (match) {\n          throw new Parse.Error(\n            Parse.Error.INVALID_KEY_NAME,\n            `Prohibited keyword in request data: ${JSON.stringify(keyword)}.`\n          );\n        }\n      }\n    }\n\n    object[firstKey] = this._expandResultOnKeyPath(\n      object[firstKey] || {},\n      nextPath,\n      value[firstKey]\n    );\n    delete object[key];\n    return object;\n  }\n\n  _sanitizeDatabaseResult(originalObject: any, result: any): Promise<any> {\n    const response = {};\n    if (!result) {\n      return Promise.resolve(response);\n    }\n    Object.keys(originalObject).forEach(key => {\n      const keyUpdate = originalObject[key];\n      // determine if that was an op\n      if (\n        keyUpdate &&\n        typeof keyUpdate === 'object' &&\n        keyUpdate.__op &&\n        ['Add', 'AddUnique', 'Remove', 'Increment', 'SetOnInsert'].indexOf(keyUpdate.__op) > -1\n      ) {\n        // only valid ops that produce an actionable result\n        // the op may have happened on a keypath\n        this._expandResultOnKeyPath(response, key, result);\n        // Revert array to object conversion on dot notation for arrays (e.g. \"field.0.key\")\n        if (key.includes('.')) {\n          const [field, index] = key.split('.');\n          const isArrayIndex = Array.from(index).every(c => c >= '0' && c <= '9');\n          if (isArrayIndex && Array.isArray(result[field]) && !Array.isArray(response[field])) {\n            response[field] = result[field];\n          }\n        }\n      }\n    });\n    return Promise.resolve(response);\n  }\n\n  static _validateQuery: (any, boolean, boolean, boolean) => void;\n  static filterSensitiveData: (boolean, boolean, any[], any, any, any, string, any[], any) => void;\n}\n\nmodule.exports = DatabaseController;\n// Expose validateQuery for tests\nmodule.exports._validateQuery = validateQuery;\nmodule.exports.filterSensitiveData = filterSensitiveData;\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.6.0-alpha.29",
3
+ "version": "9.6.0-alpha.30",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {