parse-server 4.10.4 → 5.0.0-alpha.12

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.
Files changed (134) hide show
  1. package/README.md +461 -157
  2. package/lib/AccountLockout.js +23 -2
  3. package/lib/Adapters/AdapterLoader.js +1 -1
  4. package/lib/Adapters/Analytics/AnalyticsAdapter.js +1 -1
  5. package/lib/Adapters/Auth/AuthAdapter.js +1 -1
  6. package/lib/Adapters/Auth/OAuth1Client.js +1 -1
  7. package/lib/Adapters/Auth/facebook.js +110 -10
  8. package/lib/Adapters/Auth/gcenter.js +1 -1
  9. package/lib/Adapters/Auth/gpgames.js +1 -1
  10. package/lib/Adapters/Auth/instagram.js +4 -2
  11. package/lib/Adapters/Auth/keycloak.js +1 -1
  12. package/lib/Adapters/Auth/ldap.js +3 -1
  13. package/lib/Adapters/Auth/oauth2.js +1 -1
  14. package/lib/Adapters/Auth/phantauth.js +1 -1
  15. package/lib/Adapters/Cache/CacheAdapter.js +1 -1
  16. package/lib/Adapters/Cache/RedisCacheAdapter.js +143 -0
  17. package/lib/Adapters/Cache/SchemaCache.js +31 -0
  18. package/lib/Adapters/Email/MailAdapter.js +1 -1
  19. package/lib/Adapters/Files/FilesAdapter.js +1 -1
  20. package/lib/Adapters/Files/GridFSBucketAdapter.js +1 -1
  21. package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
  22. package/lib/Adapters/Logger/LoggerAdapter.js +1 -1
  23. package/lib/Adapters/Logger/WinstonLogger.js +4 -4
  24. package/lib/Adapters/PubSub/EventEmitterPubSub.js +5 -1
  25. package/lib/Adapters/PubSub/PubSubAdapter.js +1 -1
  26. package/lib/Adapters/Push/PushAdapter.js +1 -1
  27. package/lib/Adapters/Storage/Mongo/MongoCollection.js +1 -1
  28. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +21 -3
  29. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +43 -11
  30. package/lib/Adapters/Storage/Mongo/MongoTransform.js +9 -6
  31. package/lib/Adapters/Storage/Postgres/PostgresClient.js +11 -1
  32. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +107 -62
  33. package/lib/Adapters/WebSocketServer/WSAdapter.js +1 -1
  34. package/lib/Adapters/WebSocketServer/WSSAdapter.js +1 -1
  35. package/lib/Auth.js +2 -39
  36. package/lib/Config.js +201 -8
  37. package/lib/Controllers/AdaptableController.js +1 -9
  38. package/lib/Controllers/CacheController.js +1 -1
  39. package/lib/Controllers/DatabaseController.js +166 -45
  40. package/lib/Controllers/FilesController.js +1 -1
  41. package/lib/Controllers/HooksController.js +2 -2
  42. package/lib/Controllers/LiveQueryController.js +16 -3
  43. package/lib/Controllers/LoggerController.js +1 -1
  44. package/lib/Controllers/ParseGraphQLController.js +2 -2
  45. package/lib/Controllers/PushController.js +1 -1
  46. package/lib/Controllers/SchemaController.js +114 -93
  47. package/lib/Controllers/UserController.js +16 -5
  48. package/lib/Controllers/index.js +10 -11
  49. package/lib/Deprecator/Deprecations.js +28 -0
  50. package/lib/Deprecator/Deprecator.js +135 -0
  51. package/lib/GraphQL/ParseGraphQLSchema.js +71 -39
  52. package/lib/GraphQL/ParseGraphQLServer.js +3 -3
  53. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +2 -2
  54. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +2 -2
  55. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +4 -7
  56. package/lib/GraphQL/loaders/defaultRelaySchema.js +3 -3
  57. package/lib/GraphQL/loaders/filesMutations.js +2 -2
  58. package/lib/GraphQL/loaders/functionsMutations.js +9 -5
  59. package/lib/GraphQL/loaders/parseClassMutations.js +21 -9
  60. package/lib/GraphQL/loaders/parseClassQueries.js +9 -6
  61. package/lib/GraphQL/loaders/parseClassTypes.js +5 -5
  62. package/lib/GraphQL/loaders/schemaDirectives.js +1 -1
  63. package/lib/GraphQL/loaders/schemaMutations.js +8 -6
  64. package/lib/GraphQL/loaders/schemaQueries.js +6 -4
  65. package/lib/GraphQL/loaders/usersMutations.js +65 -7
  66. package/lib/GraphQL/transformers/constraintType.js +2 -2
  67. package/lib/GraphQL/transformers/inputType.js +2 -2
  68. package/lib/GraphQL/transformers/mutation.js +45 -10
  69. package/lib/GraphQL/transformers/outputType.js +2 -2
  70. package/lib/GraphQL/transformers/query.js +2 -2
  71. package/lib/GraphQL/transformers/schemaFields.js +1 -1
  72. package/lib/KeyPromiseQueue.js +59 -0
  73. package/lib/LiveQuery/Client.js +1 -1
  74. package/lib/LiveQuery/Id.js +1 -1
  75. package/lib/LiveQuery/ParseLiveQueryServer.js +144 -38
  76. package/lib/LiveQuery/ParseWebSocketServer.js +2 -2
  77. package/lib/LiveQuery/QueryTools.js +50 -1
  78. package/lib/LiveQuery/equalObjects.js +1 -1
  79. package/lib/Options/Definitions.js +256 -33
  80. package/lib/Options/docs.js +79 -21
  81. package/lib/Options/index.js +3 -1
  82. package/lib/Page.js +53 -0
  83. package/lib/ParseServer.js +40 -16
  84. package/lib/ParseServerRESTController.js +55 -45
  85. package/lib/PromiseRouter.js +7 -20
  86. package/lib/Push/PushQueue.js +1 -1
  87. package/lib/Push/PushWorker.js +2 -2
  88. package/lib/Push/utils.js +1 -1
  89. package/lib/RestQuery.js +44 -8
  90. package/lib/RestWrite.js +60 -10
  91. package/lib/Routers/AggregateRouter.js +23 -18
  92. package/lib/Routers/AudiencesRouter.js +2 -2
  93. package/lib/Routers/ClassesRouter.js +11 -11
  94. package/lib/Routers/CloudCodeRouter.js +1 -1
  95. package/lib/Routers/FeaturesRouter.js +2 -2
  96. package/lib/Routers/FilesRouter.js +34 -7
  97. package/lib/Routers/FunctionsRouter.js +2 -2
  98. package/lib/Routers/GlobalConfigRouter.js +2 -2
  99. package/lib/Routers/GraphQLRouter.js +3 -3
  100. package/lib/Routers/HooksRouter.js +2 -2
  101. package/lib/Routers/LogsRouter.js +2 -2
  102. package/lib/Routers/PagesRouter.js +722 -0
  103. package/lib/Routers/PurgeRouter.js +2 -2
  104. package/lib/Routers/PushRouter.js +3 -3
  105. package/lib/Routers/SchemasRouter.js +43 -16
  106. package/lib/Routers/SecurityRouter.js +47 -0
  107. package/lib/Routers/SessionsRouter.js +4 -2
  108. package/lib/Routers/UsersRouter.js +88 -17
  109. package/lib/SchemaMigrations/DefinedSchemas.js +421 -0
  110. package/lib/SchemaMigrations/Migrations.js +36 -0
  111. package/lib/Security/Check.js +118 -0
  112. package/lib/Security/CheckGroup.js +54 -0
  113. package/lib/Security/CheckGroups/CheckGroupDatabase.js +57 -0
  114. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +82 -0
  115. package/lib/Security/CheckGroups/CheckGroups.js +24 -0
  116. package/lib/Security/CheckRunner.js +236 -0
  117. package/lib/StatusHandler.js +27 -36
  118. package/lib/TestUtils.js +1 -1
  119. package/lib/Utils.js +226 -0
  120. package/lib/batch.js +55 -44
  121. package/lib/cli/utils/commander.js +8 -3
  122. package/lib/cloud-code/HTTPResponse.js +1 -1
  123. package/lib/cloud-code/Parse.Cloud.js +155 -19
  124. package/lib/cloud-code/httpRequest.js +1 -1
  125. package/lib/index.js +10 -12
  126. package/lib/middlewares.js +39 -4
  127. package/lib/rest.js +4 -4
  128. package/lib/triggers.js +134 -121
  129. package/lib/vendor/mongodbUrl.js +8 -10
  130. package/package.json +60 -39
  131. package/CHANGELOG.md +0 -1780
  132. package/lib/Adapters/Cache/RedisCacheAdapter/KeyPromiseQueue.js +0 -59
  133. package/lib/Adapters/Cache/RedisCacheAdapter/index.js +0 -130
  134. package/lib/Controllers/SchemaCache.js +0 -75
@@ -41,6 +41,8 @@ var _LogsRouter = require("./Routers/LogsRouter");
41
41
 
42
42
  var _ParseLiveQueryServer = require("./LiveQuery/ParseLiveQueryServer");
43
43
 
44
+ var _PagesRouter = require("./Routers/PagesRouter");
45
+
44
46
  var _PublicAPIRouter = require("./Routers/PublicAPIRouter");
45
47
 
46
48
  var _PushRouter = require("./Routers/PushRouter");
@@ -67,9 +69,17 @@ var controllers = _interopRequireWildcard(require("./Controllers"));
67
69
 
68
70
  var _ParseGraphQLServer = require("./GraphQL/ParseGraphQLServer");
69
71
 
70
- function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
72
+ var _SecurityRouter = require("./Routers/SecurityRouter");
73
+
74
+ var _CheckRunner = _interopRequireDefault(require("./Security/CheckRunner"));
75
+
76
+ var _Deprecator = _interopRequireDefault(require("./Deprecator/Deprecator"));
77
+
78
+ var _DefinedSchemas = require("./SchemaMigrations/DefinedSchemas");
71
79
 
