parse-server 8.1.0-alpha.2 → 8.1.0-alpha.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -47,7 +47,7 @@ A big *thank you* 🙏 to our [sponsors](#sponsors) and [backers](#backers) who
47
47
  - [PostgreSQL](#postgresql)
48
48
  - [Locally](#locally)
49
49
  - [Docker Container](#docker-container)
50
- - [Saving an Object](#saving-an-object)
50
+ - [Saving and Querying Objects](#saving-and-querying-objects)
51
51
  - [Connect an SDK](#connect-an-sdk)
52
52
  - [Running Parse Server elsewhere](#running-parse-server-elsewhere)
53
53
  - [Sample Application](#sample-application)
@@ -186,70 +186,9 @@ That's it! You are now running a standalone version of Parse Server on your mach
186
186
 
187
187
  **Using a remote MongoDB?** Pass the `--databaseURI DATABASE_URI` parameter when starting `parse-server`. Learn more about configuring Parse Server [here](#configuration). For a full list of available options, run `parse-server --help`.
188
188
 
189
- ### Saving an Object
189
+ ### Saving and Querying Objects
190
190
 
191
- Now that you're running Parse Server, it is time to save your first object. We'll use the [REST API](http://docs.parseplatform.org/rest/guide), but you can easily do the same using any of the [Parse SDKs](http://parseplatform.org/#sdks). Run the following:
192
-
193
- ```bash
194
- $ curl -X POST \
195
- -H "X-Parse-Application-Id: APPLICATION_ID" \
196
- -H "Content-Type: application/json" \
197
- -d '{"score":1337,"playerName":"Sean Plott","cheatMode":false}' \
198
- http://localhost:1337/parse/classes/GameScore
199
- ```
200
-
201
- You should get a response similar to this:
202
-
203
- ```js
204
- {
205
- "objectId": "2ntvSpRGIK",
206
- "createdAt": "2016-03-11T23:51:48.050Z"
207
- }
208
- ```
209
-
210
- You can now retrieve this object directly (make sure to replace `2ntvSpRGIK` with the actual `objectId` you received when the object was created):
211
-
212
- ```bash
213
- $ curl -X GET \
214
- -H "X-Parse-Application-Id: APPLICATION_ID" \
215
- http://localhost:1337/parse/classes/GameScore/2ntvSpRGIK
216
- ```
217
- ```json
218
- // Response
219
- {
220
- "objectId": "2ntvSpRGIK",
221
- "score": 1337,
222
- "playerName": "Sean Plott",
223
- "cheatMode": false,
224
- "updatedAt": "2016-03-11T23:51:48.050Z",
225
- "createdAt": "2016-03-11T23:51:48.050Z"
226
- }
227
- ```
228
-
229
- Keeping tracks of individual object ids is not ideal, however. In most cases you will want to run a query over the collection, like so:
230
-
231
- ```bash
232
- $ curl -X GET \
233
- -H "X-Parse-Application-Id: APPLICATION_ID" \
234
- http://localhost:1337/parse/classes/GameScore
235
- ```
236
- ```json
237
- // The response will provide all the matching objects within the `results` array:
238
- {
239
- "results": [
240
- {
241
- "objectId": "2ntvSpRGIK",
242
- "score": 1337,
243
- "playerName": "Sean Plott",
244
- "cheatMode": false,
245
- "updatedAt": "2016-03-11T23:51:48.050Z",
246
- "createdAt": "2016-03-11T23:51:48.050Z"
247
- }
248
- ]
249
- }
250
- ```
251
-
252
- To learn more about using saving and querying objects on Parse Server, check out the [Parse documentation](http://docs.parseplatform.org).
191
+ Now that you're running Parse Server, it is time to save your first object. The easiest way is to use the [REST API](http://docs.parseplatform.org/rest/guide), but you can easily do the same using any of the [Parse SDKs](http://parseplatform.org/#sdks). To learn more check out the [documentation](http://docs.parseplatform.org).
253
192
 
254
193
  ### Connect an SDK
255
194
 
@@ -84,9 +84,19 @@ class ParseLiveQueryServer {
84
84
  }
85
85
  async shutdown() {
86
86
  if (this.subscriber.isOpen) {
87
- await Promise.all([...[...this.clients.values()].map(client => client.parseWebSocket.ws.close()), this.parseWebSocketServer.close(), ...Array.from(this.subscriber.subscriptions.keys()).map(key => this.subscriber.unsubscribe(key)), this.subscriber.close?.()]);
87
+ await Promise.all([...[...this.clients.values()].map(client => client.parseWebSocket.ws.close()), this.parseWebSocketServer.close?.(), ...Array.from(this.subscriber.subscriptions?.keys() || []).map(key => this.subscriber.unsubscribe(key)), this.subscriber.close?.()]);
88
+ }
89
+ if (typeof this.subscriber.quit === 'function') {
90
+ try {
91
+ await this.subscriber.quit();
92
+ } catch (err) {
93
+ _logger.default.error('PubSubAdapter error on shutdown', {
94
+ error: err
95
+ });
96
+ }
97
+ } else {
98
+ this.subscriber.isOpen = false;
88
99
  }
89
- this.subscriber.isOpen = false;
90
100
  }
91
101
  _createSubscribers() {
92
102
  const messageRecieved = (channel, messageStr) => {
@@ -840,4 +850,4 @@ class ParseLiveQueryServer {
840
850
  }
841
851
  }
842
852
  exports.ParseLiveQueryServer = ParseLiveQueryServer;
843
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_tv","_interopRequireDefault","require","_node","_Subscription","_Client","_ParseWebSocketServer","_logger","_RequestSchema","_QueryTools","_ParsePubSub","_SchemaController","_lodash","_uuid","_triggers","_Auth","_Controllers","_lruCache","_UsersRouter","_DatabaseController","_util","_deepcopy","e","__esModule","default","ParseLiveQueryServer","constructor","server","config","parseServerConfig","clients","Map","subscriptions","appId","Parse","applicationId","masterKey","keyPairs","key","Object","keys","set","logger","verbose","disableSingleInstance","serverURL","initialize","javaScriptKey","cacheController","getCacheController","cacheTimeout","authCache","LRU","max","ttl","parseWebSocketServer","ParseWebSocketServer","parseWebsocket","_onConnect","subscriber","ParsePubSub","createSubscriber","connect","isOpen","Promise","resolve","_createSubscribers","shutdown","all","values","map","client","parseWebSocket","ws","close","Array","from","unsubscribe","messageRecieved","channel","messageStr","message","JSON","parse","error","_clearCachedRoles","userId","_inflateParseObject","_onAfterSave","_onAfterDelete","on","field","subscribe","currentParseObject","UserRouter","removeHiddenProperties","className","parseObject","_finishFetch","originalParseObject","deletedParseObject","toJSON","classLevelPermissions","id","size","classSubscriptions","get","debug","subscription","isSubscriptionMatched","_matchesSubscription","clientId","requestIds","_","entries","clientRequestIds","forEach","requestId","acl","getACL","op","_getCLPOperation","query","res","_matchesCLP","isMatched","_matchesACL","event","sessionToken","object","useMasterKey","hasMasterKey","installationId","sendEvent","trigger","getTrigger","auth","getAuthFromClient","user","fromJSON","runTrigger","toJSONwithObjects","_filterSensitiveData","pushDelete","resolveError","Client","pushError","code","stringify","isOriginalSubscriptionMatched","isCurrentSubscriptionMatched","originalACLCheckingPromise","originalACL","currentACLCheckingPromise","currentACL","isOriginalMatched","isCurrentMatched","hash","type","watchFieldsChanged","_checkWatchFields","original","functionName","charAt","toUpperCase","slice","request","tv4","validate","RequestSchema","_handleConnect","_handleSubscribe","_handleUpdateSubscription","_handleUnsubscribe","info","has","runLiveQueryEventHandlers","delete","subscriptionInfo","subscriptionInfos","deleteClientSubscription","hasSubscribingClient","matchesQuery","deepcopy","validTokens","Query","Session","equalTo","User","createWithoutData","find","token","authPromise","auth1","auth2","getAuthForSessionToken","clearRoleCache","fromCache","then","catch","result","Error","INVALID_SESSION_TOKEN","getSubscriptionInfo","aclGroup","push","SchemaController","validatePermission","clientAuth","filter","obj","protectedFields","isArray","getDatabaseController","addProtectedFields","DatabaseController","filterSensitiveData","length","objectId","_verifyACL","isSubscriptionSessionTokenMatched","getReadAccess","acl_has_roles","permissionsById","some","startsWith","roleNames","getUserRoles","role","getSessionFromClient","watch","isDeepStrictEqual","getPublicReadAccess","subscriptionToken","clientSessionToken","_validateKeys","_hasMasterKey","uuidv4","req","pushConnect","validKeyPairs","prototype","hasOwnProperty","call","isValid","secret","authCalled","parseQuery","withJSON","where","toPointer","master","subscriptionHash","queryHash","Subscription","split","addSubscriptionInfo","addClientSubscription","pushSubscribe","notifyClient","deleteSubscriptionInfo","pushUnsubscribe","exports"],"sources":["../../src/LiveQuery/ParseLiveQueryServer.js"],"sourcesContent":["import tv4 from 'tv4';\nimport Parse from 'parse/node';\nimport { Subscription } from './Subscription';\nimport { Client } from './Client';\nimport { ParseWebSocketServer } from './ParseWebSocketServer';\nimport logger from '../logger';\nimport RequestSchema from './RequestSchema';\nimport { matchesQuery, queryHash } from './QueryTools';\nimport { ParsePubSub } from './ParsePubSub';\nimport SchemaController from '../Controllers/SchemaController';\nimport _ from 'lodash';\nimport { v4 as uuidv4 } from 'uuid';\nimport {\n  runLiveQueryEventHandlers,\n  getTrigger,\n  runTrigger,\n  resolveError,\n  toJSONwithObjects,\n} from '../triggers';\nimport { getAuthForSessionToken, Auth } from '../Auth';\nimport { getCacheController, getDatabaseController } from '../Controllers';\nimport { LRUCache as LRU } from 'lru-cache';\nimport UserRouter from '../Routers/UsersRouter';\nimport DatabaseController from '../Controllers/DatabaseController';\nimport { isDeepStrictEqual } from 'util';\nimport deepcopy from 'deepcopy';\n\nclass ParseLiveQueryServer {\n  clients: Map;\n  // className -> (queryHash -> subscription)\n  subscriptions: Object;\n  parseWebSocketServer: Object;\n  keyPairs: any;\n  // The subscriber we use to get object update from publisher\n  subscriber: Object;\n\n  constructor(server: any, config: any = {}, parseServerConfig: any = {}) {\n    this.server = server;\n    this.clients = new Map();\n    this.subscriptions = new Map();\n    this.config = config;\n\n    config.appId = config.appId || Parse.applicationId;\n    config.masterKey = config.masterKey || Parse.masterKey;\n\n    // Store keys, convert obj to map\n    const keyPairs = config.keyPairs || {};\n    this.keyPairs = new Map();\n    for (const key of Object.keys(keyPairs)) {\n      this.keyPairs.set(key, keyPairs[key]);\n    }\n    logger.verbose('Support key pairs', this.keyPairs);\n\n    // Initialize Parse\n    Parse.Object.disableSingleInstance();\n    const serverURL = config.serverURL || Parse.serverURL;\n    Parse.serverURL = serverURL;\n    Parse.initialize(config.appId, Parse.javaScriptKey, config.masterKey);\n\n    // The cache controller is a proper cache controller\n    // with access to User and Roles\n    this.cacheController = getCacheController(parseServerConfig);\n\n    config.cacheTimeout = config.cacheTimeout || 5 * 1000; // 5s\n\n    // This auth cache stores the promises for each auth resolution.\n    // The main benefit is to be able to reuse the same user / session token resolution.\n    this.authCache = new LRU({\n      max: 500, // 500 concurrent\n      ttl: config.cacheTimeout,\n    });\n    // Initialize websocket server\n    this.parseWebSocketServer = new ParseWebSocketServer(\n      server,\n      parseWebsocket => this._onConnect(parseWebsocket),\n      config\n    );\n    this.subscriber = ParsePubSub.createSubscriber(config);\n    if (!this.subscriber.connect) {\n      this.connect();\n    }\n  }\n\n  async connect() {\n    if (this.subscriber.isOpen) {\n      return;\n    }\n    if (typeof this.subscriber.connect === 'function') {\n      await Promise.resolve(this.subscriber.connect());\n    } else {\n      this.subscriber.isOpen = true;\n    }\n    this._createSubscribers();\n  }\n\n  async shutdown() {\n    if (this.subscriber.isOpen) {\n      await Promise.all([\n        ...[...this.clients.values()].map(client => client.parseWebSocket.ws.close()),\n        this.parseWebSocketServer.close(),\n        ...Array.from(this.subscriber.subscriptions.keys()).map(key =>\n          this.subscriber.unsubscribe(key)\n        ),\n        this.subscriber.close?.(),\n      ]);\n    }\n    this.subscriber.isOpen = false;\n  }\n\n  _createSubscribers() {\n    const messageRecieved = (channel, messageStr) => {\n      logger.verbose('Subscribe message %j', messageStr);\n      let message;\n      try {\n        message = JSON.parse(messageStr);\n      } catch (e) {\n        logger.error('unable to parse message', messageStr, e);\n        return;\n      }\n      if (channel === Parse.applicationId + 'clearCache') {\n        this._clearCachedRoles(message.userId);\n        return;\n      }\n      this._inflateParseObject(message);\n      if (channel === Parse.applicationId + 'afterSave') {\n        this._onAfterSave(message);\n      } else if (channel === Parse.applicationId + 'afterDelete') {\n        this._onAfterDelete(message);\n      } else {\n        logger.error('Get message %s from unknown channel %j', message, channel);\n      }\n    };\n    this.subscriber.on('message', (channel, messageStr) => messageRecieved(channel, messageStr));\n    for (const field of ['afterSave', 'afterDelete', 'clearCache']) {\n      const channel = `${Parse.applicationId}${field}`;\n      this.subscriber.subscribe(channel, messageStr => messageRecieved(channel, messageStr));\n    }\n  }\n\n  // Message is the JSON object from publisher. Message.currentParseObject is the ParseObject JSON after changes.\n  // Message.originalParseObject is the original ParseObject JSON.\n  _inflateParseObject(message: any): void {\n    // Inflate merged object\n    const currentParseObject = message.currentParseObject;\n    UserRouter.removeHiddenProperties(currentParseObject);\n    let className = currentParseObject.className;\n    let parseObject = new Parse.Object(className);\n    parseObject._finishFetch(currentParseObject);\n    message.currentParseObject = parseObject;\n    // Inflate original object\n    const originalParseObject = message.originalParseObject;\n    if (originalParseObject) {\n      UserRouter.removeHiddenProperties(originalParseObject);\n      className = originalParseObject.className;\n      parseObject = new Parse.Object(className);\n      parseObject._finishFetch(originalParseObject);\n      message.originalParseObject = parseObject;\n    }\n  }\n\n  // Message is the JSON object from publisher after inflated. Message.currentParseObject is the ParseObject after changes.\n  // Message.originalParseObject is the original ParseObject.\n  async _onAfterDelete(message: any): void {\n    logger.verbose(Parse.applicationId + 'afterDelete is triggered');\n\n    let deletedParseObject = message.currentParseObject.toJSON();\n    const classLevelPermissions = message.classLevelPermissions;\n    const className = deletedParseObject.className;\n    logger.verbose('ClassName: %j | ObjectId: %s', className, deletedParseObject.id);\n    logger.verbose('Current client number : %d', this.clients.size);\n\n    const classSubscriptions = this.subscriptions.get(className);\n    if (typeof classSubscriptions === 'undefined') {\n      logger.debug('Can not find subscriptions under this class ' + className);\n      return;\n    }\n\n    for (const subscription of classSubscriptions.values()) {\n      const isSubscriptionMatched = this._matchesSubscription(deletedParseObject, subscription);\n      if (!isSubscriptionMatched) {\n        continue;\n      }\n      for (const [clientId, requestIds] of _.entries(subscription.clientRequestIds)) {\n        const client = this.clients.get(clientId);\n        if (typeof client === 'undefined') {\n          continue;\n        }\n        requestIds.forEach(async requestId => {\n          const acl = message.currentParseObject.getACL();\n          // Check CLP\n          const op = this._getCLPOperation(subscription.query);\n          let res = {};\n          try {\n            await this._matchesCLP(\n              classLevelPermissions,\n              message.currentParseObject,\n              client,\n              requestId,\n              op\n            );\n            const isMatched = await this._matchesACL(acl, client, requestId);\n            if (!isMatched) {\n              return null;\n            }\n            res = {\n              event: 'delete',\n              sessionToken: client.sessionToken,\n              object: deletedParseObject,\n              clients: this.clients.size,\n              subscriptions: this.subscriptions.size,\n              useMasterKey: client.hasMasterKey,\n              installationId: client.installationId,\n              sendEvent: true,\n            };\n            const trigger = getTrigger(className, 'afterEvent', Parse.applicationId);\n            if (trigger) {\n              const auth = await this.getAuthFromClient(client, requestId);\n              if (auth && auth.user) {\n                res.user = auth.user;\n              }\n              if (res.object) {\n                res.object = Parse.Object.fromJSON(res.object);\n              }\n              await runTrigger(trigger, `afterEvent.${className}`, res, auth);\n            }\n            if (!res.sendEvent) {\n              return;\n            }\n            if (res.object && typeof res.object.toJSON === 'function') {\n              deletedParseObject = toJSONwithObjects(res.object, res.object.className || className);\n            }\n            await this._filterSensitiveData(\n              classLevelPermissions,\n              res,\n              client,\n              requestId,\n              op,\n              subscription.query\n            );\n            client.pushDelete(requestId, deletedParseObject);\n          } catch (e) {\n            const error = resolveError(e);\n            Client.pushError(client.parseWebSocket, error.code, error.message, false, requestId);\n            logger.error(\n              `Failed running afterLiveQueryEvent on class ${className} for event ${res.event} with session ${res.sessionToken} with:\\n Error: ` +\n                JSON.stringify(error)\n            );\n          }\n        });\n      }\n    }\n  }\n\n  // Message is the JSON object from publisher after inflated. Message.currentParseObject is the ParseObject after changes.\n  // Message.originalParseObject is the original ParseObject.\n  async _onAfterSave(message: any): void {\n    logger.verbose(Parse.applicationId + 'afterSave is triggered');\n\n    let originalParseObject = null;\n    if (message.originalParseObject) {\n      originalParseObject = message.originalParseObject.toJSON();\n    }\n    const classLevelPermissions = message.classLevelPermissions;\n    let currentParseObject = message.currentParseObject.toJSON();\n    const className = currentParseObject.className;\n    logger.verbose('ClassName: %s | ObjectId: %s', className, currentParseObject.id);\n    logger.verbose('Current client number : %d', this.clients.size);\n\n    const classSubscriptions = this.subscriptions.get(className);\n    if (typeof classSubscriptions === 'undefined') {\n      logger.debug('Can not find subscriptions under this class ' + className);\n      return;\n    }\n    for (const subscription of classSubscriptions.values()) {\n      const isOriginalSubscriptionMatched = this._matchesSubscription(\n        originalParseObject,\n        subscription\n      );\n      const isCurrentSubscriptionMatched = this._matchesSubscription(\n        currentParseObject,\n        subscription\n      );\n      for (const [clientId, requestIds] of _.entries(subscription.clientRequestIds)) {\n        const client = this.clients.get(clientId);\n        if (typeof client === 'undefined') {\n          continue;\n        }\n        requestIds.forEach(async requestId => {\n          // Set orignal ParseObject ACL checking promise, if the object does not match\n          // subscription, we do not need to check ACL\n          let originalACLCheckingPromise;\n          if (!isOriginalSubscriptionMatched) {\n            originalACLCheckingPromise = Promise.resolve(false);\n          } else {\n            let originalACL;\n            if (message.originalParseObject) {\n              originalACL = message.originalParseObject.getACL();\n            }\n            originalACLCheckingPromise = this._matchesACL(originalACL, client, requestId);\n          }\n          // Set current ParseObject ACL checking promise, if the object does not match\n          // subscription, we do not need to check ACL\n          let currentACLCheckingPromise;\n          let res = {};\n          if (!isCurrentSubscriptionMatched) {\n            currentACLCheckingPromise = Promise.resolve(false);\n          } else {\n            const currentACL = message.currentParseObject.getACL();\n            currentACLCheckingPromise = this._matchesACL(currentACL, client, requestId);\n          }\n          try {\n            const op = this._getCLPOperation(subscription.query);\n            await this._matchesCLP(\n              classLevelPermissions,\n              message.currentParseObject,\n              client,\n              requestId,\n              op\n            );\n            const [isOriginalMatched, isCurrentMatched] = await Promise.all([\n              originalACLCheckingPromise,\n              currentACLCheckingPromise,\n            ]);\n            logger.verbose(\n              'Original %j | Current %j | Match: %s, %s, %s, %s | Query: %s',\n              originalParseObject,\n              currentParseObject,\n              isOriginalSubscriptionMatched,\n              isCurrentSubscriptionMatched,\n              isOriginalMatched,\n              isCurrentMatched,\n              subscription.hash\n            );\n            // Decide event type\n            let type;\n            if (isOriginalMatched && isCurrentMatched) {\n              type = 'update';\n            } else if (isOriginalMatched && !isCurrentMatched) {\n              type = 'leave';\n            } else if (!isOriginalMatched && isCurrentMatched) {\n              if (originalParseObject) {\n                type = 'enter';\n              } else {\n                type = 'create';\n              }\n            } else {\n              return null;\n            }\n            const watchFieldsChanged = this._checkWatchFields(client, requestId, message);\n            if (!watchFieldsChanged && (type === 'update' || type === 'create')) {\n              return;\n            }\n            res = {\n              event: type,\n              sessionToken: client.sessionToken,\n              object: currentParseObject,\n              original: originalParseObject,\n              clients: this.clients.size,\n              subscriptions: this.subscriptions.size,\n              useMasterKey: client.hasMasterKey,\n              installationId: client.installationId,\n              sendEvent: true,\n            };\n            const trigger = getTrigger(className, 'afterEvent', Parse.applicationId);\n            if (trigger) {\n              if (res.object) {\n                res.object = Parse.Object.fromJSON(res.object);\n              }\n              if (res.original) {\n                res.original = Parse.Object.fromJSON(res.original);\n              }\n              const auth = await this.getAuthFromClient(client, requestId);\n              if (auth && auth.user) {\n                res.user = auth.user;\n              }\n              await runTrigger(trigger, `afterEvent.${className}`, res, auth);\n            }\n            if (!res.sendEvent) {\n              return;\n            }\n            if (res.object && typeof res.object.toJSON === 'function') {\n              currentParseObject = toJSONwithObjects(res.object, res.object.className || className);\n            }\n            if (res.original && typeof res.original.toJSON === 'function') {\n              originalParseObject = toJSONwithObjects(\n                res.original,\n                res.original.className || className\n              );\n            }\n            await this._filterSensitiveData(\n              classLevelPermissions,\n              res,\n              client,\n              requestId,\n              op,\n              subscription.query\n            );\n            const functionName = 'push' + res.event.charAt(0).toUpperCase() + res.event.slice(1);\n            if (client[functionName]) {\n              client[functionName](requestId, currentParseObject, originalParseObject);\n            }\n          } catch (e) {\n            const error = resolveError(e);\n            Client.pushError(client.parseWebSocket, error.code, error.message, false, requestId);\n            logger.error(\n              `Failed running afterLiveQueryEvent on class ${className} for event ${res.event} with session ${res.sessionToken} with:\\n Error: ` +\n                JSON.stringify(error)\n            );\n          }\n        });\n      }\n    }\n  }\n\n  _onConnect(parseWebsocket: any): void {\n    parseWebsocket.on('message', request => {\n      if (typeof request === 'string') {\n        try {\n          request = JSON.parse(request);\n        } catch (e) {\n          logger.error('unable to parse request', request, e);\n          return;\n        }\n      }\n      logger.verbose('Request: %j', request);\n\n      // Check whether this request is a valid request, return error directly if not\n      if (\n        !tv4.validate(request, RequestSchema['general']) ||\n        !tv4.validate(request, RequestSchema[request.op])\n      ) {\n        Client.pushError(parseWebsocket, 1, tv4.error.message);\n        logger.error('Connect message error %s', tv4.error.message);\n        return;\n      }\n\n      switch (request.op) {\n        case 'connect':\n          this._handleConnect(parseWebsocket, request);\n          break;\n        case 'subscribe':\n          this._handleSubscribe(parseWebsocket, request);\n          break;\n        case 'update':\n          this._handleUpdateSubscription(parseWebsocket, request);\n          break;\n        case 'unsubscribe':\n          this._handleUnsubscribe(parseWebsocket, request);\n          break;\n        default:\n          Client.pushError(parseWebsocket, 3, 'Get unknown operation');\n          logger.error('Get unknown operation', request.op);\n      }\n    });\n\n    parseWebsocket.on('disconnect', () => {\n      logger.info(`Client disconnect: ${parseWebsocket.clientId}`);\n      const clientId = parseWebsocket.clientId;\n      if (!this.clients.has(clientId)) {\n        runLiveQueryEventHandlers({\n          event: 'ws_disconnect_error',\n          clients: this.clients.size,\n          subscriptions: this.subscriptions.size,\n          error: `Unable to find client ${clientId}`,\n        });\n        logger.error(`Can not find client ${clientId} on disconnect`);\n        return;\n      }\n\n      // Delete client\n      const client = this.clients.get(clientId);\n      this.clients.delete(clientId);\n\n      // Delete client from subscriptions\n      for (const [requestId, subscriptionInfo] of _.entries(client.subscriptionInfos)) {\n        const subscription = subscriptionInfo.subscription;\n        subscription.deleteClientSubscription(clientId, requestId);\n\n        // If there is no client which is subscribing this subscription, remove it from subscriptions\n        const classSubscriptions = this.subscriptions.get(subscription.className);\n        if (!subscription.hasSubscribingClient()) {\n          classSubscriptions.delete(subscription.hash);\n        }\n        // If there is no subscriptions under this class, remove it from subscriptions\n        if (classSubscriptions.size === 0) {\n          this.subscriptions.delete(subscription.className);\n        }\n      }\n\n      logger.verbose('Current clients %d', this.clients.size);\n      logger.verbose('Current subscriptions %d', this.subscriptions.size);\n      runLiveQueryEventHandlers({\n        event: 'ws_disconnect',\n        clients: this.clients.size,\n        subscriptions: this.subscriptions.size,\n        useMasterKey: client.hasMasterKey,\n        installationId: client.installationId,\n        sessionToken: client.sessionToken,\n      });\n    });\n\n    runLiveQueryEventHandlers({\n      event: 'ws_connect',\n      clients: this.clients.size,\n      subscriptions: this.subscriptions.size,\n    });\n  }\n\n  _matchesSubscription(parseObject: any, subscription: any): boolean {\n    // Object is undefined or null, not match\n    if (!parseObject) {\n      return false;\n    }\n    return matchesQuery(deepcopy(parseObject), subscription.query);\n  }\n\n  async _clearCachedRoles(userId: string) {\n    try {\n      const validTokens = await new Parse.Query(Parse.Session)\n        .equalTo('user', Parse.User.createWithoutData(userId))\n        .find({ useMasterKey: true });\n      await Promise.all(\n        validTokens.map(async token => {\n          const sessionToken = token.get('sessionToken');\n          const authPromise = this.authCache.get(sessionToken);\n          if (!authPromise) {\n            return;\n          }\n          const [auth1, auth2] = await Promise.all([\n            authPromise,\n            getAuthForSessionToken({ cacheController: this.cacheController, sessionToken }),\n          ]);\n          auth1.auth?.clearRoleCache(sessionToken);\n          auth2.auth?.clearRoleCache(sessionToken);\n          this.authCache.delete(sessionToken);\n        })\n      );\n    } catch (e) {\n      logger.verbose(`Could not clear role cache. ${e}`);\n    }\n  }\n\n  getAuthForSessionToken(sessionToken: ?string): Promise<{ auth: ?Auth, userId: ?string }> {\n    if (!sessionToken) {\n      return Promise.resolve({});\n    }\n    const fromCache = this.authCache.get(sessionToken);\n    if (fromCache) {\n      return fromCache;\n    }\n    const authPromise = getAuthForSessionToken({\n      cacheController: this.cacheController,\n      sessionToken: sessionToken,\n    })\n      .then(auth => {\n        return { auth, userId: auth && auth.user && auth.user.id };\n      })\n      .catch(error => {\n        // There was an error with the session token\n        const result = {};\n        if (error && error.code === Parse.Error.INVALID_SESSION_TOKEN) {\n          result.error = error;\n          this.authCache.set(sessionToken, Promise.resolve(result), this.config.cacheTimeout);\n        } else {\n          this.authCache.delete(sessionToken);\n        }\n        return result;\n      });\n    this.authCache.set(sessionToken, authPromise);\n    return authPromise;\n  }\n\n  async _matchesCLP(\n    classLevelPermissions: ?any,\n    object: any,\n    client: any,\n    requestId: number,\n    op: string\n  ): any {\n    // try to match on user first, less expensive than with roles\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    const aclGroup = ['*'];\n    let userId;\n    if (typeof subscriptionInfo !== 'undefined') {\n      const { userId } = await this.getAuthForSessionToken(subscriptionInfo.sessionToken);\n      if (userId) {\n        aclGroup.push(userId);\n      }\n    }\n    try {\n      await SchemaController.validatePermission(\n        classLevelPermissions,\n        object.className,\n        aclGroup,\n        op\n      );\n      return true;\n    } catch (e) {\n      logger.verbose(`Failed matching CLP for ${object.id} ${userId} ${e}`);\n      return false;\n    }\n    // TODO: handle roles permissions\n    // Object.keys(classLevelPermissions).forEach((key) => {\n    //   const perm = classLevelPermissions[key];\n    //   Object.keys(perm).forEach((key) => {\n    //     if (key.indexOf('role'))\n    //   });\n    // })\n    // // it's rejected here, check the roles\n    // var rolesQuery = new Parse.Query(Parse.Role);\n    // rolesQuery.equalTo(\"users\", user);\n    // return rolesQuery.find({useMasterKey:true});\n  }\n\n  async _filterSensitiveData(\n    classLevelPermissions: ?any,\n    res: any,\n    client: any,\n    requestId: number,\n    op: string,\n    query: any\n  ) {\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    const aclGroup = ['*'];\n    let clientAuth;\n    if (typeof subscriptionInfo !== 'undefined') {\n      const { userId, auth } = await this.getAuthForSessionToken(subscriptionInfo.sessionToken);\n      if (userId) {\n        aclGroup.push(userId);\n      }\n      clientAuth = auth;\n    }\n    const filter = obj => {\n      if (!obj) {\n        return;\n      }\n      let protectedFields = classLevelPermissions?.protectedFields || [];\n      if (!client.hasMasterKey && !Array.isArray(protectedFields)) {\n        protectedFields = getDatabaseController(this.config).addProtectedFields(\n          classLevelPermissions,\n          res.object.className,\n          query,\n          aclGroup,\n          clientAuth\n        );\n      }\n      return DatabaseController.filterSensitiveData(\n        client.hasMasterKey,\n        false,\n        aclGroup,\n        clientAuth,\n        op,\n        classLevelPermissions,\n        res.object.className,\n        protectedFields,\n        obj,\n        query\n      );\n    };\n    res.object = filter(res.object);\n    res.original = filter(res.original);\n  }\n\n  _getCLPOperation(query: any) {\n    return typeof query === 'object' &&\n      Object.keys(query).length == 1 &&\n      typeof query.objectId === 'string'\n      ? 'get'\n      : 'find';\n  }\n\n  async _verifyACL(acl: any, token: string) {\n    if (!token) {\n      return false;\n    }\n\n    const { auth, userId } = await this.getAuthForSessionToken(token);\n\n    // Getting the session token failed\n    // This means that no additional auth is available\n    // At this point, just bail out as no additional visibility can be inferred.\n    if (!auth || !userId) {\n      return false;\n    }\n    const isSubscriptionSessionTokenMatched = acl.getReadAccess(userId);\n    if (isSubscriptionSessionTokenMatched) {\n      return true;\n    }\n\n    // Check if the user has any roles that match the ACL\n    return Promise.resolve()\n      .then(async () => {\n        // Resolve false right away if the acl doesn't have any roles\n        const acl_has_roles = Object.keys(acl.permissionsById).some(key => key.startsWith('role:'));\n        if (!acl_has_roles) {\n          return false;\n        }\n        const roleNames = await auth.getUserRoles();\n        // Finally, see if any of the user's roles allow them read access\n        for (const role of roleNames) {\n          // We use getReadAccess as `role` is in the form `role:roleName`\n          if (acl.getReadAccess(role)) {\n            return true;\n          }\n        }\n        return false;\n      })\n      .catch(() => {\n        return false;\n      });\n  }\n\n  async getAuthFromClient(client: any, requestId: number, sessionToken: string) {\n    const getSessionFromClient = () => {\n      const subscriptionInfo = client.getSubscriptionInfo(requestId);\n      if (typeof subscriptionInfo === 'undefined') {\n        return client.sessionToken;\n      }\n      return subscriptionInfo.sessionToken || client.sessionToken;\n    };\n    if (!sessionToken) {\n      sessionToken = getSessionFromClient();\n    }\n    if (!sessionToken) {\n      return;\n    }\n    const { auth } = await this.getAuthForSessionToken(sessionToken);\n    return auth;\n  }\n\n  _checkWatchFields(client: any, requestId: any, message: any) {\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    const watch = subscriptionInfo?.watch;\n    if (!watch) {\n      return true;\n    }\n    const object = message.currentParseObject;\n    const original = message.originalParseObject;\n    return watch.some(field => !isDeepStrictEqual(object.get(field), original?.get(field)));\n  }\n\n  async _matchesACL(acl: any, client: any, requestId: number): Promise<boolean> {\n    // Return true directly if ACL isn't present, ACL is public read, or client has master key\n    if (!acl || acl.getPublicReadAccess() || client.hasMasterKey) {\n      return true;\n    }\n    // Check subscription sessionToken matches ACL first\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    if (typeof subscriptionInfo === 'undefined') {\n      return false;\n    }\n\n    const subscriptionToken = subscriptionInfo.sessionToken;\n    const clientSessionToken = client.sessionToken;\n\n    if (await this._verifyACL(acl, subscriptionToken)) {\n      return true;\n    }\n\n    if (await this._verifyACL(acl, clientSessionToken)) {\n      return true;\n    }\n\n    return false;\n  }\n\n  async _handleConnect(parseWebsocket: any, request: any): any {\n    if (!this._validateKeys(request, this.keyPairs)) {\n      Client.pushError(parseWebsocket, 4, 'Key in request is not valid');\n      logger.error('Key in request is not valid');\n      return;\n    }\n    const hasMasterKey = this._hasMasterKey(request, this.keyPairs);\n    const clientId = uuidv4();\n    const client = new Client(\n      clientId,\n      parseWebsocket,\n      hasMasterKey,\n      request.sessionToken,\n      request.installationId\n    );\n    try {\n      const req = {\n        client,\n        event: 'connect',\n        clients: this.clients.size,\n        subscriptions: this.subscriptions.size,\n        sessionToken: request.sessionToken,\n        useMasterKey: client.hasMasterKey,\n        installationId: request.installationId,\n      };\n      const trigger = getTrigger('@Connect', 'beforeConnect', Parse.applicationId);\n      if (trigger) {\n        const auth = await this.getAuthFromClient(client, request.requestId, req.sessionToken);\n        if (auth && auth.user) {\n          req.user = auth.user;\n        }\n        await runTrigger(trigger, `beforeConnect.@Connect`, req, auth);\n      }\n      parseWebsocket.clientId = clientId;\n      this.clients.set(parseWebsocket.clientId, client);\n      logger.info(`Create new client: ${parseWebsocket.clientId}`);\n      client.pushConnect();\n      runLiveQueryEventHandlers(req);\n    } catch (e) {\n      const error = resolveError(e);\n      Client.pushError(parseWebsocket, error.code, error.message, false);\n      logger.error(\n        `Failed running beforeConnect for session ${request.sessionToken} with:\\n Error: ` +\n          JSON.stringify(error)\n      );\n    }\n  }\n\n  _hasMasterKey(request: any, validKeyPairs: any): boolean {\n    if (!validKeyPairs || validKeyPairs.size == 0 || !validKeyPairs.has('masterKey')) {\n      return false;\n    }\n    if (!request || !Object.prototype.hasOwnProperty.call(request, 'masterKey')) {\n      return false;\n    }\n    return request.masterKey === validKeyPairs.get('masterKey');\n  }\n\n  _validateKeys(request: any, validKeyPairs: any): boolean {\n    if (!validKeyPairs || validKeyPairs.size == 0) {\n      return true;\n    }\n    let isValid = false;\n    for (const [key, secret] of validKeyPairs) {\n      if (!request[key] || request[key] !== secret) {\n        continue;\n      }\n      isValid = true;\n      break;\n    }\n    return isValid;\n  }\n\n  async _handleSubscribe(parseWebsocket: any, request: any): any {\n    // If we can not find this client, return error to client\n    if (!Object.prototype.hasOwnProperty.call(parseWebsocket, 'clientId')) {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Can not find this client, make sure you connect to server before subscribing'\n      );\n      logger.error('Can not find this client, make sure you connect to server before subscribing');\n      return;\n    }\n    const client = this.clients.get(parseWebsocket.clientId);\n    const className = request.query.className;\n    let authCalled = false;\n    try {\n      const trigger = getTrigger(className, 'beforeSubscribe', Parse.applicationId);\n      if (trigger) {\n        const auth = await this.getAuthFromClient(client, request.requestId, request.sessionToken);\n        authCalled = true;\n        if (auth && auth.user) {\n          request.user = auth.user;\n        }\n\n        const parseQuery = new Parse.Query(className);\n        parseQuery.withJSON(request.query);\n        request.query = parseQuery;\n        await runTrigger(trigger, `beforeSubscribe.${className}`, request, auth);\n\n        const query = request.query.toJSON();\n        request.query = query;\n      }\n\n      if (className === '_Session') {\n        if (!authCalled) {\n          const auth = await this.getAuthFromClient(\n            client,\n            request.requestId,\n            request.sessionToken\n          );\n          if (auth && auth.user) {\n            request.user = auth.user;\n          }\n        }\n        if (request.user) {\n          request.query.where.user = request.user.toPointer();\n        } else if (!request.master) {\n          Client.pushError(\n            parseWebsocket,\n            Parse.Error.INVALID_SESSION_TOKEN,\n            'Invalid session token',\n            false,\n            request.requestId\n          );\n          return;\n        }\n      }\n      // Get subscription from subscriptions, create one if necessary\n      const subscriptionHash = queryHash(request.query);\n      // Add className to subscriptions if necessary\n\n      if (!this.subscriptions.has(className)) {\n        this.subscriptions.set(className, new Map());\n      }\n      const classSubscriptions = this.subscriptions.get(className);\n      let subscription;\n      if (classSubscriptions.has(subscriptionHash)) {\n        subscription = classSubscriptions.get(subscriptionHash);\n      } else {\n        subscription = new Subscription(className, request.query.where, subscriptionHash);\n        classSubscriptions.set(subscriptionHash, subscription);\n      }\n\n      // Add subscriptionInfo to client\n      const subscriptionInfo = {\n        subscription: subscription,\n      };\n      // Add selected fields, sessionToken and installationId for this subscription if necessary\n      if (request.query.keys) {\n        subscriptionInfo.keys = Array.isArray(request.query.keys)\n          ? request.query.keys\n          : request.query.keys.split(',');\n      }\n      if (request.query.watch) {\n        subscriptionInfo.watch = request.query.watch;\n      }\n      if (request.sessionToken) {\n        subscriptionInfo.sessionToken = request.sessionToken;\n      }\n      client.addSubscriptionInfo(request.requestId, subscriptionInfo);\n\n      // Add clientId to subscription\n      subscription.addClientSubscription(parseWebsocket.clientId, request.requestId);\n\n      client.pushSubscribe(request.requestId);\n\n      logger.verbose(\n        `Create client ${parseWebsocket.clientId} new subscription: ${request.requestId}`\n      );\n      logger.verbose('Current client number: %d', this.clients.size);\n      runLiveQueryEventHandlers({\n        client,\n        event: 'subscribe',\n        clients: this.clients.size,\n        subscriptions: this.subscriptions.size,\n        sessionToken: request.sessionToken,\n        useMasterKey: client.hasMasterKey,\n        installationId: client.installationId,\n      });\n    } catch (e) {\n      const error = resolveError(e);\n      Client.pushError(parseWebsocket, error.code, error.message, false, request.requestId);\n      logger.error(\n        `Failed running beforeSubscribe on ${className} for session ${request.sessionToken} with:\\n Error: ` +\n          JSON.stringify(error)\n      );\n    }\n  }\n\n  _handleUpdateSubscription(parseWebsocket: any, request: any): any {\n    this._handleUnsubscribe(parseWebsocket, request, false);\n    this._handleSubscribe(parseWebsocket, request);\n  }\n\n  _handleUnsubscribe(parseWebsocket: any, request: any, notifyClient: boolean = true): any {\n    // If we can not find this client, return error to client\n    if (!Object.prototype.hasOwnProperty.call(parseWebsocket, 'clientId')) {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Can not find this client, make sure you connect to server before unsubscribing'\n      );\n      logger.error(\n        'Can not find this client, make sure you connect to server before unsubscribing'\n      );\n      return;\n    }\n    const requestId = request.requestId;\n    const client = this.clients.get(parseWebsocket.clientId);\n    if (typeof client === 'undefined') {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Cannot find client with clientId ' +\n          parseWebsocket.clientId +\n          '. Make sure you connect to live query server before unsubscribing.'\n      );\n      logger.error('Can not find this client ' + parseWebsocket.clientId);\n      return;\n    }\n\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    if (typeof subscriptionInfo === 'undefined') {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Cannot find subscription with clientId ' +\n          parseWebsocket.clientId +\n          ' subscriptionId ' +\n          requestId +\n          '. Make sure you subscribe to live query server before unsubscribing.'\n      );\n      logger.error(\n        'Can not find subscription with clientId ' +\n          parseWebsocket.clientId +\n          ' subscriptionId ' +\n          requestId\n      );\n      return;\n    }\n\n    // Remove subscription from client\n    client.deleteSubscriptionInfo(requestId);\n    // Remove client from subscription\n    const subscription = subscriptionInfo.subscription;\n    const className = subscription.className;\n    subscription.deleteClientSubscription(parseWebsocket.clientId, requestId);\n    // If there is no client which is subscribing this subscription, remove it from subscriptions\n    const classSubscriptions = this.subscriptions.get(className);\n    if (!subscription.hasSubscribingClient()) {\n      classSubscriptions.delete(subscription.hash);\n    }\n    // If there is no subscriptions under this class, remove it from subscriptions\n    if (classSubscriptions.size === 0) {\n      this.subscriptions.delete(className);\n    }\n    runLiveQueryEventHandlers({\n      client,\n      event: 'unsubscribe',\n      clients: this.clients.size,\n      subscriptions: this.subscriptions.size,\n      sessionToken: subscriptionInfo.sessionToken,\n      useMasterKey: client.hasMasterKey,\n      installationId: client.installationId,\n    });\n\n    if (!notifyClient) {\n      return;\n    }\n\n    client.pushUnsubscribe(request.requestId);\n\n    logger.verbose(\n      `Delete client: ${parseWebsocket.clientId} | subscription: ${request.requestId}`\n    );\n  }\n}\n\nexport { ParseLiveQueryServer };\n"],"mappings":"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","ignoreList":[]}
853
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_tv","_interopRequireDefault","require","_node","_Subscription","_Client","_ParseWebSocketServer","_logger","_RequestSchema","_QueryTools","_ParsePubSub","_SchemaController","_lodash","_uuid","_triggers","_Auth","_Controllers","_lruCache","_UsersRouter","_DatabaseController","_util","_deepcopy","e","__esModule","default","ParseLiveQueryServer","constructor","server","config","parseServerConfig","clients","Map","subscriptions","appId","Parse","applicationId","masterKey","keyPairs","key","Object","keys","set","logger","verbose","disableSingleInstance","serverURL","initialize","javaScriptKey","cacheController","getCacheController","cacheTimeout","authCache","LRU","max","ttl","parseWebSocketServer","ParseWebSocketServer","parseWebsocket","_onConnect","subscriber","ParsePubSub","createSubscriber","connect","isOpen","Promise","resolve","_createSubscribers","shutdown","all","values","map","client","parseWebSocket","ws","close","Array","from","unsubscribe","quit","err","error","messageRecieved","channel","messageStr","message","JSON","parse","_clearCachedRoles","userId","_inflateParseObject","_onAfterSave","_onAfterDelete","on","field","subscribe","currentParseObject","UserRouter","removeHiddenProperties","className","parseObject","_finishFetch","originalParseObject","deletedParseObject","toJSON","classLevelPermissions","id","size","classSubscriptions","get","debug","subscription","isSubscriptionMatched","_matchesSubscription","clientId","requestIds","_","entries","clientRequestIds","forEach","requestId","acl","getACL","op","_getCLPOperation","query","res","_matchesCLP","isMatched","_matchesACL","event","sessionToken","object","useMasterKey","hasMasterKey","installationId","sendEvent","trigger","getTrigger","auth","getAuthFromClient","user","fromJSON","runTrigger","toJSONwithObjects","_filterSensitiveData","pushDelete","resolveError","Client","pushError","code","stringify","isOriginalSubscriptionMatched","isCurrentSubscriptionMatched","originalACLCheckingPromise","originalACL","currentACLCheckingPromise","currentACL","isOriginalMatched","isCurrentMatched","hash","type","watchFieldsChanged","_checkWatchFields","original","functionName","charAt","toUpperCase","slice","request","tv4","validate","RequestSchema","_handleConnect","_handleSubscribe","_handleUpdateSubscription","_handleUnsubscribe","info","has","runLiveQueryEventHandlers","delete","subscriptionInfo","subscriptionInfos","deleteClientSubscription","hasSubscribingClient","matchesQuery","deepcopy","validTokens","Query","Session","equalTo","User","createWithoutData","find","token","authPromise","auth1","auth2","getAuthForSessionToken","clearRoleCache","fromCache","then","catch","result","Error","INVALID_SESSION_TOKEN","getSubscriptionInfo","aclGroup","push","SchemaController","validatePermission","clientAuth","filter","obj","protectedFields","isArray","getDatabaseController","addProtectedFields","DatabaseController","filterSensitiveData","length","objectId","_verifyACL","isSubscriptionSessionTokenMatched","getReadAccess","acl_has_roles","permissionsById","some","startsWith","roleNames","getUserRoles","role","getSessionFromClient","watch","isDeepStrictEqual","getPublicReadAccess","subscriptionToken","clientSessionToken","_validateKeys","_hasMasterKey","uuidv4","req","pushConnect","validKeyPairs","prototype","hasOwnProperty","call","isValid","secret","authCalled","parseQuery","withJSON","where","toPointer","master","subscriptionHash","queryHash","Subscription","split","addSubscriptionInfo","addClientSubscription","pushSubscribe","notifyClient","deleteSubscriptionInfo","pushUnsubscribe","exports"],"sources":["../../src/LiveQuery/ParseLiveQueryServer.js"],"sourcesContent":["import tv4 from 'tv4';\nimport Parse from 'parse/node';\nimport { Subscription } from './Subscription';\nimport { Client } from './Client';\nimport { ParseWebSocketServer } from './ParseWebSocketServer';\nimport logger from '../logger';\nimport RequestSchema from './RequestSchema';\nimport { matchesQuery, queryHash } from './QueryTools';\nimport { ParsePubSub } from './ParsePubSub';\nimport SchemaController from '../Controllers/SchemaController';\nimport _ from 'lodash';\nimport { v4 as uuidv4 } from 'uuid';\nimport {\n  runLiveQueryEventHandlers,\n  getTrigger,\n  runTrigger,\n  resolveError,\n  toJSONwithObjects,\n} from '../triggers';\nimport { getAuthForSessionToken, Auth } from '../Auth';\nimport { getCacheController, getDatabaseController } from '../Controllers';\nimport { LRUCache as LRU } from 'lru-cache';\nimport UserRouter from '../Routers/UsersRouter';\nimport DatabaseController from '../Controllers/DatabaseController';\nimport { isDeepStrictEqual } from 'util';\nimport deepcopy from 'deepcopy';\n\nclass ParseLiveQueryServer {\n  clients: Map;\n  // className -> (queryHash -> subscription)\n  subscriptions: Object;\n  parseWebSocketServer: Object;\n  keyPairs: any;\n  // The subscriber we use to get object update from publisher\n  subscriber: Object;\n\n  constructor(server: any, config: any = {}, parseServerConfig: any = {}) {\n    this.server = server;\n    this.clients = new Map();\n    this.subscriptions = new Map();\n    this.config = config;\n\n    config.appId = config.appId || Parse.applicationId;\n    config.masterKey = config.masterKey || Parse.masterKey;\n\n    // Store keys, convert obj to map\n    const keyPairs = config.keyPairs || {};\n    this.keyPairs = new Map();\n    for (const key of Object.keys(keyPairs)) {\n      this.keyPairs.set(key, keyPairs[key]);\n    }\n    logger.verbose('Support key pairs', this.keyPairs);\n\n    // Initialize Parse\n    Parse.Object.disableSingleInstance();\n    const serverURL = config.serverURL || Parse.serverURL;\n    Parse.serverURL = serverURL;\n    Parse.initialize(config.appId, Parse.javaScriptKey, config.masterKey);\n\n    // The cache controller is a proper cache controller\n    // with access to User and Roles\n    this.cacheController = getCacheController(parseServerConfig);\n\n    config.cacheTimeout = config.cacheTimeout || 5 * 1000; // 5s\n\n    // This auth cache stores the promises for each auth resolution.\n    // The main benefit is to be able to reuse the same user / session token resolution.\n    this.authCache = new LRU({\n      max: 500, // 500 concurrent\n      ttl: config.cacheTimeout,\n    });\n    // Initialize websocket server\n    this.parseWebSocketServer = new ParseWebSocketServer(\n      server,\n      parseWebsocket => this._onConnect(parseWebsocket),\n      config\n    );\n    this.subscriber = ParsePubSub.createSubscriber(config);\n    if (!this.subscriber.connect) {\n      this.connect();\n    }\n  }\n\n  async connect() {\n    if (this.subscriber.isOpen) {\n      return;\n    }\n    if (typeof this.subscriber.connect === 'function') {\n      await Promise.resolve(this.subscriber.connect());\n    } else {\n      this.subscriber.isOpen = true;\n    }\n    this._createSubscribers();\n  }\n\n  async shutdown() {\n    if (this.subscriber.isOpen) {\n      await Promise.all([\n        ...[...this.clients.values()].map(client => client.parseWebSocket.ws.close()),\n        this.parseWebSocketServer.close?.(),\n        ...Array.from(this.subscriber.subscriptions?.keys() || []).map(key =>\n          this.subscriber.unsubscribe(key)\n        ),\n        this.subscriber.close?.(),\n      ]);\n    }\n    if (typeof this.subscriber.quit === 'function') {\n      try {\n        await this.subscriber.quit();\n      } catch (err) {\n        logger.error('PubSubAdapter error on shutdown', { error: err });\n      }\n    } else {\n      this.subscriber.isOpen = false;\n    }\n  }\n\n  _createSubscribers() {\n    const messageRecieved = (channel, messageStr) => {\n      logger.verbose('Subscribe message %j', messageStr);\n      let message;\n      try {\n        message = JSON.parse(messageStr);\n      } catch (e) {\n        logger.error('unable to parse message', messageStr, e);\n        return;\n      }\n      if (channel === Parse.applicationId + 'clearCache') {\n        this._clearCachedRoles(message.userId);\n        return;\n      }\n      this._inflateParseObject(message);\n      if (channel === Parse.applicationId + 'afterSave') {\n        this._onAfterSave(message);\n      } else if (channel === Parse.applicationId + 'afterDelete') {\n        this._onAfterDelete(message);\n      } else {\n        logger.error('Get message %s from unknown channel %j', message, channel);\n      }\n    };\n    this.subscriber.on('message', (channel, messageStr) => messageRecieved(channel, messageStr));\n    for (const field of ['afterSave', 'afterDelete', 'clearCache']) {\n      const channel = `${Parse.applicationId}${field}`;\n      this.subscriber.subscribe(channel, messageStr => messageRecieved(channel, messageStr));\n    }\n  }\n\n  // Message is the JSON object from publisher. Message.currentParseObject is the ParseObject JSON after changes.\n  // Message.originalParseObject is the original ParseObject JSON.\n  _inflateParseObject(message: any): void {\n    // Inflate merged object\n    const currentParseObject = message.currentParseObject;\n    UserRouter.removeHiddenProperties(currentParseObject);\n    let className = currentParseObject.className;\n    let parseObject = new Parse.Object(className);\n    parseObject._finishFetch(currentParseObject);\n    message.currentParseObject = parseObject;\n    // Inflate original object\n    const originalParseObject = message.originalParseObject;\n    if (originalParseObject) {\n      UserRouter.removeHiddenProperties(originalParseObject);\n      className = originalParseObject.className;\n      parseObject = new Parse.Object(className);\n      parseObject._finishFetch(originalParseObject);\n      message.originalParseObject = parseObject;\n    }\n  }\n\n  // Message is the JSON object from publisher after inflated. Message.currentParseObject is the ParseObject after changes.\n  // Message.originalParseObject is the original ParseObject.\n  async _onAfterDelete(message: any): void {\n    logger.verbose(Parse.applicationId + 'afterDelete is triggered');\n\n    let deletedParseObject = message.currentParseObject.toJSON();\n    const classLevelPermissions = message.classLevelPermissions;\n    const className = deletedParseObject.className;\n    logger.verbose('ClassName: %j | ObjectId: %s', className, deletedParseObject.id);\n    logger.verbose('Current client number : %d', this.clients.size);\n\n    const classSubscriptions = this.subscriptions.get(className);\n    if (typeof classSubscriptions === 'undefined') {\n      logger.debug('Can not find subscriptions under this class ' + className);\n      return;\n    }\n\n    for (const subscription of classSubscriptions.values()) {\n      const isSubscriptionMatched = this._matchesSubscription(deletedParseObject, subscription);\n      if (!isSubscriptionMatched) {\n        continue;\n      }\n      for (const [clientId, requestIds] of _.entries(subscription.clientRequestIds)) {\n        const client = this.clients.get(clientId);\n        if (typeof client === 'undefined') {\n          continue;\n        }\n        requestIds.forEach(async requestId => {\n          const acl = message.currentParseObject.getACL();\n          // Check CLP\n          const op = this._getCLPOperation(subscription.query);\n          let res = {};\n          try {\n            await this._matchesCLP(\n              classLevelPermissions,\n              message.currentParseObject,\n              client,\n              requestId,\n              op\n            );\n            const isMatched = await this._matchesACL(acl, client, requestId);\n            if (!isMatched) {\n              return null;\n            }\n            res = {\n              event: 'delete',\n              sessionToken: client.sessionToken,\n              object: deletedParseObject,\n              clients: this.clients.size,\n              subscriptions: this.subscriptions.size,\n              useMasterKey: client.hasMasterKey,\n              installationId: client.installationId,\n              sendEvent: true,\n            };\n            const trigger = getTrigger(className, 'afterEvent', Parse.applicationId);\n            if (trigger) {\n              const auth = await this.getAuthFromClient(client, requestId);\n              if (auth && auth.user) {\n                res.user = auth.user;\n              }\n              if (res.object) {\n                res.object = Parse.Object.fromJSON(res.object);\n              }\n              await runTrigger(trigger, `afterEvent.${className}`, res, auth);\n            }\n            if (!res.sendEvent) {\n              return;\n            }\n            if (res.object && typeof res.object.toJSON === 'function') {\n              deletedParseObject = toJSONwithObjects(res.object, res.object.className || className);\n            }\n            await this._filterSensitiveData(\n              classLevelPermissions,\n              res,\n              client,\n              requestId,\n              op,\n              subscription.query\n            );\n            client.pushDelete(requestId, deletedParseObject);\n          } catch (e) {\n            const error = resolveError(e);\n            Client.pushError(client.parseWebSocket, error.code, error.message, false, requestId);\n            logger.error(\n              `Failed running afterLiveQueryEvent on class ${className} for event ${res.event} with session ${res.sessionToken} with:\\n Error: ` +\n                JSON.stringify(error)\n            );\n          }\n        });\n      }\n    }\n  }\n\n  // Message is the JSON object from publisher after inflated. Message.currentParseObject is the ParseObject after changes.\n  // Message.originalParseObject is the original ParseObject.\n  async _onAfterSave(message: any): void {\n    logger.verbose(Parse.applicationId + 'afterSave is triggered');\n\n    let originalParseObject = null;\n    if (message.originalParseObject) {\n      originalParseObject = message.originalParseObject.toJSON();\n    }\n    const classLevelPermissions = message.classLevelPermissions;\n    let currentParseObject = message.currentParseObject.toJSON();\n    const className = currentParseObject.className;\n    logger.verbose('ClassName: %s | ObjectId: %s', className, currentParseObject.id);\n    logger.verbose('Current client number : %d', this.clients.size);\n\n    const classSubscriptions = this.subscriptions.get(className);\n    if (typeof classSubscriptions === 'undefined') {\n      logger.debug('Can not find subscriptions under this class ' + className);\n      return;\n    }\n    for (const subscription of classSubscriptions.values()) {\n      const isOriginalSubscriptionMatched = this._matchesSubscription(\n        originalParseObject,\n        subscription\n      );\n      const isCurrentSubscriptionMatched = this._matchesSubscription(\n        currentParseObject,\n        subscription\n      );\n      for (const [clientId, requestIds] of _.entries(subscription.clientRequestIds)) {\n        const client = this.clients.get(clientId);\n        if (typeof client === 'undefined') {\n          continue;\n        }\n        requestIds.forEach(async requestId => {\n          // Set orignal ParseObject ACL checking promise, if the object does not match\n          // subscription, we do not need to check ACL\n          let originalACLCheckingPromise;\n          if (!isOriginalSubscriptionMatched) {\n            originalACLCheckingPromise = Promise.resolve(false);\n          } else {\n            let originalACL;\n            if (message.originalParseObject) {\n              originalACL = message.originalParseObject.getACL();\n            }\n            originalACLCheckingPromise = this._matchesACL(originalACL, client, requestId);\n          }\n          // Set current ParseObject ACL checking promise, if the object does not match\n          // subscription, we do not need to check ACL\n          let currentACLCheckingPromise;\n          let res = {};\n          if (!isCurrentSubscriptionMatched) {\n            currentACLCheckingPromise = Promise.resolve(false);\n          } else {\n            const currentACL = message.currentParseObject.getACL();\n            currentACLCheckingPromise = this._matchesACL(currentACL, client, requestId);\n          }\n          try {\n            const op = this._getCLPOperation(subscription.query);\n            await this._matchesCLP(\n              classLevelPermissions,\n              message.currentParseObject,\n              client,\n              requestId,\n              op\n            );\n            const [isOriginalMatched, isCurrentMatched] = await Promise.all([\n              originalACLCheckingPromise,\n              currentACLCheckingPromise,\n            ]);\n            logger.verbose(\n              'Original %j | Current %j | Match: %s, %s, %s, %s | Query: %s',\n              originalParseObject,\n              currentParseObject,\n              isOriginalSubscriptionMatched,\n              isCurrentSubscriptionMatched,\n              isOriginalMatched,\n              isCurrentMatched,\n              subscription.hash\n            );\n            // Decide event type\n            let type;\n            if (isOriginalMatched && isCurrentMatched) {\n              type = 'update';\n            } else if (isOriginalMatched && !isCurrentMatched) {\n              type = 'leave';\n            } else if (!isOriginalMatched && isCurrentMatched) {\n              if (originalParseObject) {\n                type = 'enter';\n              } else {\n                type = 'create';\n              }\n            } else {\n              return null;\n            }\n            const watchFieldsChanged = this._checkWatchFields(client, requestId, message);\n            if (!watchFieldsChanged && (type === 'update' || type === 'create')) {\n              return;\n            }\n            res = {\n              event: type,\n              sessionToken: client.sessionToken,\n              object: currentParseObject,\n              original: originalParseObject,\n              clients: this.clients.size,\n              subscriptions: this.subscriptions.size,\n              useMasterKey: client.hasMasterKey,\n              installationId: client.installationId,\n              sendEvent: true,\n            };\n            const trigger = getTrigger(className, 'afterEvent', Parse.applicationId);\n            if (trigger) {\n              if (res.object) {\n                res.object = Parse.Object.fromJSON(res.object);\n              }\n              if (res.original) {\n                res.original = Parse.Object.fromJSON(res.original);\n              }\n              const auth = await this.getAuthFromClient(client, requestId);\n              if (auth && auth.user) {\n                res.user = auth.user;\n              }\n              await runTrigger(trigger, `afterEvent.${className}`, res, auth);\n            }\n            if (!res.sendEvent) {\n              return;\n            }\n            if (res.object && typeof res.object.toJSON === 'function') {\n              currentParseObject = toJSONwithObjects(res.object, res.object.className || className);\n            }\n            if (res.original && typeof res.original.toJSON === 'function') {\n              originalParseObject = toJSONwithObjects(\n                res.original,\n                res.original.className || className\n              );\n            }\n            await this._filterSensitiveData(\n              classLevelPermissions,\n              res,\n              client,\n              requestId,\n              op,\n              subscription.query\n            );\n            const functionName = 'push' + res.event.charAt(0).toUpperCase() + res.event.slice(1);\n            if (client[functionName]) {\n              client[functionName](requestId, currentParseObject, originalParseObject);\n            }\n          } catch (e) {\n            const error = resolveError(e);\n            Client.pushError(client.parseWebSocket, error.code, error.message, false, requestId);\n            logger.error(\n              `Failed running afterLiveQueryEvent on class ${className} for event ${res.event} with session ${res.sessionToken} with:\\n Error: ` +\n                JSON.stringify(error)\n            );\n          }\n        });\n      }\n    }\n  }\n\n  _onConnect(parseWebsocket: any): void {\n    parseWebsocket.on('message', request => {\n      if (typeof request === 'string') {\n        try {\n          request = JSON.parse(request);\n        } catch (e) {\n          logger.error('unable to parse request', request, e);\n          return;\n        }\n      }\n      logger.verbose('Request: %j', request);\n\n      // Check whether this request is a valid request, return error directly if not\n      if (\n        !tv4.validate(request, RequestSchema['general']) ||\n        !tv4.validate(request, RequestSchema[request.op])\n      ) {\n        Client.pushError(parseWebsocket, 1, tv4.error.message);\n        logger.error('Connect message error %s', tv4.error.message);\n        return;\n      }\n\n      switch (request.op) {\n        case 'connect':\n          this._handleConnect(parseWebsocket, request);\n          break;\n        case 'subscribe':\n          this._handleSubscribe(parseWebsocket, request);\n          break;\n        case 'update':\n          this._handleUpdateSubscription(parseWebsocket, request);\n          break;\n        case 'unsubscribe':\n          this._handleUnsubscribe(parseWebsocket, request);\n          break;\n        default:\n          Client.pushError(parseWebsocket, 3, 'Get unknown operation');\n          logger.error('Get unknown operation', request.op);\n      }\n    });\n\n    parseWebsocket.on('disconnect', () => {\n      logger.info(`Client disconnect: ${parseWebsocket.clientId}`);\n      const clientId = parseWebsocket.clientId;\n      if (!this.clients.has(clientId)) {\n        runLiveQueryEventHandlers({\n          event: 'ws_disconnect_error',\n          clients: this.clients.size,\n          subscriptions: this.subscriptions.size,\n          error: `Unable to find client ${clientId}`,\n        });\n        logger.error(`Can not find client ${clientId} on disconnect`);\n        return;\n      }\n\n      // Delete client\n      const client = this.clients.get(clientId);\n      this.clients.delete(clientId);\n\n      // Delete client from subscriptions\n      for (const [requestId, subscriptionInfo] of _.entries(client.subscriptionInfos)) {\n        const subscription = subscriptionInfo.subscription;\n        subscription.deleteClientSubscription(clientId, requestId);\n\n        // If there is no client which is subscribing this subscription, remove it from subscriptions\n        const classSubscriptions = this.subscriptions.get(subscription.className);\n        if (!subscription.hasSubscribingClient()) {\n          classSubscriptions.delete(subscription.hash);\n        }\n        // If there is no subscriptions under this class, remove it from subscriptions\n        if (classSubscriptions.size === 0) {\n          this.subscriptions.delete(subscription.className);\n        }\n      }\n\n      logger.verbose('Current clients %d', this.clients.size);\n      logger.verbose('Current subscriptions %d', this.subscriptions.size);\n      runLiveQueryEventHandlers({\n        event: 'ws_disconnect',\n        clients: this.clients.size,\n        subscriptions: this.subscriptions.size,\n        useMasterKey: client.hasMasterKey,\n        installationId: client.installationId,\n        sessionToken: client.sessionToken,\n      });\n    });\n\n    runLiveQueryEventHandlers({\n      event: 'ws_connect',\n      clients: this.clients.size,\n      subscriptions: this.subscriptions.size,\n    });\n  }\n\n  _matchesSubscription(parseObject: any, subscription: any): boolean {\n    // Object is undefined or null, not match\n    if (!parseObject) {\n      return false;\n    }\n    return matchesQuery(deepcopy(parseObject), subscription.query);\n  }\n\n  async _clearCachedRoles(userId: string) {\n    try {\n      const validTokens = await new Parse.Query(Parse.Session)\n        .equalTo('user', Parse.User.createWithoutData(userId))\n        .find({ useMasterKey: true });\n      await Promise.all(\n        validTokens.map(async token => {\n          const sessionToken = token.get('sessionToken');\n          const authPromise = this.authCache.get(sessionToken);\n          if (!authPromise) {\n            return;\n          }\n          const [auth1, auth2] = await Promise.all([\n            authPromise,\n            getAuthForSessionToken({ cacheController: this.cacheController, sessionToken }),\n          ]);\n          auth1.auth?.clearRoleCache(sessionToken);\n          auth2.auth?.clearRoleCache(sessionToken);\n          this.authCache.delete(sessionToken);\n        })\n      );\n    } catch (e) {\n      logger.verbose(`Could not clear role cache. ${e}`);\n    }\n  }\n\n  getAuthForSessionToken(sessionToken: ?string): Promise<{ auth: ?Auth, userId: ?string }> {\n    if (!sessionToken) {\n      return Promise.resolve({});\n    }\n    const fromCache = this.authCache.get(sessionToken);\n    if (fromCache) {\n      return fromCache;\n    }\n    const authPromise = getAuthForSessionToken({\n      cacheController: this.cacheController,\n      sessionToken: sessionToken,\n    })\n      .then(auth => {\n        return { auth, userId: auth && auth.user && auth.user.id };\n      })\n      .catch(error => {\n        // There was an error with the session token\n        const result = {};\n        if (error && error.code === Parse.Error.INVALID_SESSION_TOKEN) {\n          result.error = error;\n          this.authCache.set(sessionToken, Promise.resolve(result), this.config.cacheTimeout);\n        } else {\n          this.authCache.delete(sessionToken);\n        }\n        return result;\n      });\n    this.authCache.set(sessionToken, authPromise);\n    return authPromise;\n  }\n\n  async _matchesCLP(\n    classLevelPermissions: ?any,\n    object: any,\n    client: any,\n    requestId: number,\n    op: string\n  ): any {\n    // try to match on user first, less expensive than with roles\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    const aclGroup = ['*'];\n    let userId;\n    if (typeof subscriptionInfo !== 'undefined') {\n      const { userId } = await this.getAuthForSessionToken(subscriptionInfo.sessionToken);\n      if (userId) {\n        aclGroup.push(userId);\n      }\n    }\n    try {\n      await SchemaController.validatePermission(\n        classLevelPermissions,\n        object.className,\n        aclGroup,\n        op\n      );\n      return true;\n    } catch (e) {\n      logger.verbose(`Failed matching CLP for ${object.id} ${userId} ${e}`);\n      return false;\n    }\n    // TODO: handle roles permissions\n    // Object.keys(classLevelPermissions).forEach((key) => {\n    //   const perm = classLevelPermissions[key];\n    //   Object.keys(perm).forEach((key) => {\n    //     if (key.indexOf('role'))\n    //   });\n    // })\n    // // it's rejected here, check the roles\n    // var rolesQuery = new Parse.Query(Parse.Role);\n    // rolesQuery.equalTo(\"users\", user);\n    // return rolesQuery.find({useMasterKey:true});\n  }\n\n  async _filterSensitiveData(\n    classLevelPermissions: ?any,\n    res: any,\n    client: any,\n    requestId: number,\n    op: string,\n    query: any\n  ) {\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    const aclGroup = ['*'];\n    let clientAuth;\n    if (typeof subscriptionInfo !== 'undefined') {\n      const { userId, auth } = await this.getAuthForSessionToken(subscriptionInfo.sessionToken);\n      if (userId) {\n        aclGroup.push(userId);\n      }\n      clientAuth = auth;\n    }\n    const filter = obj => {\n      if (!obj) {\n        return;\n      }\n      let protectedFields = classLevelPermissions?.protectedFields || [];\n      if (!client.hasMasterKey && !Array.isArray(protectedFields)) {\n        protectedFields = getDatabaseController(this.config).addProtectedFields(\n          classLevelPermissions,\n          res.object.className,\n          query,\n          aclGroup,\n          clientAuth\n        );\n      }\n      return DatabaseController.filterSensitiveData(\n        client.hasMasterKey,\n        false,\n        aclGroup,\n        clientAuth,\n        op,\n        classLevelPermissions,\n        res.object.className,\n        protectedFields,\n        obj,\n        query\n      );\n    };\n    res.object = filter(res.object);\n    res.original = filter(res.original);\n  }\n\n  _getCLPOperation(query: any) {\n    return typeof query === 'object' &&\n      Object.keys(query).length == 1 &&\n      typeof query.objectId === 'string'\n      ? 'get'\n      : 'find';\n  }\n\n  async _verifyACL(acl: any, token: string) {\n    if (!token) {\n      return false;\n    }\n\n    const { auth, userId } = await this.getAuthForSessionToken(token);\n\n    // Getting the session token failed\n    // This means that no additional auth is available\n    // At this point, just bail out as no additional visibility can be inferred.\n    if (!auth || !userId) {\n      return false;\n    }\n    const isSubscriptionSessionTokenMatched = acl.getReadAccess(userId);\n    if (isSubscriptionSessionTokenMatched) {\n      return true;\n    }\n\n    // Check if the user has any roles that match the ACL\n    return Promise.resolve()\n      .then(async () => {\n        // Resolve false right away if the acl doesn't have any roles\n        const acl_has_roles = Object.keys(acl.permissionsById).some(key => key.startsWith('role:'));\n        if (!acl_has_roles) {\n          return false;\n        }\n        const roleNames = await auth.getUserRoles();\n        // Finally, see if any of the user's roles allow them read access\n        for (const role of roleNames) {\n          // We use getReadAccess as `role` is in the form `role:roleName`\n          if (acl.getReadAccess(role)) {\n            return true;\n          }\n        }\n        return false;\n      })\n      .catch(() => {\n        return false;\n      });\n  }\n\n  async getAuthFromClient(client: any, requestId: number, sessionToken: string) {\n    const getSessionFromClient = () => {\n      const subscriptionInfo = client.getSubscriptionInfo(requestId);\n      if (typeof subscriptionInfo === 'undefined') {\n        return client.sessionToken;\n      }\n      return subscriptionInfo.sessionToken || client.sessionToken;\n    };\n    if (!sessionToken) {\n      sessionToken = getSessionFromClient();\n    }\n    if (!sessionToken) {\n      return;\n    }\n    const { auth } = await this.getAuthForSessionToken(sessionToken);\n    return auth;\n  }\n\n  _checkWatchFields(client: any, requestId: any, message: any) {\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    const watch = subscriptionInfo?.watch;\n    if (!watch) {\n      return true;\n    }\n    const object = message.currentParseObject;\n    const original = message.originalParseObject;\n    return watch.some(field => !isDeepStrictEqual(object.get(field), original?.get(field)));\n  }\n\n  async _matchesACL(acl: any, client: any, requestId: number): Promise<boolean> {\n    // Return true directly if ACL isn't present, ACL is public read, or client has master key\n    if (!acl || acl.getPublicReadAccess() || client.hasMasterKey) {\n      return true;\n    }\n    // Check subscription sessionToken matches ACL first\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    if (typeof subscriptionInfo === 'undefined') {\n      return false;\n    }\n\n    const subscriptionToken = subscriptionInfo.sessionToken;\n    const clientSessionToken = client.sessionToken;\n\n    if (await this._verifyACL(acl, subscriptionToken)) {\n      return true;\n    }\n\n    if (await this._verifyACL(acl, clientSessionToken)) {\n      return true;\n    }\n\n    return false;\n  }\n\n  async _handleConnect(parseWebsocket: any, request: any): any {\n    if (!this._validateKeys(request, this.keyPairs)) {\n      Client.pushError(parseWebsocket, 4, 'Key in request is not valid');\n      logger.error('Key in request is not valid');\n      return;\n    }\n    const hasMasterKey = this._hasMasterKey(request, this.keyPairs);\n    const clientId = uuidv4();\n    const client = new Client(\n      clientId,\n      parseWebsocket,\n      hasMasterKey,\n      request.sessionToken,\n      request.installationId\n    );\n    try {\n      const req = {\n        client,\n        event: 'connect',\n        clients: this.clients.size,\n        subscriptions: this.subscriptions.size,\n        sessionToken: request.sessionToken,\n        useMasterKey: client.hasMasterKey,\n        installationId: request.installationId,\n      };\n      const trigger = getTrigger('@Connect', 'beforeConnect', Parse.applicationId);\n      if (trigger) {\n        const auth = await this.getAuthFromClient(client, request.requestId, req.sessionToken);\n        if (auth && auth.user) {\n          req.user = auth.user;\n        }\n        await runTrigger(trigger, `beforeConnect.@Connect`, req, auth);\n      }\n      parseWebsocket.clientId = clientId;\n      this.clients.set(parseWebsocket.clientId, client);\n      logger.info(`Create new client: ${parseWebsocket.clientId}`);\n      client.pushConnect();\n      runLiveQueryEventHandlers(req);\n    } catch (e) {\n      const error = resolveError(e);\n      Client.pushError(parseWebsocket, error.code, error.message, false);\n      logger.error(\n        `Failed running beforeConnect for session ${request.sessionToken} with:\\n Error: ` +\n          JSON.stringify(error)\n      );\n    }\n  }\n\n  _hasMasterKey(request: any, validKeyPairs: any): boolean {\n    if (!validKeyPairs || validKeyPairs.size == 0 || !validKeyPairs.has('masterKey')) {\n      return false;\n    }\n    if (!request || !Object.prototype.hasOwnProperty.call(request, 'masterKey')) {\n      return false;\n    }\n    return request.masterKey === validKeyPairs.get('masterKey');\n  }\n\n  _validateKeys(request: any, validKeyPairs: any): boolean {\n    if (!validKeyPairs || validKeyPairs.size == 0) {\n      return true;\n    }\n    let isValid = false;\n    for (const [key, secret] of validKeyPairs) {\n      if (!request[key] || request[key] !== secret) {\n        continue;\n      }\n      isValid = true;\n      break;\n    }\n    return isValid;\n  }\n\n  async _handleSubscribe(parseWebsocket: any, request: any): any {\n    // If we can not find this client, return error to client\n    if (!Object.prototype.hasOwnProperty.call(parseWebsocket, 'clientId')) {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Can not find this client, make sure you connect to server before subscribing'\n      );\n      logger.error('Can not find this client, make sure you connect to server before subscribing');\n      return;\n    }\n    const client = this.clients.get(parseWebsocket.clientId);\n    const className = request.query.className;\n    let authCalled = false;\n    try {\n      const trigger = getTrigger(className, 'beforeSubscribe', Parse.applicationId);\n      if (trigger) {\n        const auth = await this.getAuthFromClient(client, request.requestId, request.sessionToken);\n        authCalled = true;\n        if (auth && auth.user) {\n          request.user = auth.user;\n        }\n\n        const parseQuery = new Parse.Query(className);\n        parseQuery.withJSON(request.query);\n        request.query = parseQuery;\n        await runTrigger(trigger, `beforeSubscribe.${className}`, request, auth);\n\n        const query = request.query.toJSON();\n        request.query = query;\n      }\n\n      if (className === '_Session') {\n        if (!authCalled) {\n          const auth = await this.getAuthFromClient(\n            client,\n            request.requestId,\n            request.sessionToken\n          );\n          if (auth && auth.user) {\n            request.user = auth.user;\n          }\n        }\n        if (request.user) {\n          request.query.where.user = request.user.toPointer();\n        } else if (!request.master) {\n          Client.pushError(\n            parseWebsocket,\n            Parse.Error.INVALID_SESSION_TOKEN,\n            'Invalid session token',\n            false,\n            request.requestId\n          );\n          return;\n        }\n      }\n      // Get subscription from subscriptions, create one if necessary\n      const subscriptionHash = queryHash(request.query);\n      // Add className to subscriptions if necessary\n\n      if (!this.subscriptions.has(className)) {\n        this.subscriptions.set(className, new Map());\n      }\n      const classSubscriptions = this.subscriptions.get(className);\n      let subscription;\n      if (classSubscriptions.has(subscriptionHash)) {\n        subscription = classSubscriptions.get(subscriptionHash);\n      } else {\n        subscription = new Subscription(className, request.query.where, subscriptionHash);\n        classSubscriptions.set(subscriptionHash, subscription);\n      }\n\n      // Add subscriptionInfo to client\n      const subscriptionInfo = {\n        subscription: subscription,\n      };\n      // Add selected fields, sessionToken and installationId for this subscription if necessary\n      if (request.query.keys) {\n        subscriptionInfo.keys = Array.isArray(request.query.keys)\n          ? request.query.keys\n          : request.query.keys.split(',');\n      }\n      if (request.query.watch) {\n        subscriptionInfo.watch = request.query.watch;\n      }\n      if (request.sessionToken) {\n        subscriptionInfo.sessionToken = request.sessionToken;\n      }\n      client.addSubscriptionInfo(request.requestId, subscriptionInfo);\n\n      // Add clientId to subscription\n      subscription.addClientSubscription(parseWebsocket.clientId, request.requestId);\n\n      client.pushSubscribe(request.requestId);\n\n      logger.verbose(\n        `Create client ${parseWebsocket.clientId} new subscription: ${request.requestId}`\n      );\n      logger.verbose('Current client number: %d', this.clients.size);\n      runLiveQueryEventHandlers({\n        client,\n        event: 'subscribe',\n        clients: this.clients.size,\n        subscriptions: this.subscriptions.size,\n        sessionToken: request.sessionToken,\n        useMasterKey: client.hasMasterKey,\n        installationId: client.installationId,\n      });\n    } catch (e) {\n      const error = resolveError(e);\n      Client.pushError(parseWebsocket, error.code, error.message, false, request.requestId);\n      logger.error(\n        `Failed running beforeSubscribe on ${className} for session ${request.sessionToken} with:\\n Error: ` +\n          JSON.stringify(error)\n      );\n    }\n  }\n\n  _handleUpdateSubscription(parseWebsocket: any, request: any): any {\n    this._handleUnsubscribe(parseWebsocket, request, false);\n    this._handleSubscribe(parseWebsocket, request);\n  }\n\n  _handleUnsubscribe(parseWebsocket: any, request: any, notifyClient: boolean = true): any {\n    // If we can not find this client, return error to client\n    if (!Object.prototype.hasOwnProperty.call(parseWebsocket, 'clientId')) {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Can not find this client, make sure you connect to server before unsubscribing'\n      );\n      logger.error(\n        'Can not find this client, make sure you connect to server before unsubscribing'\n      );\n      return;\n    }\n    const requestId = request.requestId;\n    const client = this.clients.get(parseWebsocket.clientId);\n    if (typeof client === 'undefined') {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Cannot find client with clientId ' +\n          parseWebsocket.clientId +\n          '. Make sure you connect to live query server before unsubscribing.'\n      );\n      logger.error('Can not find this client ' + parseWebsocket.clientId);\n      return;\n    }\n\n    const subscriptionInfo = client.getSubscriptionInfo(requestId);\n    if (typeof subscriptionInfo === 'undefined') {\n      Client.pushError(\n        parseWebsocket,\n        2,\n        'Cannot find subscription with clientId ' +\n          parseWebsocket.clientId +\n          ' subscriptionId ' +\n          requestId +\n          '. Make sure you subscribe to live query server before unsubscribing.'\n      );\n      logger.error(\n        'Can not find subscription with clientId ' +\n          parseWebsocket.clientId +\n          ' subscriptionId ' +\n          requestId\n      );\n      return;\n    }\n\n    // Remove subscription from client\n    client.deleteSubscriptionInfo(requestId);\n    // Remove client from subscription\n    const subscription = subscriptionInfo.subscription;\n    const className = subscription.className;\n    subscription.deleteClientSubscription(parseWebsocket.clientId, requestId);\n    // If there is no client which is subscribing this subscription, remove it from subscriptions\n    const classSubscriptions = this.subscriptions.get(className);\n    if (!subscription.hasSubscribingClient()) {\n      classSubscriptions.delete(subscription.hash);\n    }\n    // If there is no subscriptions under this class, remove it from subscriptions\n    if (classSubscriptions.size === 0) {\n      this.subscriptions.delete(className);\n    }\n    runLiveQueryEventHandlers({\n      client,\n      event: 'unsubscribe',\n      clients: this.clients.size,\n      subscriptions: this.subscriptions.size,\n      sessionToken: subscriptionInfo.sessionToken,\n      useMasterKey: client.hasMasterKey,\n      installationId: client.installationId,\n    });\n\n    if (!notifyClient) {\n      return;\n    }\n\n    client.pushUnsubscribe(request.requestId);\n\n    logger.verbose(\n      `Delete client: ${parseWebsocket.clientId} | subscription: ${request.requestId}`\n    );\n  }\n}\n\nexport { ParseLiveQueryServer };\n"],"mappings":"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","ignoreList":[]}
@@ -41,6 +41,7 @@ var _CheckRunner = _interopRequireDefault(require("./Security/CheckRunner"));
41
41
  var _Deprecator = _interopRequireDefault(require("./Deprecator/Deprecator"));
42
42
  var _DefinedSchemas = require("./SchemaMigrations/DefinedSchemas");
43
43
  var _Definitions = _interopRequireDefault(require("./Options/Definitions"));
44
+ var _TestUtils = require("./TestUtils");
44
45
  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); }
45
46
  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; }
46
47
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
@@ -58,6 +59,9 @@ var batch = require('./batch'),
58
59
  // Mutate the Parse object to add the Cloud Code handlers
59
60
  addParseCloud();
60
61
 
62
+ // Track connections to destroy them on shutdown
63
+ const connections = new _TestUtils.Connections();
64
+
61
65
  // ParseServer works like a constructor of an express app.
62
66
  // https://parseplatform.org/parse-server/api/master/ParseServerOptions.html
63
67
  class ParseServer {
@@ -217,8 +221,40 @@ class ParseServer {
217
221
  }
218
222
  return this._app;
219
223
  }
220
- handleShutdown() {
224
+
225
+ /**
226
+ * Stops the parse server, cancels any ongoing requests and closes all connections.
227
+ *
228
+ * Currently, express doesn't shut down immediately after receiving SIGINT/SIGTERM
229
+ * if it has client connections that haven't timed out.
230
+ * (This is a known issue with node - https://github.com/nodejs/node/issues/2642)
231
+ *
232
+ * @returns {Promise<void>} a promise that resolves when the server is stopped
233
+ */
234
+ async handleShutdown() {
235
+ const serverClosePromise = (0, _TestUtils.resolvingPromise)();
236
+ const liveQueryServerClosePromise = (0, _TestUtils.resolvingPromise)();
221
237
  const promises = [];
238
+ this.server.close(error => {
239
+ /* istanbul ignore next */
240
+ if (error) {
241
+ // eslint-disable-next-line no-console
242
+ console.error('Error while closing parse server', error);
243
+ }
244
+ serverClosePromise.resolve();
245
+ });
246
+ if (this.liveQueryServer?.server?.close && this.liveQueryServer.server !== this.server) {
247
+ this.liveQueryServer.server.close(error => {
248
+ /* istanbul ignore next */
249
+ if (error) {
250
+ // eslint-disable-next-line no-console
251
+ console.error('Error while closing live query server', error);
252
+ }
253
+ liveQueryServerClosePromise.resolve();
254
+ });
255
+ } else {
256
+ liveQueryServerClosePromise.resolve();
257
+ }
222
258
  const {
223
259
  adapter: databaseAdapter
224
260
  } = this.config.databaseController;
@@ -237,17 +273,15 @@ class ParseServer {
237
273
  if (cacheAdapter && typeof cacheAdapter.handleShutdown === 'function') {
238
274
  promises.push(cacheAdapter.handleShutdown());
239
275
  }
240
- if (this.liveQueryServer?.server?.close) {
241
- promises.push(new Promise(resolve => this.liveQueryServer.server.close(resolve)));
242
- }
243
276
  if (this.liveQueryServer) {
244
277
  promises.push(this.liveQueryServer.shutdown());
245
278
  }
246
- return (promises.length > 0 ? Promise.all(promises) : Promise.resolve()).then(() => {
247
- if (this.config.serverCloseComplete) {
248
- this.config.serverCloseComplete();
249
- }
250
- });
279
+ await Promise.all(promises);
280
+ connections.destroyAll();
281
+ await Promise.all([serverClosePromise, liveQueryServerClosePromise]);
282
+ if (this.config.serverCloseComplete) {
283
+ this.config.serverCloseComplete();
284
+ }
251
285
  }
252
286
 
253
287
  /**
@@ -397,8 +431,12 @@ class ParseServer {
397
431
  });
398
432
  });
399
433
  this.server = server;
434
+ connections.track(server);
400
435
  if (options.startLiveQueryServer || options.liveQueryServerOptions) {
401
436
  this.liveQueryServer = await ParseServer.createLiveQueryServer(server, options.liveQueryServerOptions, options);
437
+ if (this.liveQueryServer.server !== this.server) {
438
+ connections.track(this.liveQueryServer.server);
439
+ }
402
440
  }
403
441
  if (options.trustProxy) {
404
442
  app.set('trust proxy', options.trustProxy);
@@ -553,34 +591,12 @@ function injectDefaults(options) {
553
591
  // Those can't be tested as it requires a subprocess
554
592
  /* istanbul ignore next */
555
593
  function configureListeners(parseServer) {
556
- const server = parseServer.server;
557
- const sockets = {};
558
- /* 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)
559
- 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. */
560
- server.on('connection', socket => {
561
- const socketId = socket.remoteAddress + ':' + socket.remotePort;
562
- sockets[socketId] = socket;
563
- socket.on('close', () => {
564
- delete sockets[socketId];
565
- });
566
- });
567
- const destroyAliveConnections = function () {
568
- for (const socketId in sockets) {
569
- try {
570
- sockets[socketId].destroy();
571
- } catch (e) {
572
- /* */
573
- }
574
- }
575
- };
576
594
  const handleShutdown = function () {
577
595
  process.stdout.write('Termination signal received. Shutting down.');
578
- destroyAliveConnections();
579
- server.close();
580
596
  parseServer.handleShutdown();
581
597
  };
582
598
  process.on('SIGTERM', handleShutdown);
583
599
  process.on('SIGINT', handleShutdown);
584
600
  }
585
601
  var _default = exports.default = ParseServer;
586
- //# 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","batch","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","push","res","Array","isArray","forEach","item","idx","concat","diff","length","logger","error","join","injectDefaults","appId","requiredParameter","masterKey","javascriptKey","serverURL","initialize","Config","validateOptions","allControllers","getControllers","state","config","put","assign","masterKeyIpsStore","Map","maintenanceKeyIpsStore","setLogger","loggerController","start","databaseController","hooksController","cacheController","cloud","security","schema","liveQueryController","performInitialization","code","Error","DUPLICATE_VALUE","pushController","getPushController","load","startupPromises","loadMasterKey","DefinedSchemas","execute","adapter","connect","Promise","all","resolve","json","process","env","npm_package_json","npm_package_type","cwd","setTimeout","enableCheck","enableCheckLog","CheckRunner","run","console","app","_app","handleShutdown","promises","databaseAdapter","fileAdapter","filesController","cacheAdapter","liveQueryServer","server","close","shutdown","then","serverCloseComplete","maxUploadSize","directAccess","pages","rateLimit","api","use","allowCrossDomain","allowDoubleForwardSlash","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","isValidHttpUrl","string","url","URL","_","protocol","replace","warn","request","response","catch","data","retry","headers","ParseCloud","conf","applicationId","newVal","configurable","Cloud","global","keys","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  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 = [this.config.loadMasterKey?.()];\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      // eslint-disable-next-line no-console\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    api.use(middlewares.allowDoubleForwardSlash);\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      express.urlencoded({ extended: false }),\n      pages.enableRouter\n        ? new PagesRouter(pages).expressRouter()\n        : new PublicAPIRouter().expressRouter()\n    );\n\n    api.use(express.json({ type: '*/*', limit: maxUploadSize }));\n    api.use(middlewares.allowMethodOverride);\n    api.use(middlewares.handleParseHeaders);\n    api.set('query parser', 'extended');\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      // eslint-disable-next-line no-console\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        // eslint-disable-next-line no-console\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      // eslint-disable-next-line no-console\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":[]}
602
+ //# 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","_TestUtils","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","batch","express","middlewares","Parse","parse","path","fs","addParseCloud","connections","Connections","ParseServer","constructor","options","Deprecator","scanParseServerOptions","interfaces","JSON","stringify","OptionsDefinitions","getValidObject","root","result","key","prototype","type","endsWith","slice","optionsBlueprint","validateKeyNames","original","ref","name","prefix","push","res","Array","isArray","forEach","item","idx","concat","diff","length","logger","error","join","injectDefaults","appId","requiredParameter","masterKey","javascriptKey","serverURL","initialize","Config","validateOptions","allControllers","getControllers","state","config","put","assign","masterKeyIpsStore","Map","maintenanceKeyIpsStore","setLogger","loggerController","start","databaseController","hooksController","cacheController","cloud","security","schema","liveQueryController","performInitialization","code","Error","DUPLICATE_VALUE","pushController","getPushController","load","startupPromises","loadMasterKey","DefinedSchemas","execute","adapter","connect","Promise","all","resolve","json","process","env","npm_package_json","npm_package_type","cwd","setTimeout","enableCheck","enableCheckLog","CheckRunner","run","console","app","_app","handleShutdown","serverClosePromise","resolvingPromise","liveQueryServerClosePromise","promises","server","close","liveQueryServer","databaseAdapter","fileAdapter","filesController","cacheAdapter","shutdown","destroyAll","serverCloseComplete","maxUploadSize","directAccess","pages","rateLimit","api","use","allowCrossDomain","allowDoubleForwardSlash","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","track","startLiveQueryServer","liveQueryServerOptions","createLiveQueryServer","trustProxy","configureListeners","expressApp","parseServer","httpServer","createServer","ParseLiveQueryServer","isValidHttpUrl","string","url","URL","_","protocol","replace","warn","request","response","catch","data","retry","headers","ParseCloud","conf","applicationId","newVal","configurable","Cloud","global","keys","defaults","regex","match","userSensitiveFields","from","Set","protectedFields","_User","c","cur","unq","stdout","_default","exports"],"sources":["../src/ParseServer.js"],"sourcesContent":["// ParseServer - open-source compatible API Server for Parse apps\n\nvar batch = require('./batch'),\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';\nimport { resolvingPromise, Connections } from './TestUtils';\n\n// Mutate the Parse object to add the Cloud Code handlers\naddParseCloud();\n\n// Track connections to destroy them on shutdown\nconst connections = new Connections();\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 = [this.config.loadMasterKey?.()];\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      // eslint-disable-next-line no-console\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  /**\n   * Stops the parse server, cancels any ongoing requests and closes all connections.\n   *\n   * Currently, express doesn't shut down immediately after receiving SIGINT/SIGTERM\n   * if it has client connections that haven't timed out.\n   * (This is a known issue with node - https://github.com/nodejs/node/issues/2642)\n   *\n   * @returns {Promise<void>} a promise that resolves when the server is stopped\n   */\n  async handleShutdown() {\n    const serverClosePromise = resolvingPromise();\n    const liveQueryServerClosePromise = resolvingPromise();\n    const promises = [];\n    this.server.close((error) => {\n      /* istanbul ignore next */\n      if (error) {\n        // eslint-disable-next-line no-console\n        console.error('Error while closing parse server', error);\n      }\n      serverClosePromise.resolve();\n    });\n    if (this.liveQueryServer?.server?.close && this.liveQueryServer.server !== this.server) {\n      this.liveQueryServer.server.close((error) => {\n        /* istanbul ignore next */\n        if (error) {\n          // eslint-disable-next-line no-console\n          console.error('Error while closing live query server', error);\n        }\n        liveQueryServerClosePromise.resolve();\n      });\n    } else {\n      liveQueryServerClosePromise.resolve();\n    }\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) {\n      promises.push(this.liveQueryServer.shutdown());\n    }\n    await Promise.all(promises);\n    connections.destroyAll();\n    await Promise.all([serverClosePromise, liveQueryServerClosePromise]);\n    if (this.config.serverCloseComplete) {\n      this.config.serverCloseComplete();\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    api.use(middlewares.allowDoubleForwardSlash);\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      express.urlencoded({ extended: false }),\n      pages.enableRouter\n        ? new PagesRouter(pages).expressRouter()\n        : new PublicAPIRouter().expressRouter()\n    );\n\n    api.use(express.json({ type: '*/*', limit: maxUploadSize }));\n    api.use(middlewares.allowMethodOverride);\n    api.use(middlewares.handleParseHeaders);\n    api.set('query parser', 'extended');\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      // eslint-disable-next-line no-console\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    connections.track(server);\n\n    if (options.startLiveQueryServer || options.liveQueryServerOptions) {\n      this.liveQueryServer = await ParseServer.createLiveQueryServer(\n        server,\n        options.liveQueryServerOptions,\n        options\n      );\n      if (this.liveQueryServer.server !== this.server) {\n        connections.track(this.liveQueryServer.server);\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        // eslint-disable-next-line no-console\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      // eslint-disable-next-line no-console\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 handleShutdown = function () {\n    process.stdout.write('Termination signal received. Shutting down.');\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":[]}
@@ -5,9 +5,10 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.ParseServerRESTController = ParseServerRESTController;
7
7
  exports.default = void 0;
8
+ var _RESTController = _interopRequireDefault(require("parse/lib/node/RESTController"));
9
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
8
10
  const Config = require('./Config');
9
11
  const Auth = require('./Auth');
10
- const RESTController = require('parse/lib/node/RESTController');
11
12
  const Parse = require('parse/node');
12
13
  function getSessionToken(options) {
13
14
  if (options && typeof options.sessionToken === 'string') {
@@ -147,7 +148,7 @@ function ParseServerRESTController(applicationId, router) {
147
148
  }
148
149
  }, err => {
149
150
  if (err instanceof Parse.Error && err.code == Parse.Error.INVALID_JSON && err.message == `cannot route ${method} ${path}`) {
150
- RESTController.request.apply(null, args).then(resolve, reject);
151
+ _RESTController.default.request.apply(null, args).then(resolve, reject);
151
152
  } else {
152
153
  reject(err);
153
154
  }
@@ -157,9 +158,9 @@ function ParseServerRESTController(applicationId, router) {
157
158
  }
158
159
  return {
159
160
  request: handleRequest,
160
- ajax: RESTController.ajax,
161
- handleError: RESTController.handleError
161
+ ajax: _RESTController.default.ajax,
162
+ handleError: _RESTController.default.handleError
162
163
  };
163
164
  }
164
165
  var _default = exports.default = ParseServerRESTController;
165
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Config","require","Auth","RESTController","Parse","getSessionToken","options","sessionToken","Promise","resolve","getAuth","config","installationId","useMasterKey","isMaster","then","getAuthForSessionToken","ParseServerRESTController","applicationId","router","handleRequest","method","path","data","args","arguments","get","serverURL","URL","indexOf","pathname","slice","length","batch","transactionRetries","initialPromise","transaction","database","createTransactionalSession","promises","requests","map","request","body","response","returnStatus","status","_status","headers","_headers","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","_default","exports","default"],"sources":["../src/ParseServerRESTController.js"],"sourcesContent":["const Config = require('./Config');\nconst Auth = require('./Auth');\nconst RESTController = require('parse/lib/node/RESTController');\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 = new URL(config.serverURL);\n    if (path.indexOf(serverURL.pathname) === 0) {\n      path = path.slice(serverURL.pathname.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                  const headers = response._headers;\n                  delete response._status;\n                  delete response._headers;\n                  return { success: response, _status: status, _headers: headers };\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, headers = {} } = resp;\n              if (options.returnStatus) {\n                resolve({ ...response, _status: status, _headers: headers });\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"],"mappings":"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","ignoreList":[]}
166
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_RESTController","_interopRequireDefault","require","e","__esModule","default","Config","Auth","Parse","getSessionToken","options","sessionToken","Promise","resolve","getAuth","config","installationId","useMasterKey","isMaster","then","getAuthForSessionToken","ParseServerRESTController","applicationId","router","handleRequest","method","path","data","args","arguments","get","serverURL","URL","indexOf","pathname","slice","length","batch","transactionRetries","initialPromise","transaction","database","createTransactionalSession","promises","requests","map","request","body","response","returnStatus","status","_status","headers","_headers","success","error","code","message","all","result","find","resultItem","abortTransactionalSession","reject","commitTransactionalSession","catch","errorItem","query","auth","info","context","tryRouteRequest","resp","err","Error","INVALID_JSON","RESTController","apply","ajax","handleError","_default","exports"],"sources":["../src/ParseServerRESTController.js"],"sourcesContent":["const Config = require('./Config');\nconst Auth = require('./Auth');\nimport RESTController from 'parse/lib/node/RESTController';\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 = new URL(config.serverURL);\n    if (path.indexOf(serverURL.pathname) === 0) {\n      path = path.slice(serverURL.pathname.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                  const headers = response._headers;\n                  delete response._status;\n                  delete response._headers;\n                  return { success: response, _status: status, _headers: headers };\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, headers = {} } = resp;\n              if (options.returnStatus) {\n                resolve({ ...response, _status: status, _headers: headers });\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"],"mappings":"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","ignoreList":[]}
package/lib/TestUtils.js CHANGED
@@ -3,7 +3,9 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ exports.Connections = void 0;
6
7
  exports.destroyAllDataPermanently = destroyAllDataPermanently;
8
+ exports.getConnectionsCount = getConnectionsCount;
7
9
  exports.resolvingPromise = resolvingPromise;
8
10
  exports.sleep = sleep;
9
11
  var _cache = _interopRequireDefault(require("./cache"));
@@ -46,4 +48,40 @@ function resolvingPromise() {
46
48
  function sleep(ms) {
47
49
  return new Promise(resolve => setTimeout(resolve, ms));
48
50
  }
49
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY2FjaGUiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9TY2hlbWFDYWNoZSIsImUiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsImRlc3Ryb3lBbGxEYXRhUGVybWFuZW50bHkiLCJmYXN0IiwicHJvY2VzcyIsImVudiIsIlRFU1RJTkciLCJQcm9taXNlIiwiYWxsIiwiT2JqZWN0Iiwia2V5cyIsIkFwcENhY2hlIiwiY2FjaGUiLCJtYXAiLCJhcHBJZCIsImFwcCIsImdldCIsImRlbGV0ZVByb21pc2VzIiwiY2FjaGVBZGFwdGVyIiwiY2xlYXIiLCJwdXNoIiwiZGF0YWJhc2VDb250cm9sbGVyIiwiZGVsZXRlRXZlcnl0aGluZyIsImRhdGFiYXNlQWRhcHRlciIsIlNjaGVtYUNhY2hlIiwiZGVsZXRlQWxsQ2xhc3NlcyIsInJlc29sdmluZ1Byb21pc2UiLCJyZXMiLCJyZWoiLCJwcm9taXNlIiwicmVzb2x2ZSIsInJlamVjdCIsInNsZWVwIiwibXMiLCJzZXRUaW1lb3V0Il0sInNvdXJjZXMiOlsiLi4vc3JjL1Rlc3RVdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQXBwQ2FjaGUgZnJvbSAnLi9jYWNoZSc7XG5pbXBvcnQgU2NoZW1hQ2FjaGUgZnJvbSAnLi9BZGFwdGVycy9DYWNoZS9TY2hlbWFDYWNoZSc7XG5cbi8qKlxuICogRGVzdHJveXMgYWxsIGRhdGEgaW4gdGhlIGRhdGFiYXNlXG4gKiBAcGFyYW0ge2Jvb2xlYW59IGZhc3Qgc2V0IHRvIHRydWUgaWYgaXQncyBvayB0byBqdXN0IGRyb3Agb2JqZWN0cyBhbmQgbm90IGluZGV4ZXMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZXN0cm95QWxsRGF0YVBlcm1hbmVudGx5KGZhc3QpIHtcbiAgaWYgKCFwcm9jZXNzLmVudi5URVNUSU5HKSB7XG4gICAgdGhyb3cgJ09ubHkgc3VwcG9ydGVkIGluIHRlc3QgZW52aXJvbm1lbnQnO1xuICB9XG4gIHJldHVybiBQcm9taXNlLmFsbChcbiAgICBPYmplY3Qua2V5cyhBcHBDYWNoZS5jYWNoZSkubWFwKGFwcElkID0+IHtcbiAgICAgIGNvbnN0IGFwcCA9IEFwcENhY2hlLmdldChhcHBJZCk7XG4gICAgICBjb25zdCBkZWxldGVQcm9taXNlcyA9IFtdO1xuICAgICAgaWYgKGFwcC5jYWNoZUFkYXB0ZXIgJiYgYXBwLmNhY2hlQWRhcHRlci5jbGVhcikge1xuICAgICAgICBkZWxldGVQcm9taXNlcy5wdXNoKGFwcC5jYWNoZUFkYXB0ZXIuY2xlYXIoKSk7XG4gICAgICB9XG4gICAgICBpZiAoYXBwLmRhdGFiYXNlQ29udHJvbGxlcikge1xuICAgICAgICBkZWxldGVQcm9taXNlcy5wdXNoKGFwcC5kYXRhYmFzZUNvbnRyb2xsZXIuZGVsZXRlRXZlcnl0aGluZyhmYXN0KSk7XG4gICAgICB9IGVsc2UgaWYgKGFwcC5kYXRhYmFzZUFkYXB0ZXIpIHtcbiAgICAgICAgU2NoZW1hQ2FjaGUuY2xlYXIoKTtcbiAgICAgICAgZGVsZXRlUHJvbWlzZXMucHVzaChhcHAuZGF0YWJhc2VBZGFwdGVyLmRlbGV0ZUFsbENsYXNzZXMoZmFzdCkpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIFByb21pc2UuYWxsKGRlbGV0ZVByb21pc2VzKTtcbiAgICB9KVxuICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2aW5nUHJvbWlzZSgpIHtcbiAgbGV0IHJlcztcbiAgbGV0IHJlajtcbiAgY29uc3QgcHJvbWlzZSA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICByZXMgPSByZXNvbHZlO1xuICAgIHJlaiA9IHJlamVjdDtcbiAgfSk7XG4gIHByb21pc2UucmVzb2x2ZSA9IHJlcztcbiAgcHJvbWlzZS5yZWplY3QgPSByZWo7XG4gIHJldHVybiBwcm9taXNlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2xlZXAobXMpIHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiBzZXRUaW1lb3V0KHJlc29sdmUsIG1zKSk7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsWUFBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQXVELFNBQUFELHVCQUFBRyxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRXZEO0FBQ0E7QUFDQTtBQUNBO0FBQ08sU0FBU0cseUJBQXlCQSxDQUFDQyxJQUFJLEVBQUU7RUFDOUMsSUFBSSxDQUFDQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsT0FBTyxFQUFFO0lBQ3hCLE1BQU0sb0NBQW9DO0VBQzVDO0VBQ0EsT0FBT0MsT0FBTyxDQUFDQyxHQUFHLENBQ2hCQyxNQUFNLENBQUNDLElBQUksQ0FBQ0MsY0FBUSxDQUFDQyxLQUFLLENBQUMsQ0FBQ0MsR0FBRyxDQUFDQyxLQUFLLElBQUk7SUFDdkMsTUFBTUMsR0FBRyxHQUFHSixjQUFRLENBQUNLLEdBQUcsQ0FBQ0YsS0FBSyxDQUFDO0lBQy9CLE1BQU1HLGNBQWMsR0FBRyxFQUFFO0lBQ3pCLElBQUlGLEdBQUcsQ0FBQ0csWUFBWSxJQUFJSCxHQUFHLENBQUNHLFlBQVksQ0FBQ0MsS0FBSyxFQUFFO01BQzlDRixjQUFjLENBQUNHLElBQUksQ0FBQ0wsR0FBRyxDQUFDRyxZQUFZLENBQUNDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDL0M7SUFDQSxJQUFJSixHQUFHLENBQUNNLGtCQUFrQixFQUFFO01BQzFCSixjQUFjLENBQUNHLElBQUksQ0FBQ0wsR0FBRyxDQUFDTSxrQkFBa0IsQ0FBQ0MsZ0JBQWdCLENBQUNuQixJQUFJLENBQUMsQ0FBQztJQUNwRSxDQUFDLE1BQU0sSUFBSVksR0FBRyxDQUFDUSxlQUFlLEVBQUU7TUFDOUJDLG9CQUFXLENBQUNMLEtBQUssQ0FBQyxDQUFDO01BQ25CRixjQUFjLENBQUNHLElBQUksQ0FBQ0wsR0FBRyxDQUFDUSxlQUFlLENBQUNFLGdCQUFnQixDQUFDdEIsSUFBSSxDQUFDLENBQUM7SUFDakU7SUFDQSxPQUFPSSxPQUFPLENBQUNDLEdBQUcsQ0FBQ1MsY0FBYyxDQUFDO0VBQ3BDLENBQUMsQ0FDSCxDQUFDO0FBQ0g7QUFFTyxTQUFTUyxnQkFBZ0JBLENBQUEsRUFBRztFQUNqQyxJQUFJQyxHQUFHO0VBQ1AsSUFBSUMsR0FBRztFQUNQLE1BQU1DLE9BQU8sR0FBRyxJQUFJdEIsT0FBTyxDQUFDLENBQUN1QixPQUFPLEVBQUVDLE1BQU0sS0FBSztJQUMvQ0osR0FBRyxHQUFHRyxPQUFPO0lBQ2JGLEdBQUcsR0FBR0csTUFBTTtFQUNkLENBQUMsQ0FBQztFQUNGRixPQUFPLENBQUNDLE9BQU8sR0FBR0gsR0FBRztFQUNyQkUsT0FBTyxDQUFDRSxNQUFNLEdBQUdILEdBQUc7RUFDcEIsT0FBT0MsT0FBTztBQUNoQjtBQUVPLFNBQVNHLEtBQUtBLENBQUNDLEVBQUUsRUFBRTtFQUN4QixPQUFPLElBQUkxQixPQUFPLENBQUV1QixPQUFPLElBQUtJLFVBQVUsQ0FBQ0osT0FBTyxFQUFFRyxFQUFFLENBQUMsQ0FBQztBQUMxRCIsImlnbm9yZUxpc3QiOltdfQ==
51
+ function getConnectionsCount(server) {
52
+ return new Promise((resolve, reject) => {
53
+ server.getConnections((err, count) => {
54
+ /* istanbul ignore next */
55
+ if (err) {
56
+ reject(err);
57
+ } else {
58
+ resolve(count);
59
+ }
60
+ });
61
+ });
62
+ }
63
+ ;
64
+ class Connections {
65
+ constructor() {
66
+ this.sockets = new Set();
67
+ }
68
+ track(server) {
69
+ server.on('connection', socket => {
70
+ this.sockets.add(socket);
71
+ socket.on('close', () => {
72
+ this.sockets.delete(socket);
73
+ });
74
+ });
75
+ }
76
+ destroyAll() {
77
+ for (const socket of this.sockets.values()) {
78
+ socket.destroy();
79
+ }
80
+ this.sockets.clear();
81
+ }
82
+ count() {
83
+ return this.sockets.size;
84
+ }
85
+ }
86
+ exports.Connections = Connections;
87
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY2FjaGUiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9TY2hlbWFDYWNoZSIsImUiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsImRlc3Ryb3lBbGxEYXRhUGVybWFuZW50bHkiLCJmYXN0IiwicHJvY2VzcyIsImVudiIsIlRFU1RJTkciLCJQcm9taXNlIiwiYWxsIiwiT2JqZWN0Iiwia2V5cyIsIkFwcENhY2hlIiwiY2FjaGUiLCJtYXAiLCJhcHBJZCIsImFwcCIsImdldCIsImRlbGV0ZVByb21pc2VzIiwiY2FjaGVBZGFwdGVyIiwiY2xlYXIiLCJwdXNoIiwiZGF0YWJhc2VDb250cm9sbGVyIiwiZGVsZXRlRXZlcnl0aGluZyIsImRhdGFiYXNlQWRhcHRlciIsIlNjaGVtYUNhY2hlIiwiZGVsZXRlQWxsQ2xhc3NlcyIsInJlc29sdmluZ1Byb21pc2UiLCJyZXMiLCJyZWoiLCJwcm9taXNlIiwicmVzb2x2ZSIsInJlamVjdCIsInNsZWVwIiwibXMiLCJzZXRUaW1lb3V0IiwiZ2V0Q29ubmVjdGlvbnNDb3VudCIsInNlcnZlciIsImdldENvbm5lY3Rpb25zIiwiZXJyIiwiY291bnQiLCJDb25uZWN0aW9ucyIsImNvbnN0cnVjdG9yIiwic29ja2V0cyIsIlNldCIsInRyYWNrIiwib24iLCJzb2NrZXQiLCJhZGQiLCJkZWxldGUiLCJkZXN0cm95QWxsIiwidmFsdWVzIiwiZGVzdHJveSIsInNpemUiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vc3JjL1Rlc3RVdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQXBwQ2FjaGUgZnJvbSAnLi9jYWNoZSc7XG5pbXBvcnQgU2NoZW1hQ2FjaGUgZnJvbSAnLi9BZGFwdGVycy9DYWNoZS9TY2hlbWFDYWNoZSc7XG5cbi8qKlxuICogRGVzdHJveXMgYWxsIGRhdGEgaW4gdGhlIGRhdGFiYXNlXG4gKiBAcGFyYW0ge2Jvb2xlYW59IGZhc3Qgc2V0IHRvIHRydWUgaWYgaXQncyBvayB0byBqdXN0IGRyb3Agb2JqZWN0cyBhbmQgbm90IGluZGV4ZXMuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkZXN0cm95QWxsRGF0YVBlcm1hbmVudGx5KGZhc3QpIHtcbiAgaWYgKCFwcm9jZXNzLmVudi5URVNUSU5HKSB7XG4gICAgdGhyb3cgJ09ubHkgc3VwcG9ydGVkIGluIHRlc3QgZW52aXJvbm1lbnQnO1xuICB9XG4gIHJldHVybiBQcm9taXNlLmFsbChcbiAgICBPYmplY3Qua2V5cyhBcHBDYWNoZS5jYWNoZSkubWFwKGFwcElkID0+IHtcbiAgICAgIGNvbnN0IGFwcCA9IEFwcENhY2hlLmdldChhcHBJZCk7XG4gICAgICBjb25zdCBkZWxldGVQcm9taXNlcyA9IFtdO1xuICAgICAgaWYgKGFwcC5jYWNoZUFkYXB0ZXIgJiYgYXBwLmNhY2hlQWRhcHRlci5jbGVhcikge1xuICAgICAgICBkZWxldGVQcm9taXNlcy5wdXNoKGFwcC5jYWNoZUFkYXB0ZXIuY2xlYXIoKSk7XG4gICAgICB9XG4gICAgICBpZiAoYXBwLmRhdGFiYXNlQ29udHJvbGxlcikge1xuICAgICAgICBkZWxldGVQcm9taXNlcy5wdXNoKGFwcC5kYXRhYmFzZUNvbnRyb2xsZXIuZGVsZXRlRXZlcnl0aGluZyhmYXN0KSk7XG4gICAgICB9IGVsc2UgaWYgKGFwcC5kYXRhYmFzZUFkYXB0ZXIpIHtcbiAgICAgICAgU2NoZW1hQ2FjaGUuY2xlYXIoKTtcbiAgICAgICAgZGVsZXRlUHJvbWlzZXMucHVzaChhcHAuZGF0YWJhc2VBZGFwdGVyLmRlbGV0ZUFsbENsYXNzZXMoZmFzdCkpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIFByb21pc2UuYWxsKGRlbGV0ZVByb21pc2VzKTtcbiAgICB9KVxuICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2aW5nUHJvbWlzZSgpIHtcbiAgbGV0IHJlcztcbiAgbGV0IHJlajtcbiAgY29uc3QgcHJvbWlzZSA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICByZXMgPSByZXNvbHZlO1xuICAgIHJlaiA9IHJlamVjdDtcbiAgfSk7XG4gIHByb21pc2UucmVzb2x2ZSA9IHJlcztcbiAgcHJvbWlzZS5yZWplY3QgPSByZWo7XG4gIHJldHVybiBwcm9taXNlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2xlZXAobXMpIHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiBzZXRUaW1lb3V0KHJlc29sdmUsIG1zKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25uZWN0aW9uc0NvdW50KHNlcnZlcikge1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHNlcnZlci5nZXRDb25uZWN0aW9ucygoZXJyLCBjb3VudCkgPT4ge1xuICAgICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICAgIGlmIChlcnIpIHtcbiAgICAgICAgcmVqZWN0KGVycik7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXNvbHZlKGNvdW50KTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSk7XG59O1xuXG5leHBvcnQgY2xhc3MgQ29ubmVjdGlvbnMge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLnNvY2tldHMgPSBuZXcgU2V0KCk7XG4gIH1cblxuICB0cmFjayhzZXJ2ZXIpIHtcbiAgICBzZXJ2ZXIub24oJ2Nvbm5lY3Rpb24nLCBzb2NrZXQgPT4ge1xuICAgICAgdGhpcy5zb2NrZXRzLmFkZChzb2NrZXQpO1xuICAgICAgc29ja2V0Lm9uKCdjbG9zZScsICgpID0+IHtcbiAgICAgICAgdGhpcy5zb2NrZXRzLmRlbGV0ZShzb2NrZXQpO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cblxuICBkZXN0cm95QWxsKCkge1xuICAgIGZvciAoY29uc3Qgc29ja2V0IG9mIHRoaXMuc29ja2V0cy52YWx1ZXMoKSkge1xuICAgICAgc29ja2V0LmRlc3Ryb3koKTtcbiAgICB9XG4gICAgdGhpcy5zb2NrZXRzLmNsZWFyKCk7XG4gIH1cblxuICBjb3VudCgpIHtcbiAgICByZXR1cm4gdGhpcy5zb2NrZXRzLnNpemU7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLFlBQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUF1RCxTQUFBRCx1QkFBQUcsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUV2RDtBQUNBO0FBQ0E7QUFDQTtBQUNPLFNBQVNHLHlCQUF5QkEsQ0FBQ0MsSUFBSSxFQUFFO0VBQzlDLElBQUksQ0FBQ0MsT0FBTyxDQUFDQyxHQUFHLENBQUNDLE9BQU8sRUFBRTtJQUN4QixNQUFNLG9DQUFvQztFQUM1QztFQUNBLE9BQU9DLE9BQU8sQ0FBQ0MsR0FBRyxDQUNoQkMsTUFBTSxDQUFDQyxJQUFJLENBQUNDLGNBQVEsQ0FBQ0MsS0FBSyxDQUFDLENBQUNDLEdBQUcsQ0FBQ0MsS0FBSyxJQUFJO0lBQ3ZDLE1BQU1DLEdBQUcsR0FBR0osY0FBUSxDQUFDSyxHQUFHLENBQUNGLEtBQUssQ0FBQztJQUMvQixNQUFNRyxjQUFjLEdBQUcsRUFBRTtJQUN6QixJQUFJRixHQUFHLENBQUNHLFlBQVksSUFBSUgsR0FBRyxDQUFDRyxZQUFZLENBQUNDLEtBQUssRUFBRTtNQUM5Q0YsY0FBYyxDQUFDRyxJQUFJLENBQUNMLEdBQUcsQ0FBQ0csWUFBWSxDQUFDQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQy9DO0lBQ0EsSUFBSUosR0FBRyxDQUFDTSxrQkFBa0IsRUFBRTtNQUMxQkosY0FBYyxDQUFDRyxJQUFJLENBQUNMLEdBQUcsQ0FBQ00sa0JBQWtCLENBQUNDLGdCQUFnQixDQUFDbkIsSUFBSSxDQUFDLENBQUM7SUFDcEUsQ0FBQyxNQUFNLElBQUlZLEdBQUcsQ0FBQ1EsZUFBZSxFQUFFO01BQzlCQyxvQkFBVyxDQUFDTCxLQUFLLENBQUMsQ0FBQztNQUNuQkYsY0FBYyxDQUFDRyxJQUFJLENBQUNMLEdBQUcsQ0FBQ1EsZUFBZSxDQUFDRSxnQkFBZ0IsQ0FBQ3RCLElBQUksQ0FBQyxDQUFDO0lBQ2pFO0lBQ0EsT0FBT0ksT0FBTyxDQUFDQyxHQUFHLENBQUNTLGNBQWMsQ0FBQztFQUNwQyxDQUFDLENBQ0gsQ0FBQztBQUNIO0FBRU8sU0FBU1MsZ0JBQWdCQSxDQUFBLEVBQUc7RUFDakMsSUFBSUMsR0FBRztFQUNQLElBQUlDLEdBQUc7RUFDUCxNQUFNQyxPQUFPLEdBQUcsSUFBSXRCLE9BQU8sQ0FBQyxDQUFDdUIsT0FBTyxFQUFFQyxNQUFNLEtBQUs7SUFDL0NKLEdBQUcsR0FBR0csT0FBTztJQUNiRixHQUFHLEdBQUdHLE1BQU07RUFDZCxDQUFDLENBQUM7RUFDRkYsT0FBTyxDQUFDQyxPQUFPLEdBQUdILEdBQUc7RUFDckJFLE9BQU8sQ0FBQ0UsTUFBTSxHQUFHSCxHQUFHO0VBQ3BCLE9BQU9DLE9BQU87QUFDaEI7QUFFTyxTQUFTRyxLQUFLQSxDQUFDQyxFQUFFLEVBQUU7RUFDeEIsT0FBTyxJQUFJMUIsT0FBTyxDQUFFdUIsT0FBTyxJQUFLSSxVQUFVLENBQUNKLE9BQU8sRUFBRUcsRUFBRSxDQUFDLENBQUM7QUFDMUQ7QUFFTyxTQUFTRSxtQkFBbUJBLENBQUNDLE1BQU0sRUFBRTtFQUMxQyxPQUFPLElBQUk3QixPQUFPLENBQUMsQ0FBQ3VCLE9BQU8sRUFBRUMsTUFBTSxLQUFLO0lBQ3RDSyxNQUFNLENBQUNDLGNBQWMsQ0FBQyxDQUFDQyxHQUFHLEVBQUVDLEtBQUssS0FBSztNQUNwQztNQUNBLElBQUlELEdBQUcsRUFBRTtRQUNQUCxNQUFNLENBQUNPLEdBQUcsQ0FBQztNQUNiLENBQUMsTUFBTTtRQUNMUixPQUFPLENBQUNTLEtBQUssQ0FBQztNQUNoQjtJQUNGLENBQUMsQ0FBQztFQUNKLENBQUMsQ0FBQztBQUNKO0FBQUM7QUFFTSxNQUFNQyxXQUFXLENBQUM7RUFDdkJDLFdBQVdBLENBQUEsRUFBRztJQUNaLElBQUksQ0FBQ0MsT0FBTyxHQUFHLElBQUlDLEdBQUcsQ0FBQyxDQUFDO0VBQzFCO0VBRUFDLEtBQUtBLENBQUNSLE1BQU0sRUFBRTtJQUNaQSxNQUFNLENBQUNTLEVBQUUsQ0FBQyxZQUFZLEVBQUVDLE1BQU0sSUFBSTtNQUNoQyxJQUFJLENBQUNKLE9BQU8sQ0FBQ0ssR0FBRyxDQUFDRCxNQUFNLENBQUM7TUFDeEJBLE1BQU0sQ0FBQ0QsRUFBRSxDQUFDLE9BQU8sRUFBRSxNQUFNO1FBQ3ZCLElBQUksQ0FBQ0gsT0FBTyxDQUFDTSxNQUFNLENBQUNGLE1BQU0sQ0FBQztNQUM3QixDQUFDLENBQUM7SUFDSixDQUFDLENBQUM7RUFDSjtFQUVBRyxVQUFVQSxDQUFBLEVBQUc7SUFDWCxLQUFLLE1BQU1ILE1BQU0sSUFBSSxJQUFJLENBQUNKLE9BQU8sQ0FBQ1EsTUFBTSxDQUFDLENBQUMsRUFBRTtNQUMxQ0osTUFBTSxDQUFDSyxPQUFPLENBQUMsQ0FBQztJQUNsQjtJQUNBLElBQUksQ0FBQ1QsT0FBTyxDQUFDdkIsS0FBSyxDQUFDLENBQUM7RUFDdEI7RUFFQW9CLEtBQUtBLENBQUEsRUFBRztJQUNOLE9BQU8sSUFBSSxDQUFDRyxPQUFPLENBQUNVLElBQUk7RUFDMUI7QUFDRjtBQUFDQyxPQUFBLENBQUFiLFdBQUEsR0FBQUEsV0FBQSIsImlnbm9yZUxpc3QiOltdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "8.1.0-alpha.2",
3
+ "version": "8.1.0-alpha.4",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {
@@ -24,7 +24,7 @@
24
24
  "@babel/eslint-parser": "7.26.10",
25
25
  "@graphql-tools/merge": "9.0.24",
26
26
  "@graphql-tools/schema": "10.0.23",
27
- "@graphql-tools/utils": "10.6.3",
27
+ "@graphql-tools/utils": "10.8.4",
28
28
  "@parse/fs-files-adapter": "3.0.0",
29
29
  "@parse/push-adapter": "6.11.0",
30
30
  "bcryptjs": "2.4.3",
@@ -41,7 +41,7 @@
41
41
  "graphql-upload": "15.0.2",
42
42
  "intersect": "1.0.1",
43
43
  "jsonwebtoken": "9.0.2",
44
- "jwks-rsa": "3.1.0",
44
+ "jwks-rsa": "3.2.0",
45
45
  "ldapjs": "3.0.7",
46
46
  "lodash": "4.17.21",
47
47
  "lru-cache": "10.4.0",
@@ -49,7 +49,7 @@
49
49
  "mongodb": "6.15.0",
50
50
  "mustache": "4.2.0",
51
51
  "otpauth": "9.3.6",
52
- "parse": "6.0.0",
52
+ "parse": "6.1.0",
53
53
  "path-to-regexp": "6.3.0",
54
54
  "pg-monitor": "2.1.0",
55
55
  "pg-promise": "11.13.0",