parse-server 2.8.4 → 8.6.2

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 (240) hide show
  1. package/LICENSE +167 -25
  2. package/NOTICE +10 -0
  3. package/README.md +929 -278
  4. package/lib/AccountLockout.js +47 -30
  5. package/lib/Adapters/AdapterLoader.js +21 -6
  6. package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
  7. package/lib/Adapters/Auth/AuthAdapter.js +116 -13
  8. package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
  9. package/lib/Adapters/Auth/OAuth1Client.js +27 -46
  10. package/lib/Adapters/Auth/apple.js +123 -0
  11. package/lib/Adapters/Auth/facebook.js +162 -35
  12. package/lib/Adapters/Auth/gcenter.js +217 -0
  13. package/lib/Adapters/Auth/github.js +118 -48
  14. package/lib/Adapters/Auth/google.js +160 -51
  15. package/lib/Adapters/Auth/gpgames.js +125 -0
  16. package/lib/Adapters/Auth/httpsRequest.js +6 -7
  17. package/lib/Adapters/Auth/index.js +170 -62
  18. package/lib/Adapters/Auth/instagram.js +114 -40
  19. package/lib/Adapters/Auth/janraincapture.js +52 -23
  20. package/lib/Adapters/Auth/janrainengage.js +19 -36
  21. package/lib/Adapters/Auth/keycloak.js +148 -0
  22. package/lib/Adapters/Auth/ldap.js +167 -0
  23. package/lib/Adapters/Auth/line.js +125 -0
  24. package/lib/Adapters/Auth/linkedin.js +111 -55
  25. package/lib/Adapters/Auth/meetup.js +24 -34
  26. package/lib/Adapters/Auth/mfa.js +324 -0
  27. package/lib/Adapters/Auth/microsoft.js +111 -0
  28. package/lib/Adapters/Auth/oauth2.js +97 -162
  29. package/lib/Adapters/Auth/phantauth.js +53 -0
  30. package/lib/Adapters/Auth/qq.js +108 -49
  31. package/lib/Adapters/Auth/spotify.js +107 -55
  32. package/lib/Adapters/Auth/twitter.js +188 -48
  33. package/lib/Adapters/Auth/utils.js +28 -0
  34. package/lib/Adapters/Auth/vkontakte.js +26 -39
  35. package/lib/Adapters/Auth/wechat.js +106 -44
  36. package/lib/Adapters/Auth/weibo.js +132 -58
  37. package/lib/Adapters/Cache/CacheAdapter.js +13 -8
  38. package/lib/Adapters/Cache/InMemoryCache.js +3 -13
  39. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
  40. package/lib/Adapters/Cache/LRUCache.js +13 -27
  41. package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
  42. package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
  43. package/lib/Adapters/Cache/SchemaCache.js +25 -0
  44. package/lib/Adapters/Email/MailAdapter.js +10 -8
  45. package/lib/Adapters/Files/FilesAdapter.js +83 -25
  46. package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
  47. package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
  48. package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
  49. package/lib/Adapters/Logger/WinstonLogger.js +69 -88
  50. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
  51. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
  52. package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
  53. package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
  54. package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
  55. package/lib/Adapters/Push/PushAdapter.js +14 -7
  56. package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
  57. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
  58. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
  59. package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
  60. package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
  61. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
  62. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
  63. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
  64. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  65. package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
  66. package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
  67. package/lib/Auth.js +488 -125
  68. package/lib/ClientSDK.js +2 -6
  69. package/lib/Config.js +525 -94
  70. package/lib/Controllers/AdaptableController.js +5 -25
  71. package/lib/Controllers/AnalyticsController.js +22 -23
  72. package/lib/Controllers/CacheController.js +10 -31
  73. package/lib/Controllers/DatabaseController.js +767 -313
  74. package/lib/Controllers/FilesController.js +49 -54
  75. package/lib/Controllers/HooksController.js +80 -84
  76. package/lib/Controllers/LiveQueryController.js +35 -22
  77. package/lib/Controllers/LoggerController.js +22 -58
  78. package/lib/Controllers/ParseGraphQLController.js +293 -0
  79. package/lib/Controllers/PushController.js +58 -49
  80. package/lib/Controllers/SchemaController.js +916 -422
  81. package/lib/Controllers/UserController.js +265 -180
  82. package/lib/Controllers/index.js +90 -125
  83. package/lib/Controllers/types.js +1 -1
  84. package/lib/Deprecator/Deprecations.js +30 -0
  85. package/lib/Deprecator/Deprecator.js +127 -0
  86. package/lib/Error.js +48 -0
  87. package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
  88. package/lib/GraphQL/ParseGraphQLServer.js +214 -0
  89. package/lib/GraphQL/helpers/objectsMutations.js +30 -0
  90. package/lib/GraphQL/helpers/objectsQueries.js +246 -0
  91. package/lib/GraphQL/loaders/configMutations.js +87 -0
  92. package/lib/GraphQL/loaders/configQueries.js +79 -0
  93. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
  94. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
  95. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
  96. package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
  97. package/lib/GraphQL/loaders/filesMutations.js +107 -0
  98. package/lib/GraphQL/loaders/functionsMutations.js +78 -0
  99. package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
  100. package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
  101. package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
  102. package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
  103. package/lib/GraphQL/loaders/schemaMutations.js +162 -0
  104. package/lib/GraphQL/loaders/schemaQueries.js +81 -0
  105. package/lib/GraphQL/loaders/schemaTypes.js +341 -0
  106. package/lib/GraphQL/loaders/usersMutations.js +433 -0
  107. package/lib/GraphQL/loaders/usersQueries.js +90 -0
  108. package/lib/GraphQL/parseGraphQLUtils.js +63 -0
  109. package/lib/GraphQL/transformers/className.js +14 -0
  110. package/lib/GraphQL/transformers/constraintType.js +53 -0
  111. package/lib/GraphQL/transformers/inputType.js +51 -0
  112. package/lib/GraphQL/transformers/mutation.js +274 -0
  113. package/lib/GraphQL/transformers/outputType.js +51 -0
  114. package/lib/GraphQL/transformers/query.js +237 -0
  115. package/lib/GraphQL/transformers/schemaFields.js +99 -0
  116. package/lib/KeyPromiseQueue.js +48 -0
  117. package/lib/LiveQuery/Client.js +25 -33
  118. package/lib/LiveQuery/Id.js +2 -5
  119. package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
  120. package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
  121. package/lib/LiveQuery/ParsePubSub.js +7 -16
  122. package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
  123. package/lib/LiveQuery/QueryTools.js +76 -15
  124. package/lib/LiveQuery/RequestSchema.js +111 -97
  125. package/lib/LiveQuery/SessionTokenCache.js +23 -36
  126. package/lib/LiveQuery/Subscription.js +8 -17
  127. package/lib/LiveQuery/equalObjects.js +2 -3
  128. package/lib/Options/Definitions.js +1355 -382
  129. package/lib/Options/docs.js +301 -62
  130. package/lib/Options/index.js +11 -1
  131. package/lib/Options/parsers.js +14 -10
  132. package/lib/Page.js +44 -0
  133. package/lib/ParseMessageQueue.js +6 -13
  134. package/lib/ParseServer.js +474 -235
  135. package/lib/ParseServerRESTController.js +102 -40
  136. package/lib/PromiseRouter.js +39 -50
  137. package/lib/Push/PushQueue.js +24 -30
  138. package/lib/Push/PushWorker.js +32 -56
  139. package/lib/Push/utils.js +22 -35
  140. package/lib/RestQuery.js +361 -139
  141. package/lib/RestWrite.js +713 -344
  142. package/lib/Routers/AggregateRouter.js +97 -71
  143. package/lib/Routers/AnalyticsRouter.js +8 -14
  144. package/lib/Routers/AudiencesRouter.js +16 -35
  145. package/lib/Routers/ClassesRouter.js +86 -72
  146. package/lib/Routers/CloudCodeRouter.js +28 -37
  147. package/lib/Routers/FeaturesRouter.js +22 -25
  148. package/lib/Routers/FilesRouter.js +266 -171
  149. package/lib/Routers/FunctionsRouter.js +87 -103
  150. package/lib/Routers/GlobalConfigRouter.js +94 -33
  151. package/lib/Routers/GraphQLRouter.js +41 -0
  152. package/lib/Routers/HooksRouter.js +43 -47
  153. package/lib/Routers/IAPValidationRouter.js +57 -70
  154. package/lib/Routers/InstallationsRouter.js +17 -25
  155. package/lib/Routers/LogsRouter.js +10 -25
  156. package/lib/Routers/PagesRouter.js +647 -0
  157. package/lib/Routers/PublicAPIRouter.js +104 -112
  158. package/lib/Routers/PurgeRouter.js +19 -29
  159. package/lib/Routers/PushRouter.js +14 -28
  160. package/lib/Routers/RolesRouter.js +7 -14
  161. package/lib/Routers/SchemasRouter.js +63 -42
  162. package/lib/Routers/SecurityRouter.js +34 -0
  163. package/lib/Routers/SessionsRouter.js +25 -38
  164. package/lib/Routers/UsersRouter.js +463 -190
  165. package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
  166. package/lib/SchemaMigrations/Migrations.js +30 -0
  167. package/lib/Security/Check.js +109 -0
  168. package/lib/Security/CheckGroup.js +44 -0
  169. package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
  170. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
  171. package/lib/Security/CheckGroups/CheckGroups.js +21 -0
  172. package/lib/Security/CheckRunner.js +213 -0
  173. package/lib/SharedRest.js +29 -0
  174. package/lib/StatusHandler.js +96 -93
  175. package/lib/TestUtils.js +70 -14
  176. package/lib/Utils.js +468 -0
  177. package/lib/batch.js +74 -40
  178. package/lib/cache.js +8 -8
  179. package/lib/cli/definitions/parse-live-query-server.js +4 -3
  180. package/lib/cli/definitions/parse-server.js +4 -3
  181. package/lib/cli/parse-live-query-server.js +9 -17
  182. package/lib/cli/parse-server.js +49 -47
  183. package/lib/cli/utils/commander.js +20 -29
  184. package/lib/cli/utils/runner.js +31 -32
  185. package/lib/cloud-code/Parse.Cloud.js +711 -36
  186. package/lib/cloud-code/Parse.Server.js +21 -0
  187. package/lib/cryptoUtils.js +6 -11
  188. package/lib/defaults.js +21 -15
  189. package/lib/deprecated.js +1 -1
  190. package/lib/index.js +78 -67
  191. package/lib/logger.js +12 -20
  192. package/lib/middlewares.js +484 -160
  193. package/lib/password.js +10 -6
  194. package/lib/request.js +175 -0
  195. package/lib/requiredParameter.js +4 -3
  196. package/lib/rest.js +157 -82
  197. package/lib/triggers.js +627 -185
  198. package/lib/vendor/README.md +3 -3
  199. package/lib/vendor/mongodbUrl.js +224 -137
  200. package/package.json +135 -57
  201. package/postinstall.js +38 -50
  202. package/public_html/invalid_verification_link.html +3 -3
  203. package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
  204. package/types/@types/deepcopy/index.d.ts +5 -0
  205. package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
  206. package/types/Options/index.d.ts +301 -0
  207. package/types/ParseServer.d.ts +65 -0
  208. package/types/eslint.config.mjs +30 -0
  209. package/types/index.d.ts +21 -0
  210. package/types/logger.d.ts +2 -0
  211. package/types/tests.ts +44 -0
  212. package/types/tsconfig.json +24 -0
  213. package/CHANGELOG.md +0 -1246
  214. package/PATENTS +0 -37
  215. package/bin/dev +0 -37
  216. package/lib/.DS_Store +0 -0
  217. package/lib/Adapters/Auth/common.js +0 -2
  218. package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
  219. package/lib/Controllers/SchemaCache.js +0 -97
  220. package/lib/LiveQuery/.DS_Store +0 -0
  221. package/lib/cli/utils/parsers.js +0 -77
  222. package/lib/cloud-code/.DS_Store +0 -0
  223. package/lib/cloud-code/HTTPResponse.js +0 -57
  224. package/lib/cloud-code/Untitled-1 +0 -123
  225. package/lib/cloud-code/httpRequest.js +0 -102
  226. package/lib/cloud-code/team.html +0 -123
  227. package/lib/graphql/ParseClass.js +0 -234
  228. package/lib/graphql/Schema.js +0 -197
  229. package/lib/graphql/index.js +0 -1
  230. package/lib/graphql/types/ACL.js +0 -35
  231. package/lib/graphql/types/Date.js +0 -25
  232. package/lib/graphql/types/File.js +0 -24
  233. package/lib/graphql/types/GeoPoint.js +0 -35
  234. package/lib/graphql/types/JSONObject.js +0 -30
  235. package/lib/graphql/types/NumberInput.js +0 -43
  236. package/lib/graphql/types/NumberQuery.js +0 -42
  237. package/lib/graphql/types/Pointer.js +0 -35
  238. package/lib/graphql/types/QueryConstraint.js +0 -61
  239. package/lib/graphql/types/StringQuery.js +0 -39
  240. package/lib/graphql/types/index.js +0 -110
