parse-server 6.0.0-alpha.2 → 6.0.0-alpha.21

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 (191) hide show
  1. package/README.md +45 -17
  2. package/lib/AccountLockout.js +11 -26
  3. package/lib/Adapters/AdapterLoader.js +8 -14
  4. package/lib/Adapters/Analytics/AnalyticsAdapter.js +2 -8
  5. package/lib/Adapters/Auth/AuthAdapter.js +7 -16
  6. package/lib/Adapters/Auth/OAuth1Client.js +32 -57
  7. package/lib/Adapters/Auth/apple.js +6 -22
  8. package/lib/Adapters/Auth/facebook.js +7 -37
  9. package/lib/Adapters/Auth/gcenter.js +8 -37
  10. package/lib/Adapters/Auth/github.js +7 -10
  11. package/lib/Adapters/Auth/google.js +11 -34
  12. package/lib/Adapters/Auth/gpgames.js +5 -8
  13. package/lib/Adapters/Auth/httpsRequest.js +1 -7
  14. package/lib/Adapters/Auth/index.js +20 -65
  15. package/lib/Adapters/Auth/instagram.js +5 -9
  16. package/lib/Adapters/Auth/janraincapture.js +8 -12
  17. package/lib/Adapters/Auth/janrainengage.js +7 -11
  18. package/lib/Adapters/Auth/keycloak.js +5 -19
  19. package/lib/Adapters/Auth/ldap.js +1 -15
  20. package/lib/Adapters/Auth/line.js +7 -10
  21. package/lib/Adapters/Auth/linkedin.js +7 -12
  22. package/lib/Adapters/Auth/meetup.js +7 -10
  23. package/lib/Adapters/Auth/microsoft.js +7 -10
  24. package/lib/Adapters/Auth/oauth2.js +6 -18
  25. package/lib/Adapters/Auth/phantauth.js +8 -10
  26. package/lib/Adapters/Auth/qq.js +7 -13
  27. package/lib/Adapters/Auth/spotify.js +7 -14
  28. package/lib/Adapters/Auth/twitter.js +5 -15
  29. package/lib/Adapters/Auth/vkontakte.js +9 -15
  30. package/lib/Adapters/Auth/wechat.js +7 -10
  31. package/lib/Adapters/Auth/weibo.js +7 -11
  32. package/lib/Adapters/Cache/CacheAdapter.js +4 -12
  33. package/lib/Adapters/Cache/InMemoryCache.js +5 -19
  34. package/lib/Adapters/Cache/InMemoryCacheAdapter.js +1 -11
  35. package/lib/Adapters/Cache/LRUCache.js +1 -11
  36. package/lib/Adapters/Cache/NullCacheAdapter.js +1 -8
  37. package/lib/Adapters/Cache/RedisCacheAdapter.js +46 -87
  38. package/lib/Adapters/Cache/SchemaCache.js +1 -6
  39. package/lib/Adapters/Email/MailAdapter.js +2 -7
  40. package/lib/Adapters/Files/FilesAdapter.js +7 -21
  41. package/lib/Adapters/Files/GridFSBucketAdapter.js +6 -44
  42. package/lib/Adapters/Files/GridStoreAdapter.js +1 -1
  43. package/lib/Adapters/Logger/LoggerAdapter.js +2 -11
  44. package/lib/Adapters/Logger/WinstonLogger.js +3 -30
  45. package/lib/Adapters/Logger/WinstonLoggerAdapter.js +5 -16
  46. package/lib/Adapters/MessageQueue/EventEmitterMQ.js +3 -20
  47. package/lib/Adapters/PubSub/EventEmitterPubSub.js +1 -16
  48. package/lib/Adapters/PubSub/PubSubAdapter.js +2 -9
  49. package/lib/Adapters/PubSub/RedisPubSub.js +13 -10
  50. package/lib/Adapters/Push/PushAdapter.js +2 -8
  51. package/lib/Adapters/Storage/Mongo/MongoCollection.js +12 -37
  52. package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +26 -79
  53. package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +78 -209
  54. package/lib/Adapters/Storage/Mongo/MongoTransform.js +82 -371
  55. package/lib/Adapters/Storage/Postgres/PostgresClient.js +1 -13
  56. package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +1 -20
  57. package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +119 -446
  58. package/lib/Adapters/Storage/Postgres/sql/index.js +4 -7
  59. package/lib/Adapters/Storage/StorageAdapter.js +1 -1
  60. package/lib/Adapters/WebSocketServer/WSAdapter.js +3 -12
  61. package/lib/Adapters/WebSocketServer/WSSAdapter.js +7 -12
  62. package/lib/Auth.js +54 -121
  63. package/lib/ClientSDK.js +3 -11
  64. package/lib/Config.js +69 -113
  65. package/lib/Controllers/AdaptableController.js +6 -18
  66. package/lib/Controllers/AnalyticsController.js +1 -9
  67. package/lib/Controllers/CacheController.js +3 -23
  68. package/lib/Controllers/DatabaseController.js +147 -345
  69. package/lib/Controllers/FilesController.js +5 -34
  70. package/lib/Controllers/HooksController.js +1 -51
  71. package/lib/Controllers/LiveQueryController.js +4 -23
  72. package/lib/Controllers/LoggerController.js +15 -54
  73. package/lib/Controllers/ParseGraphQLController.js +49 -104
  74. package/lib/Controllers/PushController.js +20 -59
  75. package/lib/Controllers/SchemaController.js +154 -344
  76. package/lib/Controllers/UserController.js +11 -72
  77. package/lib/Controllers/index.js +19 -68
  78. package/lib/Controllers/types.js +1 -1
  79. package/lib/Deprecator/Deprecations.js +1 -8
  80. package/lib/Deprecator/Deprecator.js +9 -18
  81. package/lib/GraphQL/ParseGraphQLSchema.js +16 -100
  82. package/lib/GraphQL/ParseGraphQLServer.js +2 -29
  83. package/lib/GraphQL/helpers/objectsMutations.js +2 -12
  84. package/lib/GraphQL/helpers/objectsQueries.js +18 -76
  85. package/lib/GraphQL/loaders/defaultGraphQLMutations.js +1 -9
  86. package/lib/GraphQL/loaders/defaultGraphQLQueries.js +1 -8
  87. package/lib/GraphQL/loaders/defaultGraphQLTypes.js +9 -115
  88. package/lib/GraphQL/loaders/defaultRelaySchema.js +6 -18
  89. package/lib/GraphQL/loaders/filesMutations.js +2 -19
  90. package/lib/GraphQL/loaders/functionsMutations.js +6 -17
  91. package/lib/GraphQL/loaders/parseClassMutations.js +6 -44
  92. package/lib/GraphQL/loaders/parseClassQueries.js +1 -26
  93. package/lib/GraphQL/loaders/parseClassTypes.js +10 -64
  94. package/lib/GraphQL/loaders/schemaDirectives.js +1 -17
  95. package/lib/GraphQL/loaders/schemaMutations.js +1 -20
  96. package/lib/GraphQL/loaders/schemaQueries.js +1 -14
  97. package/lib/GraphQL/loaders/schemaTypes.js +2 -6
  98. package/lib/GraphQL/loaders/usersMutations.js +6 -28
  99. package/lib/GraphQL/loaders/usersQueries.js +4 -26
  100. package/lib/GraphQL/parseGraphQLUtils.js +6 -19
  101. package/lib/GraphQL/transformers/className.js +1 -4
  102. package/lib/GraphQL/transformers/constraintType.js +1 -20
  103. package/lib/GraphQL/transformers/inputType.js +1 -20
  104. package/lib/GraphQL/transformers/mutation.js +6 -51
  105. package/lib/GraphQL/transformers/outputType.js +1 -20
  106. package/lib/GraphQL/transformers/query.js +6 -42
  107. package/lib/GraphQL/transformers/schemaFields.js +7 -34
  108. package/lib/KeyPromiseQueue.js +1 -12
  109. package/lib/LiveQuery/Client.js +1 -25
  110. package/lib/LiveQuery/Id.js +1 -7
  111. package/lib/LiveQuery/ParseCloudCodePublisher.js +13 -19
  112. package/lib/LiveQuery/ParseLiveQueryServer.js +92 -306
  113. package/lib/LiveQuery/ParsePubSub.js +1 -12
  114. package/lib/LiveQuery/ParseWebSocketServer.js +4 -26
  115. package/lib/LiveQuery/QueryTools.js +14 -116
  116. package/lib/LiveQuery/RequestSchema.js +1 -1
  117. package/lib/LiveQuery/SessionTokenCache.js +1 -17
  118. package/lib/LiveQuery/Subscription.js +4 -18
  119. package/lib/LiveQuery/equalObjects.js +2 -14
  120. package/lib/Options/Definitions.js +79 -10
  121. package/lib/Options/docs.js +23 -3
  122. package/lib/Options/index.js +4 -12
  123. package/lib/Options/parsers.js +1 -18
  124. package/lib/Page.js +1 -9
  125. package/lib/ParseMessageQueue.js +1 -10
  126. package/lib/ParseServer.js +144 -182
  127. package/lib/ParseServerRESTController.js +6 -33
  128. package/lib/PromiseRouter.js +16 -50
  129. package/lib/Push/PushQueue.js +3 -15
  130. package/lib/Push/PushWorker.js +7 -32
  131. package/lib/Push/utils.js +9 -38
  132. package/lib/RestQuery.js +105 -242
  133. package/lib/RestWrite.js +212 -377
  134. package/lib/Routers/AggregateRouter.js +14 -51
  135. package/lib/Routers/AnalyticsRouter.js +2 -8
  136. package/lib/Routers/AudiencesRouter.js +1 -15
  137. package/lib/Routers/ClassesRouter.js +3 -53
  138. package/lib/Routers/CloudCodeRouter.js +1 -19
  139. package/lib/Routers/FeaturesRouter.js +1 -10
  140. package/lib/Routers/FilesRouter.js +29 -76
  141. package/lib/Routers/FunctionsRouter.js +5 -28
  142. package/lib/Routers/GlobalConfigRouter.js +4 -18
  143. package/lib/Routers/GraphQLRouter.js +1 -14
  144. package/lib/Routers/HooksRouter.js +1 -29
  145. package/lib/Routers/IAPValidationRouter.js +6 -29
  146. package/lib/Routers/InstallationsRouter.js +2 -12
  147. package/lib/Routers/LogsRouter.js +4 -16
  148. package/lib/Routers/PagesRouter.js +69 -129
  149. package/lib/Routers/PublicAPIRouter.js +3 -62
  150. package/lib/Routers/PurgeRouter.js +1 -15
  151. package/lib/Routers/PushRouter.js +2 -18
  152. package/lib/Routers/RolesRouter.js +1 -7
  153. package/lib/Routers/SchemasRouter.js +4 -34
  154. package/lib/Routers/SecurityRouter.js +1 -12
  155. package/lib/Routers/SessionsRouter.js +3 -19
  156. package/lib/Routers/UsersRouter.js +58 -155
  157. package/lib/SchemaMigrations/DefinedSchemas.js +56 -115
  158. package/lib/SchemaMigrations/Migrations.js +2 -8
  159. package/lib/Security/Check.js +8 -16
  160. package/lib/Security/CheckGroup.js +4 -11
  161. package/lib/Security/CheckGroups/CheckGroupDatabase.js +8 -18
  162. package/lib/Security/CheckGroups/CheckGroupServerConfig.js +5 -15
  163. package/lib/Security/CheckGroups/CheckGroups.js +1 -4
  164. package/lib/Security/CheckRunner.js +22 -41
  165. package/lib/StatusHandler.js +12 -69
  166. package/lib/TestUtils.js +1 -6
  167. package/lib/Utils.js +27 -66
  168. package/lib/batch.js +17 -28
  169. package/lib/cache.js +1 -3
  170. package/lib/cli/definitions/parse-live-query-server.js +1 -3
  171. package/lib/cli/definitions/parse-server.js +1 -3
  172. package/lib/cli/parse-live-query-server.js +1 -6
  173. package/lib/cli/parse-server.js +11 -21
  174. package/lib/cli/utils/commander.js +13 -51
  175. package/lib/cli/utils/runner.js +1 -14
  176. package/lib/cloud-code/Parse.Cloud.js +71 -92
  177. package/lib/cryptoUtils.js +11 -19
  178. package/lib/defaults.js +2 -14
  179. package/lib/deprecated.js +1 -2
  180. package/lib/index.js +16 -34
  181. package/lib/logger.js +6 -13
  182. package/lib/middlewares.js +147 -151
  183. package/lib/password.js +6 -10
  184. package/lib/request.js +173 -2
  185. package/lib/requiredParameter.js +1 -3
  186. package/lib/rest.js +19 -41
  187. package/lib/triggers.js +54 -252
  188. package/lib/vendor/mongodbUrl.js +125 -305
  189. package/package.json +22 -19
  190. package/lib/cloud-code/HTTPResponse.js +0 -73
  191. package/lib/cloud-code/httpRequest.js +0 -192
@@ -4,27 +4,16 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = exports.PublicAPIRouter = void 0;
7
-
8
7
  var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
9
-
10
8
  var _Config = _interopRequireDefault(require("../Config"));
11
-
12
9
  var _express = _interopRequireDefault(require("express"));
13
-
14
10
  var _path = _interopRequireDefault(require("path"));
