ParseServer.js 88 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = void 0;
  6. var _Options = require("./Options");
  7. var _defaults = _interopRequireDefault(require("./defaults"));
  8. var logging = _interopRequireWildcard(require("./logger"));
  9. var _Config = _interopRequireDefault(require("./Config"));
  10. var _PromiseRouter = _interopRequireDefault(require("./PromiseRouter"));
  11. var _requiredParameter = _interopRequireDefault(require("./requiredParameter"));
  12. var _AnalyticsRouter = require("./Routers/AnalyticsRouter");
  13. var _ClassesRouter = require("./Routers/ClassesRouter");
  14. var _FeaturesRouter = require("./Routers/FeaturesRouter");
  15. var _FilesRouter = require("./Routers/FilesRouter");
  16. var _FunctionsRouter = require("./Routers/FunctionsRouter");
  17. var _GlobalConfigRouter = require("./Routers/GlobalConfigRouter");
  18. var _GraphQLRouter = require("./Routers/GraphQLRouter");
  19. var _HooksRouter = require("./Routers/HooksRouter");
  20. var _IAPValidationRouter = require("./Routers/IAPValidationRouter");
  21. var _InstallationsRouter = require("./Routers/InstallationsRouter");
  22. var _LogsRouter = require("./Routers/LogsRouter");
  23. var _ParseLiveQueryServer = require("./LiveQuery/ParseLiveQueryServer");
  24. var _PagesRouter = require("./Routers/PagesRouter");
  25. var _PublicAPIRouter = require("./Routers/PublicAPIRouter");
  26. var _PushRouter = require("./Routers/PushRouter");
  27. var _CloudCodeRouter = require("./Routers/CloudCodeRouter");
  28. var _RolesRouter = require("./Routers/RolesRouter");
  29. var _SchemasRouter = require("./Routers/SchemasRouter");
  30. var _SessionsRouter = require("./Routers/SessionsRouter");
  31. var _UsersRouter = require("./Routers/UsersRouter");
  32. var _PurgeRouter = require("./Routers/PurgeRouter");
  33. var _AudiencesRouter = require("./Routers/AudiencesRouter");
  34. var _AggregateRouter = require("./Routers/AggregateRouter");
  35. var _ParseServerRESTController = require("./ParseServerRESTController");
  36. var controllers = _interopRequireWildcard(require("./Controllers"));
  37. var _ParseGraphQLServer = require("./GraphQL/ParseGraphQLServer");
  38. var _SecurityRouter = require("./Routers/SecurityRouter");
  39. var _CheckRunner = _interopRequireDefault(require("./Security/CheckRunner"));
  40. var _Deprecator = _interopRequireDefault(require("./Deprecator/Deprecator"));
  41. var _DefinedSchemas = require("./SchemaMigrations/DefinedSchemas");
  42. var _Definitions = _interopRequireDefault(require("./Options/Definitions"));
  43. function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
  44. function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
  45. function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
  46. function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
  47. function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
  48. function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
  49. function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
  50. function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
  51. // ParseServer - open-source compatible API Server for Parse apps
  52. var batch = require('./batch'),
  53. bodyParser = require('body-parser'),
  54. express = require('express'),
  55. middlewares = require('./middlewares'),
  56. Parse = require('parse/node').Parse,
  57. {
  58. parse
  59. } = require('graphql'),
  60. path = require('path'),
  61. fs = require('fs');
  62. // Mutate the Parse object to add the Cloud Code handlers
  63. addParseCloud();
  64. // ParseServer works like a constructor of an express app.
  65. // https://parseplatform.org/parse-server/api/master/ParseServerOptions.html
  66. class ParseServer {
  67. /**
  68. * @constructor
  69. * @param {ParseServerOptions} options the parse server initialization options
  70. */
  71. constructor(options) {
  72. // Scan for deprecated Parse Server options
  73. _Deprecator.default.scanParseServerOptions(options);
  74. const interfaces = JSON.parse(JSON.stringify(_Definitions.default));
  75. function getValidObject(root) {
  76. const result = {};
  77. for (const key in root) {
  78. if (Object.prototype.hasOwnProperty.call(root[key], 'type')) {
  79. if (root[key].type.endsWith('[]')) {
  80. result[key] = [getValidObject(interfaces[root[key].type.slice(0, -2)])];
  81. } else {
  82. result[key] = getValidObject(interfaces[root[key].type]);
  83. }
  84. } else {
  85. result[key] = '';
  86. }
  87. }
  88. return result;
  89. }
  90. const optionsBlueprint = getValidObject(interfaces['ParseServerOptions']);
  91. function validateKeyNames(original, ref, name = '') {
  92. let result = [];
  93. const prefix = name + (name !== '' ? '.' : '');
  94. for (const key in original) {
  95. if (!Object.prototype.hasOwnProperty.call(ref, key)) {
  96. result.push(prefix + key);
  97. } else {
  98. if (ref[key] === '') continue;
  99. let res = [];
  100. if (Array.isArray(original[key]) && Array.isArray(ref[key])) {
  101. const type = ref[key][0];
  102. original[key].forEach((item, idx) => {
  103. if (typeof item === 'object' && item !== null) {
  104. res = res.concat(validateKeyNames(item, type, prefix + key + `[${idx}]`));
  105. }
  106. });
  107. } else if (typeof original[key] === 'object' && typeof ref[key] === 'object') {
  108. res = validateKeyNames(original[key], ref[key], prefix + key);
  109. }
  110. result = result.concat(res);
  111. }
  112. }
  113. return result;
  114. }
  115. const diff = validateKeyNames(options, optionsBlueprint);
  116. if (diff.length > 0) {
  117. const logger = logging.logger;
  118. logger.error(`Invalid key(s) found in Parse Server configuration: ${diff.join(', ')}`);
  119. }
  120. // Set option defaults
  121. injectDefaults(options);
  122. const {
  123. appId = (0, _requiredParameter.default)('You must provide an appId!'),
  124. masterKey = (0, _requiredParameter.default)('You must provide a masterKey!'),
  125. javascriptKey,
  126. serverURL = (0, _requiredParameter.default)('You must provide a serverURL!')
  127. } = options;
  128. // Initialize the node client SDK automatically
  129. Parse.initialize(appId, javascriptKey || 'unused', masterKey);
  130. Parse.serverURL = serverURL;
  131. _Config.default.validateOptions(options);
  132. const allControllers = controllers.getControllers(options);
  133. options.state = 'initialized';
  134. this.config = _Config.default.put(Object.assign({}, options, allControllers));
  135. this.config.masterKeyIpsStore = new Map();
  136. this.config.maintenanceKeyIpsStore = new Map();
  137. logging.setLogger(allControllers.loggerController);
  138. }
  139. /**
  140. * Starts Parse Server as an express app; this promise resolves when Parse Server is ready to accept requests.
  141. */
  142. async start() {
  143. try {
  144. var _cacheController$adap;
  145. if (this.config.state === 'ok') {
  146. return this;
  147. }
  148. this.config.state = 'starting';
  149. _Config.default.put(this.config);
  150. const {
  151. databaseController,
  152. hooksController,
  153. cacheController,
  154. cloud,
  155. security,
  156. schema,
  157. liveQueryController
  158. } = this.config;
  159. try {
  160. await databaseController.performInitialization();
  161. } catch (e) {
  162. if (e.code !== Parse.Error.DUPLICATE_VALUE) {
  163. throw e;
  164. }
  165. }
  166. const pushController = await controllers.getPushController(this.config);
  167. await hooksController.load();
  168. const startupPromises = [];
  169. if (schema) {
  170. startupPromises.push(new _DefinedSchemas.DefinedSchemas(schema, this.config).execute());
  171. }
  172. if ((_cacheController$adap = cacheController.adapter) !== null && _cacheController$adap !== void 0 && _cacheController$adap.connect && typeof cacheController.adapter.connect === 'function') {
  173. startupPromises.push(cacheController.adapter.connect());
  174. }
  175. startupPromises.push(liveQueryController.connect());
  176. await Promise.all(startupPromises);
  177. if (cloud) {
  178. addParseCloud();
  179. if (typeof cloud === 'function') {
  180. await Promise.resolve(cloud(Parse));
  181. } else if (typeof cloud === 'string') {
  182. var _json;
  183. let json;
  184. if (process.env.npm_package_json) {
  185. json = require(process.env.npm_package_json);
  186. }
  187. if (process.env.npm_package_type === 'module' || ((_json = json) === null || _json === void 0 ? void 0 : _json.type) === 'module') {
  188. await import(path.resolve(process.cwd(), cloud));
  189. } else {
  190. require(path.resolve(process.cwd(), cloud));
  191. }
  192. } else {
  193. throw "argument 'cloud' must either be a string or a function";
  194. }
  195. await new Promise(resolve => setTimeout(resolve, 10));
  196. }
  197. if (security && security.enableCheck && security.enableCheckLog) {
  198. new _CheckRunner.default(security).run();
  199. }
  200. this.config.state = 'ok';
  201. this.config = _objectSpread(_objectSpread({}, this.config), pushController);
  202. _Config.default.put(this.config);
  203. return this;
  204. } catch (error) {
  205. console.error(error);
  206. this.config.state = 'error';
  207. throw error;
  208. }
  209. }
  210. get app() {
  211. if (!this._app) {
  212. this._app = ParseServer.app(this.config);
  213. }
  214. return this._app;
  215. }
  216. handleShutdown() {
  217. var _this$liveQueryServer;
  218. const promises = [];
  219. const {
  220. adapter: databaseAdapter
  221. } = this.config.databaseController;
  222. if (databaseAdapter && typeof databaseAdapter.handleShutdown === 'function') {
  223. promises.push(databaseAdapter.handleShutdown());
  224. }
  225. const {
  226. adapter: fileAdapter
  227. } = this.config.filesController;
  228. if (fileAdapter && typeof fileAdapter.handleShutdown === 'function') {
  229. promises.push(fileAdapter.handleShutdown());
  230. }
  231. const {
  232. adapter: cacheAdapter
  233. } = this.config.cacheController;
  234. if (cacheAdapter && typeof cacheAdapter.handleShutdown === 'function') {
  235. promises.push(cacheAdapter.handleShutdown());
  236. }
  237. if ((_this$liveQueryServer = this.liveQueryServer) !== null && _this$liveQueryServer !== void 0 && (_this$liveQueryServer = _this$liveQueryServer.server) !== null && _this$liveQueryServer !== void 0 && _this$liveQueryServer.close) {
  238. promises.push(new Promise(resolve => this.liveQueryServer.server.close(resolve)));
  239. }
  240. if (this.liveQueryServer) {
  241. promises.push(this.liveQueryServer.shutdown());
  242. }
  243. return (promises.length > 0 ? Promise.all(promises) : Promise.resolve()).then(() => {
  244. if (this.config.serverCloseComplete) {
  245. this.config.serverCloseComplete();
  246. }
  247. });
  248. }
  249. /**
  250. * @static
  251. * Create an express app for the parse server
  252. * @param {Object} options let you specify the maxUploadSize when creating the express app */
  253. static app(options) {
  254. const {
  255. maxUploadSize = '20mb',
  256. appId,
  257. directAccess,
  258. pages,
  259. rateLimit = []
  260. } = options;
  261. // This app serves the Parse API directly.
  262. // It's the equivalent of https://api.parse.com/1 in the hosted Parse API.
  263. var api = express();
  264. //api.use("/apps", express.static(__dirname + "/public"));
  265. api.use(middlewares.allowCrossDomain(appId));
  266. // File handling needs to be before default middlewares are applied
  267. api.use('/', new _FilesRouter.FilesRouter().expressRouter({
  268. maxUploadSize: maxUploadSize
  269. }));
  270. api.use('/health', function (req, res) {
  271. res.status(options.state === 'ok' ? 200 : 503);
  272. if (options.state === 'starting') {
  273. res.set('Retry-After', 1);
  274. }
  275. res.json({
  276. status: options.state
  277. });
  278. });
  279. api.use('/', bodyParser.urlencoded({
  280. extended: false
  281. }), pages.enableRouter ? new _PagesRouter.PagesRouter(pages).expressRouter() : new _PublicAPIRouter.PublicAPIRouter().expressRouter());
  282. api.use(bodyParser.json({
  283. type: '*/*',
  284. limit: maxUploadSize
  285. }));
  286. api.use(middlewares.allowMethodOverride);
  287. api.use(middlewares.handleParseHeaders);
  288. const routes = Array.isArray(rateLimit) ? rateLimit : [rateLimit];
  289. for (const route of routes) {
  290. middlewares.addRateLimit(route, options);
  291. }
  292. api.use(middlewares.handleParseSession);
  293. const appRouter = ParseServer.promiseRouter({
  294. appId
  295. });
  296. api.use(appRouter.expressRouter());
  297. api.use(middlewares.handleParseErrors);
  298. // run the following when not testing
  299. if (!process.env.TESTING) {
  300. //This causes tests to spew some useless warnings, so disable in test
  301. /* istanbul ignore next */
  302. process.on('uncaughtException', err => {
  303. if (err.code === 'EADDRINUSE') {
  304. // user-friendly message for this common error
  305. process.stderr.write(`Unable to listen on port ${err.port}. The port is already in use.`);
  306. process.exit(0);
  307. } else {
  308. if (err.message) {
  309. process.stderr.write('An uncaught exception occurred: ' + err.message);
  310. }
  311. if (err.stack) {
  312. process.stderr.write('Stack Trace:\n' + err.stack);
  313. } else {
  314. process.stderr.write(err);
  315. }
  316. process.exit(1);
  317. }
  318. });
  319. // verify the server url after a 'mount' event is received
  320. /* istanbul ignore next */
  321. api.on('mount', async function () {
  322. await new Promise(resolve => setTimeout(resolve, 1000));
  323. ParseServer.verifyServerUrl();
  324. });
  325. }
  326. if (process.env.PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS === '1' || directAccess) {
  327. Parse.CoreManager.setRESTController((0, _ParseServerRESTController.ParseServerRESTController)(appId, appRouter));
  328. }
  329. return api;
  330. }
  331. static promiseRouter({
  332. appId
  333. }) {
  334. 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()];
  335. const routes = routers.reduce((memo, router) => {
  336. return memo.concat(router.routes);
  337. }, []);
  338. const appRouter = new _PromiseRouter.default(routes, appId);
  339. batch.mountOnto(appRouter);
  340. return appRouter;
  341. }
  342. /**
  343. * starts the parse server's express app
  344. * @param {ParseServerOptions} options to use to start the server
  345. * @returns {ParseServer} the parse server instance
  346. */
  347. async startApp(options) {
  348. try {
  349. await this.start();
  350. } catch (e) {
  351. console.error('Error on ParseServer.startApp: ', e);
  352. throw e;
  353. }
  354. const app = express();
  355. if (options.middleware) {
  356. let middleware;
  357. if (typeof options.middleware == 'string') {
  358. middleware = require(path.resolve(process.cwd(), options.middleware));
  359. } else {
  360. middleware = options.middleware; // use as-is let express fail
  361. }
  362. app.use(middleware);
  363. }
  364. app.use(options.mountPath, this.app);
  365. if (options.mountGraphQL === true || options.mountPlayground === true) {
  366. let graphQLCustomTypeDefs = undefined;
  367. if (typeof options.graphQLSchema === 'string') {
  368. graphQLCustomTypeDefs = parse(fs.readFileSync(options.graphQLSchema, 'utf8'));
  369. } else if (typeof options.graphQLSchema === 'object' || typeof options.graphQLSchema === 'function') {
  370. graphQLCustomTypeDefs = options.graphQLSchema;
  371. }
  372. const parseGraphQLServer = new _ParseGraphQLServer.ParseGraphQLServer(this, {
  373. graphQLPath: options.graphQLPath,
  374. playgroundPath: options.playgroundPath,
  375. graphQLCustomTypeDefs
  376. });
  377. if (options.mountGraphQL) {
  378. parseGraphQLServer.applyGraphQL(app);
  379. }
  380. if (options.mountPlayground) {
  381. parseGraphQLServer.applyPlayground(app);
  382. }
  383. }
  384. const server = await new Promise(resolve => {
  385. app.listen(options.port, options.host, function () {
  386. resolve(this);
  387. });
  388. });
  389. this.server = server;
  390. if (options.startLiveQueryServer || options.liveQueryServerOptions) {
  391. this.liveQueryServer = await ParseServer.createLiveQueryServer(server, options.liveQueryServerOptions, options);
  392. }
  393. if (options.trustProxy) {
  394. app.set('trust proxy', options.trustProxy);
  395. }
  396. /* istanbul ignore next */
  397. if (!process.env.TESTING) {
  398. configureListeners(this);
  399. }
  400. this.expressApp = app;
  401. return this;
  402. }
  403. /**
  404. * Creates a new ParseServer and starts it.
  405. * @param {ParseServerOptions} options used to start the server
  406. * @returns {ParseServer} the parse server instance
  407. */
  408. static async startApp(options) {
  409. const parseServer = new ParseServer(options);
  410. return parseServer.startApp(options);
  411. }
  412. /**
  413. * Helper method to create a liveQuery server
  414. * @static
  415. * @param {Server} httpServer an optional http server to pass
  416. * @param {LiveQueryServerOptions} config options for the liveQueryServer
  417. * @param {ParseServerOptions} options options for the ParseServer
  418. * @returns {Promise<ParseLiveQueryServer>} the live query server instance
  419. */
  420. static async createLiveQueryServer(httpServer, config, options) {
  421. if (!httpServer || config && config.port) {
  422. var app = express();
  423. httpServer = require('http').createServer(app);
  424. httpServer.listen(config.port);
  425. }
  426. const server = new _ParseLiveQueryServer.ParseLiveQueryServer(httpServer, config, options);
  427. await server.connect();
  428. return server;
  429. }
  430. static async verifyServerUrl() {
  431. // perform a health check on the serverURL value
  432. if (Parse.serverURL) {
  433. var _response$headers;
  434. const isValidHttpUrl = string => {
  435. let url;
  436. try {
  437. url = new URL(string);
  438. } catch (_) {
  439. return false;
  440. }
  441. return url.protocol === 'http:' || url.protocol === 'https:';
  442. };
  443. const url = `${Parse.serverURL.replace(/\/$/, '')}/health`;
  444. if (!isValidHttpUrl(url)) {
  445. console.warn(`\nWARNING, Unable to connect to '${Parse.serverURL}' as the URL is invalid.` + ` Cloud code and push notifications may be unavailable!\n`);
  446. return;
  447. }
  448. const request = require('./request');
  449. const response = await request({
  450. url
  451. }).catch(response => response);
  452. const json = response.data || null;
  453. const retry = (_response$headers = response.headers) === null || _response$headers === void 0 ? void 0 : _response$headers['retry-after'];
  454. if (retry) {
  455. await new Promise(resolve => setTimeout(resolve, retry * 1000));
  456. return this.verifyServerUrl();
  457. }
  458. if (response.status !== 200 || (json === null || json === void 0 ? void 0 : json.status) !== 'ok') {
  459. /* eslint-disable no-console */
  460. console.warn(`\nWARNING, Unable to connect to '${Parse.serverURL}'.` + ` Cloud code and push notifications may be unavailable!\n`);
  461. /* eslint-enable no-console */
  462. return;
  463. }
  464. return true;
  465. }
  466. }
  467. }
  468. function addParseCloud() {
  469. const ParseCloud = require('./cloud-code/Parse.Cloud');
  470. const ParseServer = require('./cloud-code/Parse.Server');
  471. Object.defineProperty(Parse, 'Server', {
  472. get() {
  473. const conf = _Config.default.get(Parse.applicationId);
  474. return _objectSpread(_objectSpread({}, conf), ParseServer);
  475. },
  476. set(newVal) {
  477. newVal.appId = Parse.applicationId;
  478. _Config.default.put(newVal);
  479. },
  480. configurable: true
  481. });
  482. Object.assign(Parse.Cloud, ParseCloud);
  483. global.Parse = Parse;
  484. }
  485. function injectDefaults(options) {
  486. Object.keys(_defaults.default).forEach(key => {
  487. if (!Object.prototype.hasOwnProperty.call(options, key)) {
  488. options[key] = _defaults.default[key];
  489. }
  490. });
  491. if (!Object.prototype.hasOwnProperty.call(options, 'serverURL')) {
  492. options.serverURL = `http://localhost:${options.port}${options.mountPath}`;
  493. }
  494. // Reserved Characters
  495. if (options.appId) {
  496. const regex = /[!#$%'()*+&/:;=?@[\]{}^,|<>]/g;
  497. if (options.appId.match(regex)) {
  498. console.warn(`\nWARNING, appId that contains special characters can cause issues while using with urls.\n`);
  499. }
  500. }
  501. // Backwards compatibility
  502. if (options.userSensitiveFields) {
  503. /* eslint-disable no-console */
  504. !process.env.TESTING && console.warn(`\nDEPRECATED: userSensitiveFields has been replaced by protectedFields allowing the ability to protect fields in all classes with CLP. \n`);
  505. /* eslint-enable no-console */
  506. const userSensitiveFields = Array.from(new Set([...(_defaults.default.userSensitiveFields || []), ...(options.userSensitiveFields || [])]));
  507. // If the options.protectedFields is unset,
  508. // it'll be assigned the default above.
  509. // Here, protect against the case where protectedFields
  510. // is set, but doesn't have _User.
  511. if (!('_User' in options.protectedFields)) {
  512. options.protectedFields = Object.assign({
  513. _User: []
  514. }, options.protectedFields);
  515. }
  516. options.protectedFields['_User']['*'] = Array.from(new Set([...(options.protectedFields['_User']['*'] || []), ...userSensitiveFields]));
  517. }
  518. // Merge protectedFields options with defaults.
  519. Object.keys(_defaults.default.protectedFields).forEach(c => {
  520. const cur = options.protectedFields[c];
  521. if (!cur) {
  522. options.protectedFields[c] = _defaults.default.protectedFields[c];
  523. } else {
  524. Object.keys(_defaults.default.protectedFields[c]).forEach(r => {
  525. const unq = new Set([...(options.protectedFields[c][r] || []), ..._defaults.default.protectedFields[c][r]]);
  526. options.protectedFields[c][r] = Array.from(unq);
  527. });
  528. }
  529. });
  530. }
  531. // Those can't be tested as it requires a subprocess
  532. /* istanbul ignore next */
  533. function configureListeners(parseServer) {
  534. const server = parseServer.server;
  535. const sockets = {};
  536. /* 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)
  537. 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. */
  538. server.on('connection', socket => {
  539. const socketId = socket.remoteAddress + ':' + socket.remotePort;
  540. sockets[socketId] = socket;
  541. socket.on('close', () => {
  542. delete sockets[socketId];
  543. });
  544. });
  545. const destroyAliveConnections = function () {
  546. for (const socketId in sockets) {
  547. try {
  548. sockets[socketId].destroy();
  549. } catch (e) {
  550. /* */
  551. }
  552. }
  553. };
  554. const handleShutdown = function () {
  555. process.stdout.write('Termination signal received. Shutting down.');
  556. destroyAliveConnections();
  557. server.close();
  558. parseServer.handleShutdown();
  559. };
  560. process.on('SIGTERM', handleShutdown);
  561. process.on('SIGINT', handleShutdown);
  562. }
  563. var _default = exports.default = ParseServer;
  564. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_Options","require","_defaults","_interopRequireDefault","logging","_interopRequireWildcard","_Config","_PromiseRouter","_requiredParameter","_AnalyticsRouter","_ClassesRouter","_FeaturesRouter","_FilesRouter","_FunctionsRouter","_GlobalConfigRouter","_GraphQLRouter","_HooksRouter","_IAPValidationRouter","_InstallationsRouter","_LogsRouter","_ParseLiveQueryServer","_PagesRouter","_PublicAPIRouter","_PushRouter","_CloudCodeRouter","_RolesRouter","_SchemasRouter","_SessionsRouter","_UsersRouter","_PurgeRouter","_AudiencesRouter","_AggregateRouter","_ParseServerRESTController","controllers","_ParseGraphQLServer","_SecurityRouter","_CheckRunner","_Deprecator","_DefinedSchemas","_Definitions","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","_toPropertyKey","value","configurable","writable","_toPrimitive","Symbol","toPrimitive","TypeError","String","Number","batch","bodyParser","express","middlewares","Parse","parse","path","fs","addParseCloud","ParseServer","constructor","options","Deprecator","scanParseServerOptions","interfaces","JSON","stringify","OptionsDefinitions","getValidObject","root","result","key","prototype","type","endsWith","slice","optionsBlueprint","validateKeyNames","original","ref","name","prefix","res","Array","isArray","item","idx","concat","diff","logger","error","join","injectDefaults","appId","requiredParameter","masterKey","javascriptKey","serverURL","initialize","Config","validateOptions","allControllers","getControllers","state","config","put","assign","masterKeyIpsStore","Map","maintenanceKeyIpsStore","setLogger","loggerController","start","_cacheController$adap","databaseController","hooksController","cacheController","cloud","security","schema","liveQueryController","performInitialization","code","Error","DUPLICATE_VALUE","pushController","getPushController","load","startupPromises","DefinedSchemas","execute","adapter","connect","Promise","all","resolve","_json","json","process","env","npm_package_json","npm_package_type","cwd","setTimeout","enableCheck","enableCheckLog","CheckRunner","run","console","app","_app","handleShutdown","_this$liveQueryServer","promises","databaseAdapter","fileAdapter","filesController","cacheAdapter","liveQueryServer","server","close","shutdown","then","serverCloseComplete","maxUploadSize","directAccess","pages","rateLimit","api","use","allowCrossDomain","FilesRouter","expressRouter","req","status","urlencoded","extended","enableRouter","PagesRouter","PublicAPIRouter","limit","allowMethodOverride","handleParseHeaders","routes","route","addRateLimit","handleParseSession","appRouter","promiseRouter","handleParseErrors","TESTING","on","err","stderr","write","port","exit","message","stack","verifyServerUrl","PARSE_SERVER_ENABLE_EXPERIMENTAL_DIRECT_ACCESS","CoreManager","setRESTController","ParseServerRESTController","routers","ClassesRouter","UsersRouter","SessionsRouter","RolesRouter","AnalyticsRouter","InstallationsRouter","FunctionsRouter","SchemasRouter","PushRouter","LogsRouter","IAPValidationRouter","FeaturesRouter","GlobalConfigRouter","GraphQLRouter","PurgeRouter","HooksRouter","CloudCodeRouter","AudiencesRouter","AggregateRouter","SecurityRouter","reduce","memo","router","PromiseRouter","mountOnto","startApp","middleware","mountPath","mountGraphQL","mountPlayground","graphQLCustomTypeDefs","undefined","graphQLSchema","readFileSync","parseGraphQLServer","ParseGraphQLServer","graphQLPath","playgroundPath","applyGraphQL","applyPlayground","listen","host","startLiveQueryServer","liveQueryServerOptions","createLiveQueryServer","trustProxy","configureListeners","expressApp","parseServer","httpServer","createServer","ParseLiveQueryServer","_response$headers","isValidHttpUrl","string","url","URL","_","protocol","replace","warn","request","response","catch","data","retry","headers","ParseCloud","conf","applicationId","newVal","Cloud","global","defaults","regex","match","userSensitiveFields","from","Set","protectedFields","_User","c","cur","unq","sockets","socket","socketId","remoteAddress","remotePort","destroyAliveConnections","destroy","stdout","_default","exports"],"sources":["../src/ParseServer.js"],"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';\nimport OptionsDefinitions from './Options/Definitions';\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\n    const interfaces = JSON.parse(JSON.stringify(OptionsDefinitions));\n\n    function getValidObject(root) {\n      const result = {};\n      for (const key in root) {\n        if (Object.prototype.hasOwnProperty.call(root[key], 'type')) {\n          if (root[key].type.endsWith('[]')) {\n            result[key] = [getValidObject(interfaces[root[key].type.slice(0, -2)])];\n          } else {\n            result[key] = getValidObject(interfaces[root[key].type]);\n          }\n        } else {\n          result[key] = '';\n        }\n      }\n      return result;\n    }\n\n    const optionsBlueprint = getValidObject(interfaces['ParseServerOptions']);\n\n    function validateKeyNames(original, ref, name = '') {\n      let result = [];\n      const prefix = name + (name !== '' ? '.' : '');\n      for (const key in original) {\n        if (!Object.prototype.hasOwnProperty.call(ref, key)) {\n          result.push(prefix + key);\n        } else {\n          if (ref[key] === '') continue;\n          let res = [];\n          if (Array.isArray(original[key]) && Array.isArray(ref[key])) {\n            const type = ref[key][0];\n            original[key].forEach((item, idx) => {\n              if (typeof item === 'object' && item !== null) {\n                res = res.concat(validateKeyNames(item, type, prefix + key + `[${idx}]`));\n              }\n            });\n          } else if (typeof original[key] === 'object' && typeof ref[key] === 'object') {\n            res = validateKeyNames(original[key], ref[key], prefix + key);\n          }\n          result = result.concat(res);\n        }\n      }\n      return result;\n    }\n\n    const diff = validateKeyNames(options, optionsBlueprint);\n    if (diff.length > 0) {\n      const logger = logging.logger;\n      logger.error(`Invalid key(s) found in Parse Server configuration: ${diff.join(', ')}`);\n    }\n\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      javascriptKey,\n      serverURL = requiredParameter('You must provide a serverURL!'),\n    } = options;\n    // Initialize the node client SDK automatically\n    Parse.initialize(appId, javascriptKey || 'unused', masterKey);\n    Parse.serverURL = serverURL;\n    Config.validateOptions(options);\n    const allControllers = controllers.getControllers(options);\n\n    options.state = 'initialized';\n    this.config = Config.put(Object.assign({}, options, allControllers));\n    this.config.masterKeyIpsStore = new Map();\n    this.config.maintenanceKeyIpsStore = new Map();\n    logging.setLogger(allControllers.loggerController);\n  }\n\n  /**\n   * Starts Parse Server as an express app; this promise resolves when Parse Server is ready to accept requests.\n   */\n\n  async start() {\n    try {\n      if (this.config.state === 'ok') {\n        return this;\n      }\n      this.config.state = 'starting';\n      Config.put(this.config);\n      const {\n        databaseController,\n        hooksController,\n        cacheController,\n        cloud,\n        security,\n        schema,\n        liveQueryController,\n      } = this.config;\n      try {\n        await databaseController.performInitialization();\n      } catch (e) {\n        if (e.code !== Parse.Error.DUPLICATE_VALUE) {\n          throw e;\n        }\n      }\n      const pushController = await controllers.getPushController(this.config);\n      await hooksController.load();\n      const startupPromises = [];\n      if (schema) {\n        startupPromises.push(new DefinedSchemas(schema, this.config).execute());\n      }\n      if (\n        cacheController.adapter?.connect &&\n        typeof cacheController.adapter.connect === 'function'\n      ) {\n        startupPromises.push(cacheController.adapter.connect());\n      }\n      startupPromises.push(liveQueryController.connect());\n      await Promise.all(startupPromises);\n      if (cloud) {\n        addParseCloud();\n        if (typeof cloud === 'function') {\n          await Promise.resolve(cloud(Parse));\n        } else if (typeof cloud === 'string') {\n          let json;\n          if (process.env.npm_package_json) {\n            json = require(process.env.npm_package_json);\n          }\n          if (process.env.npm_package_type === 'module' || json?.type === 'module') {\n            await import(path.resolve(process.cwd(), cloud));\n          } else {\n            require(path.resolve(process.cwd(), cloud));\n          }\n        } else {\n          throw \"argument 'cloud' must either be a string or a function\";\n        }\n        await new Promise(resolve => setTimeout(resolve, 10));\n      }\n      if (security && security.enableCheck && security.enableCheckLog) {\n        new CheckRunner(security).run();\n      }\n      this.config.state = 'ok';\n      this.config = { ...this.config, ...pushController };\n      Config.put(this.config);\n      return this;\n    } catch (error) {\n      console.error(error);\n      this.config.state = 'error';\n      throw error;\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    if (this.liveQueryServer?.server?.close) {\n      promises.push(new Promise(resolve => this.liveQueryServer.server.close(resolve)));\n    }\n    if (this.liveQueryServer) {\n      promises.push(this.liveQueryServer.shutdown());\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, rateLimit = [] } = 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.status(options.state === 'ok' ? 200 : 503);\n      if (options.state === 'starting') {\n        res.set('Retry-After', 1);\n      }\n      res.json({\n        status: options.state,\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    const routes = Array.isArray(rateLimit) ? rateLimit : [rateLimit];\n    for (const route of routes) {\n      middlewares.addRateLimit(route, options);\n    }\n    api.use(middlewares.handleParseSession);\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          if (err.message) {\n            process.stderr.write('An uncaught exception occurred: ' + err.message);\n          }\n          if (err.stack) {\n            process.stderr.write('Stack Trace:\\n' + err.stack);\n          } else {\n            process.stderr.write(err);\n          }\n          process.exit(1);\n        }\n      });\n      // verify the server url after a 'mount' event is received\n      /* istanbul ignore next */\n      api.on('mount', async function () {\n        await new Promise(resolve => setTimeout(resolve, 1000));\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   * @returns {ParseServer} the parse server instance\n   */\n\n  async startApp(options: ParseServerOptions) {\n    try {\n      await this.start();\n    } catch (e) {\n      console.error('Error on ParseServer.startApp: ', e);\n      throw e;\n    }\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    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    const server = await new Promise(resolve => {\n      app.listen(options.port, options.host, function () {\n        resolve(this);\n      });\n    });\n    this.server = server;\n\n    if (options.startLiveQueryServer || options.liveQueryServerOptions) {\n      this.liveQueryServer = await ParseServer.createLiveQueryServer(\n        server,\n        options.liveQueryServerOptions,\n        options\n      );\n    }\n    if (options.trustProxy) {\n      app.set('trust proxy', options.trustProxy);\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   * @returns {ParseServer} the parse server instance\n   */\n  static async startApp(options: ParseServerOptions) {\n    const parseServer = new ParseServer(options);\n    return parseServer.startApp(options);\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 {Promise<ParseLiveQueryServer>} the live query server instance\n   */\n  static async 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    const server = new ParseLiveQueryServer(httpServer, config, options);\n    await server.connect();\n    return server;\n  }\n\n  static async verifyServerUrl() {\n    // perform a health check on the serverURL value\n    if (Parse.serverURL) {\n      const isValidHttpUrl = string => {\n        let url;\n        try {\n          url = new URL(string);\n        } catch (_) {\n          return false;\n        }\n        return url.protocol === 'http:' || url.protocol === 'https:';\n      };\n      const url = `${Parse.serverURL.replace(/\\/$/, '')}/health`;\n      if (!isValidHttpUrl(url)) {\n        console.warn(\n          `\\nWARNING, Unable to connect to '${Parse.serverURL}' as the URL is invalid.` +\n            ` Cloud code and push notifications may be unavailable!\\n`\n        );\n        return;\n      }\n      const request = require('./request');\n      const response = await request({ url }).catch(response => response);\n      const json = response.data || null;\n      const retry = response.headers?.['retry-after'];\n      if (retry) {\n        await new Promise(resolve => setTimeout(resolve, retry * 1000));\n        return this.verifyServerUrl();\n      }\n      if (response.status !== 200 || 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        return;\n      }\n      return true;\n    }\n  }\n}\n\nfunction addParseCloud() {\n  const ParseCloud = require('./cloud-code/Parse.Cloud');\n  const ParseServer = require('./cloud-code/Parse.Server');\n  Object.defineProperty(Parse, 'Server', {\n    get() {\n      const conf = Config.get(Parse.applicationId);\n      return { ...conf, ...ParseServer };\n    },\n    set(newVal) {\n      newVal.appId = Parse.applicationId;\n      Config.put(newVal);\n    },\n    configurable: true,\n  });\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\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"],"mappings":"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","ignoreList":[]}