parse-server 8.0.0-alpha.9 → 8.0.0
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/README.md +1 -3
- package/lib/Adapters/AdapterLoader.js +1 -2
- package/lib/Adapters/Cache/RedisCacheAdapter.js +2 -2
- package/lib/Adapters/PubSub/RedisPubSub.js +22 -3
- package/lib/Adapters/Storage/Postgres/PostgresStorageAdapter.js +4 -4
- package/lib/Config.js +19 -1
- package/lib/Controllers/AnalyticsController.js +3 -3
- package/lib/Controllers/UserController.js +43 -48
- package/lib/GraphQL/helpers/objectsQueries.js +2 -1
- package/lib/GraphQL/loaders/usersMutations.js +2 -6
- package/lib/Options/Definitions.js +6 -1
- package/lib/Options/docs.js +3 -2
- package/lib/Options/index.js +1 -1
- package/lib/ParseServer.js +10 -5
- package/lib/PromiseRouter.js +2 -2
- package/lib/Routers/AggregateRouter.js +2 -2
- package/lib/Routers/AudiencesRouter.js +2 -2
- package/lib/Routers/ClassesRouter.js +5 -5
- package/lib/Routers/CloudCodeRouter.js +3 -3
- package/lib/Routers/FilesRouter.js +2 -3
- package/lib/Routers/FunctionsRouter.js +2 -2
- package/lib/Routers/GlobalConfigRouter.js +3 -3
- package/lib/Routers/GraphQLRouter.js +2 -2
- package/lib/Routers/HooksRouter.js +5 -5
- package/lib/Routers/IAPValidationRouter.js +4 -4
- package/lib/Routers/InstallationsRouter.js +2 -2
- package/lib/Routers/PagesRouter.js +22 -36
- package/lib/Routers/PublicAPIRouter.js +26 -32
- package/lib/Routers/PushRouter.js +2 -2
- package/lib/Routers/SchemasRouter.js +6 -6
- package/lib/Routers/UsersRouter.js +20 -10
- package/lib/SchemaMigrations/DefinedSchemas.js +3 -3
- package/lib/batch.js +5 -5
- package/lib/middlewares.js +29 -6
- package/lib/vendor/mongodbUrl.js +2 -2
- package/package.json +15 -17
- package/public_html/invalid_verification_link.html +3 -3
|
@@ -25,7 +25,6 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
25
25
|
}
|
|
26
26
|
verifyEmail(req) {
|
|
27
27
|
const {
|
|
28
|
-
username,
|
|
29
28
|
token: rawToken
|
|
30
29
|
} = req.query;
|
|
31
30
|
const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
|
|
@@ -37,24 +36,21 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
37
36
|
if (!config.publicServerURL) {
|
|
38
37
|
return this.missingPublicServerURL();
|
|
39
38
|
}
|
|
40
|
-
if (!token
|
|
39
|
+
if (!token) {
|
|
41
40
|
return this.invalidLink(req);
|
|
42
41
|
}
|
|
43
42
|
const userController = config.userController;
|
|
44
|
-
return userController.verifyEmail(
|
|
45
|
-
const params = _querystring.default.stringify({
|
|
46
|
-
username
|
|
47
|
-
});
|
|
43
|
+
return userController.verifyEmail(token).then(() => {
|
|
48
44
|
return Promise.resolve({
|
|
49
45
|
status: 302,
|
|
50
|
-
location: `${config.verifyEmailSuccessURL}
|
|
46
|
+
location: `${config.verifyEmailSuccessURL}`
|
|
51
47
|
});
|
|
52
48
|
}, () => {
|
|
53
|
-
return this.invalidVerificationLink(req);
|
|
49
|
+
return this.invalidVerificationLink(req, token);
|
|
54
50
|
});
|
|
55
51
|
}
|
|
56
52
|
resendVerificationEmail(req) {
|
|
57
|
-
const username = req.body
|
|
53
|
+
const username = req.body?.username;
|
|
58
54
|
const appId = req.params.appId;
|
|
59
55
|
const config = _Config.default.get(appId);
|
|
60
56
|
if (!config) {
|
|
@@ -63,11 +59,12 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
63
59
|
if (!config.publicServerURL) {
|
|
64
60
|
return this.missingPublicServerURL();
|
|
65
61
|
}
|
|
66
|
-
|
|
62
|
+
const token = req.body.token;
|
|
63
|
+
if (!username && !token) {
|
|
67
64
|
return this.invalidLink(req);
|
|
68
65
|
}
|
|
69
66
|
const userController = config.userController;
|
|
70
|
-
return userController.resendVerificationEmail(username, req).then(() => {
|
|
67
|
+
return userController.resendVerificationEmail(username, req, token).then(() => {
|
|
71
68
|
return Promise.resolve({
|
|
72
69
|
status: 302,
|
|
73
70
|
location: `${config.linkSendSuccessURL}`
|
|
@@ -112,18 +109,16 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
112
109
|
return this.missingPublicServerURL();
|
|
113
110
|
}
|
|
114
111
|
const {
|
|
115
|
-
username,
|
|
116
112
|
token: rawToken
|
|
117
113
|
} = req.query;
|
|
118
114
|
const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
|
|
119
|
-
if (!
|
|
115
|
+
if (!token) {
|
|
120
116
|
return this.invalidLink(req);
|
|
121
117
|
}
|
|
122
|
-
return config.userController.checkResetTokenValidity(
|
|
118
|
+
return config.userController.checkResetTokenValidity(token).then(() => {
|
|
123
119
|
const params = _querystring.default.stringify({
|
|
124
120
|
token,
|
|
125
121
|
id: config.applicationId,
|
|
126
|
-
username,
|
|
127
122
|
app: config.appName
|
|
128
123
|
});
|
|
129
124
|
return Promise.resolve({
|
|
@@ -143,24 +138,20 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
143
138
|
return this.missingPublicServerURL();
|
|
144
139
|
}
|
|
145
140
|
const {
|
|
146
|
-
username,
|
|
147
141
|
new_password,
|
|
148
142
|
token: rawToken
|
|
149
|
-
} = req.body;
|
|
143
|
+
} = req.body || {};
|
|
150
144
|
const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;
|
|
151
|
-
if ((!
|
|
145
|
+
if ((!token || !new_password) && req.xhr === false) {
|
|
152
146
|
return this.invalidLink(req);
|
|
153
147
|
}
|
|
154
|
-
if (!username) {
|
|
155
|
-
throw new _node.Parse.Error(_node.Parse.Error.USERNAME_MISSING, 'Missing username');
|
|
156
|
-
}
|
|
157
148
|
if (!token) {
|
|
158
149
|
throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, 'Missing token');
|
|
159
150
|
}
|
|
160
151
|
if (!new_password) {
|
|
161
152
|
throw new _node.Parse.Error(_node.Parse.Error.PASSWORD_MISSING, 'Missing password');
|
|
162
153
|
}
|
|
163
|
-
return config.userController.updatePassword(
|
|
154
|
+
return config.userController.updatePassword(token, new_password).then(() => {
|
|
164
155
|
return Promise.resolve({
|
|
165
156
|
success: true
|
|
166
157
|
});
|
|
@@ -170,13 +161,17 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
170
161
|
err
|
|
171
162
|
});
|
|
172
163
|
}).then(result => {
|
|
173
|
-
const
|
|
174
|
-
username: username,
|
|
164
|
+
const queryString = {
|
|
175
165
|
token: token,
|
|
176
166
|
id: config.applicationId,
|
|
177
167
|
error: result.err,
|
|
178
168
|
app: config.appName
|
|
179
|
-
}
|
|
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);
|
|
180
175
|
if (req.xhr) {
|
|
181
176
|
if (result.success) {
|
|
182
177
|
return Promise.resolve({
|
|
@@ -188,8 +183,7 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
188
183
|
throw new _node.Parse.Error(_node.Parse.Error.OTHER_CAUSE, `${result.err}`);
|
|
189
184
|
}
|
|
190
185
|
}
|
|
191
|
-
const
|
|
192
|
-
const location = result.success ? `${config.passwordResetSuccessURL}?username=${encodedUsername}` : `${config.choosePasswordURL}?${params}`;
|
|
186
|
+
const location = result.success ? `${config.passwordResetSuccessURL}` : `${config.choosePasswordURL}?${params}`;
|
|
193
187
|
return Promise.resolve({
|
|
194
188
|
status: 302,
|
|
195
189
|
location
|
|
@@ -202,12 +196,12 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
202
196
|
location: req.config.invalidLinkURL
|
|
203
197
|
});
|
|
204
198
|
}
|
|
205
|
-
invalidVerificationLink(req) {
|
|
199
|
+
invalidVerificationLink(req, token) {
|
|
206
200
|
const config = req.config;
|
|
207
|
-
if (req.
|
|
201
|
+
if (req.params.appId) {
|
|
208
202
|
const params = _querystring.default.stringify({
|
|
209
|
-
|
|
210
|
-
|
|
203
|
+
appId: req.params.appId,
|
|
204
|
+
token
|
|
211
205
|
});
|
|
212
206
|
return Promise.resolve({
|
|
213
207
|
status: 302,
|
|
@@ -267,4 +261,4 @@ class PublicAPIRouter extends _PromiseRouter.default {
|
|
|
267
261
|
}
|
|
268
262
|
exports.PublicAPIRouter = PublicAPIRouter;
|
|
269
263
|
var _default = exports.default = PublicAPIRouter;
|
|
270
|
-
//# 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","username","token","rawToken","query","toString","appId","params","config","Config","get","invalidRequest","publicServerURL","missingPublicServerURL","invalidLink","userController","then","qs","stringify","Promise","status","location","verifyEmailSuccessURL","invalidVerificationLink","resendVerificationEmail","body","linkSendSuccessURL","linkSendFailURL","changePassword","reject","id","text","fs","readFile","err","data","replace","requestResetPassword","checkResetTokenValidity","applicationId","app","appName","choosePasswordURL","resetPassword","new_password","xhr","Parse","Error","USERNAME_MISSING","OTHER_CAUSE","PASSWORD_MISSING","updatePassword","success","result","error","response","encodedUsername","encodeURIComponent","passwordResetSuccessURL","invalidLinkURL","invalidVerificationLinkURL","message","setConfig","mountRoutes","route","expressRouter","router","express","Router","use","static","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 { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!token || !username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n    return userController.verifyEmail(username, token).then(\n      () => {\n        const params = qs.stringify({ username });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.verifyEmailSuccessURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidVerificationLink(req);\n      }\n    );\n  }\n\n  resendVerificationEmail(req) {\n    const username = req.body.username;\n    const appId = req.params.appId;\n    const config = Config.get(appId);\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    if (!username) {\n      return this.invalidLink(req);\n    }\n\n    const userController = config.userController;\n\n    return userController.resendVerificationEmail(username, req).then(\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendSuccessURL}`,\n        });\n      },\n      () => {\n        return Promise.resolve({\n          status: 302,\n          location: `${config.linkSendFailURL}`,\n        });\n      }\n    );\n  }\n\n  changePassword(req) {\n    return new Promise((resolve, reject) => {\n      const config = Config.get(req.query.id);\n\n      if (!config) {\n        this.invalidRequest();\n      }\n\n      if (!config.publicServerURL) {\n        return resolve({\n          status: 404,\n          text: 'Not found.',\n        });\n      }\n      // Should we keep the file in memory or leave like that?\n      fs.readFile(path.resolve(views, 'choose_password'), 'utf-8', (err, data) => {\n        if (err) {\n          return reject(err);\n        }\n        data = data.replace('PARSE_SERVER_URL', `'${config.publicServerURL}'`);\n        resolve({\n          text: data,\n        });\n      });\n    });\n  }\n\n  requestResetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, token: rawToken } = req.query;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if (!username || !token) {\n      return this.invalidLink(req);\n    }\n\n    return config.userController.checkResetTokenValidity(username, token).then(\n      () => {\n        const params = qs.stringify({\n          token,\n          id: config.applicationId,\n          username,\n          app: config.appName,\n        });\n        return Promise.resolve({\n          status: 302,\n          location: `${config.choosePasswordURL}?${params}`,\n        });\n      },\n      () => {\n        return this.invalidLink(req);\n      }\n    );\n  }\n\n  resetPassword(req) {\n    const config = req.config;\n\n    if (!config) {\n      this.invalidRequest();\n    }\n\n    if (!config.publicServerURL) {\n      return this.missingPublicServerURL();\n    }\n\n    const { username, new_password, token: rawToken } = req.body;\n    const token = rawToken && typeof rawToken !== 'string' ? rawToken.toString() : rawToken;\n\n    if ((!username || !token || !new_password) && req.xhr === false) {\n      return this.invalidLink(req);\n    }\n\n    if (!username) {\n      throw new Parse.Error(Parse.Error.USERNAME_MISSING, 'Missing username');\n    }\n\n    if (!token) {\n      throw new Parse.Error(Parse.Error.OTHER_CAUSE, 'Missing token');\n    }\n\n    if (!new_password) {\n      throw new Parse.Error(Parse.Error.PASSWORD_MISSING, 'Missing password');\n    }\n\n    return config.userController\n      .updatePassword(username, token, new_password)\n      .then(\n        () => {\n          return Promise.resolve({\n            success: true,\n          });\n        },\n        err => {\n          return Promise.resolve({\n            success: false,\n            err,\n          });\n        }\n      )\n      .then(result => {\n        const params = qs.stringify({\n          username: username,\n          token: token,\n          id: config.applicationId,\n          error: result.err,\n          app: config.appName,\n        });\n\n        if (req.xhr) {\n          if (result.success) {\n            return Promise.resolve({\n              status: 200,\n              response: 'Password successfully reset',\n            });\n          }\n          if (result.err) {\n            throw new Parse.Error(Parse.Error.OTHER_CAUSE, `${result.err}`);\n          }\n        }\n\n        const encodedUsername = encodeURIComponent(username);\n        const location = result.success\n          ? `${config.passwordResetSuccessURL}?username=${encodedUsername}`\n          : `${config.choosePasswordURL}?${params}`;\n\n        return Promise.resolve({\n          status: 302,\n          location,\n        });\n      });\n  }\n\n  invalidLink(req) {\n    return Promise.resolve({\n      status: 302,\n      location: req.config.invalidLinkURL,\n    });\n  }\n\n  invalidVerificationLink(req) {\n    const config = req.config;\n    if (req.query.username && req.params.appId) {\n      const params = qs.stringify({\n        username: req.query.username,\n        appId: req.params.appId,\n      });\n      return Promise.resolve({\n        status: 302,\n        location: `${config.invalidVerificationLinkURL}?${params}`,\n      });\n    } else {\n      return this.invalidLink(req);\n    }\n  }\n\n  missingPublicServerURL() {\n    return Promise.resolve({\n      text: 'Not found.',\n      status: 404,\n    });\n  }\n\n  invalidRequest() {\n    const error = new Error();\n    error.status = 403;\n    error.message = 'unauthorized';\n    throw error;\n  }\n\n  setConfig(req) {\n    req.config = Config.get(req.params.appId);\n    return Promise.resolve();\n  }\n\n  mountRoutes() {\n    this.route(\n      'GET',\n      '/apps/:appId/verify_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.verifyEmail(req);\n      }\n    );\n\n    this.route(\n      'POST',\n      '/apps/:appId/resend_verification_email',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resendVerificationEmail(req);\n      }\n    );\n\n    this.route('GET', '/apps/choose_password', req => {\n      return this.changePassword(req);\n    });\n\n    this.route(\n      'POST',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.resetPassword(req);\n      }\n    );\n\n    this.route(\n      'GET',\n      '/apps/:appId/request_password_reset',\n      req => {\n        this.setConfig(req);\n      },\n      req => {\n        return this.requestResetPassword(req);\n      }\n    );\n  }\n\n  expressRouter() {\n    const router = express.Router();\n    router.use('/apps', express.static(public_html));\n    router.use('/', super.expressRouter());\n    return router;\n  }\n}\n\nexport default PublicAPIRouter;\n"],"mappings":"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","ignoreList":[]}
|
|
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":[]}
|
|
@@ -28,7 +28,7 @@ class PushRouter extends _PromiseRouter.default {
|
|
|
28
28
|
resolve = _resolve;
|
|
29
29
|
});
|
|
30
30
|
let pushStatusId;
|
|
31
|
-
pushController.sendPush(req.body, where, req.config, req.auth, objectId => {
|
|
31
|
+
pushController.sendPush(req.body || {}, where, req.config, req.auth, objectId => {
|
|
32
32
|
pushStatusId = objectId;
|
|
33
33
|
resolve({
|
|
34
34
|
headers: {
|
|
@@ -72,4 +72,4 @@ class PushRouter extends _PromiseRouter.default {
|
|
|
72
72
|
}
|
|
73
73
|
exports.PushRouter = PushRouter;
|
|
74
74
|
var _default = exports.default = PushRouter;
|
|
75
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","middleware","_interopRequireWildcard","_node","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","PushRouter","PromiseRouter","mountRoutes","route","promiseEnforceMasterKeyAccess","handlePOST","req","auth","isReadOnly","Parse","Error","OPERATION_FORBIDDEN","pushController","config","PUSH_MISCONFIGURED","where","getQueryCondition","resolve","promise","Promise","_resolve","pushStatusId","sendPush","body","objectId","headers","response","result","catch","err","loggerController","error","hasWhere","hasChannels","channels","$in","exports","_default"],"sources":["../../src/Routers/PushRouter.js"],"sourcesContent":["import PromiseRouter from '../PromiseRouter';\nimport * as middleware from '../middlewares';\nimport { Parse } from 'parse/node';\n\nexport class PushRouter extends PromiseRouter {\n  mountRoutes() {\n    this.route('POST', '/push', middleware.promiseEnforceMasterKeyAccess, PushRouter.handlePOST);\n  }\n\n  static handlePOST(req) {\n    if (req.auth.isReadOnly) {\n      throw new Parse.Error(\n        Parse.Error.OPERATION_FORBIDDEN,\n        \"read-only masterKey isn't allowed to send push notifications.\"\n      );\n    }\n    const pushController = req.config.pushController;\n    if (!pushController) {\n      throw new Parse.Error(Parse.Error.PUSH_MISCONFIGURED, 'Push controller is not set');\n    }\n\n    const where = PushRouter.getQueryCondition(req);\n    let resolve;\n    const promise = new Promise(_resolve => {\n      resolve = _resolve;\n    });\n    let pushStatusId;\n    pushController\n      .sendPush(req.body || {}, where, req.config, req.auth, objectId => {\n        pushStatusId = objectId;\n        resolve({\n          headers: {\n            'X-Parse-Push-Status-Id': pushStatusId,\n          },\n          response: {\n            result: true,\n          },\n        });\n      })\n      .catch(err => {\n        req.config.loggerController.error(\n          `_PushStatus ${pushStatusId}: error while sending push`,\n          err\n        );\n      });\n    return promise;\n  }\n\n  /**\n   * Get query condition from the request body.\n   * @param {Object} req A request object\n   * @returns {Object} The query condition, the where field in a query api call\n   */\n  static getQueryCondition(req) {\n    const body = req.body || {};\n    const hasWhere = typeof body.where !== 'undefined';\n    const hasChannels = typeof body.channels !== 'undefined';\n\n    let where;\n    if (hasWhere && hasChannels) {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Channels and query can not be set at the same time.'\n      );\n    } else if (hasWhere) {\n      where = body.where;\n    } else if (hasChannels) {\n      where = {\n        channels: {\n          $in: body.channels,\n        },\n      };\n    } else {\n      throw new Parse.Error(\n        Parse.Error.PUSH_MISCONFIGURED,\n        'Sending a push requires either \"channels\" or a \"where\" query.'\n      );\n    }\n    return where;\n  }\n}\n\nexport default PushRouter;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -71,27 +71,27 @@ async function createSchema(req) {
|
|
|
71
71
|
if (req.auth.isReadOnly) {
|
|
72
72
|
throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to create a schema.");
|
|
73
73
|
}
|
|
74
|
-
if (req.params.className && req.body
|
|
74
|
+
if (req.params.className && req.body?.className) {
|
|
75
75
|
if (req.params.className != req.body.className) {
|
|
76
76
|
return classNameMismatchResponse(req.body.className, req.params.className);
|
|
77
77
|
}
|
|
78
78
|
}
|
|
79
|
-
const className = req.params.className || req.body
|
|
79
|
+
const className = req.params.className || req.body?.className;
|
|
80
80
|
if (!className) {
|
|
81
81
|
throw new Parse.Error(135, `POST ${req.path} needs a class name.`);
|
|
82
82
|
}
|
|
83
|
-
return await internalCreateSchema(className, req.body, req.config);
|
|
83
|
+
return await internalCreateSchema(className, req.body || {}, req.config);
|
|
84
84
|
}
|
|
85
85
|
function modifySchema(req) {
|
|
86
86
|
checkIfDefinedSchemasIsUsed(req);
|
|
87
87
|
if (req.auth.isReadOnly) {
|
|
88
88
|
throw new Parse.Error(Parse.Error.OPERATION_FORBIDDEN, "read-only masterKey isn't allowed to update a schema.");
|
|
89
89
|
}
|
|
90
|
-
if (req.body
|
|
90
|
+
if (req.body?.className && req.body.className != req.params.className) {
|
|
91
91
|
return classNameMismatchResponse(req.body.className, req.params.className);
|
|
92
92
|
}
|
|
93
93
|
const className = req.params.className;
|
|
94
|
-
return internalUpdateSchema(className, req.body, req.config);
|
|
94
|
+
return internalUpdateSchema(className, req.body || {}, req.config);
|
|
95
95
|
}
|
|
96
96
|
const deleteSchema = req => {
|
|
97
97
|
if (req.auth.isReadOnly) {
|
|
@@ -115,4 +115,4 @@ class SchemasRouter extends _PromiseRouter.default {
|
|
|
115
115
|
}
|
|
116
116
|
}
|
|
117
117
|
exports.SchemasRouter = SchemasRouter;
|
|
118
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","middleware","_interopRequireWildcard","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Parse","SchemaController","classNameMismatchResponse","bodyClass","pathClass","Error","INVALID_CLASS_NAME","getAllSchemas","req","config","database","loadSchema","clearCache","then","schemaController","getAllClasses","schemas","response","results","getOneSchema","className","params","schema","catch","error","undefined","INTERNAL_SERVER_ERROR","checkIfDefinedSchemasIsUsed","lockSchemas","OPERATION_FORBIDDEN","internalCreateSchema","body","controller","addClassIfNotExists","fields","classLevelPermissions","indexes","exports","internalUpdateSchema","updateClass","createSchema","auth","isReadOnly","path","modifySchema","deleteSchema","classNameIsValid","invalidClassNameMessage","SchemasRouter","PromiseRouter","mountRoutes","route","promiseEnforceMasterKeyAccess"],"sources":["../../src/Routers/SchemasRouter.js"],"sourcesContent":["// schemas.js\n\nvar Parse = require('parse/node').Parse,\n  SchemaController = require('../Controllers/SchemaController');\n\nimport PromiseRouter from '../PromiseRouter';\nimport * as middleware from '../middlewares';\n\nfunction classNameMismatchResponse(bodyClass, pathClass) {\n  throw new Parse.Error(\n    Parse.Error.INVALID_CLASS_NAME,\n    `Class name mismatch between ${bodyClass} and ${pathClass}.`\n  );\n}\n\nfunction getAllSchemas(req) {\n  return req.config.database\n    .loadSchema({ clearCache: true })\n    .then(schemaController => schemaController.getAllClasses({ clearCache: true }))\n    .then(schemas => ({ response: { results: schemas } }));\n}\n\nfunction getOneSchema(req) {\n  const className = req.params.className;\n  return req.config.database\n    .loadSchema({ clearCache: true })\n    .then(schemaController => schemaController.getOneSchema(className, true))\n    .then(schema => ({ response: schema }))\n    .catch(error => {\n      if (error === undefined) {\n        throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class ${className} does not exist.`);\n      } else {\n        throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Database adapter error.');\n      }\n    });\n}\n\nconst checkIfDefinedSchemasIsUsed = req => {\n  if (req.config?.schema?.lockSchemas === true) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      'Cannot perform this operation when schemas options is used.'\n    );\n  }\n};\n\nexport const internalCreateSchema = async (className, body, config) => {\n  const controller = await config.database.loadSchema({ clearCache: true });\n  const response = await controller.addClassIfNotExists(\n    className,\n    body.fields,\n    body.classLevelPermissions,\n    body.indexes\n  );\n  return {\n    response,\n  };\n};\n\nexport const internalUpdateSchema = async (className, body, config) => {\n  const controller = await config.database.loadSchema({ clearCache: true });\n  const response = await controller.updateClass(\n    className,\n    body.fields || {},\n    body.classLevelPermissions,\n    body.indexes,\n    config.database\n  );\n  return { response };\n};\n\nasync function createSchema(req) {\n  checkIfDefinedSchemasIsUsed(req);\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to create a schema.\"\n    );\n  }\n  if (req.params.className && req.body.className) {\n    if (req.params.className != req.body.className) {\n      return classNameMismatchResponse(req.body.className, req.params.className);\n    }\n  }\n\n  const className = req.params.className || req.body.className;\n  if (!className) {\n    throw new Parse.Error(135, `POST ${req.path} needs a class name.`);\n  }\n\n  return await internalCreateSchema(className, req.body, req.config);\n}\n\nfunction modifySchema(req) {\n  checkIfDefinedSchemasIsUsed(req);\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to update a schema.\"\n    );\n  }\n  if (req.body.className && req.body.className != req.params.className) {\n    return classNameMismatchResponse(req.body.className, req.params.className);\n  }\n  const className = req.params.className;\n\n  return internalUpdateSchema(className, req.body, req.config);\n}\n\nconst deleteSchema = req => {\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to delete a schema.\"\n    );\n  }\n  if (!SchemaController.classNameIsValid(req.params.className)) {\n    throw new Parse.Error(\n      Parse.Error.INVALID_CLASS_NAME,\n      SchemaController.invalidClassNameMessage(req.params.className)\n    );\n  }\n  return req.config.database.deleteSchema(req.params.className).then(() => ({ response: {} }));\n};\n\nexport class SchemasRouter extends PromiseRouter {\n  mountRoutes() {\n    this.route('GET', '/schemas', middleware.promiseEnforceMasterKeyAccess, getAllSchemas);\n    this.route(\n      'GET',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      getOneSchema\n    );\n    this.route('POST', '/schemas', middleware.promiseEnforceMasterKeyAccess, createSchema);\n    this.route(\n      'POST',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      createSchema\n    );\n    this.route(\n      'PUT',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      modifySchema\n    );\n    this.route(\n      'DELETE',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      deleteSchema\n    );\n  }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_PromiseRouter","_interopRequireDefault","require","middleware","_interopRequireWildcard","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Parse","SchemaController","classNameMismatchResponse","bodyClass","pathClass","Error","INVALID_CLASS_NAME","getAllSchemas","req","config","database","loadSchema","clearCache","then","schemaController","getAllClasses","schemas","response","results","getOneSchema","className","params","schema","catch","error","undefined","INTERNAL_SERVER_ERROR","checkIfDefinedSchemasIsUsed","lockSchemas","OPERATION_FORBIDDEN","internalCreateSchema","body","controller","addClassIfNotExists","fields","classLevelPermissions","indexes","exports","internalUpdateSchema","updateClass","createSchema","auth","isReadOnly","path","modifySchema","deleteSchema","classNameIsValid","invalidClassNameMessage","SchemasRouter","PromiseRouter","mountRoutes","route","promiseEnforceMasterKeyAccess"],"sources":["../../src/Routers/SchemasRouter.js"],"sourcesContent":["// schemas.js\n\nvar Parse = require('parse/node').Parse,\n  SchemaController = require('../Controllers/SchemaController');\n\nimport PromiseRouter from '../PromiseRouter';\nimport * as middleware from '../middlewares';\n\nfunction classNameMismatchResponse(bodyClass, pathClass) {\n  throw new Parse.Error(\n    Parse.Error.INVALID_CLASS_NAME,\n    `Class name mismatch between ${bodyClass} and ${pathClass}.`\n  );\n}\n\nfunction getAllSchemas(req) {\n  return req.config.database\n    .loadSchema({ clearCache: true })\n    .then(schemaController => schemaController.getAllClasses({ clearCache: true }))\n    .then(schemas => ({ response: { results: schemas } }));\n}\n\nfunction getOneSchema(req) {\n  const className = req.params.className;\n  return req.config.database\n    .loadSchema({ clearCache: true })\n    .then(schemaController => schemaController.getOneSchema(className, true))\n    .then(schema => ({ response: schema }))\n    .catch(error => {\n      if (error === undefined) {\n        throw new Parse.Error(Parse.Error.INVALID_CLASS_NAME, `Class ${className} does not exist.`);\n      } else {\n        throw new Parse.Error(Parse.Error.INTERNAL_SERVER_ERROR, 'Database adapter error.');\n      }\n    });\n}\n\nconst checkIfDefinedSchemasIsUsed = req => {\n  if (req.config?.schema?.lockSchemas === true) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      'Cannot perform this operation when schemas options is used.'\n    );\n  }\n};\n\nexport const internalCreateSchema = async (className, body, config) => {\n  const controller = await config.database.loadSchema({ clearCache: true });\n  const response = await controller.addClassIfNotExists(\n    className,\n    body.fields,\n    body.classLevelPermissions,\n    body.indexes\n  );\n  return {\n    response,\n  };\n};\n\nexport const internalUpdateSchema = async (className, body, config) => {\n  const controller = await config.database.loadSchema({ clearCache: true });\n  const response = await controller.updateClass(\n    className,\n    body.fields || {},\n    body.classLevelPermissions,\n    body.indexes,\n    config.database\n  );\n  return { response };\n};\n\nasync function createSchema(req) {\n  checkIfDefinedSchemasIsUsed(req);\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to create a schema.\"\n    );\n  }\n  if (req.params.className && req.body?.className) {\n    if (req.params.className != req.body.className) {\n      return classNameMismatchResponse(req.body.className, req.params.className);\n    }\n  }\n\n  const className = req.params.className || req.body?.className;\n  if (!className) {\n    throw new Parse.Error(135, `POST ${req.path} needs a class name.`);\n  }\n\n  return await internalCreateSchema(className, req.body || {}, req.config);\n}\n\nfunction modifySchema(req) {\n  checkIfDefinedSchemasIsUsed(req);\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to update a schema.\"\n    );\n  }\n  if (req.body?.className && req.body.className != req.params.className) {\n    return classNameMismatchResponse(req.body.className, req.params.className);\n  }\n  const className = req.params.className;\n\n  return internalUpdateSchema(className, req.body || {}, req.config);\n}\n\nconst deleteSchema = req => {\n  if (req.auth.isReadOnly) {\n    throw new Parse.Error(\n      Parse.Error.OPERATION_FORBIDDEN,\n      \"read-only masterKey isn't allowed to delete a schema.\"\n    );\n  }\n  if (!SchemaController.classNameIsValid(req.params.className)) {\n    throw new Parse.Error(\n      Parse.Error.INVALID_CLASS_NAME,\n      SchemaController.invalidClassNameMessage(req.params.className)\n    );\n  }\n  return req.config.database.deleteSchema(req.params.className).then(() => ({ response: {} }));\n};\n\nexport class SchemasRouter extends PromiseRouter {\n  mountRoutes() {\n    this.route('GET', '/schemas', middleware.promiseEnforceMasterKeyAccess, getAllSchemas);\n    this.route(\n      'GET',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      getOneSchema\n    );\n    this.route('POST', '/schemas', middleware.promiseEnforceMasterKeyAccess, createSchema);\n    this.route(\n      'POST',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      createSchema\n    );\n    this.route(\n      'PUT',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      modifySchema\n    );\n    this.route(\n      'DELETE',\n      '/schemas/:className',\n      middleware.promiseEnforceMasterKeyAccess,\n      deleteSchema\n    );\n  }\n}\n"],"mappings":"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","ignoreList":[]}
|