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
@@ -1,90 +1,70 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.PublicAPIRouter = undefined;
7
-
8
- var _PromiseRouter = require('../PromiseRouter');
9
-
10
- var _PromiseRouter2 = _interopRequireDefault(_PromiseRouter);
11
-
12
- var _Config = require('../Config');
13
-
14
- var _Config2 = _interopRequireDefault(_Config);
15
-
16
- var _express = require('express');
17
-
18
- var _express2 = _interopRequireDefault(_express);
19
-
20
- var _path = require('path');
21
-
22
- var _path2 = _interopRequireDefault(_path);
23
-
24
- var _fs = require('fs');
25
-
26
- var _fs2 = _interopRequireDefault(_fs);
27
-
28
- var _querystring = require('querystring');
29
-
30
- var _querystring2 = _interopRequireDefault(_querystring);
31
-
32
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
33
-
34
- const public_html = _path2.default.resolve(__dirname, "../../public_html");
35
- const views = _path2.default.resolve(__dirname, '../../views');
36
-
37
- class PublicAPIRouter extends _PromiseRouter2.default {
38
-
6
+ exports.default = exports.PublicAPIRouter = void 0;
7
+ var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
8
+ var _Config = _interopRequireDefault(require("../Config"));
9
+ var _express = _interopRequireDefault(require("express"));
10
+ var _path = _interopRequireDefault(require("path"));
11
+ var _fs = _interopRequireDefault(require("fs"));
12
+ var _querystring = _interopRequireDefault(require("querystring"));
13
+ var _node = require("parse/node");
14
+ var _Deprecator = _interopRequireDefault(require("../Deprecator/Deprecator"));
15
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
16
+ const public_html = _path.default.resolve(__dirname, '../../public_html');
17
+ const views = _path.default.resolve(__dirname, '../../views');
18
+ class PublicAPIRouter extends _PromiseRouter.default {
19
+ constructor() {
20
+ super();
21
+ _Deprecator.default.logRuntimeDeprecation({
22
+ usage: 'PublicAPIRouter',
23
+ solution: 'pages.enableRouter'
24
+ });
25
+ }
39
26
  verifyEmail(req) {
40
- const { token, username } = req.query;
27
+ const {
28
+ token: rawToken
29
+ } = req.query;
30
+ const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
41
31
  const appId = req.params.appId;
42
- const config = _Config2.default.get(appId);
43
-
32
+ const config = _Config.default.get(appId);
44
33
  if (!config) {
45
34
  this.invalidRequest();
46
35
  }
47
-
48
36
  if (!config.publicServerURL) {
49
37
  return this.missingPublicServerURL();
50
38
  }
51
-
52
- if (!token || !username) {
39
+ if (!token) {
53
40
  return this.invalidLink(req);
54
41
  }
55
-
56
42
  const userController = config.userController;
57
- return userController.verifyEmail(username, token).then(() => {
58
- const params = _querystring2.default.stringify({ username });
43
+ return userController.verifyEmail(token).then(() => {
59
44
  return Promise.resolve({
60
45
  status: 302,
61
- location: `${config.verifyEmailSuccessURL}?${params}`
46
+ location: `${config.verifyEmailSuccessURL}`
62
47
  });
63
48
  }, () => {
64
- return this.invalidVerificationLink(req);
49
+ return this.invalidVerificationLink(req, token);
65
50
  });
66
51
  }
67
-
68
52
  resendVerificationEmail(req) {
69
- const username = req.body.username;
53
+ const username = req.body?.username;
70
54
  const appId = req.params.appId;
71
- const config = _Config2.default.get(appId);
72
-
55
+ const config = _Config.default.get(appId);
73
56
  if (!config) {
74
57
  this.invalidRequest();
75
58
  }
76
-
77
59
  if (!config.publicServerURL) {
78
60
  return this.missingPublicServerURL();
79
61
  }
80
-
81
- if (!username) {
62
+ const token = req.body.token;
63
+ if (!username && !token) {
82
64
  return this.invalidLink(req);
83
65
  }
84
-
85
66
  const userController = config.userController;
86
-
87
- return userController.resendVerificationEmail(username).then(() => {
67
+ return userController.resendVerificationEmail(username, req, token).then(() => {
88
68
  return Promise.resolve({
89
69
  status: 302,
90
70
  location: `${config.linkSendSuccessURL}`
@@ -96,15 +76,12 @@ class PublicAPIRouter extends _PromiseRouter2.default {
96
76
  });
97
77
  });
98
78
  }
99
-
100
79
  changePassword(req) {
101
80
  return new Promise((resolve, reject) => {
102
- const config = _Config2.default.get(req.query.id);
103
-
81
+ const config = _Config.default.get(req.query.id);
104
82
  if (!config) {
105
83
  this.invalidRequest();
106
84
  }
107
-
108
85
  if (!config.publicServerURL) {
109
86
  return resolve({
110
87
  status: 404,
@@ -112,38 +89,38 @@ class PublicAPIRouter extends _PromiseRouter2.default {
112
89
  });
113
90
  }
114
91
  // Should we keep the file in memory or leave like that?
115
- _fs2.default.readFile(_path2.default.resolve(views, "choose_password"), 'utf-8', (err, data) => {
92
+ _fs.default.readFile(_path.default.resolve(views, 'choose_password'), 'utf-8', (err, data) => {
116
93
  if (err) {
117
94
  return reject(err);
118
95
  }
119
- data = data.replace("PARSE_SERVER_URL", `'${config.publicServerURL}'`);
96
+ data = data.replace('PARSE_SERVER_URL', `'${config.publicServerURL}'`);
120
97
  resolve({
121
98
  text: data
122
99
  });
123
100
  });
124
101
  });
125
102
  }
126
-
127
103
  requestResetPassword(req) {
128
-
129
104
  const config = req.config;
130
-
131
105
  if (!config) {
132
106
  this.invalidRequest();
133
107
  }
134
-
135
108
  if (!config.publicServerURL) {
136
109
  return this.missingPublicServerURL();
137
110
  }
138
-
139
- const { username, token } = req.query;
140
-
141
- if (!username || !token) {
111
+ const {
112
+ token: rawToken
113
+ } = req.query;
114
+ const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
115
+ if (!token) {
142
116
  return this.invalidLink(req);
143
117
  }
144
-
145
- return config.userController.checkResetTokenValidity(username, token).then(() => {
146
- const params = _querystring2.default.stringify({ token, id: config.applicationId, username, app: config.appName });
118
+ return config.userController.checkResetTokenValidity(token).then(() => {
119
+ const params = _querystring.default.stringify({
120
+ token,
121
+ id: config.applicationId,
122
+ app: config.appName
123
+ });
147
124
  return Promise.resolve({
148
125
  status: 302,
149
126
  location: `${config.choosePasswordURL}?${params}`
@@ -152,55 +129,80 @@ class PublicAPIRouter extends _PromiseRouter2.default {
152
129
  return this.invalidLink(req);
153
130
  });
154
131
  }
155
-
156
132
  resetPassword(req) {
157
-
158
133
  const config = req.config;
159
-
160
134
  if (!config) {
161
135
  this.invalidRequest();
162
136
  }
163
-
164
137
  if (!config.publicServerURL) {
165
138
  return this.missingPublicServerURL();
166
139
  }
167
-
168
140
  const {
169
- username,
170
- token,
171
- new_password
172
- } = req.body;
173
-
174
- if (!username || !token || !new_password) {
141
+ new_password,
142
+ token: rawToken
143
+ } = req.body || {};
144
+ const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
145
+ if ((!token || !new_password) && req.xhr === false) {
175
146
  return this.invalidLink(req);
176
147
  }
177
-
178
- return config.userController.updatePassword(username, token, new_password).then(() => {
179
- const params = _querystring2.default.stringify({ username: username });
148
+ if (!token) {
149
+ throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, 'Missing token');
150
+ }
151
+ if (!new_password) {
152
+ throw new _node.Parse.Error(_node.Parse.Error.PASSWORD_MISSING, 'Missing password');
153
+ }
154
+ return config.userController.updatePassword(token, new_password).then(() => {
180
155
  return Promise.resolve({
181
- status: 302,
182
- location: `${config.passwordResetSuccessURL}?${params}`
156
+ success: true
183
157
  });
184
158
  }, err => {
185
- const params = _querystring2.default.stringify({ username: username, token: token, id: config.applicationId, error: err, app: config.appName });
159
+ return Promise.resolve({
160
+ success: false,
161
+ err
162
+ });
163
+ }).then(result => {
164
+ const queryString = {
165
+ token: token,
166
+ id: config.applicationId,
167
+ error: result.err,
168
+ app: config.appName
169
+ };
170
+ if (result?.err === 'The password reset link has expired') {
171
+ delete queryString.token;
172
+ queryString.token = token;
173
+ }
174
+ const params = _querystring.default.stringify(queryString);
175
+ if (req.xhr) {
176
+ if (result.success) {
177
+ return Promise.resolve({
178
+ status: 200,
179
+ response: 'Password successfully reset'
180
+ });
181
+ }
182
+ if (result.err) {
183
+ throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, `${result.err}`);
184
+ }
185
+ }
186
+ const location = result.success ? `${config.passwordResetSuccessURL}` : `${config.choosePasswordURL}?${params}`;
186
187
  return Promise.resolve({
187
188
  status: 302,
188
- location: `${config.choosePasswordURL}?${params}`
189
+ location
189
190
  });
190
191
  });
191
192
  }
192
-
193
193
  invalidLink(req) {
194
194
  return Promise.resolve({
195
195
  status: 302,
196
196
  location: req.config.invalidLinkURL
197
197
  });
198
198
  }
199
-
200
- invalidVerificationLink(req) {
199
+ invalidVerificationLink(req, token) {
201
200
  const config = req.config;
202
- if (req.query.username && req.params.appId) {
203
- const params = _querystring2.default.stringify({ username: req.query.username, appId: req.params.appId });
201
+ if (req.params.appId) {
202
+ const params = _querystring.default.stringify({
203
+ appId: req.params.appId,
204
+ token
205
+ });
204
206
  return Promise.resolve({
205
207
  status: 302,
206
208
  location: `${config.invalidVerificationLinkURL}?${params}`
@@ -209,64 +211,54 @@ class PublicAPIRouter extends _PromiseRouter2.default {
209
211
  return this.invalidLink(req);
210
212
  }
211
213
  }
212
-
213
214
  missingPublicServerURL() {
214
215
  return Promise.resolve({
215
216
  text: 'Not found.',
216
217
  status: 404
217
218
  });
218
219
  }
219
-
220
220
  invalidRequest() {
221
221
  const error = new Error();
222
222
  error.status = 403;
223
- error.message = "unauthorized";
223
+ error.message = 'unauthorized';
224
224
  throw error;
225
225
  }
226
-
227
226
  setConfig(req) {
228
- req.config = _Config2.default.get(req.params.appId);
227
+ req.config = _Config.default.get(req.params.appId);
229
228
  return Promise.resolve();
230
229
  }
231
-
232
230
  mountRoutes() {
233
231
  this.route('GET', '/apps/:appId/verify_email', req => {
234
232
  this.setConfig(req);
235
233
  }, req => {
236
234
  return this.verifyEmail(req);
237
235
  });
238
-
239
236
  this.route('POST', '/apps/:appId/resend_verification_email', req => {
240
237
  this.setConfig(req);
241
238
  }, req => {
242
239
  return this.resendVerificationEmail(req);
243
240
  });
244
-
245
241
  this.route('GET', '/apps/choose_password', req => {
246
242
  return this.changePassword(req);
247
243
  });
248
-
249
244
  this.route('POST', '/apps/:appId/request_password_reset', req => {
250
245
  this.setConfig(req);
251
246
  }, req => {
252
247
  return this.resetPassword(req);
253
248
  });
254
-
255
249
  this.route('GET', '/apps/:appId/request_password_reset', req => {
256
250
  this.setConfig(req);
257
251
  }, req => {
258
252
  return this.requestResetPassword(req);
259
253
  });
260
254
  }
261
-
262
255
  expressRouter() {
263
- const router = _express2.default.Router();
264
- router.use("/apps", _express2.default.static(public_html));
265
- router.use("/", super.expressRouter());
256
+ const router = _express.default.Router();
257
+ router.use('/apps', _express.default.static(public_html));
258
+ router.use('/', super.expressRouter());
266
259
  return router;
267
260
  }
268
261
  }
269
-
270
262
  exports.PublicAPIRouter = PublicAPIRouter;
271
- exports.default = PublicAPIRouter;
272
- //# 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","token","username","query","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","updatePassword","passwordResetSuccessURL","error","invalidLinkURL","invalidVerificationLinkURL","Error","message","setConfig","mountRoutes","route","expressRouter","router","express","Router","use","static"],"mappings":"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","file":"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';\n\nconst public_html = path.resolve(__dirname, \"../../public_html\");\nconst views = path.resolve(__dirname, '../../views');\n\nexport class PublicAPIRouter extends PromiseRouter {\n\n  verifyEmail(req) {\n    const { token, username } = req.query;\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      const params = qs.stringify({username});\n      return Promise.resolve({\n        status: 302,\n        location: `${config.verifyEmailSuccessURL}?${params}`\n      });\n    }, ()=> {\n      return this.invalidVerificationLink(req);\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      return Promise.resolve({\n        status: 302,\n        location: `${config.linkSendSuccessURL}`\n      });\n    }, ()=> {\n      return Promise.resolve({\n        status: 302,\n        location: `${config.linkSendFailURL}`\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\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 } = req.query;\n\n    if (!username || !token) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.checkResetTokenValidity(username, token).then(() => {\n      const params = qs.stringify({token, id: config.applicationId, username, app: config.appName, });\n      return Promise.resolve({\n        status: 302,\n        location: `${config.choosePasswordURL}?${params}`\n      })\n    }, () => {\n      return this.invalidLink(req);\n    })\n  }\n\n  resetPassword(req) {\n\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 {\n      username,\n      token,\n      new_password\n    } = req.body;\n\n    if (!username || !token || !new_password) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.updatePassword(username, token, new_password).then(() => {\n      const params = qs.stringify({username: username});\n      return Promise.resolve({\n        status: 302,\n        location: `${config.passwordResetSuccessURL}?${params}`\n      });\n    }, (err) => {\n      const params = qs.stringify({username: username, token: token, id: config.applicationId, error:err, app:config.appName});\n      return Promise.resolve({\n        status: 302,\n        location: `${config.choosePasswordURL}?${params}`\n      });\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({username: req.query.username, appId: req.params.appId});\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('GET','/apps/:appId/verify_email',\n      req => { this.setConfig(req) },\n      req => { return this.verifyEmail(req); });\n\n    this.route('POST', '/apps/:appId/resend_verification_email',\n      req => { this.setConfig(req); },\n      req => { return this.resendVerificationEmail(req); });\n\n    this.route('GET','/apps/choose_password',\n      req => { return this.changePassword(req); });\n\n    this.route('POST','/apps/:appId/request_password_reset',\n      req => { this.setConfig(req) },\n      req => { return this.resetPassword(req); });\n\n    this.route('GET','/apps/:appId/request_password_reset',\n      req => { this.setConfig(req) },\n      req => { return this.requestResetPassword(req); });\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
+ var _default = exports.default = PublicAPIRouter;
264
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","_Config","_express","_path","_fs","_querystring","_node","_Deprecator","e","__esModule","default","public_html","path","resolve","__dirname","views","PublicAPIRouter","PromiseRouter","constructor","Deprecator","logRuntimeDeprecation","usage","solution","verifyEmail","req","token","rawToken","query","toString","appId","params","config","Config","get","invalidRequest","publicServerURL","missingPublicServerURL","invalidLink","userController","then","Promise","status","location","verifyEmailSuccessURL","invalidVerificationLink","resendVerificationEmail","username","body","linkSendSuccessURL","linkSendFailURL","changePassword","reject","id","text","fs","readFile","err","data","replace","requestResetPassword","checkResetTokenValidity","qs","stringify","applicationId","app","appName","choosePasswordURL","resetPassword","new_password","xhr","Parse","Error","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","success","result","queryString","error","response","passwordResetSuccessURL","invalidLinkURL","invalidVerificationLinkURL","message","setConfig","mountRoutes","route","expressRouter","router","express","Router","use","static","exports","_default"],"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';\nimport Deprecator from '../Deprecator/Deprecator';\n\nconst public_html = path.resolve(__dirname, '../../public_html');\nconst views = path.resolve(__dirname, '../../views');\n\nexport class PublicAPIRouter extends PromiseRouter {\n  constructor() {\n    super();\n    Deprecator.logRuntimeDeprecation({\n      usage: 'PublicAPIRouter',\n      solution: 'pages.enableRouter'\n    });\n  }\n  verifyEmail(req) {\n    const { 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) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(token).then(\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.verifyEmailSuccessURL}`,\n        });\n      },\n      () => {\n        return this.invalidVerificationLink(req, token);\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    const token = req.body.token;\n\n    if (!username && !token) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username, req, token).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 { token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!token) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.checkResetTokenValidity(token).then(\n      () => {\n        const params = qs.stringify({\n          token,\n          id: config.applicationId,\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 { new_password, token: rawToken } = req.body || {};\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!token || !new_password) && req.xhr === false) {\n      return this.invalidLink(req);\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(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 queryString = {\n          token: token,\n          id: config.applicationId,\n          error: result.err,\n          app: config.appName,\n        };\n\n        if (result?.err === 'The password reset link has expired') {\n          delete queryString.token;\n          queryString.token = token;\n        }\n        const params = qs.stringify(queryString);\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 location = result.success\n          ? `${config.passwordResetSuccessURL}`\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, token) {\n    const config = req.config;\n    if (req.params.appId) {\n      const params = qs.stringify({\n        appId: req.params.appId,\n        token,\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":"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","ignoreList":[]}
@@ -1,31 +1,19 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.PurgeRouter = 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
- var _node = require('parse/node');
17
-
18
- var _node2 = _interopRequireDefault(_node);
19
-
20
- 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; } }
21
-
22
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
23
-
24
- class PurgeRouter extends _PromiseRouter2.default {
25
-
6
+ exports.default = exports.PurgeRouter = void 0;
7
+ var _PromiseRouter = _interopRequireDefault(require("../PromiseRouter"));
8
+ var middleware = _interopRequireWildcard(require("../middlewares"));
9
+ var _node = _interopRequireDefault(require("parse/node"));
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 PurgeRouter extends _PromiseRouter.default {
26
14
  handlePurge(req) {
27
15
  if (req.auth.isReadOnly) {
28
- throw new _node2.default.Error(_node2.default.Error.OPERATION_FORBIDDEN, 'read-only masterKey isn\'t allowed to purge a schema.');
16
+ throw (0, _Error.createSanitizedError)(_node.default.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to purge a schema.", req.config);
29
17
  }
30
18
  return req.config.database.purgeCollection(req.params.className).then(() => {
31
19
  var cacheAdapter = req.config.cacheController;
@@ -34,22 +22,24 @@ class PurgeRouter extends _PromiseRouter2.default {
34
22
  } else if (req.params.className == '_Role') {
35
23
  cacheAdapter.role.clear();
36
24
  }
37
- return { response: {} };
25
+ return {
26
+ response: {}
27
+ };
38
28
  }).catch(error => {
39
- if (!error || error && error.code === _node2.default.Error.OBJECT_NOT_FOUND) {
40
- return { response: {} };
29
+ if (!error || error && error.code === _node.default.Error.OBJECT_NOT_FOUND) {
30
+ return {
31
+ response: {}
32
+ };
41
33
  }
42
34
  throw error;
43
35
  });
44
36
  }
45
-
46
37
  mountRoutes() {
47
38
  this.route('DELETE', '/purge/:className', middleware.promiseEnforceMasterKeyAccess, req => {
48
39
  return this.handlePurge(req);
49
40
  });
50
41
  }
51
42
  }
52
-
53
43
  exports.PurgeRouter = PurgeRouter;
54
- exports.default = PurgeRouter;
55
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1B1cmdlUm91dGVyLmpzIl0sIm5hbWVzIjpbIm1pZGRsZXdhcmUiLCJQdXJnZVJvdXRlciIsIlByb21pc2VSb3V0ZXIiLCJoYW5kbGVQdXJnZSIsInJlcSIsImF1dGgiLCJpc1JlYWRPbmx5IiwiUGFyc2UiLCJFcnJvciIsIk9QRVJBVElPTl9GT1JCSURERU4iLCJjb25maWciLCJkYXRhYmFzZSIsInB1cmdlQ29sbGVjdGlvbiIsInBhcmFtcyIsImNsYXNzTmFtZSIsInRoZW4iLCJjYWNoZUFkYXB0ZXIiLCJjYWNoZUNvbnRyb2xsZXIiLCJ1c2VyIiwiY2xlYXIiLCJyb2xlIiwicmVzcG9uc2UiLCJjYXRjaCIsImVycm9yIiwiY29kZSIsIk9CSkVDVF9OT1RfRk9VTkQiLCJtb3VudFJvdXRlcyIsInJvdXRlIiwicHJvbWlzZUVuZm9yY2VNYXN0ZXJLZXlBY2Nlc3MiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7OztBQUNBOztJQUFZQSxVOztBQUNaOzs7Ozs7OztBQUVPLE1BQU1DLFdBQU4sU0FBMEJDLHVCQUExQixDQUF3Qzs7QUFFN0NDLGNBQVlDLEdBQVosRUFBaUI7QUFDZixRQUFJQSxJQUFJQyxJQUFKLENBQVNDLFVBQWIsRUFBeUI7QUFDdkIsWUFBTSxJQUFJQyxlQUFNQyxLQUFWLENBQWdCRCxlQUFNQyxLQUFOLENBQVlDLG1CQUE1QixFQUFpRCx1REFBakQsQ0FBTjtBQUNEO0FBQ0QsV0FBT0wsSUFBSU0sTUFBSixDQUFXQyxRQUFYLENBQW9CQyxlQUFwQixDQUFvQ1IsSUFBSVMsTUFBSixDQUFXQyxTQUEvQyxFQUNKQyxJQURJLENBQ0MsTUFBTTtBQUNWLFVBQUlDLGVBQWVaLElBQUlNLE1BQUosQ0FBV08sZUFBOUI7QUFDQSxVQUFJYixJQUFJUyxNQUFKLENBQVdDLFNBQVgsSUFBd0IsVUFBNUIsRUFBd0M7QUFDdENFLHFCQUFhRSxJQUFiLENBQWtCQyxLQUFsQjtBQUNELE9BRkQsTUFFTyxJQUFJZixJQUFJUyxNQUFKLENBQVdDLFNBQVgsSUFBd0IsT0FBNUIsRUFBcUM7QUFDMUNFLHFCQUFhSSxJQUFiLENBQWtCRCxLQUFsQjtBQUNEO0FBQ0QsYUFBTyxFQUFDRSxVQUFVLEVBQVgsRUFBUDtBQUNELEtBVEksRUFTRkMsS0FURSxDQVNLQyxLQUFELElBQVc7QUFDbEIsVUFBSSxDQUFDQSxLQUFELElBQVdBLFNBQVNBLE1BQU1DLElBQU4sS0FBZWpCLGVBQU1DLEtBQU4sQ0FBWWlCLGdCQUFuRCxFQUFzRTtBQUNwRSxlQUFPLEVBQUNKLFVBQVUsRUFBWCxFQUFQO0FBQ0Q7QUFDRCxZQUFNRSxLQUFOO0FBQ0QsS0FkSSxDQUFQO0FBZUQ7O0FBRURHLGdCQUFjO0FBQ1osU0FBS0MsS0FBTCxDQUFXLFFBQVgsRUFBc0IsbUJBQXRCLEVBQTJDM0IsV0FBVzRCLDZCQUF0RCxFQUFzRnhCLEdBQUQsSUFBUztBQUFFLGFBQU8sS0FBS0QsV0FBTCxDQUFpQkMsR0FBakIsQ0FBUDtBQUErQixLQUEvSDtBQUNEO0FBekI0Qzs7UUFBbENILFcsR0FBQUEsVztrQkE0QkVBLFciLCJmaWxlIjoiUHVyZ2VSb3V0ZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvbWlzZVJvdXRlciBmcm9tICcuLi9Qcm9taXNlUm91dGVyJztcbmltcG9ydCAqIGFzIG1pZGRsZXdhcmUgZnJvbSAnLi4vbWlkZGxld2FyZXMnO1xuaW1wb3J0IFBhcnNlIGZyb20gJ3BhcnNlL25vZGUnO1xuXG5leHBvcnQgY2xhc3MgUHVyZ2VSb3V0ZXIgZXh0ZW5kcyBQcm9taXNlUm91dGVyIHtcblxuICBoYW5kbGVQdXJnZShyZXEpIHtcbiAgICBpZiAocmVxLmF1dGguaXNSZWFkT25seSkge1xuICAgICAgdGhyb3cgbmV3IFBhcnNlLkVycm9yKFBhcnNlLkVycm9yLk9QRVJBVElPTl9GT1JCSURERU4sICdyZWFkLW9ubHkgbWFzdGVyS2V5IGlzblxcJ3QgYWxsb3dlZCB0byBwdXJnZSBhIHNjaGVtYS4nKTtcbiAgICB9XG4gICAgcmV0dXJuIHJlcS5jb25maWcuZGF0YWJhc2UucHVyZ2VDb2xsZWN0aW9uKHJlcS5wYXJhbXMuY2xhc3NOYW1lKVxuICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICB2YXIgY2FjaGVBZGFwdGVyID0gcmVxLmNvbmZpZy5jYWNoZUNvbnRyb2xsZXI7XG4gICAgICAgIGlmIChyZXEucGFyYW1zLmNsYXNzTmFtZSA9PSAnX1Nlc3Npb24nKSB7XG4gICAgICAgICAgY2FjaGVBZGFwdGVyLnVzZXIuY2xlYXIoKTtcbiAgICAgICAgfSBlbHNlIGlmIChyZXEucGFyYW1zLmNsYXNzTmFtZSA9PSAnX1JvbGUnKSB7XG4gICAgICAgICAgY2FjaGVBZGFwdGVyLnJvbGUuY2xlYXIoKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4ge3Jlc3BvbnNlOiB7fX07XG4gICAgICB9KS5jYXRjaCgoZXJyb3IpID0+IHtcbiAgICAgICAgaWYgKCFlcnJvciB8fCAoZXJyb3IgJiYgZXJyb3IuY29kZSA9PT0gUGFyc2UuRXJyb3IuT0JKRUNUX05PVF9GT1VORCkpIHtcbiAgICAgICAgICByZXR1cm4ge3Jlc3BvbnNlOiB7fX07XG4gICAgICAgIH1cbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9KTtcbiAgfVxuXG4gIG1vdW50Um91dGVzKCkge1xuICAgIHRoaXMucm91dGUoJ0RFTEVURScsICAnL3B1cmdlLzpjbGFzc05hbWUnLCBtaWRkbGV3YXJlLnByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzLCAocmVxKSA9PiB7IHJldHVybiB0aGlzLmhhbmRsZVB1cmdlKHJlcSk7IH0pO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IFB1cmdlUm91dGVyO1xuIl19
44
+ var _default = exports.default = PurgeRouter;
45
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfUHJvbWlzZVJvdXRlciIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwibWlkZGxld2FyZSIsIl9pbnRlcm9wUmVxdWlyZVdpbGRjYXJkIiwiX25vZGUiLCJfRXJyb3IiLCJlIiwidCIsIldlYWtNYXAiLCJyIiwibiIsIl9fZXNNb2R1bGUiLCJvIiwiaSIsImYiLCJfX3Byb3RvX18iLCJkZWZhdWx0IiwiaGFzIiwiZ2V0Iiwic2V0IiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJQdXJnZVJvdXRlciIsIlByb21pc2VSb3V0ZXIiLCJoYW5kbGVQdXJnZSIsInJlcSIsImF1dGgiLCJpc1JlYWRPbmx5IiwiY3JlYXRlU2FuaXRpemVkRXJyb3IiLCJQYXJzZSIsIkVycm9yIiwiT1BFUkFUSU9OX0ZPUkJJRERFTiIsImNvbmZpZyIsImRhdGFiYXNlIiwicHVyZ2VDb2xsZWN0aW9uIiwicGFyYW1zIiwiY2xhc3NOYW1lIiwidGhlbiIsImNhY2hlQWRhcHRlciIsImNhY2hlQ29udHJvbGxlciIsInVzZXIiLCJjbGVhciIsInJvbGUiLCJyZXNwb25zZSIsImNhdGNoIiwiZXJyb3IiLCJjb2RlIiwiT0JKRUNUX05PVF9GT1VORCIsIm1vdW50Um91dGVzIiwicm91dGUiLCJwcm9taXNlRW5mb3JjZU1hc3RlcktleUFjY2VzcyIsImV4cG9ydHMiLCJfZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1B1cmdlUm91dGVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9taXNlUm91dGVyIGZyb20gJy4uL1Byb21pc2VSb3V0ZXInO1xuaW1wb3J0ICogYXMgbWlkZGxld2FyZSBmcm9tICcuLi9taWRkbGV3YXJlcyc7XG5pbXBvcnQgUGFyc2UgZnJvbSAncGFyc2Uvbm9kZSc7XG5pbXBvcnQgeyBjcmVhdGVTYW5pdGl6ZWRFcnJvciB9IGZyb20gJy4uL0Vycm9yJztcblxuZXhwb3J0IGNsYXNzIFB1cmdlUm91dGVyIGV4dGVuZHMgUHJvbWlzZVJvdXRlciB7XG4gIGhhbmRsZVB1cmdlKHJlcSkge1xuICAgIGlmIChyZXEuYXV0aC5pc1JlYWRPbmx5KSB7XG4gICAgICB0aHJvdyBjcmVhdGVTYW5pdGl6ZWRFcnJvcihcbiAgICAgICAgUGFyc2UuRXJyb3IuT1BFUkFUSU9OX0ZPUkJJRERFTixcbiAgICAgICAgXCJyZWFkLW9ubHkgbWFzdGVyS2V5IGlzbid0IGFsbG93ZWQgdG8gcHVyZ2UgYSBzY2hlbWEuXCIsXG4gICAgICAgIHJlcS5jb25maWdcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiByZXEuY29uZmlnLmRhdGFiYXNlXG4gICAgICAucHVyZ2VDb2xsZWN0aW9uKHJlcS5wYXJhbXMuY2xhc3NOYW1lKVxuICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICB2YXIgY2FjaGVBZGFwdGVyID0gcmVxLmNvbmZpZy5jYWNoZUNvbnRyb2xsZXI7XG4gICAgICAgIGlmIChyZXEucGFyYW1zLmNsYXNzTmFtZSA9PSAnX1Nlc3Npb24nKSB7XG4gICAgICAgICAgY2FjaGVBZGFwdGVyLnVzZXIuY2xlYXIoKTtcbiAgICAgICAgfSBlbHNlIGlmIChyZXEucGFyYW1zLmNsYXNzTmFtZSA9PSAnX1JvbGUnKSB7XG4gICAgICAgICAgY2FjaGVBZGFwdGVyLnJvbGUuY2xlYXIoKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyByZXNwb25zZToge30gfTtcbiAgICAgIH0pXG4gICAgICAuY2F0Y2goZXJyb3IgPT4ge1xuICAgICAgICBpZiAoIWVycm9yIHx8IChlcnJvciAmJiBlcnJvci5jb2RlID09PSBQYXJzZS5FcnJvci5PQkpFQ1RfTk9UX0ZPVU5EKSkge1xuICAgICAgICAgIHJldHVybiB7IHJlc3BvbnNlOiB7fSB9O1xuICAgICAgICB9XG4gICAgICAgIHRocm93IGVycm9yO1xuICAgICAgfSk7XG4gIH1cblxuICBtb3VudFJvdXRlcygpIHtcbiAgICB0aGlzLnJvdXRlKCdERUxFVEUnLCAnL3B1cmdlLzpjbGFzc05hbWUnLCBtaWRkbGV3YXJlLnByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzLCByZXEgPT4ge1xuICAgICAgcmV0dXJuIHRoaXMuaGFuZGxlUHVyZ2UocmVxKTtcbiAgICB9KTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQdXJnZVJvdXRlcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsY0FBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsVUFBQSxHQUFBQyx1QkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUcsS0FBQSxHQUFBSixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUksTUFBQSxHQUFBSixPQUFBO0FBQWdELFNBQUFFLHdCQUFBRyxDQUFBLEVBQUFDLENBQUEsNkJBQUFDLE9BQUEsTUFBQUMsQ0FBQSxPQUFBRCxPQUFBLElBQUFFLENBQUEsT0FBQUYsT0FBQSxZQUFBTCx1QkFBQSxZQUFBQSxDQUFBRyxDQUFBLEVBQUFDLENBQUEsU0FBQUEsQ0FBQSxJQUFBRCxDQUFBLElBQUFBLENBQUEsQ0FBQUssVUFBQSxTQUFBTCxDQUFBLE1BQUFNLENBQUEsRUFBQUMsQ0FBQSxFQUFBQyxDQUFBLEtBQUFDLFNBQUEsUUFBQUMsT0FBQSxFQUFBVixDQUFBLGlCQUFBQSxDQUFBLHVCQUFBQSxDQUFBLHlCQUFBQSxDQUFBLFNBQUFRLENBQUEsTUFBQUYsQ0FBQSxHQUFBTCxDQUFBLEdBQUFHLENBQUEsR0FBQUQsQ0FBQSxRQUFBRyxDQUFBLENBQUFLLEdBQUEsQ0FBQVgsQ0FBQSxVQUFBTSxDQUFBLENBQUFNLEdBQUEsQ0FBQVosQ0FBQSxHQUFBTSxDQUFBLENBQUFPLEdBQUEsQ0FBQWIsQ0FBQSxFQUFBUSxDQUFBLGdCQUFBUCxDQUFBLElBQUFELENBQUEsZ0JBQUFDLENBQUEsT0FBQWEsY0FBQSxDQUFBQyxJQUFBLENBQUFmLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLElBQUFELENBQUEsR0FBQVUsTUFBQSxDQUFBQyxjQUFBLEtBQUFELE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQWxCLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLENBQUFLLEdBQUEsSUFBQUwsQ0FBQSxDQUFBTSxHQUFBLElBQUFQLENBQUEsQ0FBQUUsQ0FBQSxFQUFBUCxDQUFBLEVBQUFNLENBQUEsSUFBQUMsQ0FBQSxDQUFBUCxDQUFBLElBQUFELENBQUEsQ0FBQUMsQ0FBQSxXQUFBTyxDQUFBLEtBQUFSLENBQUEsRUFBQUMsQ0FBQTtBQUFBLFNBQUFQLHVCQUFBTSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBSyxVQUFBLEdBQUFMLENBQUEsS0FBQVUsT0FBQSxFQUFBVixDQUFBO0FBRXpDLE1BQU1tQixXQUFXLFNBQVNDLHNCQUFhLENBQUM7RUFDN0NDLFdBQVdBLENBQUNDLEdBQUcsRUFBRTtJQUNmLElBQUlBLEdBQUcsQ0FBQ0MsSUFBSSxDQUFDQyxVQUFVLEVBQUU7TUFDdkIsTUFBTSxJQUFBQywyQkFBb0IsRUFDeEJDLGFBQUssQ0FBQ0MsS0FBSyxDQUFDQyxtQkFBbUIsRUFDL0Isc0RBQXNELEVBQ3RETixHQUFHLENBQUNPLE1BQ04sQ0FBQztJQUNIO0lBQ0EsT0FBT1AsR0FBRyxDQUFDTyxNQUFNLENBQUNDLFFBQVEsQ0FDdkJDLGVBQWUsQ0FBQ1QsR0FBRyxDQUFDVSxNQUFNLENBQUNDLFNBQVMsQ0FBQyxDQUNyQ0MsSUFBSSxDQUFDLE1BQU07TUFDVixJQUFJQyxZQUFZLEdBQUdiLEdBQUcsQ0FBQ08sTUFBTSxDQUFDTyxlQUFlO01BQzdDLElBQUlkLEdBQUcsQ0FBQ1UsTUFBTSxDQUFDQyxTQUFTLElBQUksVUFBVSxFQUFFO1FBQ3RDRSxZQUFZLENBQUNFLElBQUksQ0FBQ0MsS0FBSyxDQUFDLENBQUM7TUFDM0IsQ0FBQyxNQUFNLElBQUloQixHQUFHLENBQUNVLE1BQU0sQ0FBQ0MsU0FBUyxJQUFJLE9BQU8sRUFBRTtRQUMxQ0UsWUFBWSxDQUFDSSxJQUFJLENBQUNELEtBQUssQ0FBQyxDQUFDO01BQzNCO01BQ0EsT0FBTztRQUFFRSxRQUFRLEVBQUUsQ0FBQztNQUFFLENBQUM7SUFDekIsQ0FBQyxDQUFDLENBQ0RDLEtBQUssQ0FBQ0MsS0FBSyxJQUFJO01BQ2QsSUFBSSxDQUFDQSxLQUFLLElBQUtBLEtBQUssSUFBSUEsS0FBSyxDQUFDQyxJQUFJLEtBQUtqQixhQUFLLENBQUNDLEtBQUssQ0FBQ2lCLGdCQUFpQixFQUFFO1FBQ3BFLE9BQU87VUFBRUosUUFBUSxFQUFFLENBQUM7UUFBRSxDQUFDO01BQ3pCO01BQ0EsTUFBTUUsS0FBSztJQUNiLENBQUMsQ0FBQztFQUNOO0VBRUFHLFdBQVdBLENBQUEsRUFBRztJQUNaLElBQUksQ0FBQ0MsS0FBSyxDQUFDLFFBQVEsRUFBRSxtQkFBbUIsRUFBRWxELFVBQVUsQ0FBQ21ELDZCQUE2QixFQUFFekIsR0FBRyxJQUFJO01BQ3pGLE9BQU8sSUFBSSxDQUFDRCxXQUFXLENBQUNDLEdBQUcsQ0FBQztJQUM5QixDQUFDLENBQUM7RUFDSjtBQUNGO0FBQUMwQixPQUFBLENBQUE3QixXQUFBLEdBQUFBLFdBQUE7QUFBQSxJQUFBOEIsUUFBQSxHQUFBRCxPQUFBLENBQUF0QyxPQUFBLEdBRWNTLFdBQVciLCJpZ25vcmVMaXN0IjpbXX0=