parse-server 5.5.3 → 5.5.5

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.
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ const classesWithMasterOnlyAccess = ['_JobStatus', '_PushStatus', '_Hooks', '_GlobalConfig', '_JobSchedule', '_Idempotency']; // Disallowing access to the _Role collection except by master key
4
+
5
+ function enforceRoleSecurity(method, className, auth) {
6
+ if (className === '_Installation' && !auth.isMaster) {
7
+ if (method === 'delete' || method === 'find') {
8
+ const error = `Clients aren't allowed to perform the ${method} operation on the installation collection.`;
9
+ throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
10
+ }
11
+ } //all volatileClasses are masterKey only
12
+
13
+
14
+ if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster) {
15
+ const error = `Clients aren't allowed to perform the ${method} operation on the ${className} collection.`;
16
+ throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
17
+ } // readOnly masterKey is not allowed
18
+
19
+
20
+ if (auth.isReadOnly && (method === 'delete' || method === 'create' || method === 'update')) {
21
+ const error = `read-only masterKey isn't allowed to perform the ${method} operation.`;
22
+ throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
23
+ }
24
+ }
25
+
26
+ module.exports = {
27
+ enforceRoleSecurity
28
+ };
29
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9TaGFyZWRSZXN0LmpzIl0sIm5hbWVzIjpbImNsYXNzZXNXaXRoTWFzdGVyT25seUFjY2VzcyIsImVuZm9yY2VSb2xlU2VjdXJpdHkiLCJtZXRob2QiLCJjbGFzc05hbWUiLCJhdXRoIiwiaXNNYXN0ZXIiLCJlcnJvciIsIlBhcnNlIiwiRXJyb3IiLCJPUEVSQVRJT05fRk9SQklEREVOIiwiaW5kZXhPZiIsImlzUmVhZE9ubHkiLCJtb2R1bGUiLCJleHBvcnRzIl0sIm1hcHBpbmdzIjoiOztBQUFBLE1BQU1BLDJCQUEyQixHQUFHLENBQ2xDLFlBRGtDLEVBRWxDLGFBRmtDLEVBR2xDLFFBSGtDLEVBSWxDLGVBSmtDLEVBS2xDLGNBTGtDLEVBTWxDLGNBTmtDLENBQXBDLEMsQ0FRQTs7QUFDQSxTQUFTQyxtQkFBVCxDQUE2QkMsTUFBN0IsRUFBcUNDLFNBQXJDLEVBQWdEQyxJQUFoRCxFQUFzRDtBQUNwRCxNQUFJRCxTQUFTLEtBQUssZUFBZCxJQUFpQyxDQUFDQyxJQUFJLENBQUNDLFFBQTNDLEVBQXFEO0FBQ25ELFFBQUlILE1BQU0sS0FBSyxRQUFYLElBQXVCQSxNQUFNLEtBQUssTUFBdEMsRUFBOEM7QUFDNUMsWUFBTUksS0FBSyxHQUFJLHlDQUF3Q0osTUFBTyw0Q0FBOUQ7QUFDQSxZQUFNLElBQUlLLEtBQUssQ0FBQ0MsS0FBVixDQUFnQkQsS0FBSyxDQUFDQyxLQUFOLENBQVlDLG1CQUE1QixFQUFpREgsS0FBakQsQ0FBTjtBQUNEO0FBQ0YsR0FObUQsQ0FRcEQ7OztBQUNBLE1BQUlOLDJCQUEyQixDQUFDVSxPQUE1QixDQUFvQ1AsU0FBcEMsS0FBa0QsQ0FBbEQsSUFBdUQsQ0FBQ0MsSUFBSSxDQUFDQyxRQUFqRSxFQUEyRTtBQUN6RSxVQUFNQyxLQUFLLEdBQUkseUNBQXdDSixNQUFPLHFCQUFvQkMsU0FBVSxjQUE1RjtBQUNBLFVBQU0sSUFBSUksS0FBSyxDQUFDQyxLQUFWLENBQWdCRCxLQUFLLENBQUNDLEtBQU4sQ0FBWUMsbUJBQTVCLEVBQWlESCxLQUFqRCxDQUFOO0FBQ0QsR0FabUQsQ0FjcEQ7OztBQUNBLE1BQUlGLElBQUksQ0FBQ08sVUFBTCxLQUFvQlQsTUFBTSxLQUFLLFFBQVgsSUFBdUJBLE1BQU0sS0FBSyxRQUFsQyxJQUE4Q0EsTUFBTSxLQUFLLFFBQTdFLENBQUosRUFBNEY7QUFDMUYsVUFBTUksS0FBSyxHQUFJLG9EQUFtREosTUFBTyxhQUF6RTtBQUNBLFVBQU0sSUFBSUssS0FBSyxDQUFDQyxLQUFWLENBQWdCRCxLQUFLLENBQUNDLEtBQU4sQ0FBWUMsbUJBQTVCLEVBQWlESCxLQUFqRCxDQUFOO0FBQ0Q7QUFDRjs7QUFFRE0sTUFBTSxDQUFDQyxPQUFQLEdBQWlCO0FBQ2ZaLEVBQUFBO0FBRGUsQ0FBakIiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBjbGFzc2VzV2l0aE1hc3Rlck9ubHlBY2Nlc3MgPSBbXG4gICdfSm9iU3RhdHVzJyxcbiAgJ19QdXNoU3RhdHVzJyxcbiAgJ19Ib29rcycsXG4gICdfR2xvYmFsQ29uZmlnJyxcbiAgJ19Kb2JTY2hlZHVsZScsXG4gICdfSWRlbXBvdGVuY3knLFxuXTtcbi8vIERpc2FsbG93aW5nIGFjY2VzcyB0byB0aGUgX1JvbGUgY29sbGVjdGlvbiBleGNlcHQgYnkgbWFzdGVyIGtleVxuZnVuY3Rpb24gZW5mb3JjZVJvbGVTZWN1cml0eShtZXRob2QsIGNsYXNzTmFtZSwgYXV0aCkge1xuICBpZiAoY2xhc3NOYW1lID09PSAnX0luc3RhbGxhdGlvbicgJiYgIWF1dGguaXNNYXN0ZXIpIHtcbiAgICBpZiAobWV0aG9kID09PSAnZGVsZXRlJyB8fCBtZXRob2QgPT09ICdmaW5kJykge1xuICAgICAgY29uc3QgZXJyb3IgPSBgQ2xpZW50cyBhcmVuJ3QgYWxsb3dlZCB0byBwZXJmb3JtIHRoZSAke21ldGhvZH0gb3BlcmF0aW9uIG9uIHRoZSBpbnN0YWxsYXRpb24gY29sbGVjdGlvbi5gO1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFBhcnNlLkVycm9yLk9QRVJBVElPTl9GT1JCSURERU4sIGVycm9yKTtcbiAgICB9XG4gIH1cblxuICAvL2FsbCB2b2xhdGlsZUNsYXNzZXMgYXJlIG1hc3RlcktleSBvbmx5XG4gIGlmIChjbGFzc2VzV2l0aE1hc3Rlck9ubHlBY2Nlc3MuaW5kZXhPZihjbGFzc05hbWUpID49IDAgJiYgIWF1dGguaXNNYXN0ZXIpIHtcbiAgICBjb25zdCBlcnJvciA9IGBDbGllbnRzIGFyZW4ndCBhbGxvd2VkIHRvIHBlcmZvcm0gdGhlICR7bWV0aG9kfSBvcGVyYXRpb24gb24gdGhlICR7Y2xhc3NOYW1lfSBjb2xsZWN0aW9uLmA7XG4gICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFBhcnNlLkVycm9yLk9QRVJBVElPTl9GT1JCSURERU4sIGVycm9yKTtcbiAgfVxuXG4gIC8vIHJlYWRPbmx5IG1hc3RlcktleSBpcyBub3QgYWxsb3dlZFxuICBpZiAoYXV0aC5pc1JlYWRPbmx5ICYmIChtZXRob2QgPT09ICdkZWxldGUnIHx8IG1ldGhvZCA9PT0gJ2NyZWF0ZScgfHwgbWV0aG9kID09PSAndXBkYXRlJykpIHtcbiAgICBjb25zdCBlcnJvciA9IGByZWFkLW9ubHkgbWFzdGVyS2V5IGlzbid0IGFsbG93ZWQgdG8gcGVyZm9ybSB0aGUgJHttZXRob2R9IG9wZXJhdGlvbi5gO1xuICAgIHRocm93IG5ldyBQYXJzZS5FcnJvcihQYXJzZS5FcnJvci5PUEVSQVRJT05fRk9SQklEREVOLCBlcnJvcik7XG4gIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gIGVuZm9yY2VSb2xlU2VjdXJpdHksXG59O1xuIl19
package/lib/rest.js CHANGED
@@ -16,6 +16,10 @@ var RestWrite = require('./RestWrite');
16
16
 