15
-
16
11
  var _fs = _interopRequireDefault(require("fs"));
17
-
18
12
  var _querystring = _interopRequireDefault(require("querystring"));
19
-
20
13
  var _node = require("parse/node");
21
-
22
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
23
-
24
15
  const public_html = _path.default.resolve(__dirname, '../../public_html');
25
-
26
16
  const views = _path.default.resolve(__dirname, '../../views');
27
-
28
17
  class PublicAPIRouter extends _PromiseRouter.default {
29
18
  verifyEmail(req) {
30
19
  const {
@@ -33,27 +22,21 @@ class PublicAPIRouter extends _PromiseRouter.default {
33
22
  } = req.query;
34
23
  const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
35
24
  const appId = req.params.appId;
36
-
37
25
  const config = _Config.default.get(appId);
38
-
39
26
  if (!config) {
40
27
  this.invalidRequest();
41
28
  }
42
-
43
29
  if (!config.publicServerURL) {
44
30
  return this.missingPublicServerURL();
45
31
  }
46
-
47
32
  if (!token || !username) {
48
33
  return this.invalidLink(req);
49
34
  }
50
-
51
35
  const userController = config.userController;
52
36
  return userController.verifyEmail(username, token).then(() => {
53
37
  const params = _querystring.default.stringify({
54
38
  username
55
39
  });
56
-
57
40
  return Promise.resolve({
58
41
  status: 302,
59
42
  location: `${config.verifyEmailSuccessURL}?${params}`
@@ -62,25 +45,19 @@ class PublicAPIRouter extends _PromiseRouter.default {
62
45
  return this.invalidVerificationLink(req);
63
46
  });
64
47
  }
65
-
66
48
  resendVerificationEmail(req) {
67
49
  const username = req.body.username;
68
50
  const appId = req.params.appId;
69
-
70
51
  const config = _Config.default.get(appId);
71
-
72
52
  if (!config) {
73
53
  this.invalidRequest();
74
54
  }
75
-
76
55
  if (!config.publicServerURL) {
77
56
  return this.missingPublicServerURL();
78
57
  }
79
-
80
58
  if (!username) {
81
59
  return this.invalidLink(req);
82
60
  }
83
-
84
61
  const userController = config.userController;
85
62
  return userController.resendVerificationEmail(username).then(() => {
86
63
  return Promise.resolve({
@@ -94,28 +71,23 @@ class PublicAPIRouter extends _PromiseRouter.default {
94
71
  });
95
72
  });
96
73
  }
97
-
98
74
  changePassword(req) {
99
75
  return new Promise((resolve, reject) => {
100
76
  const config = _Config.default.get(req.query.id);
101
-
102
77
  if (!config) {
103
78
  this.invalidRequest();
104
79
  }
105
-
106
80
  if (!config.publicServerURL) {
107
81
  return resolve({
108
82
  status: 404,
109
83
  text: 'Not found.'
110
84
  });
111
- } // Should we keep the file in memory or leave like that?
112
-
113
-
85
+ }
86
+ // Should we keep the file in memory or leave like that?
114
87
  _fs.default.readFile(_path.default.resolve(views, 'choose_password'), 'utf-8', (err, data) => {
115
88
  if (err) {
116
89
  return reject(err);
117
90
  }
118
-
119
91
  data = data.replace('PARSE_SERVER_URL', `'${config.publicServerURL}'`);
120
92
  resolve({
121
93
  text: data
@@ -123,28 +95,22 @@ class PublicAPIRouter extends _PromiseRouter.default {
123
95
  });
124
96
  });
125
97
  }
126
-
127
98
  requestResetPassword(req) {
128
99
  const config = req.config;
129
-
130
100
  if (!config) {
131
101
  this.invalidRequest();
132
102
  }
133
-
134
103
  if (!config.publicServerURL) {
135
104
  return this.missingPublicServerURL();
136
105
  }
137
-
138
106
  const {
139
107
  username,
140
108
  token: rawToken
141
109
  } = req.query;
142
110
  const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
143
-
144
111
  if (!username || !token) {
145
112
  return this.invalidLink(req);
146
113
  }
147
-
148
114
  return config.userController.checkResetTokenValidity(username, token).then(() => {
149
115
  const params = _querystring.default.stringify({
150
116
  token,
@@ -152,7 +118,6 @@ class PublicAPIRouter extends _PromiseRouter.default {
152
118
  username,
153
119
  app: config.appName
154
120
  });
155
-
156
121
  return Promise.resolve({
157
122
  status: 302,
158
123
  location: `${config.choosePasswordURL}?${params}`
@@ -161,41 +126,32 @@ class PublicAPIRouter extends _PromiseRouter.default {
161
126
  return this.invalidLink(req);
162
127
  });
163
128
  }
164
-
165
129
  resetPassword(req) {
166
130
  const config = req.config;
167
-
168
131
  if (!config) {
169
132
  this.invalidRequest();
170
133
  }
171
-
172
134
  if (!config.publicServerURL) {
173
135
  return this.missingPublicServerURL();
174
136
  }
175
-
176
137
  const {
177
138
  username,
178
139
  new_password,
179
140
  token: rawToken
180
141
  } = req.body;
181
142
  const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
182
-
183
143
  if ((!username || !token || !new_password) && req.xhr === false) {
184
144
  return this.invalidLink(req);
185
145
  }
186
-
187
146
  if (!username) {
188
147
  throw new _node.Parse.Error(_node.Parse.Error.USERNAME_MISSING, 'Missing username');
189
148
  }
190
-
191
149
  if (!token) {
192
150
  throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, 'Missing token');
193
151
  }
194
-
195
152
  if (!new_password) {
196
153
  throw new _node.Parse.Error(_node.Parse.Error.PASSWORD_MISSING, 'Missing password');
197
154
  }
198
-
199
155
  return config.userController.updatePassword(username, token, new_password).then(() => {
200
156
  return Promise.resolve({
201
157
  success: true
@@ -213,7 +169,6 @@ class PublicAPIRouter extends _PromiseRouter.default {
213
169
  error: result.err,
214
170
  app: config.appName
215
171
  });
216
-
217
172
  if (req.xhr) {
218
173
  if (result.success) {
219
174
  return Promise.resolve({
@@ -221,12 +176,10 @@ class PublicAPIRouter extends _PromiseRouter.default {
221
176
  response: 'Password successfully reset'
222
177
  });
223
178
  }
224
-
225
179
  if (result.err) {
226
180
  throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, `${result.err}`);
227
181
  }
228
182
  }
229
-
230
183
  const encodedUsername = encodeURIComponent(username);
231
184
  const location = result.success ? `${config.passwordResetSuccessURL}?username=${encodedUsername}` : `${config.choosePasswordURL}?${params}`;
232
185
  return Promise.resolve({
@@ -235,23 +188,19 @@ class PublicAPIRouter extends _PromiseRouter.default {
235
188
  });
236
189
  });
237
190
  }
238
-
239
191
  invalidLink(req) {
240
192
  return Promise.resolve({
241
193
  status: 302,
242
194
  location: req.config.invalidLinkURL
243
195
  });
244
196
  }
245
-
246
197
  invalidVerificationLink(req) {
247
198
  const config = req.config;
248
-
249
199
  if (req.query.username && req.params.appId) {
250
200
  const params = _querystring.default.stringify({
251
201
  username: req.query.username,
252
202
  appId: req.params.appId
253
203
  });
254
-
255
204
  return Promise.resolve({
256
205
  status: 302,
257
206
  location: `${config.invalidVerificationLinkURL}?${params}`
@@ -260,26 +209,22 @@ class PublicAPIRouter extends _PromiseRouter.default {
260
209
  return this.invalidLink(req);
261
210
  }
262
211
  }
263
-
264
212
  missingPublicServerURL() {
265
213
  return Promise.resolve({
266
214
  text: 'Not found.',
267
215
  status: 404
268
216
  });
269
217
  }
270
-
271
218
  invalidRequest() {
272
219
  const error = new Error();
273
220
  error.status = 403;
274
221
  error.message = 'unauthorized';
275
222
  throw error;
276
223
  }
277
-
278
224
  setConfig(req) {
279
225
  req.config = _Config.default.get(req.params.appId);
280
226
  return Promise.resolve();
281
227
  }
282
-
283
228
  mountRoutes() {
284
229
  this.route('GET', '/apps/:appId/verify_email', req => {
285
230
  this.setConfig(req);
@@ -305,18 +250,14 @@ class PublicAPIRouter extends _PromiseRouter.default {
305
250
  return this.requestResetPassword(req);
306
251
  });
307
252
  }
308
-
309
253
  expressRouter() {
310
254
  const router = _express.default.Router();
311
-
312
255
  router.use('/apps', _express.default.static(public_html));
313
256
  router.use('/', super.expressRouter());
314
257
  return router;
315
258
  }
316
-
317
259
  }
318
-
319
260
  exports.PublicAPIRouter = PublicAPIRouter;
320
261
  var _default = PublicAPIRouter;
321
262
  exports.default = _default;
322
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Routers/PublicAPIRouter.js"],"names":["public_html","path","resolve","__dirname","views","PublicAPIRouter","PromiseRouter","verifyEmail","req","username","token","rawToken","query","toString","appId","params","config","Config","get","invalidRequest","publicServerURL","missingPublicServerURL","invalidLink","userController","then","qs","stringify","Promise","status","location","verifyEmailSuccessURL","invalidVerificationLink","resendVerificationEmail","body","linkSendSuccessURL","linkSendFailURL","changePassword","reject","id","text","fs","readFile","err","data","replace","requestResetPassword","checkResetTokenValidity","applicationId","app","appName","choosePasswordURL","resetPassword","new_password","xhr","Parse","Error","USERNAME_MISSING","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","success","result","error","response","encodedUsername","encodeURIComponent","passwordResetSuccessURL","invalidLinkURL","invalidVerificationLinkURL","message","setConfig","mountRoutes","route","expressRouter","router","express","Router","use","static"],"mappings":"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","sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport Config from '../Config';\nimport express from 'express';\nimport path from 'path';\nimport fs from 'fs';\nimport qs from 'querystring';\nimport { Parse } from 'parse/node';\n\nconst public_html = path.resolve(__dirname, '../../public_html');\nconst views = path.resolve(__dirname, '../../views');\n\nexport class PublicAPIRouter extends PromiseRouter {\n  verifyEmail(req) {\n    const { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!token || !username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(username, token).then(\n      () => {\n        const params = qs.stringify({ username });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.verifyEmailSuccessURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidVerificationLink(req);\n      }\n    );\n  }\n\n  resendVerificationEmail(req) {\n    const username = req.body.username;\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username).then(\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendSuccessURL}`,\n        });\n      },\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendFailURL}`,\n        });\n      }\n    );\n  }\n\n  changePassword(req) {\n    return new Promise((resolve, reject) => {\n      const config = Config.get(req.query.id);\n\n      if (!config) {\n        this.invalidRequest();\n      }\n\n      if (!config.publicServerURL) {\n        return resolve({\n          status: 404,\n          text: 'Not found.',\n        });\n      }\n      // Should we keep the file in memory or leave like that?\n      fs.readFile(path.resolve(views, 'choose_password'), 'utf-8', (err, data) => {\n        if (err) {\n          return reject(err);\n        }\n        data = data.replace('PARSE_SERVER_URL', `'${config.publicServerURL}'`);\n        resolve({\n          text: data,\n        });\n      });\n    });\n  }\n\n  requestResetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!username || !token) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.checkResetTokenValidity(username, token).then(\n      () => {\n        const params = qs.stringify({\n          token,\n          id: config.applicationId,\n          username,\n          app: config.appName,\n        });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.choosePasswordURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidLink(req);\n      }\n    );\n  }\n\n  resetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, new_password, token: rawToken } = req.body;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!username || !token || !new_password) && req.xhr === false) {\n      return this.invalidLink(req);\n    }\n\n    if (!username) {\n      throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'Missing username');\n    }\n\n    if (!token) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Missing token');\n    }\n\n    if (!new_password) {\n      throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'Missing password');\n    }\n\n    return config.userController\n      .updatePassword(username, token, new_password)\n      .then(\n        () => {\n          return Promise.resolve({\n            success: true,\n          });\n        },\n        err => {\n          return Promise.resolve({\n            success: false,\n            err,\n          });\n        }\n      )\n      .then(result => {\n        const params = qs.stringify({\n          username: username,\n          token: token,\n          id: config.applicationId,\n          error: result.err,\n          app: config.appName,\n        });\n\n        if (req.xhr) {\n          if (result.success) {\n            return Promise.resolve({\n              status: 200,\n              response: 'Password successfully reset',\n            });\n          }\n          if (result.err) {\n            throw new Parse.Error(Parse.Error.OTHER_CAUSE, `${result.err}`);\n          }\n        }\n\n        const encodedUsername = encodeURIComponent(username);\n        const location = result.success\n          ? `${config.passwordResetSuccessURL}?username=${encodedUsername}`\n          : `${config.choosePasswordURL}?${params}`;\n\n        return Promise.resolve({\n          status: 302,\n          location,\n        });\n      });\n  }\n\n  invalidLink(req) {\n    return Promise.resolve({\n      status: 302,\n      location: req.config.invalidLinkURL,\n    });\n  }\n\n  invalidVerificationLink(req) {\n    const config = req.config;\n    if (req.query.username && req.params.appId) {\n      const params = qs.stringify({\n        username: req.query.username,\n        appId: req.params.appId,\n      });\n      return Promise.resolve({\n        status: 302,\n        location: `${config.invalidVerificationLinkURL}?${params}`,\n      });\n    } else {\n      return this.invalidLink(req);\n    }\n  }\n\n  missingPublicServerURL() {\n    return Promise.resolve({\n      text: 'Not found.',\n      status: 404,\n    });\n  }\n\n  invalidRequest() {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized';\n    throw error;\n  }\n\n  setConfig(req) {\n    req.config = Config.get(req.params.appId);\n    return Promise.resolve();\n  }\n\n  mountRoutes() {\n    this.route(\n      'GET',\n      '/apps/:appId/verify_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.verifyEmail(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      '/apps/:appId/resend_verification_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resendVerificationEmail(req);\n      }\n    );\n\n    this.route('GET', '/apps/choose_password', req => {\n      return this.changePassword(req);\n    });\n\n    this.route(\n      'POST',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resetPassword(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.requestResetPassword(req);\n      }\n    );\n  }\n\n  expressRouter() {\n    const router = express.Router();\n    router.use('/apps', express.static(public_html));\n    router.use('/', super.expressRouter());\n    return router;\n  }\n}\n\nexport default PublicAPIRouter;\n"]}
263
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["public_html","path","resolve","__dirname","views","PublicAPIRouter","PromiseRouter","verifyEmail","req","username","token","rawToken","query","toString","appId","params","config","Config","get","invalidRequest","publicServerURL","missingPublicServerURL","invalidLink","userController","then","qs","stringify","Promise","status","location","verifyEmailSuccessURL","invalidVerificationLink","resendVerificationEmail","body","linkSendSuccessURL","linkSendFailURL","changePassword","reject","id","text","fs","readFile","err","data","replace","requestResetPassword","checkResetTokenValidity","applicationId","app","appName","choosePasswordURL","resetPassword","new_password","xhr","Parse","Error","USERNAME_MISSING","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","success","result","error","response","encodedUsername","encodeURIComponent","passwordResetSuccessURL","invalidLinkURL","invalidVerificationLinkURL","message","setConfig","mountRoutes","route","expressRouter","router","express","Router","use","static"],"sources":["../../src/Routers/PublicAPIRouter.js"],"sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport Config from '../Config';\nimport express from 'express';\nimport path from 'path';\nimport fs from 'fs';\nimport qs from 'querystring';\nimport { Parse } from 'parse/node';\n\nconst public_html = path.resolve(__dirname, '../../public_html');\nconst views = path.resolve(__dirname, '../../views');\n\nexport class PublicAPIRouter extends PromiseRouter {\n  verifyEmail(req) {\n    const { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!token || !username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(username, token).then(\n      () => {\n        const params = qs.stringify({ username });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.verifyEmailSuccessURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidVerificationLink(req);\n      }\n    );\n  }\n\n  resendVerificationEmail(req) {\n    const username = req.body.username;\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username).then(\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendSuccessURL}`,\n        });\n      },\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendFailURL}`,\n        });\n      }\n    );\n  }\n\n  changePassword(req) {\n    return new Promise((resolve, reject) => {\n      const config = Config.get(req.query.id);\n\n      if (!config) {\n        this.invalidRequest();\n      }\n\n      if (!config.publicServerURL) {\n        return resolve({\n          status: 404,\n          text: 'Not found.',\n        });\n      }\n      // Should we keep the file in memory or leave like that?\n      fs.readFile(path.resolve(views, 'choose_password'), 'utf-8', (err, data) => {\n        if (err) {\n          return reject(err);\n        }\n        data = data.replace('PARSE_SERVER_URL', `'${config.publicServerURL}'`);\n        resolve({\n          text: data,\n        });\n      });\n    });\n  }\n\n  requestResetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!username || !token) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.checkResetTokenValidity(username, token).then(\n      () => {\n        const params = qs.stringify({\n          token,\n          id: config.applicationId,\n          username,\n          app: config.appName,\n        });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.choosePasswordURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidLink(req);\n      }\n    );\n  }\n\n  resetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, new_password, token: rawToken } = req.body;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!username || !token || !new_password) && req.xhr === false) {\n      return this.invalidLink(req);\n    }\n\n    if (!username) {\n      throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'Missing username');\n    }\n\n    if (!token) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Missing token');\n    }\n\n    if (!new_password) {\n      throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'Missing password');\n    }\n\n    return config.userController\n      .updatePassword(username, token, new_password)\n      .then(\n        () => {\n          return Promise.resolve({\n            success: true,\n          });\n        },\n        err => {\n          return Promise.resolve({\n            success: false,\n            err,\n          });\n        }\n      )\n      .then(result => {\n        const params = qs.stringify({\n          username: username,\n          token: token,\n          id: config.applicationId,\n          error: result.err,\n          app: config.appName,\n        });\n\n        if (req.xhr) {\n          if (result.success) {\n            return Promise.resolve({\n              status: 200,\n              response: 'Password successfully reset',\n            });\n          }\n          if (result.err) {\n            throw new Parse.Error(Parse.Error.OTHER_CAUSE, `${result.err}`);\n          }\n        }\n\n        const encodedUsername = encodeURIComponent(username);\n        const location = result.success\n          ? `${config.passwordResetSuccessURL}?username=${encodedUsername}`\n          : `${config.choosePasswordURL}?${params}`;\n\n        return Promise.resolve({\n          status: 302,\n          location,\n        });\n      });\n  }\n\n  invalidLink(req) {\n    return Promise.resolve({\n      status: 302,\n      location: req.config.invalidLinkURL,\n    });\n  }\n\n  invalidVerificationLink(req) {\n    const config = req.config;\n    if (req.query.username && req.params.appId) {\n      const params = qs.stringify({\n        username: req.query.username,\n        appId: req.params.appId,\n      });\n      return Promise.resolve({\n        status: 302,\n        location: `${config.invalidVerificationLinkURL}?${params}`,\n      });\n    } else {\n      return this.invalidLink(req);\n    }\n  }\n\n  missingPublicServerURL() {\n    return Promise.resolve({\n      text: 'Not found.',\n      status: 404,\n    });\n  }\n\n  invalidRequest() {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized';\n    throw error;\n  }\n\n  setConfig(req) {\n    req.config = Config.get(req.params.appId);\n    return Promise.resolve();\n  }\n\n  mountRoutes() {\n    this.route(\n      'GET',\n      '/apps/:appId/verify_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.verifyEmail(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      '/apps/:appId/resend_verification_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resendVerificationEmail(req);\n      }\n    );\n\n    this.route('GET', '/apps/choose_password', req => {\n      return this.changePassword(req);\n    });\n\n    this.route(\n      'POST',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resetPassword(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.requestResetPassword(req);\n      }\n    );\n  }\n\n  expressRouter() {\n    const router = express.Router();\n    router.use('/apps', express.static(public_html));\n    router.use('/', super.expressRouter());\n    return router;\n  }\n}\n\nexport default PublicAPIRouter;\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAmC;AAEnC,MAAMA,WAAW,GAAGC,aAAI,CAACC,OAAO,CAACC,SAAS,EAAE,mBAAmB,CAAC;AAChE,MAAMC,KAAK,GAAGH,aAAI,CAACC,OAAO,CAACC,SAAS,EAAE,aAAa,CAAC;AAE7C,MAAME,eAAe,SAASC,sBAAa,CAAC;EACjDC,WAAW,CAACC,GAAG,EAAE;IACf,MAAM;MAAEC,QAAQ;MAAEC,KAAK,EAAEC;IAAS,CAAC,GAAGH,GAAG,CAACI,KAAK;IAC/C,MAAMF,KAAK,GAAGC,QAAQ,IAAI,OAAOA,QAAQ,KAAK,QAAQ,GAAGA,QAAQ,CAACE,QAAQ,EAAE,GAAGF,QAAQ;IAEvF,MAAMG,KAAK,GAAGN,GAAG,CAACO,MAAM,CAACD,KAAK;IAC9B,MAAME,MAAM,GAAGC,eAAM,CAACC,GAAG,CAACJ,KAAK,CAAC;IAEhC,IAAI,CAACE,MAAM,EAAE;MACX,IAAI,CAACG,cAAc,EAAE;IACvB;IAEA,IAAI,CAACH,MAAM,CAACI,eAAe,EAAE;MAC3B,OAAO,IAAI,CAACC,sBAAsB,EAAE;IACtC;IAEA,IAAI,CAACX,KAAK,IAAI,CAACD,QAAQ,EAAE;MACvB,OAAO,IAAI,CAACa,WAAW,CAACd,GAAG,CAAC;IAC9B;IAEA,MAAMe,cAAc,GAAGP,MAAM,CAACO,cAAc;IAC5C,OAAOA,cAAc,CAAChB,WAAW,CAACE,QAAQ,EAAEC,KAAK,CAAC,CAACc,IAAI,CACrD,MAAM;MACJ,MAAMT,MAAM,GAAGU,oBAAE,CAACC,SAAS,CAAC;QAAEjB;MAAS,CAAC,CAAC;MACzC,OAAOkB,OAAO,CAACzB,OAAO,CAAC;QACrB0B,MAAM,EAAE,GAAG;QACXC,QAAQ,EAAG,GAAEb,MAAM,CAACc,qBAAsB,IAAGf,MAAO;MACtD,CAAC,CAAC;IACJ,CAAC,EACD,MAAM;MACJ,OAAO,IAAI,CAACgB,uBAAuB,CAACvB,GAAG,CAAC;IAC1C,CAAC,CACF;EACH;EAEAwB,uBAAuB,CAACxB,GAAG,EAAE;IAC3B,MAAMC,QAAQ,GAAGD,GAAG,CAACyB,IAAI,CAACxB,QAAQ;IAClC,MAAMK,KAAK,GAAGN,GAAG,CAACO,MAAM,CAACD,KAAK;IAC9B,MAAME,MAAM,GAAGC,eAAM,CAACC,GAAG,CAACJ,KAAK,CAAC;IAEhC,IAAI,CAACE,MAAM,EAAE;MACX,IAAI,CAACG,cAAc,EAAE;IACvB;IAEA,IAAI,CAACH,MAAM,CAACI,eAAe,EAAE;MAC3B,OAAO,IAAI,CAACC,sBAAsB,EAAE;IACtC;IAEA,IAAI,CAACZ,QAAQ,EAAE;MACb,OAAO,IAAI,CAACa,WAAW,CAACd,GAAG,CAAC;IAC9B;IAEA,MAAMe,cAAc,GAAGP,MAAM,CAACO,cAAc;IAE5C,OAAOA,cAAc,CAACS,uBAAuB,CAACvB,QAAQ,CAAC,CAACe,IAAI,CAC1D,MAAM;MACJ,OAAOG,OAAO,CAACzB,OAAO,CAAC;QACrB0B,MAAM,EAAE,GAAG;QACXC,QAAQ,EAAG,GAAEb,MAAM,CAACkB,kBAAmB;MACzC,CAAC,CAAC;IACJ,CAAC,EACD,MAAM;MACJ,OAAOP,OAAO,CAACzB,OAAO,CAAC;QACrB0B,MAAM,EAAE,GAAG;QACXC,QAAQ,EAAG,GAAEb,MAAM,CAACmB,eAAgB;MACtC,CAAC,CAAC;IACJ,CAAC,CACF;EACH;EAEAC,cAAc,CAAC5B,GAAG,EAAE;IAClB,OAAO,IAAImB,OAAO,CAAC,CAACzB,OAAO,EAAEmC,MAAM,KAAK;MACtC,MAAMrB,MAAM,GAAGC,eAAM,CAACC,GAAG,CAACV,GAAG,CAACI,KAAK,CAAC0B,EAAE,CAAC;MAEvC,IAAI,CAACtB,MAAM,EAAE;QACX,IAAI,CAACG,cAAc,EAAE;MACvB;MAEA,IAAI,CAACH,MAAM,CAACI,eAAe,EAAE;QAC3B,OAAOlB,OAAO,CAAC;UACb0B,MAAM,EAAE,GAAG;UACXW,IAAI,EAAE;QACR,CAAC,CAAC;MACJ;MACA;MACAC,WAAE,CAACC,QAAQ,CAACxC,aAAI,CAACC,OAAO,CAACE,KAAK,EAAE,iBAAiB,CAAC,EAAE,OAAO,EAAE,CAACsC,GAAG,EAAEC,IAAI,KAAK;QAC1E,IAAID,GAAG,EAAE;UACP,OAAOL,MAAM,CAACK,GAAG,CAAC;QACpB;QACAC,IAAI,GAAGA,IAAI,CAACC,OAAO,CAAC,kBAAkB,EAAG,IAAG5B,MAAM,CAACI,eAAgB,GAAE,CAAC;QACtElB,OAAO,CAAC;UACNqC,IAAI,EAAEI;QACR,CAAC,CAAC;MACJ,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ;EAEAE,oBAAoB,CAACrC,GAAG,EAAE;IACxB,MAAMQ,MAAM,GAAGR,GAAG,CAACQ,MAAM;IAEzB,IAAI,CAACA,MAAM,EAAE;MACX,IAAI,CAACG,cAAc,EAAE;IACvB;IAEA,IAAI,CAACH,MAAM,CAACI,eAAe,EAAE;MAC3B,OAAO,IAAI,CAACC,sBAAsB,EAAE;IACtC;IAEA,MAAM;MAAEZ,QAAQ;MAAEC,KAAK,EAAEC;IAAS,CAAC,GAAGH,GAAG,CAACI,KAAK;IAC/C,MAAMF,KAAK,GAAGC,QAAQ,IAAI,OAAOA,QAAQ,KAAK,QAAQ,GAAGA,QAAQ,CAACE,QAAQ,EAAE,GAAGF,QAAQ;IAEvF,IAAI,CAACF,QAAQ,IAAI,CAACC,KAAK,EAAE;MACvB,OAAO,IAAI,CAACY,WAAW,CAACd,GAAG,CAAC;IAC9B;IAEA,OAAOQ,MAAM,CAACO,cAAc,CAACuB,uBAAuB,CAACrC,QAAQ,EAAEC,KAAK,CAAC,CAACc,IAAI,CACxE,MAAM;MACJ,MAAMT,MAAM,GAAGU,oBAAE,CAACC,SAAS,CAAC;QAC1BhB,KAAK;QACL4B,EAAE,EAAEtB,MAAM,CAAC+B,aAAa;QACxBtC,QAAQ;QACRuC,GAAG,EAAEhC,MAAM,CAACiC;MACd,CAAC,CAAC;MACF,OAAOtB,OAAO,CAACzB,OAAO,CAAC;QACrB0B,MAAM,EAAE,GAAG;QACXC,QAAQ,EAAG,GAAEb,MAAM,CAACkC,iBAAkB,IAAGnC,MAAO;MAClD,CAAC,CAAC;IACJ,CAAC,EACD,MAAM;MACJ,OAAO,IAAI,CAACO,WAAW,CAACd,GAAG,CAAC;IAC9B,CAAC,CACF;EACH;EAEA2C,aAAa,CAAC3C,GAAG,EAAE;IACjB,MAAMQ,MAAM,GAAGR,GAAG,CAACQ,MAAM;IAEzB,IAAI,CAACA,MAAM,EAAE;MACX,IAAI,CAACG,cAAc,EAAE;IACvB;IAEA,IAAI,CAACH,MAAM,CAACI,eAAe,EAAE;MAC3B,OAAO,IAAI,CAACC,sBAAsB,EAAE;IACtC;IAEA,MAAM;MAAEZ,QAAQ;MAAE2C,YAAY;MAAE1C,KAAK,EAAEC;IAAS,CAAC,GAAGH,GAAG,CAACyB,IAAI;IAC5D,MAAMvB,KAAK,GAAGC,QAAQ,IAAI,OAAOA,QAAQ,KAAK,QAAQ,GAAGA,QAAQ,CAACE,QAAQ,EAAE,GAAGF,QAAQ;IAEvF,IAAI,CAAC,CAACF,QAAQ,IAAI,CAACC,KAAK,IAAI,CAAC0C,YAAY,KAAK5C,GAAG,CAAC6C,GAAG,KAAK,KAAK,EAAE;MAC/D,OAAO,IAAI,CAAC/B,WAAW,CAACd,GAAG,CAAC;IAC9B;IAEA,IAAI,CAACC,QAAQ,EAAE;MACb,MAAM,IAAI6C,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACC,gBAAgB,EAAE,kBAAkB,CAAC;IACzE;IAEA,IAAI,CAAC9C,KAAK,EAAE;MACV,MAAM,IAAI4C,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACE,WAAW,EAAE,eAAe,CAAC;IACjE;IAEA,IAAI,CAACL,YAAY,EAAE;MACjB,MAAM,IAAIE,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACG,gBAAgB,EAAE,kBAAkB,CAAC;IACzE;IAEA,OAAO1C,MAAM,CAACO,cAAc,CACzBoC,cAAc,CAAClD,QAAQ,EAAEC,KAAK,EAAE0C,YAAY,CAAC,CAC7C5B,IAAI,CACH,MAAM;MACJ,OAAOG,OAAO,CAACzB,OAAO,CAAC;QACrB0D,OAAO,EAAE;MACX,CAAC,CAAC;IACJ,CAAC,EACDlB,GAAG,IAAI;MACL,OAAOf,OAAO,CAACzB,OAAO,CAAC;QACrB0D,OAAO,EAAE,KAAK;QACdlB;MACF,CAAC,CAAC;IACJ,CAAC,CACF,CACAlB,IAAI,CAACqC,MAAM,IAAI;MACd,MAAM9C,MAAM,GAAGU,oBAAE,CAACC,SAAS,CAAC;QAC1BjB,QAAQ,EAAEA,QAAQ;QAClBC,KAAK,EAAEA,KAAK;QACZ4B,EAAE,EAAEtB,MAAM,CAAC+B,aAAa;QACxBe,KAAK,EAAED,MAAM,CAACnB,GAAG;QACjBM,GAAG,EAAEhC,MAAM,CAACiC;MACd,CAAC,CAAC;MAEF,IAAIzC,GAAG,CAAC6C,GAAG,EAAE;QACX,IAAIQ,MAAM,CAACD,OAAO,EAAE;UAClB,OAAOjC,OAAO,CAACzB,OAAO,CAAC;YACrB0B,MAAM,EAAE,GAAG;YACXmC,QAAQ,EAAE;UACZ,CAAC,CAAC;QACJ;QACA,IAAIF,MAAM,CAACnB,GAAG,EAAE;UACd,MAAM,IAAIY,WAAK,CAACC,KAAK,CAACD,WAAK,CAACC,KAAK,CAACE,WAAW,EAAG,GAAEI,MAAM,CAACnB,GAAI,EAAC,CAAC;QACjE;MACF;MAEA,MAAMsB,eAAe,GAAGC,kBAAkB,CAACxD,QAAQ,CAAC;MACpD,MAAMoB,QAAQ,GAAGgC,MAAM,CAACD,OAAO,GAC1B,GAAE5C,MAAM,CAACkD,uBAAwB,aAAYF,eAAgB,EAAC,GAC9D,GAAEhD,MAAM,CAACkC,iBAAkB,IAAGnC,MAAO,EAAC;MAE3C,OAAOY,OAAO,CAACzB,OAAO,CAAC;QACrB0B,MAAM,EAAE,GAAG;QACXC;MACF,CAAC,CAAC;IACJ,CAAC,CAAC;EACN;EAEAP,WAAW,CAACd,GAAG,EAAE;IACf,OAAOmB,OAAO,CAACzB,OAAO,CAAC;MACrB0B,MAAM,EAAE,GAAG;MACXC,QAAQ,EAAErB,GAAG,CAACQ,MAAM,CAACmD;IACvB,CAAC,CAAC;EACJ;EAEApC,uBAAuB,CAACvB,GAAG,EAAE;IAC3B,MAAMQ,MAAM,GAAGR,GAAG,CAACQ,MAAM;IACzB,IAAIR,GAAG,CAACI,KAAK,CAACH,QAAQ,IAAID,GAAG,CAACO,MAAM,CAACD,KAAK,EAAE;MAC1C,MAAMC,MAAM,GAAGU,oBAAE,CAACC,SAAS,CAAC;QAC1BjB,QAAQ,EAAED,GAAG,CAACI,KAAK,CAACH,QAAQ;QAC5BK,KAAK,EAAEN,GAAG,CAACO,MAAM,CAACD;MACpB,CAAC,CAAC;MACF,OAAOa,OAAO,CAACzB,OAAO,CAAC;QACrB0B,MAAM,EAAE,GAAG;QACXC,QAAQ,EAAG,GAAEb,MAAM,CAACoD,0BAA2B,IAAGrD,MAAO;MAC3D,CAAC,CAAC;IACJ,CAAC,MAAM;MACL,OAAO,IAAI,CAACO,WAAW,CAACd,GAAG,CAAC;IAC9B;EACF;EAEAa,sBAAsB,GAAG;IACvB,OAAOM,OAAO,CAACzB,OAAO,CAAC;MACrBqC,IAAI,EAAE,YAAY;MAClBX,MAAM,EAAE;IACV,CAAC,CAAC;EACJ;EAEAT,cAAc,GAAG;IACf,MAAM2C,KAAK,GAAG,IAAIP,KAAK,EAAE;IACzBO,KAAK,CAAClC,MAAM,GAAG,GAAG;IAClBkC,KAAK,CAACO,OAAO,GAAG,cAAc;IAC9B,MAAMP,KAAK;EACb;EAEAQ,SAAS,CAAC9D,GAAG,EAAE;IACbA,GAAG,CAACQ,MAAM,GAAGC,eAAM,CAACC,GAAG,CAACV,GAAG,CAACO,MAAM,CAACD,KAAK,CAAC;IACzC,OAAOa,OAAO,CAACzB,OAAO,EAAE;EAC1B;EAEAqE,WAAW,GAAG;IACZ,IAAI,CAACC,KAAK,CACR,KAAK,EACL,2BAA2B,EAC3BhE,GAAG,IAAI;MACL,IAAI,CAAC8D,SAAS,CAAC9D,GAAG,CAAC;IACrB,CAAC,EACDA,GAAG,IAAI;MACL,OAAO,IAAI,CAACD,WAAW,CAACC,GAAG,CAAC;IAC9B,CAAC,CACF;IAED,IAAI,CAACgE,KAAK,CACR,MAAM,EACN,wCAAwC,EACxChE,GAAG,IAAI;MACL,IAAI,CAAC8D,SAAS,CAAC9D,GAAG,CAAC;IACrB,CAAC,EACDA,GAAG,IAAI;MACL,OAAO,IAAI,CAACwB,uBAAuB,CAACxB,GAAG,CAAC;IAC1C,CAAC,CACF;IAED,IAAI,CAACgE,KAAK,CAAC,KAAK,EAAE,uBAAuB,EAAEhE,GAAG,IAAI;MAChD,OAAO,IAAI,CAAC4B,cAAc,CAAC5B,GAAG,CAAC;IACjC,CAAC,CAAC;IAEF,IAAI,CAACgE,KAAK,CACR,MAAM,EACN,qCAAqC,EACrChE,GAAG,IAAI;MACL,IAAI,CAAC8D,SAAS,CAAC9D,GAAG,CAAC;IACrB,CAAC,EACDA,GAAG,IAAI;MACL,OAAO,IAAI,CAAC2C,aAAa,CAAC3C,GAAG,CAAC;IAChC,CAAC,CACF;IAED,IAAI,CAACgE,KAAK,CACR,KAAK,EACL,qCAAqC,EACrChE,GAAG,IAAI;MACL,IAAI,CAAC8D,SAAS,CAAC9D,GAAG,CAAC;IACrB,CAAC,EACDA,GAAG,IAAI;MACL,OAAO,IAAI,CAACqC,oBAAoB,CAACrC,GAAG,CAAC;IACvC,CAAC,CACF;EACH;EAEAiE,aAAa,GAAG;IACd,MAAMC,MAAM,GAAGC,gBAAO,CAACC,MAAM,EAAE;IAC/BF,MAAM,CAACG,GAAG,CAAC,OAAO,EAAEF,gBAAO,CAACG,MAAM,CAAC9E,WAAW,CAAC,CAAC;IAChD0E,MAAM,CAACG,GAAG,CAAC,GAAG,EAAE,KAAK,CAACJ,aAAa,EAAE,CAAC;IACtC,OAAOC,MAAM;EACf;AACF;AAAC;AAAA,eAEcrE,eAAe;AAAA"}
@@ -4,34 +4,24 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = exports.PurgeRouter = void 0;
7
-
8
7
  var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
9
-
10
8
  var middleware = _interopRequireWildcard(require("../middlewares"));
11
-
12
9
  var _node = _interopRequireDefault(require("parse/node"));
13
-
14
10
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
15
-
16
11
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
17
-
18
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
20
13
  class PurgeRouter extends _PromiseRouter.default {
21
14
  handlePurge(req) {
22
15
  if (req.auth.isReadOnly) {
23
16
  throw new _node.default.Error(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to purge a schema.");
24
17
  }
25
-
26
18
  return req.config.database.purgeCollection(req.params.className).then(() => {
27
19
  var cacheAdapter = req.config.cacheController;
28
-
29
20
  if (req.params.className == '_Session') {
30
21
  cacheAdapter.user.clear();
31
22
  } else if (req.params.className == '_Role') {
32
23
  cacheAdapter.role.clear();
33
24
  }
34
-
35
25
  return {
36
26
  response: {}
37
27
  };
@@ -41,20 +31,16 @@ class PurgeRouter extends _PromiseRouter.default {
41
31
  response: {}
42
32
  };
43
33
  }
44
-
45
34
  throw error;
46
35
  });
47
36
  }
48
-
49
37
  mountRoutes() {
50
38
  this.route('DELETE', '/purge/:className', middleware.promiseEnforceMasterKeyAccess, req => {
51
39
  return this.handlePurge(req);
52
40
  });
53
41
  }
54
-
55
42
  }
56
-
57
43
  exports.PurgeRouter = PurgeRouter;
58
44
  var _default = PurgeRouter;
59
45
  exports.default = _default;
60
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1B1cmdlUm91dGVyLmpzIl0sIm5hbWVzIjpbIlB1cmdlUm91dGVyIiwiUHJvbWlzZVJvdXRlciIsImhhbmRsZVB1cmdlIiwicmVxIiwiYXV0aCIsImlzUmVhZE9ubHkiLCJQYXJzZSIsIkVycm9yIiwiT1BFUkFUSU9OX0ZPUkJJRERFTiIsImNvbmZpZyIsImRhdGFiYXNlIiwicHVyZ2VDb2xsZWN0aW9uIiwicGFyYW1zIiwiY2xhc3NOYW1lIiwidGhlbiIsImNhY2hlQWRhcHRlciIsImNhY2hlQ29udHJvbGxlciIsInVzZXIiLCJjbGVhciIsInJvbGUiLCJyZXNwb25zZSIsImNhdGNoIiwiZXJyb3IiLCJjb2RlIiwiT0JKRUNUX05PVF9GT1VORCIsIm1vdW50Um91dGVzIiwicm91dGUiLCJtaWRkbGV3YXJlIiwicHJvbWlzZUVuZm9yY2VNYXN0ZXJLZXlBY2Nlc3MiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7Ozs7Ozs7QUFFTyxNQUFNQSxXQUFOLFNBQTBCQyxzQkFBMUIsQ0FBd0M7QUFDN0NDLEVBQUFBLFdBQVcsQ0FBQ0MsR0FBRCxFQUFNO0FBQ2YsUUFBSUEsR0FBRyxDQUFDQyxJQUFKLENBQVNDLFVBQWIsRUFBeUI7QUFDdkIsWUFBTSxJQUFJQyxjQUFNQyxLQUFWLENBQ0pELGNBQU1DLEtBQU4sQ0FBWUMsbUJBRFIsRUFFSixzREFGSSxDQUFOO0FBSUQ7O0FBQ0QsV0FBT0wsR0FBRyxDQUFDTSxNQUFKLENBQVdDLFFBQVgsQ0FDSkMsZUFESSxDQUNZUixHQUFHLENBQUNTLE1BQUosQ0FBV0MsU0FEdkIsRUFFSkMsSUFGSSxDQUVDLE1BQU07QUFDVixVQUFJQyxZQUFZLEdBQUdaLEdBQUcsQ0FBQ00sTUFBSixDQUFXTyxlQUE5Qjs7QUFDQSxVQUFJYixHQUFHLENBQUNTLE1BQUosQ0FBV0MsU0FBWCxJQUF3QixVQUE1QixFQUF3QztBQUN0Q0UsUUFBQUEsWUFBWSxDQUFDRSxJQUFiLENBQWtCQyxLQUFsQjtBQUNELE9BRkQsTUFFTyxJQUFJZixHQUFHLENBQUNTLE1BQUosQ0FBV0MsU0FBWCxJQUF3QixPQUE1QixFQUFxQztBQUMxQ0UsUUFBQUEsWUFBWSxDQUFDSSxJQUFiLENBQWtCRCxLQUFsQjtBQUNEOztBQUNELGFBQU87QUFBRUUsUUFBQUEsUUFBUSxFQUFFO0FBQVosT0FBUDtBQUNELEtBVkksRUFXSkMsS0FYSSxDQVdFQyxLQUFLLElBQUk7QUFDZCxVQUFJLENBQUNBLEtBQUQsSUFBV0EsS0FBSyxJQUFJQSxLQUFLLENBQUNDLElBQU4sS0FBZWpCLGNBQU1DLEtBQU4sQ0FBWWlCLGdCQUFuRCxFQUFzRTtBQUNwRSxlQUFPO0FBQUVKLFVBQUFBLFFBQVEsRUFBRTtBQUFaLFNBQVA7QUFDRDs7QUFDRCxZQUFNRSxLQUFOO0FBQ0QsS0FoQkksQ0FBUDtBQWlCRDs7QUFFREcsRUFBQUEsV0FBVyxHQUFHO0FBQ1osU0FBS0MsS0FBTCxDQUFXLFFBQVgsRUFBcUIsbUJBQXJCLEVBQTBDQyxVQUFVLENBQUNDLDZCQUFyRCxFQUFvRnpCLEdBQUcsSUFBSTtBQUN6RixhQUFPLEtBQUtELFdBQUwsQ0FBaUJDLEdBQWpCLENBQVA7QUFDRCxLQUZEO0FBR0Q7O0FBL0I0Qzs7O2VBa0NoQ0gsVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9taXNlUm91dGVyIGZyb20gJy4uL1Byb21pc2VSb3V0ZXInO1xuaW1wb3J0ICogYXMgbWlkZGxld2FyZSBmcm9tICcuLi9taWRkbGV3YXJlcyc7XG5pbXBvcnQgUGFyc2UgZnJvbSAncGFyc2Uvbm9kZSc7XG5cbmV4cG9ydCBjbGFzcyBQdXJnZVJvdXRlciBleHRlbmRzIFByb21pc2VSb3V0ZXIge1xuICBoYW5kbGVQdXJnZShyZXEpIHtcbiAgICBpZiAocmVxLmF1dGguaXNSZWFkT25seSkge1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFxuICAgICAgICBQYXJzZS5FcnJvci5PUEVSQVRJT05fRk9SQklEREVOLFxuICAgICAgICBcInJlYWQtb25seSBtYXN0ZXJLZXkgaXNuJ3QgYWxsb3dlZCB0byBwdXJnZSBhIHNjaGVtYS5cIlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIHJlcS5jb25maWcuZGF0YWJhc2VcbiAgICAgIC5wdXJnZUNvbGxlY3Rpb24ocmVxLnBhcmFtcy5jbGFzc05hbWUpXG4gICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgIHZhciBjYWNoZUFkYXB0ZXIgPSByZXEuY29uZmlnLmNhY2hlQ29udHJvbGxlcjtcbiAgICAgICAgaWYgKHJlcS5wYXJhbXMuY2xhc3NOYW1lID09ICdfU2Vzc2lvbicpIHtcbiAgICAgICAgICBjYWNoZUFkYXB0ZXIudXNlci5jbGVhcigpO1xuICAgICAgICB9IGVsc2UgaWYgKHJlcS5wYXJhbXMuY2xhc3NOYW1lID09ICdfUm9sZScpIHtcbiAgICAgICAgICBjYWNoZUFkYXB0ZXIucm9sZS5jbGVhcigpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB7IHJlc3BvbnNlOiB7fSB9O1xuICAgICAgfSlcbiAgICAgIC5jYXRjaChlcnJvciA9PiB7XG4gICAgICAgIGlmICghZXJyb3IgfHwgKGVycm9yICYmIGVycm9yLmNvZGUgPT09IFBhcnNlLkVycm9yLk9CSkVDVF9OT1RfRk9VTkQpKSB7XG4gICAgICAgICAgcmV0dXJuIHsgcmVzcG9uc2U6IHt9IH07XG4gICAgICAgIH1cbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9KTtcbiAgfVxuXG4gIG1vdW50Um91dGVzKCkge1xuICAgIHRoaXMucm91dGUoJ0RFTEVURScsICcvcHVyZ2UvOmNsYXNzTmFtZScsIG1pZGRsZXdhcmUucHJvbWlzZUVuZm9yY2VNYXN0ZXJLZXlBY2Nlc3MsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVQdXJnZShyZXEpO1xuICAgIH0pO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IFB1cmdlUm91dGVyO1xuIl19
46
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQdXJnZVJvdXRlciIsIlByb21pc2VSb3V0ZXIiLCJoYW5kbGVQdXJnZSIsInJlcSIsImF1dGgiLCJpc1JlYWRPbmx5IiwiUGFyc2UiLCJFcnJvciIsIk9QRVJBVElPTl9GT1JCSURERU4iLCJjb25maWciLCJkYXRhYmFzZSIsInB1cmdlQ29sbGVjdGlvbiIsInBhcmFtcyIsImNsYXNzTmFtZSIsInRoZW4iLCJjYWNoZUFkYXB0ZXIiLCJjYWNoZUNvbnRyb2xsZXIiLCJ1c2VyIiwiY2xlYXIiLCJyb2xlIiwicmVzcG9uc2UiLCJjYXRjaCIsImVycm9yIiwiY29kZSIsIk9CSkVDVF9OT1RfRk9VTkQiLCJtb3VudFJvdXRlcyIsInJvdXRlIiwibWlkZGxld2FyZSIsInByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL1JvdXRlcnMvUHVyZ2VSb3V0ZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb21pc2VSb3V0ZXIgZnJvbSAnLi4vUHJvbWlzZVJvdXRlcic7XG5pbXBvcnQgKiBhcyBtaWRkbGV3YXJlIGZyb20gJy4uL21pZGRsZXdhcmVzJztcbmltcG9ydCBQYXJzZSBmcm9tICdwYXJzZS9ub2RlJztcblxuZXhwb3J0IGNsYXNzIFB1cmdlUm91dGVyIGV4dGVuZHMgUHJvbWlzZVJvdXRlciB7XG4gIGhhbmRsZVB1cmdlKHJlcSkge1xuICAgIGlmIChyZXEuYXV0aC5pc1JlYWRPbmx5KSB7XG4gICAgICB0aHJvdyBuZXcgUGFyc2UuRXJyb3IoXG4gICAgICAgIFBhcnNlLkVycm9yLk9QRVJBVElPTl9GT1JCSURERU4sXG4gICAgICAgIFwicmVhZC1vbmx5IG1hc3RlcktleSBpc24ndCBhbGxvd2VkIHRvIHB1cmdlIGEgc2NoZW1hLlwiXG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gcmVxLmNvbmZpZy5kYXRhYmFzZVxuICAgICAgLnB1cmdlQ29sbGVjdGlvbihyZXEucGFyYW1zLmNsYXNzTmFtZSlcbiAgICAgIC50aGVuKCgpID0+IHtcbiAgICAgICAgdmFyIGNhY2hlQWRhcHRlciA9IHJlcS5jb25maWcuY2FjaGVDb250cm9sbGVyO1xuICAgICAgICBpZiAocmVxLnBhcmFtcy5jbGFzc05hbWUgPT0gJ19TZXNzaW9uJykge1xuICAgICAgICAgIGNhY2hlQWRhcHRlci51c2VyLmNsZWFyKCk7XG4gICAgICAgIH0gZWxzZSBpZiAocmVxLnBhcmFtcy5jbGFzc05hbWUgPT0gJ19Sb2xlJykge1xuICAgICAgICAgIGNhY2hlQWRhcHRlci5yb2xlLmNsZWFyKCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHsgcmVzcG9uc2U6IHt9IH07XG4gICAgICB9KVxuICAgICAgLmNhdGNoKGVycm9yID0+IHtcbiAgICAgICAgaWYgKCFlcnJvciB8fCAoZXJyb3IgJiYgZXJyb3IuY29kZSA9PT0gUGFyc2UuRXJyb3IuT0JKRUNUX05PVF9GT1VORCkpIHtcbiAgICAgICAgICByZXR1cm4geyByZXNwb25zZToge30gfTtcbiAgICAgICAgfVxuICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgIH0pO1xuICB9XG5cbiAgbW91bnRSb3V0ZXMoKSB7XG4gICAgdGhpcy5yb3V0ZSgnREVMRVRFJywgJy9wdXJnZS86Y2xhc3NOYW1lJywgbWlkZGxld2FyZS5wcm9taXNlRW5mb3JjZU1hc3RlcktleUFjY2VzcywgcmVxID0+IHtcbiAgICAgIHJldHVybiB0aGlzLmhhbmRsZVB1cmdlKHJlcSk7XG4gICAgfSk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgUHVyZ2VSb3V0ZXI7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUErQjtBQUFBO0FBQUE7QUFFeEIsTUFBTUEsV0FBVyxTQUFTQyxzQkFBYSxDQUFDO0VBQzdDQyxXQUFXLENBQUNDLEdBQUcsRUFBRTtJQUNmLElBQUlBLEdBQUcsQ0FBQ0MsSUFBSSxDQUFDQyxVQUFVLEVBQUU7TUFDdkIsTUFBTSxJQUFJQyxhQUFLLENBQUNDLEtBQUssQ0FDbkJELGFBQUssQ0FBQ0MsS0FBSyxDQUFDQyxtQkFBbUIsRUFDL0Isc0RBQXNELENBQ3ZEO0lBQ0g7SUFDQSxPQUFPTCxHQUFHLENBQUNNLE1BQU0sQ0FBQ0MsUUFBUSxDQUN2QkMsZUFBZSxDQUFDUixHQUFHLENBQUNTLE1BQU0sQ0FBQ0MsU0FBUyxDQUFDLENBQ3JDQyxJQUFJLENBQUMsTUFBTTtNQUNWLElBQUlDLFlBQVksR0FBR1osR0FBRyxDQUFDTSxNQUFNLENBQUNPLGVBQWU7TUFDN0MsSUFBSWIsR0FBRyxDQUFDUyxNQUFNLENBQUNDLFNBQVMsSUFBSSxVQUFVLEVBQUU7UUFDdENFLFlBQVksQ0FBQ0UsSUFBSSxDQUFDQyxLQUFLLEVBQUU7TUFDM0IsQ0FBQyxNQUFNLElBQUlmLEdBQUcsQ0FBQ1MsTUFBTSxDQUFDQyxTQUFTLElBQUksT0FBTyxFQUFFO1FBQzFDRSxZQUFZLENBQUNJLElBQUksQ0FBQ0QsS0FBSyxFQUFFO01BQzNCO01BQ0EsT0FBTztRQUFFRSxRQUFRLEVBQUUsQ0FBQztNQUFFLENBQUM7SUFDekIsQ0FBQyxDQUFDLENBQ0RDLEtBQUssQ0FBQ0MsS0FBSyxJQUFJO01BQ2QsSUFBSSxDQUFDQSxLQUFLLElBQUtBLEtBQUssSUFBSUEsS0FBSyxDQUFDQyxJQUFJLEtBQUtqQixhQUFLLENBQUNDLEtBQUssQ0FBQ2lCLGdCQUFpQixFQUFFO1FBQ3BFLE9BQU87VUFBRUosUUFBUSxFQUFFLENBQUM7UUFBRSxDQUFDO01BQ3pCO01BQ0EsTUFBTUUsS0FBSztJQUNiLENBQUMsQ0FBQztFQUNOO0VBRUFHLFdBQVcsR0FBRztJQUNaLElBQUksQ0FBQ0MsS0FBSyxDQUFDLFFBQVEsRUFBRSxtQkFBbUIsRUFBRUMsVUFBVSxDQUFDQyw2QkFBNkIsRUFBRXpCLEdBQUcsSUFBSTtNQUN6RixPQUFPLElBQUksQ0FBQ0QsV0FBVyxDQUFDQyxHQUFHLENBQUM7SUFDOUIsQ0FBQyxDQUFDO0VBQ0o7QUFDRjtBQUFDO0FBQUEsZUFFY0gsV0FBVztBQUFBIn0=
@@ -4,35 +4,24 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = exports.PushRouter = void 0;
7
-
8
7
  var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
9
-
10
8
  var middleware = _interopRequireWildcard(require("../middlewares"));
11
-
12
9
  var _node = require("parse/node");
13
-
14
10
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
15
-
16
11
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
17
-
18
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
20
13
  class PushRouter extends _PromiseRouter.default {
21
14
  mountRoutes() {
22
15
  this.route('POST', '/push', middleware.promiseEnforceMasterKeyAccess, PushRouter.handlePOST);
23
16
  }
24
-
25
17
  static handlePOST(req) {
26
18
  if (req.auth.isReadOnly) {
27
19
  throw new _node.Parse.Error(_node.Parse.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to send push notifications.");
28
20
  }
29
-
30
21
  const pushController = req.config.pushController;
31
-
32
22
  if (!pushController) {
33
23
  throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Push controller is not set');
34
24
  }
35
-
36
25
  const where = PushRouter.getQueryCondition(req);
37
26
  let resolve;
38
27
  const promise = new Promise(_resolve => {
@@ -54,19 +43,17 @@ class PushRouter extends _PromiseRouter.default {
54
43
  });
55
44
  return promise;
56
45
  }
46
+
57
47
  /**
58
48
  * Get query condition from the request body.
59
49
  * @param {Object} req A request object
60
50
  * @returns {Object} The query condition, the where field in a query api call
61
51
  */
62
-
63
-
64
52
  static getQueryCondition(req) {
65
53
  const body = req.body || {};
66
54
  const hasWhere = typeof body.where !== 'undefined';
67
55
  const hasChannels = typeof body.channels !== 'undefined';
68
56
  let where;
69
-
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.');
72
59
  } else if (hasWhere) {
@@ -80,13 +67,10 @@ class PushRouter extends _PromiseRouter.default {
80
67
  } else {
81
68
  throw new _node.Parse.Error(_node.Parse.Error.PUSH_MISCONFIGURED, 'Sending a push requires either "channels" or a "where" query.');
82
69
  }
83
-
84
70
  return where;
85
71
  }
86
-
87
72
  }
88
-
89
73
  exports.PushRouter = PushRouter;
90
74
  var _default = PushRouter;
91
75
  exports.default = _default;
92
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1B1c2hSb3V0ZXIuanMiXSwibmFtZXMiOlsiUHVzaFJvdXRlciIsIlByb21pc2VSb3V0ZXIiLCJtb3VudFJvdXRlcyIsInJvdXRlIiwibWlkZGxld2FyZSIsInByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzIiwiaGFuZGxlUE9TVCIsInJlcSIsImF1dGgiLCJpc1JlYWRPbmx5IiwiUGFyc2UiLCJFcnJvciIsIk9QRVJBVElPTl9GT1JCSURERU4iLCJwdXNoQ29udHJvbGxlciIsImNvbmZpZyIsIlBVU0hfTUlTQ09ORklHVVJFRCIsIndoZXJlIiwiZ2V0UXVlcnlDb25kaXRpb24iLCJyZXNvbHZlIiwicHJvbWlzZSIsIlByb21pc2UiLCJfcmVzb2x2ZSIsInB1c2hTdGF0dXNJZCIsInNlbmRQdXNoIiwiYm9keSIsIm9iamVjdElkIiwiaGVhZGVycyIsInJlc3BvbnNlIiwicmVzdWx0IiwiY2F0Y2giLCJlcnIiLCJsb2dnZXJDb250cm9sbGVyIiwiZXJyb3IiLCJoYXNXaGVyZSIsImhhc0NoYW5uZWxzIiwiY2hhbm5lbHMiLCIkaW4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7Ozs7Ozs7QUFFTyxNQUFNQSxVQUFOLFNBQXlCQyxzQkFBekIsQ0FBdUM7QUFDNUNDLEVBQUFBLFdBQVcsR0FBRztBQUNaLFNBQUtDLEtBQUwsQ0FBVyxNQUFYLEVBQW1CLE9BQW5CLEVBQTRCQyxVQUFVLENBQUNDLDZCQUF2QyxFQUFzRUwsVUFBVSxDQUFDTSxVQUFqRjtBQUNEOztBQUVnQixTQUFWQSxVQUFVLENBQUNDLEdBQUQsRUFBTTtBQUNyQixRQUFJQSxHQUFHLENBQUNDLElBQUosQ0FBU0MsVUFBYixFQUF5QjtBQUN2QixZQUFNLElBQUlDLFlBQU1DLEtBQVYsQ0FDSkQsWUFBTUMsS0FBTixDQUFZQyxtQkFEUixFQUVKLCtEQUZJLENBQU47QUFJRDs7QUFDRCxVQUFNQyxjQUFjLEdBQUdOLEdBQUcsQ0FBQ08sTUFBSixDQUFXRCxjQUFsQzs7QUFDQSxRQUFJLENBQUNBLGNBQUwsRUFBcUI7QUFDbkIsWUFBTSxJQUFJSCxZQUFNQyxLQUFWLENBQWdCRCxZQUFNQyxLQUFOLENBQVlJLGtCQUE1QixFQUFnRCw0QkFBaEQsQ0FBTjtBQUNEOztBQUVELFVBQU1DLEtBQUssR0FBR2hCLFVBQVUsQ0FBQ2lCLGlCQUFYLENBQTZCVixHQUE3QixDQUFkO0FBQ0EsUUFBSVcsT0FBSjtBQUNBLFVBQU1DLE9BQU8sR0FBRyxJQUFJQyxPQUFKLENBQVlDLFFBQVEsSUFBSTtBQUN0Q0gsTUFBQUEsT0FBTyxHQUFHRyxRQUFWO0FBQ0QsS0FGZSxDQUFoQjtBQUdBLFFBQUlDLFlBQUo7QUFDQVQsSUFBQUEsY0FBYyxDQUNYVSxRQURILENBQ1loQixHQUFHLENBQUNpQixJQURoQixFQUNzQlIsS0FEdEIsRUFDNkJULEdBQUcsQ0FBQ08sTUFEakMsRUFDeUNQLEdBQUcsQ0FBQ0MsSUFEN0MsRUFDbURpQixRQUFRLElBQUk7QUFDM0RILE1BQUFBLFlBQVksR0FBR0csUUFBZjtBQUNBUCxNQUFBQSxPQUFPLENBQUM7QUFDTlEsUUFBQUEsT0FBTyxFQUFFO0FBQ1Asb0NBQTBCSjtBQURuQixTQURIO0FBSU5LLFFBQUFBLFFBQVEsRUFBRTtBQUNSQyxVQUFBQSxNQUFNLEVBQUU7QUFEQTtBQUpKLE9BQUQsQ0FBUDtBQVFELEtBWEgsRUFZR0MsS0FaSCxDQVlTQyxHQUFHLElBQUk7QUFDWnZCLE1BQUFBLEdBQUcsQ0FBQ08sTUFBSixDQUFXaUIsZ0JBQVgsQ0FBNEJDLEtBQTVCLENBQ0csZUFBY1YsWUFBYSw0QkFEOUIsRUFFRVEsR0FGRjtBQUlELEtBakJIO0FBa0JBLFdBQU9YLE9BQVA7QUFDRDtBQUVEO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7OztBQUMwQixTQUFqQkYsaUJBQWlCLENBQUNWLEdBQUQsRUFBTTtBQUM1QixVQUFNaUIsSUFBSSxHQUFHakIsR0FBRyxDQUFDaUIsSUFBSixJQUFZLEVBQXpCO0FBQ0EsVUFBTVMsUUFBUSxHQUFHLE9BQU9ULElBQUksQ0FBQ1IsS0FBWixLQUFzQixXQUF2QztBQUNBLFVBQU1rQixXQUFXLEdBQUcsT0FBT1YsSUFBSSxDQUFDVyxRQUFaLEtBQXlCLFdBQTdDO0FBRUEsUUFBSW5CLEtBQUo7O0FBQ0EsUUFBSWlCLFFBQVEsSUFBSUMsV0FBaEIsRUFBNkI7QUFDM0IsWUFBTSxJQUFJeEIsWUFBTUMsS0FBVixDQUNKRCxZQUFNQyxLQUFOLENBQVlJLGtCQURSLEVBRUoscURBRkksQ0FBTjtBQUlELEtBTEQsTUFLTyxJQUFJa0IsUUFBSixFQUFjO0FBQ25CakIsTUFBQUEsS0FBSyxHQUFHUSxJQUFJLENBQUNSLEtBQWI7QUFDRCxLQUZNLE1BRUEsSUFBSWtCLFdBQUosRUFBaUI7QUFDdEJsQixNQUFBQSxLQUFLLEdBQUc7QUFDTm1CLFFBQUFBLFFBQVEsRUFBRTtBQUNSQyxVQUFBQSxHQUFHLEVBQUVaLElBQUksQ0FBQ1c7QUFERjtBQURKLE9BQVI7QUFLRCxLQU5NLE1BTUE7QUFDTCxZQUFNLElBQUl6QixZQUFNQyxLQUFWLENBQ0pELFlBQU1DLEtBQU4sQ0FBWUksa0JBRFIsRUFFSiwrREFGSSxDQUFOO0FBSUQ7O0FBQ0QsV0FBT0MsS0FBUDtBQUNEOztBQTNFMkM7OztlQThFL0JoQixVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb21pc2VSb3V0ZXIgZnJvbSAnLi4vUHJvbWlzZVJvdXRlcic7XG5pbXBvcnQgKiBhcyBtaWRkbGV3YXJlIGZyb20gJy4uL21pZGRsZXdhcmVzJztcbmltcG9ydCB7IFBhcnNlIH0gZnJvbSAncGFyc2Uvbm9kZSc7XG5cbmV4cG9ydCBjbGFzcyBQdXNoUm91dGVyIGV4dGVuZHMgUHJvbWlzZVJvdXRlciB7XG4gIG1vdW50Um91dGVzKCkge1xuICAgIHRoaXMucm91dGUoJ1BPU1QnLCAnL3B1c2gnLCBtaWRkbGV3YXJlLnByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzLCBQdXNoUm91dGVyLmhhbmRsZVBPU1QpO1xuICB9XG5cbiAgc3RhdGljIGhhbmRsZVBPU1QocmVxKSB7XG4gICAgaWYgKHJlcS5hdXRoLmlzUmVhZE9ubHkpIHtcbiAgICAgIHRocm93IG5ldyBQYXJzZS5FcnJvcihcbiAgICAgICAgUGFyc2UuRXJyb3IuT1BFUkFUSU9OX0ZPUkJJRERFTixcbiAgICAgICAgXCJyZWFkLW9ubHkgbWFzdGVyS2V5IGlzbid0IGFsbG93ZWQgdG8gc2VuZCBwdXNoIG5vdGlmaWNhdGlvbnMuXCJcbiAgICAgICk7XG4gICAgfVxuICAgIGNvbnN0IHB1c2hDb250cm9sbGVyID0gcmVxLmNvbmZpZy5wdXNoQ29udHJvbGxlcjtcbiAgICBpZiAoIXB1c2hDb250cm9sbGVyKSB7XG4gICAgICB0aHJvdyBuZXcgUGFyc2UuRXJyb3IoUGFyc2UuRXJyb3IuUFVTSF9NSVNDT05GSUdVUkVELCAnUHVzaCBjb250cm9sbGVyIGlzIG5vdCBzZXQnKTtcbiAgICB9XG5cbiAgICBjb25zdCB3aGVyZSA9IFB1c2hSb3V0ZXIuZ2V0UXVlcnlDb25kaXRpb24ocmVxKTtcbiAgICBsZXQgcmVzb2x2ZTtcbiAgICBjb25zdCBwcm9taXNlID0gbmV3IFByb21pc2UoX3Jlc29sdmUgPT4ge1xuICAgICAgcmVzb2x2ZSA9IF9yZXNvbHZlO1xuICAgIH0pO1xuICAgIGxldCBwdXNoU3RhdHVzSWQ7XG4gICAgcHVzaENvbnRyb2xsZXJcbiAgICAgIC5zZW5kUHVzaChyZXEuYm9keSwgd2hlcmUsIHJlcS5jb25maWcsIHJlcS5hdXRoLCBvYmplY3RJZCA9PiB7XG4gICAgICAgIHB1c2hTdGF0dXNJZCA9IG9iamVjdElkO1xuICAgICAgICByZXNvbHZlKHtcbiAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICAnWC1QYXJzZS1QdXNoLVN0YXR1cy1JZCc6IHB1c2hTdGF0dXNJZCxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHJlc3BvbnNlOiB7XG4gICAgICAgICAgICByZXN1bHQ6IHRydWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9KVxuICAgICAgLmNhdGNoKGVyciA9PiB7XG4gICAgICAgIHJlcS5jb25maWcubG9nZ2VyQ29udHJvbGxlci5lcnJvcihcbiAgICAgICAgICBgX1B1c2hTdGF0dXMgJHtwdXNoU3RhdHVzSWR9OiBlcnJvciB3aGlsZSBzZW5kaW5nIHB1c2hgLFxuICAgICAgICAgIGVyclxuICAgICAgICApO1xuICAgICAgfSk7XG4gICAgcmV0dXJuIHByb21pc2U7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHF1ZXJ5IGNvbmRpdGlvbiBmcm9tIHRoZSByZXF1ZXN0IGJvZHkuXG4gICAqIEBwYXJhbSB7T2JqZWN0fSByZXEgQSByZXF1ZXN0IG9iamVjdFxuICAgKiBAcmV0dXJucyB7T2JqZWN0fSBUaGUgcXVlcnkgY29uZGl0aW9uLCB0aGUgd2hlcmUgZmllbGQgaW4gYSBxdWVyeSBhcGkgY2FsbFxuICAgKi9cbiAgc3RhdGljIGdldFF1ZXJ5Q29uZGl0aW9uKHJlcSkge1xuICAgIGNvbnN0IGJvZHkgPSByZXEuYm9keSB8fCB7fTtcbiAgICBjb25zdCBoYXNXaGVyZSA9IHR5cGVvZiBib2R5LndoZXJlICE9PSAndW5kZWZpbmVkJztcbiAgICBjb25zdCBoYXNDaGFubmVscyA9IHR5cGVvZiBib2R5LmNoYW5uZWxzICE9PSAndW5kZWZpbmVkJztcblxuICAgIGxldCB3aGVyZTtcbiAgICBpZiAoaGFzV2hlcmUgJiYgaGFzQ2hhbm5lbHMpIHtcbiAgICAgIHRocm93IG5ldyBQYXJzZS5FcnJvcihcbiAgICAgICAgUGFyc2UuRXJyb3IuUFVTSF9NSVNDT05GSUdVUkVELFxuICAgICAgICAnQ2hhbm5lbHMgYW5kIHF1ZXJ5IGNhbiBub3QgYmUgc2V0IGF0IHRoZSBzYW1lIHRpbWUuJ1xuICAgICAgKTtcbiAgICB9IGVsc2UgaWYgKGhhc1doZXJlKSB7XG4gICAgICB3aGVyZSA9IGJvZHkud2hlcmU7XG4gICAgfSBlbHNlIGlmIChoYXNDaGFubmVscykge1xuICAgICAgd2hlcmUgPSB7XG4gICAgICAgIGNoYW5uZWxzOiB7XG4gICAgICAgICAgJGluOiBib2R5LmNoYW5uZWxzLFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFxuICAgICAgICBQYXJzZS5FcnJvci5QVVNIX01JU0NPTkZJR1VSRUQsXG4gICAgICAgICdTZW5kaW5nIGEgcHVzaCByZXF1aXJlcyBlaXRoZXIgXCJjaGFubmVsc1wiIG9yIGEgXCJ3aGVyZVwiIHF1ZXJ5LidcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiB3aGVyZTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQdXNoUm91dGVyO1xuIl19
76
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQdXNoUm91dGVyIiwiUHJvbWlzZVJvdXRlciIsIm1vdW50Um91dGVzIiwicm91dGUiLCJtaWRkbGV3YXJlIiwicHJvbWlzZUVuZm9yY2VNYXN0ZXJLZXlBY2Nlc3MiLCJoYW5kbGVQT1NUIiwicmVxIiwiYXV0aCIsImlzUmVhZE9ubHkiLCJQYXJzZSIsIkVycm9yIiwiT1BFUkFUSU9OX0ZPUkJJRERFTiIsInB1c2hDb250cm9sbGVyIiwiY29uZmlnIiwiUFVTSF9NSVNDT05GSUdVUkVEIiwid2hlcmUiLCJnZXRRdWVyeUNvbmRpdGlvbiIsInJlc29sdmUiLCJwcm9taXNlIiwiUHJvbWlzZSIsIl9yZXNvbHZlIiwicHVzaFN0YXR1c0lkIiwic2VuZFB1c2giLCJib2R5Iiwib2JqZWN0SWQiLCJoZWFkZXJzIiwicmVzcG9uc2UiLCJyZXN1bHQiLCJjYXRjaCIsImVyciIsImxvZ2dlckNvbnRyb2xsZXIiLCJlcnJvciIsImhhc1doZXJlIiwiaGFzQ2hhbm5lbHMiLCJjaGFubmVscyIsIiRpbiJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1B1c2hSb3V0ZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb21pc2VSb3V0ZXIgZnJvbSAnLi4vUHJvbWlzZVJvdXRlcic7XG5pbXBvcnQgKiBhcyBtaWRkbGV3YXJlIGZyb20gJy4uL21pZGRsZXdhcmVzJztcbmltcG9ydCB7IFBhcnNlIH0gZnJvbSAncGFyc2Uvbm9kZSc7XG5cbmV4cG9ydCBjbGFzcyBQdXNoUm91dGVyIGV4dGVuZHMgUHJvbWlzZVJvdXRlciB7XG4gIG1vdW50Um91dGVzKCkge1xuICAgIHRoaXMucm91dGUoJ1BPU1QnLCAnL3B1c2gnLCBtaWRkbGV3YXJlLnByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzLCBQdXNoUm91dGVyLmhhbmRsZVBPU1QpO1xuICB9XG5cbiAgc3RhdGljIGhhbmRsZVBPU1QocmVxKSB7XG4gICAgaWYgKHJlcS5hdXRoLmlzUmVhZE9ubHkpIHtcbiAgICAgIHRocm93IG5ldyBQYXJzZS5FcnJvcihcbiAgICAgICAgUGFyc2UuRXJyb3IuT1BFUkFUSU9OX0ZPUkJJRERFTixcbiAgICAgICAgXCJyZWFkLW9ubHkgbWFzdGVyS2V5IGlzbid0IGFsbG93ZWQgdG8gc2VuZCBwdXNoIG5vdGlmaWNhdGlvbnMuXCJcbiAgICAgICk7XG4gICAgfVxuICAgIGNvbnN0IHB1c2hDb250cm9sbGVyID0gcmVxLmNvbmZpZy5wdXNoQ29udHJvbGxlcjtcbiAgICBpZiAoIXB1c2hDb250cm9sbGVyKSB7XG4gICAgICB0aHJvdyBuZXcgUGFyc2UuRXJyb3IoUGFyc2UuRXJyb3IuUFVTSF9NSVNDT05GSUdVUkVELCAnUHVzaCBjb250cm9sbGVyIGlzIG5vdCBzZXQnKTtcbiAgICB9XG5cbiAgICBjb25zdCB3aGVyZSA9IFB1c2hSb3V0ZXIuZ2V0UXVlcnlDb25kaXRpb24ocmVxKTtcbiAgICBsZXQgcmVzb2x2ZTtcbiAgICBjb25zdCBwcm9taXNlID0gbmV3IFByb21pc2UoX3Jlc29sdmUgPT4ge1xuICAgICAgcmVzb2x2ZSA9IF9yZXNvbHZlO1xuICAgIH0pO1xuICAgIGxldCBwdXNoU3RhdHVzSWQ7XG4gICAgcHVzaENvbnRyb2xsZXJcbiAgICAgIC5zZW5kUHVzaChyZXEuYm9keSwgd2hlcmUsIHJlcS5jb25maWcsIHJlcS5hdXRoLCBvYmplY3RJZCA9PiB7XG4gICAgICAgIHB1c2hTdGF0dXNJZCA9IG9iamVjdElkO1xuICAgICAgICByZXNvbHZlKHtcbiAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICAnWC1QYXJzZS1QdXNoLVN0YXR1cy1JZCc6IHB1c2hTdGF0dXNJZCxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHJlc3BvbnNlOiB7XG4gICAgICAgICAgICByZXN1bHQ6IHRydWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgICB9KVxuICAgICAgLmNhdGNoKGVyciA9PiB7XG4gICAgICAgIHJlcS5jb25maWcubG9nZ2VyQ29udHJvbGxlci5lcnJvcihcbiAgICAgICAgICBgX1B1c2hTdGF0dXMgJHtwdXNoU3RhdHVzSWR9OiBlcnJvciB3aGlsZSBzZW5kaW5nIHB1c2hgLFxuICAgICAgICAgIGVyclxuICAgICAgICApO1xuICAgICAgfSk7XG4gICAgcmV0dXJuIHByb21pc2U7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHF1ZXJ5IGNvbmRpdGlvbiBmcm9tIHRoZSByZXF1ZXN0IGJvZHkuXG4gICAqIEBwYXJhbSB7T2JqZWN0fSByZXEgQSByZXF1ZXN0IG9iamVjdFxuICAgKiBAcmV0dXJucyB7T2JqZWN0fSBUaGUgcXVlcnkgY29uZGl0aW9uLCB0aGUgd2hlcmUgZmllbGQgaW4gYSBxdWVyeSBhcGkgY2FsbFxuICAgKi9cbiAgc3RhdGljIGdldFF1ZXJ5Q29uZGl0aW9uKHJlcSkge1xuICAgIGNvbnN0IGJvZHkgPSByZXEuYm9keSB8fCB7fTtcbiAgICBjb25zdCBoYXNXaGVyZSA9IHR5cGVvZiBib2R5LndoZXJlICE9PSAndW5kZWZpbmVkJztcbiAgICBjb25zdCBoYXNDaGFubmVscyA9IHR5cGVvZiBib2R5LmNoYW5uZWxzICE9PSAndW5kZWZpbmVkJztcblxuICAgIGxldCB3aGVyZTtcbiAgICBpZiAoaGFzV2hlcmUgJiYgaGFzQ2hhbm5lbHMpIHtcbiAgICAgIHRocm93IG5ldyBQYXJzZS5FcnJvcihcbiAgICAgICAgUGFyc2UuRXJyb3IuUFVTSF9NSVNDT05GSUdVUkVELFxuICAgICAgICAnQ2hhbm5lbHMgYW5kIHF1ZXJ5IGNhbiBub3QgYmUgc2V0IGF0IHRoZSBzYW1lIHRpbWUuJ1xuICAgICAgKTtcbiAgICB9IGVsc2UgaWYgKGhhc1doZXJlKSB7XG4gICAgICB3aGVyZSA9IGJvZHkud2hlcmU7XG4gICAgfSBlbHNlIGlmIChoYXNDaGFubmVscykge1xuICAgICAgd2hlcmUgPSB7XG4gICAgICAgIGNoYW5uZWxzOiB7XG4gICAgICAgICAgJGluOiBib2R5LmNoYW5uZWxzLFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFxuICAgICAgICBQYXJzZS5FcnJvci5QVVNIX01JU0NPTkZJR1VSRUQsXG4gICAgICAgICdTZW5kaW5nIGEgcHVzaCByZXF1aXJlcyBlaXRoZXIgXCJjaGFubmVsc1wiIG9yIGEgXCJ3aGVyZVwiIHF1ZXJ5LidcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiB3aGVyZTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQdXNoUm91dGVyO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFBbUM7QUFBQTtBQUFBO0FBRTVCLE1BQU1BLFVBQVUsU0FBU0Msc0JBQWEsQ0FBQztFQUM1Q0MsV0FBVyxHQUFHO0lBQ1osSUFBSSxDQUFDQyxLQUFLLENBQUMsTUFBTSxFQUFFLE9BQU8sRUFBRUMsVUFBVSxDQUFDQyw2QkFBNkIsRUFBRUwsVUFBVSxDQUFDTSxVQUFVLENBQUM7RUFDOUY7RUFFQSxPQUFPQSxVQUFVLENBQUNDLEdBQUcsRUFBRTtJQUNyQixJQUFJQSxHQUFHLENBQUNDLElBQUksQ0FBQ0MsVUFBVSxFQUFFO01BQ3ZCLE1BQU0sSUFBSUMsV0FBSyxDQUFDQyxLQUFLLENBQ25CRCxXQUFLLENBQUNDLEtBQUssQ0FBQ0MsbUJBQW1CLEVBQy9CLCtEQUErRCxDQUNoRTtJQUNIO0lBQ0EsTUFBTUMsY0FBYyxHQUFHTixHQUFHLENBQUNPLE1BQU0sQ0FBQ0QsY0FBYztJQUNoRCxJQUFJLENBQUNBLGNBQWMsRUFBRTtNQUNuQixNQUFNLElBQUlILFdBQUssQ0FBQ0MsS0FBSyxDQUFDRCxXQUFLLENBQUNDLEtBQUssQ0FBQ0ksa0JBQWtCLEVBQUUsNEJBQTRCLENBQUM7SUFDckY7SUFFQSxNQUFNQyxLQUFLLEdBQUdoQixVQUFVLENBQUNpQixpQkFBaUIsQ0FBQ1YsR0FBRyxDQUFDO0lBQy9DLElBQUlXLE9BQU87SUFDWCxNQUFNQyxPQUFPLEdBQUcsSUFBSUMsT0FBTyxDQUFDQyxRQUFRLElBQUk7TUFDdENILE9BQU8sR0FBR0csUUFBUTtJQUNwQixDQUFDLENBQUM7SUFDRixJQUFJQyxZQUFZO0lBQ2hCVCxjQUFjLENBQ1hVLFFBQVEsQ0FBQ2hCLEdBQUcsQ0FBQ2lCLElBQUksRUFBRVIsS0FBSyxFQUFFVCxHQUFHLENBQUNPLE1BQU0sRUFBRVAsR0FBRyxDQUFDQyxJQUFJLEVBQUVpQixRQUFRLElBQUk7TUFDM0RILFlBQVksR0FBR0csUUFBUTtNQUN2QlAsT0FBTyxDQUFDO1FBQ05RLE9BQU8sRUFBRTtVQUNQLHdCQUF3QixFQUFFSjtRQUM1QixDQUFDO1FBQ0RLLFFBQVEsRUFBRTtVQUNSQyxNQUFNLEVBQUU7UUFDVjtNQUNGLENBQUMsQ0FBQztJQUNKLENBQUMsQ0FBQyxDQUNEQyxLQUFLLENBQUNDLEdBQUcsSUFBSTtNQUNadkIsR0FBRyxDQUFDTyxNQUFNLENBQUNpQixnQkFBZ0IsQ0FBQ0MsS0FBSyxDQUM5QixlQUFjVixZQUFhLDRCQUEyQixFQUN2RFEsR0FBRyxDQUNKO0lBQ0gsQ0FBQyxDQUFDO0lBQ0osT0FBT1gsT0FBTztFQUNoQjs7RUFFQTtBQUNGO0FBQ0E7QUFDQTtBQUNBO0VBQ0UsT0FBT0YsaUJBQWlCLENBQUNWLEdBQUcsRUFBRTtJQUM1QixNQUFNaUIsSUFBSSxHQUFHakIsR0FBRyxDQUFDaUIsSUFBSSxJQUFJLENBQUMsQ0FBQztJQUMzQixNQUFNUyxRQUFRLEdBQUcsT0FBT1QsSUFBSSxDQUFDUixLQUFLLEtBQUssV0FBVztJQUNsRCxNQUFNa0IsV0FBVyxHQUFHLE9BQU9WLElBQUksQ0FBQ1csUUFBUSxLQUFLLFdBQVc7SUFFeEQsSUFBSW5CLEtBQUs7SUFDVCxJQUFJaUIsUUFBUSxJQUFJQyxXQUFXLEVBQUU7TUFDM0IsTUFBTSxJQUFJeEIsV0FBSyxDQUFDQyxLQUFLLENBQ25CRCxXQUFLLENBQUNDLEtBQUssQ0FBQ0ksa0JBQWtCLEVBQzlCLHFEQUFxRCxDQUN0RDtJQUNILENBQUMsTUFBTSxJQUFJa0IsUUFBUSxFQUFFO01BQ25CakIsS0FBSyxHQUFHUSxJQUFJLENBQUNSLEtBQUs7SUFDcEIsQ0FBQyxNQUFNLElBQUlrQixXQUFXLEVBQUU7TUFDdEJsQixLQUFLLEdBQUc7UUFDTm1CLFFBQVEsRUFBRTtVQUNSQyxHQUFHLEVBQUVaLElBQUksQ0FBQ1c7UUFDWjtNQUNGLENBQUM7SUFDSCxDQUFDLE1BQU07TUFDTCxNQUFNLElBQUl6QixXQUFLLENBQUNDLEtBQUssQ0FDbkJELFdBQUssQ0FBQ0MsS0FBSyxDQUFDSSxrQkFBa0IsRUFDOUIsK0RBQStELENBQ2hFO0lBQ0g7SUFDQSxPQUFPQyxLQUFLO0VBQ2Q7QUFDRjtBQUFDO0FBQUEsZUFFY2hCLFVBQVU7QUFBQSJ9
@@ -4,16 +4,12 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = exports.RolesRouter = void 0;
7
-
8
7
  var _ClassesRouter = _interopRequireDefault(require("./ClassesRouter"));
9
-
10
8
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
-
12
9
  class RolesRouter extends _ClassesRouter.default {
13
10
  className() {
14
11
  return '_Role';
15
12
  }
16
-
17
13
  mountRoutes() {
18
14
  this.route('GET', '/roles', req => {
19
15
  return this.handleFind(req);
@@ -31,10 +27,8 @@ class RolesRouter extends _ClassesRouter.default {
31
27
  return this.handleDelete(req);
32
28
  });
33
29
  }
34
-
35
30
  }
36
-
37
31
  exports.RolesRouter = RolesRouter;
38
32
  var _default = RolesRouter;
39
33
  exports.default = _default;
40
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1JvbGVzUm91dGVyLmpzIl0sIm5hbWVzIjpbIlJvbGVzUm91dGVyIiwiQ2xhc3Nlc1JvdXRlciIsImNsYXNzTmFtZSIsIm1vdW50Um91dGVzIiwicm91dGUiLCJyZXEiLCJoYW5kbGVGaW5kIiwiaGFuZGxlR2V0IiwiaGFuZGxlQ3JlYXRlIiwiaGFuZGxlVXBkYXRlIiwiaGFuZGxlRGVsZXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7QUFFTyxNQUFNQSxXQUFOLFNBQTBCQyxzQkFBMUIsQ0FBd0M7QUFDN0NDLEVBQUFBLFNBQVMsR0FBRztBQUNWLFdBQU8sT0FBUDtBQUNEOztBQUVEQyxFQUFBQSxXQUFXLEdBQUc7QUFDWixTQUFLQyxLQUFMLENBQVcsS0FBWCxFQUFrQixRQUFsQixFQUE0QkMsR0FBRyxJQUFJO0FBQ2pDLGFBQU8sS0FBS0MsVUFBTCxDQUFnQkQsR0FBaEIsQ0FBUDtBQUNELEtBRkQ7QUFHQSxTQUFLRCxLQUFMLENBQVcsS0FBWCxFQUFrQixrQkFBbEIsRUFBc0NDLEdBQUcsSUFBSTtBQUMzQyxhQUFPLEtBQUtFLFNBQUwsQ0FBZUYsR0FBZixDQUFQO0FBQ0QsS0FGRDtBQUdBLFNBQUtELEtBQUwsQ0FBVyxNQUFYLEVBQW1CLFFBQW5CLEVBQTZCQyxHQUFHLElBQUk7QUFDbEMsYUFBTyxLQUFLRyxZQUFMLENBQWtCSCxHQUFsQixDQUFQO0FBQ0QsS0FGRDtBQUdBLFNBQUtELEtBQUwsQ0FBVyxLQUFYLEVBQWtCLGtCQUFsQixFQUFzQ0MsR0FBRyxJQUFJO0FBQzNDLGFBQU8sS0FBS0ksWUFBTCxDQUFrQkosR0FBbEIsQ0FBUDtBQUNELEtBRkQ7QUFHQSxTQUFLRCxLQUFMLENBQVcsUUFBWCxFQUFxQixrQkFBckIsRUFBeUNDLEdBQUcsSUFBSTtBQUM5QyxhQUFPLEtBQUtLLFlBQUwsQ0FBa0JMLEdBQWxCLENBQVA7QUFDRCxLQUZEO0FBR0Q7O0FBckI0Qzs7O2VBd0JoQ0wsVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDbGFzc2VzUm91dGVyIGZyb20gJy4vQ2xhc3Nlc1JvdXRlcic7XG5cbmV4cG9ydCBjbGFzcyBSb2xlc1JvdXRlciBleHRlbmRzIENsYXNzZXNSb3V0ZXIge1xuICBjbGFzc05hbWUoKSB7XG4gICAgcmV0dXJuICdfUm9sZSc7XG4gIH1cblxuICBtb3VudFJvdXRlcygpIHtcbiAgICB0aGlzLnJvdXRlKCdHRVQnLCAnL3JvbGVzJywgcmVxID0+IHtcbiAgICAgIHJldHVybiB0aGlzLmhhbmRsZUZpbmQocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdHRVQnLCAnL3JvbGVzLzpvYmplY3RJZCcsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVHZXQocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdQT1NUJywgJy9yb2xlcycsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVDcmVhdGUocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdQVVQnLCAnL3JvbGVzLzpvYmplY3RJZCcsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVVcGRhdGUocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdERUxFVEUnLCAnL3JvbGVzLzpvYmplY3RJZCcsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVEZWxldGUocmVxKTtcbiAgICB9KTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBSb2xlc1JvdXRlcjtcbiJdfQ==
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSb2xlc1JvdXRlciIsIkNsYXNzZXNSb3V0ZXIiLCJjbGFzc05hbWUiLCJtb3VudFJvdXRlcyIsInJvdXRlIiwicmVxIiwiaGFuZGxlRmluZCIsImhhbmRsZUdldCIsImhhbmRsZUNyZWF0ZSIsImhhbmRsZVVwZGF0ZSIsImhhbmRsZURlbGV0ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1JvbGVzUm91dGVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDbGFzc2VzUm91dGVyIGZyb20gJy4vQ2xhc3Nlc1JvdXRlcic7XG5cbmV4cG9ydCBjbGFzcyBSb2xlc1JvdXRlciBleHRlbmRzIENsYXNzZXNSb3V0ZXIge1xuICBjbGFzc05hbWUoKSB7XG4gICAgcmV0dXJuICdfUm9sZSc7XG4gIH1cblxuICBtb3VudFJvdXRlcygpIHtcbiAgICB0aGlzLnJvdXRlKCdHRVQnLCAnL3JvbGVzJywgcmVxID0+IHtcbiAgICAgIHJldHVybiB0aGlzLmhhbmRsZUZpbmQocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdHRVQnLCAnL3JvbGVzLzpvYmplY3RJZCcsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVHZXQocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdQT1NUJywgJy9yb2xlcycsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVDcmVhdGUocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdQVVQnLCAnL3JvbGVzLzpvYmplY3RJZCcsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVVcGRhdGUocmVxKTtcbiAgICB9KTtcbiAgICB0aGlzLnJvdXRlKCdERUxFVEUnLCAnL3JvbGVzLzpvYmplY3RJZCcsIHJlcSA9PiB7XG4gICAgICByZXR1cm4gdGhpcy5oYW5kbGVEZWxldGUocmVxKTtcbiAgICB9KTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBSb2xlc1JvdXRlcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7QUFBNEM7QUFFckMsTUFBTUEsV0FBVyxTQUFTQyxzQkFBYSxDQUFDO0VBQzdDQyxTQUFTLEdBQUc7SUFDVixPQUFPLE9BQU87RUFDaEI7RUFFQUMsV0FBVyxHQUFHO0lBQ1osSUFBSSxDQUFDQyxLQUFLLENBQUMsS0FBSyxFQUFFLFFBQVEsRUFBRUMsR0FBRyxJQUFJO01BQ2pDLE9BQU8sSUFBSSxDQUFDQyxVQUFVLENBQUNELEdBQUcsQ0FBQztJQUM3QixDQUFDLENBQUM7SUFDRixJQUFJLENBQUNELEtBQUssQ0FBQyxLQUFLLEVBQUUsa0JBQWtCLEVBQUVDLEdBQUcsSUFBSTtNQUMzQyxPQUFPLElBQUksQ0FBQ0UsU0FBUyxDQUFDRixHQUFHLENBQUM7SUFDNUIsQ0FBQyxDQUFDO0lBQ0YsSUFBSSxDQUFDRCxLQUFLLENBQUMsTUFBTSxFQUFFLFFBQVEsRUFBRUMsR0FBRyxJQUFJO01BQ2xDLE9BQU8sSUFBSSxDQUFDRyxZQUFZLENBQUNILEdBQUcsQ0FBQztJQUMvQixDQUFDLENBQUM7SUFDRixJQUFJLENBQUNELEtBQUssQ0FBQyxLQUFLLEVBQUUsa0JBQWtCLEVBQUVDLEdBQUcsSUFBSTtNQUMzQyxPQUFPLElBQUksQ0FBQ0ksWUFBWSxDQUFDSixHQUFHLENBQUM7SUFDL0IsQ0FBQyxDQUFDO0lBQ0YsSUFBSSxDQUFDRCxLQUFLLENBQUMsUUFBUSxFQUFFLGtCQUFrQixFQUFFQyxHQUFHLElBQUk7TUFDOUMsT0FBTyxJQUFJLENBQUNLLFlBQVksQ0FBQ0wsR0FBRyxDQUFDO0lBQy9CLENBQUMsQ0FBQztFQUNKO0FBQ0Y7QUFBQztBQUFBLGVBRWNMLFdBQVc7QUFBQSJ9