From 730e307d18371d7a78fc14a4fb9bd25550f494ce Mon Sep 17 00:00:00 2001 From: Paulo Barbosa Date: Mon, 12 Aug 2019 12:56:09 +0100 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9BFixed=20generic=20500=20for=20bad?= =?UTF-8?q?=20key=20param=20in=20content=20API=20(#10977)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit refs #10948 - Throws 400 when using multiple key query-values instead of a 500 error --- core/server/services/auth/api-key/content.js | 7 +++++++ core/server/translations/en.json | 1 + .../regression/api/v2/content/posts_spec.js | 9 +++++++++ .../unit/services/auth/api-key/content_spec.js | 17 +++++++++++++++++ 4 files changed, 34 insertions(+) diff --git a/core/server/services/auth/api-key/content.js b/core/server/services/auth/api-key/content.js index 53156fc529..3a3b4f9061 100644 --- a/core/server/services/auth/api-key/content.js +++ b/core/server/services/auth/api-key/content.js @@ -7,6 +7,13 @@ const authenticateContentApiKey = function authenticateContentApiKey(req, res, n return next(); } + if (req.query.key.constructor === Array) { + return next(new common.errors.BadRequestError({ + message: common.i18n.t('errors.middleware.auth.invalidRequest'), + code: 'INVALID_REQUEST' + })); + } + let key = req.query.key; models.ApiKey.findOne({secret: key}).then((apiKey) => { diff --git a/core/server/translations/en.json b/core/server/translations/en.json index 771b49f009..c2a86b7d7a 100644 --- a/core/server/translations/en.json +++ b/core/server/translations/en.json @@ -75,6 +75,7 @@ "unknownContentApiKey": "Unknown Content API Key", "adminApiKidMissing": "Admin API kid missing.", "invalidApiKeyType": "Invalid API Key type", + "invalidRequest": "Invalid Request", "invalidToken": "Invalid token", "invalidTokenWithMessage": "Invalid token: {message}", "incorrectAuthHeaderFormat": "Authorization header format is \"Authorization: Ghost [token]\"" diff --git a/core/test/regression/api/v2/content/posts_spec.js b/core/test/regression/api/v2/content/posts_spec.js index c4fc234d10..d8fefe49d8 100644 --- a/core/test/regression/api/v2/content/posts_spec.js +++ b/core/test/regression/api/v2/content/posts_spec.js @@ -154,4 +154,13 @@ describe('Posts', function () { localUtils.API.checkResponse(res.body.posts[0], 'post', null, null, ['id', 'title', 'slug']); }); }); + + it('can\'t read page with multiple keys', function () { + return request + .get(localUtils.API.getApiQuery(`posts?key=${validKey}&key=&fields=title,slug`)) + .set('Origin', testUtils.API.getURL()) + .expect('Content-Type', /json/) + .expect('Cache-Control', testUtils.cacheRules.private) + .expect(400); + }); }); diff --git a/core/test/unit/services/auth/api-key/content_spec.js b/core/test/unit/services/auth/api-key/content_spec.js index 17a4b7364b..4aa126857e 100644 --- a/core/test/unit/services/auth/api-key/content_spec.js +++ b/core/test/unit/services/auth/api-key/content_spec.js @@ -78,4 +78,21 @@ describe('Content API Key Auth', function () { done(); }); }); + + it('shouldn\'t authenticate with invalid request', function (done) { + const req = { + query: { + key: [this.fakeApiKey.secret, ''] + } + }; + const res = {}; + + authenticateContentApiKey(req, res, function next(err) { + should.exist(err); + should.equal(err instanceof common.errors.BadRequestError, true); + err.code.should.eql('INVALID_REQUEST'); + should.not.exist(req.api_key); + done(); + }); + }); });