Island: Raise exception instead of returning bool in authenticate()

This commit is contained in:
Mike Salvatore 2021-10-28 14:45:44 -04:00
parent 730565c2aa
commit 28df604d7b
4 changed files with 18 additions and 9 deletions

View File

@ -18,6 +18,10 @@ class AlreadyRegisteredError(RegistrationNotNeededError):
""" Raise to indicate the reason why registration is not required """ """ Raise to indicate the reason why registration is not required """
class IncorrectCredentialsError(Exception):
""" Raise to indicate that authentication failed """
class RulePathCreatorNotFound(Exception): class RulePathCreatorNotFound(Exception):
""" Raise to indicate that ScoutSuite rule doesn't have a path creator""" """ Raise to indicate that ScoutSuite rule doesn't have a path creator"""

View File

@ -7,6 +7,7 @@ from flask import make_response, request
from flask_jwt_extended.exceptions import JWTExtendedException from flask_jwt_extended.exceptions import JWTExtendedException
from jwt import PyJWTError from jwt import PyJWTError
from common.utils.exceptions import IncorrectCredentialsError
from monkey_island.cc.resources.auth.credential_utils import get_username_password_from_request from monkey_island.cc.resources.auth.credential_utils import get_username_password_from_request
from monkey_island.cc.services.authentication import AuthenticationService from monkey_island.cc.services.authentication import AuthenticationService
@ -37,12 +38,14 @@ class Authenticate(flask_restful.Resource):
""" """
username, password = get_username_password_from_request(request) username, password = get_username_password_from_request(request)
if AuthenticationService.authenticate(username, password): try:
AuthenticationService.authenticate(username, password)
access_token = _create_access_token(username) access_token = _create_access_token(username)
return make_response({"access_token": access_token, "error": ""}, 200) except IncorrectCredentialsError:
return make_response({"error": "Invalid credentials"}, 401) return make_response({"error": "Invalid credentials"}, 401)
return make_response({"access_token": access_token, "error": ""}, 200)
def _create_access_token(username): def _create_access_token(username):
access_token = flask_jwt_extended.create_access_token(identity=username) access_token = flask_jwt_extended.create_access_token(identity=username)

View File

@ -1,6 +1,7 @@
import bcrypt import bcrypt
import monkey_island.cc.environment.environment_singleton as env_singleton import monkey_island.cc.environment.environment_singleton as env_singleton
from common.utils.exceptions import IncorrectCredentialsError
from monkey_island.cc.environment.user_creds import UserCreds from monkey_island.cc.environment.user_creds import UserCreds
from monkey_island.cc.server_utils.encryption import ( from monkey_island.cc.server_utils.encryption import (
reset_datastore_encryptor, reset_datastore_encryptor,
@ -31,12 +32,11 @@ class AuthenticationService:
reset_database() reset_database()
@classmethod @classmethod
def authenticate(cls, username: str, password: str) -> bool: def authenticate(cls, username: str, password: str):
if _credentials_match_registered_user(username, password): if not _credentials_match_registered_user(username, password):
cls._unlock_datastore_encryptor(username, password) raise IncorrectCredentialsError()
return True
return False cls._unlock_datastore_encryptor(username, password)
@classmethod @classmethod
def _unlock_datastore_encryptor(cls, username: str, password: str): def _unlock_datastore_encryptor(cls, username: str, password: str):

View File

@ -3,6 +3,8 @@ from unittest.mock import MagicMock
import pytest import pytest
from common.utils.exceptions import IncorrectCredentialsError
USERNAME = "test_user" USERNAME = "test_user"
PASSWORD = "test_password" PASSWORD = "test_password"
TEST_REQUEST = f'{{"username": "{USERNAME}", "password": "{PASSWORD}"}}' TEST_REQUEST = f'{{"username": "{USERNAME}", "password": "{PASSWORD}"}}'
@ -51,7 +53,7 @@ def test_authentication_successful(make_auth_request, mock_authentication_servic
def test_authentication_failure(make_auth_request, mock_authentication_service): def test_authentication_failure(make_auth_request, mock_authentication_service):
mock_authentication_service.authenticate = MagicMock(return_value=False) mock_authentication_service.authenticate = MagicMock(side_effect=IncorrectCredentialsError())
response = make_auth_request(TEST_REQUEST) response = make_auth_request(TEST_REQUEST)