parse-server 6.0.0-alpha.9 → 6.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (192) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +57 -33
  4. package/lib/AccountLockout.js +11 -26
  5. package/lib/Adapters/AdapterLoader.js +8 -14
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
  7. package/lib/Adapters/Auth/AuthAdapter.js +7 -16
  8. package/lib/Adapters/Auth/OAuth1Client.js +32 -57
  9. package/lib/Adapters/Auth/apple.js +6 -22
  10. package/lib/Adapters/Auth/facebook.js +7 -37
  11. package/lib/Adapters/Auth/gcenter.js +8 -37
  12. package/lib/Adapters/Auth/github.js +7 -10
  13. package/lib/Adapters/Auth/google.js +11 -34
  14. package/lib/Adapters/Auth/gpgames.js +5 -8
  15. package/lib/Adapters/Auth/httpsRequest.js +1 -7
  16. package/lib/Adapters/Auth/index.js +20 -65
  17. package/lib/Adapters/Auth/instagram.js +5 -9
  18. package/lib/Adapters/Auth/janraincapture.js +8 -12
  19. package/lib/Adapters/Auth/janrainengage.js +7 -11
  20. package/lib/Adapters/Auth/keycloak.js +5 -19
  21. package/lib/Adapters/Auth/ldap.js +1 -15
  22. package/lib/Adapters/Auth/line.js +7 -10
  23. package/lib/Adapters/Auth/linkedin.js +7 -12
  24. package/lib/Adapters/Auth/meetup.js +7 -10
  25. package/lib/Adapters/Auth/microsoft.js +7 -10
  26. package/lib/Adapters/Auth/oauth2.js +6 -18
  27. package/lib/Adapters/Auth/phantauth.js +8 -10
  28. package/lib/Adapters/Auth/qq.js +7 -13
  29. package/lib/Adapters/Auth/spotify.js +7 -14
  30. package/lib/Adapters/Auth/twitter.js +5 -15
  31. package/lib/Adapters/Auth/vkontakte.js +9 -15
  32. package/lib/Adapters/Auth/wechat.js +7 -10
  33. package/lib/Adapters/Auth/weibo.js +7 -11
  34. package/lib/Adapters/Cache/CacheAdapter.js +4 -12
  35. package/lib/Adapters/Cache/InMemoryCache.js +5 -19
  36. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
  37. package/lib/Adapters/Cache/LRUCache.js +1 -11
  38. package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
  39. package/lib/Adapters/Cache/RedisCacheAdapter.js +3 -30
  40. package/lib/Adapters/Cache/SchemaCache.js +1 -6
  41. package/lib/Adapters/Email/MailAdapter.js +2 -7
  42. package/lib/Adapters/Files/FilesAdapter.js +7 -21
  43. package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
  44. package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
  45. package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
  46. package/lib/Adapters/Logger/WinstonLogger.js +3 -30
  47. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
  48. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
  49. package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
  50. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
  51. package/lib/Adapters/PubSub/RedisPubSub.js +12 -7
  52. package/lib/Adapters/Push/PushAdapter.js +2 -8
  53. package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
  54. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
  55. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
  56. package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
  57. package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
  58. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
  59. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
  60. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
  61. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  62. package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
  63. package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
  64. package/lib/Auth.js +68 -121
  65. package/lib/ClientSDK.js +3 -11
  66. package/lib/Config.js +73 -115
  67. package/lib/Controllers/AdaptableController.js +6 -18
  68. package/lib/Controllers/AnalyticsController.js +1 -9
  69. package/lib/Controllers/CacheController.js +3 -23
  70. package/lib/Controllers/DatabaseController.js +171 -364
  71. package/lib/Controllers/FilesController.js +5 -34
  72. package/lib/Controllers/HooksController.js +1 -51
  73. package/lib/Controllers/LiveQueryController.js +4 -23
  74. package/lib/Controllers/LoggerController.js +15 -54
  75. package/lib/Controllers/ParseGraphQLController.js +49 -104
  76. package/lib/Controllers/PushController.js +20 -59
  77. package/lib/Controllers/SchemaController.js +162 -348
  78. package/lib/Controllers/UserController.js +17 -78
  79. package/lib/Controllers/index.js +19 -68
  80. package/lib/Controllers/types.js +1 -1
  81. package/lib/Deprecator/Deprecations.js +1 -1
  82. package/lib/Deprecator/Deprecator.js +9 -18
  83. package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
  84. package/lib/GraphQL/ParseGraphQLServer.js +2 -29
  85. package/lib/GraphQL/helpers/objectsMutations.js +2 -12
  86. package/lib/GraphQL/helpers/objectsQueries.js +18 -76
  87. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
  88. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
  89. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
  90. package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
  91. package/lib/GraphQL/loaders/filesMutations.js +2 -19
  92. package/lib/GraphQL/loaders/functionsMutations.js +6 -17
  93. package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
  94. package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
  95. package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
  96. package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
  97. package/lib/GraphQL/loaders/schemaMutations.js +1 -20
  98. package/lib/GraphQL/loaders/schemaQueries.js +1 -14
  99. package/lib/GraphQL/loaders/schemaTypes.js +2 -6
  100. package/lib/GraphQL/loaders/usersMutations.js +6 -28
  101. package/lib/GraphQL/loaders/usersQueries.js +4 -26
  102. package/lib/GraphQL/parseGraphQLUtils.js +6 -19
  103. package/lib/GraphQL/transformers/className.js +1 -4
  104. package/lib/GraphQL/transformers/constraintType.js +1 -20
  105. package/lib/GraphQL/transformers/inputType.js +1 -20
  106. package/lib/GraphQL/transformers/mutation.js +6 -51
  107. package/lib/GraphQL/transformers/outputType.js +1 -20
  108. package/lib/GraphQL/transformers/query.js +6 -42
  109. package/lib/GraphQL/transformers/schemaFields.js +7 -34
  110. package/lib/KeyPromiseQueue.js +1 -12
  111. package/lib/LiveQuery/Client.js +1 -25
  112. package/lib/LiveQuery/Id.js +1 -7
  113. package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
  114. package/lib/LiveQuery/ParseLiveQueryServer.js +111 -307
  115. package/lib/LiveQuery/ParsePubSub.js +1 -12
  116. package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
  117. package/lib/LiveQuery/QueryTools.js +14 -116
  118. package/lib/LiveQuery/RequestSchema.js +1 -1
  119. package/lib/LiveQuery/SessionTokenCache.js +1 -17
  120. package/lib/LiveQuery/Subscription.js +4 -18
  121. package/lib/LiveQuery/equalObjects.js +2 -14
  122. package/lib/Options/Definitions.js +88 -8
  123. package/lib/Options/docs.js +25 -3
  124. package/lib/Options/index.js +4 -12
  125. package/lib/Options/parsers.js +1 -18
  126. package/lib/Page.js +1 -9
  127. package/lib/ParseMessageQueue.js +1 -10
  128. package/lib/ParseServer.js +175 -207
  129. package/lib/ParseServerRESTController.js +6 -33
  130. package/lib/PromiseRouter.js +16 -50
  131. package/lib/Push/PushQueue.js +3 -15
  132. package/lib/Push/PushWorker.js +7 -32
  133. package/lib/Push/utils.js +9 -38
  134. package/lib/RestQuery.js +105 -242
  135. package/lib/RestWrite.js +224 -389
  136. package/lib/Routers/AggregateRouter.js +14 -51
  137. package/lib/Routers/AnalyticsRouter.js +2 -8
  138. package/lib/Routers/AudiencesRouter.js +1 -15
  139. package/lib/Routers/ClassesRouter.js +3 -53
  140. package/lib/Routers/CloudCodeRouter.js +1 -19
  141. package/lib/Routers/FeaturesRouter.js +1 -10
  142. package/lib/Routers/FilesRouter.js +29 -76
  143. package/lib/Routers/FunctionsRouter.js +5 -28
  144. package/lib/Routers/GlobalConfigRouter.js +4 -18
  145. package/lib/Routers/GraphQLRouter.js +1 -14
  146. package/lib/Routers/HooksRouter.js +1 -29
  147. package/lib/Routers/IAPValidationRouter.js +6 -29
  148. package/lib/Routers/InstallationsRouter.js +2 -12
  149. package/lib/Routers/LogsRouter.js +4 -16
  150. package/lib/Routers/PagesRouter.js +69 -129
  151. package/lib/Routers/PublicAPIRouter.js +3 -62
  152. package/lib/Routers/PurgeRouter.js +1 -15
  153. package/lib/Routers/PushRouter.js +2 -18
  154. package/lib/Routers/RolesRouter.js +1 -7
  155. package/lib/Routers/SchemasRouter.js +4 -34
  156. package/lib/Routers/SecurityRouter.js +1 -12
  157. package/lib/Routers/SessionsRouter.js +3 -19
  158. package/lib/Routers/UsersRouter.js +48 -135
  159. package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
  160. package/lib/SchemaMigrations/Migrations.js +2 -8
  161. package/lib/Security/Check.js +8 -16
  162. package/lib/Security/CheckGroup.js +4 -11
  163. package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
  164. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
  165. package/lib/Security/CheckGroups/CheckGroups.js +1 -4
  166. package/lib/Security/CheckRunner.js +22 -41
  167. package/lib/StatusHandler.js +12 -69
  168. package/lib/TestUtils.js +1 -6
  169. package/lib/Utils.js +27 -66
  170. package/lib/batch.js +17 -28
  171. package/lib/cache.js +1 -3
  172. package/lib/cli/definitions/parse-live-query-server.js +1 -3
  173. package/lib/cli/definitions/parse-server.js +1 -3
  174. package/lib/cli/parse-live-query-server.js +1 -6
  175. package/lib/cli/parse-server.js +11 -21
  176. package/lib/cli/utils/commander.js +13 -51
  177. package/lib/cli/utils/runner.js +1 -14
  178. package/lib/cloud-code/Parse.Cloud.js +71 -81
  179. package/lib/cryptoUtils.js +11 -19
  180. package/lib/defaults.js +2 -14
  181. package/lib/deprecated.js +1 -2
  182. package/lib/index.js +16 -34
  183. package/lib/logger.js +6 -13
  184. package/lib/middlewares.js +166 -148
  185. package/lib/password.js +6 -10
  186. package/lib/request.js +8 -42
  187. package/lib/requiredParameter.js +1 -3
  188. package/lib/rest.js +25 -47
  189. package/lib/triggers.js +54 -252
  190. package/lib/vendor/mongodbUrl.js +129 -310
  191. package/package.json +13 -10
  192. package/PATENTS +0 -37