72
- function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
80
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
81
+
82
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
73
83
 
74
84
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
75
85
 
@@ -95,14 +105,20 @@ class ParseServer {
95
105
  * @param {ParseServerOptions} options the parse server initialization options
96
106
  */
97
107
  constructor(options) {
108
+ // Scan for deprecated Parse Server options
109
+ _Deprecator.default.scanParseServerOptions(options); // Set option defaults
110
+
111
+
98
112
  injectDefaults(options);
99
113
  const {
100
114
  appId = (0, _requiredParameter.default)('You must provide an appId!'),
101
115
  masterKey = (0, _requiredParameter.default)('You must provide a masterKey!'),
102
116
  cloud,
117
+ security,
103
118
  javascriptKey,
104
119
  serverURL = (0, _requiredParameter.default)('You must provide a serverURL!'),
105
- serverStartComplete
120
+ serverStartComplete,
121
+ schema
106
122
  } = options; // Initialize the node client SDK automatically
107
123
 
108
124
  Parse.initialize(appId, javascriptKey || 'unused', masterKey);
@@ -114,11 +130,13 @@ class ParseServer {
114
130
  hooksController
115
131
  } = allControllers;
116
132
  this.config = _Config.default.put(Object.assign({}, options, allControllers));
117
- logging.setLogger(loggerController);
118
- const dbInitPromise = databaseController.performInitialization();
119
- const hooksLoadPromise = hooksController.load(); // Note: Tests will start to fail if any validation happens after this is called.
133
+ logging.setLogger(loggerController); // Note: Tests will start to fail if any validation happens after this is called.
134
+
135
+ databaseController.performInitialization().then(() => hooksController.load()).then(async () => {
136
+ if (schema) {
137
+ await new _DefinedSchemas.DefinedSchemas(schema, this.config).execute();
138
+ }
120
139
 
121
- Promise.all([dbInitPromise, hooksLoadPromise]).then(() => {
122
140
  if (serverStartComplete) {
123
141
  serverStartComplete();
124
142
  }
@@ -142,6 +160,10 @@ class ParseServer {
142
160
  throw "argument 'cloud' must either be a string or a function";
143
161
  }
144
162
  }
163
+
164
+ if (security && security.enableCheck && security.enableCheckLog) {
165
+ new _CheckRunner.default(options.security).run();
166
+ }
145
167
  }
146
168
 
147
169
  get app() {
@@ -190,13 +212,15 @@ class ParseServer {
190
212
  * @param {Object} options let you specify the maxUploadSize when creating the express app */
191
213
 
192
214
 
193
- static app({
194
- maxUploadSize = '20mb',
195
- appId,
196
- directAccess
197
- }) {
198
- // This app serves the Parse API directly.
215
+ static app(options) {
216
+ const {
217
+ maxUploadSize = '20mb',
218
+ appId,
219
+ directAccess,
220
+ pages
221
+ } = options; // This app serves the Parse API directly.
199
222
  // It's the equivalent of https://api.parse.com/1 in the hosted Parse API.
223
+
200
224
  var api = express(); //api.use("/apps", express.static(__dirname + "/public"));
201
225
 
202
226
  api.use(middlewares.allowCrossDomain(appId)); // File handling needs to be before default middlewares are applied
@@ -211,7 +235,7 @@ class ParseServer {
211
235
  });
212
236
  api.use('/', bodyParser.urlencoded({
213
237
  extended: false
214
- }), new _PublicAPIRouter.PublicAPIRouter().expressRouter());
238
+ }), pages.enableRouter ? new _PagesRouter.PagesRouter(pages).expressRouter() : new _PublicAPIRouter.PublicAPIRouter().expressRouter());
215
239
  api.use(bodyParser.json({
216
240
  type: '*/*',
217
241
  limit: maxUploadSize
@@ -255,7 +279,7 @@ class ParseServer {
255
279
  static promiseRouter({
256
280
  appId
257
281
  }) {
258
- const routers = [new _ClassesRouter.ClassesRouter(), new _UsersRouter.UsersRouter(), new _SessionsRouter.SessionsRouter(), new _RolesRouter.RolesRouter(), new _AnalyticsRouter.AnalyticsRouter(), new _InstallationsRouter.InstallationsRouter(), new _FunctionsRouter.FunctionsRouter(), new _SchemasRouter.SchemasRouter(), new _PushRouter.PushRouter(), new _LogsRouter.LogsRouter(), new _IAPValidationRouter.IAPValidationRouter(), new _FeaturesRouter.FeaturesRouter(), new _GlobalConfigRouter.GlobalConfigRouter(), new _GraphQLRouter.GraphQLRouter(), new _PurgeRouter.PurgeRouter(), new _HooksRouter.HooksRouter(), new _CloudCodeRouter.CloudCodeRouter(), new _AudiencesRouter.AudiencesRouter(), new _AggregateRouter.AggregateRouter()];
282
+ const routers = [new _ClassesRouter.ClassesRouter(), new _UsersRouter.UsersRouter(), new _SessionsRouter.SessionsRouter(), new _RolesRouter.RolesRouter(), new _AnalyticsRouter.AnalyticsRouter(), new _InstallationsRouter.InstallationsRouter(), new _FunctionsRouter.FunctionsRouter(), new _SchemasRouter.SchemasRouter(), new _PushRouter.PushRouter(), new _LogsRouter.LogsRouter(), new _IAPValidationRouter.IAPValidationRouter(), new _FeaturesRouter.FeaturesRouter(), new _GlobalConfigRouter.GlobalConfigRouter(), new _GraphQLRouter.GraphQLRouter(), new _PurgeRouter.PurgeRouter(), new _HooksRouter.HooksRouter(), new _CloudCodeRouter.CloudCodeRouter(), new _AudiencesRouter.AudiencesRouter(), new _AggregateRouter.AggregateRouter(), new _SecurityRouter.SecurityRouter()];
259
283
  const routes = routers.reduce((memo, router) => {
260
284
  return memo.concat(router.routes);
261
285
  }, []);
@@ -492,4 +516,4 @@ function configureListeners(parseServer) {
492
516
 
493
517
  var _default = ParseServer;
494
518
  exports.default = _default;
495
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ParseServer.js"],"names":["batch","require","bodyParser","express","middlewares","Parse","parse","path","fs","addParseCloud","ParseServer","constructor","options","injectDefaults","appId","masterKey","cloud","javascriptKey","serverURL","serverStartComplete","initialize","allControllers","controllers","getControllers","loggerController","databaseController","hooksController","config","Config","put","Object","assign","logging","setLogger","dbInitPromise","performInitialization","hooksLoadPromise","load","Promise","all","then","catch","error","console","process","exit","resolve","cwd","app","_app","handleShutdown","promises","adapter","databaseAdapter","push","fileAdapter","filesController","cacheAdapter","cacheController","length","serverCloseComplete","maxUploadSize","directAccess","api","use","allowCrossDomain","FilesRouter","expressRouter","req","res","json","status","urlencoded","extended","PublicAPIRouter","type","limit","allowMethodOverride","handleParseHeaders","appRouter","promiseRouter","handleParseErrors","env","TESTING","on","err","code","stderr","write","port","verifyServerUrl","PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS","CoreManager","setRESTController","routers","ClassesRouter","UsersRouter","SessionsRouter","RolesRouter","AnalyticsRouter","InstallationsRouter","FunctionsRouter","SchemasRouter","PushRouter","LogsRouter","IAPValidationRouter","FeaturesRouter","GlobalConfigRouter","GraphQLRouter","PurgeRouter","HooksRouter","CloudCodeRouter","AudiencesRouter","AggregateRouter","routes","reduce","memo","router","concat","PromiseRouter","mountOnto","start","callback","middleware","mountPath","mountGraphQL","mountPlayground","graphQLCustomTypeDefs","undefined","graphQLSchema","readFileSync","parseGraphQLServer","ParseGraphQLServer","graphQLPath","playgroundPath","applyGraphQL","applyPlayground","server","listen","host","startLiveQueryServer","liveQueryServerOptions","liveQueryServer","createLiveQueryServer","configureListeners","expressApp","parseServer","httpServer","createServer","ParseLiveQueryServer","request","url","replace","response","data","warn","ParseCloud","Cloud","global","keys","defaults","forEach","key","prototype","hasOwnProperty","call","regex","match","userSensitiveFields","Array","from","Set","protectedFields","_User","c","cur","r","unq","masterKeyIps","sockets","socket","socketId","remoteAddress","remotePort","destroyAliveConnections","destroy","e","stdout","close"],"mappings":"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","sourcesContent":["// ParseServer - open-source compatible API Server for Parse apps\n\nvar batch = require('./batch'),\n  bodyParser = require('body-parser'),\n  express = require('express'),\n  middlewares = require('./middlewares'),\n  Parse = require('parse/node').Parse,\n  { parse } = require('graphql'),\n  path = require('path'),\n  fs = require('fs');\n\nimport { ParseServerOptions, LiveQueryServerOptions } from './Options';\nimport defaults from './defaults';\nimport * as logging from './logger';\nimport Config from './Config';\nimport PromiseRouter from './PromiseRouter';\nimport requiredParameter from './requiredParameter';\nimport { AnalyticsRouter } from './Routers/AnalyticsRouter';\nimport { ClassesRouter } from './Routers/ClassesRouter';\nimport { FeaturesRouter } from './Routers/FeaturesRouter';\nimport { FilesRouter } from './Routers/FilesRouter';\nimport { FunctionsRouter } from './Routers/FunctionsRouter';\nimport { GlobalConfigRouter } from './Routers/GlobalConfigRouter';\nimport { GraphQLRouter } from './Routers/GraphQLRouter';\nimport { HooksRouter } from './Routers/HooksRouter';\nimport { IAPValidationRouter } from './Routers/IAPValidationRouter';\nimport { InstallationsRouter } from './Routers/InstallationsRouter';\nimport { LogsRouter } from './Routers/LogsRouter';\nimport { ParseLiveQueryServer } from './LiveQuery/ParseLiveQueryServer';\nimport { PublicAPIRouter } from './Routers/PublicAPIRouter';\nimport { PushRouter } from './Routers/PushRouter';\nimport { CloudCodeRouter } from './Routers/CloudCodeRouter';\nimport { RolesRouter } from './Routers/RolesRouter';\nimport { SchemasRouter } from './Routers/SchemasRouter';\nimport { SessionsRouter } from './Routers/SessionsRouter';\nimport { UsersRouter } from './Routers/UsersRouter';\nimport { PurgeRouter } from './Routers/PurgeRouter';\nimport { AudiencesRouter } from './Routers/AudiencesRouter';\nimport { AggregateRouter } from './Routers/AggregateRouter';\nimport { ParseServerRESTController } from './ParseServerRESTController';\nimport * as controllers from './Controllers';\nimport { ParseGraphQLServer } from './GraphQL/ParseGraphQLServer';\n\n// Mutate the Parse object to add the Cloud Code handlers\naddParseCloud();\n\n// ParseServer works like a constructor of an express app.\n// https://parseplatform.org/parse-server/api/master/ParseServerOptions.html\nclass ParseServer {\n  /**\n   * @constructor\n   * @param {ParseServerOptions} options the parse server initialization options\n   */\n  constructor(options: ParseServerOptions) {\n    injectDefaults(options);\n    const {\n      appId = requiredParameter('You must provide an appId!'),\n      masterKey = requiredParameter('You must provide a masterKey!'),\n      cloud,\n      javascriptKey,\n      serverURL = requiredParameter('You must provide a serverURL!'),\n      serverStartComplete,\n    } = options;\n    // Initialize the node client SDK automatically\n    Parse.initialize(appId, javascriptKey || 'unused', masterKey);\n    Parse.serverURL = serverURL;\n\n    const allControllers = controllers.getControllers(options);\n\n    const { loggerController, databaseController, hooksController } = allControllers;\n    this.config = Config.put(Object.assign({}, options, allControllers));\n\n    logging.setLogger(loggerController);\n    const dbInitPromise = databaseController.performInitialization();\n    const hooksLoadPromise = hooksController.load();\n\n    // Note: Tests will start to fail if any validation happens after this is called.\n    Promise.all([dbInitPromise, hooksLoadPromise])\n      .then(() => {\n        if (serverStartComplete) {\n          serverStartComplete();\n        }\n      })\n      .catch(error => {\n        if (serverStartComplete) {\n          serverStartComplete(error);\n        } else {\n          console.error(error);\n          process.exit(1);\n        }\n      });\n\n    if (cloud) {\n      addParseCloud();\n      if (typeof cloud === 'function') {\n        cloud(Parse);\n      } else if (typeof cloud === 'string') {\n        require(path.resolve(process.cwd(), cloud));\n      } else {\n        throw \"argument 'cloud' must either be a string or a function\";\n      }\n    }\n  }\n\n  get app() {\n    if (!this._app) {\n      this._app = ParseServer.app(this.config);\n    }\n    return this._app;\n  }\n\n  handleShutdown() {\n    const promises = [];\n    const { adapter: databaseAdapter } = this.config.databaseController;\n    if (databaseAdapter && typeof databaseAdapter.handleShutdown === 'function') {\n      promises.push(databaseAdapter.handleShutdown());\n    }\n    const { adapter: fileAdapter } = this.config.filesController;\n    if (fileAdapter && typeof fileAdapter.handleShutdown === 'function') {\n      promises.push(fileAdapter.handleShutdown());\n    }\n    const { adapter: cacheAdapter } = this.config.cacheController;\n    if (cacheAdapter && typeof cacheAdapter.handleShutdown === 'function') {\n      promises.push(cacheAdapter.handleShutdown());\n    }\n    return (promises.length > 0 ? Promise.all(promises) : Promise.resolve()).then(() => {\n      if (this.config.serverCloseComplete) {\n        this.config.serverCloseComplete();\n      }\n    });\n  }\n\n  /**\n   * @static\n   * Create an express app for the parse server\n   * @param {Object} options let you specify the maxUploadSize when creating the express app  */\n  static app({ maxUploadSize = '20mb', appId, directAccess }) {\n    // This app serves the Parse API directly.\n    // It's the equivalent of https://api.parse.com/1 in the hosted Parse API.\n    var api = express();\n    //api.use(\"/apps\", express.static(__dirname + \"/public\"));\n    api.use(middlewares.allowCrossDomain(appId));\n    // File handling needs to be before default middlewares are applied\n    api.use(\n      '/',\n      new FilesRouter().expressRouter({\n        maxUploadSize: maxUploadSize,\n      })\n    );\n\n    api.use('/health', function (req, res) {\n      res.json({\n        status: 'ok',\n      });\n    });\n\n    api.use('/', bodyParser.urlencoded({ extended: false }), new PublicAPIRouter().expressRouter());\n\n    api.use(bodyParser.json({ type: '*/*', limit: maxUploadSize }));\n    api.use(middlewares.allowMethodOverride);\n    api.use(middlewares.handleParseHeaders);\n\n    const appRouter = ParseServer.promiseRouter({ appId });\n    api.use(appRouter.expressRouter());\n\n    api.use(middlewares.handleParseErrors);\n\n    // run the following when not testing\n    if (!process.env.TESTING) {\n      //This causes tests to spew some useless warnings, so disable in test\n      /* istanbul ignore next */\n      process.on('uncaughtException', err => {\n        if (err.code === 'EADDRINUSE') {\n          // user-friendly message for this common error\n          process.stderr.write(`Unable to listen on port ${err.port}. The port is already in use.`);\n          process.exit(0);\n        } else {\n          throw err;\n        }\n      });\n      // verify the server url after a 'mount' event is received\n      /* istanbul ignore next */\n      api.on('mount', function () {\n        ParseServer.verifyServerUrl();\n      });\n    }\n    if (process.env.PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS === '1' || directAccess) {\n      Parse.CoreManager.setRESTController(ParseServerRESTController(appId, appRouter));\n    }\n    return api;\n  }\n\n  static promiseRouter({ appId }) {\n    const routers = [\n      new ClassesRouter(),\n      new UsersRouter(),\n      new SessionsRouter(),\n      new RolesRouter(),\n      new AnalyticsRouter(),\n      new InstallationsRouter(),\n      new FunctionsRouter(),\n      new SchemasRouter(),\n      new PushRouter(),\n      new LogsRouter(),\n      new IAPValidationRouter(),\n      new FeaturesRouter(),\n      new GlobalConfigRouter(),\n      new GraphQLRouter(),\n      new PurgeRouter(),\n      new HooksRouter(),\n      new CloudCodeRouter(),\n      new AudiencesRouter(),\n      new AggregateRouter(),\n    ];\n\n    const routes = routers.reduce((memo, router) => {\n      return memo.concat(router.routes);\n    }, []);\n\n    const appRouter = new PromiseRouter(routes, appId);\n\n    batch.mountOnto(appRouter);\n    return appRouter;\n  }\n\n  /**\n   * starts the parse server's express app\n   * @param {ParseServerOptions} options to use to start the server\n   * @param {Function} callback called when the server has started\n   * @returns {ParseServer} the parse server instance\n   */\n  start(options: ParseServerOptions, callback: ?() => void) {\n    const app = express();\n    if (options.middleware) {\n      let middleware;\n      if (typeof options.middleware == 'string') {\n        middleware = require(path.resolve(process.cwd(), options.middleware));\n      } else {\n        middleware = options.middleware; // use as-is let express fail\n      }\n      app.use(middleware);\n    }\n\n    app.use(options.mountPath, this.app);\n\n    if (options.mountGraphQL === true || options.mountPlayground === true) {\n      let graphQLCustomTypeDefs = undefined;\n      if (typeof options.graphQLSchema === 'string') {\n        graphQLCustomTypeDefs = parse(fs.readFileSync(options.graphQLSchema, 'utf8'));\n      } else if (\n        typeof options.graphQLSchema === 'object' ||\n        typeof options.graphQLSchema === 'function'\n      ) {\n        graphQLCustomTypeDefs = options.graphQLSchema;\n      }\n\n      const parseGraphQLServer = new ParseGraphQLServer(this, {\n        graphQLPath: options.graphQLPath,\n        playgroundPath: options.playgroundPath,\n        graphQLCustomTypeDefs,\n      });\n\n      if (options.mountGraphQL) {\n        parseGraphQLServer.applyGraphQL(app);\n      }\n\n      if (options.mountPlayground) {\n        parseGraphQLServer.applyPlayground(app);\n      }\n    }\n\n    const server = app.listen(options.port, options.host, callback);\n    this.server = server;\n\n    if (options.startLiveQueryServer || options.liveQueryServerOptions) {\n      this.liveQueryServer = ParseServer.createLiveQueryServer(\n        server,\n        options.liveQueryServerOptions,\n        options\n      );\n    }\n    /* istanbul ignore next */\n    if (!process.env.TESTING) {\n      configureListeners(this);\n    }\n    this.expressApp = app;\n    return this;\n  }\n\n  /**\n   * Creates a new ParseServer and starts it.\n   * @param {ParseServerOptions} options used to start the server\n   * @param {Function} callback called when the server has started\n   * @returns {ParseServer} the parse server instance\n   */\n  static start(options: ParseServerOptions, callback: ?() => void) {\n    const parseServer = new ParseServer(options);\n    return parseServer.start(options, callback);\n  }\n\n  /**\n   * Helper method to create a liveQuery server\n   * @static\n   * @param {Server} httpServer an optional http server to pass\n   * @param {LiveQueryServerOptions} config options for the liveQueryServer\n   * @param {ParseServerOptions} options options for the ParseServer\n   * @returns {ParseLiveQueryServer} the live query server instance\n   */\n  static createLiveQueryServer(\n    httpServer,\n    config: LiveQueryServerOptions,\n    options: ParseServerOptions\n  ) {\n    if (!httpServer || (config && config.port)) {\n      var app = express();\n      httpServer = require('http').createServer(app);\n      httpServer.listen(config.port);\n    }\n    return new ParseLiveQueryServer(httpServer, config, options);\n  }\n\n  static verifyServerUrl(callback) {\n    // perform a health check on the serverURL value\n    if (Parse.serverURL) {\n      const request = require('./request');\n      request({ url: Parse.serverURL.replace(/\\/$/, '') + '/health' })\n        .catch(response => response)\n        .then(response => {\n          const json = response.data || null;\n          if (response.status !== 200 || !json || (json && json.status !== 'ok')) {\n            /* eslint-disable no-console */\n            console.warn(\n              `\\nWARNING, Unable to connect to '${Parse.serverURL}'.` +\n                ` Cloud code and push notifications may be unavailable!\\n`\n            );\n            /* eslint-enable no-console */\n            if (callback) {\n              callback(false);\n            }\n          } else {\n            if (callback) {\n              callback(true);\n            }\n          }\n        });\n    }\n  }\n}\n\nfunction addParseCloud() {\n  const ParseCloud = require('./cloud-code/Parse.Cloud');\n  Object.assign(Parse.Cloud, ParseCloud);\n  global.Parse = Parse;\n}\n\nfunction injectDefaults(options: ParseServerOptions) {\n  Object.keys(defaults).forEach(key => {\n    if (!Object.prototype.hasOwnProperty.call(options, key)) {\n      options[key] = defaults[key];\n    }\n  });\n\n  if (!Object.prototype.hasOwnProperty.call(options, 'serverURL')) {\n    options.serverURL = `http://localhost:${options.port}${options.mountPath}`;\n  }\n\n  // Reserved Characters\n  if (options.appId) {\n    const regex = /[!#$%'()*+&/:;=?@[\\]{}^,|<>]/g;\n    if (options.appId.match(regex)) {\n      console.warn(\n        `\\nWARNING, appId that contains special characters can cause issues while using with urls.\\n`\n      );\n    }\n  }\n\n  // Backwards compatibility\n  if (options.userSensitiveFields) {\n    /* eslint-disable no-console */\n    !process.env.TESTING &&\n      console.warn(\n        `\\nDEPRECATED: userSensitiveFields has been replaced by protectedFields allowing the ability to protect fields in all classes with CLP. \\n`\n      );\n    /* eslint-enable no-console */\n\n    const userSensitiveFields = Array.from(\n      new Set([...(defaults.userSensitiveFields || []), ...(options.userSensitiveFields || [])])\n    );\n\n    // If the options.protectedFields is unset,\n    // it'll be assigned the default above.\n    // Here, protect against the case where protectedFields\n    // is set, but doesn't have _User.\n    if (!('_User' in options.protectedFields)) {\n      options.protectedFields = Object.assign({ _User: [] }, options.protectedFields);\n    }\n\n    options.protectedFields['_User']['*'] = Array.from(\n      new Set([...(options.protectedFields['_User']['*'] || []), ...userSensitiveFields])\n    );\n  }\n\n  // Merge protectedFields options with defaults.\n  Object.keys(defaults.protectedFields).forEach(c => {\n    const cur = options.protectedFields[c];\n    if (!cur) {\n      options.protectedFields[c] = defaults.protectedFields[c];\n    } else {\n      Object.keys(defaults.protectedFields[c]).forEach(r => {\n        const unq = new Set([\n          ...(options.protectedFields[c][r] || []),\n          ...defaults.protectedFields[c][r],\n        ]);\n        options.protectedFields[c][r] = Array.from(unq);\n      });\n    }\n  });\n\n  options.masterKeyIps = Array.from(\n    new Set(options.masterKeyIps.concat(defaults.masterKeyIps, options.masterKeyIps))\n  );\n}\n\n// Those can't be tested as it requires a subprocess\n/* istanbul ignore next */\nfunction configureListeners(parseServer) {\n  const server = parseServer.server;\n  const sockets = {};\n  /* Currently, express doesn't shut down immediately after receiving SIGINT/SIGTERM if it has client connections that haven't timed out. (This is a known issue with node - https://github.com/nodejs/node/issues/2642)\n    This function, along with `destroyAliveConnections()`, intend to fix this behavior such that parse server will close all open connections and initiate the shutdown process as soon as it receives a SIGINT/SIGTERM signal. */\n  server.on('connection', socket => {\n    const socketId = socket.remoteAddress + ':' + socket.remotePort;\n    sockets[socketId] = socket;\n    socket.on('close', () => {\n      delete sockets[socketId];\n    });\n  });\n\n  const destroyAliveConnections = function () {\n    for (const socketId in sockets) {\n      try {\n        sockets[socketId].destroy();\n      } catch (e) {\n        /* */\n      }\n    }\n  };\n\n  const handleShutdown = function () {\n    process.stdout.write('Termination signal received. Shutting down.');\n    destroyAliveConnections();\n    server.close();\n    parseServer.handleShutdown();\n  };\n  process.on('SIGTERM', handleShutdown);\n  process.on('SIGINT', handleShutdown);\n}\n\nexport default ParseServer;\n"]}
519
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ParseServer.js"],"names":["batch","require","bodyParser","express","middlewares","Parse","parse","path","fs","addParseCloud","ParseServer","constructor","options","Deprecator","scanParseServerOptions","injectDefaults","appId","masterKey","cloud","security","javascriptKey","serverURL","serverStartComplete","schema","initialize","allControllers","controllers","getControllers","loggerController","databaseController","hooksController","config","Config","put","Object","assign","logging","setLogger","performInitialization","then","load","DefinedSchemas","execute","catch","error","console","process","exit","resolve","cwd","enableCheck","enableCheckLog","CheckRunner","run","app","_app","handleShutdown","promises","adapter","databaseAdapter","push","fileAdapter","filesController","cacheAdapter","cacheController","length","Promise","all","serverCloseComplete","maxUploadSize","directAccess","pages","api","use","allowCrossDomain","FilesRouter","expressRouter","req","res","json","status","urlencoded","extended","enableRouter","PagesRouter","PublicAPIRouter","type","limit","allowMethodOverride","handleParseHeaders","appRouter","promiseRouter","handleParseErrors","env","TESTING","on","err","code","stderr","write","port","verifyServerUrl","PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS","CoreManager","setRESTController","routers","ClassesRouter","UsersRouter","SessionsRouter","RolesRouter","AnalyticsRouter","InstallationsRouter","FunctionsRouter","SchemasRouter","PushRouter","LogsRouter","IAPValidationRouter","FeaturesRouter","GlobalConfigRouter","GraphQLRouter","PurgeRouter","HooksRouter","CloudCodeRouter","AudiencesRouter","AggregateRouter","SecurityRouter","routes","reduce","memo","router","concat","PromiseRouter","mountOnto","start","callback","middleware","mountPath","mountGraphQL","mountPlayground","graphQLCustomTypeDefs","undefined","graphQLSchema","readFileSync","parseGraphQLServer","ParseGraphQLServer","graphQLPath","playgroundPath","applyGraphQL","applyPlayground","server","listen","host","startLiveQueryServer","liveQueryServerOptions","liveQueryServer","createLiveQueryServer","configureListeners","expressApp","parseServer","httpServer","createServer","ParseLiveQueryServer","request","url","replace","response","data","warn","ParseCloud","Cloud","global","keys","defaults","forEach","key","prototype","hasOwnProperty","call","regex","match","userSensitiveFields","Array","from","Set","protectedFields","_User","c","cur","r","unq","masterKeyIps","sockets","socket","socketId","remoteAddress","remotePort","destroyAliveConnections","destroy","e","stdout","close"],"mappings":"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","sourcesContent":["// ParseServer - open-source compatible API Server for Parse apps\n\nvar batch = require('./batch'),\n  bodyParser = require('body-parser'),\n  express = require('express'),\n  middlewares = require('./middlewares'),\n  Parse = require('parse/node').Parse,\n  { parse } = require('graphql'),\n  path = require('path'),\n  fs = require('fs');\n\nimport { ParseServerOptions, LiveQueryServerOptions } from './Options';\nimport defaults from './defaults';\nimport * as logging from './logger';\nimport Config from './Config';\nimport PromiseRouter from './PromiseRouter';\nimport requiredParameter from './requiredParameter';\nimport { AnalyticsRouter } from './Routers/AnalyticsRouter';\nimport { ClassesRouter } from './Routers/ClassesRouter';\nimport { FeaturesRouter } from './Routers/FeaturesRouter';\nimport { FilesRouter } from './Routers/FilesRouter';\nimport { FunctionsRouter } from './Routers/FunctionsRouter';\nimport { GlobalConfigRouter } from './Routers/GlobalConfigRouter';\nimport { GraphQLRouter } from './Routers/GraphQLRouter';\nimport { HooksRouter } from './Routers/HooksRouter';\nimport { IAPValidationRouter } from './Routers/IAPValidationRouter';\nimport { InstallationsRouter } from './Routers/InstallationsRouter';\nimport { LogsRouter } from './Routers/LogsRouter';\nimport { ParseLiveQueryServer } from './LiveQuery/ParseLiveQueryServer';\nimport { PagesRouter } from './Routers/PagesRouter';\nimport { PublicAPIRouter } from './Routers/PublicAPIRouter';\nimport { PushRouter } from './Routers/PushRouter';\nimport { CloudCodeRouter } from './Routers/CloudCodeRouter';\nimport { RolesRouter } from './Routers/RolesRouter';\nimport { SchemasRouter } from './Routers/SchemasRouter';\nimport { SessionsRouter } from './Routers/SessionsRouter';\nimport { UsersRouter } from './Routers/UsersRouter';\nimport { PurgeRouter } from './Routers/PurgeRouter';\nimport { AudiencesRouter } from './Routers/AudiencesRouter';\nimport { AggregateRouter } from './Routers/AggregateRouter';\nimport { ParseServerRESTController } from './ParseServerRESTController';\nimport * as controllers from './Controllers';\nimport { ParseGraphQLServer } from './GraphQL/ParseGraphQLServer';\nimport { SecurityRouter } from './Routers/SecurityRouter';\nimport CheckRunner from './Security/CheckRunner';\nimport Deprecator from './Deprecator/Deprecator';\nimport { DefinedSchemas } from './SchemaMigrations/DefinedSchemas';\n\n// Mutate the Parse object to add the Cloud Code handlers\naddParseCloud();\n\n// ParseServer works like a constructor of an express app.\n// https://parseplatform.org/parse-server/api/master/ParseServerOptions.html\nclass ParseServer {\n  /**\n   * @constructor\n   * @param {ParseServerOptions} options the parse server initialization options\n   */\n  constructor(options: ParseServerOptions) {\n    // Scan for deprecated Parse Server options\n    Deprecator.scanParseServerOptions(options);\n    // Set option defaults\n    injectDefaults(options);\n    const {\n      appId = requiredParameter('You must provide an appId!'),\n      masterKey = requiredParameter('You must provide a masterKey!'),\n      cloud,\n      security,\n      javascriptKey,\n      serverURL = requiredParameter('You must provide a serverURL!'),\n      serverStartComplete,\n      schema,\n    } = options;\n    // Initialize the node client SDK automatically\n    Parse.initialize(appId, javascriptKey || 'unused', masterKey);\n    Parse.serverURL = serverURL;\n\n    const allControllers = controllers.getControllers(options);\n\n    const { loggerController, databaseController, hooksController } = allControllers;\n    this.config = Config.put(Object.assign({}, options, allControllers));\n\n    logging.setLogger(loggerController);\n\n    // Note: Tests will start to fail if any validation happens after this is called.\n    databaseController\n      .performInitialization()\n      .then(() => hooksController.load())\n      .then(async () => {\n        if (schema) {\n          await new DefinedSchemas(schema, this.config).execute();\n        }\n        if (serverStartComplete) {\n          serverStartComplete();\n        }\n      })\n      .catch(error => {\n        if (serverStartComplete) {\n          serverStartComplete(error);\n        } else {\n          console.error(error);\n          process.exit(1);\n        }\n      });\n\n    if (cloud) {\n      addParseCloud();\n      if (typeof cloud === 'function') {\n        cloud(Parse);\n      } else if (typeof cloud === 'string') {\n        require(path.resolve(process.cwd(), cloud));\n      } else {\n        throw \"argument 'cloud' must either be a string or a function\";\n      }\n    }\n\n    if (security && security.enableCheck && security.enableCheckLog) {\n      new CheckRunner(options.security).run();\n    }\n  }\n\n  get app() {\n    if (!this._app) {\n      this._app = ParseServer.app(this.config);\n    }\n    return this._app;\n  }\n\n  handleShutdown() {\n    const promises = [];\n    const { adapter: databaseAdapter } = this.config.databaseController;\n    if (databaseAdapter && typeof databaseAdapter.handleShutdown === 'function') {\n      promises.push(databaseAdapter.handleShutdown());\n    }\n    const { adapter: fileAdapter } = this.config.filesController;\n    if (fileAdapter && typeof fileAdapter.handleShutdown === 'function') {\n      promises.push(fileAdapter.handleShutdown());\n    }\n    const { adapter: cacheAdapter } = this.config.cacheController;\n    if (cacheAdapter && typeof cacheAdapter.handleShutdown === 'function') {\n      promises.push(cacheAdapter.handleShutdown());\n    }\n    return (promises.length > 0 ? Promise.all(promises) : Promise.resolve()).then(() => {\n      if (this.config.serverCloseComplete) {\n        this.config.serverCloseComplete();\n      }\n    });\n  }\n\n  /**\n   * @static\n   * Create an express app for the parse server\n   * @param {Object} options let you specify the maxUploadSize when creating the express app  */\n  static app(options) {\n    const { maxUploadSize = '20mb', appId, directAccess, pages } = options;\n    // This app serves the Parse API directly.\n    // It's the equivalent of https://api.parse.com/1 in the hosted Parse API.\n    var api = express();\n    //api.use(\"/apps\", express.static(__dirname + \"/public\"));\n    api.use(middlewares.allowCrossDomain(appId));\n    // File handling needs to be before default middlewares are applied\n    api.use(\n      '/',\n      new FilesRouter().expressRouter({\n        maxUploadSize: maxUploadSize,\n      })\n    );\n\n    api.use('/health', function (req, res) {\n      res.json({\n        status: 'ok',\n      });\n    });\n\n    api.use(\n      '/',\n      bodyParser.urlencoded({ extended: false }),\n      pages.enableRouter\n        ? new PagesRouter(pages).expressRouter()\n        : new PublicAPIRouter().expressRouter()\n    );\n\n    api.use(bodyParser.json({ type: '*/*', limit: maxUploadSize }));\n    api.use(middlewares.allowMethodOverride);\n    api.use(middlewares.handleParseHeaders);\n\n    const appRouter = ParseServer.promiseRouter({ appId });\n    api.use(appRouter.expressRouter());\n\n    api.use(middlewares.handleParseErrors);\n\n    // run the following when not testing\n    if (!process.env.TESTING) {\n      //This causes tests to spew some useless warnings, so disable in test\n      /* istanbul ignore next */\n      process.on('uncaughtException', err => {\n        if (err.code === 'EADDRINUSE') {\n          // user-friendly message for this common error\n          process.stderr.write(`Unable to listen on port ${err.port}. The port is already in use.`);\n          process.exit(0);\n        } else {\n          throw err;\n        }\n      });\n      // verify the server url after a 'mount' event is received\n      /* istanbul ignore next */\n      api.on('mount', function () {\n        ParseServer.verifyServerUrl();\n      });\n    }\n    if (process.env.PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS === '1' || directAccess) {\n      Parse.CoreManager.setRESTController(ParseServerRESTController(appId, appRouter));\n    }\n    return api;\n  }\n\n  static promiseRouter({ appId }) {\n    const routers = [\n      new ClassesRouter(),\n      new UsersRouter(),\n      new SessionsRouter(),\n      new RolesRouter(),\n      new AnalyticsRouter(),\n      new InstallationsRouter(),\n      new FunctionsRouter(),\n      new SchemasRouter(),\n      new PushRouter(),\n      new LogsRouter(),\n      new IAPValidationRouter(),\n      new FeaturesRouter(),\n      new GlobalConfigRouter(),\n      new GraphQLRouter(),\n      new PurgeRouter(),\n      new HooksRouter(),\n      new CloudCodeRouter(),\n      new AudiencesRouter(),\n      new AggregateRouter(),\n      new SecurityRouter(),\n    ];\n\n    const routes = routers.reduce((memo, router) => {\n      return memo.concat(router.routes);\n    }, []);\n\n    const appRouter = new PromiseRouter(routes, appId);\n\n    batch.mountOnto(appRouter);\n    return appRouter;\n  }\n\n  /**\n   * starts the parse server's express app\n   * @param {ParseServerOptions} options to use to start the server\n   * @param {Function} callback called when the server has started\n   * @returns {ParseServer} the parse server instance\n   */\n  start(options: ParseServerOptions, callback: ?() => void) {\n    const app = express();\n    if (options.middleware) {\n      let middleware;\n      if (typeof options.middleware == 'string') {\n        middleware = require(path.resolve(process.cwd(), options.middleware));\n      } else {\n        middleware = options.middleware; // use as-is let express fail\n      }\n      app.use(middleware);\n    }\n\n    app.use(options.mountPath, this.app);\n\n    if (options.mountGraphQL === true || options.mountPlayground === true) {\n      let graphQLCustomTypeDefs = undefined;\n      if (typeof options.graphQLSchema === 'string') {\n        graphQLCustomTypeDefs = parse(fs.readFileSync(options.graphQLSchema, 'utf8'));\n      } else if (\n        typeof options.graphQLSchema === 'object' ||\n        typeof options.graphQLSchema === 'function'\n      ) {\n        graphQLCustomTypeDefs = options.graphQLSchema;\n      }\n\n      const parseGraphQLServer = new ParseGraphQLServer(this, {\n        graphQLPath: options.graphQLPath,\n        playgroundPath: options.playgroundPath,\n        graphQLCustomTypeDefs,\n      });\n\n      if (options.mountGraphQL) {\n        parseGraphQLServer.applyGraphQL(app);\n      }\n\n      if (options.mountPlayground) {\n        parseGraphQLServer.applyPlayground(app);\n      }\n    }\n\n    const server = app.listen(options.port, options.host, callback);\n    this.server = server;\n\n    if (options.startLiveQueryServer || options.liveQueryServerOptions) {\n      this.liveQueryServer = ParseServer.createLiveQueryServer(\n        server,\n        options.liveQueryServerOptions,\n        options\n      );\n    }\n    /* istanbul ignore next */\n    if (!process.env.TESTING) {\n      configureListeners(this);\n    }\n    this.expressApp = app;\n    return this;\n  }\n\n  /**\n   * Creates a new ParseServer and starts it.\n   * @param {ParseServerOptions} options used to start the server\n   * @param {Function} callback called when the server has started\n   * @returns {ParseServer} the parse server instance\n   */\n  static start(options: ParseServerOptions, callback: ?() => void) {\n    const parseServer = new ParseServer(options);\n    return parseServer.start(options, callback);\n  }\n\n  /**\n   * Helper method to create a liveQuery server\n   * @static\n   * @param {Server} httpServer an optional http server to pass\n   * @param {LiveQueryServerOptions} config options for the liveQueryServer\n   * @param {ParseServerOptions} options options for the ParseServer\n   * @returns {ParseLiveQueryServer} the live query server instance\n   */\n  static createLiveQueryServer(\n    httpServer,\n    config: LiveQueryServerOptions,\n    options: ParseServerOptions\n  ) {\n    if (!httpServer || (config && config.port)) {\n      var app = express();\n      httpServer = require('http').createServer(app);\n      httpServer.listen(config.port);\n    }\n    return new ParseLiveQueryServer(httpServer, config, options);\n  }\n\n  static verifyServerUrl(callback) {\n    // perform a health check on the serverURL value\n    if (Parse.serverURL) {\n      const request = require('./request');\n      request({ url: Parse.serverURL.replace(/\\/$/, '') + '/health' })\n        .catch(response => response)\n        .then(response => {\n          const json = response.data || null;\n          if (response.status !== 200 || !json || (json && json.status !== 'ok')) {\n            /* eslint-disable no-console */\n            console.warn(\n              `\\nWARNING, Unable to connect to '${Parse.serverURL}'.` +\n                ` Cloud code and push notifications may be unavailable!\\n`\n            );\n            /* eslint-enable no-console */\n            if (callback) {\n              callback(false);\n            }\n          } else {\n            if (callback) {\n              callback(true);\n            }\n          }\n        });\n    }\n  }\n}\n\nfunction addParseCloud() {\n  const ParseCloud = require('./cloud-code/Parse.Cloud');\n  Object.assign(Parse.Cloud, ParseCloud);\n  global.Parse = Parse;\n}\n\nfunction injectDefaults(options: ParseServerOptions) {\n  Object.keys(defaults).forEach(key => {\n    if (!Object.prototype.hasOwnProperty.call(options, key)) {\n      options[key] = defaults[key];\n    }\n  });\n\n  if (!Object.prototype.hasOwnProperty.call(options, 'serverURL')) {\n    options.serverURL = `http://localhost:${options.port}${options.mountPath}`;\n  }\n\n  // Reserved Characters\n  if (options.appId) {\n    const regex = /[!#$%'()*+&/:;=?@[\\]{}^,|<>]/g;\n    if (options.appId.match(regex)) {\n      console.warn(\n        `\\nWARNING, appId that contains special characters can cause issues while using with urls.\\n`\n      );\n    }\n  }\n\n  // Backwards compatibility\n  if (options.userSensitiveFields) {\n    /* eslint-disable no-console */\n    !process.env.TESTING &&\n      console.warn(\n        `\\nDEPRECATED: userSensitiveFields has been replaced by protectedFields allowing the ability to protect fields in all classes with CLP. \\n`\n      );\n    /* eslint-enable no-console */\n\n    const userSensitiveFields = Array.from(\n      new Set([...(defaults.userSensitiveFields || []), ...(options.userSensitiveFields || [])])\n    );\n\n    // If the options.protectedFields is unset,\n    // it'll be assigned the default above.\n    // Here, protect against the case where protectedFields\n    // is set, but doesn't have _User.\n    if (!('_User' in options.protectedFields)) {\n      options.protectedFields = Object.assign({ _User: [] }, options.protectedFields);\n    }\n\n    options.protectedFields['_User']['*'] = Array.from(\n      new Set([...(options.protectedFields['_User']['*'] || []), ...userSensitiveFields])\n    );\n  }\n\n  // Merge protectedFields options with defaults.\n  Object.keys(defaults.protectedFields).forEach(c => {\n    const cur = options.protectedFields[c];\n    if (!cur) {\n      options.protectedFields[c] = defaults.protectedFields[c];\n    } else {\n      Object.keys(defaults.protectedFields[c]).forEach(r => {\n        const unq = new Set([\n          ...(options.protectedFields[c][r] || []),\n          ...defaults.protectedFields[c][r],\n        ]);\n        options.protectedFields[c][r] = Array.from(unq);\n      });\n    }\n  });\n\n  options.masterKeyIps = Array.from(\n    new Set(options.masterKeyIps.concat(defaults.masterKeyIps, options.masterKeyIps))\n  );\n}\n\n// Those can't be tested as it requires a subprocess\n/* istanbul ignore next */\nfunction configureListeners(parseServer) {\n  const server = parseServer.server;\n  const sockets = {};\n  /* Currently, express doesn't shut down immediately after receiving SIGINT/SIGTERM if it has client connections that haven't timed out. (This is a known issue with node - https://github.com/nodejs/node/issues/2642)\n    This function, along with `destroyAliveConnections()`, intend to fix this behavior such that parse server will close all open connections and initiate the shutdown process as soon as it receives a SIGINT/SIGTERM signal. */\n  server.on('connection', socket => {\n    const socketId = socket.remoteAddress + ':' + socket.remotePort;\n    sockets[socketId] = socket;\n    socket.on('close', () => {\n      delete sockets[socketId];\n    });\n  });\n\n  const destroyAliveConnections = function () {\n    for (const socketId in sockets) {\n      try {\n        sockets[socketId].destroy();\n      } catch (e) {\n        /* */\n      }\n    }\n  };\n\n  const handleShutdown = function () {\n    process.stdout.write('Termination signal received. Shutting down.');\n    destroyAliveConnections();\n    server.close();\n    parseServer.handleShutdown();\n  };\n  process.on('SIGTERM', handleShutdown);\n  process.on('SIGINT', handleShutdown);\n}\n\nexport default ParseServer;\n"]}
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.ParseServerRESTController = ParseServerRESTController;
7
7
  exports.default = void 0;
8
8
 
9
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
9
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
10
10
 
11
11
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
12
12
 
@@ -78,52 +78,62 @@ function ParseServerRESTController(applicationId, router) {
78
78
  }
79
79
 
80
80
  if (path === '/batch') {
81
- let initialPromise = Promise.resolve();
82
-
83
- if (data.transaction === true) {
84
- initialPromise = config.database.createTransactionalSession();
85
- }
86
-
87
- return initialPromise.then(() => {
88
- const promises = data.requests.map(request => {
89
- return handleRequest(request.method, request.path, request.body, options, config).then(response => {
90
- if (options.returnStatus) {
91
- const status = response._status;
92
- delete response._status;
81
+ const batch = transactionRetries => {
82
+ let initialPromise = Promise.resolve();
83
+
84
+ if (data.transaction === true) {
85
+ initialPromise = config.database.createTransactionalSession();
86
+ }
87
+
88
+ return initialPromise.then(() => {
89
+ const promises = data.requests.map(request => {
90
+ return handleRequest(request.method, request.path, request.body, options, config).then(response => {
91
+ if (options.returnStatus) {
92
+ const status = response._status;
93
+ delete response._status;
94
+ return {
95
+ success: response,
96
+ _status: status
97
+ };
98
+ }
99
+
93
100
  return {
94
- success: response,
95
- _status: status
101
+ success: response
96
102
  };
97
- }
98
-
99
- return {
100
- success: response
101
- };
102
- }, error => {
103
- return {
104
- error: {
105
- code: error.code,
106
- error: error.message
107
- }
108
- };
103
+ }, error => {
104
+ return {
105
+ error: {
106
+ code: error.code,
107
+ error: error.message
108
+ }
109
+ };
110
+ });
109
111
  });
110
- });
111
- return Promise.all(promises).then(result => {
112
- if (data.transaction === true) {
113
- if (result.find(resultItem => typeof resultItem.error === 'object')) {
114
- return config.database.abortTransactionalSession().then(() => {
115
- return Promise.reject(result);
116
- });
112
+ return Promise.all(promises).then(result => {
113
+ if (data.transaction === true) {
114
+ if (result.find(resultItem => typeof resultItem.error === 'object')) {
115
+ return config.database.abortTransactionalSession().then(() => {
116
+ return Promise.reject(result);
117
+ });
118
+ } else {
119
+ return config.database.commitTransactionalSession().then(() => {
120
+ return result;
121
+ });
122
+ }
117
123
  } else {
118
- return config.database.commitTransactionalSession().then(() => {
119
- return result;
120
- });
124
+ return result;
121
125
  }
122
- } else {
123
- return result;
124
- }
126
+ }).catch(error => {
127
+ if (error && error.find(errorItem => typeof errorItem.error === 'object' && errorItem.error.code === 251) && transactionRetries > 0) {
128
+ return batch(transactionRetries - 1);
129
+ }
130
+
131
+ throw error;
132
+ });
125
133
  });
126
- });
134
+ };
135
+
136
+ return batch(5);
127
137
  }
128
138
 
129
139
  let query;
@@ -142,8 +152,7 @@ function ParseServerRESTController(applicationId, router) {
142
152
  applicationId: applicationId,
143
153
  sessionToken: options.sessionToken,
144
154
  installationId: options.installationId,
145
- context: options.context || {} // Add context
146
-
155
+ context: options.context || {}
147
156
  },
148
157
  query
149
158
  };
@@ -175,10 +184,11 @@ function ParseServerRESTController(applicationId, router) {
175
184
 
176
185
  return {
177
186
  request: handleRequest,
178
- ajax: RESTController.ajax
187
+ ajax: RESTController.ajax,
188
+ handleError: RESTController.handleError
179
189
  };
180
190
  }
181
191
 
182
192
  var _default = ParseServerRESTController;
183
193
  exports.default = _default;
184
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ParseServerRESTController.js"],"names":["Config","require","Auth","RESTController","URL","Parse","getSessionToken","options","sessionToken","Promise","resolve","getAuth","config","installationId","useMasterKey","isMaster","then","getAuthForSessionToken","ParseServerRESTController","applicationId","router","handleRequest","method","path","data","args","arguments","get","serverURL","parse","indexOf","slice","length","initialPromise","transaction","database","createTransactionalSession","promises","requests","map","request","body","response","returnStatus","status","_status","success","error","code","message","all","result","find","resultItem","abortTransactionalSession","reject","commitTransactionalSession","query","auth","info","context","tryRouteRequest","resp","err","Error","INVALID_JSON","apply","ajax"],"mappings":"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","sourcesContent":["const Config = require('./Config');\nconst Auth = require('./Auth');\nconst RESTController = require('parse/lib/node/RESTController');\nconst URL = require('url');\nconst Parse = require('parse/node');\n\nfunction getSessionToken(options) {\n  if (options && typeof options.sessionToken === 'string') {\n    return Promise.resolve(options.sessionToken);\n  }\n  return Promise.resolve(null);\n}\n\nfunction getAuth(options = {}, config) {\n  const installationId = options.installationId || 'cloud';\n  if (options.useMasterKey) {\n    return Promise.resolve(new Auth.Auth({ config, isMaster: true, installationId }));\n  }\n  return getSessionToken(options).then(sessionToken => {\n    if (sessionToken) {\n      options.sessionToken = sessionToken;\n      return Auth.getAuthForSessionToken({\n        config,\n        sessionToken: sessionToken,\n        installationId,\n      });\n    } else {\n      return Promise.resolve(new Auth.Auth({ config, installationId }));\n    }\n  });\n}\n\nfunction ParseServerRESTController(applicationId, router) {\n  function handleRequest(method, path, data = {}, options = {}, config) {\n    // Store the arguments, for later use if internal fails\n    const args = arguments;\n\n    if (!config) {\n      config = Config.get(applicationId);\n    }\n    const serverURL = URL.parse(config.serverURL);\n    if (path.indexOf(serverURL.path) === 0) {\n      path = path.slice(serverURL.path.length, path.length);\n    }\n\n    if (path[0] !== '/') {\n      path = '/' + path;\n    }\n\n    if (path === '/batch') {\n      let initialPromise = Promise.resolve();\n      if (data.transaction === true) {\n        initialPromise = config.database.createTransactionalSession();\n      }\n      return initialPromise.then(() => {\n        const promises = data.requests.map(request => {\n          return handleRequest(request.method, request.path, request.body, options, config).then(\n            response => {\n              if (options.returnStatus) {\n                const status = response._status;\n                delete response._status;\n                return { success: response, _status: status };\n              }\n              return { success: response };\n            },\n            error => {\n              return {\n                error: { code: error.code, error: error.message },\n              };\n            }\n          );\n        });\n        return Promise.all(promises).then(result => {\n          if (data.transaction === true) {\n            if (result.find(resultItem => typeof resultItem.error === 'object')) {\n              return config.database.abortTransactionalSession().then(() => {\n                return Promise.reject(result);\n              });\n            } else {\n              return config.database.commitTransactionalSession().then(() => {\n                return result;\n              });\n            }\n          } else {\n            return result;\n          }\n        });\n      });\n    }\n\n    let query;\n    if (method === 'GET') {\n      query = data;\n    }\n\n    return new Promise((resolve, reject) => {\n      getAuth(options, config).then(auth => {\n        const request = {\n          body: data,\n          config,\n          auth,\n          info: {\n            applicationId: applicationId,\n            sessionToken: options.sessionToken,\n            installationId: options.installationId,\n            context: options.context || {}, // Add context\n          },\n          query,\n        };\n        return Promise.resolve()\n          .then(() => {\n            return router.tryRouteRequest(method, path, request);\n          })\n          .then(\n            resp => {\n              const { response, status } = resp;\n              if (options.returnStatus) {\n                resolve({ ...response, _status: status });\n              } else {\n                resolve(response);\n              }\n            },\n            err => {\n              if (\n                err instanceof Parse.Error &&\n                err.code == Parse.Error.INVALID_JSON &&\n                err.message == `cannot route ${method} ${path}`\n              ) {\n                RESTController.request.apply(null, args).then(resolve, reject);\n              } else {\n                reject(err);\n              }\n            }\n          );\n      }, reject);\n    });\n  }\n\n  return {\n    request: handleRequest,\n    ajax: RESTController.ajax,\n  };\n}\n\nexport default ParseServerRESTController;\nexport { ParseServerRESTController };\n"]}
194
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/ParseServerRESTController.js"],"names":["Config","require","Auth","RESTController","URL","Parse","getSessionToken","options","sessionToken","Promise","resolve","getAuth","config","installationId","useMasterKey","isMaster","then","getAuthForSessionToken","ParseServerRESTController","applicationId","router","handleRequest","method","path","data","args","arguments","get","serverURL","parse","indexOf","slice","length","batch","transactionRetries","initialPromise","transaction","database","createTransactionalSession","promises","requests","map","request","body","response","returnStatus","status","_status","success","error","code","message","all","result","find","resultItem","abortTransactionalSession","reject","commitTransactionalSession","catch","errorItem","query","auth","info","context","tryRouteRequest","resp","err","Error","INVALID_JSON","apply","ajax","handleError"],"mappings":";;;;;;;;;;;;;;AAAA,MAAMA,MAAM,GAAGC,OAAO,CAAC,UAAD,CAAtB;;AACA,MAAMC,IAAI,GAAGD,OAAO,CAAC,QAAD,CAApB;;AACA,MAAME,cAAc,GAAGF,OAAO,CAAC,+BAAD,CAA9B;;AACA,MAAMG,GAAG,GAAGH,OAAO,CAAC,KAAD,CAAnB;;AACA,MAAMI,KAAK,GAAGJ,OAAO,CAAC,YAAD,CAArB;;AAEA,SAASK,eAAT,CAAyBC,OAAzB,EAAkC;AAChC,MAAIA,OAAO,IAAI,OAAOA,OAAO,CAACC,YAAf,KAAgC,QAA/C,EAAyD;AACvD,WAAOC,OAAO,CAACC,OAAR,CAAgBH,OAAO,CAACC,YAAxB,CAAP;AACD;;AACD,SAAOC,OAAO,CAACC,OAAR,CAAgB,IAAhB,CAAP;AACD;;AAED,SAASC,OAAT,CAAiBJ,OAAO,GAAG,EAA3B,EAA+BK,MAA/B,EAAuC;AACrC,QAAMC,cAAc,GAAGN,OAAO,CAACM,cAAR,IAA0B,OAAjD;;AACA,MAAIN,OAAO,CAACO,YAAZ,EAA0B;AACxB,WAAOL,OAAO,CAACC,OAAR,CAAgB,IAAIR,IAAI,CAACA,IAAT,CAAc;AAAEU,MAAAA,MAAF;AAAUG,MAAAA,QAAQ,EAAE,IAApB;AAA0BF,MAAAA;AAA1B,KAAd,CAAhB,CAAP;AACD;;AACD,SAAOP,eAAe,CAACC,OAAD,CAAf,CAAyBS,IAAzB,CAA8BR,YAAY,IAAI;AACnD,QAAIA,YAAJ,EAAkB;AAChBD,MAAAA,OAAO,CAACC,YAAR,GAAuBA,YAAvB;AACA,aAAON,IAAI,CAACe,sBAAL,CAA4B;AACjCL,QAAAA,MADiC;AAEjCJ,QAAAA,YAAY,EAAEA,YAFmB;AAGjCK,QAAAA;AAHiC,OAA5B,CAAP;AAKD,KAPD,MAOO;AACL,aAAOJ,OAAO,CAACC,OAAR,CAAgB,IAAIR,IAAI,CAACA,IAAT,CAAc;AAAEU,QAAAA,MAAF;AAAUC,QAAAA;AAAV,OAAd,CAAhB,CAAP;AACD;AACF,GAXM,CAAP;AAYD;;AAED,SAASK,yBAAT,CAAmCC,aAAnC,EAAkDC,MAAlD,EAA0D;AACxD,WAASC,aAAT,CAAuBC,MAAvB,EAA+BC,IAA/B,EAAqCC,IAAI,GAAG,EAA5C,EAAgDjB,OAAO,GAAG,EAA1D,EAA8DK,MAA9D,EAAsE;AACpE;AACA,UAAMa,IAAI,GAAGC,SAAb;;AAEA,QAAI,CAACd,MAAL,EAAa;AACXA,MAAAA,MAAM,GAAGZ,MAAM,CAAC2B,GAAP,CAAWR,aAAX,CAAT;AACD;;AACD,UAAMS,SAAS,GAAGxB,GAAG,CAACyB,KAAJ,CAAUjB,MAAM,CAACgB,SAAjB,CAAlB;;AACA,QAAIL,IAAI,CAACO,OAAL,CAAaF,SAAS,CAACL,IAAvB,MAAiC,CAArC,EAAwC;AACtCA,MAAAA,IAAI,GAAGA,IAAI,CAACQ,KAAL,CAAWH,SAAS,CAACL,IAAV,CAAeS,MAA1B,EAAkCT,IAAI,CAACS,MAAvC,CAAP;AACD;;AAED,QAAIT,IAAI,CAAC,CAAD,CAAJ,KAAY,GAAhB,EAAqB;AACnBA,MAAAA,IAAI,GAAG,MAAMA,IAAb;AACD;;AAED,QAAIA,IAAI,KAAK,QAAb,EAAuB;AACrB,YAAMU,KAAK,GAAGC,kBAAkB,IAAI;AAClC,YAAIC,cAAc,GAAG1B,OAAO,CAACC,OAAR,EAArB;;AACA,YAAIc,IAAI,CAACY,WAAL,KAAqB,IAAzB,EAA+B;AAC7BD,UAAAA,cAAc,GAAGvB,MAAM,CAACyB,QAAP,CAAgBC,0BAAhB,EAAjB;AACD;;AACD,eAAOH,cAAc,CAACnB,IAAf,CAAoB,MAAM;AAC/B,gBAAMuB,QAAQ,GAAGf,IAAI,CAACgB,QAAL,CAAcC,GAAd,CAAkBC,OAAO,IAAI;AAC5C,mBAAOrB,aAAa,CAACqB,OAAO,CAACpB,MAAT,EAAiBoB,OAAO,CAACnB,IAAzB,EAA+BmB,OAAO,CAACC,IAAvC,EAA6CpC,OAA7C,EAAsDK,MAAtD,CAAb,CAA2EI,IAA3E,CACL4B,QAAQ,IAAI;AACV,kBAAIrC,OAAO,CAACsC,YAAZ,EAA0B;AACxB,sBAAMC,MAAM,GAAGF,QAAQ,CAACG,OAAxB;AACA,uBAAOH,QAAQ,CAACG,OAAhB;AACA,uBAAO;AAAEC,kBAAAA,OAAO,EAAEJ,QAAX;AAAqBG,kBAAAA,OAAO,EAAED;AAA9B,iBAAP;AACD;;AACD,qBAAO;AAAEE,gBAAAA,OAAO,EAAEJ;AAAX,eAAP;AACD,aARI,EASLK,KAAK,IAAI;AACP,qBAAO;AACLA,gBAAAA,KAAK,EAAE;AAAEC,kBAAAA,IAAI,EAAED,KAAK,CAACC,IAAd;AAAoBD,kBAAAA,KAAK,EAAEA,KAAK,CAACE;AAAjC;AADF,eAAP;AAGD,aAbI,CAAP;AAeD,WAhBgB,CAAjB;AAiBA,iBAAO1C,OAAO,CAAC2C,GAAR,CAAYb,QAAZ,EACJvB,IADI,CACCqC,MAAM,IAAI;AACd,gBAAI7B,IAAI,CAACY,WAAL,KAAqB,IAAzB,EAA+B;AAC7B,kBAAIiB,MAAM,CAACC,IAAP,CAAYC,UAAU,IAAI,OAAOA,UAAU,CAACN,KAAlB,KAA4B,QAAtD,CAAJ,EAAqE;AACnE,uBAAOrC,MAAM,CAACyB,QAAP,CAAgBmB,yBAAhB,GAA4CxC,IAA5C,CAAiD,MAAM;AAC5D,yBAAOP,OAAO,CAACgD,MAAR,CAAeJ,MAAf,CAAP;AACD,iBAFM,CAAP;AAGD,eAJD,MAIO;AACL,uBAAOzC,MAAM,CAACyB,QAAP,CAAgBqB,0BAAhB,GAA6C1C,IAA7C,CAAkD,MAAM;AAC7D,yBAAOqC,MAAP;AACD,iBAFM,CAAP;AAGD;AACF,aAVD,MAUO;AACL,qBAAOA,MAAP;AACD;AACF,WAfI,EAgBJM,KAhBI,CAgBEV,KAAK,IAAI;AACd,gBACEA,KAAK,IACLA,KAAK,CAACK,IAAN,CACEM,SAAS,IAAI,OAAOA,SAAS,CAACX,KAAjB,KAA2B,QAA3B,IAAuCW,SAAS,CAACX,KAAV,CAAgBC,IAAhB,KAAyB,GAD/E,CADA,IAIAhB,kBAAkB,GAAG,CALvB,EAME;AACA,qBAAOD,KAAK,CAACC,kBAAkB,GAAG,CAAtB,CAAZ;AACD;;AACD,kBAAMe,KAAN;AACD,WA3BI,CAAP;AA4BD,SA9CM,CAAP;AA+CD,OApDD;;AAqDA,aAAOhB,KAAK,CAAC,CAAD,CAAZ;AACD;;AAED,QAAI4B,KAAJ;;AACA,QAAIvC,MAAM,KAAK,KAAf,EAAsB;AACpBuC,MAAAA,KAAK,GAAGrC,IAAR;AACD;;AAED,WAAO,IAAIf,OAAJ,CAAY,CAACC,OAAD,EAAU+C,MAAV,KAAqB;AACtC9C,MAAAA,OAAO,CAACJ,OAAD,EAAUK,MAAV,CAAP,CAAyBI,IAAzB,CAA8B8C,IAAI,IAAI;AACpC,cAAMpB,OAAO,GAAG;AACdC,UAAAA,IAAI,EAAEnB,IADQ;AAEdZ,UAAAA,MAFc;AAGdkD,UAAAA,IAHc;AAIdC,UAAAA,IAAI,EAAE;AACJ5C,YAAAA,aAAa,EAAEA,aADX;AAEJX,YAAAA,YAAY,EAAED,OAAO,CAACC,YAFlB;AAGJK,YAAAA,cAAc,EAAEN,OAAO,CAACM,cAHpB;AAIJmD,YAAAA,OAAO,EAAEzD,OAAO,CAACyD,OAAR,IAAmB;AAJxB,WAJQ;AAUdH,UAAAA;AAVc,SAAhB;AAYA,eAAOpD,OAAO,CAACC,OAAR,GACJM,IADI,CACC,MAAM;AACV,iBAAOI,MAAM,CAAC6C,eAAP,CAAuB3C,MAAvB,EAA+BC,IAA/B,EAAqCmB,OAArC,CAAP;AACD,SAHI,EAIJ1B,IAJI,CAKHkD,IAAI,IAAI;AACN,gBAAM;AAAEtB,YAAAA,QAAF;AAAYE,YAAAA;AAAZ,cAAuBoB,IAA7B;;AACA,cAAI3D,OAAO,CAACsC,YAAZ,EAA0B;AACxBnC,YAAAA,OAAO,iCAAMkC,QAAN;AAAgBG,cAAAA,OAAO,EAAED;AAAzB,eAAP;AACD,WAFD,MAEO;AACLpC,YAAAA,OAAO,CAACkC,QAAD,CAAP;AACD;AACF,SAZE,EAaHuB,GAAG,IAAI;AACL,cACEA,GAAG,YAAY9D,KAAK,CAAC+D,KAArB,IACAD,GAAG,CAACjB,IAAJ,IAAY7C,KAAK,CAAC+D,KAAN,CAAYC,YADxB,IAEAF,GAAG,CAAChB,OAAJ,IAAgB,gBAAe7B,MAAO,IAAGC,IAAK,EAHhD,EAIE;AACApB,YAAAA,cAAc,CAACuC,OAAf,CAAuB4B,KAAvB,CAA6B,IAA7B,EAAmC7C,IAAnC,EAAyCT,IAAzC,CAA8CN,OAA9C,EAAuD+C,MAAvD;AACD,WAND,MAMO;AACLA,YAAAA,MAAM,CAACU,GAAD,CAAN;AACD;AACF,SAvBE,CAAP;AAyBD,OAtCD,EAsCGV,MAtCH;AAuCD,KAxCM,CAAP;AAyCD;;AAED,SAAO;AACLf,IAAAA,OAAO,EAAErB,aADJ;AAELkD,IAAAA,IAAI,EAAEpE,cAAc,CAACoE,IAFhB;AAGLC,IAAAA,WAAW,EAAErE,cAAc,CAACqE;AAHvB,GAAP;AAKD;;eAEctD,yB","sourcesContent":["const Config = require('./Config');\nconst Auth = require('./Auth');\nconst RESTController = require('parse/lib/node/RESTController');\nconst URL = require('url');\nconst Parse = require('parse/node');\n\nfunction getSessionToken(options) {\n  if (options && typeof options.sessionToken === 'string') {\n    return Promise.resolve(options.sessionToken);\n  }\n  return Promise.resolve(null);\n}\n\nfunction getAuth(options = {}, config) {\n  const installationId = options.installationId || 'cloud';\n  if (options.useMasterKey) {\n    return Promise.resolve(new Auth.Auth({ config, isMaster: true, installationId }));\n  }\n  return getSessionToken(options).then(sessionToken => {\n    if (sessionToken) {\n      options.sessionToken = sessionToken;\n      return Auth.getAuthForSessionToken({\n        config,\n        sessionToken: sessionToken,\n        installationId,\n      });\n    } else {\n      return Promise.resolve(new Auth.Auth({ config, installationId }));\n    }\n  });\n}\n\nfunction ParseServerRESTController(applicationId, router) {\n  function handleRequest(method, path, data = {}, options = {}, config) {\n    // Store the arguments, for later use if internal fails\n    const args = arguments;\n\n    if (!config) {\n      config = Config.get(applicationId);\n    }\n    const serverURL = URL.parse(config.serverURL);\n    if (path.indexOf(serverURL.path) === 0) {\n      path = path.slice(serverURL.path.length, path.length);\n    }\n\n    if (path[0] !== '/') {\n      path = '/' + path;\n    }\n\n    if (path === '/batch') {\n      const batch = transactionRetries => {\n        let initialPromise = Promise.resolve();\n        if (data.transaction === true) {\n          initialPromise = config.database.createTransactionalSession();\n        }\n        return initialPromise.then(() => {\n          const promises = data.requests.map(request => {\n            return handleRequest(request.method, request.path, request.body, options, config).then(\n              response => {\n                if (options.returnStatus) {\n                  const status = response._status;\n                  delete response._status;\n                  return { success: response, _status: status };\n                }\n                return { success: response };\n              },\n              error => {\n                return {\n                  error: { code: error.code, error: error.message },\n                };\n              }\n            );\n          });\n          return Promise.all(promises)\n            .then(result => {\n              if (data.transaction === true) {\n                if (result.find(resultItem => typeof resultItem.error === 'object')) {\n                  return config.database.abortTransactionalSession().then(() => {\n                    return Promise.reject(result);\n                  });\n                } else {\n                  return config.database.commitTransactionalSession().then(() => {\n                    return result;\n                  });\n                }\n              } else {\n                return result;\n              }\n            })\n            .catch(error => {\n              if (\n                error &&\n                error.find(\n                  errorItem => typeof errorItem.error === 'object' && errorItem.error.code === 251\n                ) &&\n                transactionRetries > 0\n              ) {\n                return batch(transactionRetries - 1);\n              }\n              throw error;\n            });\n        });\n      };\n      return batch(5);\n    }\n\n    let query;\n    if (method === 'GET') {\n      query = data;\n    }\n\n    return new Promise((resolve, reject) => {\n      getAuth(options, config).then(auth => {\n        const request = {\n          body: data,\n          config,\n          auth,\n          info: {\n            applicationId: applicationId,\n            sessionToken: options.sessionToken,\n            installationId: options.installationId,\n            context: options.context || {},\n          },\n          query,\n        };\n        return Promise.resolve()\n          .then(() => {\n            return router.tryRouteRequest(method, path, request);\n          })\n          .then(\n            resp => {\n              const { response, status } = resp;\n              if (options.returnStatus) {\n                resolve({ ...response, _status: status });\n              } else {\n                resolve(response);\n              }\n            },\n            err => {\n              if (\n                err instanceof Parse.Error &&\n                err.code == Parse.Error.INVALID_JSON &&\n                err.message == `cannot route ${method} ${path}`\n              ) {\n                RESTController.request.apply(null, args).then(resolve, reject);\n              } else {\n                reject(err);\n              }\n            }\n          );\n      }, reject);\n    });\n  }\n\n  return {\n    request: handleRequest,\n    ajax: RESTController.ajax,\n    handleError: RESTController.handleError,\n  };\n}\n\nexport default ParseServerRESTController;\nexport { ParseServerRESTController };\n"]}