parse-server 4.10.6 → 4.10.9

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.
@@ -225,7 +225,7 @@ function getDatabaseController(options, cacheController) {
225
225
  databaseAdapter = (0, _AdapterLoader.loadAdapter)(databaseAdapter);
226
226
  }
227
227
 
228
- return new _DatabaseController.default(databaseAdapter, new _SchemaCache.default(cacheController, schemaCacheTTL, enableSingleSchemaCache));
228
+ return new _DatabaseController.default(databaseAdapter, new _SchemaCache.default(cacheController, schemaCacheTTL, enableSingleSchemaCache), options);
229
229
  }
230
230
 
231
231
  function getHooksController(options, databaseController) {
@@ -309,4 +309,4 @@ function getDatabaseAdapter(databaseURI, collectionPrefix, databaseOptions) {
309
309
  });
310
310
  }
311
311
  }
312
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/index.js"],"names":["getControllers","options","loggerController","getLoggerController","filesController","getFilesController","userController","getUserController","pushController","hasPushScheduledSupport","hasPushSupport","pushControllerQueue","pushWorker","getPushController","cacheController","getCacheController","analyticsController","getAnalyticsController","liveQueryController","getLiveQueryController","databaseController","getDatabaseController","hooksController","getHooksController","authDataManager","getAuthDataManager","parseGraphQLController","getParseGraphQLController","appId","jsonLogs","logsFolder","verbose","logLevel","maxLogFiles","silent","loggerAdapter","loggerOptions","loggerControllerAdapter","WinstonLoggerAdapter","LoggerController","databaseURI","filesAdapter","databaseAdapter","preserveFileName","fileKey","filesControllerAdapter","GridFSBucketAdapter","FilesController","emailAdapter","verifyUserEmails","emailControllerAdapter","UserController","cacheAdapter","cacheTTL","cacheMaxSize","cacheControllerAdapter","InMemoryCacheAdapter","ttl","maxSize","CacheController","controllerDeps","ParseGraphQLController","mountGraphQL","analyticsAdapter","analyticsControllerAdapter","AnalyticsAdapter","AnalyticsController","LiveQueryController","liveQuery","databaseOptions","collectionPrefix","schemaCacheTTL","enableSingleSchemaCache","defaults","getDatabaseAdapter","DatabaseController","SchemaCache","webhookKey","HooksController","scheduledPush","push","pushOptions","Object","assign","pushQueueOptions","queueOptions","pushAdapter","adapter","ParsePushAdapter","PushController","disablePushWorker","PushQueue","PushWorker","auth","enableAnonymousUsers","protocol","parsedURI","url","parse","toLowerCase","e","PostgresStorageAdapter","uri","MongoStorageAdapter","mongoOptions"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AAEO,SAASA,cAAT,CAAwBC,OAAxB,EAAqD;AAC1D,QAAMC,gBAAgB,GAAGC,mBAAmB,CAACF,OAAD,CAA5C;AACA,QAAMG,eAAe,GAAGC,kBAAkB,CAACJ,OAAD,CAA1C;AACA,QAAMK,cAAc,GAAGC,iBAAiB,CAACN,OAAD,CAAxC;AACA,QAAM;AACJO,IAAAA,cADI;AAEJC,IAAAA,uBAFI;AAGJC,IAAAA,cAHI;AAIJC,IAAAA,mBAJI;AAKJC,IAAAA;AALI,MAMFC,iBAAiB,CAACZ,OAAD,CANrB;AAOA,QAAMa,eAAe,GAAGC,kBAAkB,CAACd,OAAD,CAA1C;AACA,QAAMe,mBAAmB,GAAGC,sBAAsB,CAAChB,OAAD,CAAlD;AACA,QAAMiB,mBAAmB,GAAGC,sBAAsB,CAAClB,OAAD,CAAlD;AACA,QAAMmB,kBAAkB,GAAGC,qBAAqB,CAACpB,OAAD,EAAUa,eAAV,CAAhD;AACA,QAAMQ,eAAe,GAAGC,kBAAkB,CAACtB,OAAD,EAAUmB,kBAAV,CAA1C;AACA,QAAMI,eAAe,GAAGC,kBAAkB,CAACxB,OAAD,CAA1C;AACA,QAAMyB,sBAAsB,GAAGC,yBAAyB,CAAC1B,OAAD,EAAU;AAChEmB,IAAAA,kBADgE;AAEhEN,IAAAA;AAFgE,GAAV,CAAxD;AAIA,SAAO;AACLZ,IAAAA,gBADK;AAELE,IAAAA,eAFK;AAGLE,IAAAA,cAHK;AAILE,IAAAA,cAJK;AAKLC,IAAAA,uBALK;AAMLC,IAAAA,cANK;AAOLE,IAAAA,UAPK;AAQLD,IAAAA,mBARK;AASLK,IAAAA,mBATK;AAULF,IAAAA,eAVK;AAWLY,IAAAA,sBAXK;AAYLR,IAAAA,mBAZK;AAaLE,IAAAA,kBAbK;AAcLE,IAAAA,eAdK;AAeLE,IAAAA;AAfK,GAAP;AAiBD;;AAEM,SAASrB,mBAAT,CAA6BF,OAA7B,EAA4E;AACjF,QAAM;AACJ2B,IAAAA,KADI;AAEJC,IAAAA,QAFI;AAGJC,IAAAA,UAHI;AAIJC,IAAAA,OAJI;AAKJC,IAAAA,QALI;AAMJC,IAAAA,WANI;AAOJC,IAAAA,MAPI;AAQJC,IAAAA;AARI,MASFlC,OATJ;AAUA,QAAMmC,aAAa,GAAG;AACpBP,IAAAA,QADoB;AAEpBC,IAAAA,UAFoB;AAGpBC,IAAAA,OAHoB;AAIpBC,IAAAA,QAJoB;AAKpBE,IAAAA,MALoB;AAMpBD,IAAAA;AANoB,GAAtB;AAQA,QAAMI,uBAAuB,GAAG,gCAAYF,aAAZ,EAA2BG,0CAA3B,EAAiDF,aAAjD,CAAhC;AACA,SAAO,IAAIG,kCAAJ,CAAqBF,uBAArB,EAA8CT,KAA9C,EAAqDQ,aAArD,CAAP;AACD;;AAEM,SAAS/B,kBAAT,CAA4BJ,OAA5B,EAA0E;AAC/E,QAAM;AAAE2B,IAAAA,KAAF;AAASY,IAAAA,WAAT;AAAsBC,IAAAA,YAAtB;AAAoCC,IAAAA,eAApC;AAAqDC,IAAAA,gBAArD;AAAuEC,IAAAA;AAAvE,MAAmF3C,OAAzF;;AACA,MAAI,CAACwC,YAAD,IAAiBC,eAArB,EAAsC;AACpC,UAAM,sFAAN;AACD;;AACD,QAAMG,sBAAsB,GAAG,gCAAYJ,YAAZ,EAA0B,MAAM;AAC7D,WAAO,IAAIK,wCAAJ,CAAwBN,WAAxB,EAAqC,EAArC,EAAyCI,OAAzC,CAAP;AACD,GAF8B,CAA/B;AAGA,SAAO,IAAIG,gCAAJ,CAAoBF,sBAApB,EAA4CjB,KAA5C,EAAmD;AACxDe,IAAAA;AADwD,GAAnD,CAAP;AAGD;;AAEM,SAASpC,iBAAT,CAA2BN,OAA3B,EAAwE;AAC7E,QAAM;AAAE2B,IAAAA,KAAF;AAASoB,IAAAA,YAAT;AAAuBC,IAAAA;AAAvB,MAA4ChD,OAAlD;AACA,QAAMiD,sBAAsB,GAAG,gCAAYF,YAAZ,CAA/B;AACA,SAAO,IAAIG,8BAAJ,CAAmBD,sBAAnB,EAA2CtB,KAA3C,EAAkD;AACvDqB,IAAAA;AADuD,GAAlD,CAAP;AAGD;;AAEM,SAASlC,kBAAT,CAA4Bd,OAA5B,EAA0E;AAC/E,QAAM;AAAE2B,IAAAA,KAAF;AAASwB,IAAAA,YAAT;AAAuBC,IAAAA,QAAvB;AAAiCC,IAAAA;AAAjC,MAAkDrD,OAAxD;AACA,QAAMsD,sBAAsB,GAAG,gCAAYH,YAAZ,EAA0BI,0CAA1B,EAAgD;AAC7E5B,IAAAA,KAAK,EAAEA,KADsE;AAE7E6B,IAAAA,GAAG,EAAEJ,QAFwE;AAG7EK,IAAAA,OAAO,EAAEJ;AAHoE,GAAhD,CAA/B;AAKA,SAAO,IAAIK,gCAAJ,CAAoBJ,sBAApB,EAA4C3B,KAA5C,CAAP;AACD;;AAEM,SAASD,yBAAT,CACL1B,OADK,EAEL2D,cAFK,EAGmB;AACxB,SAAO,IAAIC,+BAAJ;AACLC,IAAAA,YAAY,EAAE7D,OAAO,CAAC6D;AADjB,KAEFF,cAFE,EAAP;AAID;;AAEM,SAAS3C,sBAAT,CAAgChB,OAAhC,EAAkF;AACvF,QAAM;AAAE8D,IAAAA;AAAF,MAAuB9D,OAA7B;AACA,QAAM+D,0BAA0B,GAAG,gCAAYD,gBAAZ,EAA8BE,kCAA9B,CAAnC;AACA,SAAO,IAAIC,wCAAJ,CAAwBF,0BAAxB,CAAP;AACD;;AAEM,SAAS7C,sBAAT,CAAgClB,OAAhC,EAAkF;AACvF,SAAO,IAAIkE,wCAAJ,CAAwBlE,OAAO,CAACmE,SAAhC,CAAP;AACD;;AAEM,SAAS/C,qBAAT,CACLpB,OADK,EAELa,eAFK,EAGe;AACpB,QAAM;AACJ0B,IAAAA,WADI;AAEJ6B,IAAAA,eAFI;AAGJC,IAAAA,gBAHI;AAIJC,IAAAA,cAJI;AAKJC,IAAAA;AALI,MAMFvE,OANJ;AAOA,MAAI;AAAEyC,IAAAA;AAAF,MAAsBzC,OAA1B;;AACA,MACE,CAACoE,eAAe,IACb7B,WAAW,IAAIA,WAAW,KAAKiC,kBAASjC,WAD1C,IAEC8B,gBAAgB,KAAKG,kBAASH,gBAFhC,KAGA5B,eAJF,EAKE;AACA,UAAM,+FAAN;AACD,GAPD,MAOO,IAAI,CAACA,eAAL,EAAsB;AAC3BA,IAAAA,eAAe,GAAGgC,kBAAkB,CAAClC,WAAD,EAAc8B,gBAAd,EAAgCD,eAAhC,CAApC;AACD,GAFM,MAEA;AACL3B,IAAAA,eAAe,GAAG,gCAAYA,eAAZ,CAAlB;AACD;;AACD,SAAO,IAAIiC,2BAAJ,CACLjC,eADK,EAEL,IAAIkC,oBAAJ,CAAgB9D,eAAhB,EAAiCyD,cAAjC,EAAiDC,uBAAjD,CAFK,CAAP;AAID;;AAEM,SAASjD,kBAAT,CACLtB,OADK,EAELmB,kBAFK,EAGY;AACjB,QAAM;AAAEQ,IAAAA,KAAF;AAASiD,IAAAA;AAAT,MAAwB5E,OAA9B;AACA,SAAO,IAAI6E,gCAAJ,CAAoBlD,KAApB,EAA2BR,kBAA3B,EAA+CyD,UAA/C,CAAP;AACD;;AASM,SAAShE,iBAAT,CAA2BZ,OAA3B,EAAyE;AAC9E,QAAM;AAAE8E,IAAAA,aAAF;AAAiBC,IAAAA;AAAjB,MAA0B/E,OAAhC;AAEA,QAAMgF,WAAW,GAAGC,MAAM,CAACC,MAAP,CAAc,EAAd,EAAkBH,IAAlB,CAApB;AACA,QAAMI,gBAAgB,GAAGH,WAAW,CAACI,YAAZ,IAA4B,EAArD;;AACA,MAAIJ,WAAW,CAACI,YAAhB,EAA8B;AAC5B,WAAOJ,WAAW,CAACI,YAAnB;AACD,GAP6E,CAS9E;;;AACA,QAAMC,WAAW,GAAG,gCAClBL,WAAW,IAAIA,WAAW,CAACM,OADT,EAElBC,oBAFkB,EAGlBP,WAHkB,CAApB,CAV8E,CAe9E;AACA;;AACA,QAAMzE,cAAc,GAAG,IAAIiF,8BAAJ,EAAvB;AACA,QAAM/E,cAAc,GAAG,CAAC,EAAE4E,WAAW,IAAIN,IAAjB,CAAxB;AACA,QAAMvE,uBAAuB,GAAGC,cAAc,IAAIqE,aAAa,KAAK,IAApE;AAEA,QAAM;AAAEW,IAAAA;AAAF,MAAwBN,gBAA9B;AAEA,QAAMzE,mBAAmB,GAAG,IAAIgF,oBAAJ,CAAcP,gBAAd,CAA5B;AACA,MAAIxE,UAAJ;;AACA,MAAI,CAAC8E,iBAAL,EAAwB;AACtB9E,IAAAA,UAAU,GAAG,IAAIgF,sBAAJ,CAAeN,WAAf,EAA4BF,gBAA5B,CAAb;AACD;;AACD,SAAO;AACL5E,IAAAA,cADK;AAELE,IAAAA,cAFK;AAGLD,IAAAA,uBAHK;AAILE,IAAAA,mBAJK;AAKLC,IAAAA;AALK,GAAP;AAOD;;AAEM,SAASa,kBAAT,CAA4BxB,OAA5B,EAAyD;AAC9D,QAAM;AAAE4F,IAAAA,IAAF;AAAQC,IAAAA;AAAR,MAAiC7F,OAAvC;AACA,SAAO,mBAAgB4F,IAAhB,EAAsBC,oBAAtB,CAAP;AACD;;AAEM,SAASpB,kBAAT,CAA4BlC,WAA5B,EAAyC8B,gBAAzC,EAA2DD,eAA3D,EAA4E;AACjF,MAAI0B,QAAJ;;AACA,MAAI;AACF,UAAMC,SAAS,GAAGC,aAAIC,KAAJ,CAAU1D,WAAV,CAAlB;;AACAuD,IAAAA,QAAQ,GAAGC,SAAS,CAACD,QAAV,GAAqBC,SAAS,CAACD,QAAV,CAAmBI,WAAnB,EAArB,GAAwD,IAAnE;AACD,GAHD,CAGE,OAAOC,CAAP,EAAU;AACV;AACD;;AACD,UAAQL,QAAR;AACE,SAAK,WAAL;AACE,aAAO,IAAIM,+BAAJ,CAA2B;AAChCC,QAAAA,GAAG,EAAE9D,WAD2B;AAEhC8B,QAAAA,gBAFgC;AAGhCD,QAAAA;AAHgC,OAA3B,CAAP;;AAKF;AACE,aAAO,IAAIkC,4BAAJ,CAAwB;AAC7BD,QAAAA,GAAG,EAAE9D,WADwB;AAE7B8B,QAAAA,gBAF6B;AAG7BkC,QAAAA,YAAY,EAAEnC;AAHe,OAAxB,CAAP;AARJ;AAcD","sourcesContent":["import authDataManager from '../Adapters/Auth';\nimport { ParseServerOptions } from '../Options';\nimport { loadAdapter } from '../Adapters/AdapterLoader';\nimport defaults from '../defaults';\nimport url from 'url';\n// Controllers\nimport { LoggerController } from './LoggerController';\nimport { FilesController } from './FilesController';\nimport { HooksController } from './HooksController';\nimport { UserController } from './UserController';\nimport { CacheController } from './CacheController';\nimport { LiveQueryController } from './LiveQueryController';\nimport { AnalyticsController } from './AnalyticsController';\nimport { PushController } from './PushController';\nimport { PushQueue } from '../Push/PushQueue';\nimport { PushWorker } from '../Push/PushWorker';\nimport DatabaseController from './DatabaseController';\nimport SchemaCache from './SchemaCache';\n\n// Adapters\nimport { GridFSBucketAdapter } from '../Adapters/Files/GridFSBucketAdapter';\nimport { WinstonLoggerAdapter } from '../Adapters/Logger/WinstonLoggerAdapter';\nimport { InMemoryCacheAdapter } from '../Adapters/Cache/InMemoryCacheAdapter';\nimport { AnalyticsAdapter } from '../Adapters/Analytics/AnalyticsAdapter';\nimport MongoStorageAdapter from '../Adapters/Storage/Mongo/MongoStorageAdapter';\nimport PostgresStorageAdapter from '../Adapters/Storage/Postgres/PostgresStorageAdapter';\nimport ParsePushAdapter from '@parse/push-adapter';\nimport ParseGraphQLController from './ParseGraphQLController';\n\nexport function getControllers(options: ParseServerOptions) {\n  const loggerController = getLoggerController(options);\n  const filesController = getFilesController(options);\n  const userController = getUserController(options);\n  const {\n    pushController,\n    hasPushScheduledSupport,\n    hasPushSupport,\n    pushControllerQueue,\n    pushWorker,\n  } = getPushController(options);\n  const cacheController = getCacheController(options);\n  const analyticsController = getAnalyticsController(options);\n  const liveQueryController = getLiveQueryController(options);\n  const databaseController = getDatabaseController(options, cacheController);\n  const hooksController = getHooksController(options, databaseController);\n  const authDataManager = getAuthDataManager(options);\n  const parseGraphQLController = getParseGraphQLController(options, {\n    databaseController,\n    cacheController,\n  });\n  return {\n    loggerController,\n    filesController,\n    userController,\n    pushController,\n    hasPushScheduledSupport,\n    hasPushSupport,\n    pushWorker,\n    pushControllerQueue,\n    analyticsController,\n    cacheController,\n    parseGraphQLController,\n    liveQueryController,\n    databaseController,\n    hooksController,\n    authDataManager,\n  };\n}\n\nexport function getLoggerController(options: ParseServerOptions): LoggerController {\n  const {\n    appId,\n    jsonLogs,\n    logsFolder,\n    verbose,\n    logLevel,\n    maxLogFiles,\n    silent,\n    loggerAdapter,\n  } = options;\n  const loggerOptions = {\n    jsonLogs,\n    logsFolder,\n    verbose,\n    logLevel,\n    silent,\n    maxLogFiles,\n  };\n  const loggerControllerAdapter = loadAdapter(loggerAdapter, WinstonLoggerAdapter, loggerOptions);\n  return new LoggerController(loggerControllerAdapter, appId, loggerOptions);\n}\n\nexport function getFilesController(options: ParseServerOptions): FilesController {\n  const { appId, databaseURI, filesAdapter, databaseAdapter, preserveFileName, fileKey } = options;\n  if (!filesAdapter && databaseAdapter) {\n    throw 'When using an explicit database adapter, you must also use an explicit filesAdapter.';\n  }\n  const filesControllerAdapter = loadAdapter(filesAdapter, () => {\n    return new GridFSBucketAdapter(databaseURI, {}, fileKey);\n  });\n  return new FilesController(filesControllerAdapter, appId, {\n    preserveFileName,\n  });\n}\n\nexport function getUserController(options: ParseServerOptions): UserController {\n  const { appId, emailAdapter, verifyUserEmails } = options;\n  const emailControllerAdapter = loadAdapter(emailAdapter);\n  return new UserController(emailControllerAdapter, appId, {\n    verifyUserEmails,\n  });\n}\n\nexport function getCacheController(options: ParseServerOptions): CacheController {\n  const { appId, cacheAdapter, cacheTTL, cacheMaxSize } = options;\n  const cacheControllerAdapter = loadAdapter(cacheAdapter, InMemoryCacheAdapter, {\n    appId: appId,\n    ttl: cacheTTL,\n    maxSize: cacheMaxSize,\n  });\n  return new CacheController(cacheControllerAdapter, appId);\n}\n\nexport function getParseGraphQLController(\n  options: ParseServerOptions,\n  controllerDeps\n): ParseGraphQLController {\n  return new ParseGraphQLController({\n    mountGraphQL: options.mountGraphQL,\n    ...controllerDeps,\n  });\n}\n\nexport function getAnalyticsController(options: ParseServerOptions): AnalyticsController {\n  const { analyticsAdapter } = options;\n  const analyticsControllerAdapter = loadAdapter(analyticsAdapter, AnalyticsAdapter);\n  return new AnalyticsController(analyticsControllerAdapter);\n}\n\nexport function getLiveQueryController(options: ParseServerOptions): LiveQueryController {\n  return new LiveQueryController(options.liveQuery);\n}\n\nexport function getDatabaseController(\n  options: ParseServerOptions,\n  cacheController: CacheController\n): DatabaseController {\n  const {\n    databaseURI,\n    databaseOptions,\n    collectionPrefix,\n    schemaCacheTTL,\n    enableSingleSchemaCache,\n  } = options;\n  let { databaseAdapter } = options;\n  if (\n    (databaseOptions ||\n      (databaseURI && databaseURI !== defaults.databaseURI) ||\n      collectionPrefix !== defaults.collectionPrefix) &&\n    databaseAdapter\n  ) {\n    throw 'You cannot specify both a databaseAdapter and a databaseURI/databaseOptions/collectionPrefix.';\n  } else if (!databaseAdapter) {\n    databaseAdapter = getDatabaseAdapter(databaseURI, collectionPrefix, databaseOptions);\n  } else {\n    databaseAdapter = loadAdapter(databaseAdapter);\n  }\n  return new DatabaseController(\n    databaseAdapter,\n    new SchemaCache(cacheController, schemaCacheTTL, enableSingleSchemaCache)\n  );\n}\n\nexport function getHooksController(\n  options: ParseServerOptions,\n  databaseController: DatabaseController\n): HooksController {\n  const { appId, webhookKey } = options;\n  return new HooksController(appId, databaseController, webhookKey);\n}\n\ninterface PushControlling {\n  pushController: PushController;\n  hasPushScheduledSupport: boolean;\n  pushControllerQueue: PushQueue;\n  pushWorker: PushWorker;\n}\n\nexport function getPushController(options: ParseServerOptions): PushControlling {\n  const { scheduledPush, push } = options;\n\n  const pushOptions = Object.assign({}, push);\n  const pushQueueOptions = pushOptions.queueOptions || {};\n  if (pushOptions.queueOptions) {\n    delete pushOptions.queueOptions;\n  }\n\n  // Pass the push options too as it works with the default\n  const pushAdapter = loadAdapter(\n    pushOptions && pushOptions.adapter,\n    ParsePushAdapter,\n    pushOptions\n  );\n  // We pass the options and the base class for the adatper,\n  // Note that passing an instance would work too\n  const pushController = new PushController();\n  const hasPushSupport = !!(pushAdapter && push);\n  const hasPushScheduledSupport = hasPushSupport && scheduledPush === true;\n\n  const { disablePushWorker } = pushQueueOptions;\n\n  const pushControllerQueue = new PushQueue(pushQueueOptions);\n  let pushWorker;\n  if (!disablePushWorker) {\n    pushWorker = new PushWorker(pushAdapter, pushQueueOptions);\n  }\n  return {\n    pushController,\n    hasPushSupport,\n    hasPushScheduledSupport,\n    pushControllerQueue,\n    pushWorker,\n  };\n}\n\nexport function getAuthDataManager(options: ParseServerOptions) {\n  const { auth, enableAnonymousUsers } = options;\n  return authDataManager(auth, enableAnonymousUsers);\n}\n\nexport function getDatabaseAdapter(databaseURI, collectionPrefix, databaseOptions) {\n  let protocol;\n  try {\n    const parsedURI = url.parse(databaseURI);\n    protocol = parsedURI.protocol ? parsedURI.protocol.toLowerCase() : null;\n  } catch (e) {\n    /* */\n  }\n  switch (protocol) {\n    case 'postgres:':\n      return new PostgresStorageAdapter({\n        uri: databaseURI,\n        collectionPrefix,\n        databaseOptions,\n      });\n    default:\n      return new MongoStorageAdapter({\n        uri: databaseURI,\n        collectionPrefix,\n        mongoOptions: databaseOptions,\n      });\n  }\n}\n"]}
312
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Controllers/index.js"],"names":["getControllers","options","loggerController","getLoggerController","filesController","getFilesController","userController","getUserController","pushController","hasPushScheduledSupport","hasPushSupport","pushControllerQueue","pushWorker","getPushController","cacheController","getCacheController","analyticsController","getAnalyticsController","liveQueryController","getLiveQueryController","databaseController","getDatabaseController","hooksController","getHooksController","authDataManager","getAuthDataManager","parseGraphQLController","getParseGraphQLController","appId","jsonLogs","logsFolder","verbose","logLevel","maxLogFiles","silent","loggerAdapter","loggerOptions","loggerControllerAdapter","WinstonLoggerAdapter","LoggerController","databaseURI","filesAdapter","databaseAdapter","preserveFileName","fileKey","filesControllerAdapter","GridFSBucketAdapter","FilesController","emailAdapter","verifyUserEmails","emailControllerAdapter","UserController","cacheAdapter","cacheTTL","cacheMaxSize","cacheControllerAdapter","InMemoryCacheAdapter","ttl","maxSize","CacheController","controllerDeps","ParseGraphQLController","mountGraphQL","analyticsAdapter","analyticsControllerAdapter","AnalyticsAdapter","AnalyticsController","LiveQueryController","liveQuery","databaseOptions","collectionPrefix","schemaCacheTTL","enableSingleSchemaCache","defaults","getDatabaseAdapter","DatabaseController","SchemaCache","webhookKey","HooksController","scheduledPush","push","pushOptions","Object","assign","pushQueueOptions","queueOptions","pushAdapter","adapter","ParsePushAdapter","PushController","disablePushWorker","PushQueue","PushWorker","auth","enableAnonymousUsers","protocol","parsedURI","url","parse","toLowerCase","e","PostgresStorageAdapter","uri","MongoStorageAdapter","mongoOptions"],"mappings":"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","sourcesContent":["import authDataManager from '../Adapters/Auth';\nimport { ParseServerOptions } from '../Options';\nimport { loadAdapter } from '../Adapters/AdapterLoader';\nimport defaults from '../defaults';\nimport url from 'url';\n// Controllers\nimport { LoggerController } from './LoggerController';\nimport { FilesController } from './FilesController';\nimport { HooksController } from './HooksController';\nimport { UserController } from './UserController';\nimport { CacheController } from './CacheController';\nimport { LiveQueryController } from './LiveQueryController';\nimport { AnalyticsController } from './AnalyticsController';\nimport { PushController } from './PushController';\nimport { PushQueue } from '../Push/PushQueue';\nimport { PushWorker } from '../Push/PushWorker';\nimport DatabaseController from './DatabaseController';\nimport SchemaCache from './SchemaCache';\n\n// Adapters\nimport { GridFSBucketAdapter } from '../Adapters/Files/GridFSBucketAdapter';\nimport { WinstonLoggerAdapter } from '../Adapters/Logger/WinstonLoggerAdapter';\nimport { InMemoryCacheAdapter } from '../Adapters/Cache/InMemoryCacheAdapter';\nimport { AnalyticsAdapter } from '../Adapters/Analytics/AnalyticsAdapter';\nimport MongoStorageAdapter from '../Adapters/Storage/Mongo/MongoStorageAdapter';\nimport PostgresStorageAdapter from '../Adapters/Storage/Postgres/PostgresStorageAdapter';\nimport ParsePushAdapter from '@parse/push-adapter';\nimport ParseGraphQLController from './ParseGraphQLController';\n\nexport function getControllers(options: ParseServerOptions) {\n  const loggerController = getLoggerController(options);\n  const filesController = getFilesController(options);\n  const userController = getUserController(options);\n  const {\n    pushController,\n    hasPushScheduledSupport,\n    hasPushSupport,\n    pushControllerQueue,\n    pushWorker,\n  } = getPushController(options);\n  const cacheController = getCacheController(options);\n  const analyticsController = getAnalyticsController(options);\n  const liveQueryController = getLiveQueryController(options);\n  const databaseController = getDatabaseController(options, cacheController);\n  const hooksController = getHooksController(options, databaseController);\n  const authDataManager = getAuthDataManager(options);\n  const parseGraphQLController = getParseGraphQLController(options, {\n    databaseController,\n    cacheController,\n  });\n  return {\n    loggerController,\n    filesController,\n    userController,\n    pushController,\n    hasPushScheduledSupport,\n    hasPushSupport,\n    pushWorker,\n    pushControllerQueue,\n    analyticsController,\n    cacheController,\n    parseGraphQLController,\n    liveQueryController,\n    databaseController,\n    hooksController,\n    authDataManager,\n  };\n}\n\nexport function getLoggerController(options: ParseServerOptions): LoggerController {\n  const {\n    appId,\n    jsonLogs,\n    logsFolder,\n    verbose,\n    logLevel,\n    maxLogFiles,\n    silent,\n    loggerAdapter,\n  } = options;\n  const loggerOptions = {\n    jsonLogs,\n    logsFolder,\n    verbose,\n    logLevel,\n    silent,\n    maxLogFiles,\n  };\n  const loggerControllerAdapter = loadAdapter(loggerAdapter, WinstonLoggerAdapter, loggerOptions);\n  return new LoggerController(loggerControllerAdapter, appId, loggerOptions);\n}\n\nexport function getFilesController(options: ParseServerOptions): FilesController {\n  const { appId, databaseURI, filesAdapter, databaseAdapter, preserveFileName, fileKey } = options;\n  if (!filesAdapter && databaseAdapter) {\n    throw 'When using an explicit database adapter, you must also use an explicit filesAdapter.';\n  }\n  const filesControllerAdapter = loadAdapter(filesAdapter, () => {\n    return new GridFSBucketAdapter(databaseURI, {}, fileKey);\n  });\n  return new FilesController(filesControllerAdapter, appId, {\n    preserveFileName,\n  });\n}\n\nexport function getUserController(options: ParseServerOptions): UserController {\n  const { appId, emailAdapter, verifyUserEmails } = options;\n  const emailControllerAdapter = loadAdapter(emailAdapter);\n  return new UserController(emailControllerAdapter, appId, {\n    verifyUserEmails,\n  });\n}\n\nexport function getCacheController(options: ParseServerOptions): CacheController {\n  const { appId, cacheAdapter, cacheTTL, cacheMaxSize } = options;\n  const cacheControllerAdapter = loadAdapter(cacheAdapter, InMemoryCacheAdapter, {\n    appId: appId,\n    ttl: cacheTTL,\n    maxSize: cacheMaxSize,\n  });\n  return new CacheController(cacheControllerAdapter, appId);\n}\n\nexport function getParseGraphQLController(\n  options: ParseServerOptions,\n  controllerDeps\n): ParseGraphQLController {\n  return new ParseGraphQLController({\n    mountGraphQL: options.mountGraphQL,\n    ...controllerDeps,\n  });\n}\n\nexport function getAnalyticsController(options: ParseServerOptions): AnalyticsController {\n  const { analyticsAdapter } = options;\n  const analyticsControllerAdapter = loadAdapter(analyticsAdapter, AnalyticsAdapter);\n  return new AnalyticsController(analyticsControllerAdapter);\n}\n\nexport function getLiveQueryController(options: ParseServerOptions): LiveQueryController {\n  return new LiveQueryController(options.liveQuery);\n}\n\nexport function getDatabaseController(\n  options: ParseServerOptions,\n  cacheController: CacheController\n): DatabaseController {\n  const {\n    databaseURI,\n    databaseOptions,\n    collectionPrefix,\n    schemaCacheTTL,\n    enableSingleSchemaCache,\n  } = options;\n  let { databaseAdapter } = options;\n  if (\n    (databaseOptions ||\n      (databaseURI && databaseURI !== defaults.databaseURI) ||\n      collectionPrefix !== defaults.collectionPrefix) &&\n    databaseAdapter\n  ) {\n    throw 'You cannot specify both a databaseAdapter and a databaseURI/databaseOptions/collectionPrefix.';\n  } else if (!databaseAdapter) {\n    databaseAdapter = getDatabaseAdapter(databaseURI, collectionPrefix, databaseOptions);\n  } else {\n    databaseAdapter = loadAdapter(databaseAdapter);\n  }\n  return new DatabaseController(\n    databaseAdapter,\n    new SchemaCache(cacheController, schemaCacheTTL, enableSingleSchemaCache),\n    options\n  );\n}\n\nexport function getHooksController(\n  options: ParseServerOptions,\n  databaseController: DatabaseController\n): HooksController {\n  const { appId, webhookKey } = options;\n  return new HooksController(appId, databaseController, webhookKey);\n}\n\ninterface PushControlling {\n  pushController: PushController;\n  hasPushScheduledSupport: boolean;\n  pushControllerQueue: PushQueue;\n  pushWorker: PushWorker;\n}\n\nexport function getPushController(options: ParseServerOptions): PushControlling {\n  const { scheduledPush, push } = options;\n\n  const pushOptions = Object.assign({}, push);\n  const pushQueueOptions = pushOptions.queueOptions || {};\n  if (pushOptions.queueOptions) {\n    delete pushOptions.queueOptions;\n  }\n\n  // Pass the push options too as it works with the default\n  const pushAdapter = loadAdapter(\n    pushOptions && pushOptions.adapter,\n    ParsePushAdapter,\n    pushOptions\n  );\n  // We pass the options and the base class for the adatper,\n  // Note that passing an instance would work too\n  const pushController = new PushController();\n  const hasPushSupport = !!(pushAdapter && push);\n  const hasPushScheduledSupport = hasPushSupport && scheduledPush === true;\n\n  const { disablePushWorker } = pushQueueOptions;\n\n  const pushControllerQueue = new PushQueue(pushQueueOptions);\n  let pushWorker;\n  if (!disablePushWorker) {\n    pushWorker = new PushWorker(pushAdapter, pushQueueOptions);\n  }\n  return {\n    pushController,\n    hasPushSupport,\n    hasPushScheduledSupport,\n    pushControllerQueue,\n    pushWorker,\n  };\n}\n\nexport function getAuthDataManager(options: ParseServerOptions) {\n  const { auth, enableAnonymousUsers } = options;\n  return authDataManager(auth, enableAnonymousUsers);\n}\n\nexport function getDatabaseAdapter(databaseURI, collectionPrefix, databaseOptions) {\n  let protocol;\n  try {\n    const parsedURI = url.parse(databaseURI);\n    protocol = parsedURI.protocol ? parsedURI.protocol.toLowerCase() : null;\n  } catch (e) {\n    /* */\n  }\n  switch (protocol) {\n    case 'postgres:':\n      return new PostgresStorageAdapter({\n        uri: databaseURI,\n        collectionPrefix,\n        databaseOptions,\n      });\n    default:\n      return new MongoStorageAdapter({\n        uri: databaseURI,\n        collectionPrefix,\n        mongoOptions: databaseOptions,\n      });\n  }\n}\n"]}
@@ -330,6 +330,19 @@ module.exports.ParseServerOptions = {
330
330
  env: 'PARSE_SERVER_READ_ONLY_MASTER_KEY',
331
331
  help: 'Read-only key, which has the same capabilities as MasterKey without writes'
332
332
  },