package/lib/password.js CHANGED
@@ -3,36 +3,32 @@
3
3
  // Tools for encrypting and decrypting passwords.
4
4
  // Basically promise-friendly wrappers for bcrypt.
5
5
  var bcrypt = require('bcryptjs');
6
-
7
6
  try {
8
7
  const _bcrypt = require('@node-rs/bcrypt');
9
-
10
8
  bcrypt = {
11
9
  hash: _bcrypt.hash,
12
10
  compare: _bcrypt.verify
13
11
  };
14
12
  } catch (e) {
15
13
  /* */
16
- } // Returns a promise for a hashed password string.
17
-
14
+ }
18
15
 
16
+ // Returns a promise for a hashed password string.
19
17
  function hash(password) {
20
18
  return bcrypt.hash(password, 10);
21
- } // Returns a promise for whether this password compares to equal this
22
- // hashed password.
23
-
19
+ }
24
20
 
21
+ // Returns a promise for whether this password compares to equal this
22
+ // hashed password.
25
23
  function compare(password, hashedPassword) {
26
24
  // Cannot bcrypt compare when one is undefined
27
25
  if (!password || !hashedPassword) {
28
26
  return Promise.resolve(false);
29
27
  }
30
-
31
28
  return bcrypt.compare(password, hashedPassword);
32
29
  }
33
-
34
30
  module.exports = {
35
31
  hash: hash,
36
32
  compare: compare
37
33
  };