17
17
  var triggers = require('./triggers');
18
18
 
19
+ const {
20
+ enforceRoleSecurity
21
+ } = require('./SharedRest');
22
+
19
23
  function checkTriggers(className, config, types) {
20
24
  return types.some(triggerType => {
21
25
  return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);
@@ -27,28 +31,36 @@ function checkLiveQuery(className, config) {
27
31
  } // Returns a promise for an object with optional keys 'results' and 'count'.
28
32
 
29
33
 
30
- function find(config, auth, className, restWhere, restOptions, clientSDK, context) {
31
- enforceRoleSecurity('find', className, auth);
32
- return triggers.maybeRunQueryTrigger(triggers.Types.beforeFind, className, restWhere, restOptions, config, auth, context).then(result => {
33
- restWhere = result.restWhere || restWhere;
34
- restOptions = result.restOptions || restOptions;
35
- const query = new RestQuery(config, auth, className, restWhere, restOptions, clientSDK, true, context);
36
- return query.execute();
34
+ const find = async (config, auth, className, restWhere, restOptions, clientSDK, context) => {
35
+ const query = await RestQuery({
36
+ method: RestQuery.Method.find,
37
+ config,
38
+ auth,
39
+ className,
40
+ restWhere,
41
+ restOptions,
42
+ clientSDK,
43
+ context
37
44
  });
38
- } // get is just like find but only queries an objectId.
45
+ return query.execute();
46
+ }; // get is just like find but only queries an objectId.
39
47
 
40
48
 
41
- const get = (config, auth, className, objectId, restOptions, clientSDK, context) => {
49
+ const get = async (config, auth, className, objectId, restOptions, clientSDK, context) => {
42
50
  var restWhere = {
43
51
  objectId
44
52
  };
45
- enforceRoleSecurity('get', className, auth);
46
- return triggers.maybeRunQueryTrigger(triggers.Types.beforeFind, className, restWhere, restOptions, config, auth, context, true).then(result => {
47
- restWhere = result.restWhere || restWhere;
48
- restOptions = result.restOptions || restOptions;
49
- const query = new RestQuery(config, auth, className, restWhere, restOptions, clientSDK, true, context);
50
- return query.execute();
53
+ const query = await RestQuery({
54
+ method: RestQuery.Method.get,
55
+ config,
56
+ auth,
57
+ className,
58
+ restWhere,
59
+ restOptions,
60
+ clientSDK,
61
+ context
51
62
  });
63
+ return query.execute();
52
64
  }; // Returns a promise that doesn't resolve to any useful value.
53
65
 
54
66
 
@@ -64,14 +76,21 @@ function del(config, auth, className, objectId, context) {
64
76
  enforceRoleSecurity('delete', className, auth);
65
77
  let inflatedObject;
66
78
  let schemaController;
67
- return Promise.resolve().then(() => {
79
+ return Promise.resolve().then(async () => {
68
80
  const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);
69
81
  const hasLiveQuery = checkLiveQuery(className, config);
70
82
 
71
83
  if (hasTriggers || hasLiveQuery || className == '_Session') {
72
- return new RestQuery(config, auth, className, {
73
- objectId
74
- }).execute({
84
+ const query = await RestQuery({
85
+ method: RestQuery.Method.get,
86
+ config,
87
+ auth,
88
+ className,
89
+ restWhere: {
90
+ objectId
91
+ }
92
+ });
93
+ return query.execute({
75
94
  op: 'delete'
76
95
  }).then(response => {
77
96
  if (response && response.results && response.results.length) {
@@ -139,13 +158,23 @@ function create(config, auth, className, restObject, clientSDK, context) {
139
158
 
140
159
  function update(config, auth, className, restWhere, restObject, clientSDK, context) {
141
160
  enforceRoleSecurity('update', className, auth);
142
- return Promise.resolve().then(() => {
161
+ return Promise.resolve().then(async () => {
143
162
  const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);
144
163
  const hasLiveQuery = checkLiveQuery(className, config);
145
164
 
146
165
  if (hasTriggers || hasLiveQuery) {
147
166
  // Do not use find, as it runs the before finds
148
- return new RestQuery(config, auth, className, restWhere, undefined, undefined, false, context).execute({
167
+ const query = await RestQuery({
168
+ method: RestQuery.Method.get,
169
+ config,
170
+ auth,
171
+ className,
172
+ restWhere,
173
+ runAfterFind: false,
174
+ runBeforeFind: false,
175
+ context
176
+ });
177
+ return query.execute({
149
178
  op: 'update'
150
179
  });
151
180
  }
@@ -175,29 +204,6 @@ function handleSessionMissingError(error, className, auth) {
175
204
  throw error;
176
205
  }
177
206
 
178
- const classesWithMasterOnlyAccess = ['_JobStatus', '_PushStatus', '_Hooks', '_GlobalConfig', '_JobSchedule', '_Idempotency']; // Disallowing access to the _Role collection except by master key
179
-
180
- function enforceRoleSecurity(method, className, auth) {
181
- if (className === '_Installation' && !auth.isMaster) {
182
- if (method === 'delete' || method === 'find') {
183
- const error = `Clients aren't allowed to perform the ${method} operation on the installation collection.`;
184
- throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
185
- }
186
- } //all volatileClasses are masterKey only
187
-
188
-
189
- if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster) {
190
- const error = `Clients aren't allowed to perform the ${method} operation on the ${className} collection.`;
191
- throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
192
- } // readOnly masterKey is not allowed
193
-
194
-
195
- if (auth.isReadOnly && (method === 'delete' || method === 'create' || method === 'update')) {
196
- const error = `read-only masterKey isn't allowed to perform the ${method} operation.`;
197
- throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
198
- }
199
- }
200
-
201
207
  module.exports = {
202
208
  create,
203
209
  del,
@@ -205,4 +211,4 @@ module.exports = {
205
211
  get,
206
212
  update
207
213
  };
208
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/rest.js"],"names":["Parse","require","RestQuery","RestWrite","triggers","checkTriggers","className","config","types","some","triggerType","getTrigger","Types","applicationId","checkLiveQuery","liveQueryController","hasLiveQuery","find","auth","restWhere","restOptions","clientSDK","context","enforceRoleSecurity","maybeRunQueryTrigger","beforeFind","then","result","query","execute","get","objectId","del","Error","INVALID_JSON","isUnauthenticated","SESSION_MISSING","inflatedObject","schemaController","Promise","resolve","hasTriggers","op","response","results","length","firstResult","isMaster","user","id","INVALID_SESSION_TOKEN","cacheAdapter","cacheController","sessionToken","Object","fromJSON","maybeRunTrigger","beforeDelete","OBJECT_NOT_FOUND","getUserRoles","database","loadSchema","s","options","acl","push","concat","userRoles","destroy","perms","getClassLevelPermissions","onAfterDelete","afterDelete","catch","error","handleSessionMissingError","create","restObject","write","update","undefined","originalRestObject","code","classesWithMasterOnlyAccess","method","OPERATION_FORBIDDEN","indexOf","isReadOnly","module","exports"],"mappings":"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","sourcesContent":["// This file contains helpers for running operations in REST format.\n// The goal is that handlers that explicitly handle an express route\n// should just be shallow wrappers around things in this file, but\n// these functions should not explicitly depend on the request\n// object.\n// This means that one of these handlers can support multiple\n// routes. That's useful for the routes that do really similar\n// things.\n\nvar Parse = require('parse/node').Parse;\n\nvar RestQuery = require('./RestQuery');\nvar RestWrite = require('./RestWrite');\nvar triggers = require('./triggers');\n\nfunction checkTriggers(className, config, types) {\n  return types.some(triggerType => {\n    return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);\n  });\n}\n\nfunction checkLiveQuery(className, config) {\n  return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);\n}\n\n// Returns a promise for an object with optional keys 'results' and 'count'.\nfunction find(config, auth, className, restWhere, restOptions, clientSDK, context) {\n  enforceRoleSecurity('find', className, auth);\n  return triggers\n    .maybeRunQueryTrigger(\n      triggers.Types.beforeFind,\n      className,\n      restWhere,\n      restOptions,\n      config,\n      auth,\n      context\n    )\n    .then(result => {\n      restWhere = result.restWhere || restWhere;\n      restOptions = result.restOptions || restOptions;\n      const query = new RestQuery(\n        config,\n        auth,\n        className,\n        restWhere,\n        restOptions,\n        clientSDK,\n        true,\n        context\n      );\n      return query.execute();\n    });\n}\n\n// get is just like find but only queries an objectId.\nconst get = (config, auth, className, objectId, restOptions, clientSDK, context) => {\n  var restWhere = { objectId };\n  enforceRoleSecurity('get', className, auth);\n  return triggers\n    .maybeRunQueryTrigger(\n      triggers.Types.beforeFind,\n      className,\n      restWhere,\n      restOptions,\n      config,\n      auth,\n      context,\n      true\n    )\n    .then(result => {\n      restWhere = result.restWhere || restWhere;\n      restOptions = result.restOptions || restOptions;\n      const query = new RestQuery(\n        config,\n        auth,\n        className,\n        restWhere,\n        restOptions,\n        clientSDK,\n        true,\n        context\n      );\n      return query.execute();\n    });\n};\n\n// Returns a promise that doesn't resolve to any useful value.\nfunction del(config, auth, className, objectId, context) {\n  if (typeof objectId !== 'string') {\n    throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');\n  }\n\n  if (className === '_User' && auth.isUnauthenticated()) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');\n  }\n\n  enforceRoleSecurity('delete', className, auth);\n\n  let inflatedObject;\n  let schemaController;\n\n  return Promise.resolve()\n    .then(() => {\n      const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery || className == '_Session') {\n        return new RestQuery(config, auth, className, { objectId })\n          .execute({ op: 'delete' })\n          .then(response => {\n            if (response && response.results && response.results.length) {\n              const firstResult = response.results[0];\n              firstResult.className = className;\n              if (className === '_Session' && !auth.isMaster) {\n                if (!auth.user || firstResult.user.objectId !== auth.user.id) {\n                  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n                }\n              }\n              var cacheAdapter = config.cacheController;\n              cacheAdapter.user.del(firstResult.sessionToken);\n              inflatedObject = Parse.Object.fromJSON(firstResult);\n              return triggers.maybeRunTrigger(\n                triggers.Types.beforeDelete,\n                auth,\n                inflatedObject,\n                null,\n                config,\n                context\n              );\n            }\n            throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');\n          });\n      }\n      return Promise.resolve({});\n    })\n    .then(() => {\n      if (!auth.isMaster) {\n        return auth.getUserRoles();\n      } else {\n        return;\n      }\n    })\n    .then(() => config.database.loadSchema())\n    .then(s => {\n      schemaController = s;\n      const options = {};\n      if (!auth.isMaster) {\n        options.acl = ['*'];\n        if (auth.user) {\n          options.acl.push(auth.user.id);\n          options.acl = options.acl.concat(auth.userRoles);\n        }\n      }\n\n      return config.database.destroy(\n        className,\n        {\n          objectId: objectId,\n        },\n        options,\n        schemaController\n      );\n    })\n    .then(() => {\n      // Notify LiveQuery server if possible\n      const perms = schemaController.getClassLevelPermissions(className);\n      config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);\n      return triggers.maybeRunTrigger(\n        triggers.Types.afterDelete,\n        auth,\n        inflatedObject,\n        null,\n        config,\n        context\n      );\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\n// Returns a promise for a {response, status, location} object.\nfunction create(config, auth, className, restObject, clientSDK, context) {\n  enforceRoleSecurity('create', className, auth);\n  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);\n  return write.execute();\n}\n\n// Returns a promise that contains the fields of the update that the\n// REST API is supposed to return.\n// Usually, this is just updatedAt.\nfunction update(config, auth, className, restWhere, restObject, clientSDK, context) {\n  enforceRoleSecurity('update', className, auth);\n\n  return Promise.resolve()\n    .then(() => {\n      const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery) {\n        // Do not use find, as it runs the before finds\n        return new RestQuery(\n          config,\n          auth,\n          className,\n          restWhere,\n          undefined,\n          undefined,\n          false,\n          context\n        ).execute({\n          op: 'update',\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(({ results }) => {\n      var originalRestObject;\n      if (results && results.length) {\n        originalRestObject = results[0];\n      }\n      return new RestWrite(\n        config,\n        auth,\n        className,\n        restWhere,\n        restObject,\n        originalRestObject,\n        clientSDK,\n        context,\n        'update'\n      ).execute();\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\nfunction handleSessionMissingError(error, className, auth) {\n  // If we're trying to update a user without / with bad session token\n  if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');\n  }\n  throw error;\n}\n\nconst classesWithMasterOnlyAccess = [\n  '_JobStatus',\n  '_PushStatus',\n  '_Hooks',\n  '_GlobalConfig',\n  '_JobSchedule',\n  '_Idempotency',\n];\n// Disallowing access to the _Role collection except by master key\nfunction enforceRoleSecurity(method, className, auth) {\n  if (className === '_Installation' && !auth.isMaster) {\n    if (method === 'delete' || method === 'find') {\n      const error = `Clients aren't allowed to perform the ${method} operation on the installation collection.`;\n      throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n    }\n  }\n\n  //all volatileClasses are masterKey only\n  if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster) {\n    const error = `Clients aren't allowed to perform the ${method} operation on the ${className} collection.`;\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n  }\n\n  // readOnly masterKey is not allowed\n  if (auth.isReadOnly && (method === 'delete' || method === 'create' || method === 'update')) {\n    const error = `read-only masterKey isn't allowed to perform the ${method} operation.`;\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);\n  }\n}\n\nmodule.exports = {\n  create,\n  del,\n  find,\n  get,\n  update,\n};\n"]}
214
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/rest.js"],"names":["Parse","require","RestQuery","RestWrite","triggers","enforceRoleSecurity","checkTriggers","className","config","types","some","triggerType","getTrigger","Types","applicationId","checkLiveQuery","liveQueryController","hasLiveQuery","find","auth","restWhere","restOptions","clientSDK","context","query","method","Method","execute","get","objectId","del","Error","INVALID_JSON","isUnauthenticated","SESSION_MISSING","inflatedObject","schemaController","Promise","resolve","then","hasTriggers","op","response","results","length","firstResult","isMaster","user","id","INVALID_SESSION_TOKEN","cacheAdapter","cacheController","sessionToken","Object","fromJSON","maybeRunTrigger","beforeDelete","OBJECT_NOT_FOUND","getUserRoles","database","loadSchema","s","options","acl","push","concat","userRoles","destroy","perms","getClassLevelPermissions","onAfterDelete","afterDelete","catch","error","handleSessionMissingError","create","restObject","write","update","runAfterFind","runBeforeFind","originalRestObject","code","module","exports"],"mappings":"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","sourcesContent":["// This file contains helpers for running operations in REST format.\n// The goal is that handlers that explicitly handle an express route\n// should just be shallow wrappers around things in this file, but\n// these functions should not explicitly depend on the request\n// object.\n// This means that one of these handlers can support multiple\n// routes. That's useful for the routes that do really similar\n// things.\n\nvar Parse = require('parse/node').Parse;\n\nvar RestQuery = require('./RestQuery');\nvar RestWrite = require('./RestWrite');\nvar triggers = require('./triggers');\nconst { enforceRoleSecurity } = require('./SharedRest');\n\nfunction checkTriggers(className, config, types) {\n  return types.some(triggerType => {\n    return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);\n  });\n}\n\nfunction checkLiveQuery(className, config) {\n  return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);\n}\n\n// Returns a promise for an object with optional keys 'results' and 'count'.\nconst find = async (config, auth, className, restWhere, restOptions, clientSDK, context) => {\n  const query = await RestQuery({\n    method: RestQuery.Method.find,\n    config,\n    auth,\n    className,\n    restWhere,\n    restOptions,\n    clientSDK,\n    context,\n  });\n  return query.execute();\n};\n\n// get is just like find but only queries an objectId.\nconst get = async (config, auth, className, objectId, restOptions, clientSDK, context) => {\n  var restWhere = { objectId };\n  const query = await RestQuery({\n    method: RestQuery.Method.get,\n    config,\n    auth,\n    className,\n    restWhere,\n    restOptions,\n    clientSDK,\n    context,\n  });\n  return query.execute();\n};\n\n// Returns a promise that doesn't resolve to any useful value.\nfunction del(config, auth, className, objectId, context) {\n  if (typeof objectId !== 'string') {\n    throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');\n  }\n\n  if (className === '_User' && auth.isUnauthenticated()) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');\n  }\n\n  enforceRoleSecurity('delete', className, auth);\n\n  let inflatedObject;\n  let schemaController;\n\n  return Promise.resolve()\n    .then(async () => {\n      const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery || className == '_Session') {\n        const query = await RestQuery({\n          method: RestQuery.Method.get,\n          config,\n          auth,\n          className,\n          restWhere: { objectId },\n        });\n        return query.execute({ op: 'delete' }).then(response => {\n          if (response && response.results && response.results.length) {\n            const firstResult = response.results[0];\n            firstResult.className = className;\n            if (className === '_Session' && !auth.isMaster) {\n              if (!auth.user || firstResult.user.objectId !== auth.user.id) {\n                throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');\n              }\n            }\n            var cacheAdapter = config.cacheController;\n            cacheAdapter.user.del(firstResult.sessionToken);\n            inflatedObject = Parse.Object.fromJSON(firstResult);\n            return triggers.maybeRunTrigger(\n              triggers.Types.beforeDelete,\n              auth,\n              inflatedObject,\n              null,\n              config,\n              context\n            );\n          }\n          throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(() => {\n      if (!auth.isMaster) {\n        return auth.getUserRoles();\n      } else {\n        return;\n      }\n    })\n    .then(() => config.database.loadSchema())\n    .then(s => {\n      schemaController = s;\n      const options = {};\n      if (!auth.isMaster) {\n        options.acl = ['*'];\n        if (auth.user) {\n          options.acl.push(auth.user.id);\n          options.acl = options.acl.concat(auth.userRoles);\n        }\n      }\n\n      return config.database.destroy(\n        className,\n        {\n          objectId: objectId,\n        },\n        options,\n        schemaController\n      );\n    })\n    .then(() => {\n      // Notify LiveQuery server if possible\n      const perms = schemaController.getClassLevelPermissions(className);\n      config.liveQueryController.onAfterDelete(className, inflatedObject, null, perms);\n      return triggers.maybeRunTrigger(\n        triggers.Types.afterDelete,\n        auth,\n        inflatedObject,\n        null,\n        config,\n        context\n      );\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\n// Returns a promise for a {response, status, location} object.\nfunction create(config, auth, className, restObject, clientSDK, context) {\n  enforceRoleSecurity('create', className, auth);\n  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);\n  return write.execute();\n}\n\n// Returns a promise that contains the fields of the update that the\n// REST API is supposed to return.\n// Usually, this is just updatedAt.\nfunction update(config, auth, className, restWhere, restObject, clientSDK, context) {\n  enforceRoleSecurity('update', className, auth);\n\n  return Promise.resolve()\n    .then(async () => {\n      const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);\n      const hasLiveQuery = checkLiveQuery(className, config);\n      if (hasTriggers || hasLiveQuery) {\n        // Do not use find, as it runs the before finds\n        const query = await RestQuery({\n          method: RestQuery.Method.get,\n          config,\n          auth,\n          className,\n          restWhere,\n          runAfterFind: false,\n          runBeforeFind: false,\n          context,\n        });\n        return query.execute({\n          op: 'update',\n        });\n      }\n      return Promise.resolve({});\n    })\n    .then(({ results }) => {\n      var originalRestObject;\n      if (results && results.length) {\n        originalRestObject = results[0];\n      }\n      return new RestWrite(\n        config,\n        auth,\n        className,\n        restWhere,\n        restObject,\n        originalRestObject,\n        clientSDK,\n        context,\n        'update'\n      ).execute();\n    })\n    .catch(error => {\n      handleSessionMissingError(error, className, auth);\n    });\n}\n\nfunction handleSessionMissingError(error, className, auth) {\n  // If we're trying to update a user without / with bad session token\n  if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster) {\n    throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');\n  }\n  throw error;\n}\n\nmodule.exports = {\n  create,\n  del,\n  find,\n  get,\n  update,\n};\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-server",
3
- "version": "5.5.3",
3
+ "version": "5.5.5",
4
4
  "description": "An express module providing a Parse-compatible API server",
5
5
  "main": "lib/index.js",
6
6
  "repository": {
@@ -19,10 +19,10 @@
19
19
  ],
20
20
  "license": "BSD-3-Clause",
21
21
  "dependencies": {
22
- "@graphql-yoga/node": "2.6.0",
23
- "@graphql-tools/utils": "8.12.0",
24
22
  "@graphql-tools/merge": "8.4.1",
25
23
  "@graphql-tools/schema": "9.0.4",
24
+ "@graphql-tools/utils": "8.12.0",
25
+ "@graphql-yoga/node": "2.6.0",
26
26
  "@parse/fs-files-adapter": "1.2.2",
27
27
  "@parse/push-adapter": "4.1.3",
28
28
  "bcryptjs": "2.4.3",
@@ -34,8 +34,8 @@
34
34
  "follow-redirects": "1.15.2",
35
35
  "graphql": "16.6.0",
36
36
  "graphql-list-fields": "2.0.2",
37
- "graphql-tag": "2.12.6",
38
37
  "graphql-relay": "0.10.0",
38
+ "graphql-tag": "2.12.6",
39
39
  "intersect": "1.0.1",
40
40
  "jsonwebtoken": "9.0.0",
41
41
  "jwks-rsa": "2.1.4",
@@ -50,7 +50,7 @@
50
50
  "pg-promise": "10.12.0",
51
51
  "pluralize": "8.0.0",
52
52
  "redis": "3.1.2",
53
- "semver": "7.5.1",
53
+ "semver": "7.5.2",
54
54
  "subscriptions-transport-ws": "0.11.0",
55
55
  "tv4": "1.3.0",
56
56
  "uuid": "9.0.0",