333
+ requestKeywordDenylist: {
334
+ env: 'PARSE_SERVER_REQUEST_KEYWORD_DENYLIST',
335
+ help: 'An array of keys and values that are prohibited in database read and write requests to prevent potential security vulnerabilities. It is possible to specify only a key (`{"key":"..."}`), only a value (`{"value":"..."}`) or a key-value pair (`{"key":"...","value":"..."}`). The specification can use the following types: `boolean`, `numeric` or `string`, where `string` will be interpreted as a regex notation. Request data is deep-scanned for matching definitions to detect also any nested occurrences. Defaults are patterns that are likely to be used in malicious requests. Setting this option will override the default patterns.',
336
+ action: parsers.arrayParser,
337
+ default: [{
338
+ key: '_bsontype',
339
+ value: 'Code'
340
+ }, {
341
+ key: 'constructor'
342
+ }, {
343
+ key: '__proto__'
344
+ }]
345
+ },
333
346
  restAPIKey: {
334
347
  env: 'PARSE_SERVER_REST_API_KEY',
335
348
  help: 'Key for REST calls'
@@ -581,4 +594,4 @@ module.exports.PasswordPolicyOptions = {
581
594
  help: 'a RegExp object or a regex string representing the pattern to enforce'
582
595
  }
583
596
  };