38
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wYXNzd29yZC5qcyJdLCJuYW1lcyI6WyJiY3J5cHQiLCJyZXF1aXJlIiwiX2JjcnlwdCIsImhhc2giLCJjb21wYXJlIiwidmVyaWZ5IiwiZSIsInBhc3N3b3JkIiwiaGFzaGVkUGFzc3dvcmQiLCJQcm9taXNlIiwicmVzb2x2ZSIsIm1vZHVsZSIsImV4cG9ydHMiXSwibWFwcGluZ3MiOiI7O0FBQUE7QUFDQTtBQUNBLElBQUlBLE1BQU0sR0FBR0MsT0FBTyxDQUFDLFVBQUQsQ0FBcEI7O0FBRUEsSUFBSTtBQUNGLFFBQU1DLE9BQU8sR0FBR0QsT0FBTyxDQUFDLGlCQUFELENBQXZCOztBQUNBRCxFQUFBQSxNQUFNLEdBQUc7QUFDUEcsSUFBQUEsSUFBSSxFQUFFRCxPQUFPLENBQUNDLElBRFA7QUFFUEMsSUFBQUEsT0FBTyxFQUFFRixPQUFPLENBQUNHO0FBRlYsR0FBVDtBQUlELENBTkQsQ0FNRSxPQUFPQyxDQUFQLEVBQVU7QUFDVjtBQUNELEMsQ0FFRDs7O0FBQ0EsU0FBU0gsSUFBVCxDQUFjSSxRQUFkLEVBQXdCO0FBQ3RCLFNBQU9QLE1BQU0sQ0FBQ0csSUFBUCxDQUFZSSxRQUFaLEVBQXNCLEVBQXRCLENBQVA7QUFDRCxDLENBRUQ7QUFDQTs7O0FBQ0EsU0FBU0gsT0FBVCxDQUFpQkcsUUFBakIsRUFBMkJDLGNBQTNCLEVBQTJDO0FBQ3pDO0FBQ0EsTUFBSSxDQUFDRCxRQUFELElBQWEsQ0FBQ0MsY0FBbEIsRUFBa0M7QUFDaEMsV0FBT0MsT0FBTyxDQUFDQyxPQUFSLENBQWdCLEtBQWhCLENBQVA7QUFDRDs7QUFDRCxTQUFPVixNQUFNLENBQUNJLE9BQVAsQ0FBZUcsUUFBZixFQUF5QkMsY0FBekIsQ0FBUDtBQUNEOztBQUVERyxNQUFNLENBQUNDLE9BQVAsR0FBaUI7QUFDZlQsRUFBQUEsSUFBSSxFQUFFQSxJQURTO0FBRWZDLEVBQUFBLE9BQU8sRUFBRUE7QUFGTSxDQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIi8vIFRvb2xzIGZvciBlbmNyeXB0aW5nIGFuZCBkZWNyeXB0aW5nIHBhc3N3b3Jkcy5cbi8vIEJhc2ljYWxseSBwcm9taXNlLWZyaWVuZGx5IHdyYXBwZXJzIGZvciBiY3J5cHQuXG52YXIgYmNyeXB0ID0gcmVxdWlyZSgnYmNyeXB0anMnKTtcblxudHJ5IHtcbiAgY29uc3QgX2JjcnlwdCA9IHJlcXVpcmUoJ0Bub2RlLXJzL2JjcnlwdCcpO1xuICBiY3J5cHQgPSB7XG4gICAgaGFzaDogX2JjcnlwdC5oYXNoLFxuICAgIGNvbXBhcmU6IF9iY3J5cHQudmVyaWZ5LFxuICB9O1xufSBjYXRjaCAoZSkge1xuICAvKiAqL1xufVxuXG4vLyBSZXR1cm5zIGEgcHJvbWlzZSBmb3IgYSBoYXNoZWQgcGFzc3dvcmQgc3RyaW5nLlxuZnVuY3Rpb24gaGFzaChwYXNzd29yZCkge1xuICByZXR1cm4gYmNyeXB0Lmhhc2gocGFzc3dvcmQsIDEwKTtcbn1cblxuLy8gUmV0dXJucyBhIHByb21pc2UgZm9yIHdoZXRoZXIgdGhpcyBwYXNzd29yZCBjb21wYXJlcyB0byBlcXVhbCB0aGlzXG4vLyBoYXNoZWQgcGFzc3dvcmQuXG5mdW5jdGlvbiBjb21wYXJlKHBhc3N3b3JkLCBoYXNoZWRQYXNzd29yZCkge1xuICAvLyBDYW5ub3QgYmNyeXB0IGNvbXBhcmUgd2hlbiBvbmUgaXMgdW5kZWZpbmVkXG4gIGlmICghcGFzc3dvcmQgfHwgIWhhc2hlZFBhc3N3b3JkKSB7XG4gICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShmYWxzZSk7XG4gIH1cbiAgcmV0dXJuIGJjcnlwdC5jb21wYXJlKHBhc3N3b3JkLCBoYXNoZWRQYXNzd29yZCk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICBoYXNoOiBoYXNoLFxuICBjb21wYXJlOiBjb21wYXJlLFxufTtcbiJdfQ==
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJiY3J5cHQiLCJyZXF1aXJlIiwiX2JjcnlwdCIsImhhc2giLCJjb21wYXJlIiwidmVyaWZ5IiwiZSIsInBhc3N3b3JkIiwiaGFzaGVkUGFzc3dvcmQiLCJQcm9taXNlIiwicmVzb2x2ZSIsIm1vZHVsZSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi9zcmMvcGFzc3dvcmQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gVG9vbHMgZm9yIGVuY3J5cHRpbmcgYW5kIGRlY3J5cHRpbmcgcGFzc3dvcmRzLlxuLy8gQmFzaWNhbGx5IHByb21pc2UtZnJpZW5kbHkgd3JhcHBlcnMgZm9yIGJjcnlwdC5cbnZhciBiY3J5cHQgPSByZXF1aXJlKCdiY3J5cHRqcycpO1xuXG50cnkge1xuICBjb25zdCBfYmNyeXB0ID0gcmVxdWlyZSgnQG5vZGUtcnMvYmNyeXB0Jyk7XG4gIGJjcnlwdCA9IHtcbiAgICBoYXNoOiBfYmNyeXB0Lmhhc2gsXG4gICAgY29tcGFyZTogX2JjcnlwdC52ZXJpZnksXG4gIH07XG59IGNhdGNoIChlKSB7XG4gIC8qICovXG59XG5cbi8vIFJldHVybnMgYSBwcm9taXNlIGZvciBhIGhhc2hlZCBwYXNzd29yZCBzdHJpbmcuXG5mdW5jdGlvbiBoYXNoKHBhc3N3b3JkKSB7XG4gIHJldHVybiBiY3J5cHQuaGFzaChwYXNzd29yZCwgMTApO1xufVxuXG4vLyBSZXR1cm5zIGEgcHJvbWlzZSBmb3Igd2hldGhlciB0aGlzIHBhc3N3b3JkIGNvbXBhcmVzIHRvIGVxdWFsIHRoaXNcbi8vIGhhc2hlZCBwYXNzd29yZC5cbmZ1bmN0aW9uIGNvbXBhcmUocGFzc3dvcmQsIGhhc2hlZFBhc3N3b3JkKSB7XG4gIC8vIENhbm5vdCBiY3J5cHQgY29tcGFyZSB3aGVuIG9uZSBpcyB1bmRlZmluZWRcbiAgaWYgKCFwYXNzd29yZCB8fCAhaGFzaGVkUGFzc3dvcmQpIHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGZhbHNlKTtcbiAgfVxuICByZXR1cm4gYmNyeXB0LmNvbXBhcmUocGFzc3dvcmQsIGhhc2hlZFBhc3N3b3JkKTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gIGhhc2g6IGhhc2gsXG4gIGNvbXBhcmU6IGNvbXBhcmUsXG59O1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBO0FBQ0E7QUFDQSxJQUFJQSxNQUFNLEdBQUdDLE9BQU8sQ0FBQyxVQUFVLENBQUM7QUFFaEMsSUFBSTtFQUNGLE1BQU1DLE9BQU8sR0FBR0QsT0FBTyxDQUFDLGlCQUFpQixDQUFDO0VBQzFDRCxNQUFNLEdBQUc7SUFDUEcsSUFBSSxFQUFFRCxPQUFPLENBQUNDLElBQUk7SUFDbEJDLE9BQU8sRUFBRUYsT0FBTyxDQUFDRztFQUNuQixDQUFDO0FBQ0gsQ0FBQyxDQUFDLE9BQU9DLENBQUMsRUFBRTtFQUNWO0FBQUE7O0FBR0Y7QUFDQSxTQUFTSCxJQUFJLENBQUNJLFFBQVEsRUFBRTtFQUN0QixPQUFPUCxNQUFNLENBQUNHLElBQUksQ0FBQ0ksUUFBUSxFQUFFLEVBQUUsQ0FBQztBQUNsQzs7QUFFQTtBQUNBO0FBQ0EsU0FBU0gsT0FBTyxDQUFDRyxRQUFRLEVBQUVDLGNBQWMsRUFBRTtFQUN6QztFQUNBLElBQUksQ0FBQ0QsUUFBUSxJQUFJLENBQUNDLGNBQWMsRUFBRTtJQUNoQyxPQUFPQyxPQUFPLENBQUNDLE9BQU8sQ0FBQyxLQUFLLENBQUM7RUFDL0I7RUFDQSxPQUFPVixNQUFNLENBQUNJLE9BQU8sQ0FBQ0csUUFBUSxFQUFFQyxjQUFjLENBQUM7QUFDakQ7QUFFQUcsTUFBTSxDQUFDQyxPQUFPLEdBQUc7RUFDZlQsSUFBSSxFQUFFQSxJQUFJO0VBQ1ZDLE9BQU8sRUFBRUE7QUFDWCxDQUFDIn0=
package/lib/request.js CHANGED
@@ -1,23 +1,16 @@
1
1
  "use strict";
