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.
- package/LICENSE +167 -25
- package/NOTICE +10 -0
- package/README.md +929 -278
- package/lib/AccountLockout.js +47 -30
- package/lib/Adapters/AdapterLoader.js +21 -6
- package/lib/Adapters/Analytics/AnalyticsAdapter.js +15 -12
- package/lib/Adapters/Auth/AuthAdapter.js +116 -13
- package/lib/Adapters/Auth/BaseCodeAuthAdapter.js +99 -0
- package/lib/Adapters/Auth/OAuth1Client.js +27 -46
- package/lib/Adapters/Auth/apple.js +123 -0
- package/lib/Adapters/Auth/facebook.js +162 -35
- package/lib/Adapters/Auth/gcenter.js +217 -0
- package/lib/Adapters/Auth/github.js +118 -48
- package/lib/Adapters/Auth/google.js +160 -51
- package/lib/Adapters/Auth/gpgames.js +125 -0
- package/lib/Adapters/Auth/httpsRequest.js +6 -7
- package/lib/Adapters/Auth/index.js +170 -62
- package/lib/Adapters/Auth/instagram.js +114 -40
- package/lib/Adapters/Auth/janraincapture.js +52 -23
- package/lib/Adapters/Auth/janrainengage.js +19 -36
- package/lib/Adapters/Auth/keycloak.js +148 -0
- package/lib/Adapters/Auth/ldap.js +167 -0
- package/lib/Adapters/Auth/line.js +125 -0
- package/lib/Adapters/Auth/linkedin.js +111 -55
- package/lib/Adapters/Auth/meetup.js +24 -34
- package/lib/Adapters/Auth/mfa.js +324 -0
- package/lib/Adapters/Auth/microsoft.js +111 -0
- package/lib/Adapters/Auth/oauth2.js +97 -162
- package/lib/Adapters/Auth/phantauth.js +53 -0
- package/lib/Adapters/Auth/qq.js +108 -49
- package/lib/Adapters/Auth/spotify.js +107 -55
- package/lib/Adapters/Auth/twitter.js +188 -48
- package/lib/Adapters/Auth/utils.js +28 -0
- package/lib/Adapters/Auth/vkontakte.js +26 -39
- package/lib/Adapters/Auth/wechat.js +106 -44
- package/lib/Adapters/Auth/weibo.js +132 -58
- package/lib/Adapters/Cache/CacheAdapter.js +13 -8
- package/lib/Adapters/Cache/InMemoryCache.js +3 -13
- package/lib/Adapters/Cache/InMemoryCacheAdapter.js +5 -13
- package/lib/Adapters/Cache/LRUCache.js +13 -27
- package/lib/Adapters/Cache/NullCacheAdapter.js +3 -8
- package/lib/Adapters/Cache/RedisCacheAdapter.js +85 -76
- package/lib/Adapters/Cache/SchemaCache.js +25 -0
- package/lib/Adapters/Email/MailAdapter.js +10 -8
- package/lib/Adapters/Files/FilesAdapter.js +83 -25
- package/lib/Adapters/Files/GridFSBucketAdapter.js +231 -0
- package/lib/Adapters/Files/GridStoreAdapter.js +4 -91
- package/lib/Adapters/Logger/LoggerAdapter.js +18 -14
- package/lib/Adapters/Logger/WinstonLogger.js +69 -88
- package/lib/Adapters/Logger/WinstonLoggerAdapter.js +7 -16
- package/lib/Adapters/MessageQueue/EventEmitterMQ.js +8 -26
- package/lib/Adapters/PubSub/EventEmitterPubSub.js +12 -25
- package/lib/Adapters/PubSub/PubSubAdapter.js +34 -0
- package/lib/Adapters/PubSub/RedisPubSub.js +42 -19
- package/lib/Adapters/Push/PushAdapter.js +14 -7
- package/lib/Adapters/Storage/Mongo/MongoCollection.js +137 -45
- package/lib/Adapters/Storage/Mongo/MongoSchemaCollection.js +158 -63
- package/lib/Adapters/Storage/Mongo/MongoStorageAdapter.js +320 -168
- package/lib/Adapters/Storage/Mongo/MongoTransform.js +279 -306
- package/lib/Adapters/Storage/Postgres/PostgresClient.js +14 -10
- package/lib/Adapters/Storage/Postgres/PostgresConfigParser.js +47 -21
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +854 -468
- package/lib/Adapters/Storage/Postgres/sql/index.js +4 -6
- package/lib/Adapters/Storage/StorageAdapter.js +1 -1
- package/lib/Adapters/WebSocketServer/WSAdapter.js +35 -0
- package/lib/Adapters/WebSocketServer/WSSAdapter.js +66 -0
- package/lib/Auth.js +488 -125
- package/lib/ClientSDK.js +2 -6
- package/lib/Config.js +525 -94
- package/lib/Controllers/AdaptableController.js +5 -25
- package/lib/Controllers/AnalyticsController.js +22 -23
- package/lib/Controllers/CacheController.js +10 -31
- package/lib/Controllers/DatabaseController.js +767 -313
- package/lib/Controllers/FilesController.js +49 -54
- package/lib/Controllers/HooksController.js +80 -84
- package/lib/Controllers/LiveQueryController.js +35 -22
- package/lib/Controllers/LoggerController.js +22 -58
- package/lib/Controllers/ParseGraphQLController.js +293 -0
- package/lib/Controllers/PushController.js +58 -49
- package/lib/Controllers/SchemaController.js +916 -422
- package/lib/Controllers/UserController.js +265 -180
- package/lib/Controllers/index.js +90 -125
- package/lib/Controllers/types.js +1 -1
- package/lib/Deprecator/Deprecations.js +30 -0
- package/lib/Deprecator/Deprecator.js +127 -0
- package/lib/Error.js +48 -0
- package/lib/GraphQL/ParseGraphQLSchema.js +375 -0
- package/lib/GraphQL/ParseGraphQLServer.js +214 -0
- package/lib/GraphQL/helpers/objectsMutations.js +30 -0
- package/lib/GraphQL/helpers/objectsQueries.js +246 -0
- package/lib/GraphQL/loaders/configMutations.js +87 -0
- package/lib/GraphQL/loaders/configQueries.js +79 -0
- package/lib/GraphQL/loaders/defaultGraphQLMutations.js +21 -0
- package/lib/GraphQL/loaders/defaultGraphQLQueries.js +23 -0
- package/lib/GraphQL/loaders/defaultGraphQLTypes.js +1098 -0
- package/lib/GraphQL/loaders/defaultRelaySchema.js +53 -0
- package/lib/GraphQL/loaders/filesMutations.js +107 -0
- package/lib/GraphQL/loaders/functionsMutations.js +78 -0
- package/lib/GraphQL/loaders/parseClassMutations.js +268 -0
- package/lib/GraphQL/loaders/parseClassQueries.js +127 -0
- package/lib/GraphQL/loaders/parseClassTypes.js +493 -0
- package/lib/GraphQL/loaders/schemaDirectives.js +62 -0
- package/lib/GraphQL/loaders/schemaMutations.js +162 -0
- package/lib/GraphQL/loaders/schemaQueries.js +81 -0
- package/lib/GraphQL/loaders/schemaTypes.js +341 -0
- package/lib/GraphQL/loaders/usersMutations.js +433 -0
- package/lib/GraphQL/loaders/usersQueries.js +90 -0
- package/lib/GraphQL/parseGraphQLUtils.js +63 -0
- package/lib/GraphQL/transformers/className.js +14 -0
- package/lib/GraphQL/transformers/constraintType.js +53 -0
- package/lib/GraphQL/transformers/inputType.js +51 -0
- package/lib/GraphQL/transformers/mutation.js +274 -0
- package/lib/GraphQL/transformers/outputType.js +51 -0
- package/lib/GraphQL/transformers/query.js +237 -0
- package/lib/GraphQL/transformers/schemaFields.js +99 -0
- package/lib/KeyPromiseQueue.js +48 -0
- package/lib/LiveQuery/Client.js +25 -33
- package/lib/LiveQuery/Id.js +2 -5
- package/lib/LiveQuery/ParseCloudCodePublisher.js +26 -23
- package/lib/LiveQuery/ParseLiveQueryServer.js +560 -285
- package/lib/LiveQuery/ParsePubSub.js +7 -16
- package/lib/LiveQuery/ParseWebSocketServer.js +42 -39
- package/lib/LiveQuery/QueryTools.js +76 -15
- package/lib/LiveQuery/RequestSchema.js +111 -97
- package/lib/LiveQuery/SessionTokenCache.js +23 -36
- package/lib/LiveQuery/Subscription.js +8 -17
- package/lib/LiveQuery/equalObjects.js +2 -3
- package/lib/Options/Definitions.js +1355 -382
- package/lib/Options/docs.js +301 -62
- package/lib/Options/index.js +11 -1
- package/lib/Options/parsers.js +14 -10
- package/lib/Page.js +44 -0
- package/lib/ParseMessageQueue.js +6 -13
- package/lib/ParseServer.js +474 -235
- package/lib/ParseServerRESTController.js +102 -40
- package/lib/PromiseRouter.js +39 -50
- package/lib/Push/PushQueue.js +24 -30
- package/lib/Push/PushWorker.js +32 -56
- package/lib/Push/utils.js +22 -35
- package/lib/RestQuery.js +361 -139
- package/lib/RestWrite.js +713 -344
- package/lib/Routers/AggregateRouter.js +97 -71
- package/lib/Routers/AnalyticsRouter.js +8 -14
- package/lib/Routers/AudiencesRouter.js +16 -35
- package/lib/Routers/ClassesRouter.js +86 -72
- package/lib/Routers/CloudCodeRouter.js +28 -37
- package/lib/Routers/FeaturesRouter.js +22 -25
- package/lib/Routers/FilesRouter.js +266 -171
- package/lib/Routers/FunctionsRouter.js +87 -103
- package/lib/Routers/GlobalConfigRouter.js +94 -33
- package/lib/Routers/GraphQLRouter.js +41 -0
- package/lib/Routers/HooksRouter.js +43 -47
- package/lib/Routers/IAPValidationRouter.js +57 -70
- package/lib/Routers/InstallationsRouter.js +17 -25
- package/lib/Routers/LogsRouter.js +10 -25
- package/lib/Routers/PagesRouter.js +647 -0
- package/lib/Routers/PublicAPIRouter.js +104 -112
- package/lib/Routers/PurgeRouter.js +19 -29
- package/lib/Routers/PushRouter.js +14 -28
- package/lib/Routers/RolesRouter.js +7 -14
- package/lib/Routers/SchemasRouter.js +63 -42
- package/lib/Routers/SecurityRouter.js +34 -0
- package/lib/Routers/SessionsRouter.js +25 -38
- package/lib/Routers/UsersRouter.js +463 -190
- package/lib/SchemaMigrations/DefinedSchemas.js +379 -0
- package/lib/SchemaMigrations/Migrations.js +30 -0
- package/lib/Security/Check.js +109 -0
- package/lib/Security/CheckGroup.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupDatabase.js +44 -0
- package/lib/Security/CheckGroups/CheckGroupServerConfig.js +96 -0
- package/lib/Security/CheckGroups/CheckGroups.js +21 -0
- package/lib/Security/CheckRunner.js +213 -0
- package/lib/SharedRest.js +29 -0
- package/lib/StatusHandler.js +96 -93
- package/lib/TestUtils.js +70 -14
- package/lib/Utils.js +468 -0
- package/lib/batch.js +74 -40
- package/lib/cache.js +8 -8
- package/lib/cli/definitions/parse-live-query-server.js +4 -3
- package/lib/cli/definitions/parse-server.js +4 -3
- package/lib/cli/parse-live-query-server.js +9 -17
- package/lib/cli/parse-server.js +49 -47
- package/lib/cli/utils/commander.js +20 -29
- package/lib/cli/utils/runner.js +31 -32
- package/lib/cloud-code/Parse.Cloud.js +711 -36
- package/lib/cloud-code/Parse.Server.js +21 -0
- package/lib/cryptoUtils.js +6 -11
- package/lib/defaults.js +21 -15
- package/lib/deprecated.js +1 -1
- package/lib/index.js +78 -67
- package/lib/logger.js +12 -20
- package/lib/middlewares.js +484 -160
- package/lib/password.js +10 -6
- package/lib/request.js +175 -0
- package/lib/requiredParameter.js +4 -3
- package/lib/rest.js +157 -82
- package/lib/triggers.js +627 -185
- package/lib/vendor/README.md +3 -3
- package/lib/vendor/mongodbUrl.js +224 -137
- package/package.json +135 -57
- package/postinstall.js +38 -50
- package/public_html/invalid_verification_link.html +3 -3
- package/types/@types/@parse/fs-files-adapter/index.d.ts +5 -0
- package/types/@types/deepcopy/index.d.ts +5 -0
- package/types/LiveQuery/ParseLiveQueryServer.d.ts +40 -0
- package/types/Options/index.d.ts +301 -0
- package/types/ParseServer.d.ts +65 -0
- package/types/eslint.config.mjs +30 -0
- package/types/index.d.ts +21 -0
- package/types/logger.d.ts +2 -0
- package/types/tests.ts +44 -0
- package/types/tsconfig.json +24 -0
- package/CHANGELOG.md +0 -1246
- package/PATENTS +0 -37
- package/bin/dev +0 -37
- package/lib/.DS_Store +0 -0
- package/lib/Adapters/Auth/common.js +0 -2
- package/lib/Adapters/Auth/facebookaccountkit.js +0 -69
- package/lib/Controllers/SchemaCache.js +0 -97
- package/lib/LiveQuery/.DS_Store +0 -0
- package/lib/cli/utils/parsers.js +0 -77
- package/lib/cloud-code/.DS_Store +0 -0
- package/lib/cloud-code/HTTPResponse.js +0 -57
- package/lib/cloud-code/Untitled-1 +0 -123
- package/lib/cloud-code/httpRequest.js +0 -102
- package/lib/cloud-code/team.html +0 -123
- package/lib/graphql/ParseClass.js +0 -234
- package/lib/graphql/Schema.js +0 -197
- package/lib/graphql/index.js +0 -1
- package/lib/graphql/types/ACL.js +0 -35
- package/lib/graphql/types/Date.js +0 -25
- package/lib/graphql/types/File.js +0 -24
- package/lib/graphql/types/GeoPoint.js +0 -35
- package/lib/graphql/types/JSONObject.js +0 -30
- package/lib/graphql/types/NumberInput.js +0 -43
- package/lib/graphql/types/NumberQuery.js +0 -42
- package/lib/graphql/types/Pointer.js +0 -35
- package/lib/graphql/types/QueryConstraint.js +0 -61
- package/lib/graphql/types/StringQuery.js +0 -39
- package/lib/graphql/types/index.js +0 -110
|
@@ -1,90 +1,70 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.PublicAPIRouter =
|
|
7
|
-
|
|
8
|
-
var
|
|
9
|
-
|
|
10
|
-
var
|
|
11
|
-
|
|
12
|
-
var
|
|
13
|
-
|
|
14
|
-
var
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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 {
|
|
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 =
|
|
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(
|
|
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}
|
|
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
|
|
53
|
+
const username = req.body?.username;
|
|
70
54
|
const appId = req.params.appId;
|
|
71
|
-
const config =
|
|
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 =
|
|
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
|
-
|
|
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(
|
|
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
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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
|
-
|
|
146
|
-
|
|
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
|
-
|
|
170
|
-
token
|
|
171
|
-
|
|
172
|
-
|
|
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
|
-
|
|
179
|
-
|
|
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
|
-
|
|
182
|
-
location: `${config.passwordResetSuccessURL}?${params}`
|
|
156
|
+
success: true
|
|
183
157
|
});
|
|
184
158
|
}, err => {
|
|
185
|
-
|
|
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
|
|
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.
|
|
203
|
-
const params =
|
|
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 =
|
|
223
|
+
error.message = 'unauthorized';
|
|
224
224
|
throw error;
|
|
225
225
|
}
|
|
226
|
-
|
|
227
226
|
setConfig(req) {
|
|
228
|
-
req.config =
|
|
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 =
|
|
264
|
-
router.use(
|
|
265
|
-
router.use(
|
|
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
|
-
|
|
1
|
+
"use strict";
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.PurgeRouter =
|
|
7
|
-
|
|
8
|
-
var
|
|
9
|
-
|
|
10
|
-
var
|
|
11
|
-
|
|
12
|
-
|
|
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
|
|
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 {
|
|
25
|
+
return {
|
|
26
|
+
response: {}
|
|
27
|
+
};
|
|
38
28
|
}).catch(error => {
|
|
39
|
-
if (!error || error && error.code ===
|
|
40
|
-
return {
|
|
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,
|
|
44
|
+
var _default = exports.default = PurgeRouter;
|
|
45
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfUHJvbWlzZVJvdXRlciIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwibWlkZGxld2FyZSIsIl9pbnRlcm9wUmVxdWlyZVdpbGRjYXJkIiwiX25vZGUiLCJfRXJyb3IiLCJlIiwidCIsIldlYWtNYXAiLCJyIiwibiIsIl9fZXNNb2R1bGUiLCJvIiwiaSIsImYiLCJfX3Byb3RvX18iLCJkZWZhdWx0IiwiaGFzIiwiZ2V0Iiwic2V0IiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJQdXJnZVJvdXRlciIsIlByb21pc2VSb3V0ZXIiLCJoYW5kbGVQdXJnZSIsInJlcSIsImF1dGgiLCJpc1JlYWRPbmx5IiwiY3JlYXRlU2FuaXRpemVkRXJyb3IiLCJQYXJzZSIsIkVycm9yIiwiT1BFUkFUSU9OX0ZPUkJJRERFTiIsImNvbmZpZyIsImRhdGFiYXNlIiwicHVyZ2VDb2xsZWN0aW9uIiwicGFyYW1zIiwiY2xhc3NOYW1lIiwidGhlbiIsImNhY2hlQWRhcHRlciIsImNhY2hlQ29udHJvbGxlciIsInVzZXIiLCJjbGVhciIsInJvbGUiLCJyZXNwb25zZSIsImNhdGNoIiwiZXJyb3IiLCJjb2RlIiwiT0JKRUNUX05PVF9GT1VORCIsIm1vdW50Um91dGVzIiwicm91dGUiLCJwcm9taXNlRW5mb3JjZU1hc3RlcktleUFjY2VzcyIsImV4cG9ydHMiLCJfZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Sb3V0ZXJzL1B1cmdlUm91dGVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9taXNlUm91dGVyIGZyb20gJy4uL1Byb21pc2VSb3V0ZXInO1xuaW1wb3J0ICogYXMgbWlkZGxld2FyZSBmcm9tICcuLi9taWRkbGV3YXJlcyc7XG5pbXBvcnQgUGFyc2UgZnJvbSAncGFyc2Uvbm9kZSc7XG5pbXBvcnQgeyBjcmVhdGVTYW5pdGl6ZWRFcnJvciB9IGZyb20gJy4uL0Vycm9yJztcblxuZXhwb3J0IGNsYXNzIFB1cmdlUm91dGVyIGV4dGVuZHMgUHJvbWlzZVJvdXRlciB7XG4gIGhhbmRsZVB1cmdlKHJlcSkge1xuICAgIGlmIChyZXEuYXV0aC5pc1JlYWRPbmx5KSB7XG4gICAgICB0aHJvdyBjcmVhdGVTYW5pdGl6ZWRFcnJvcihcbiAgICAgICAgUGFyc2UuRXJyb3IuT1BFUkFUSU9OX0ZPUkJJRERFTixcbiAgICAgICAgXCJyZWFkLW9ubHkgbWFzdGVyS2V5IGlzbid0IGFsbG93ZWQgdG8gcHVyZ2UgYSBzY2hlbWEuXCIsXG4gICAgICAgIHJlcS5jb25maWdcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiByZXEuY29uZmlnLmRhdGFiYXNlXG4gICAgICAucHVyZ2VDb2xsZWN0aW9uKHJlcS5wYXJhbXMuY2xhc3NOYW1lKVxuICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICB2YXIgY2FjaGVBZGFwdGVyID0gcmVxLmNvbmZpZy5jYWNoZUNvbnRyb2xsZXI7XG4gICAgICAgIGlmIChyZXEucGFyYW1zLmNsYXNzTmFtZSA9PSAnX1Nlc3Npb24nKSB7XG4gICAgICAgICAgY2FjaGVBZGFwdGVyLnVzZXIuY2xlYXIoKTtcbiAgICAgICAgfSBlbHNlIGlmIChyZXEucGFyYW1zLmNsYXNzTmFtZSA9PSAnX1JvbGUnKSB7XG4gICAgICAgICAgY2FjaGVBZGFwdGVyLnJvbGUuY2xlYXIoKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyByZXNwb25zZToge30gfTtcbiAgICAgIH0pXG4gICAgICAuY2F0Y2goZXJyb3IgPT4ge1xuICAgICAgICBpZiAoIWVycm9yIHx8IChlcnJvciAmJiBlcnJvci5jb2RlID09PSBQYXJzZS5FcnJvci5PQkpFQ1RfTk9UX0ZPVU5EKSkge1xuICAgICAgICAgIHJldHVybiB7IHJlc3BvbnNlOiB7fSB9O1xuICAgICAgICB9XG4gICAgICAgIHRocm93IGVycm9yO1xuICAgICAgfSk7XG4gIH1cblxuICBtb3VudFJvdXRlcygpIHtcbiAgICB0aGlzLnJvdXRlKCdERUxFVEUnLCAnL3B1cmdlLzpjbGFzc05hbWUnLCBtaWRkbGV3YXJlLnByb21pc2VFbmZvcmNlTWFzdGVyS2V5QWNjZXNzLCByZXEgPT4ge1xuICAgICAgcmV0dXJuIHRoaXMuaGFuZGxlUHVyZ2UocmVxKTtcbiAgICB9KTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBQdXJnZVJvdXRlcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsY0FBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsVUFBQSxHQUFBQyx1QkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUcsS0FBQSxHQUFBSixzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUksTUFBQSxHQUFBSixPQUFBO0FBQWdELFNBQUFFLHdCQUFBRyxDQUFBLEVBQUFDLENBQUEsNkJBQUFDLE9BQUEsTUFBQUMsQ0FBQSxPQUFBRCxPQUFBLElBQUFFLENBQUEsT0FBQUYsT0FBQSxZQUFBTCx1QkFBQSxZQUFBQSxDQUFBRyxDQUFBLEVBQUFDLENBQUEsU0FBQUEsQ0FBQSxJQUFBRCxDQUFBLElBQUFBLENBQUEsQ0FBQUssVUFBQSxTQUFBTCxDQUFBLE1BQUFNLENBQUEsRUFBQUMsQ0FBQSxFQUFBQyxDQUFBLEtBQUFDLFNBQUEsUUFBQUMsT0FBQSxFQUFBVixDQUFBLGlCQUFBQSxDQUFBLHVCQUFBQSxDQUFBLHlCQUFBQSxDQUFBLFNBQUFRLENBQUEsTUFBQUYsQ0FBQSxHQUFBTCxDQUFBLEdBQUFHLENBQUEsR0FBQUQsQ0FBQSxRQUFBRyxDQUFBLENBQUFLLEdBQUEsQ0FBQVgsQ0FBQSxVQUFBTSxDQUFBLENBQUFNLEdBQUEsQ0FBQVosQ0FBQSxHQUFBTSxDQUFBLENBQUFPLEdBQUEsQ0FBQWIsQ0FBQSxFQUFBUSxDQUFBLGdCQUFBUCxDQUFBLElBQUFELENBQUEsZ0JBQUFDLENBQUEsT0FBQWEsY0FBQSxDQUFBQyxJQUFBLENBQUFmLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLElBQUFELENBQUEsR0FBQVUsTUFBQSxDQUFBQyxjQUFBLEtBQUFELE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQWxCLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLENBQUFLLEdBQUEsSUFBQUwsQ0FBQSxDQUFBTSxHQUFBLElBQUFQLENBQUEsQ0FBQUUsQ0FBQSxFQUFBUCxDQUFBLEVBQUFNLENBQUEsSUFBQUMsQ0FBQSxDQUFBUCxDQUFBLElBQUFELENBQUEsQ0FBQUMsQ0FBQSxXQUFBTyxDQUFBLEtBQUFSLENBQUEsRUFBQUMsQ0FBQTtBQUFBLFNBQUFQLHVCQUFBTSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBSyxVQUFBLEdBQUFMLENBQUEsS0FBQVUsT0FBQSxFQUFBVixDQUFBO0FBRXpDLE1BQU1tQixXQUFXLFNBQVNDLHNCQUFhLENBQUM7RUFDN0NDLFdBQVdBLENBQUNDLEdBQUcsRUFBRTtJQUNmLElBQUlBLEdBQUcsQ0FBQ0MsSUFBSSxDQUFDQyxVQUFVLEVBQUU7TUFDdkIsTUFBTSxJQUFBQywyQkFBb0IsRUFDeEJDLGFBQUssQ0FBQ0MsS0FBSyxDQUFDQyxtQkFBbUIsRUFDL0Isc0RBQXNELEVBQ3RETixHQUFHLENBQUNPLE1BQ04sQ0FBQztJQUNIO0lBQ0EsT0FBT1AsR0FBRyxDQUFDTyxNQUFNLENBQUNDLFFBQVEsQ0FDdkJDLGVBQWUsQ0FBQ1QsR0FBRyxDQUFDVSxNQUFNLENBQUNDLFNBQVMsQ0FBQyxDQUNyQ0MsSUFBSSxDQUFDLE1BQU07TUFDVixJQUFJQyxZQUFZLEdBQUdiLEdBQUcsQ0FBQ08sTUFBTSxDQUFDTyxlQUFlO01BQzdDLElBQUlkLEdBQUcsQ0FBQ1UsTUFBTSxDQUFDQyxTQUFTLElBQUksVUFBVSxFQUFFO1FBQ3RDRSxZQUFZLENBQUNFLElBQUksQ0FBQ0MsS0FBSyxDQUFDLENBQUM7TUFDM0IsQ0FBQyxNQUFNLElBQUloQixHQUFHLENBQUNVLE1BQU0sQ0FBQ0MsU0FBUyxJQUFJLE9BQU8sRUFBRTtRQUMxQ0UsWUFBWSxDQUFDSSxJQUFJLENBQUNELEtBQUssQ0FBQyxDQUFDO01BQzNCO01BQ0EsT0FBTztRQUFFRSxRQUFRLEVBQUUsQ0FBQztNQUFFLENBQUM7SUFDekIsQ0FBQyxDQUFDLENBQ0RDLEtBQUssQ0FBQ0MsS0FBSyxJQUFJO01BQ2QsSUFBSSxDQUFDQSxLQUFLLElBQUtBLEtBQUssSUFBSUEsS0FBSyxDQUFDQyxJQUFJLEtBQUtqQixhQUFLLENBQUNDLEtBQUssQ0FBQ2lCLGdCQUFpQixFQUFFO1FBQ3BFLE9BQU87VUFBRUosUUFBUSxFQUFFLENBQUM7UUFBRSxDQUFDO01BQ3pCO01BQ0EsTUFBTUUsS0FBSztJQUNiLENBQUMsQ0FBQztFQUNOO0VBRUFHLFdBQVdBLENBQUEsRUFBRztJQUNaLElBQUksQ0FBQ0MsS0FBSyxDQUFDLFFBQVEsRUFBRSxtQkFBbUIsRUFBRWxELFVBQVUsQ0FBQ21ELDZCQUE2QixFQUFFekIsR0FBRyxJQUFJO01BQ3pGLE9BQU8sSUFBSSxDQUFDRCxXQUFXLENBQUNDLEdBQUcsQ0FBQztJQUM5QixDQUFDLENBQUM7RUFDSjtBQUNGO0FBQUMwQixPQUFBLENBQUE3QixXQUFBLEdBQUFBLFdBQUE7QUFBQSxJQUFBOEIsUUFBQSxHQUFBRCxPQUFBLENBQUF0QyxPQUFBLEdBRWNTLFdBQVciLCJpZ25vcmVMaXN0IjpbXX0=
|