forked from p15670423/monkey
Add exception handling for config decryption
This commit is contained in:
parent
d67e84a6a7
commit
b9fb4c6902
|
@ -64,3 +64,7 @@ class NoCredentialsError(Exception):
|
|||
|
||||
class InvalidConfigurationError(Exception):
|
||||
""" Raise when configuration is invalid """
|
||||
|
||||
|
||||
class FailedDecryption(Exception):
|
||||
""" Raise when any kind of decryption fails """
|
||||
|
|
|
@ -6,10 +6,12 @@ from flask import request
|
|||
|
||||
from common.utils.exceptions import (
|
||||
InvalidConfigurationError,
|
||||
InvalidCredentialsError,
|
||||
# InvalidCredentialsError,
|
||||
NoCredentialsError,
|
||||
FailedDecryption,
|
||||
)
|
||||
from monkey_island.cc.resources.auth.auth import jwt_required
|
||||
from monkey_island.cc.services.utils.config_encryption import decrypt_config
|
||||
|
||||
|
||||
@dataclass
|
||||
|
@ -30,12 +32,19 @@ class TempConfiguration(flask_restful.Resource):
|
|||
def post(self):
|
||||
request_contents = json.loads(request.data)
|
||||
try:
|
||||
self.decrypt(request_contents["password"])
|
||||
decrypt_config(request_contents["encrypted_config"], request_contents["password"])
|
||||
self.import_config()
|
||||
return ResponseContents().form_response()
|
||||
except InvalidCredentialsError:
|
||||
# except InvalidCredentialsError:
|
||||
# return ResponseContents(
|
||||
# import_status="wrong_password", message="Wrong password supplied", status_code=403
|
||||
# ).form_response()
|
||||
except FailedDecryption as ex:
|
||||
return ResponseContents(
|
||||
import_status="wrong_password", message="Wrong password supplied", status_code=403
|
||||
import_status="decryption_failure",
|
||||
message="Decryptioon of configuration failed. Error thrown during decryption: "
|
||||
+ f"{str(ex)}",
|
||||
status_code=403,
|
||||
).form_response()
|
||||
except InvalidConfigurationError:
|
||||
return ResponseContents(
|
||||
|
@ -52,12 +61,12 @@ class TempConfiguration(flask_restful.Resource):
|
|||
status_code=403,
|
||||
).form_response()
|
||||
|
||||
def decrypt(self, password=""):
|
||||
if not password:
|
||||
raise NoCredentialsError
|
||||
if not password == "abc":
|
||||
raise InvalidCredentialsError
|
||||
return False
|
||||
# def decrypt(self, password=""):
|
||||
# if not password:
|
||||
# raise NoCredentialsError
|
||||
# if not password == "abc":
|
||||
# raise InvalidCredentialsError
|
||||
# return False
|
||||
|
||||
def import_config(self):
|
||||
return True
|
||||
|
|
|
@ -4,6 +4,8 @@ from typing import Dict
|
|||
|
||||
import pyAesCrypt
|
||||
|
||||
from common.utils.exceptions import FailedDecryption, NoCredentialsError
|
||||
|
||||
# TODO use from pyAesCrypt
|
||||
BUFFER_SIZE = 64 * 1024
|
||||
|
||||
|
@ -21,11 +23,15 @@ def encrypt_config(config: Dict, password: str) -> str:
|
|||
|
||||
|
||||
def decrypt_config(enc_config: bytes, password: str) -> Dict:
|
||||
if not password:
|
||||
raise NoCredentialsError
|
||||
|
||||
ciphertext_config_stream = io.BytesIO(enc_config)
|
||||
dec_plaintext_config_stream = io.BytesIO()
|
||||
|
||||
len_ciphertext_config_stream = len(ciphertext_config_stream.getvalue())
|
||||
|
||||
try:
|
||||
pyAesCrypt.decryptStream(
|
||||
ciphertext_config_stream,
|
||||
dec_plaintext_config_stream,
|
||||
|
@ -33,6 +39,8 @@ def decrypt_config(enc_config: bytes, password: str) -> Dict:
|
|||
BUFFER_SIZE,
|
||||
len_ciphertext_config_stream,
|
||||
)
|
||||
except ValueError as ex:
|
||||
raise FailedDecryption(str(ex))
|
||||
|
||||
plaintext_config = json.loads(dec_plaintext_config_stream.getvalue().decode("utf-8"))
|
||||
return plaintext_config
|
||||
|
|
Loading…
Reference in New Issue