Skip to content

Commit

Permalink
Ignore authorization headers if not Bearer (#325)
Browse files Browse the repository at this point in the history
* Ignore authorization headers if not Bearer

* Update jwt.js

* lint fix

* Apply suggestions from code review

Co-authored-by: KaKa <23028015+climba03003@users.noreply.github.com>
Signed-off-by: cberescu <ciprian@berescu.com>

* Update jwt.js

Co-authored-by: Gürgün Dayıoğlu <gurgun.dayioglu@icloud.com>
Signed-off-by: cberescu <ciprian@berescu.com>

* fixed tests

---------

Signed-off-by: cberescu <ciprian@berescu.com>
Co-authored-by: Ciprian <cberescu@gmail.com>
Co-authored-by: KaKa <23028015+climba03003@users.noreply.github.com>
Co-authored-by: Gürgün Dayıoğlu <gurgun.dayioglu@icloud.com>
  • Loading branch information
4 people authored Jan 7, 2024
1 parent 7a8802f commit 3bab18e
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 16 deletions.
7 changes: 1 addition & 6 deletions jwt.js
Original file line number Diff line number Diff line change
Expand Up @@ -240,15 +240,10 @@ function fastifyJwt (fastify, options, next) {
if (!token) {
throw new BadRequestError()
}
} else if ((request.headers && request.headers.authorization) && (!onlyCookie)) {
} else if (request.headers.authorization && !onlyCookie && /^Bearer\s/i.test(request.headers.authorization)) {
const parts = request.headers.authorization.split(' ')
if (parts.length === 2) {
const scheme = parts[0]
token = parts[1]

if (!/^Bearer$/i.test(scheme)) {
throw new BadRequestError()
}
} else {
throw new BadRequestError()
}
Expand Down
18 changes: 8 additions & 10 deletions test/jwt.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -1617,8 +1617,7 @@ test('errors', function (t) {
t.equal(response.statusCode, 401)
})
})

t.test('authorization header format error', function (t) {
t.test('no bearer authorization header error', function (t) {
t.plan(2)

fastify.inject({
Expand All @@ -1629,8 +1628,8 @@ test('errors', function (t) {
}
}).then(function (response) {
const error = JSON.parse(response.payload)
t.equal(error.message, 'Format is Authorization: Bearer [token]')
t.equal(response.statusCode, 400)
t.equal(error.message, 'No Authorization was found in request.headers')
t.equal(response.statusCode, 401)
})
})

Expand Down Expand Up @@ -2196,7 +2195,7 @@ test('token in cookie, with @fastify/cookie parsing', function (t) {
})

t.test('both authorization and cookie headers present, header malformed', function (t) {
t.plan(3)
t.plan(2)
fastify.inject({
method: 'post',
url: '/sign',
Expand All @@ -2215,9 +2214,8 @@ test('token in cookie, with @fastify/cookie parsing', function (t) {
authorization: 'BearerX'
}
}).then(function (verifyResponse) {
const error = JSON.parse(verifyResponse.payload)
t.equal(error.message, 'Format is Authorization: Bearer [token]')
t.equal(error.statusCode, 400)
const decodedToken = JSON.parse(verifyResponse.payload)
t.equal(decodedToken.foo, 'bar')
})
})
})
Expand Down Expand Up @@ -2394,8 +2392,8 @@ test('custom response messages', function (t) {
}
}).then(function (response) {
const error = JSON.parse(response.payload)
t.equal(error.message, 'Format is Authorization: Bearer [token]')
t.equal(response.statusCode, 400)
t.equal(error.message, 'auth header missing')
t.equal(response.statusCode, 401)
})
})

Expand Down

0 comments on commit 3bab18e

Please sign in to comment.