mirror of
https://github.com/GSA/notifications-api.git
synced 2025-12-23 08:51:30 -05:00
This pull request fixes a bug in authentication.
If the service does not have any api keys, there would be an error but it was not formed well.
This commit is contained in:
@@ -48,6 +48,8 @@ def requires_auth():
|
|||||||
except TokenDecodeError:
|
except TokenDecodeError:
|
||||||
errors_resp = authentication_response("Invalid token: signature", 403)
|
errors_resp = authentication_response("Invalid token: signature", 403)
|
||||||
|
|
||||||
|
if not api_client['secret']:
|
||||||
|
errors_resp = authentication_response("Invalid token: signature", 403)
|
||||||
return errors_resp
|
return errors_resp
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -273,6 +273,27 @@ def test_authentication_returns_error_when_api_client_has_no_secrets(notify_api,
|
|||||||
notify_api.config['ADMIN_CLIENT_SECRET'] = api_secret
|
notify_api.config['ADMIN_CLIENT_SECRET'] = api_secret
|
||||||
|
|
||||||
|
|
||||||
|
def test_authentication_returns_error_when_service_has_no_secrets(notify_api,
|
||||||
|
notify_db,
|
||||||
|
notify_db_session,
|
||||||
|
sample_service):
|
||||||
|
with notify_api.test_request_context():
|
||||||
|
with notify_api.test_client() as client:
|
||||||
|
import uuid
|
||||||
|
token = create_jwt_token(
|
||||||
|
request_method="GET",
|
||||||
|
request_path='/service',
|
||||||
|
secret=str(uuid.uuid4()),
|
||||||
|
client_id=str(sample_service.id))
|
||||||
|
|
||||||
|
response = client.get(
|
||||||
|
'/service',
|
||||||
|
headers={'Authorization': 'Bearer {}'.format(token)})
|
||||||
|
assert response.status_code == 403
|
||||||
|
error_message = json.loads(response.get_data())
|
||||||
|
assert error_message['message'] == 'Invalid token: signature'
|
||||||
|
|
||||||
|
|
||||||
def __create_get_token(service_id):
|
def __create_get_token(service_id):
|
||||||
if service_id:
|
if service_id:
|
||||||
return create_jwt_token(request_method="GET",
|
return create_jwt_token(request_method="GET",
|
||||||
|
|||||||
Reference in New Issue
Block a user