2
2
 
3
3
  var _querystring = _interopRequireDefault(require("querystring"));
4
-
5
4
  var _logger = _interopRequireDefault(require("./logger"));
6
-
7
5
  var _followRedirects = require("follow-redirects");
8
-
9
6
  var _url = require("url");
10
-
11
7
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
-
13
8
  class HTTPResponse {
14
9
  constructor(response, body) {
15
10
  let _text, _data;
16
-
17
11
  this.status = response.statusCode;
18
12
  this.headers = response.headers || {};
19
13
  this.cookies = this.headers['set-cookie'];
20
-
21
14
  if (typeof body == 'string') {
22
15
  _text = body;
23
16
  } else if (Buffer.isBuffer(body)) {
@@ -25,17 +18,14 @@ class HTTPResponse {
25
18
  } else if (typeof body == 'object') {
26
19
  _data = body;
27
20
  }
28
-
29
21
  const getText = () => {
30
22
  if (!_text && this.buffer) {
31
23
  _text = this.buffer.toString('utf-8');
32
24
  } else if (!_text && _data) {
33
25
  _text = JSON.stringify(_data);
34
26
  }
35
-
36
27
  return _text;
37
28
  };
38
-
39
29
  const getData = () => {
40
30
  if (!_data) {
41
31
  try {
@@ -44,10 +34,8 @@ class HTTPResponse {
44
34
  /* */
45
35
  }
46
36
  }
47
-
48
37
  return _data;
49
38
  };
50
-
51
39
  Object.defineProperty(this, 'body', {
52
40
  get: () => {
53
41
  return body;
@@ -62,14 +50,11 @@ class HTTPResponse {
62
50
  get: getData
63
51
  });
64
52
  }
65
-
66
53
  }
67
-
68
54
  const clients = {
69
55
  'http:': _followRedirects.http,
70
56
  'https:': _followRedirects.https
71
57
  };
72
-
73
58
  function makeCallback(resolve, reject) {
74
59
  return function (response) {
75
60
  const chunks = [];
@@ -78,8 +63,9 @@ function makeCallback(resolve, reject) {
78
63
  });
79
64
  response.on('end', () => {
80
65
  const body = Buffer.concat(chunks);
81
- const httpResponse = new HTTPResponse(response, body); // Consider <200 && >= 400 as errors
66
+ const httpResponse = new HTTPResponse(response, body);
82
67
 
68
+ // Consider <200 && >= 400 as errors
83
69
  if (httpResponse.status < 200 || httpResponse.status >= 400) {
84
70
  return reject(httpResponse);
85
71
  } else {
@@ -89,7 +75,6 @@ function makeCallback(resolve, reject) {
89
75
  response.on('error', reject);
90
76
  };
91
77
  }
92
-
93
78
  const encodeBody = function ({
94
79
  body,
95
80
  headers = {}
@@ -100,61 +85,51 @@ const encodeBody = function ({
100
85
  headers
101
86
  };
102
87
  }
103
-
104
88
  var contentTypeKeys = Object.keys(headers).filter(key => {
105
89
  return key.match(/content-type/i) != null;
106
90
  });
107
-
108
91
  if (contentTypeKeys.length == 0) {
109
92
  // no content type
110
93
  // As per https://parse.com/docs/cloudcode/guide#cloud-code-advanced-sending-a-post-request the default encoding is supposedly x-www-form-urlencoded
94
+
111
95
  body = _querystring.default.stringify(body);
112
96
  headers['Content-Type'] = 'application/x-www-form-urlencoded';
113
97
  } else {
114
98
  /* istanbul ignore next */
115
99
  if (contentTypeKeys.length > 1) {
116
100
  _logger.default.error('Parse.Cloud.httpRequest', 'multiple content-type headers are set.');
117
- } // There maybe many, we'll just take the 1st one
118
-
119
-
101
+ }
102
+ // There maybe many, we'll just take the 1st one
120
103
  var contentType = contentTypeKeys[0];
121
-
122
104
  if (headers[contentType].match(/application\/json/i)) {
123
105
  body = JSON.stringify(body);
124
106
  } else if (headers[contentType].match(/application\/x-www-form-urlencoded/i)) {
125
107
  body = _querystring.default.stringify(body);
126
108
  }
127
109
  }
128
-
129
110
  return {
130
111
  body,
131
112
  headers
132
113
  };
133
114
  };
134
-
135
115
  function httpRequest(options) {
136
116
  let url;
137
-
138
117
  try {
139
118
  url = (0, _url.parse)(options.url);
140
119
  } catch (e) {
141
120
  return Promise.reject(e);
142
121
  }
143
-
144
- options = Object.assign(options, encodeBody(options)); // support params options
145
-
122
+ options = Object.assign(options, encodeBody(options));
123
+ // support params options
146
124
  if (typeof options.params === 'object') {
147
125
  options.qs = options.params;
148
126
  } else if (typeof options.params === 'string') {
149
127
  options.qs = _querystring.default.parse(options.params);
150
128
  }
151
-
152
129
  const client = clients[url.protocol];
153
-
154
130
  if (!client) {
155
131
  return Promise.reject(`Unsupported protocol ${url.protocol}`);
156
132
  }
157
-
158
133
  const requestOptions = {
159
134
  method: options.method,
160
135
  port: Number(url.port),
@@ -164,7 +139,6 @@ function httpRequest(options) {
164
139
  encoding: null,
165
140
  followRedirects: options.followRedirects === true
166
141
  };
167
-
168
142
  if (requestOptions.headers) {
169
143
  Object.keys(requestOptions.headers).forEach(key => {
170
144
  if (typeof requestOptions.headers[key] === 'undefined') {
@@ -172,38 +146,30 @@ function httpRequest(options) {
172
146
  }
173
147
  });
174
148
  }
175
-
176
149
  if (url.search) {
177
150
  options.qs = Object.assign({}, options.qs, _querystring.default.parse(url.query));
178
151
  }
179
-
180
152
  if (url.auth) {
181
153
  requestOptions.auth = url.auth;
182
154
  }
183
-
184
155
  if (options.qs) {
185
156
  requestOptions.path += `?${_querystring.default.stringify(options.qs)}`;
186
157
  }
187
-
188
158
  if (options.agent) {
189
159
  requestOptions.agent = options.agent;
190
160
  }
191
-
192
161
  return new Promise((resolve, reject) => {
193
162
  const req = client.request(requestOptions, makeCallback(resolve, reject, options));
194
-
195
163
  if (options.body) {
196
164
  req.write(options.body);
197
165
  }
198
-
199
166
  req.on('error', error => {
200
167
  reject(error);
201
168
  });
202
169
  req.end();
203
170
  });
204
171
  }
205
-
206
172
  module.exports = httpRequest;
207
173
  module.exports.encodeBody = encodeBody;
208
174
  module.exports.HTTPResponse = HTTPResponse;
209
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/request.js"],"names":["HTTPResponse","constructor","response","body","_text","_data","status","statusCode","headers","cookies","Buffer","isBuffer","buffer","getText","toString","JSON","stringify","getData","parse","e","Object","defineProperty","get","enumerable","clients","http","https","makeCallback","resolve","reject","chunks","on","chunk","push","concat","httpResponse","encodeBody","contentTypeKeys","keys","filter","key","match","length","querystring","log","error","contentType","httpRequest","options","url","Promise","assign","params","qs","client","protocol","requestOptions","method","port","Number","path","pathname","hostname","encoding","followRedirects","forEach","search","query","auth","agent","req","request","write","end","module","exports"],"mappings":"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","sourcesContent":["import querystring from 'querystring';\nimport log from './logger';\nimport { http, https } from 'follow-redirects';\nimport { parse } from 'url';\n\nclass HTTPResponse {\n  constructor(response, body) {\n    let _text, _data;\n    this.status = response.statusCode;\n    this.headers = response.headers || {};\n    this.cookies = this.headers['set-cookie'];\n\n    if (typeof body == 'string') {\n      _text = body;\n    } else if (Buffer.isBuffer(body)) {\n      this.buffer = body;\n    } else if (typeof body == 'object') {\n      _data = body;\n    }\n\n    const getText = () => {\n      if (!_text && this.buffer) {\n        _text = this.buffer.toString('utf-8');\n      } else if (!_text && _data) {\n        _text = JSON.stringify(_data);\n      }\n      return _text;\n    };\n\n    const getData = () => {\n      if (!_data) {\n        try {\n          _data = JSON.parse(getText());\n        } catch (e) {\n          /* */\n        }\n      }\n      return _data;\n    };\n\n    Object.defineProperty(this, 'body', {\n      get: () => {\n        return body;\n      },\n    });\n\n    Object.defineProperty(this, 'text', {\n      enumerable: true,\n      get: getText,\n    });\n\n    Object.defineProperty(this, 'data', {\n      enumerable: true,\n      get: getData,\n    });\n  }\n}\n\nconst clients = {\n  'http:': http,\n  'https:': https,\n};\n\nfunction makeCallback(resolve, reject) {\n  return function (response) {\n    const chunks = [];\n    response.on('data', chunk => {\n      chunks.push(chunk);\n    });\n    response.on('end', () => {\n      const body = Buffer.concat(chunks);\n      const httpResponse = new HTTPResponse(response, body);\n\n      // Consider <200 && >= 400 as errors\n      if (httpResponse.status < 200 || httpResponse.status >= 400) {\n        return reject(httpResponse);\n      } else {\n        return resolve(httpResponse);\n      }\n    });\n    response.on('error', reject);\n  };\n}\n\nconst encodeBody = function ({ body, headers = {} }) {\n  if (typeof body !== 'object') {\n    return { body, headers };\n  }\n  var contentTypeKeys = Object.keys(headers).filter(key => {\n    return key.match(/content-type/i) != null;\n  });\n\n  if (contentTypeKeys.length == 0) {\n    // no content type\n    //  As per https://parse.com/docs/cloudcode/guide#cloud-code-advanced-sending-a-post-request the default encoding is supposedly x-www-form-urlencoded\n\n    body = querystring.stringify(body);\n    headers['Content-Type'] = 'application/x-www-form-urlencoded';\n  } else {\n    /* istanbul ignore next */\n    if (contentTypeKeys.length > 1) {\n      log.error('Parse.Cloud.httpRequest', 'multiple content-type headers are set.');\n    }\n    // There maybe many, we'll just take the 1st one\n    var contentType = contentTypeKeys[0];\n    if (headers[contentType].match(/application\\/json/i)) {\n      body = JSON.stringify(body);\n    } else if (headers[contentType].match(/application\\/x-www-form-urlencoded/i)) {\n      body = querystring.stringify(body);\n    }\n  }\n  return { body, headers };\n};\n\nfunction httpRequest(options) {\n  let url;\n  try {\n    url = parse(options.url);\n  } catch (e) {\n    return Promise.reject(e);\n  }\n  options = Object.assign(options, encodeBody(options));\n  // support params options\n  if (typeof options.params === 'object') {\n    options.qs = options.params;\n  } else if (typeof options.params === 'string') {\n    options.qs = querystring.parse(options.params);\n  }\n  const client = clients[url.protocol];\n  if (!client) {\n    return Promise.reject(`Unsupported protocol ${url.protocol}`);\n  }\n  const requestOptions = {\n    method: options.method,\n    port: Number(url.port),\n    path: url.pathname,\n    hostname: url.hostname,\n    headers: options.headers,\n    encoding: null,\n    followRedirects: options.followRedirects === true,\n  };\n  if (requestOptions.headers) {\n    Object.keys(requestOptions.headers).forEach(key => {\n      if (typeof requestOptions.headers[key] === 'undefined') {\n        delete requestOptions.headers[key];\n      }\n    });\n  }\n  if (url.search) {\n    options.qs = Object.assign({}, options.qs, querystring.parse(url.query));\n  }\n  if (url.auth) {\n    requestOptions.auth = url.auth;\n  }\n  if (options.qs) {\n    requestOptions.path += `?${querystring.stringify(options.qs)}`;\n  }\n  if (options.agent) {\n    requestOptions.agent = options.agent;\n  }\n  return new Promise((resolve, reject) => {\n    const req = client.request(requestOptions, makeCallback(resolve, reject, options));\n    if (options.body) {\n      req.write(options.body);\n    }\n    req.on('error', error => {\n      reject(error);\n    });\n    req.end();\n  });\n}\nmodule.exports = httpRequest;\nmodule.exports.encodeBody = encodeBody;\nmodule.exports.HTTPResponse = HTTPResponse;\n"]}
175
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["HTTPResponse","constructor","response","body","_text","_data","status","statusCode","headers","cookies","Buffer","isBuffer","buffer","getText","toString","JSON","stringify","getData","parse","e","Object","defineProperty","get","enumerable","clients","http","https","makeCallback","resolve","reject","chunks","on","chunk","push","concat","httpResponse","encodeBody","contentTypeKeys","keys","filter","key","match","length","querystring","log","error","contentType","httpRequest","options","url","Promise","assign","params","qs","client","protocol","requestOptions","method","port","Number","path","pathname","hostname","encoding","followRedirects","forEach","search","query","auth","agent","req","request","write","end","module","exports"],"sources":["../src/request.js"],"sourcesContent":["import querystring from 'querystring';\nimport log from './logger';\nimport { http, https } from 'follow-redirects';\nimport { parse } from 'url';\n\nclass HTTPResponse {\n  constructor(response, body) {\n    let _text, _data;\n    this.status = response.statusCode;\n    this.headers = response.headers || {};\n    this.cookies = this.headers['set-cookie'];\n\n    if (typeof body == 'string') {\n      _text = body;\n    } else if (Buffer.isBuffer(body)) {\n      this.buffer = body;\n    } else if (typeof body == 'object') {\n      _data = body;\n    }\n\n    const getText = () => {\n      if (!_text && this.buffer) {\n        _text = this.buffer.toString('utf-8');\n      } else if (!_text && _data) {\n        _text = JSON.stringify(_data);\n      }\n      return _text;\n    };\n\n    const getData = () => {\n      if (!_data) {\n        try {\n          _data = JSON.parse(getText());\n        } catch (e) {\n          /* */\n        }\n      }\n      return _data;\n    };\n\n    Object.defineProperty(this, 'body', {\n      get: () => {\n        return body;\n      },\n    });\n\n    Object.defineProperty(this, 'text', {\n      enumerable: true,\n      get: getText,\n    });\n\n    Object.defineProperty(this, 'data', {\n      enumerable: true,\n      get: getData,\n    });\n  }\n}\n\nconst clients = {\n  'http:': http,\n  'https:': https,\n};\n\nfunction makeCallback(resolve, reject) {\n  return function (response) {\n    const chunks = [];\n    response.on('data', chunk => {\n      chunks.push(chunk);\n    });\n    response.on('end', () => {\n      const body = Buffer.concat(chunks);\n      const httpResponse = new HTTPResponse(response, body);\n\n      // Consider <200 && >= 400 as errors\n      if (httpResponse.status < 200 || httpResponse.status >= 400) {\n        return reject(httpResponse);\n      } else {\n        return resolve(httpResponse);\n      }\n    });\n    response.on('error', reject);\n  };\n}\n\nconst encodeBody = function ({ body, headers = {} }) {\n  if (typeof body !== 'object') {\n    return { body, headers };\n  }\n  var contentTypeKeys = Object.keys(headers).filter(key => {\n    return key.match(/content-type/i) != null;\n  });\n\n  if (contentTypeKeys.length == 0) {\n    // no content type\n    //  As per https://parse.com/docs/cloudcode/guide#cloud-code-advanced-sending-a-post-request the default encoding is supposedly x-www-form-urlencoded\n\n    body = querystring.stringify(body);\n    headers['Content-Type'] = 'application/x-www-form-urlencoded';\n  } else {\n    /* istanbul ignore next */\n    if (contentTypeKeys.length > 1) {\n      log.error('Parse.Cloud.httpRequest', 'multiple content-type headers are set.');\n    }\n    // There maybe many, we'll just take the 1st one\n    var contentType = contentTypeKeys[0];\n    if (headers[contentType].match(/application\\/json/i)) {\n      body = JSON.stringify(body);\n    } else if (headers[contentType].match(/application\\/x-www-form-urlencoded/i)) {\n      body = querystring.stringify(body);\n    }\n  }\n  return { body, headers };\n};\n\nfunction httpRequest(options) {\n  let url;\n  try {\n    url = parse(options.url);\n  } catch (e) {\n    return Promise.reject(e);\n  }\n  options = Object.assign(options, encodeBody(options));\n  // support params options\n  if (typeof options.params === 'object') {\n    options.qs = options.params;\n  } else if (typeof options.params === 'string') {\n    options.qs = querystring.parse(options.params);\n  }\n  const client = clients[url.protocol];\n  if (!client) {\n    return Promise.reject(`Unsupported protocol ${url.protocol}`);\n  }\n  const requestOptions = {\n    method: options.method,\n    port: Number(url.port),\n    path: url.pathname,\n    hostname: url.hostname,\n    headers: options.headers,\n    encoding: null,\n    followRedirects: options.followRedirects === true,\n  };\n  if (requestOptions.headers) {\n    Object.keys(requestOptions.headers).forEach(key => {\n      if (typeof requestOptions.headers[key] === 'undefined') {\n        delete requestOptions.headers[key];\n      }\n    });\n  }\n  if (url.search) {\n    options.qs = Object.assign({}, options.qs, querystring.parse(url.query));\n  }\n  if (url.auth) {\n    requestOptions.auth = url.auth;\n  }\n  if (options.qs) {\n    requestOptions.path += `?${querystring.stringify(options.qs)}`;\n  }\n  if (options.agent) {\n    requestOptions.agent = options.agent;\n  }\n  return new Promise((resolve, reject) => {\n    const req = client.request(requestOptions, makeCallback(resolve, reject, options));\n    if (options.body) {\n      req.write(options.body);\n    }\n    req.on('error', error => {\n      reject(error);\n    });\n    req.end();\n  });\n}\nmodule.exports = httpRequest;\nmodule.exports.encodeBody = encodeBody;\nmodule.exports.HTTPResponse = HTTPResponse;\n"],"mappings":"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"}
@@ -4,10 +4,8 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
-
8
7
  var _default = errorMessage => {
9
8
  throw errorMessage;
10
9
  };
11
-
12
10
  exports.default = _default;
13
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXF1aXJlZFBhcmFtZXRlci5qcyJdLCJuYW1lcyI6WyJlcnJvck1lc3NhZ2UiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7ZUFDZ0JBLFlBQUQsSUFBK0I7QUFDNUMsUUFBTUEsWUFBTjtBQUNELEMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGZsb3cgKi9cbmV4cG9ydCBkZWZhdWx0IChlcnJvck1lc3NhZ2U6IHN0cmluZyk6IGFueSA9PiB7XG4gIHRocm93IGVycm9yTWVzc2FnZTtcbn07XG4iXX0=
11
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJlcnJvck1lc3NhZ2UiXSwic291cmNlcyI6WyIuLi9zcmMvcmVxdWlyZWRQYXJhbWV0ZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBmbG93ICovXG5leHBvcnQgZGVmYXVsdCAoZXJyb3JNZXNzYWdlOiBzdHJpbmcpOiBhbnkgPT4ge1xuICB0aHJvdyBlcnJvck1lc3NhZ2U7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7ZUFDZ0JBLFlBQW9CLElBQVU7RUFDNUMsTUFBTUEsWUFBWTtBQUNwQixDQUFDO0FBQUEifQ==
package/lib/rest.js CHANGED
@@ -8,25 +8,21 @@
8
8
  // This means that one of these handlers can support multiple
9
9
  // routes. That's useful for the routes that do really similar
10
10
  // things.
11
- var Parse = require('parse/node').Parse;
12
11
 
12
+ var Parse = require('parse/node').Parse;
13
13
  var RestQuery = require('./RestQuery');
14
-
15
14
  var RestWrite = require('./RestWrite');
16
-
17
15
  var triggers = require('./triggers');
18
-
19
16
  function checkTriggers(className, config, types) {
20
17
  return types.some(triggerType => {
21
18
  return triggers.getTrigger(className, triggers.Types[triggerType], config.applicationId);
22
19
  });
23
20
  }
24
-
25
21
  function checkLiveQuery(className, config) {
26
22
  return config.liveQueryController && config.liveQueryController.hasLiveQuery(className);
27
- } // Returns a promise for an object with optional keys 'results' and 'count'.
28
-
23
+ }
29
24
 
25
+ // Returns a promise for an object with optional keys 'results' and 'count'.
30
26
  function find(config, auth, className, restWhere, restOptions, clientSDK, context) {
31
27
  enforceRoleSecurity('find', className, auth);
32
28
  return triggers.maybeRunQueryTrigger(triggers.Types.beforeFind, className, restWhere, restOptions, config, auth, context).then(result => {
@@ -35,9 +31,9 @@ function find(config, auth, className, restWhere, restOptions, clientSDK, contex
35
31
  const query = new RestQuery(config, auth, className, restWhere, restOptions, clientSDK, true, context);
36
32
  return query.execute();
37
33
  });
38
- } // get is just like find but only queries an objectId.
39
-
34
+ }
40
35
 
36
+ // get is just like find but only queries an objectId.
41
37
  const get = (config, auth, className, objectId, restOptions, clientSDK, context) => {
42
38
  var restWhere = {
43
39
  objectId
@@ -49,25 +45,22 @@ const get = (config, auth, className, objectId, restOptions, clientSDK, context)
49
45
  const query = new RestQuery(config, auth, className, restWhere, restOptions, clientSDK, true, context);
50
46
  return query.execute();
51
47
  });
52
- }; // Returns a promise that doesn't resolve to any useful value.
53
-
48
+ };
54
49
 
50
+ // Returns a promise that doesn't resolve to any useful value.
55
51
  function del(config, auth, className, objectId, context) {
56
52
  if (typeof objectId !== 'string') {
57
53
  throw new Parse.Error(Parse.Error.INVALID_JSON, 'bad objectId');
58
54
  }
59
-
60
55
  if (className === '_User' && auth.isUnauthenticated()) {
61
56
  throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth to delete user');
62
57
  }
63
-
64
58
  enforceRoleSecurity('delete', className, auth);
65
59
  let inflatedObject;
66
60
  let schemaController;
67
61
  return Promise.resolve().then(() => {
68
62
  const hasTriggers = checkTriggers(className, config, ['beforeDelete', 'afterDelete']);
69
63
  const hasLiveQuery = checkLiveQuery(className, config);
70
-
71
64
  if (hasTriggers || hasLiveQuery || className == '_Session') {
72
65
  return new RestQuery(config, auth, className, {
73
66
  objectId
@@ -77,26 +70,22 @@ function del(config, auth, className, objectId, context) {
77
70
  if (response && response.results && response.results.length) {
78
71
  const firstResult = response.results[0];
79
72
  firstResult.className = className;
80
-
81
- if (className === '_Session' && !auth.isMaster) {
73
+ if (className === '_Session' && !auth.isMaster && !auth.isMaintenance) {
82
74
  if (!auth.user || firstResult.user.objectId !== auth.user.id) {
83
75
  throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Invalid session token');
84
76
  }
85
77
  }
86
-
87
78
  var cacheAdapter = config.cacheController;
88
79
  cacheAdapter.user.del(firstResult.sessionToken);
89
80
  inflatedObject = Parse.Object.fromJSON(firstResult);
90
81
  return triggers.maybeRunTrigger(triggers.Types.beforeDelete, auth, inflatedObject, null, config, context);
91
82
  }
92
-
93
83
  throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'Object not found for delete.');
94
84
  });
95
85
  }
96
-
97
86
  return Promise.resolve({});
98
87
  }).then(() => {
99
- if (!auth.isMaster) {
88
+ if (!auth.isMaster && !auth.isMaintenance) {
100
89
  return auth.getUserRoles();
101
90
  } else {
102
91
  return;
@@ -104,16 +93,13 @@ function del(config, auth, className, objectId, context) {
104
93
  }).then(() => config.database.loadSchema()).then(s => {
105
94
  schemaController = s;
106
95
  const options = {};
107
-
108
- if (!auth.isMaster) {
96
+ if (!auth.isMaster && !auth.isMaintenance) {
109
97
  options.acl = ['*'];
110
-
111
98
  if (auth.user) {
112
99
  options.acl.push(auth.user.id);
113
100
  options.acl = options.acl.concat(auth.userRoles);
114
101
  }
115
102
  }
116
-
117
103
  return config.database.destroy(className, {
118
104
  objectId: objectId
119
105
  }, options, schemaController);
@@ -125,79 +111,71 @@ function del(config, auth, className, objectId, context) {
125
111
  }).catch(error => {
126
112
  handleSessionMissingError(error, className, auth);
127
113
  });
128
- } // Returns a promise for a {response, status, location} object.
129
-
114
+ }
130
115
 
116
+ // Returns a promise for a {response, status, location} object.
131
117
  function create(config, auth, className, restObject, clientSDK, context) {
132
118
  enforceRoleSecurity('create', className, auth);
133
119
  var write = new RestWrite(config, auth, className, null, restObject, null, clientSDK, context);
134
120
  return write.execute();
135
- } // Returns a promise that contains the fields of the update that the
121
+ }
122
+
123
+ // Returns a promise that contains the fields of the update that the
136
124
  // REST API is supposed to return.
137
125
  // Usually, this is just updatedAt.
138
-
139
-
140
126
  function update(config, auth, className, restWhere, restObject, clientSDK, context) {
141
127
  enforceRoleSecurity('update', className, auth);
142
128
  return Promise.resolve().then(() => {
143
129
  const hasTriggers = checkTriggers(className, config, ['beforeSave', 'afterSave']);
144
130
  const hasLiveQuery = checkLiveQuery(className, config);
145
-
146
131
  if (hasTriggers || hasLiveQuery) {
147
132
  // Do not use find, as it runs the before finds
148
133
  return new RestQuery(config, auth, className, restWhere, undefined, undefined, false, context).execute({
149
134
  op: 'update'
150
135
  });
151
136
  }
152
-
153
137
  return Promise.resolve({});
154
138
  }).then(({
155
139
  results
156
140
  }) => {
157
141
  var originalRestObject;
158
-
159
142
  if (results && results.length) {
160
143
  originalRestObject = results[0];
161
144
  }
162
-
163
145
  return new RestWrite(config, auth, className, restWhere, restObject, originalRestObject, clientSDK, context, 'update').execute();
164
146
  }).catch(error => {
165
147
  handleSessionMissingError(error, className, auth);
166
148
  });
167
149
  }
168
-
169
150
  function handleSessionMissingError(error, className, auth) {
170
151
  // If we're trying to update a user without / with bad session token
171
- if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster) {
152
+ if (className === '_User' && error.code === Parse.Error.OBJECT_NOT_FOUND && !auth.isMaster && !auth.isMaintenance) {
172
153
  throw new Parse.Error(Parse.Error.SESSION_MISSING, 'Insufficient auth.');
173
154
  }
174
-
175
155
  throw error;
176
156
  }
177
-
178
- const classesWithMasterOnlyAccess = ['_JobStatus', '_PushStatus', '_Hooks', '_GlobalConfig', '_JobSchedule', '_Idempotency']; // Disallowing access to the _Role collection except by master key
179
-
157
+ const classesWithMasterOnlyAccess = ['_JobStatus', '_PushStatus', '_Hooks', '_GlobalConfig', '_JobSchedule', '_Idempotency'];
158
+ // Disallowing access to the _Role collection except by master key
180
159
  function enforceRoleSecurity(method, className, auth) {
181
- if (className === '_Installation' && !auth.isMaster) {
160
+ if (className === '_Installation' && !auth.isMaster && !auth.isMaintenance) {
182
161
  if (method === 'delete' || method === 'find') {
183
162
  const error = `Clients aren't allowed to perform the ${method} operation on the installation collection.`;
184
163
  throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
185
164
  }
186
- } //all volatileClasses are masterKey only
187
-
165
+ }
188
166
 
189
- if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster) {
167
+ //all volatileClasses are masterKey only
168
+ if (classesWithMasterOnlyAccess.indexOf(className) >= 0 && !auth.isMaster && !auth.isMaintenance) {
190
169
  const error = `Clients aren't allowed to perform the ${method} operation on the ${className} collection.`;
191
170
  throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
192
- } // readOnly masterKey is not allowed
193
-
171
+ }
194
172
 
173
+ // readOnly masterKey is not allowed
195
174
  if (auth.isReadOnly && (method === 'delete' || method === 'create' || method === 'update')) {
196
175
  const error = `read-only masterKey isn't allowed to perform the ${method} operation.`;
197
176
  throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, error);
198
177
  }
199
178
  }
200
-
201
179
  module.exports = {
202
180
  create,
203
181
  del,
@@ -205,4 +183,4 @@ module.exports = {
205
183
  get,
206
184
  update
207
185
  };
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"]}
186
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"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","isMaintenance","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"],"sources":["../src/rest.js"],"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 && !auth.isMaintenance) {\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 && !auth.isMaintenance) {\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 && !auth.isMaintenance) {\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 (\n    className === '_User' &&\n    error.code === Parse.Error.OBJECT_NOT_FOUND &&\n    !auth.isMaster &&\n    !auth.isMaintenance\n  ) {\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 && !auth.isMaintenance) {\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 (\n    classesWithMasterOnlyAccess.indexOf(className) >= 0 &&\n    !auth.isMaster &&\n    !auth.isMaintenance\n  ) {\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"],"mappings":"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"}