584
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Options/Definitions.js"],"names":["parsers","require","module","exports","ParseServerOptions","accountLockout","env","help","action","objectParser","allowClientClassCreation","booleanParser","default","allowCustomObjectId","allowHeaders","arrayParser","allowOrigin","analyticsAdapter","moduleOrObjectParser","appId","required","appName","auth","cacheAdapter","cacheMaxSize","numberParser","cacheTTL","clientKey","cloud","cluster","numberOrBooleanParser","collectionPrefix","customPages","databaseAdapter","databaseOptions","databaseURI","directAccess","dotNetKey","emailAdapter","emailVerifyTokenReuseIfValid","emailVerifyTokenValidityDuration","enableAnonymousUsers","enableExpressErrorHandler","enableSingleSchemaCache","encryptionKey","expireInactiveSessions","fileKey","filesAdapter","graphQLPath","graphQLSchema","host","idempotencyOptions","javascriptKey","jsonLogs","liveQuery","liveQueryServerOptions","loggerAdapter","logLevel","logsFolder","masterKey","masterKeyIps","maxLimit","maxLogFiles","maxUploadSize","middleware","mountGraphQL","mountPath","mountPlayground","objectIdSize","passwordPolicy","playgroundPath","port","preserveFileName","preventLoginWithUnverifiedEmail","protectedFields","_User","publicServerURL","push","readOnlyMasterKey","restAPIKey","revokeSessionOnPasswordReset","scheduledPush","schemaCacheTTL","serverCloseComplete","serverStartComplete","serverURL","sessionLength","silent","startLiveQueryServer","userSensitiveFields","verbose","verifyUserEmails","webhookKey","CustomPagesOptions","choosePassword","invalidLink","invalidVerificationLink","linkSendFail","linkSendSuccess","parseFrameURL","passwordResetSuccess","verifyEmailSuccess","LiveQueryOptions","classNames","pubSubAdapter","redisOptions","redisURL","wssAdapter","LiveQueryServerOptions","cacheTimeout","keyPairs","websocketTimeout","IdempotencyOptions","paths","ttl","AccountLockoutOptions","duration","threshold","PasswordPolicyOptions","doNotAllowUsername","maxPasswordAge","maxPasswordHistory","resetTokenReuseIfValid","resetTokenValidityDuration","validatorCallback","validatorPattern"],"mappings":"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","sourcesContent":["/*\n**** GENERATED CODE ****\nThis code has been generated by resources/buildConfigDefinitions.js\nDo not edit manually, but update Options/index.js\n*/\nvar parsers = require('./parsers');\n\nmodule.exports.ParseServerOptions = {\n  accountLockout: {\n    env: 'PARSE_SERVER_ACCOUNT_LOCKOUT',\n    help: 'account lockout policy for failed login attempts',\n    action: parsers.objectParser,\n  },\n  allowClientClassCreation: {\n    env: 'PARSE_SERVER_ALLOW_CLIENT_CLASS_CREATION',\n    help: 'Enable (or disable) client class creation, defaults to true',\n    action: parsers.booleanParser,\n    default: true,\n  },\n  allowCustomObjectId: {\n    env: 'PARSE_SERVER_ALLOW_CUSTOM_OBJECT_ID',\n    help: 'Enable (or disable) custom objectId',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  allowHeaders: {\n    env: 'PARSE_SERVER_ALLOW_HEADERS',\n    help: 'Add headers to Access-Control-Allow-Headers',\n    action: parsers.arrayParser,\n  },\n  allowOrigin: {\n    env: 'PARSE_SERVER_ALLOW_ORIGIN',\n    help: 'Sets the origin to Access-Control-Allow-Origin',\n  },\n  analyticsAdapter: {\n    env: 'PARSE_SERVER_ANALYTICS_ADAPTER',\n    help: 'Adapter module for the analytics',\n    action: parsers.moduleOrObjectParser,\n  },\n  appId: {\n    env: 'PARSE_SERVER_APPLICATION_ID',\n    help: 'Your Parse Application ID',\n    required: true,\n  },\n  appName: {\n    env: 'PARSE_SERVER_APP_NAME',\n    help: 'Sets the app name',\n  },\n  auth: {\n    env: 'PARSE_SERVER_AUTH_PROVIDERS',\n    help:\n      'Configuration for your authentication providers, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#oauth-and-3rd-party-authentication',\n    action: parsers.objectParser,\n  },\n  cacheAdapter: {\n    env: 'PARSE_SERVER_CACHE_ADAPTER',\n    help: 'Adapter module for the cache',\n    action: parsers.moduleOrObjectParser,\n  },\n  cacheMaxSize: {\n    env: 'PARSE_SERVER_CACHE_MAX_SIZE',\n    help: 'Sets the maximum size for the in memory cache, defaults to 10000',\n    action: parsers.numberParser('cacheMaxSize'),\n    default: 10000,\n  },\n  cacheTTL: {\n    env: 'PARSE_SERVER_CACHE_TTL',\n    help: 'Sets the TTL for the in memory cache (in ms), defaults to 5000 (5 seconds)',\n    action: parsers.numberParser('cacheTTL'),\n    default: 5000,\n  },\n  clientKey: {\n    env: 'PARSE_SERVER_CLIENT_KEY',\n    help: 'Key for iOS, MacOS, tvOS clients',\n  },\n  cloud: {\n    env: 'PARSE_SERVER_CLOUD',\n    help: 'Full path to your cloud code main.js',\n  },\n  cluster: {\n    env: 'PARSE_SERVER_CLUSTER',\n    help: 'Run with cluster, optionally set the number of processes default to os.cpus().length',\n    action: parsers.numberOrBooleanParser,\n  },\n  collectionPrefix: {\n    env: 'PARSE_SERVER_COLLECTION_PREFIX',\n    help: 'A collection prefix for the classes',\n    default: '',\n  },\n  customPages: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES',\n    help: 'custom pages for password validation and reset',\n    action: parsers.objectParser,\n    default: {},\n  },\n  databaseAdapter: {\n    env: 'PARSE_SERVER_DATABASE_ADAPTER',\n    help: 'Adapter module for the database',\n    action: parsers.moduleOrObjectParser,\n  },\n  databaseOptions: {\n    env: 'PARSE_SERVER_DATABASE_OPTIONS',\n    help: 'Options to pass to the mongodb client',\n    action: parsers.objectParser,\n  },\n  databaseURI: {\n    env: 'PARSE_SERVER_DATABASE_URI',\n    help: 'The full URI to your database. Supported databases are mongodb or postgres.',\n    required: true,\n    default: 'mongodb://localhost:27017/parse',\n  },\n  directAccess: {\n    env: 'PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS',\n    help:\n      'Replace HTTP Interface when using JS SDK in current node runtime, defaults to false. Caution, this is an experimental feature that may not be appropriate for production.',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  dotNetKey: {\n    env: 'PARSE_SERVER_DOT_NET_KEY',\n    help: 'Key for Unity and .Net SDK',\n  },\n  emailAdapter: {\n    env: 'PARSE_SERVER_EMAIL_ADAPTER',\n    help: 'Adapter module for email sending',\n    action: parsers.moduleOrObjectParser,\n  },\n  emailVerifyTokenReuseIfValid: {\n    env: 'PARSE_SERVER_EMAIL_VERIFY_TOKEN_REUSE_IF_VALID',\n    help:\n      'an existing email verify token should be reused when resend verification email is requested',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  emailVerifyTokenValidityDuration: {\n    env: 'PARSE_SERVER_EMAIL_VERIFY_TOKEN_VALIDITY_DURATION',\n    help: 'Email verification token validity duration, in seconds',\n    action: parsers.numberParser('emailVerifyTokenValidityDuration'),\n  },\n  enableAnonymousUsers: {\n    env: 'PARSE_SERVER_ENABLE_ANON_USERS',\n    help: 'Enable (or disable) anonymous users, defaults to true',\n    action: parsers.booleanParser,\n    default: true,\n  },\n  enableExpressErrorHandler: {\n    env: 'PARSE_SERVER_ENABLE_EXPRESS_ERROR_HANDLER',\n    help: 'Enables the default express error handler for all errors',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  enableSingleSchemaCache: {\n    env: 'PARSE_SERVER_ENABLE_SINGLE_SCHEMA_CACHE',\n    help:\n      'Use a single schema cache shared across requests. Reduces number of queries made to _SCHEMA, defaults to false, i.e. unique schema cache per request.',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  encryptionKey: {\n    env: 'PARSE_SERVER_ENCRYPTION_KEY',\n    help: 'Key for encrypting your files',\n  },\n  expireInactiveSessions: {\n    env: 'PARSE_SERVER_EXPIRE_INACTIVE_SESSIONS',\n    help: 'Sets wether we should expire the inactive sessions, defaults to true',\n    action: parsers.booleanParser,\n    default: true,\n  },\n  fileKey: {\n    env: 'PARSE_SERVER_FILE_KEY',\n    help: 'Key for your files',\n  },\n  filesAdapter: {\n    env: 'PARSE_SERVER_FILES_ADAPTER',\n    help: 'Adapter module for the files sub-system',\n    action: parsers.moduleOrObjectParser,\n  },\n  graphQLPath: {\n    env: 'PARSE_SERVER_GRAPHQL_PATH',\n    help: 'Mount path for the GraphQL endpoint, defaults to /graphql',\n    default: '/graphql',\n  },\n  graphQLSchema: {\n    env: 'PARSE_SERVER_GRAPH_QLSCHEMA',\n    help: 'Full path to your GraphQL custom schema.graphql file',\n  },\n  host: {\n    env: 'PARSE_SERVER_HOST',\n    help: 'The host to serve ParseServer on, defaults to 0.0.0.0',\n    default: '0.0.0.0',\n  },\n  idempotencyOptions: {\n    env: 'PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_OPTIONS',\n    help:\n      'Options for request idempotency to deduplicate identical requests that may be caused by network issues. Caution, this is an experimental feature that may not be appropriate for production.',\n    action: parsers.objectParser,\n    default: {},\n  },\n  javascriptKey: {\n    env: 'PARSE_SERVER_JAVASCRIPT_KEY',\n    help: 'Key for the Javascript SDK',\n  },\n  jsonLogs: {\n    env: 'JSON_LOGS',\n    help: 'Log as structured JSON objects',\n    action: parsers.booleanParser,\n  },\n  liveQuery: {\n    env: 'PARSE_SERVER_LIVE_QUERY',\n    help: \"parse-server's LiveQuery configuration object\",\n    action: parsers.objectParser,\n  },\n  liveQueryServerOptions: {\n    env: 'PARSE_SERVER_LIVE_QUERY_SERVER_OPTIONS',\n    help: 'Live query server configuration options (will start the liveQuery server)',\n    action: parsers.objectParser,\n  },\n  loggerAdapter: {\n    env: 'PARSE_SERVER_LOGGER_ADAPTER',\n    help: 'Adapter module for the logging sub-system',\n    action: parsers.moduleOrObjectParser,\n  },\n  logLevel: {\n    env: 'PARSE_SERVER_LOG_LEVEL',\n    help: 'Sets the level for logs',\n  },\n  logsFolder: {\n    env: 'PARSE_SERVER_LOGS_FOLDER',\n    help: \"Folder for the logs (defaults to './logs'); set to null to disable file based logging\",\n    default: './logs',\n  },\n  masterKey: {\n    env: 'PARSE_SERVER_MASTER_KEY',\n    help: 'Your Parse Master Key',\n    required: true,\n  },\n  masterKeyIps: {\n    env: 'PARSE_SERVER_MASTER_KEY_IPS',\n    help: 'Restrict masterKey to be used by only these ips, defaults to [] (allow all ips)',\n    action: parsers.arrayParser,\n    default: [],\n  },\n  maxLimit: {\n    env: 'PARSE_SERVER_MAX_LIMIT',\n    help: 'Max value for limit option on queries, defaults to unlimited',\n    action: parsers.numberParser('maxLimit'),\n  },\n  maxLogFiles: {\n    env: 'PARSE_SERVER_MAX_LOG_FILES',\n    help:\n      \"Maximum number of logs to keep. If not set, no logs will be removed. This can be a number of files or number of days. If using days, add 'd' as the suffix. (default: null)\",\n    action: parsers.objectParser,\n  },\n  maxUploadSize: {\n    env: 'PARSE_SERVER_MAX_UPLOAD_SIZE',\n    help: 'Max file size for uploads, defaults to 20mb',\n    default: '20mb',\n  },\n  middleware: {\n    env: 'PARSE_SERVER_MIDDLEWARE',\n    help: 'middleware for express server, can be string or function',\n  },\n  mountGraphQL: {\n    env: 'PARSE_SERVER_MOUNT_GRAPHQL',\n    help: 'Mounts the GraphQL endpoint',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  mountPath: {\n    env: 'PARSE_SERVER_MOUNT_PATH',\n    help: 'Mount path for the server, defaults to /parse',\n    default: '/parse',\n  },\n  mountPlayground: {\n    env: 'PARSE_SERVER_MOUNT_PLAYGROUND',\n    help: 'Mounts the GraphQL Playground - never use this option in production',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  objectIdSize: {\n    env: 'PARSE_SERVER_OBJECT_ID_SIZE',\n    help: \"Sets the number of characters in generated object id's, default 10\",\n    action: parsers.numberParser('objectIdSize'),\n    default: 10,\n  },\n  passwordPolicy: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY',\n    help: 'Password policy for enforcing password related rules',\n    action: parsers.objectParser,\n  },\n  playgroundPath: {\n    env: 'PARSE_SERVER_PLAYGROUND_PATH',\n    help: 'Mount path for the GraphQL Playground, defaults to /playground',\n    default: '/playground',\n  },\n  port: {\n    env: 'PORT',\n    help: 'The port to run the ParseServer, defaults to 1337.',\n    action: parsers.numberParser('port'),\n    default: 1337,\n  },\n  preserveFileName: {\n    env: 'PARSE_SERVER_PRESERVE_FILE_NAME',\n    help: 'Enable (or disable) the addition of a unique hash to the file names',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  preventLoginWithUnverifiedEmail: {\n    env: 'PARSE_SERVER_PREVENT_LOGIN_WITH_UNVERIFIED_EMAIL',\n    help:\n      'Prevent user from login if email is not verified and PARSE_SERVER_VERIFY_USER_EMAILS is true, defaults to false',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  protectedFields: {\n    env: 'PARSE_SERVER_PROTECTED_FIELDS',\n    help: 'Protected fields that should be treated with extra security when fetching details.',\n    action: parsers.objectParser,\n    default: {\n      _User: {\n        '*': ['email'],\n      },\n    },\n  },\n  publicServerURL: {\n    env: 'PARSE_PUBLIC_SERVER_URL',\n    help: 'Public URL to your parse server with http:// or https://.',\n  },\n  push: {\n    env: 'PARSE_SERVER_PUSH',\n    help:\n      'Configuration for push, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#push-notifications',\n    action: parsers.objectParser,\n  },\n  readOnlyMasterKey: {\n    env: 'PARSE_SERVER_READ_ONLY_MASTER_KEY',\n    help: 'Read-only key, which has the same capabilities as MasterKey without writes',\n  },\n  restAPIKey: {\n    env: 'PARSE_SERVER_REST_API_KEY',\n    help: 'Key for REST calls',\n  },\n  revokeSessionOnPasswordReset: {\n    env: 'PARSE_SERVER_REVOKE_SESSION_ON_PASSWORD_RESET',\n    help:\n      \"When a user changes their password, either through the reset password email or while logged in, all sessions are revoked if this is true. Set to false if you don't want to revoke sessions.\",\n    action: parsers.booleanParser,\n    default: true,\n  },\n  scheduledPush: {\n    env: 'PARSE_SERVER_SCHEDULED_PUSH',\n    help: 'Configuration for push scheduling, defaults to false.',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  schemaCacheTTL: {\n    env: 'PARSE_SERVER_SCHEMA_CACHE_TTL',\n    help:\n      'The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 5000; set 0 to disable.',\n    action: parsers.numberParser('schemaCacheTTL'),\n    default: 5000,\n  },\n  serverCloseComplete: {\n    env: 'PARSE_SERVER_SERVER_CLOSE_COMPLETE',\n    help: 'Callback when server has closed',\n  },\n  serverStartComplete: {\n    env: 'PARSE_SERVER_SERVER_START_COMPLETE',\n    help: 'Callback when server has started',\n  },\n  serverURL: {\n    env: 'PARSE_SERVER_URL',\n    help: 'URL to your parse server with http:// or https://.',\n    required: true,\n  },\n  sessionLength: {\n    env: 'PARSE_SERVER_SESSION_LENGTH',\n    help: 'Session duration, in seconds, defaults to 1 year',\n    action: parsers.numberParser('sessionLength'),\n    default: 31536000,\n  },\n  silent: {\n    env: 'SILENT',\n    help: 'Disables console output',\n    action: parsers.booleanParser,\n  },\n  startLiveQueryServer: {\n    env: 'PARSE_SERVER_START_LIVE_QUERY_SERVER',\n    help: 'Starts the liveQuery server',\n    action: parsers.booleanParser,\n  },\n  userSensitiveFields: {\n    env: 'PARSE_SERVER_USER_SENSITIVE_FIELDS',\n    help:\n      'Personally identifiable information fields in the user table the should be removed for non-authorized users. Deprecated @see protectedFields',\n    action: parsers.arrayParser,\n  },\n  verbose: {\n    env: 'VERBOSE',\n    help: 'Set the logging to verbose',\n    action: parsers.booleanParser,\n  },\n  verifyUserEmails: {\n    env: 'PARSE_SERVER_VERIFY_USER_EMAILS',\n    help: 'Enable (or disable) user email validation, defaults to false',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  webhookKey: {\n    env: 'PARSE_SERVER_WEBHOOK_KEY',\n    help: 'Key sent with outgoing webhook calls',\n  },\n};\nmodule.exports.CustomPagesOptions = {\n  choosePassword: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_CHOOSE_PASSWORD',\n    help: 'choose password page path',\n  },\n  invalidLink: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_INVALID_LINK',\n    help: 'invalid link page path',\n  },\n  invalidVerificationLink: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_INVALID_VERIFICATION_LINK',\n    help: 'invalid verification link page path',\n  },\n  linkSendFail: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_LINK_SEND_FAIL',\n    help: 'verification link send fail page path',\n  },\n  linkSendSuccess: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_LINK_SEND_SUCCESS',\n    help: 'verification link send success page path',\n  },\n  parseFrameURL: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_PARSE_FRAME_URL',\n    help: 'for masking user-facing pages',\n  },\n  passwordResetSuccess: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_PASSWORD_RESET_SUCCESS',\n    help: 'password reset success page path',\n  },\n  verifyEmailSuccess: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_VERIFY_EMAIL_SUCCESS',\n    help: 'verify email success page path',\n  },\n};\nmodule.exports.LiveQueryOptions = {\n  classNames: {\n    env: 'PARSE_SERVER_LIVEQUERY_CLASSNAMES',\n    help: \"parse-server's LiveQuery classNames\",\n    action: parsers.arrayParser,\n  },\n  pubSubAdapter: {\n    env: 'PARSE_SERVER_LIVEQUERY_PUB_SUB_ADAPTER',\n    help: 'LiveQuery pubsub adapter',\n    action: parsers.moduleOrObjectParser,\n  },\n  redisOptions: {\n    env: 'PARSE_SERVER_LIVEQUERY_REDIS_OPTIONS',\n    help: \"parse-server's LiveQuery redisOptions\",\n    action: parsers.objectParser,\n  },\n  redisURL: {\n    env: 'PARSE_SERVER_LIVEQUERY_REDIS_URL',\n    help: \"parse-server's LiveQuery redisURL\",\n  },\n  wssAdapter: {\n    env: 'PARSE_SERVER_LIVEQUERY_WSS_ADAPTER',\n    help: 'Adapter module for the WebSocketServer',\n    action: parsers.moduleOrObjectParser,\n  },\n};\nmodule.exports.LiveQueryServerOptions = {\n  appId: {\n    env: 'PARSE_LIVE_QUERY_SERVER_APP_ID',\n    help:\n      'This string should match the appId in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same appId.',\n  },\n  cacheTimeout: {\n    env: 'PARSE_LIVE_QUERY_SERVER_CACHE_TIMEOUT',\n    help:\n      \"Number in milliseconds. When clients provide the sessionToken to the LiveQuery server, the LiveQuery server will try to fetch its ParseUser's objectId from parse server and store it in the cache. The value defines the duration of the cache. Check the following Security section and our protocol specification for details, defaults to 5 * 1000 ms (5 seconds).\",\n    action: parsers.numberParser('cacheTimeout'),\n  },\n  keyPairs: {\n    env: 'PARSE_LIVE_QUERY_SERVER_KEY_PAIRS',\n    help:\n      'A JSON object that serves as a whitelist of keys. It is used for validating clients when they try to connect to the LiveQuery server. Check the following Security section and our protocol specification for details.',\n    action: parsers.objectParser,\n  },\n  logLevel: {\n    env: 'PARSE_LIVE_QUERY_SERVER_LOG_LEVEL',\n    help:\n      'This string defines the log level of the LiveQuery server. We support VERBOSE, INFO, ERROR, NONE, defaults to INFO.',\n  },\n  masterKey: {\n    env: 'PARSE_LIVE_QUERY_SERVER_MASTER_KEY',\n    help:\n      'This string should match the masterKey in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same masterKey.',\n  },\n  port: {\n    env: 'PARSE_LIVE_QUERY_SERVER_PORT',\n    help: 'The port to run the LiveQuery server, defaults to 1337.',\n    action: parsers.numberParser('port'),\n    default: 1337,\n  },\n  pubSubAdapter: {\n    env: 'PARSE_LIVE_QUERY_SERVER_PUB_SUB_ADAPTER',\n    help: 'LiveQuery pubsub adapter',\n    action: parsers.moduleOrObjectParser,\n  },\n  redisOptions: {\n    env: 'PARSE_LIVE_QUERY_SERVER_REDIS_OPTIONS',\n    help: \"parse-server's LiveQuery redisOptions\",\n    action: parsers.objectParser,\n  },\n  redisURL: {\n    env: 'PARSE_LIVE_QUERY_SERVER_REDIS_URL',\n    help: \"parse-server's LiveQuery redisURL\",\n  },\n  serverURL: {\n    env: 'PARSE_LIVE_QUERY_SERVER_SERVER_URL',\n    help:\n      'This string should match the serverURL in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same serverURL.',\n  },\n  websocketTimeout: {\n    env: 'PARSE_LIVE_QUERY_SERVER_WEBSOCKET_TIMEOUT',\n    help:\n      'Number of milliseconds between ping/pong frames. The WebSocket server sends ping/pong frames to the clients to keep the WebSocket alive. This value defines the interval of the ping/pong frame from the server to clients, defaults to 10 * 1000 ms (10 s).',\n    action: parsers.numberParser('websocketTimeout'),\n  },\n  wssAdapter: {\n    env: 'PARSE_LIVE_QUERY_SERVER_WSS_ADAPTER',\n    help: 'Adapter module for the WebSocketServer',\n    action: parsers.moduleOrObjectParser,\n  },\n};\nmodule.exports.IdempotencyOptions = {\n  paths: {\n    env: 'PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_PATHS',\n    help:\n      'An array of paths for which the feature should be enabled. The mount path must not be included, for example instead of `/parse/functions/myFunction` specifiy `functions/myFunction`. The entries are interpreted as regular expression, for example `functions/.*` matches all functions, `jobs/.*` matches all jobs, `classes/.*` matches all classes, `.*` matches all paths.',\n    action: parsers.arrayParser,\n    default: [],\n  },\n  ttl: {\n    env: 'PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_TTL',\n    help:\n      'The duration in seconds after which a request record is discarded from the database, defaults to 300s.',\n    action: parsers.numberParser('ttl'),\n    default: 300,\n  },\n};\nmodule.exports.AccountLockoutOptions = {\n  duration: {\n    env: 'PARSE_SERVER_ACCOUNT_LOCKOUT_DURATION',\n    help:\n      'number of minutes that a locked-out account remains locked out before automatically becoming unlocked.',\n    action: parsers.numberParser('duration'),\n  },\n  threshold: {\n    env: 'PARSE_SERVER_ACCOUNT_LOCKOUT_THRESHOLD',\n    help: 'number of failed sign-in attempts that will cause a user account to be locked',\n    action: parsers.numberParser('threshold'),\n  },\n};\nmodule.exports.PasswordPolicyOptions = {\n  doNotAllowUsername: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_DO_NOT_ALLOW_USERNAME',\n    help: 'disallow username in passwords',\n    action: parsers.booleanParser,\n  },\n  maxPasswordAge: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_MAX_PASSWORD_AGE',\n    help: 'days for password expiry',\n    action: parsers.numberParser('maxPasswordAge'),\n  },\n  maxPasswordHistory: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_MAX_PASSWORD_HISTORY',\n    help: 'setting to prevent reuse of previous n passwords',\n    action: parsers.numberParser('maxPasswordHistory'),\n  },\n  resetTokenReuseIfValid: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_RESET_TOKEN_REUSE_IF_VALID',\n    help: \"resend token if it's still valid\",\n    action: parsers.booleanParser,\n  },\n  resetTokenValidityDuration: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_RESET_TOKEN_VALIDITY_DURATION',\n    help: 'time for token to expire',\n    action: parsers.numberParser('resetTokenValidityDuration'),\n  },\n  validatorCallback: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_VALIDATOR_CALLBACK',\n    help: 'a callback function to be invoked to validate the password',\n  },\n  validatorPattern: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_VALIDATOR_PATTERN',\n    help: 'a RegExp object or a regex string representing the pattern to enforce',\n  },\n};\n"]}
597
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Options/Definitions.js"],"names":["parsers","require","module","exports","ParseServerOptions","accountLockout","env","help","action","objectParser","allowClientClassCreation","booleanParser","default","allowCustomObjectId","allowHeaders","arrayParser","allowOrigin","analyticsAdapter","moduleOrObjectParser","appId","required","appName","auth","cacheAdapter","cacheMaxSize","numberParser","cacheTTL","clientKey","cloud","cluster","numberOrBooleanParser","collectionPrefix","customPages","databaseAdapter","databaseOptions","databaseURI","directAccess","dotNetKey","emailAdapter","emailVerifyTokenReuseIfValid","emailVerifyTokenValidityDuration","enableAnonymousUsers","enableExpressErrorHandler","enableSingleSchemaCache","encryptionKey","expireInactiveSessions","fileKey","filesAdapter","graphQLPath","graphQLSchema","host","idempotencyOptions","javascriptKey","jsonLogs","liveQuery","liveQueryServerOptions","loggerAdapter","logLevel","logsFolder","masterKey","masterKeyIps","maxLimit","maxLogFiles","maxUploadSize","middleware","mountGraphQL","mountPath","mountPlayground","objectIdSize","passwordPolicy","playgroundPath","port","preserveFileName","preventLoginWithUnverifiedEmail","protectedFields","_User","publicServerURL","push","readOnlyMasterKey","requestKeywordDenylist","key","value","restAPIKey","revokeSessionOnPasswordReset","scheduledPush","schemaCacheTTL","serverCloseComplete","serverStartComplete","serverURL","sessionLength","silent","startLiveQueryServer","userSensitiveFields","verbose","verifyUserEmails","webhookKey","CustomPagesOptions","choosePassword","invalidLink","invalidVerificationLink","linkSendFail","linkSendSuccess","parseFrameURL","passwordResetSuccess","verifyEmailSuccess","LiveQueryOptions","classNames","pubSubAdapter","redisOptions","redisURL","wssAdapter","LiveQueryServerOptions","cacheTimeout","keyPairs","websocketTimeout","IdempotencyOptions","paths","ttl","AccountLockoutOptions","duration","threshold","PasswordPolicyOptions","doNotAllowUsername","maxPasswordAge","maxPasswordHistory","resetTokenReuseIfValid","resetTokenValidityDuration","validatorCallback","validatorPattern"],"mappings":"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","sourcesContent":["/*\n**** GENERATED CODE ****\nThis code has been generated by resources/buildConfigDefinitions.js\nDo not edit manually, but update Options/index.js\n*/\nvar parsers = require('./parsers');\n\nmodule.exports.ParseServerOptions = {\n  accountLockout: {\n    env: 'PARSE_SERVER_ACCOUNT_LOCKOUT',\n    help: 'account lockout policy for failed login attempts',\n    action: parsers.objectParser,\n  },\n  allowClientClassCreation: {\n    env: 'PARSE_SERVER_ALLOW_CLIENT_CLASS_CREATION',\n    help: 'Enable (or disable) client class creation, defaults to true',\n    action: parsers.booleanParser,\n    default: true,\n  },\n  allowCustomObjectId: {\n    env: 'PARSE_SERVER_ALLOW_CUSTOM_OBJECT_ID',\n    help: 'Enable (or disable) custom objectId',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  allowHeaders: {\n    env: 'PARSE_SERVER_ALLOW_HEADERS',\n    help: 'Add headers to Access-Control-Allow-Headers',\n    action: parsers.arrayParser,\n  },\n  allowOrigin: {\n    env: 'PARSE_SERVER_ALLOW_ORIGIN',\n    help: 'Sets the origin to Access-Control-Allow-Origin',\n  },\n  analyticsAdapter: {\n    env: 'PARSE_SERVER_ANALYTICS_ADAPTER',\n    help: 'Adapter module for the analytics',\n    action: parsers.moduleOrObjectParser,\n  },\n  appId: {\n    env: 'PARSE_SERVER_APPLICATION_ID',\n    help: 'Your Parse Application ID',\n    required: true,\n  },\n  appName: {\n    env: 'PARSE_SERVER_APP_NAME',\n    help: 'Sets the app name',\n  },\n  auth: {\n    env: 'PARSE_SERVER_AUTH_PROVIDERS',\n    help:\n      'Configuration for your authentication providers, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#oauth-and-3rd-party-authentication',\n    action: parsers.objectParser,\n  },\n  cacheAdapter: {\n    env: 'PARSE_SERVER_CACHE_ADAPTER',\n    help: 'Adapter module for the cache',\n    action: parsers.moduleOrObjectParser,\n  },\n  cacheMaxSize: {\n    env: 'PARSE_SERVER_CACHE_MAX_SIZE',\n    help: 'Sets the maximum size for the in memory cache, defaults to 10000',\n    action: parsers.numberParser('cacheMaxSize'),\n    default: 10000,\n  },\n  cacheTTL: {\n    env: 'PARSE_SERVER_CACHE_TTL',\n    help: 'Sets the TTL for the in memory cache (in ms), defaults to 5000 (5 seconds)',\n    action: parsers.numberParser('cacheTTL'),\n    default: 5000,\n  },\n  clientKey: {\n    env: 'PARSE_SERVER_CLIENT_KEY',\n    help: 'Key for iOS, MacOS, tvOS clients',\n  },\n  cloud: {\n    env: 'PARSE_SERVER_CLOUD',\n    help: 'Full path to your cloud code main.js',\n  },\n  cluster: {\n    env: 'PARSE_SERVER_CLUSTER',\n    help: 'Run with cluster, optionally set the number of processes default to os.cpus().length',\n    action: parsers.numberOrBooleanParser,\n  },\n  collectionPrefix: {\n    env: 'PARSE_SERVER_COLLECTION_PREFIX',\n    help: 'A collection prefix for the classes',\n    default: '',\n  },\n  customPages: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES',\n    help: 'custom pages for password validation and reset',\n    action: parsers.objectParser,\n    default: {},\n  },\n  databaseAdapter: {\n    env: 'PARSE_SERVER_DATABASE_ADAPTER',\n    help: 'Adapter module for the database',\n    action: parsers.moduleOrObjectParser,\n  },\n  databaseOptions: {\n    env: 'PARSE_SERVER_DATABASE_OPTIONS',\n    help: 'Options to pass to the mongodb client',\n    action: parsers.objectParser,\n  },\n  databaseURI: {\n    env: 'PARSE_SERVER_DATABASE_URI',\n    help: 'The full URI to your database. Supported databases are mongodb or postgres.',\n    required: true,\n    default: 'mongodb://localhost:27017/parse',\n  },\n  directAccess: {\n    env: 'PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS',\n    help:\n      'Replace HTTP Interface when using JS SDK in current node runtime, defaults to false. Caution, this is an experimental feature that may not be appropriate for production.',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  dotNetKey: {\n    env: 'PARSE_SERVER_DOT_NET_KEY',\n    help: 'Key for Unity and .Net SDK',\n  },\n  emailAdapter: {\n    env: 'PARSE_SERVER_EMAIL_ADAPTER',\n    help: 'Adapter module for email sending',\n    action: parsers.moduleOrObjectParser,\n  },\n  emailVerifyTokenReuseIfValid: {\n    env: 'PARSE_SERVER_EMAIL_VERIFY_TOKEN_REUSE_IF_VALID',\n    help:\n      'an existing email verify token should be reused when resend verification email is requested',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  emailVerifyTokenValidityDuration: {\n    env: 'PARSE_SERVER_EMAIL_VERIFY_TOKEN_VALIDITY_DURATION',\n    help: 'Email verification token validity duration, in seconds',\n    action: parsers.numberParser('emailVerifyTokenValidityDuration'),\n  },\n  enableAnonymousUsers: {\n    env: 'PARSE_SERVER_ENABLE_ANON_USERS',\n    help: 'Enable (or disable) anonymous users, defaults to true',\n    action: parsers.booleanParser,\n    default: true,\n  },\n  enableExpressErrorHandler: {\n    env: 'PARSE_SERVER_ENABLE_EXPRESS_ERROR_HANDLER',\n    help: 'Enables the default express error handler for all errors',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  enableSingleSchemaCache: {\n    env: 'PARSE_SERVER_ENABLE_SINGLE_SCHEMA_CACHE',\n    help:\n      'Use a single schema cache shared across requests. Reduces number of queries made to _SCHEMA, defaults to false, i.e. unique schema cache per request.',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  encryptionKey: {\n    env: 'PARSE_SERVER_ENCRYPTION_KEY',\n    help: 'Key for encrypting your files',\n  },\n  expireInactiveSessions: {\n    env: 'PARSE_SERVER_EXPIRE_INACTIVE_SESSIONS',\n    help: 'Sets wether we should expire the inactive sessions, defaults to true',\n    action: parsers.booleanParser,\n    default: true,\n  },\n  fileKey: {\n    env: 'PARSE_SERVER_FILE_KEY',\n    help: 'Key for your files',\n  },\n  filesAdapter: {\n    env: 'PARSE_SERVER_FILES_ADAPTER',\n    help: 'Adapter module for the files sub-system',\n    action: parsers.moduleOrObjectParser,\n  },\n  graphQLPath: {\n    env: 'PARSE_SERVER_GRAPHQL_PATH',\n    help: 'Mount path for the GraphQL endpoint, defaults to /graphql',\n    default: '/graphql',\n  },\n  graphQLSchema: {\n    env: 'PARSE_SERVER_GRAPH_QLSCHEMA',\n    help: 'Full path to your GraphQL custom schema.graphql file',\n  },\n  host: {\n    env: 'PARSE_SERVER_HOST',\n    help: 'The host to serve ParseServer on, defaults to 0.0.0.0',\n    default: '0.0.0.0',\n  },\n  idempotencyOptions: {\n    env: 'PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_OPTIONS',\n    help:\n      'Options for request idempotency to deduplicate identical requests that may be caused by network issues. Caution, this is an experimental feature that may not be appropriate for production.',\n    action: parsers.objectParser,\n    default: {},\n  },\n  javascriptKey: {\n    env: 'PARSE_SERVER_JAVASCRIPT_KEY',\n    help: 'Key for the Javascript SDK',\n  },\n  jsonLogs: {\n    env: 'JSON_LOGS',\n    help: 'Log as structured JSON objects',\n    action: parsers.booleanParser,\n  },\n  liveQuery: {\n    env: 'PARSE_SERVER_LIVE_QUERY',\n    help: \"parse-server's LiveQuery configuration object\",\n    action: parsers.objectParser,\n  },\n  liveQueryServerOptions: {\n    env: 'PARSE_SERVER_LIVE_QUERY_SERVER_OPTIONS',\n    help: 'Live query server configuration options (will start the liveQuery server)',\n    action: parsers.objectParser,\n  },\n  loggerAdapter: {\n    env: 'PARSE_SERVER_LOGGER_ADAPTER',\n    help: 'Adapter module for the logging sub-system',\n    action: parsers.moduleOrObjectParser,\n  },\n  logLevel: {\n    env: 'PARSE_SERVER_LOG_LEVEL',\n    help: 'Sets the level for logs',\n  },\n  logsFolder: {\n    env: 'PARSE_SERVER_LOGS_FOLDER',\n    help: \"Folder for the logs (defaults to './logs'); set to null to disable file based logging\",\n    default: './logs',\n  },\n  masterKey: {\n    env: 'PARSE_SERVER_MASTER_KEY',\n    help: 'Your Parse Master Key',\n    required: true,\n  },\n  masterKeyIps: {\n    env: 'PARSE_SERVER_MASTER_KEY_IPS',\n    help: 'Restrict masterKey to be used by only these ips, defaults to [] (allow all ips)',\n    action: parsers.arrayParser,\n    default: [],\n  },\n  maxLimit: {\n    env: 'PARSE_SERVER_MAX_LIMIT',\n    help: 'Max value for limit option on queries, defaults to unlimited',\n    action: parsers.numberParser('maxLimit'),\n  },\n  maxLogFiles: {\n    env: 'PARSE_SERVER_MAX_LOG_FILES',\n    help:\n      \"Maximum number of logs to keep. If not set, no logs will be removed. This can be a number of files or number of days. If using days, add 'd' as the suffix. (default: null)\",\n    action: parsers.objectParser,\n  },\n  maxUploadSize: {\n    env: 'PARSE_SERVER_MAX_UPLOAD_SIZE',\n    help: 'Max file size for uploads, defaults to 20mb',\n    default: '20mb',\n  },\n  middleware: {\n    env: 'PARSE_SERVER_MIDDLEWARE',\n    help: 'middleware for express server, can be string or function',\n  },\n  mountGraphQL: {\n    env: 'PARSE_SERVER_MOUNT_GRAPHQL',\n    help: 'Mounts the GraphQL endpoint',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  mountPath: {\n    env: 'PARSE_SERVER_MOUNT_PATH',\n    help: 'Mount path for the server, defaults to /parse',\n    default: '/parse',\n  },\n  mountPlayground: {\n    env: 'PARSE_SERVER_MOUNT_PLAYGROUND',\n    help: 'Mounts the GraphQL Playground - never use this option in production',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  objectIdSize: {\n    env: 'PARSE_SERVER_OBJECT_ID_SIZE',\n    help: \"Sets the number of characters in generated object id's, default 10\",\n    action: parsers.numberParser('objectIdSize'),\n    default: 10,\n  },\n  passwordPolicy: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY',\n    help: 'Password policy for enforcing password related rules',\n    action: parsers.objectParser,\n  },\n  playgroundPath: {\n    env: 'PARSE_SERVER_PLAYGROUND_PATH',\n    help: 'Mount path for the GraphQL Playground, defaults to /playground',\n    default: '/playground',\n  },\n  port: {\n    env: 'PORT',\n    help: 'The port to run the ParseServer, defaults to 1337.',\n    action: parsers.numberParser('port'),\n    default: 1337,\n  },\n  preserveFileName: {\n    env: 'PARSE_SERVER_PRESERVE_FILE_NAME',\n    help: 'Enable (or disable) the addition of a unique hash to the file names',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  preventLoginWithUnverifiedEmail: {\n    env: 'PARSE_SERVER_PREVENT_LOGIN_WITH_UNVERIFIED_EMAIL',\n    help:\n      'Prevent user from login if email is not verified and PARSE_SERVER_VERIFY_USER_EMAILS is true, defaults to false',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  protectedFields: {\n    env: 'PARSE_SERVER_PROTECTED_FIELDS',\n    help: 'Protected fields that should be treated with extra security when fetching details.',\n    action: parsers.objectParser,\n    default: {\n      _User: {\n        '*': ['email'],\n      },\n    },\n  },\n  publicServerURL: {\n    env: 'PARSE_PUBLIC_SERVER_URL',\n    help: 'Public URL to your parse server with http:// or https://.',\n  },\n  push: {\n    env: 'PARSE_SERVER_PUSH',\n    help:\n      'Configuration for push, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#push-notifications',\n    action: parsers.objectParser,\n  },\n  readOnlyMasterKey: {\n    env: 'PARSE_SERVER_READ_ONLY_MASTER_KEY',\n    help: 'Read-only key, which has the same capabilities as MasterKey without writes',\n  },\n  requestKeywordDenylist: {\n    env: 'PARSE_SERVER_REQUEST_KEYWORD_DENYLIST',\n    help:\n      'An array of keys and values that are prohibited in database read and write requests to prevent potential security vulnerabilities. It is possible to specify only a key (`{\"key\":\"...\"}`), only a value (`{\"value\":\"...\"}`) or a key-value pair (`{\"key\":\"...\",\"value\":\"...\"}`). The specification can use the following types: `boolean`, `numeric` or `string`, where `string` will be interpreted as a regex notation. Request data is deep-scanned for matching definitions to detect also any nested occurrences. Defaults are patterns that are likely to be used in malicious requests. Setting this option will override the default patterns.',\n    action: parsers.arrayParser,\n    default: [\n      {\n        key: '_bsontype',\n        value: 'Code',\n      },\n      {\n        key: 'constructor',\n      },\n      {\n        key: '__proto__',\n      },\n    ],\n  },\n  restAPIKey: {\n    env: 'PARSE_SERVER_REST_API_KEY',\n    help: 'Key for REST calls',\n  },\n  revokeSessionOnPasswordReset: {\n    env: 'PARSE_SERVER_REVOKE_SESSION_ON_PASSWORD_RESET',\n    help:\n      \"When a user changes their password, either through the reset password email or while logged in, all sessions are revoked if this is true. Set to false if you don't want to revoke sessions.\",\n    action: parsers.booleanParser,\n    default: true,\n  },\n  scheduledPush: {\n    env: 'PARSE_SERVER_SCHEDULED_PUSH',\n    help: 'Configuration for push scheduling, defaults to false.',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  schemaCacheTTL: {\n    env: 'PARSE_SERVER_SCHEMA_CACHE_TTL',\n    help:\n      'The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 5000; set 0 to disable.',\n    action: parsers.numberParser('schemaCacheTTL'),\n    default: 5000,\n  },\n  serverCloseComplete: {\n    env: 'PARSE_SERVER_SERVER_CLOSE_COMPLETE',\n    help: 'Callback when server has closed',\n  },\n  serverStartComplete: {\n    env: 'PARSE_SERVER_SERVER_START_COMPLETE',\n    help: 'Callback when server has started',\n  },\n  serverURL: {\n    env: 'PARSE_SERVER_URL',\n    help: 'URL to your parse server with http:// or https://.',\n    required: true,\n  },\n  sessionLength: {\n    env: 'PARSE_SERVER_SESSION_LENGTH',\n    help: 'Session duration, in seconds, defaults to 1 year',\n    action: parsers.numberParser('sessionLength'),\n    default: 31536000,\n  },\n  silent: {\n    env: 'SILENT',\n    help: 'Disables console output',\n    action: parsers.booleanParser,\n  },\n  startLiveQueryServer: {\n    env: 'PARSE_SERVER_START_LIVE_QUERY_SERVER',\n    help: 'Starts the liveQuery server',\n    action: parsers.booleanParser,\n  },\n  userSensitiveFields: {\n    env: 'PARSE_SERVER_USER_SENSITIVE_FIELDS',\n    help:\n      'Personally identifiable information fields in the user table the should be removed for non-authorized users. Deprecated @see protectedFields',\n    action: parsers.arrayParser,\n  },\n  verbose: {\n    env: 'VERBOSE',\n    help: 'Set the logging to verbose',\n    action: parsers.booleanParser,\n  },\n  verifyUserEmails: {\n    env: 'PARSE_SERVER_VERIFY_USER_EMAILS',\n    help: 'Enable (or disable) user email validation, defaults to false',\n    action: parsers.booleanParser,\n    default: false,\n  },\n  webhookKey: {\n    env: 'PARSE_SERVER_WEBHOOK_KEY',\n    help: 'Key sent with outgoing webhook calls',\n  },\n};\nmodule.exports.CustomPagesOptions = {\n  choosePassword: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_CHOOSE_PASSWORD',\n    help: 'choose password page path',\n  },\n  invalidLink: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_INVALID_LINK',\n    help: 'invalid link page path',\n  },\n  invalidVerificationLink: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_INVALID_VERIFICATION_LINK',\n    help: 'invalid verification link page path',\n  },\n  linkSendFail: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_LINK_SEND_FAIL',\n    help: 'verification link send fail page path',\n  },\n  linkSendSuccess: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_LINK_SEND_SUCCESS',\n    help: 'verification link send success page path',\n  },\n  parseFrameURL: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_PARSE_FRAME_URL',\n    help: 'for masking user-facing pages',\n  },\n  passwordResetSuccess: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_PASSWORD_RESET_SUCCESS',\n    help: 'password reset success page path',\n  },\n  verifyEmailSuccess: {\n    env: 'PARSE_SERVER_CUSTOM_PAGES_VERIFY_EMAIL_SUCCESS',\n    help: 'verify email success page path',\n  },\n};\nmodule.exports.LiveQueryOptions = {\n  classNames: {\n    env: 'PARSE_SERVER_LIVEQUERY_CLASSNAMES',\n    help: \"parse-server's LiveQuery classNames\",\n    action: parsers.arrayParser,\n  },\n  pubSubAdapter: {\n    env: 'PARSE_SERVER_LIVEQUERY_PUB_SUB_ADAPTER',\n    help: 'LiveQuery pubsub adapter',\n    action: parsers.moduleOrObjectParser,\n  },\n  redisOptions: {\n    env: 'PARSE_SERVER_LIVEQUERY_REDIS_OPTIONS',\n    help: \"parse-server's LiveQuery redisOptions\",\n    action: parsers.objectParser,\n  },\n  redisURL: {\n    env: 'PARSE_SERVER_LIVEQUERY_REDIS_URL',\n    help: \"parse-server's LiveQuery redisURL\",\n  },\n  wssAdapter: {\n    env: 'PARSE_SERVER_LIVEQUERY_WSS_ADAPTER',\n    help: 'Adapter module for the WebSocketServer',\n    action: parsers.moduleOrObjectParser,\n  },\n};\nmodule.exports.LiveQueryServerOptions = {\n  appId: {\n    env: 'PARSE_LIVE_QUERY_SERVER_APP_ID',\n    help:\n      'This string should match the appId in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same appId.',\n  },\n  cacheTimeout: {\n    env: 'PARSE_LIVE_QUERY_SERVER_CACHE_TIMEOUT',\n    help:\n      \"Number in milliseconds. When clients provide the sessionToken to the LiveQuery server, the LiveQuery server will try to fetch its ParseUser's objectId from parse server and store it in the cache. The value defines the duration of the cache. Check the following Security section and our protocol specification for details, defaults to 5 * 1000 ms (5 seconds).\",\n    action: parsers.numberParser('cacheTimeout'),\n  },\n  keyPairs: {\n    env: 'PARSE_LIVE_QUERY_SERVER_KEY_PAIRS',\n    help:\n      'A JSON object that serves as a whitelist of keys. It is used for validating clients when they try to connect to the LiveQuery server. Check the following Security section and our protocol specification for details.',\n    action: parsers.objectParser,\n  },\n  logLevel: {\n    env: 'PARSE_LIVE_QUERY_SERVER_LOG_LEVEL',\n    help:\n      'This string defines the log level of the LiveQuery server. We support VERBOSE, INFO, ERROR, NONE, defaults to INFO.',\n  },\n  masterKey: {\n    env: 'PARSE_LIVE_QUERY_SERVER_MASTER_KEY',\n    help:\n      'This string should match the masterKey in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same masterKey.',\n  },\n  port: {\n    env: 'PARSE_LIVE_QUERY_SERVER_PORT',\n    help: 'The port to run the LiveQuery server, defaults to 1337.',\n    action: parsers.numberParser('port'),\n    default: 1337,\n  },\n  pubSubAdapter: {\n    env: 'PARSE_LIVE_QUERY_SERVER_PUB_SUB_ADAPTER',\n    help: 'LiveQuery pubsub adapter',\n    action: parsers.moduleOrObjectParser,\n  },\n  redisOptions: {\n    env: 'PARSE_LIVE_QUERY_SERVER_REDIS_OPTIONS',\n    help: \"parse-server's LiveQuery redisOptions\",\n    action: parsers.objectParser,\n  },\n  redisURL: {\n    env: 'PARSE_LIVE_QUERY_SERVER_REDIS_URL',\n    help: \"parse-server's LiveQuery redisURL\",\n  },\n  serverURL: {\n    env: 'PARSE_LIVE_QUERY_SERVER_SERVER_URL',\n    help:\n      'This string should match the serverURL in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same serverURL.',\n  },\n  websocketTimeout: {\n    env: 'PARSE_LIVE_QUERY_SERVER_WEBSOCKET_TIMEOUT',\n    help:\n      'Number of milliseconds between ping/pong frames. The WebSocket server sends ping/pong frames to the clients to keep the WebSocket alive. This value defines the interval of the ping/pong frame from the server to clients, defaults to 10 * 1000 ms (10 s).',\n    action: parsers.numberParser('websocketTimeout'),\n  },\n  wssAdapter: {\n    env: 'PARSE_LIVE_QUERY_SERVER_WSS_ADAPTER',\n    help: 'Adapter module for the WebSocketServer',\n    action: parsers.moduleOrObjectParser,\n  },\n};\nmodule.exports.IdempotencyOptions = {\n  paths: {\n    env: 'PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_PATHS',\n    help:\n      'An array of paths for which the feature should be enabled. The mount path must not be included, for example instead of `/parse/functions/myFunction` specifiy `functions/myFunction`. The entries are interpreted as regular expression, for example `functions/.*` matches all functions, `jobs/.*` matches all jobs, `classes/.*` matches all classes, `.*` matches all paths.',\n    action: parsers.arrayParser,\n    default: [],\n  },\n  ttl: {\n    env: 'PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_TTL',\n    help:\n      'The duration in seconds after which a request record is discarded from the database, defaults to 300s.',\n    action: parsers.numberParser('ttl'),\n    default: 300,\n  },\n};\nmodule.exports.AccountLockoutOptions = {\n  duration: {\n    env: 'PARSE_SERVER_ACCOUNT_LOCKOUT_DURATION',\n    help:\n      'number of minutes that a locked-out account remains locked out before automatically becoming unlocked.',\n    action: parsers.numberParser('duration'),\n  },\n  threshold: {\n    env: 'PARSE_SERVER_ACCOUNT_LOCKOUT_THRESHOLD',\n    help: 'number of failed sign-in attempts that will cause a user account to be locked',\n    action: parsers.numberParser('threshold'),\n  },\n};\nmodule.exports.PasswordPolicyOptions = {\n  doNotAllowUsername: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_DO_NOT_ALLOW_USERNAME',\n    help: 'disallow username in passwords',\n    action: parsers.booleanParser,\n  },\n  maxPasswordAge: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_MAX_PASSWORD_AGE',\n    help: 'days for password expiry',\n    action: parsers.numberParser('maxPasswordAge'),\n  },\n  maxPasswordHistory: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_MAX_PASSWORD_HISTORY',\n    help: 'setting to prevent reuse of previous n passwords',\n    action: parsers.numberParser('maxPasswordHistory'),\n  },\n  resetTokenReuseIfValid: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_RESET_TOKEN_REUSE_IF_VALID',\n    help: \"resend token if it's still valid\",\n    action: parsers.booleanParser,\n  },\n  resetTokenValidityDuration: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_RESET_TOKEN_VALIDITY_DURATION',\n    help: 'time for token to expire',\n    action: parsers.numberParser('resetTokenValidityDuration'),\n  },\n  validatorCallback: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_VALIDATOR_CALLBACK',\n    help: 'a callback function to be invoked to validate the password',\n  },\n  validatorPattern: {\n    env: 'PARSE_SERVER_PASSWORD_POLICY_VALIDATOR_PATTERN',\n    help: 'a RegExp object or a regex string representing the pattern to enforce',\n  },\n};\n"]}
@@ -62,6 +62,7 @@
62
62
  * @property {String} publicServerURL Public URL to your parse server with http:// or https://.
63
63
  * @property {Any} push Configuration for push, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#push-notifications
64
64
  * @property {String} readOnlyMasterKey Read-only key, which has the same capabilities as MasterKey without writes
65
+ * @property {RequestKeywordDenylist[]} requestKeywordDenylist An array of keys and values that are prohibited in database read and write requests to prevent potential security vulnerabilities. It is possible to specify only a key (`{"key":"..."}`), only a value (`{"value":"..."}`) or a key-value pair (`{"key":"...","value":"..."}`). The specification can use the following types: `boolean`, `numeric` or `string`, where `string` will be interpreted as a regex notation. Request data is deep-scanned for matching definitions to detect also any nested occurrences. Defaults are patterns that are likely to be used in malicious requests. Setting this option will override the default patterns.
65
66
  * @property {String} restAPIKey Key for REST calls
66
67
  * @property {Boolean} revokeSessionOnPasswordReset When a user changes their password, either through the reset password email or while logged in, all sessions are revoked if this is true. Set to false if you don't want to revoke sessions.
67
68
  * @property {Boolean} scheduledPush Configuration for push scheduling, defaults to false.
@@ -138,4 +139,4 @@
138
139
  * @property {String} validatorPattern a RegExp object or a regex string representing the pattern to enforce
139
140
  */
140
141
  "use strict";
141
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Options/docs.js"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgFA;;;;;;;;;;;;AAYA;;;;;;;;;AASA;;;;;;;;;;;;;;;;AAgBA;;;;;;AAMA;;;;;;AAMA","sourcesContent":["/**\n * @interface ParseServerOptions\n * @property {AccountLockoutOptions} accountLockout account lockout policy for failed login attempts\n * @property {Boolean} allowClientClassCreation Enable (or disable) client class creation, defaults to true\n * @property {Boolean} allowCustomObjectId Enable (or disable) custom objectId\n * @property {String[]} allowHeaders Add headers to Access-Control-Allow-Headers\n * @property {String} allowOrigin Sets the origin to Access-Control-Allow-Origin\n * @property {Adapter<AnalyticsAdapter>} analyticsAdapter Adapter module for the analytics\n * @property {String} appId Your Parse Application ID\n * @property {String} appName Sets the app name\n * @property {Any} auth Configuration for your authentication providers, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#oauth-and-3rd-party-authentication\n * @property {Adapter<CacheAdapter>} cacheAdapter Adapter module for the cache\n * @property {Number} cacheMaxSize Sets the maximum size for the in memory cache, defaults to 10000\n * @property {Number} cacheTTL Sets the TTL for the in memory cache (in ms), defaults to 5000 (5 seconds)\n * @property {String} clientKey Key for iOS, MacOS, tvOS clients\n * @property {String} cloud Full path to your cloud code main.js\n * @property {Number|Boolean} cluster Run with cluster, optionally set the number of processes default to os.cpus().length\n * @property {String} collectionPrefix A collection prefix for the classes\n * @property {CustomPagesOptions} customPages custom pages for password validation and reset\n * @property {Adapter<StorageAdapter>} databaseAdapter Adapter module for the database\n * @property {Any} databaseOptions Options to pass to the mongodb client\n * @property {String} databaseURI The full URI to your database. Supported databases are mongodb or postgres.\n * @property {Boolean} directAccess Replace HTTP Interface when using JS SDK in current node runtime, defaults to false. Caution, this is an experimental feature that may not be appropriate for production.\n * @property {String} dotNetKey Key for Unity and .Net SDK\n * @property {Adapter<MailAdapter>} emailAdapter Adapter module for email sending\n * @property {Boolean} emailVerifyTokenReuseIfValid an existing email verify token should be reused when resend verification email is requested\n * @property {Number} emailVerifyTokenValidityDuration Email verification token validity duration, in seconds\n * @property {Boolean} enableAnonymousUsers Enable (or disable) anonymous users, defaults to true\n * @property {Boolean} enableExpressErrorHandler Enables the default express error handler for all errors\n * @property {Boolean} enableSingleSchemaCache Use a single schema cache shared across requests. Reduces number of queries made to _SCHEMA, defaults to false, i.e. unique schema cache per request.\n * @property {String} encryptionKey Key for encrypting your files\n * @property {Boolean} expireInactiveSessions Sets wether we should expire the inactive sessions, defaults to true\n * @property {String} fileKey Key for your files\n * @property {Adapter<FilesAdapter>} filesAdapter Adapter module for the files sub-system\n * @property {String} graphQLPath Mount path for the GraphQL endpoint, defaults to /graphql\n * @property {String} graphQLSchema Full path to your GraphQL custom schema.graphql file\n * @property {String} host The host to serve ParseServer on, defaults to 0.0.0.0\n * @property {IdempotencyOptions} idempotencyOptions Options for request idempotency to deduplicate identical requests that may be caused by network issues. Caution, this is an experimental feature that may not be appropriate for production.\n * @property {String} javascriptKey Key for the Javascript SDK\n * @property {Boolean} jsonLogs Log as structured JSON objects\n * @property {LiveQueryOptions} liveQuery parse-server's LiveQuery configuration object\n * @property {LiveQueryServerOptions} liveQueryServerOptions Live query server configuration options (will start the liveQuery server)\n * @property {Adapter<LoggerAdapter>} loggerAdapter Adapter module for the logging sub-system\n * @property {String} logLevel Sets the level for logs\n * @property {String} logsFolder Folder for the logs (defaults to './logs'); set to null to disable file based logging\n * @property {String} masterKey Your Parse Master Key\n * @property {String[]} masterKeyIps Restrict masterKey to be used by only these ips, defaults to [] (allow all ips)\n * @property {Number} maxLimit Max value for limit option on queries, defaults to unlimited\n * @property {Number|String} maxLogFiles Maximum number of logs to keep. If not set, no logs will be removed. This can be a number of files or number of days. If using days, add 'd' as the suffix. (default: null)\n * @property {String} maxUploadSize Max file size for uploads, defaults to 20mb\n * @property {Union} middleware middleware for express server, can be string or function\n * @property {Boolean} mountGraphQL Mounts the GraphQL endpoint\n * @property {String} mountPath Mount path for the server, defaults to /parse\n * @property {Boolean} mountPlayground Mounts the GraphQL Playground - never use this option in production\n * @property {Number} objectIdSize Sets the number of characters in generated object id's, default 10\n * @property {PasswordPolicyOptions} passwordPolicy Password policy for enforcing password related rules\n * @property {String} playgroundPath Mount path for the GraphQL Playground, defaults to /playground\n * @property {Number} port The port to run the ParseServer, defaults to 1337.\n * @property {Boolean} preserveFileName Enable (or disable) the addition of a unique hash to the file names\n * @property {Boolean} preventLoginWithUnverifiedEmail Prevent user from login if email is not verified and PARSE_SERVER_VERIFY_USER_EMAILS is true, defaults to false\n * @property {ProtectedFields} protectedFields Protected fields that should be treated with extra security when fetching details.\n * @property {String} publicServerURL Public URL to your parse server with http:// or https://.\n * @property {Any} push Configuration for push, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#push-notifications\n * @property {String} readOnlyMasterKey Read-only key, which has the same capabilities as MasterKey without writes\n * @property {String} restAPIKey Key for REST calls\n * @property {Boolean} revokeSessionOnPasswordReset When a user changes their password, either through the reset password email or while logged in, all sessions are revoked if this is true. Set to false if you don't want to revoke sessions.\n * @property {Boolean} scheduledPush Configuration for push scheduling, defaults to false.\n * @property {Number} schemaCacheTTL The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 5000; set 0 to disable.\n * @property {Function} serverCloseComplete Callback when server has closed\n * @property {Function} serverStartComplete Callback when server has started\n * @property {String} serverURL URL to your parse server with http:// or https://.\n * @property {Number} sessionLength Session duration, in seconds, defaults to 1 year\n * @property {Boolean} silent Disables console output\n * @property {Boolean} startLiveQueryServer Starts the liveQuery server\n * @property {String[]} userSensitiveFields Personally identifiable information fields in the user table the should be removed for non-authorized users. Deprecated @see protectedFields\n * @property {Boolean} verbose Set the logging to verbose\n * @property {Boolean} verifyUserEmails Enable (or disable) user email validation, defaults to false\n * @property {String} webhookKey Key sent with outgoing webhook calls\n */\n\n/**\n * @interface CustomPagesOptions\n * @property {String} choosePassword choose password page path\n * @property {String} invalidLink invalid link page path\n * @property {String} invalidVerificationLink invalid verification link page path\n * @property {String} linkSendFail verification link send fail page path\n * @property {String} linkSendSuccess verification link send success page path\n * @property {String} parseFrameURL for masking user-facing pages\n * @property {String} passwordResetSuccess password reset success page path\n * @property {String} verifyEmailSuccess verify email success page path\n */\n\n/**\n * @interface LiveQueryOptions\n * @property {String[]} classNames parse-server's LiveQuery classNames\n * @property {Adapter<PubSubAdapter>} pubSubAdapter LiveQuery pubsub adapter\n * @property {Any} redisOptions parse-server's LiveQuery redisOptions\n * @property {String} redisURL parse-server's LiveQuery redisURL\n * @property {Adapter<WSSAdapter>} wssAdapter Adapter module for the WebSocketServer\n */\n\n/**\n * @interface LiveQueryServerOptions\n * @property {String} appId This string should match the appId in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same appId.\n * @property {Number} cacheTimeout Number in milliseconds. When clients provide the sessionToken to the LiveQuery server, the LiveQuery server will try to fetch its ParseUser's objectId from parse server and store it in the cache. The value defines the duration of the cache. Check the following Security section and our protocol specification for details, defaults to 5 * 1000 ms (5 seconds).\n * @property {Any} keyPairs A JSON object that serves as a whitelist of keys. It is used for validating clients when they try to connect to the LiveQuery server. Check the following Security section and our protocol specification for details.\n * @property {String} logLevel This string defines the log level of the LiveQuery server. We support VERBOSE, INFO, ERROR, NONE, defaults to INFO.\n * @property {String} masterKey This string should match the masterKey in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same masterKey.\n * @property {Number} port The port to run the LiveQuery server, defaults to 1337.\n * @property {Adapter<PubSubAdapter>} pubSubAdapter LiveQuery pubsub adapter\n * @property {Any} redisOptions parse-server's LiveQuery redisOptions\n * @property {String} redisURL parse-server's LiveQuery redisURL\n * @property {String} serverURL This string should match the serverURL in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same serverURL.\n * @property {Number} websocketTimeout Number of milliseconds between ping/pong frames. The WebSocket server sends ping/pong frames to the clients to keep the WebSocket alive. This value defines the interval of the ping/pong frame from the server to clients, defaults to 10 * 1000 ms (10 s).\n * @property {Adapter<WSSAdapter>} wssAdapter Adapter module for the WebSocketServer\n */\n\n/**\n * @interface IdempotencyOptions\n * @property {String[]} paths An array of paths for which the feature should be enabled. The mount path must not be included, for example instead of `/parse/functions/myFunction` specifiy `functions/myFunction`. The entries are interpreted as regular expression, for example `functions/.*` matches all functions, `jobs/.*` matches all jobs, `classes/.*` matches all classes, `.*` matches all paths.\n * @property {Number} ttl The duration in seconds after which a request record is discarded from the database, defaults to 300s.\n */\n\n/**\n * @interface AccountLockoutOptions\n * @property {Number} duration number of minutes that a locked-out account remains locked out before automatically becoming unlocked.\n * @property {Number} threshold number of failed sign-in attempts that will cause a user account to be locked\n */\n\n/**\n * @interface PasswordPolicyOptions\n * @property {Boolean} doNotAllowUsername disallow username in passwords\n * @property {Number} maxPasswordAge days for password expiry\n * @property {Number} maxPasswordHistory setting to prevent reuse of previous n passwords\n * @property {Boolean} resetTokenReuseIfValid resend token if it's still valid\n * @property {Number} resetTokenValidityDuration time for token to expire\n * @property {Function} validatorCallback a callback function to be invoked to validate the password\n * @property {String} validatorPattern a RegExp object or a regex string representing the pattern to enforce\n */\n"]}
142
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Options/docs.js"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiFA;;;;;;;;;;;;AAYA;;;;;;;;;AASA;;;;;;;;;;;;;;;;AAgBA;;;;;;AAMA;;;;;;AAMA","sourcesContent":["/**\n * @interface ParseServerOptions\n * @property {AccountLockoutOptions} accountLockout account lockout policy for failed login attempts\n * @property {Boolean} allowClientClassCreation Enable (or disable) client class creation, defaults to true\n * @property {Boolean} allowCustomObjectId Enable (or disable) custom objectId\n * @property {String[]} allowHeaders Add headers to Access-Control-Allow-Headers\n * @property {String} allowOrigin Sets the origin to Access-Control-Allow-Origin\n * @property {Adapter<AnalyticsAdapter>} analyticsAdapter Adapter module for the analytics\n * @property {String} appId Your Parse Application ID\n * @property {String} appName Sets the app name\n * @property {Any} auth Configuration for your authentication providers, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#oauth-and-3rd-party-authentication\n * @property {Adapter<CacheAdapter>} cacheAdapter Adapter module for the cache\n * @property {Number} cacheMaxSize Sets the maximum size for the in memory cache, defaults to 10000\n * @property {Number} cacheTTL Sets the TTL for the in memory cache (in ms), defaults to 5000 (5 seconds)\n * @property {String} clientKey Key for iOS, MacOS, tvOS clients\n * @property {String} cloud Full path to your cloud code main.js\n * @property {Number|Boolean} cluster Run with cluster, optionally set the number of processes default to os.cpus().length\n * @property {String} collectionPrefix A collection prefix for the classes\n * @property {CustomPagesOptions} customPages custom pages for password validation and reset\n * @property {Adapter<StorageAdapter>} databaseAdapter Adapter module for the database\n * @property {Any} databaseOptions Options to pass to the mongodb client\n * @property {String} databaseURI The full URI to your database. Supported databases are mongodb or postgres.\n * @property {Boolean} directAccess Replace HTTP Interface when using JS SDK in current node runtime, defaults to false. Caution, this is an experimental feature that may not be appropriate for production.\n * @property {String} dotNetKey Key for Unity and .Net SDK\n * @property {Adapter<MailAdapter>} emailAdapter Adapter module for email sending\n * @property {Boolean} emailVerifyTokenReuseIfValid an existing email verify token should be reused when resend verification email is requested\n * @property {Number} emailVerifyTokenValidityDuration Email verification token validity duration, in seconds\n * @property {Boolean} enableAnonymousUsers Enable (or disable) anonymous users, defaults to true\n * @property {Boolean} enableExpressErrorHandler Enables the default express error handler for all errors\n * @property {Boolean} enableSingleSchemaCache Use a single schema cache shared across requests. Reduces number of queries made to _SCHEMA, defaults to false, i.e. unique schema cache per request.\n * @property {String} encryptionKey Key for encrypting your files\n * @property {Boolean} expireInactiveSessions Sets wether we should expire the inactive sessions, defaults to true\n * @property {String} fileKey Key for your files\n * @property {Adapter<FilesAdapter>} filesAdapter Adapter module for the files sub-system\n * @property {String} graphQLPath Mount path for the GraphQL endpoint, defaults to /graphql\n * @property {String} graphQLSchema Full path to your GraphQL custom schema.graphql file\n * @property {String} host The host to serve ParseServer on, defaults to 0.0.0.0\n * @property {IdempotencyOptions} idempotencyOptions Options for request idempotency to deduplicate identical requests that may be caused by network issues. Caution, this is an experimental feature that may not be appropriate for production.\n * @property {String} javascriptKey Key for the Javascript SDK\n * @property {Boolean} jsonLogs Log as structured JSON objects\n * @property {LiveQueryOptions} liveQuery parse-server's LiveQuery configuration object\n * @property {LiveQueryServerOptions} liveQueryServerOptions Live query server configuration options (will start the liveQuery server)\n * @property {Adapter<LoggerAdapter>} loggerAdapter Adapter module for the logging sub-system\n * @property {String} logLevel Sets the level for logs\n * @property {String} logsFolder Folder for the logs (defaults to './logs'); set to null to disable file based logging\n * @property {String} masterKey Your Parse Master Key\n * @property {String[]} masterKeyIps Restrict masterKey to be used by only these ips, defaults to [] (allow all ips)\n * @property {Number} maxLimit Max value for limit option on queries, defaults to unlimited\n * @property {Number|String} maxLogFiles Maximum number of logs to keep. If not set, no logs will be removed. This can be a number of files or number of days. If using days, add 'd' as the suffix. (default: null)\n * @property {String} maxUploadSize Max file size for uploads, defaults to 20mb\n * @property {Union} middleware middleware for express server, can be string or function\n * @property {Boolean} mountGraphQL Mounts the GraphQL endpoint\n * @property {String} mountPath Mount path for the server, defaults to /parse\n * @property {Boolean} mountPlayground Mounts the GraphQL Playground - never use this option in production\n * @property {Number} objectIdSize Sets the number of characters in generated object id's, default 10\n * @property {PasswordPolicyOptions} passwordPolicy Password policy for enforcing password related rules\n * @property {String} playgroundPath Mount path for the GraphQL Playground, defaults to /playground\n * @property {Number} port The port to run the ParseServer, defaults to 1337.\n * @property {Boolean} preserveFileName Enable (or disable) the addition of a unique hash to the file names\n * @property {Boolean} preventLoginWithUnverifiedEmail Prevent user from login if email is not verified and PARSE_SERVER_VERIFY_USER_EMAILS is true, defaults to false\n * @property {ProtectedFields} protectedFields Protected fields that should be treated with extra security when fetching details.\n * @property {String} publicServerURL Public URL to your parse server with http:// or https://.\n * @property {Any} push Configuration for push, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#push-notifications\n * @property {String} readOnlyMasterKey Read-only key, which has the same capabilities as MasterKey without writes\n * @property {RequestKeywordDenylist[]} requestKeywordDenylist An array of keys and values that are prohibited in database read and write requests to prevent potential security vulnerabilities. It is possible to specify only a key (`{\"key\":\"...\"}`), only a value (`{\"value\":\"...\"}`) or a key-value pair (`{\"key\":\"...\",\"value\":\"...\"}`). The specification can use the following types: `boolean`, `numeric` or `string`, where `string` will be interpreted as a regex notation. Request data is deep-scanned for matching definitions to detect also any nested occurrences. Defaults are patterns that are likely to be used in malicious requests. Setting this option will override the default patterns.\n * @property {String} restAPIKey Key for REST calls\n * @property {Boolean} revokeSessionOnPasswordReset When a user changes their password, either through the reset password email or while logged in, all sessions are revoked if this is true. Set to false if you don't want to revoke sessions.\n * @property {Boolean} scheduledPush Configuration for push scheduling, defaults to false.\n * @property {Number} schemaCacheTTL The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 5000; set 0 to disable.\n * @property {Function} serverCloseComplete Callback when server has closed\n * @property {Function} serverStartComplete Callback when server has started\n * @property {String} serverURL URL to your parse server with http:// or https://.\n * @property {Number} sessionLength Session duration, in seconds, defaults to 1 year\n * @property {Boolean} silent Disables console output\n * @property {Boolean} startLiveQueryServer Starts the liveQuery server\n * @property {String[]} userSensitiveFields Personally identifiable information fields in the user table the should be removed for non-authorized users. Deprecated @see protectedFields\n * @property {Boolean} verbose Set the logging to verbose\n * @property {Boolean} verifyUserEmails Enable (or disable) user email validation, defaults to false\n * @property {String} webhookKey Key sent with outgoing webhook calls\n */\n\n/**\n * @interface CustomPagesOptions\n * @property {String} choosePassword choose password page path\n * @property {String} invalidLink invalid link page path\n * @property {String} invalidVerificationLink invalid verification link page path\n * @property {String} linkSendFail verification link send fail page path\n * @property {String} linkSendSuccess verification link send success page path\n * @property {String} parseFrameURL for masking user-facing pages\n * @property {String} passwordResetSuccess password reset success page path\n * @property {String} verifyEmailSuccess verify email success page path\n */\n\n/**\n * @interface LiveQueryOptions\n * @property {String[]} classNames parse-server's LiveQuery classNames\n * @property {Adapter<PubSubAdapter>} pubSubAdapter LiveQuery pubsub adapter\n * @property {Any} redisOptions parse-server's LiveQuery redisOptions\n * @property {String} redisURL parse-server's LiveQuery redisURL\n * @property {Adapter<WSSAdapter>} wssAdapter Adapter module for the WebSocketServer\n */\n\n/**\n * @interface LiveQueryServerOptions\n * @property {String} appId This string should match the appId in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same appId.\n * @property {Number} cacheTimeout Number in milliseconds. When clients provide the sessionToken to the LiveQuery server, the LiveQuery server will try to fetch its ParseUser's objectId from parse server and store it in the cache. The value defines the duration of the cache. Check the following Security section and our protocol specification for details, defaults to 5 * 1000 ms (5 seconds).\n * @property {Any} keyPairs A JSON object that serves as a whitelist of keys. It is used for validating clients when they try to connect to the LiveQuery server. Check the following Security section and our protocol specification for details.\n * @property {String} logLevel This string defines the log level of the LiveQuery server. We support VERBOSE, INFO, ERROR, NONE, defaults to INFO.\n * @property {String} masterKey This string should match the masterKey in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same masterKey.\n * @property {Number} port The port to run the LiveQuery server, defaults to 1337.\n * @property {Adapter<PubSubAdapter>} pubSubAdapter LiveQuery pubsub adapter\n * @property {Any} redisOptions parse-server's LiveQuery redisOptions\n * @property {String} redisURL parse-server's LiveQuery redisURL\n * @property {String} serverURL This string should match the serverURL in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same serverURL.\n * @property {Number} websocketTimeout Number of milliseconds between ping/pong frames. The WebSocket server sends ping/pong frames to the clients to keep the WebSocket alive. This value defines the interval of the ping/pong frame from the server to clients, defaults to 10 * 1000 ms (10 s).\n * @property {Adapter<WSSAdapter>} wssAdapter Adapter module for the WebSocketServer\n */\n\n/**\n * @interface IdempotencyOptions\n * @property {String[]} paths An array of paths for which the feature should be enabled. The mount path must not be included, for example instead of `/parse/functions/myFunction` specifiy `functions/myFunction`. The entries are interpreted as regular expression, for example `functions/.*` matches all functions, `jobs/.*` matches all jobs, `classes/.*` matches all classes, `.*` matches all paths.\n * @property {Number} ttl The duration in seconds after which a request record is discarded from the database, defaults to 300s.\n */\n\n/**\n * @interface AccountLockoutOptions\n * @property {Number} duration number of minutes that a locked-out account remains locked out before automatically becoming unlocked.\n * @property {Number} threshold number of failed sign-in attempts that will cause a user account to be locked\n */\n\n/**\n * @interface PasswordPolicyOptions\n * @property {Boolean} doNotAllowUsername disallow username in passwords\n * @property {Number} maxPasswordAge days for password expiry\n * @property {Number} maxPasswordHistory setting to prevent reuse of previous n passwords\n * @property {Boolean} resetTokenReuseIfValid resend token if it's still valid\n * @property {Number} resetTokenValidityDuration time for token to expire\n * @property {Function} validatorCallback a callback function to be invoked to validate the password\n * @property {String} validatorPattern a RegExp object or a regex string representing the pattern to enforce\n */\n"]}
@@ -15,4 +15,4 @@ var _MailAdapter = require("../Adapters/Email/MailAdapter");
15
15
  var _PubSubAdapter = require("../Adapters/PubSub/PubSubAdapter");
16
16
 
17
17
  var _WSSAdapter = require("../Adapters/WebSocketServer/WSSAdapter");
18
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Options/index.js"],"names":[],"mappings":";;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA","sourcesContent":["import { AnalyticsAdapter } from '../Adapters/Analytics/AnalyticsAdapter';\nimport { FilesAdapter } from '../Adapters/Files/FilesAdapter';\nimport { LoggerAdapter } from '../Adapters/Logger/LoggerAdapter';\nimport { StorageAdapter } from '../Adapters/Storage/StorageAdapter';\nimport { CacheAdapter } from '../Adapters/Cache/CacheAdapter';\nimport { MailAdapter } from '../Adapters/Email/MailAdapter';\nimport { PubSubAdapter } from '../Adapters/PubSub/PubSubAdapter';\nimport { WSSAdapter } from '../Adapters/WebSocketServer/WSSAdapter';\n\n// @flow\ntype Adapter<T> = string | any | T;\ntype NumberOrBoolean = number | boolean;\ntype NumberOrString = number | string;\ntype ProtectedFields = any;\n\nexport interface ParseServerOptions {\n  /* Your Parse Application ID\n  :ENV: PARSE_SERVER_APPLICATION_ID */\n  appId: string;\n  /* Your Parse Master Key */\n  masterKey: string;\n  /* URL to your parse server with http:// or https://.\n  :ENV: PARSE_SERVER_URL */\n  serverURL: string;\n  /* Restrict masterKey to be used by only these ips, defaults to [] (allow all ips)\n  :DEFAULT: [] */\n  masterKeyIps: ?(string[]);\n  /* Sets the app name */\n  appName: ?string;\n  /* Add headers to Access-Control-Allow-Headers */\n  allowHeaders: ?(string[]);\n  /* Sets the origin to Access-Control-Allow-Origin */\n  allowOrigin: ?string;\n  /* Adapter module for the analytics */\n  analyticsAdapter: ?Adapter<AnalyticsAdapter>;\n  /* Adapter module for the files sub-system */\n  filesAdapter: ?Adapter<FilesAdapter>;\n  /* Configuration for push, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#push-notifications */\n  push: ?any;\n  /* Configuration for push scheduling, defaults to false.\n  :DEFAULT: false */\n  scheduledPush: ?boolean;\n  /* Adapter module for the logging sub-system */\n  loggerAdapter: ?Adapter<LoggerAdapter>;\n  /* Log as structured JSON objects\n  :ENV: JSON_LOGS */\n  jsonLogs: ?boolean;\n  /* Folder for the logs (defaults to './logs'); set to null to disable file based logging\n  :ENV: PARSE_SERVER_LOGS_FOLDER\n  :DEFAULT: ./logs */\n  logsFolder: ?string;\n  /* Set the logging to verbose\n  :ENV: VERBOSE */\n  verbose: ?boolean;\n  /* Sets the level for logs */\n  logLevel: ?string;\n  /* Maximum number of logs to keep. If not set, no logs will be removed. This can be a number of files or number of days. If using days, add 'd' as the suffix. (default: null) */\n  maxLogFiles: ?NumberOrString;\n  /* Disables console output\n  :ENV: SILENT */\n  silent: ?boolean;\n  /* The full URI to your database. Supported databases are mongodb or postgres.\n  :DEFAULT: mongodb://localhost:27017/parse */\n  databaseURI: string;\n  /* Options to pass to the mongodb client */\n  databaseOptions: ?any;\n  /* Adapter module for the database */\n  databaseAdapter: ?Adapter<StorageAdapter>;\n  /* Full path to your cloud code main.js */\n  cloud: ?string;\n  /* A collection prefix for the classes\n  :DEFAULT: '' */\n  collectionPrefix: ?string;\n  /* Key for iOS, MacOS, tvOS clients */\n  clientKey: ?string;\n  /* Key for the Javascript SDK */\n  javascriptKey: ?string;\n  /* Key for Unity and .Net SDK */\n  dotNetKey: ?string;\n  /* Key for encrypting your files\n  :ENV: PARSE_SERVER_ENCRYPTION_KEY */\n  encryptionKey: ?string;\n  /* Key for REST calls\n  :ENV: PARSE_SERVER_REST_API_KEY */\n  restAPIKey: ?string;\n  /* Read-only key, which has the same capabilities as MasterKey without writes */\n  readOnlyMasterKey: ?string;\n  /* Key sent with outgoing webhook calls */\n  webhookKey: ?string;\n  /* Key for your files */\n  fileKey: ?string;\n  /* Enable (or disable) the addition of a unique hash to the file names\n  :ENV: PARSE_SERVER_PRESERVE_FILE_NAME\n  :DEFAULT: false */\n  preserveFileName: ?boolean;\n  /* Personally identifiable information fields in the user table the should be removed for non-authorized users. Deprecated @see protectedFields */\n  userSensitiveFields: ?(string[]);\n  /* Protected fields that should be treated with extra security when fetching details.\n  :DEFAULT: {\"_User\": {\"*\": [\"email\"]}} */\n  protectedFields: ?ProtectedFields;\n  /* Enable (or disable) anonymous users, defaults to true\n  :ENV: PARSE_SERVER_ENABLE_ANON_USERS\n  :DEFAULT: true */\n  enableAnonymousUsers: ?boolean;\n  /* Enable (or disable) client class creation, defaults to true\n  :ENV: PARSE_SERVER_ALLOW_CLIENT_CLASS_CREATION\n  :DEFAULT: true */\n  allowClientClassCreation: ?boolean;\n  /* Enable (or disable) custom objectId\n  :ENV: PARSE_SERVER_ALLOW_CUSTOM_OBJECT_ID\n  :DEFAULT: false */\n  allowCustomObjectId: ?boolean;\n  /* Configuration for your authentication providers, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#oauth-and-3rd-party-authentication\n  :ENV: PARSE_SERVER_AUTH_PROVIDERS */\n  auth: ?any;\n  /* Max file size for uploads, defaults to 20mb\n  :DEFAULT: 20mb */\n  maxUploadSize: ?string;\n  /* Enable (or disable) user email validation, defaults to false\n  :DEFAULT: false */\n  verifyUserEmails: ?boolean;\n  /* Prevent user from login if email is not verified and PARSE_SERVER_VERIFY_USER_EMAILS is true, defaults to false\n  :DEFAULT: false */\n  preventLoginWithUnverifiedEmail: ?boolean;\n  /* Email verification token validity duration, in seconds */\n  emailVerifyTokenValidityDuration: ?number;\n  /* an existing email verify token should be reused when resend verification email is requested\n  :DEFAULT: false */\n  emailVerifyTokenReuseIfValid: ?boolean;\n  /* account lockout policy for failed login attempts */\n  accountLockout: ?AccountLockoutOptions;\n  /* Password policy for enforcing password related rules */\n  passwordPolicy: ?PasswordPolicyOptions;\n  /* Adapter module for the cache */\n  cacheAdapter: ?Adapter<CacheAdapter>;\n  /* Adapter module for email sending */\n  emailAdapter: ?Adapter<MailAdapter>;\n  /* Public URL to your parse server with http:// or https://.\n  :ENV: PARSE_PUBLIC_SERVER_URL */\n  publicServerURL: ?string;\n  /* custom pages for password validation and reset\n  :DEFAULT: {} */\n  customPages: ?CustomPagesOptions;\n  /* parse-server's LiveQuery configuration object */\n  liveQuery: ?LiveQueryOptions;\n  /* Session duration, in seconds, defaults to 1 year\n  :DEFAULT: 31536000 */\n  sessionLength: ?number;\n  /* Max value for limit option on queries, defaults to unlimited */\n  maxLimit: ?number;\n  /* Sets wether we should expire the inactive sessions, defaults to true\n  :DEFAULT: true */\n  expireInactiveSessions: ?boolean;\n  /* When a user changes their password, either through the reset password email or while logged in, all sessions are revoked if this is true. Set to false if you don't want to revoke sessions.\n  :DEFAULT: true */\n  revokeSessionOnPasswordReset: ?boolean;\n  /* The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 5000; set 0 to disable.\n  :DEFAULT: 5000 */\n  schemaCacheTTL: ?number;\n  /* Sets the TTL for the in memory cache (in ms), defaults to 5000 (5 seconds)\n  :DEFAULT: 5000 */\n  cacheTTL: ?number;\n  /* Sets the maximum size for the in memory cache, defaults to 10000\n  :DEFAULT: 10000 */\n  cacheMaxSize: ?number;\n  /* Replace HTTP Interface when using JS SDK in current node runtime, defaults to false. Caution, this is an experimental feature that may not be appropriate for production.\n  :ENV: PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS\n  :DEFAULT: false */\n  directAccess: ?boolean;\n  /* Use a single schema cache shared across requests. Reduces number of queries made to _SCHEMA, defaults to false, i.e. unique schema cache per request.\n  :DEFAULT: false */\n  enableSingleSchemaCache: ?boolean;\n  /* Enables the default express error handler for all errors\n  :DEFAULT: false */\n  enableExpressErrorHandler: ?boolean;\n  /* Sets the number of characters in generated object id's, default 10\n  :DEFAULT: 10 */\n  objectIdSize: ?number;\n  /* The port to run the ParseServer, defaults to 1337.\n  :ENV: PORT\n  :DEFAULT: 1337 */\n  port: ?number;\n  /* The host to serve ParseServer on, defaults to 0.0.0.0\n  :DEFAULT: 0.0.0.0 */\n  host: ?string;\n  /* Mount path for the server, defaults to /parse\n  :DEFAULT: /parse */\n  mountPath: ?string;\n  /* Run with cluster, optionally set the number of processes default to os.cpus().length */\n  cluster: ?NumberOrBoolean;\n  /* middleware for express server, can be string or function */\n  middleware: ?((() => void) | string);\n  /* Starts the liveQuery server */\n  startLiveQueryServer: ?boolean;\n  /* Live query server configuration options (will start the liveQuery server) */\n  liveQueryServerOptions: ?LiveQueryServerOptions;\n  /* Options for request idempotency to deduplicate identical requests that may be caused by network issues. Caution, this is an experimental feature that may not be appropriate for production.\n  :ENV: PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_OPTIONS\n  :DEFAULT: false */\n  idempotencyOptions: ?IdempotencyOptions;\n  /* Full path to your GraphQL custom schema.graphql file */\n  graphQLSchema: ?string;\n  /* Mounts the GraphQL endpoint\n  :ENV: PARSE_SERVER_MOUNT_GRAPHQL\n  :DEFAULT: false */\n  mountGraphQL: ?boolean;\n  /* Mount path for the GraphQL endpoint, defaults to /graphql\n  :ENV: PARSE_SERVER_GRAPHQL_PATH\n  :DEFAULT: /graphql */\n  graphQLPath: ?string;\n  /* Mounts the GraphQL Playground - never use this option in production\n  :ENV: PARSE_SERVER_MOUNT_PLAYGROUND\n  :DEFAULT: false */\n  mountPlayground: ?boolean;\n  /* Mount path for the GraphQL Playground, defaults to /playground\n  :ENV: PARSE_SERVER_PLAYGROUND_PATH\n  :DEFAULT: /playground */\n  playgroundPath: ?string;\n  /* Callback when server has started */\n  serverStartComplete: ?(error: ?Error) => void;\n  /* Callback when server has closed */\n  serverCloseComplete: ?() => void;\n}\n\nexport interface CustomPagesOptions {\n  /* invalid link page path */\n  invalidLink: ?string;\n  /* verify email success page path */\n  verifyEmailSuccess: ?string;\n  /* invalid verification link page path */\n  invalidVerificationLink: ?string;\n  /* verification link send success page path */\n  linkSendSuccess: ?string;\n  /* verification link send fail page path */\n  linkSendFail: ?string;\n  /* choose password page path */\n  choosePassword: ?string;\n  /* password reset success page path */\n  passwordResetSuccess: ?string;\n  /* for masking user-facing pages */\n  parseFrameURL: ?string;\n}\n\nexport interface LiveQueryOptions {\n  /* parse-server's LiveQuery classNames\n  :ENV: PARSE_SERVER_LIVEQUERY_CLASSNAMES */\n  classNames: ?(string[]);\n  /* parse-server's LiveQuery redisOptions */\n  redisOptions: ?any;\n  /* parse-server's LiveQuery redisURL */\n  redisURL: ?string;\n  /* LiveQuery pubsub adapter */\n  pubSubAdapter: ?Adapter<PubSubAdapter>;\n  /* Adapter module for the WebSocketServer */\n  wssAdapter: ?Adapter<WSSAdapter>;\n}\n\nexport interface LiveQueryServerOptions {\n  /* This string should match the appId in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same appId.*/\n  appId: ?string;\n  /* This string should match the masterKey in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same masterKey.*/\n  masterKey: ?string;\n  /* This string should match the serverURL in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same serverURL.*/\n  serverURL: ?string;\n  /* A JSON object that serves as a whitelist of keys. It is used for validating clients when they try to connect to the LiveQuery server. Check the following Security section and our protocol specification for details.*/\n  keyPairs: ?any;\n  /* Number of milliseconds between ping/pong frames. The WebSocket server sends ping/pong frames to the clients to keep the WebSocket alive. This value defines the interval of the ping/pong frame from the server to clients, defaults to 10 * 1000 ms (10 s).*/\n  websocketTimeout: ?number;\n  /* Number in milliseconds. When clients provide the sessionToken to the LiveQuery server, the LiveQuery server will try to fetch its ParseUser's objectId from parse server and store it in the cache. The value defines the duration of the cache. Check the following Security section and our protocol specification for details, defaults to 5 * 1000 ms (5 seconds).*/\n  cacheTimeout: ?number;\n  /* This string defines the log level of the LiveQuery server. We support VERBOSE, INFO, ERROR, NONE, defaults to INFO.*/\n  logLevel: ?string;\n  /* The port to run the LiveQuery server, defaults to 1337.\n  :DEFAULT: 1337 */\n  port: ?number;\n  /* parse-server's LiveQuery redisOptions */\n  redisOptions: ?any;\n  /* parse-server's LiveQuery redisURL */\n  redisURL: ?string;\n  /* LiveQuery pubsub adapter */\n  pubSubAdapter: ?Adapter<PubSubAdapter>;\n  /* Adapter module for the WebSocketServer */\n  wssAdapter: ?Adapter<WSSAdapter>;\n}\n\nexport interface IdempotencyOptions {\n  /* An array of paths for which the feature should be enabled. The mount path must not be included, for example instead of `/parse/functions/myFunction` specifiy `functions/myFunction`. The entries are interpreted as regular expression, for example `functions/.*` matches all functions, `jobs/.*` matches all jobs, `classes/.*` matches all classes, `.*` matches all paths.\n  :DEFAULT: [] */\n  paths: ?(string[]);\n  /* The duration in seconds after which a request record is discarded from the database, defaults to 300s.\n  :DEFAULT: 300 */\n  ttl: ?number;\n}\n\nexport interface AccountLockoutOptions {\n  /* number of minutes that a locked-out account remains locked out before automatically becoming unlocked. */\n  duration: ?number;\n  /* number of failed sign-in attempts that will cause a user account to be locked */\n  threshold: ?number;\n}\n\nexport interface PasswordPolicyOptions {\n  /* a RegExp object or a regex string representing the pattern to enforce */\n  validatorPattern: ?string;\n  /* a callback function to be invoked to validate the password  */\n  validatorCallback: ?() => void;\n  /* disallow username in passwords */\n  doNotAllowUsername: ?boolean;\n  /* days for password expiry */\n  maxPasswordAge: ?number;\n  /* setting to prevent reuse of previous n passwords */\n  maxPasswordHistory: ?number;\n  /* time for token to expire */\n  resetTokenValidityDuration: ?number;\n  /* resend token if it's still valid */\n  resetTokenReuseIfValid: ?boolean;\n}\n"]}
18
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Options/index.js"],"names":[],"mappings":";;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA","sourcesContent":["import { AnalyticsAdapter } from '../Adapters/Analytics/AnalyticsAdapter';\nimport { FilesAdapter } from '../Adapters/Files/FilesAdapter';\nimport { LoggerAdapter } from '../Adapters/Logger/LoggerAdapter';\nimport { StorageAdapter } from '../Adapters/Storage/StorageAdapter';\nimport { CacheAdapter } from '../Adapters/Cache/CacheAdapter';\nimport { MailAdapter } from '../Adapters/Email/MailAdapter';\nimport { PubSubAdapter } from '../Adapters/PubSub/PubSubAdapter';\nimport { WSSAdapter } from '../Adapters/WebSocketServer/WSSAdapter';\n\n// @flow\ntype Adapter<T> = string | any | T;\ntype NumberOrBoolean = number | boolean;\ntype NumberOrString = number | string;\ntype ProtectedFields = any;\ntype RequestKeywordDenylist = {\n  key: string | any,\n  value: any,\n};\n\nexport interface ParseServerOptions {\n  /* Your Parse Application ID\n  :ENV: PARSE_SERVER_APPLICATION_ID */\n  appId: string;\n  /* Your Parse Master Key */\n  masterKey: string;\n  /* URL to your parse server with http:// or https://.\n  :ENV: PARSE_SERVER_URL */\n  serverURL: string;\n  /* Restrict masterKey to be used by only these ips, defaults to [] (allow all ips)\n  :DEFAULT: [] */\n  masterKeyIps: ?(string[]);\n  /* Sets the app name */\n  appName: ?string;\n  /* Add headers to Access-Control-Allow-Headers */\n  allowHeaders: ?(string[]);\n  /* Sets the origin to Access-Control-Allow-Origin */\n  allowOrigin: ?string;\n  /* Adapter module for the analytics */\n  analyticsAdapter: ?Adapter<AnalyticsAdapter>;\n  /* Adapter module for the files sub-system */\n  filesAdapter: ?Adapter<FilesAdapter>;\n  /* Configuration for push, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#push-notifications */\n  push: ?any;\n  /* Configuration for push scheduling, defaults to false.\n  :DEFAULT: false */\n  scheduledPush: ?boolean;\n  /* Adapter module for the logging sub-system */\n  loggerAdapter: ?Adapter<LoggerAdapter>;\n  /* Log as structured JSON objects\n  :ENV: JSON_LOGS */\n  jsonLogs: ?boolean;\n  /* Folder for the logs (defaults to './logs'); set to null to disable file based logging\n  :ENV: PARSE_SERVER_LOGS_FOLDER\n  :DEFAULT: ./logs */\n  logsFolder: ?string;\n  /* Set the logging to verbose\n  :ENV: VERBOSE */\n  verbose: ?boolean;\n  /* Sets the level for logs */\n  logLevel: ?string;\n  /* Maximum number of logs to keep. If not set, no logs will be removed. This can be a number of files or number of days. If using days, add 'd' as the suffix. (default: null) */\n  maxLogFiles: ?NumberOrString;\n  /* Disables console output\n  :ENV: SILENT */\n  silent: ?boolean;\n  /* The full URI to your database. Supported databases are mongodb or postgres.\n  :DEFAULT: mongodb://localhost:27017/parse */\n  databaseURI: string;\n  /* Options to pass to the mongodb client */\n  databaseOptions: ?any;\n  /* Adapter module for the database */\n  databaseAdapter: ?Adapter<StorageAdapter>;\n  /* Full path to your cloud code main.js */\n  cloud: ?string;\n  /* A collection prefix for the classes\n  :DEFAULT: '' */\n  collectionPrefix: ?string;\n  /* Key for iOS, MacOS, tvOS clients */\n  clientKey: ?string;\n  /* Key for the Javascript SDK */\n  javascriptKey: ?string;\n  /* Key for Unity and .Net SDK */\n  dotNetKey: ?string;\n  /* Key for encrypting your files\n  :ENV: PARSE_SERVER_ENCRYPTION_KEY */\n  encryptionKey: ?string;\n  /* Key for REST calls\n  :ENV: PARSE_SERVER_REST_API_KEY */\n  restAPIKey: ?string;\n  /* Read-only key, which has the same capabilities as MasterKey without writes */\n  readOnlyMasterKey: ?string;\n  /* Key sent with outgoing webhook calls */\n  webhookKey: ?string;\n  /* Key for your files */\n  fileKey: ?string;\n  /* Enable (or disable) the addition of a unique hash to the file names\n  :ENV: PARSE_SERVER_PRESERVE_FILE_NAME\n  :DEFAULT: false */\n  preserveFileName: ?boolean;\n  /* Personally identifiable information fields in the user table the should be removed for non-authorized users. Deprecated @see protectedFields */\n  userSensitiveFields: ?(string[]);\n  /* Protected fields that should be treated with extra security when fetching details.\n  :DEFAULT: {\"_User\": {\"*\": [\"email\"]}} */\n  protectedFields: ?ProtectedFields;\n  /* Enable (or disable) anonymous users, defaults to true\n  :ENV: PARSE_SERVER_ENABLE_ANON_USERS\n  :DEFAULT: true */\n  enableAnonymousUsers: ?boolean;\n  /* Enable (or disable) client class creation, defaults to true\n  :ENV: PARSE_SERVER_ALLOW_CLIENT_CLASS_CREATION\n  :DEFAULT: true */\n  allowClientClassCreation: ?boolean;\n  /* Enable (or disable) custom objectId\n  :ENV: PARSE_SERVER_ALLOW_CUSTOM_OBJECT_ID\n  :DEFAULT: false */\n  allowCustomObjectId: ?boolean;\n  /* Configuration for your authentication providers, as stringified JSON. See http://docs.parseplatform.org/parse-server/guide/#oauth-and-3rd-party-authentication\n  :ENV: PARSE_SERVER_AUTH_PROVIDERS */\n  auth: ?any;\n  /* Max file size for uploads, defaults to 20mb\n  :DEFAULT: 20mb */\n  maxUploadSize: ?string;\n  /* Enable (or disable) user email validation, defaults to false\n  :DEFAULT: false */\n  verifyUserEmails: ?boolean;\n  /* Prevent user from login if email is not verified and PARSE_SERVER_VERIFY_USER_EMAILS is true, defaults to false\n  :DEFAULT: false */\n  preventLoginWithUnverifiedEmail: ?boolean;\n  /* Email verification token validity duration, in seconds */\n  emailVerifyTokenValidityDuration: ?number;\n  /* an existing email verify token should be reused when resend verification email is requested\n  :DEFAULT: false */\n  emailVerifyTokenReuseIfValid: ?boolean;\n  /* account lockout policy for failed login attempts */\n  accountLockout: ?AccountLockoutOptions;\n  /* Password policy for enforcing password related rules */\n  passwordPolicy: ?PasswordPolicyOptions;\n  /* Adapter module for the cache */\n  cacheAdapter: ?Adapter<CacheAdapter>;\n  /* Adapter module for email sending */\n  emailAdapter: ?Adapter<MailAdapter>;\n  /* Public URL to your parse server with http:// or https://.\n  :ENV: PARSE_PUBLIC_SERVER_URL */\n  publicServerURL: ?string;\n  /* custom pages for password validation and reset\n  :DEFAULT: {} */\n  customPages: ?CustomPagesOptions;\n  /* parse-server's LiveQuery configuration object */\n  liveQuery: ?LiveQueryOptions;\n  /* Session duration, in seconds, defaults to 1 year\n  :DEFAULT: 31536000 */\n  sessionLength: ?number;\n  /* Max value for limit option on queries, defaults to unlimited */\n  maxLimit: ?number;\n  /* Sets wether we should expire the inactive sessions, defaults to true\n  :DEFAULT: true */\n  expireInactiveSessions: ?boolean;\n  /* When a user changes their password, either through the reset password email or while logged in, all sessions are revoked if this is true. Set to false if you don't want to revoke sessions.\n  :DEFAULT: true */\n  revokeSessionOnPasswordReset: ?boolean;\n  /* The TTL for caching the schema for optimizing read/write operations. You should put a long TTL when your DB is in production. default to 5000; set 0 to disable.\n  :DEFAULT: 5000 */\n  schemaCacheTTL: ?number;\n  /* Sets the TTL for the in memory cache (in ms), defaults to 5000 (5 seconds)\n  :DEFAULT: 5000 */\n  cacheTTL: ?number;\n  /* Sets the maximum size for the in memory cache, defaults to 10000\n  :DEFAULT: 10000 */\n  cacheMaxSize: ?number;\n  /* Replace HTTP Interface when using JS SDK in current node runtime, defaults to false. Caution, this is an experimental feature that may not be appropriate for production.\n  :ENV: PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS\n  :DEFAULT: false */\n  directAccess: ?boolean;\n  /* Use a single schema cache shared across requests. Reduces number of queries made to _SCHEMA, defaults to false, i.e. unique schema cache per request.\n  :DEFAULT: false */\n  enableSingleSchemaCache: ?boolean;\n  /* Enables the default express error handler for all errors\n  :DEFAULT: false */\n  enableExpressErrorHandler: ?boolean;\n  /* Sets the number of characters in generated object id's, default 10\n  :DEFAULT: 10 */\n  objectIdSize: ?number;\n  /* The port to run the ParseServer, defaults to 1337.\n  :ENV: PORT\n  :DEFAULT: 1337 */\n  port: ?number;\n  /* The host to serve ParseServer on, defaults to 0.0.0.0\n  :DEFAULT: 0.0.0.0 */\n  host: ?string;\n  /* Mount path for the server, defaults to /parse\n  :DEFAULT: /parse */\n  mountPath: ?string;\n  /* Run with cluster, optionally set the number of processes default to os.cpus().length */\n  cluster: ?NumberOrBoolean;\n  /* middleware for express server, can be string or function */\n  middleware: ?((() => void) | string);\n  /* Starts the liveQuery server */\n  startLiveQueryServer: ?boolean;\n  /* Live query server configuration options (will start the liveQuery server) */\n  liveQueryServerOptions: ?LiveQueryServerOptions;\n  /* Options for request idempotency to deduplicate identical requests that may be caused by network issues. Caution, this is an experimental feature that may not be appropriate for production.\n  :ENV: PARSE_SERVER_EXPERIMENTAL_IDEMPOTENCY_OPTIONS\n  :DEFAULT: false */\n  idempotencyOptions: ?IdempotencyOptions;\n  /* Full path to your GraphQL custom schema.graphql file */\n  graphQLSchema: ?string;\n  /* Mounts the GraphQL endpoint\n  :ENV: PARSE_SERVER_MOUNT_GRAPHQL\n  :DEFAULT: false */\n  mountGraphQL: ?boolean;\n  /* Mount path for the GraphQL endpoint, defaults to /graphql\n  :ENV: PARSE_SERVER_GRAPHQL_PATH\n  :DEFAULT: /graphql */\n  graphQLPath: ?string;\n  /* Mounts the GraphQL Playground - never use this option in production\n  :ENV: PARSE_SERVER_MOUNT_PLAYGROUND\n  :DEFAULT: false */\n  mountPlayground: ?boolean;\n  /* Mount path for the GraphQL Playground, defaults to /playground\n  :ENV: PARSE_SERVER_PLAYGROUND_PATH\n  :DEFAULT: /playground */\n  playgroundPath: ?string;\n  /* Callback when server has started */\n  serverStartComplete: ?(error: ?Error) => void;\n  /* Callback when server has closed */\n  serverCloseComplete: ?() => void;\n  /* An array of keys and values that are prohibited in database read and write requests to prevent potential security vulnerabilities. It is possible to specify only a key (`{\"key\":\"...\"}`), only a value (`{\"value\":\"...\"}`) or a key-value pair (`{\"key\":\"...\",\"value\":\"...\"}`). The specification can use the following types: `boolean`, `numeric` or `string`, where `string` will be interpreted as a regex notation. Request data is deep-scanned for matching definitions to detect also any nested occurrences. Defaults are patterns that are likely to be used in malicious requests. Setting this option will override the default patterns.\n  :DEFAULT: [{\"key\":\"_bsontype\",\"value\":\"Code\"},{\"key\":\"constructor\"},{\"key\":\"__proto__\"}] */\n  requestKeywordDenylist: ?(RequestKeywordDenylist[]);\n}\n\nexport interface CustomPagesOptions {\n  /* invalid link page path */\n  invalidLink: ?string;\n  /* verify email success page path */\n  verifyEmailSuccess: ?string;\n  /* invalid verification link page path */\n  invalidVerificationLink: ?string;\n  /* verification link send success page path */\n  linkSendSuccess: ?string;\n  /* verification link send fail page path */\n  linkSendFail: ?string;\n  /* choose password page path */\n  choosePassword: ?string;\n  /* password reset success page path */\n  passwordResetSuccess: ?string;\n  /* for masking user-facing pages */\n  parseFrameURL: ?string;\n}\n\nexport interface LiveQueryOptions {\n  /* parse-server's LiveQuery classNames\n  :ENV: PARSE_SERVER_LIVEQUERY_CLASSNAMES */\n  classNames: ?(string[]);\n  /* parse-server's LiveQuery redisOptions */\n  redisOptions: ?any;\n  /* parse-server's LiveQuery redisURL */\n  redisURL: ?string;\n  /* LiveQuery pubsub adapter */\n  pubSubAdapter: ?Adapter<PubSubAdapter>;\n  /* Adapter module for the WebSocketServer */\n  wssAdapter: ?Adapter<WSSAdapter>;\n}\n\nexport interface LiveQueryServerOptions {\n  /* This string should match the appId in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same appId.*/\n  appId: ?string;\n  /* This string should match the masterKey in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same masterKey.*/\n  masterKey: ?string;\n  /* This string should match the serverURL in use by your Parse Server. If you deploy the LiveQuery server alongside Parse Server, the LiveQuery server will try to use the same serverURL.*/\n  serverURL: ?string;\n  /* A JSON object that serves as a whitelist of keys. It is used for validating clients when they try to connect to the LiveQuery server. Check the following Security section and our protocol specification for details.*/\n  keyPairs: ?any;\n  /* Number of milliseconds between ping/pong frames. The WebSocket server sends ping/pong frames to the clients to keep the WebSocket alive. This value defines the interval of the ping/pong frame from the server to clients, defaults to 10 * 1000 ms (10 s).*/\n  websocketTimeout: ?number;\n  /* Number in milliseconds. When clients provide the sessionToken to the LiveQuery server, the LiveQuery server will try to fetch its ParseUser's objectId from parse server and store it in the cache. The value defines the duration of the cache. Check the following Security section and our protocol specification for details, defaults to 5 * 1000 ms (5 seconds).*/\n  cacheTimeout: ?number;\n  /* This string defines the log level of the LiveQuery server. We support VERBOSE, INFO, ERROR, NONE, defaults to INFO.*/\n  logLevel: ?string;\n  /* The port to run the LiveQuery server, defaults to 1337.\n  :DEFAULT: 1337 */\n  port: ?number;\n  /* parse-server's LiveQuery redisOptions */\n  redisOptions: ?any;\n  /* parse-server's LiveQuery redisURL */\n  redisURL: ?string;\n  /* LiveQuery pubsub adapter */\n  pubSubAdapter: ?Adapter<PubSubAdapter>;\n  /* Adapter module for the WebSocketServer */\n  wssAdapter: ?Adapter<WSSAdapter>;\n}\n\nexport interface IdempotencyOptions {\n  /* An array of paths for which the feature should be enabled. The mount path must not be included, for example instead of `/parse/functions/myFunction` specifiy `functions/myFunction`. The entries are interpreted as regular expression, for example `functions/.*` matches all functions, `jobs/.*` matches all jobs, `classes/.*` matches all classes, `.*` matches all paths.\n  :DEFAULT: [] */\n  paths: ?(string[]);\n  /* The duration in seconds after which a request record is discarded from the database, defaults to 300s.\n  :DEFAULT: 300 */\n  ttl: ?number;\n}\n\nexport interface AccountLockoutOptions {\n  /* number of minutes that a locked-out account remains locked out before automatically becoming unlocked. */\n  duration: ?number;\n  /* number of failed sign-in attempts that will cause a user account to be locked */\n  threshold: ?number;\n}\n\nexport interface PasswordPolicyOptions {\n  /* a RegExp object or a regex string representing the pattern to enforce */\n  validatorPattern: ?string;\n  /* a callback function to be invoked to validate the password  */\n  validatorCallback: ?() => void;\n  /* disallow username in passwords */\n  doNotAllowUsername: ?boolean;\n  /* days for password expiry */\n  maxPasswordAge: ?number;\n  /* setting to prevent reuse of previous n passwords */\n  maxPasswordHistory: ?number;\n  /* time for token to expire */\n  resetTokenValidityDuration: ?number;\n  /* resend token if it's still valid */\n  resetTokenReuseIfValid: ?boolean;\n}\n"]}