Fixed support for "Bearer" and "Token" auth-schemes.

Removed the test for "Authentication: Bearer Token <TOKEN>" which was not supposed to exist (see https://github.com/channelcat/sanic/pull/821)
Also added a call to `split` when retrieving the token value to handle cases where there are leading or trailing spaces.
This commit is contained in:
François KUBLER 2017-06-29 10:23:49 +02:00
parent d2e14abfd5
commit 1f24abc3d2
2 changed files with 2 additions and 12 deletions

View File

@ -86,13 +86,13 @@ class Request(dict):
:return: token related to request :return: token related to request
""" """
prefixes = ('Bearer', 'Token ') prefixes = ('Bearer', 'Token')
auth_header = self.headers.get('Authorization') auth_header = self.headers.get('Authorization')
if auth_header is not None: if auth_header is not None:
for prefix in prefixes: for prefix in prefixes:
if prefix in auth_header: if prefix in auth_header:
return auth_header.partition(prefix)[-1] return auth_header.partition(prefix)[-1].strip()
return auth_header return auth_header

View File

@ -172,16 +172,6 @@ def test_token():
assert request.token == token assert request.token == token
token = 'a1d895e0-553a-421a-8e22-5ff8ecb48cbf'
headers = {
'content-type': 'application/json',
'Authorization': 'Bearer Token {}'.format(token)
}
request, response = app.test_client.get('/', headers=headers)
assert request.token == token
token = 'a1d895e0-553a-421a-8e22-5ff8ecb48cbf' token = 'a1d895e0-553a-421a-8e22-5ff8ecb48cbf'
headers = { headers = {
'content-type': 'application/json', 'content-type': 'application/json',