@@ -3,44 +3,32 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.PushRouter = undefined;
7
-
8
- var _PromiseRouter = require("../PromiseRouter");
9
-
10
- var _PromiseRouter2 = _interopRequireDefault(_PromiseRouter);
11
-
12
- var _middlewares = require("../middlewares");
13
-
14
- var middleware = _interopRequireWildcard(_middlewares);
15
-
6
+ exports.default = exports.PushRouter = void 0;
7
+ var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
8
+ var middleware = _interopRequireWildcard(require("../middlewares"));
16
9
  var _node = require("parse/node");
17
-
18
- function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }
19
-
20
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
-
22
- class PushRouter extends _PromiseRouter2.default {
23
-
10
+ var _Error = require("../Error");
11
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
12
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
+ class PushRouter extends _PromiseRouter.default {
24
14
  mountRoutes() {
25
- this.route("POST", "/push", middleware.promiseEnforceMasterKeyAccess, PushRouter.handlePOST);
15
+ this.route('POST', '/push', middleware.promiseEnforceMasterKeyAccess, PushRouter.handlePOST);
26
16
  }
27
-
28
17
  static handlePOST(req) {
29
18
  if (req.auth.isReadOnly) {
30
- throw new _node.Parse.Error(_node.Parse.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\'t allowed to send push notifications.');
19
+ throw (0, _Error.createSanitizedError)(_node.Parse.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to send push notifications.", req.config);
31
20
  }
32
21
  const pushController = req.config.pushController;
33
22
  if (!pushController) {
34
23
  throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Push controller is not set');
35
24
  }
36
-
37
25
  const where = PushRouter.getQueryCondition(req);
38
26
  let resolve;
39
27
  const promise = new Promise(_resolve => {
40
28
  resolve = _resolve;
41
29
  });
42
30
  let pushStatusId;
43
- pushController.sendPush(req.body, where, req.config, req.auth, objectId => {
31
+ pushController.sendPush(req.body || {}, where, req.config, req.auth, objectId => {
44
32
  pushStatusId = objectId;
45
33
  resolve({
46
34
  headers: {
@@ -65,7 +53,6 @@ class PushRouter extends _PromiseRouter2.default {
65
53
  const body = req.body || {};
66
54
  const hasWhere = typeof body.where !== 'undefined';
67
55
  const hasChannels = typeof body.channels !== 'undefined';
68
-
69
56
  let where;
70
57
  if (hasWhere && hasChannels) {
71
58
  throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Channels and query can not be set at the same time.');
@@ -73,8 +60,8 @@ class PushRouter extends _PromiseRouter2.default {
73
60
  where = body.where;
74
61
  } else if (hasChannels) {
75
62
  where = {
76
- "channels": {
77
- "$in": body.channels
63
+ channels: {
64
+ $in: body.channels
78
65
  }
79
66
  };
80
67
  } else {
@@ -83,7 +70,6 @@ class PushRouter extends _PromiseRouter2.default {
83
70
  return where;
84
71
  }
85
72
  }
86
-
87
73
  exports.PushRouter = PushRouter;
88
- exports.default = PushRouter;
89
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1B1c2hSb3V0ZXIuanMiXSwibmFtZXMiOlsibWlkZGxld2FyZSIsIlB1c2hSb3V0ZXIiLCJQcm9taXNlUm91dGVyIiwibW91bnRSb3V0ZXMiLCJyb3V0ZSIsInByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzIiwiaGFuZGxlUE9TVCIsInJlcSIsImF1dGgiLCJpc1JlYWRPbmx5IiwiUGFyc2UiLCJFcnJvciIsIk9QRVJBVElPTl9GT1JCSURERU4iLCJwdXNoQ29udHJvbGxlciIsImNvbmZpZyIsIlBVU0hfTUlTQ09ORklHVVJFRCIsIndoZXJlIiwiZ2V0UXVlcnlDb25kaXRpb24iLCJyZXNvbHZlIiwicHJvbWlzZSIsIlByb21pc2UiLCJfcmVzb2x2ZSIsInB1c2hTdGF0dXNJZCIsInNlbmRQdXNoIiwiYm9keSIsIm9iamVjdElkIiwiaGVhZGVycyIsInJlc3BvbnNlIiwicmVzdWx0IiwiY2F0Y2giLCJlcnIiLCJsb2dnZXJDb250cm9sbGVyIiwiZXJyb3IiLCJoYXNXaGVyZSIsImhhc0NoYW5uZWxzIiwiY2hhbm5lbHMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7OztBQUNBOztJQUFZQSxVOztBQUNaOzs7Ozs7QUFFTyxNQUFNQyxVQUFOLFNBQXlCQyx1QkFBekIsQ0FBdUM7O0FBRTVDQyxnQkFBYztBQUNaLFNBQUtDLEtBQUwsQ0FBVyxNQUFYLEVBQW1CLE9BQW5CLEVBQTRCSixXQUFXSyw2QkFBdkMsRUFBc0VKLFdBQVdLLFVBQWpGO0FBQ0Q7O0FBRUQsU0FBT0EsVUFBUCxDQUFrQkMsR0FBbEIsRUFBdUI7QUFDckIsUUFBSUEsSUFBSUMsSUFBSixDQUFTQyxVQUFiLEVBQXlCO0FBQ3ZCLFlBQU0sSUFBSUMsWUFBTUMsS0FBVixDQUFnQkQsWUFBTUMsS0FBTixDQUFZQyxtQkFBNUIsRUFBaUQsZ0VBQWpELENBQU47QUFDRDtBQUNELFVBQU1DLGlCQUFpQk4sSUFBSU8sTUFBSixDQUFXRCxjQUFsQztBQUNBLFFBQUksQ0FBQ0EsY0FBTCxFQUFxQjtBQUNuQixZQUFNLElBQUlILFlBQU1DLEtBQVYsQ0FBZ0JELFlBQU1DLEtBQU4sQ0FBWUksa0JBQTVCLEVBQWdELDRCQUFoRCxDQUFOO0FBQ0Q7O0FBRUQsVUFBTUMsUUFBUWYsV0FBV2dCLGlCQUFYLENBQTZCVixHQUE3QixDQUFkO0FBQ0EsUUFBSVcsT0FBSjtBQUNBLFVBQU1DLFVBQVUsSUFBSUMsT0FBSixDQUFhQyxRQUFELElBQWM7QUFDeENILGdCQUFVRyxRQUFWO0FBQ0QsS0FGZSxDQUFoQjtBQUdBLFFBQUlDLFlBQUo7QUFDQVQsbUJBQWVVLFFBQWYsQ0FBd0JoQixJQUFJaUIsSUFBNUIsRUFBa0NSLEtBQWxDLEVBQXlDVCxJQUFJTyxNQUE3QyxFQUFxRFAsSUFBSUMsSUFBekQsRUFBZ0VpQixRQUFELElBQWM7QUFDM0VILHFCQUFlRyxRQUFmO0FBQ0FQLGNBQVE7QUFDTlEsaUJBQVM7QUFDUCxvQ0FBMEJKO0FBRG5CLFNBREg7QUFJTkssa0JBQVU7QUFDUkMsa0JBQVE7QUFEQTtBQUpKLE9BQVI7QUFRRCxLQVZELEVBVUdDLEtBVkgsQ0FVVUMsR0FBRCxJQUFTO0FBQ2hCdkIsVUFBSU8sTUFBSixDQUFXaUIsZ0JBQVgsQ0FBNEJDLEtBQTVCLENBQW1DLGVBQWNWLFlBQWEsNEJBQTlELEVBQTJGUSxHQUEzRjtBQUNELEtBWkQ7QUFhQSxXQUFPWCxPQUFQO0FBQ0Q7O0FBRUQ7Ozs7O0FBS0EsU0FBT0YsaUJBQVAsQ0FBeUJWLEdBQXpCLEVBQThCO0FBQzVCLFVBQU1pQixPQUFPakIsSUFBSWlCLElBQUosSUFBWSxFQUF6QjtBQUNBLFVBQU1TLFdBQVcsT0FBT1QsS0FBS1IsS0FBWixLQUFzQixXQUF2QztBQUNBLFVBQU1rQixjQUFjLE9BQU9WLEtBQUtXLFFBQVosS0FBeUIsV0FBN0M7O0FBRUEsUUFBSW5CLEtBQUo7QUFDQSxRQUFJaUIsWUFBWUMsV0FBaEIsRUFBNkI7QUFDM0IsWUFBTSxJQUFJeEIsWUFBTUMsS0FBVixDQUFnQkQsWUFBTUMsS0FBTixDQUFZSSxrQkFBNUIsRUFDSixxREFESSxDQUFOO0FBRUQsS0FIRCxNQUdPLElBQUlrQixRQUFKLEVBQWM7QUFDbkJqQixjQUFRUSxLQUFLUixLQUFiO0FBQ0QsS0FGTSxNQUVBLElBQUlrQixXQUFKLEVBQWlCO0FBQ3RCbEIsY0FBUTtBQUNOLG9CQUFZO0FBQ1YsaUJBQU9RLEtBQUtXO0FBREY7QUFETixPQUFSO0FBS0QsS0FOTSxNQU1BO0FBQ0wsWUFBTSxJQUFJekIsWUFBTUMsS0FBVixDQUFnQkQsWUFBTUMsS0FBTixDQUFZSSxrQkFBNUIsRUFBZ0QsK0RBQWhELENBQU47QUFDRDtBQUNELFdBQU9DLEtBQVA7QUFDRDtBQS9EMkM7O1FBQWpDZixVLEdBQUFBLFU7a0JBa0VFQSxVIiwiZmlsZSI6IlB1c2hSb3V0ZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvbWlzZVJvdXRlciAgIGZyb20gJy4uL1Byb21pc2VSb3V0ZXInO1xuaW1wb3J0ICogYXMgbWlkZGxld2FyZSBmcm9tIFwiLi4vbWlkZGxld2FyZXNcIjtcbmltcG9ydCB7IFBhcnNlIH0gICAgICAgZnJvbSBcInBhcnNlL25vZGVcIjtcblxuZXhwb3J0IGNsYXNzIFB1c2hSb3V0ZXIgZXh0ZW5kcyBQcm9taXNlUm91dGVyIHtcblxuICBtb3VudFJvdXRlcygpIHtcbiAgICB0aGlzLnJvdXRlKFwiUE9TVFwiLCBcIi9wdXNoXCIsIG1pZGRsZXdhcmUucHJvbWlzZUVuZm9yY2VNYXN0ZXJLZXlBY2Nlc3MsIFB1c2hSb3V0ZXIuaGFuZGxlUE9TVCk7XG4gIH1cblxuICBzdGF0aWMgaGFuZGxlUE9TVChyZXEpIHtcbiAgICBpZiAocmVxLmF1dGguaXNSZWFkT25seSkge1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFBhcnNlLkVycm9yLk9QRVJBVElPTl9GT1JCSURERU4sICdyZWFkLW9ubHkgbWFzdGVyS2V5IGlzblxcJ3QgYWxsb3dlZCB0byBzZW5kIHB1c2ggbm90aWZpY2F0aW9ucy4nKTtcbiAgICB9XG4gICAgY29uc3QgcHVzaENvbnRyb2xsZXIgPSByZXEuY29uZmlnLnB1c2hDb250cm9sbGVyO1xuICAgIGlmICghcHVzaENvbnRyb2xsZXIpIHtcbiAgICAgIHRocm93IG5ldyBQYXJzZS5FcnJvcihQYXJzZS5FcnJvci5QVVNIX01JU0NPTkZJR1VSRUQsICdQdXNoIGNvbnRyb2xsZXIgaXMgbm90IHNldCcpO1xuICAgIH1cblxuICAgIGNvbnN0IHdoZXJlID0gUHVzaFJvdXRlci5nZXRRdWVyeUNvbmRpdGlvbihyZXEpO1xuICAgIGxldCByZXNvbHZlO1xuICAgIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZSgoX3Jlc29sdmUpID0+IHtcbiAgICAgIHJlc29sdmUgPSBfcmVzb2x2ZTtcbiAgICB9KTtcbiAgICBsZXQgcHVzaFN0YXR1c0lkO1xuICAgIHB1c2hDb250cm9sbGVyLnNlbmRQdXNoKHJlcS5ib2R5LCB3aGVyZSwgcmVxLmNvbmZpZywgcmVxLmF1dGgsIChvYmplY3RJZCkgPT4ge1xuICAgICAgcHVzaFN0YXR1c0lkID0gb2JqZWN0SWQ7XG4gICAgICByZXNvbHZlKHtcbiAgICAgICAgaGVhZGVyczoge1xuICAgICAgICAgICdYLVBhcnNlLVB1c2gtU3RhdHVzLUlkJzogcHVzaFN0YXR1c0lkXG4gICAgICAgIH0sXG4gICAgICAgIHJlc3BvbnNlOiB7XG4gICAgICAgICAgcmVzdWx0OiB0cnVlXG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH0pLmNhdGNoKChlcnIpID0+IHtcbiAgICAgIHJlcS5jb25maWcubG9nZ2VyQ29udHJvbGxlci5lcnJvcihgX1B1c2hTdGF0dXMgJHtwdXNoU3RhdHVzSWR9OiBlcnJvciB3aGlsZSBzZW5kaW5nIHB1c2hgLCBlcnIpO1xuICAgIH0pO1xuICAgIHJldHVybiBwcm9taXNlO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBxdWVyeSBjb25kaXRpb24gZnJvbSB0aGUgcmVxdWVzdCBib2R5LlxuICAgKiBAcGFyYW0ge09iamVjdH0gcmVxIEEgcmVxdWVzdCBvYmplY3RcbiAgICogQHJldHVybnMge09iamVjdH0gVGhlIHF1ZXJ5IGNvbmRpdGlvbiwgdGhlIHdoZXJlIGZpZWxkIGluIGEgcXVlcnkgYXBpIGNhbGxcbiAgICovXG4gIHN0YXRpYyBnZXRRdWVyeUNvbmRpdGlvbihyZXEpIHtcbiAgICBjb25zdCBib2R5ID0gcmVxLmJvZHkgfHwge307XG4gICAgY29uc3QgaGFzV2hlcmUgPSB0eXBlb2YgYm9keS53aGVyZSAhPT0gJ3VuZGVmaW5lZCc7XG4gICAgY29uc3QgaGFzQ2hhbm5lbHMgPSB0eXBlb2YgYm9keS5jaGFubmVscyAhPT0gJ3VuZGVmaW5lZCc7XG5cbiAgICBsZXQgd2hlcmU7XG4gICAgaWYgKGhhc1doZXJlICYmIGhhc0NoYW5uZWxzKSB7XG4gICAgICB0aHJvdyBuZXcgUGFyc2UuRXJyb3IoUGFyc2UuRXJyb3IuUFVTSF9NSVNDT05GSUdVUkVELFxuICAgICAgICAnQ2hhbm5lbHMgYW5kIHF1ZXJ5IGNhbiBub3QgYmUgc2V0IGF0IHRoZSBzYW1lIHRpbWUuJyk7XG4gICAgfSBlbHNlIGlmIChoYXNXaGVyZSkge1xuICAgICAgd2hlcmUgPSBib2R5LndoZXJlO1xuICAgIH0gZWxzZSBpZiAoaGFzQ2hhbm5lbHMpIHtcbiAgICAgIHdoZXJlID0ge1xuICAgICAgICBcImNoYW5uZWxzXCI6IHtcbiAgICAgICAgICBcIiRpblwiOiBib2R5LmNoYW5uZWxzXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFBhcnNlLkVycm9yLlBVU0hfTUlTQ09ORklHVVJFRCwgJ1NlbmRpbmcgYSBwdXNoIHJlcXVpcmVzIGVpdGhlciBcImNoYW5uZWxzXCIgb3IgYSBcIndoZXJlXCIgcXVlcnkuJyk7XG4gICAgfVxuICAgIHJldHVybiB3aGVyZTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQdXNoUm91dGVyO1xuIl19
74
+ var _default = exports.default = PushRouter;
75
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","middleware","_interopRequireWildcard","_node","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","PushRouter","PromiseRouter","mountRoutes","route","promiseEnforceMasterKeyAccess","handlePOST","req","auth","isReadOnly","createSanitizedError","Parse","Error","OPERATION_FORBIDDEN","config","pushController","PUSH_MISCONFIGURED","where","getQueryCondition","resolve","promise","Promise","_resolve","pushStatusId","sendPush","body","objectId","headers","response","result","catch","err","loggerController","error","hasWhere","hasChannels","channels","$in","exports","_default"],"sources":["../../src/Routers/PushRouter.js"],"sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport * as middleware from '../middlewares';\nimport { Parse } from 'parse/node';\nimport { createSanitizedError } from '../Error';\n\nexport class PushRouter extends PromiseRouter {\n  mountRoutes() {\n    this.route('POST', '/push', middleware.promiseEnforceMasterKeyAccess, PushRouter.handlePOST);\n  }\n\n  static handlePOST(req) {\n    if (req.auth.isReadOnly) {\n      throw createSanitizedError(\n        Parse.Error.OPERATION_FORBIDDEN,\n        \"read-only masterKey isn't allowed to send push notifications.\",\n        req.config\n      );\n    }\n    const pushController = req.config.pushController;\n    if (!pushController) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Push controller is not set');\n    }\n\n    const where = PushRouter.getQueryCondition(req);\n    let resolve;\n    const promise = new Promise(_resolve => {\n      resolve = _resolve;\n    });\n    let pushStatusId;\n    pushController\n      .sendPush(req.body || {}, where, req.config, req.auth, objectId => {\n        pushStatusId = objectId;\n        resolve({\n          headers: {\n            'X-Parse-Push-Status-Id': pushStatusId,\n          },\n          response: {\n            result: true,\n          },\n        });\n      })\n      .catch(err => {\n        req.config.loggerController.error(\n          `_PushStatus ${pushStatusId}: error while sending push`,\n          err\n        );\n      });\n    return promise;\n  }\n\n  /**\n   * Get query condition from the request body.\n   * @param {Object} req A request object\n   * @returns {Object} The query condition, the where field in a query api call\n   */\n  static getQueryCondition(req) {\n    const body = req.body || {};\n    const hasWhere = typeof body.where !== 'undefined';\n    const hasChannels = typeof body.channels !== 'undefined';\n\n    let where;\n    if (hasWhere && hasChannels) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Channels and query can not be set at the same time.'\n      );\n    } else if (hasWhere) {\n      where = body.where;\n    } else if (hasChannels) {\n      where = {\n        channels: {\n          $in: body.channels,\n        },\n      };\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Sending a push requires either \"channels\" or a \"where\" query.'\n      );\n    }\n    return where;\n  }\n}\n\nexport default PushRouter;\n"],"mappings":"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","ignoreList":[]}
@@ -1,21 +1,15 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.RolesRouter = undefined;
7
-
8
- var _ClassesRouter = require('./ClassesRouter');
9
-
10
- var _ClassesRouter2 = _interopRequireDefault(_ClassesRouter);
11
-
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
-
14
- class RolesRouter extends _ClassesRouter2.default {
6
+ exports.default = exports.RolesRouter = void 0;
7
+ var _ClassesRouter = _interopRequireDefault(require("./ClassesRouter"));
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ class RolesRouter extends _ClassesRouter.default {
15
10
  className() {
16
11
  return '_Role';
17
12
  }
18
-
19
13
  mountRoutes() {
20
14
  this.route('GET', '/roles', req => {
21
15
  return this.handleFind(req);
@@ -34,7 +28,6 @@ class RolesRouter extends _ClassesRouter2.default {
34
28
  });
35
29
  }
36
30
  }
37
-
38
31
  exports.RolesRouter = RolesRouter;
39
- exports.default = RolesRouter;
40
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1JvbGVzUm91dGVyLmpzIl0sIm5hbWVzIjpbIlJvbGVzUm91dGVyIiwiQ2xhc3Nlc1JvdXRlciIsImNsYXNzTmFtZSIsIm1vdW50Um91dGVzIiwicm91dGUiLCJyZXEiLCJoYW5kbGVGaW5kIiwiaGFuZGxlR2V0IiwiaGFuZGxlQ3JlYXRlIiwiaGFuZGxlVXBkYXRlIiwiaGFuZGxlRGVsZXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0E7Ozs7OztBQUVPLE1BQU1BLFdBQU4sU0FBMEJDLHVCQUExQixDQUF3QztBQUM3Q0MsY0FBWTtBQUNWLFdBQU8sT0FBUDtBQUNEOztBQUVEQyxnQkFBYztBQUNaLFNBQUtDLEtBQUwsQ0FBVyxLQUFYLEVBQWlCLFFBQWpCLEVBQTJCQyxPQUFPO0FBQUUsYUFBTyxLQUFLQyxVQUFMLENBQWdCRCxHQUFoQixDQUFQO0FBQThCLEtBQWxFO0FBQ0EsU0FBS0QsS0FBTCxDQUFXLEtBQVgsRUFBaUIsa0JBQWpCLEVBQXFDQyxPQUFPO0FBQUUsYUFBTyxLQUFLRSxTQUFMLENBQWVGLEdBQWYsQ0FBUDtBQUE2QixLQUEzRTtBQUNBLFNBQUtELEtBQUwsQ0FBVyxNQUFYLEVBQWtCLFFBQWxCLEVBQTRCQyxPQUFPO0FBQUUsYUFBTyxLQUFLRyxZQUFMLENBQWtCSCxHQUFsQixDQUFQO0FBQWdDLEtBQXJFO0FBQ0EsU0FBS0QsS0FBTCxDQUFXLEtBQVgsRUFBaUIsa0JBQWpCLEVBQXFDQyxPQUFPO0FBQUUsYUFBTyxLQUFLSSxZQUFMLENBQWtCSixHQUFsQixDQUFQO0FBQWdDLEtBQTlFO0FBQ0EsU0FBS0QsS0FBTCxDQUFXLFFBQVgsRUFBb0Isa0JBQXBCLEVBQXdDQyxPQUFPO0FBQUUsYUFBTyxLQUFLSyxZQUFMLENBQWtCTCxHQUFsQixDQUFQO0FBQWdDLEtBQWpGO0FBQ0Q7QUFYNEM7O1FBQWxDTCxXLEdBQUFBLFc7a0JBY0VBLFciLCJmaWxlIjoiUm9sZXNSb3V0ZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJcbmltcG9ydCBDbGFzc2VzUm91dGVyIGZyb20gJy4vQ2xhc3Nlc1JvdXRlcic7XG5cbmV4cG9ydCBjbGFzcyBSb2xlc1JvdXRlciBleHRlbmRzIENsYXNzZXNSb3V0ZXIge1xuICBjbGFzc05hbWUoKSB7XG4gICAgcmV0dXJuICdfUm9sZSc7XG4gIH1cblxuICBtb3VudFJvdXRlcygpIHtcbiAgICB0aGlzLnJvdXRlKCdHRVQnLCcvcm9sZXMnLCByZXEgPT4geyByZXR1cm4gdGhpcy5oYW5kbGVGaW5kKHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ0dFVCcsJy9yb2xlcy86b2JqZWN0SWQnLCByZXEgPT4geyByZXR1cm4gdGhpcy5oYW5kbGVHZXQocmVxKTsgfSk7XG4gICAgdGhpcy5yb3V0ZSgnUE9TVCcsJy9yb2xlcycsIHJlcSA9PiB7IHJldHVybiB0aGlzLmhhbmRsZUNyZWF0ZShyZXEpOyB9KTtcbiAgICB0aGlzLnJvdXRlKCdQVVQnLCcvcm9sZXMvOm9iamVjdElkJywgcmVxID0+IHsgcmV0dXJuIHRoaXMuaGFuZGxlVXBkYXRlKHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ0RFTEVURScsJy9yb2xlcy86b2JqZWN0SWQnLCByZXEgPT4geyByZXR1cm4gdGhpcy5oYW5kbGVEZWxldGUocmVxKTsgfSk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgUm9sZXNSb3V0ZXI7XG4iXX0=
32
+ var _default = exports.default = RolesRouter;
33
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfQ2xhc3Nlc1JvdXRlciIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiUm9sZXNSb3V0ZXIiLCJDbGFzc2VzUm91dGVyIiwiY2xhc3NOYW1lIiwibW91bnRSb3V0ZXMiLCJyb3V0ZSIsInJlcSIsImhhbmRsZUZpbmQiLCJoYW5kbGVHZXQiLCJoYW5kbGVDcmVhdGUiLCJoYW5kbGVVcGRhdGUiLCJoYW5kbGVEZWxldGUiLCJleHBvcnRzIiwiX2RlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvUm91dGVycy9Sb2xlc1JvdXRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ2xhc3Nlc1JvdXRlciBmcm9tICcuL0NsYXNzZXNSb3V0ZXInO1xuXG5leHBvcnQgY2xhc3MgUm9sZXNSb3V0ZXIgZXh0ZW5kcyBDbGFzc2VzUm91dGVyIHtcbiAgY2xhc3NOYW1lKCkge1xuICAgIHJldHVybiAnX1JvbGUnO1xuICB9XG5cbiAgbW91bnRSb3V0ZXMoKSB7XG4gICAgdGhpcy5yb3V0ZSgnR0VUJywgJy9yb2xlcycsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVGaW5kKHJlcSk7XG4gICAgfSk7XG4gICAgdGhpcy5yb3V0ZSgnR0VUJywgJy9yb2xlcy86b2JqZWN0SWQnLCByZXEgPT4ge1xuICAgICAgcmV0dXJuIHRoaXMuaGFuZGxlR2V0KHJlcSk7XG4gICAgfSk7XG4gICAgdGhpcy5yb3V0ZSgnUE9TVCcsICcvcm9sZXMnLCByZXEgPT4ge1xuICAgICAgcmV0dXJuIHRoaXMuaGFuZGxlQ3JlYXRlKHJlcSk7XG4gICAgfSk7XG4gICAgdGhpcy5yb3V0ZSgnUFVUJywgJy9yb2xlcy86b2JqZWN0SWQnLCByZXEgPT4ge1xuICAgICAgcmV0dXJuIHRoaXMuaGFuZGxlVXBkYXRlKHJlcSk7XG4gICAgfSk7XG4gICAgdGhpcy5yb3V0ZSgnREVMRVRFJywgJy9yb2xlcy86b2JqZWN0SWQnLCByZXEgPT4ge1xuICAgICAgcmV0dXJuIHRoaXMuaGFuZGxlRGVsZXRlKHJlcSk7XG4gICAgfSk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgUm9sZXNSb3V0ZXI7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLGNBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUE0QyxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUVyQyxNQUFNRyxXQUFXLFNBQVNDLHNCQUFhLENBQUM7RUFDN0NDLFNBQVNBLENBQUEsRUFBRztJQUNWLE9BQU8sT0FBTztFQUNoQjtFQUVBQyxXQUFXQSxDQUFBLEVBQUc7SUFDWixJQUFJLENBQUNDLEtBQUssQ0FBQyxLQUFLLEVBQUUsUUFBUSxFQUFFQyxHQUFHLElBQUk7TUFDakMsT0FBTyxJQUFJLENBQUNDLFVBQVUsQ0FBQ0QsR0FBRyxDQUFDO0lBQzdCLENBQUMsQ0FBQztJQUNGLElBQUksQ0FBQ0QsS0FBSyxDQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRUMsR0FBRyxJQUFJO01BQzNDLE9BQU8sSUFBSSxDQUFDRSxTQUFTLENBQUNGLEdBQUcsQ0FBQztJQUM1QixDQUFDLENBQUM7SUFDRixJQUFJLENBQUNELEtBQUssQ0FBQyxNQUFNLEVBQUUsUUFBUSxFQUFFQyxHQUFHLElBQUk7TUFDbEMsT0FBTyxJQUFJLENBQUNHLFlBQVksQ0FBQ0gsR0FBRyxDQUFDO0lBQy9CLENBQUMsQ0FBQztJQUNGLElBQUksQ0FBQ0QsS0FBSyxDQUFDLEtBQUssRUFBRSxrQkFBa0IsRUFBRUMsR0FBRyxJQUFJO01BQzNDLE9BQU8sSUFBSSxDQUFDSSxZQUFZLENBQUNKLEdBQUcsQ0FBQztJQUMvQixDQUFDLENBQUM7SUFDRixJQUFJLENBQUNELEtBQUssQ0FBQyxRQUFRLEVBQUUsa0JBQWtCLEVBQUVDLEdBQUcsSUFBSTtNQUM5QyxPQUFPLElBQUksQ0FBQ0ssWUFBWSxDQUFDTCxHQUFHLENBQUM7SUFDL0IsQ0FBQyxDQUFDO0VBQ0o7QUFDRjtBQUFDTSxPQUFBLENBQUFYLFdBQUEsR0FBQUEsV0FBQTtBQUFBLElBQUFZLFFBQUEsR0FBQUQsT0FBQSxDQUFBWixPQUFBLEdBRWNDLFdBQVciLCJpZ25vcmVMaXN0IjpbXX0=
@@ -1,38 +1,39 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.SchemasRouter = undefined;
7
-
8
- var _PromiseRouter = require('../PromiseRouter');
9
-
10
- var _PromiseRouter2 = _interopRequireDefault(_PromiseRouter);
11
-
12
- var _middlewares = require('../middlewares');
13
-
14
- var middleware = _interopRequireWildcard(_middlewares);
15
-
16
- function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }
17
-
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
6
+ exports.internalUpdateSchema = exports.internalCreateSchema = exports.SchemasRouter = void 0;
7
+ var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
8
+ var middleware = _interopRequireWildcard(require("../middlewares"));
9
+ var _Error = require("../Error");
10
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
11
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
20
12
  // schemas.js
21
13
 
22
14
  var Parse = require('parse/node').Parse,
23
- SchemaController = require('../Controllers/SchemaController');
24
-
15
+ SchemaController = require('../Controllers/SchemaController');
25
16
  function classNameMismatchResponse(bodyClass, pathClass) {
26
17
  throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class name mismatch between ${bodyClass} and ${pathClass}.`);
27
18
  }
28
-
29
19
  function getAllSchemas(req) {
30
- return req.config.database.loadSchema({ clearCache: true }).then(schemaController => schemaController.getAllClasses(true)).then(schemas => ({ response: { results: schemas } }));
20
+ return req.config.database.loadSchema({
21
+ clearCache: true
22
+ }).then(schemaController => schemaController.getAllClasses({
23
+ clearCache: true
24
+ })).then(schemas => ({
25
+ response: {
26
+ results: schemas
27
+ }
28
+ }));
31
29
  }
32
-
33
30
  function getOneSchema(req) {
34
31
  const className = req.params.className;
35
- return req.config.database.loadSchema({ clearCache: true }).then(schemaController => schemaController.getOneSchema(className, true)).then(schema => ({ response: schema })).catch(error => {
32
+ return req.config.database.loadSchema({
33
+ clearCache: true
34
+ }).then(schemaController => schemaController.getOneSchema(className, true)).then(schema => ({
35
+ response: schema
36
+ })).catch(error => {
36
37
  if (error === undefined) {
37
38
  throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class ${className} does not exist.`);
38
39
  } else {
@@ -40,50 +41,70 @@ function getOneSchema(req) {
40
41
  }
41
42
  });
42
43
  }
43
-
44
- function createSchema(req) {
44
+ const checkIfDefinedSchemasIsUsed = req => {
45
+ if (req.config?.schema?.lockSchemas === true) {
46
+ throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'Cannot perform this operation when schemas options is used.');
47
+ }
48
+ };
49
+ const internalCreateSchema = async (className, body, config) => {
50
+ const controller = await config.database.loadSchema({
51
+ clearCache: true
52
+ });
53
+ const response = await controller.addClassIfNotExists(className, body.fields, body.classLevelPermissions, body.indexes);
54
+ return {
55
+ response
56
+ };
57
+ };
58
+ exports.internalCreateSchema = internalCreateSchema;
59
+ const internalUpdateSchema = async (className, body, config) => {
60
+ const controller = await config.database.loadSchema({
61
+ clearCache: true
62
+ });
63
+ const response = await controller.updateClass(className, body.fields || {}, body.classLevelPermissions, body.indexes, config.database);
64
+ return {
65
+ response
66
+ };
67
+ };
68
+ exports.internalUpdateSchema = internalUpdateSchema;
69
+ async function createSchema(req) {
70
+ checkIfDefinedSchemasIsUsed(req);
45
71
  if (req.auth.isReadOnly) {
46
- throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\'t allowed to create a schema.');
72
+ throw (0, _Error.createSanitizedError)(Parse.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to create a schema.", req.config);
47
73
  }
48
- if (req.params.className && req.body.className) {
74
+ if (req.params.className && req.body?.className) {
49
75
  if (req.params.className != req.body.className) {
50
76
  return classNameMismatchResponse(req.body.className, req.params.className);
51
77
  }
52
78
  }
53
-
54
- const className = req.params.className || req.body.className;
79
+ const className = req.params.className || req.body?.className;
55
80
  if (!className) {
56
81
  throw new Parse.Error(135, `POST ${req.path} needs a class name.`);
57
82
  }
58
-
59
- return req.config.database.loadSchema({ clearCache: true }).then(schema => schema.addClassIfNotExists(className, req.body.fields, req.body.classLevelPermissions, req.body.indexes)).then(schema => ({ response: schema }));
83
+ return await internalCreateSchema(className, req.body || {}, req.config);
60
84
  }
61
-
62
85
  function modifySchema(req) {
86
+ checkIfDefinedSchemasIsUsed(req);
63
87
  if (req.auth.isReadOnly) {
64
- throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\'t allowed to update a schema.');
88
+ throw (0, _Error.createSanitizedError)(Parse.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to update a schema.", req.config);
65
89
  }
66
- if (req.body.className && req.body.className != req.params.className) {
90
+ if (req.body?.className && req.body.className != req.params.className) {
67
91
  return classNameMismatchResponse(req.body.className, req.params.className);
68
92
  }
69
-
70
- const submittedFields = req.body.fields || {};
71
93
  const className = req.params.className;
72
-
73
- return req.config.database.loadSchema({ clearCache: true }).then(schema => schema.updateClass(className, submittedFields, req.body.classLevelPermissions, req.body.indexes, req.config.database)).then(result => ({ response: result }));
94
+ return internalUpdateSchema(className, req.body || {}, req.config);
74
95
  }
75
-
76
96
  const deleteSchema = req => {
77
97
  if (req.auth.isReadOnly) {
78
- throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\'t allowed to delete a schema.');
98
+ throw (0, _Error.createSanitizedError)(Parse.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to delete a schema.", req.config);
79
99
  }
80
100
  if (!SchemaController.classNameIsValid(req.params.className)) {
81
101
  throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, SchemaController.invalidClassNameMessage(req.params.className));
82
102
  }
83
- return req.config.database.deleteSchema(req.params.className).then(() => ({ response: {} }));
103
+ return req.config.database.deleteSchema(req.params.className).then(() => ({
104
+ response: {}
105
+ }));
84
106
  };
85
-
86
- class SchemasRouter extends _PromiseRouter2.default {
107
+ class SchemasRouter extends _PromiseRouter.default {
87
108
  mountRoutes() {
88
109
  this.route('GET', '/schemas', middleware.promiseEnforceMasterKeyAccess, getAllSchemas);
89
110
  this.route('GET', '/schemas/:className', middleware.promiseEnforceMasterKeyAccess, getOneSchema);
@@ -94,4 +115,4 @@ class SchemasRouter extends _PromiseRouter2.default {
94
115
  }
95
116
  }
96
117
  exports.SchemasRouter = SchemasRouter;
97
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Routers/SchemasRouter.js"],"names":["middleware","Parse","require","SchemaController","classNameMismatchResponse","bodyClass","pathClass","Error","INVALID_CLASS_NAME","getAllSchemas","req","config","database","loadSchema","clearCache","then","schemaController","getAllClasses","schemas","response","results","getOneSchema","className","params","schema","catch","error","undefined","INTERNAL_SERVER_ERROR","createSchema","auth","isReadOnly","OPERATION_FORBIDDEN","body","path","addClassIfNotExists","fields","classLevelPermissions","indexes","modifySchema","submittedFields","updateClass","result","deleteSchema","classNameIsValid","invalidClassNameMessage","SchemasRouter","PromiseRouter","mountRoutes","route","promiseEnforceMasterKeyAccess"],"mappings":"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","file":"SchemasRouter.js","sourcesContent":["// schemas.js\n\nvar Parse = require('parse/node').Parse,\n  SchemaController = require('../Controllers/SchemaController');\n\nimport PromiseRouter   from '../PromiseRouter';\nimport * as middleware from \"../middlewares\";\n\nfunction classNameMismatchResponse(bodyClass, pathClass) {\n  throw new Parse.Error(\n    Parse.Error.INVALID_CLASS_NAME,\n    `Class name mismatch between ${bodyClass} and ${pathClass}.`\n  );\n}\n\nfunction getAllSchemas(req) {\n  return req.config.database.loadSchema({ clearCache: true})\n    .then(schemaController => schemaController.getAllClasses(true))\n    .then(schemas => ({ response: { results: schemas } }));\n}\n\nfunction getOneSchema(req) {\n  const className = req.params.className;\n  return req.config.database.loadSchema({ clearCache: true})\n    .then(schemaController => schemaController.getOneSchema(className, true))\n    .then(schema => ({ response: schema }))\n    .catch(error => {\n      if (error === undefined) {\n        throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class ${className} does not exist.`);\n      } else {\n        throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Database adapter error.');\n      }\n    });\n}\n\nfunction createSchema(req) {\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\\'t allowed to create a schema.');\n  }\n  if (req.params.className && req.body.className) {\n    if (req.params.className != req.body.className) {\n      return classNameMismatchResponse(req.body.className, req.params.className);\n    }\n  }\n\n  const className = req.params.className || req.body.className;\n  if (!className) {\n    throw new Parse.Error(135, `POST ${req.path} needs a class name.`);\n  }\n\n  return req.config.database.loadSchema({ clearCache: true})\n    .then(schema => schema.addClassIfNotExists(className, req.body.fields, req.body.classLevelPermissions, req.body.indexes))\n    .then(schema => ({ response: schema }));\n}\n\nfunction modifySchema(req) {\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\\'t allowed to update a schema.');\n  }\n  if (req.body.className && req.body.className != req.params.className) {\n    return classNameMismatchResponse(req.body.className, req.params.className);\n  }\n\n  const submittedFields = req.body.fields || {};\n  const className = req.params.className;\n\n  return req.config.database.loadSchema({ clearCache: true})\n    .then(schema => schema.updateClass(className, submittedFields, req.body.classLevelPermissions, req.body.indexes, req.config.database))\n    .then(result => ({response: result}));\n}\n\nconst deleteSchema = req => {\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\\'t allowed to delete a schema.');\n  }\n  if (!SchemaController.classNameIsValid(req.params.className)) {\n    throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, SchemaController.invalidClassNameMessage(req.params.className));\n  }\n  return req.config.database.deleteSchema(req.params.className)\n    .then(() => ({ response: {} }));\n}\n\nexport class SchemasRouter extends PromiseRouter {\n  mountRoutes() {\n    this.route('GET', '/schemas', middleware.promiseEnforceMasterKeyAccess, getAllSchemas);\n    this.route('GET', '/schemas/:className', middleware.promiseEnforceMasterKeyAccess, getOneSchema);\n    this.route('POST', '/schemas', middleware.promiseEnforceMasterKeyAccess, createSchema);\n    this.route('POST', '/schemas/:className', middleware.promiseEnforceMasterKeyAccess, createSchema);\n    this.route('PUT', '/schemas/:className', middleware.promiseEnforceMasterKeyAccess, modifySchema);\n    this.route('DELETE', '/schemas/:className', middleware.promiseEnforceMasterKeyAccess, deleteSchema);\n  }\n}\n"]}
118
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","middleware","_interopRequireWildcard","_Error","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Parse","SchemaController","classNameMismatchResponse","bodyClass","pathClass","Error","INVALID_CLASS_NAME","getAllSchemas","req","config","database","loadSchema","clearCache","then","schemaController","getAllClasses","schemas","response","results","getOneSchema","className","params","schema","catch","error","undefined","INTERNAL_SERVER_ERROR","checkIfDefinedSchemasIsUsed","lockSchemas","OPERATION_FORBIDDEN","internalCreateSchema","body","controller","addClassIfNotExists","fields","classLevelPermissions","indexes","exports","internalUpdateSchema","updateClass","createSchema","auth","isReadOnly","createSanitizedError","path","modifySchema","deleteSchema","classNameIsValid","invalidClassNameMessage","SchemasRouter","PromiseRouter","mountRoutes","route","promiseEnforceMasterKeyAccess"],"sources":["../../src/Routers/SchemasRouter.js"],"sourcesContent":["// schemas.js\n\nvar Parse = require('parse/node').Parse,\n  SchemaController = require('../Controllers/SchemaController');\n\nimport PromiseRouter from '../PromiseRouter';\nimport * as middleware from '../middlewares';\nimport { createSanitizedError } from '../Error';\n\nfunction classNameMismatchResponse(bodyClass, pathClass) {\n  throw new Parse.Error(\n    Parse.Error.INVALID_CLASS_NAME,\n    `Class name mismatch between ${bodyClass} and ${pathClass}.`\n  );\n}\n\nfunction getAllSchemas(req) {\n  return req.config.database\n    .loadSchema({ clearCache: true })\n    .then(schemaController => schemaController.getAllClasses({ clearCache: true }))\n    .then(schemas => ({ response: { results: schemas } }));\n}\n\nfunction getOneSchema(req) {\n  const className = req.params.className;\n  return req.config.database\n    .loadSchema({ clearCache: true })\n    .then(schemaController => schemaController.getOneSchema(className, true))\n    .then(schema => ({ response: schema }))\n    .catch(error => {\n      if (error === undefined) {\n        throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class ${className} does not exist.`);\n      } else {\n        throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Database adapter error.');\n      }\n    });\n}\n\nconst checkIfDefinedSchemasIsUsed = req => {\n  if (req.config?.schema?.lockSchemas === true) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      'Cannot perform this operation when schemas options is used.'\n    );\n  }\n};\n\nexport const internalCreateSchema = async (className, body, config) => {\n  const controller = await config.database.loadSchema({ clearCache: true });\n  const response = await controller.addClassIfNotExists(\n    className,\n    body.fields,\n    body.classLevelPermissions,\n    body.indexes\n  );\n  return {\n    response,\n  };\n};\n\nexport const internalUpdateSchema = async (className, body, config) => {\n  const controller = await config.database.loadSchema({ clearCache: true });\n  const response = await controller.updateClass(\n    className,\n    body.fields || {},\n    body.classLevelPermissions,\n    body.indexes,\n    config.database\n  );\n  return { response };\n};\n\nasync function createSchema(req) {\n  checkIfDefinedSchemasIsUsed(req);\n  if (req.auth.isReadOnly) {\n    throw createSanitizedError(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to create a schema.\",\n      req.config\n    );\n  }\n  if (req.params.className && req.body?.className) {\n    if (req.params.className != req.body.className) {\n      return classNameMismatchResponse(req.body.className, req.params.className);\n    }\n  }\n\n  const className = req.params.className || req.body?.className;\n  if (!className) {\n    throw new Parse.Error(135, `POST ${req.path} needs a class name.`);\n  }\n\n  return await internalCreateSchema(className, req.body || {}, req.config);\n}\n\nfunction modifySchema(req) {\n  checkIfDefinedSchemasIsUsed(req);\n  if (req.auth.isReadOnly) {\n    throw createSanitizedError(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to update a schema.\",\n      req.config\n    );\n  }\n  if (req.body?.className && req.body.className != req.params.className) {\n    return classNameMismatchResponse(req.body.className, req.params.className);\n  }\n  const className = req.params.className;\n\n  return internalUpdateSchema(className, req.body || {}, req.config);\n}\n\nconst deleteSchema = req => {\n  if (req.auth.isReadOnly) {\n    throw createSanitizedError(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to delete a schema.\",\n      req.config\n    );\n  }\n  if (!SchemaController.classNameIsValid(req.params.className)) {\n    throw new Parse.Error(\n      Parse.Error.INVALID_CLASS_NAME,\n      SchemaController.invalidClassNameMessage(req.params.className)\n    );\n  }\n  return req.config.database.deleteSchema(req.params.className).then(() => ({ response: {} }));\n};\n\nexport class SchemasRouter extends PromiseRouter {\n  mountRoutes() {\n    this.route('GET', '/schemas', middleware.promiseEnforceMasterKeyAccess, getAllSchemas);\n    this.route(\n      'GET',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      getOneSchema\n    );\n    this.route('POST', '/schemas', middleware.promiseEnforceMasterKeyAccess, createSchema);\n    this.route(\n      'POST',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      createSchema\n    );\n    this.route(\n      'PUT',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      modifySchema\n    );\n    this.route(\n      'DELETE',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      deleteSchema\n    );\n  }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = exports.SecurityRouter = void 0;
7
+ var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
8
+ var middleware = _interopRequireWildcard(require("../middlewares"));
9
+ var _CheckRunner = _interopRequireDefault(require("../Security/CheckRunner"));
10
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
11
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
+ class SecurityRouter extends _PromiseRouter.default {
13
+ mountRoutes() {
14
+ this.route('GET', '/security', middleware.promiseEnforceMasterKeyAccess, this._enforceSecurityCheckEnabled, async req => {
15
+ const report = await new _CheckRunner.default(req.config.security).run();
16
+ return {
17
+ status: 200,
18
+ response: report
19
+ };
20
+ });
21
+ }
22
+ async _enforceSecurityCheckEnabled(req) {
23
+ const config = req.config;
24
+ if (!config.security || !config.security.enableCheck) {
25
+ const error = new Error();
26
+ error.status = 409;
27
+ error.message = 'Enable Parse Server option `security.enableCheck` to run security check.';
28
+ throw error;
29
+ }
30
+ }
31
+ }
32
+ exports.SecurityRouter = SecurityRouter;
33
+ var _default = exports.default = SecurityRouter;
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfUHJvbWlzZVJvdXRlciIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwibWlkZGxld2FyZSIsIl9pbnRlcm9wUmVxdWlyZVdpbGRjYXJkIiwiX0NoZWNrUnVubmVyIiwiZSIsInQiLCJXZWFrTWFwIiwiciIsIm4iLCJfX2VzTW9kdWxlIiwibyIsImkiLCJmIiwiX19wcm90b19fIiwiZGVmYXVsdCIsImhhcyIsImdldCIsInNldCIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwiU2VjdXJpdHlSb3V0ZXIiLCJQcm9taXNlUm91dGVyIiwibW91bnRSb3V0ZXMiLCJyb3V0ZSIsInByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzIiwiX2VuZm9yY2VTZWN1cml0eUNoZWNrRW5hYmxlZCIsInJlcSIsInJlcG9ydCIsIkNoZWNrUnVubmVyIiwiY29uZmlnIiwic2VjdXJpdHkiLCJydW4iLCJzdGF0dXMiLCJyZXNwb25zZSIsImVuYWJsZUNoZWNrIiwiZXJyb3IiLCJFcnJvciIsIm1lc3NhZ2UiLCJleHBvcnRzIiwiX2RlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvUm91dGVycy9TZWN1cml0eVJvdXRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvbWlzZVJvdXRlciBmcm9tICcuLi9Qcm9taXNlUm91dGVyJztcbmltcG9ydCAqIGFzIG1pZGRsZXdhcmUgZnJvbSAnLi4vbWlkZGxld2FyZXMnO1xuaW1wb3J0IENoZWNrUnVubmVyIGZyb20gJy4uL1NlY3VyaXR5L0NoZWNrUnVubmVyJztcblxuZXhwb3J0IGNsYXNzIFNlY3VyaXR5Um91dGVyIGV4dGVuZHMgUHJvbWlzZVJvdXRlciB7XG4gIG1vdW50Um91dGVzKCkge1xuICAgIHRoaXMucm91dGUoXG4gICAgICAnR0VUJyxcbiAgICAgICcvc2VjdXJpdHknLFxuICAgICAgbWlkZGxld2FyZS5wcm9taXNlRW5mb3JjZU1hc3RlcktleUFjY2VzcyxcbiAgICAgIHRoaXMuX2VuZm9yY2VTZWN1cml0eUNoZWNrRW5hYmxlZCxcbiAgICAgIGFzeW5jIHJlcSA9PiB7XG4gICAgICAgIGNvbnN0IHJlcG9ydCA9IGF3YWl0IG5ldyBDaGVja1J1bm5lcihyZXEuY29uZmlnLnNlY3VyaXR5KS5ydW4oKTtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBzdGF0dXM6IDIwMCxcbiAgICAgICAgICByZXNwb25zZTogcmVwb3J0LFxuICAgICAgICB9O1xuICAgICAgfVxuICAgICk7XG4gIH1cblxuICBhc3luYyBfZW5mb3JjZVNlY3VyaXR5Q2hlY2tFbmFibGVkKHJlcSkge1xuICAgIGNvbnN0IGNvbmZpZyA9IHJlcS5jb25maWc7XG4gICAgaWYgKCFjb25maWcuc2VjdXJpdHkgfHwgIWNvbmZpZy5zZWN1cml0eS5lbmFibGVDaGVjaykge1xuICAgICAgY29uc3QgZXJyb3IgPSBuZXcgRXJyb3IoKTtcbiAgICAgIGVycm9yLnN0YXR1cyA9IDQwOTtcbiAgICAgIGVycm9yLm1lc3NhZ2UgPSAnRW5hYmxlIFBhcnNlIFNlcnZlciBvcHRpb24gYHNlY3VyaXR5LmVuYWJsZUNoZWNrYCB0byBydW4gc2VjdXJpdHkgY2hlY2suJztcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH1cbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBTZWN1cml0eVJvdXRlcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsY0FBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsVUFBQSxHQUFBQyx1QkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUcsWUFBQSxHQUFBSixzQkFBQSxDQUFBQyxPQUFBO0FBQWtELFNBQUFFLHdCQUFBRSxDQUFBLEVBQUFDLENBQUEsNkJBQUFDLE9BQUEsTUFBQUMsQ0FBQSxPQUFBRCxPQUFBLElBQUFFLENBQUEsT0FBQUYsT0FBQSxZQUFBSix1QkFBQSxZQUFBQSxD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
@@ -1,80 +1,68 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.SessionsRouter = undefined;
7
-
8
- var _ClassesRouter = require('./ClassesRouter');
9
-
10
- var _ClassesRouter2 = _interopRequireDefault(_ClassesRouter);
11
-
12
- var _node = require('parse/node');
13
-
14
- var _node2 = _interopRequireDefault(_node);
15
-
16
- var _rest = require('../rest');
17
-
18
- var _rest2 = _interopRequireDefault(_rest);
19
-
20
- var _Auth = require('../Auth');
21
-
22
- var _Auth2 = _interopRequireDefault(_Auth);
23
-
24
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
25
-
26
- class SessionsRouter extends _ClassesRouter2.default {
27
-
6
+ exports.default = exports.SessionsRouter = void 0;
7
+ var _ClassesRouter = _interopRequireDefault(require("./ClassesRouter"));
8
+ var _node = _interopRequireDefault(require("parse/node"));
9
+ var _rest = _interopRequireDefault(require("../rest"));
10
+ var _Auth = _interopRequireDefault(require("../Auth"));
11
+ var _RestWrite = _interopRequireDefault(require("../RestWrite"));
12
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
+ class SessionsRouter extends _ClassesRouter.default {
28
14
  className() {
29
15
  return '_Session';
30
16
  }
31
-
32
17
  handleMe(req) {
33
18
  // TODO: Verify correct behavior
34
19
  if (!req.info || !req.info.sessionToken) {
35
- throw new _node2.default.Error(_node2.default.Error.INVALID_SESSION_TOKEN, 'Session token required.');
20
+ throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token required.');
36
21
  }
37
- return _rest2.default.find(req.config, _Auth2.default.master(req.config), '_Session', { sessionToken: req.info.sessionToken }, undefined, req.info.clientSDK).then(response => {
22
+ return _rest.default.find(req.config, _Auth.default.master(req.config), '_Session', {
23
+ sessionToken: req.info.sessionToken
24
+ }, undefined, req.info.clientSDK, req.info.context).then(response => {
38
25
  if (!response.results || response.results.length == 0) {
39
- throw new _node2.default.Error(_node2.default.Error.INVALID_SESSION_TOKEN, 'Session token not found.');
26
+ throw new _node.default.Error(_node.default.Error.INVALID_SESSION_TOKEN, 'Session token not found.');
40
27
  }
41
28
  return {
42
29
  response: response.results[0]
43
30
  };
44
31
  });
45
32
  }
46
-
47
33
  handleUpdateToRevocableSession(req) {
48
34
  const config = req.config;
49
35
  const user = req.auth.user;
50
36
  // Issue #2720
51
37
  // Calling without a session token would result in a not found user
52
38
  if (!user) {
53
- throw new _node2.default.Error(_node2.default.Error.OBJECT_NOT_FOUND, 'invalid session');
39
+ throw new _node.default.Error(_node.default.Error.OBJECT_NOT_FOUND, 'invalid session');
54
40
  }
55
41
  const {
56
42
  sessionData,
57
43
  createSession
58
- } = _Auth2.default.createSession(config, {
44
+ } = _RestWrite.default.createSession(config, {
59
45
  userId: user.id,
60
46
  createdWith: {
61
- 'action': 'upgrade'
47
+ action: 'upgrade'
62
48
  },
63
49
  installationId: req.auth.installationId
64
50
  });
65
-
66
51
  return createSession().then(() => {
67
52
  // delete the session token, use the db to skip beforeSave
68
53
  return config.database.update('_User', {
69
54
  objectId: user.id
70
55
  }, {
71
- sessionToken: { __op: 'Delete' }
56
+ sessionToken: {
57
+ __op: 'Delete'
58
+ }
72
59
  });
73
60
  }).then(() => {
74
- return Promise.resolve({ response: sessionData });
61
+ return Promise.resolve({
62
+ response: sessionData
63
+ });
75
64
  });
76
65
  }
77
-
78
66
  mountRoutes() {
79
67
  this.route('GET', '/sessions/me', req => {
80
68
  return this.handleMe(req);
@@ -99,7 +87,6 @@ class SessionsRouter extends _ClassesRouter2.default {
99
87
  });
100
88
  }
101
89
  }
102
-
103
90
  exports.SessionsRouter = SessionsRouter;
104
- exports.default = SessionsRouter;
105
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1Nlc3Npb25zUm91dGVyLmpzIl0sIm5hbWVzIjpbIlNlc3Npb25zUm91dGVyIiwiQ2xhc3Nlc1JvdXRlciIsImNsYXNzTmFtZSIsImhhbmRsZU1lIiwicmVxIiwiaW5mbyIsInNlc3Npb25Ub2tlbiIsIlBhcnNlIiwiRXJyb3IiLCJJTlZBTElEX1NFU1NJT05fVE9LRU4iLCJyZXN0IiwiZmluZCIsImNvbmZpZyIsIkF1dGgiLCJtYXN0ZXIiLCJ1bmRlZmluZWQiLCJjbGllbnRTREsiLCJ0aGVuIiwicmVzcG9uc2UiLCJyZXN1bHRzIiwibGVuZ3RoIiwiaGFuZGxlVXBkYXRlVG9SZXZvY2FibGVTZXNzaW9uIiwidXNlciIsImF1dGgiLCJPQkpFQ1RfTk9UX0ZPVU5EIiwic2Vzc2lvbkRhdGEiLCJjcmVhdGVTZXNzaW9uIiwidXNlcklkIiwiaWQiLCJjcmVhdGVkV2l0aCIsImluc3RhbGxhdGlvbklkIiwiZGF0YWJhc2UiLCJ1cGRhdGUiLCJvYmplY3RJZCIsIl9fb3AiLCJQcm9taXNlIiwicmVzb2x2ZSIsIm1vdW50Um91dGVzIiwicm91dGUiLCJoYW5kbGVGaW5kIiwiaGFuZGxlR2V0IiwiaGFuZGxlQ3JlYXRlIiwiaGFuZGxlVXBkYXRlIiwiaGFuZGxlRGVsZXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0E7Ozs7QUFDQTs7OztBQUNBOzs7O0FBQ0E7Ozs7OztBQUVPLE1BQU1BLGNBQU4sU0FBNkJDLHVCQUE3QixDQUEyQzs7QUFFaERDLGNBQVk7QUFDVixXQUFPLFVBQVA7QUFDRDs7QUFFREMsV0FBU0MsR0FBVCxFQUFjO0FBQ1o7QUFDQSxRQUFJLENBQUNBLElBQUlDLElBQUwsSUFBYSxDQUFDRCxJQUFJQyxJQUFKLENBQVNDLFlBQTNCLEVBQXlDO0FBQ3ZDLFlBQU0sSUFBSUMsZUFBTUMsS0FBVixDQUFnQkQsZUFBTUMsS0FBTixDQUFZQyxxQkFBNUIsRUFDSix5QkFESSxDQUFOO0FBRUQ7QUFDRCxXQUFPQyxlQUFL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LE9BQU87QUFBRSxhQUFPLEtBQUtpQiw4QkFBTCxDQUFvQ2pCLEdBQXBDLENBQVA7QUFBa0QsS0FBNUc7QUFDRDtBQS9EK0M7O1FBQXJDSixjLEdBQUFBLGM7a0JBa0VFQSxjIiwiZmlsZSI6IlNlc3Npb25zUm91dGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgQ2xhc3Nlc1JvdXRlciBmcm9tICcuL0NsYXNzZXNSb3V0ZXInO1xuaW1wb3J0IFBhcnNlICAgICAgICAgZnJvbSAncGFyc2Uvbm9kZSc7XG5pbXBvcnQgcmVzdCAgICAgICAgICBmcm9tICcuLi9yZXN0JztcbmltcG9ydCBBdXRoICAgICAgICAgIGZyb20gJy4uL0F1dGgnO1xuXG5leHBvcnQgY2xhc3MgU2Vzc2lvbnNSb3V0ZXIgZXh0ZW5kcyBDbGFzc2VzUm91dGVyIHtcblxuICBjbGFzc05hbWUoKSB7XG4gICAgcmV0dXJuICdfU2Vzc2lvbic7XG4gIH1cblxuICBoYW5kbGVNZShyZXEpIHtcbiAgICAvLyBUT0RPOiBWZXJpZnkgY29ycmVjdCBiZWhhdmlvclxuICAgIGlmICghcmVxLmluZm8gfHwgIXJlcS5pbmZvLnNlc3Npb25Ub2tlbikge1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFBhcnNlLkVycm9yLklOVkFMSURfU0VTU0lPTl9UT0tFTixcbiAgICAgICAgJ1Nlc3Npb24gdG9rZW4gcmVxdWlyZWQuJyk7XG4gICAgfVxuICAgIHJldHVybiByZXN0LmZpbmQocmVxLmNvbmZpZywgQXV0aC5tYXN0ZXIocmVxLmNvbmZpZyksICdfU2Vzc2lvbicsIHsgc2Vzc2lvblRva2VuOiByZXEuaW5mby5zZXNzaW9uVG9rZW4gfSwgdW5kZWZpbmVkLCByZXEuaW5mby5jbGllbnRTREspXG4gICAgICAudGhlbigocmVzcG9uc2UpID0+IHtcbiAgICAgICAgaWYgKCFyZXNwb25zZS5yZXN1bHRzIHx8IHJlc3BvbnNlLnJlc3VsdHMubGVuZ3RoID09IDApIHtcbiAgICAgICAgICB0aHJvdyBuZXcgUGFyc2UuRXJyb3IoUGFyc2UuRXJyb3IuSU5WQUxJRF9TRVNTSU9OX1RPS0VOLFxuICAgICAgICAgICAgJ1Nlc3Npb24gdG9rZW4gbm90IGZvdW5kLicpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgcmVzcG9uc2U6IHJlc3BvbnNlLnJlc3VsdHNbMF1cbiAgICAgICAgfTtcbiAgICAgIH0pO1xuICB9XG5cbiAgaGFuZGxlVXBkYXRlVG9SZXZvY2FibGVTZXNzaW9uKHJlcSkge1xuICAgIGNvbnN0IGNvbmZpZyA9IHJlcS5jb25maWc7XG4gICAgY29uc3QgdXNlciA9IHJlcS5hdXRoLnVzZXI7XG4gICAgLy8gSXNzdWUgIzI3MjBcbiAgICAvLyBDYWxsaW5nIHdpdGhvdXQgYSBzZXNzaW9uIHRva2VuIHdvdWxkIHJlc3VsdCBpbiBhIG5vdCBmb3VuZCB1c2VyXG4gICAgaWYgKCF1c2VyKSB7XG4gICAgICB0aHJvdyBuZXcgUGFyc2UuRXJyb3IoUGFyc2UuRXJyb3IuT0JKRUNUX05PVF9GT1VORCwgJ2ludmFsaWQgc2Vzc2lvbicpO1xuICAgIH1cbiAgICBjb25zdCB7XG4gICAgICBzZXNzaW9uRGF0YSxcbiAgICAgIGNyZWF0ZVNlc3Npb25cbiAgICB9ID0gQXV0aC5jcmVhdGVTZXNzaW9uKGNvbmZpZywge1xuICAgICAgdXNlcklkOiB1c2VyLmlkLFxuICAgICAgY3JlYXRlZFdpdGg6IHtcbiAgICAgICAgJ2FjdGlvbic6ICd1cGdyYWRlJyxcbiAgICAgIH0sXG4gICAgICBpbnN0YWxsYXRpb25JZDogcmVxLmF1dGguaW5zdGFsbGF0aW9uSWQsXG4gICAgfSk7XG5cbiAgICByZXR1cm4gY3JlYXRlU2Vzc2lvbigpLnRoZW4oKCkgPT4ge1xuICAgICAgLy8gZGVsZXRlIHRoZSBzZXNzaW9uIHRva2VuLCB1c2UgdGhlIGRiIHRvIHNraXAgYmVmb3JlU2F2ZVxuICAgICAgcmV0dXJuIGNvbmZpZy5kYXRhYmFzZS51cGRhdGUoJ19Vc2VyJywge1xuICAgICAgICBvYmplY3RJZDogdXNlci5pZFxuICAgICAgfSwge1xuICAgICAgICBzZXNzaW9uVG9rZW46IHtfX29wOiAnRGVsZXRlJ31cbiAgICAgIH0pO1xuICAgIH0pLnRoZW4oKCkgPT4ge1xuICAgICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSh7IHJlc3BvbnNlOiBzZXNzaW9uRGF0YSB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIG1vdW50Um91dGVzKCkge1xuICAgIHRoaXMucm91dGUoJ0dFVCcsJy9zZXNzaW9ucy9tZScsIHJlcSA9PiB7IHJldHVybiB0aGlzLmhhbmRsZU1lKHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ0dFVCcsICcvc2Vzc2lvbnMnLCByZXEgPT4geyByZXR1cm4gdGhpcy5oYW5kbGVGaW5kKHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ0dFVCcsICcvc2Vzc2lvbnMvOm9iamVjdElkJywgcmVxID0+IHsgcmV0dXJuIHRoaXMuaGFuZGxlR2V0KHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ1BPU1QnLCAnL3Nlc3Npb25zJywgcmVxID0+IHsgcmV0dXJuIHRoaXMuaGFuZGxlQ3JlYXRlKHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ1BVVCcsICcvc2Vzc2lvbnMvOm9iamVjdElkJywgcmVxID0+IHsgcmV0dXJuIHRoaXMuaGFuZGxlVXBkYXRlKHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ0RFTEVURScsICcvc2Vzc2lvbnMvOm9iamVjdElkJywgcmVxID0+IHsgcmV0dXJuIHRoaXMuaGFuZGxlRGVsZXRlKHJlcSk7IH0pO1xuICAgIHRoaXMucm91dGUoJ1BPU1QnLCAnL3VwZ3JhZGVUb1Jldm9jYWJsZVNlc3Npb24nLCByZXEgPT4geyByZXR1cm4gdGhpcy5oYW5kbGVVcGRhdGVUb1Jldm9jYWJsZVNlc3Npb24ocmVxKTsgfSlcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBTZXNzaW9uc1JvdXRlcjtcbiJdfQ==
91
+ var _default = exports.default = SessionsRouter;
92
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_ClassesRouter","_interopRequireDefault","require","_node","_rest","_Auth","_RestWrite","e","__esModule","default","SessionsRouter","ClassesRouter","className","handleMe","req","info","sessionToken","Parse","Error","INVALID_SESSION_TOKEN","rest","find","config","Auth","master","undefined","clientSDK","context","then","response","results","length","handleUpdateToRevocableSession","user","auth","OBJECT_NOT_FOUND","sessionData","createSession","RestWrite","userId","id","createdWith","action","installationId","database","update","objectId","__op","Promise","resolve","mountRoutes","route","handleFind","handleGet","handleCreate","handleUpdate","handleDelete","exports","_default"],"sources":["../../src/Routers/SessionsRouter.js"],"sourcesContent":["import ClassesRouter from './ClassesRouter';\nimport Parse from 'parse/node';\nimport rest from '../rest';\nimport Auth from '../Auth';\nimport RestWrite from '../RestWrite';\n\nexport class SessionsRouter extends ClassesRouter {\n  className() {\n    return '_Session';\n  }\n\n  handleMe(req) {\n    // TODO: Verify correct behavior\n    if (!req.info || !req.info.sessionToken) {\n      throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token required.');\n    }\n    return rest\n      .find(\n        req.config,\n        Auth.master(req.config),\n        '_Session',\n        { sessionToken: req.info.sessionToken },\n        undefined,\n        req.info.clientSDK,\n        req.info.context\n      )\n      .then(response => {\n        if (!response.results || response.results.length == 0) {\n          throw new Parse.Error(Parse.Error.INVALID_SESSION_TOKEN, 'Session token not found.');\n        }\n        return {\n          response: response.results[0],\n        };\n      });\n  }\n\n  handleUpdateToRevocableSession(req) {\n    const config = req.config;\n    const user = req.auth.user;\n    // Issue #2720\n    // Calling without a session token would result in a not found user\n    if (!user) {\n      throw new Parse.Error(Parse.Error.OBJECT_NOT_FOUND, 'invalid session');\n    }\n    const { sessionData, createSession } = RestWrite.createSession(config, {\n      userId: user.id,\n      createdWith: {\n        action: 'upgrade',\n      },\n      installationId: req.auth.installationId,\n    });\n\n    return createSession()\n      .then(() => {\n        // delete the session token, use the db to skip beforeSave\n        return config.database.update(\n          '_User',\n          {\n            objectId: user.id,\n          },\n          {\n            sessionToken: { __op: 'Delete' },\n          }\n        );\n      })\n      .then(() => {\n        return Promise.resolve({ response: sessionData });\n      });\n  }\n\n  mountRoutes() {\n    this.route('GET', '/sessions/me', req => {\n      return this.handleMe(req);\n    });\n    this.route('GET', '/sessions', req => {\n      return this.handleFind(req);\n    });\n    this.route('GET', '/sessions/:objectId', req => {\n      return this.handleGet(req);\n    });\n    this.route('POST', '/sessions', req => {\n      return this.handleCreate(req);\n    });\n    this.route('PUT', '/sessions/:objectId', req => {\n      return this.handleUpdate(req);\n    });\n    this.route('DELETE', '/sessions/:objectId', req => {\n      return this.handleDelete(req);\n    });\n    this.route('POST', '/upgradeToRevocableSession', req => {\n      return this.handleUpdateToRevocableSession(req);\n    });\n  }\n}\n\nexport default SessionsRouter;\n"],"mappings":"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","ignoreList":[]}