Extracted island setup parameter extraction into a separate workflow/DTO

This commit is contained in:
VakarisZ 2021-05-19 14:14:01 +03:00
parent 8bb6e2f21f
commit d768d60f9f
7 changed files with 82 additions and 41 deletions

View File

@ -1,26 +1,24 @@
from gevent import monkey as gevent_monkey from gevent import monkey as gevent_monkey
from setup_param_factory import SetupParamFactory
from monkey_island.cc.arg_parser import parse_cli_args from monkey_island.cc.arg_parser import parse_cli_args
gevent_monkey.patch_all() gevent_monkey.patch_all()
import json # noqa: E402 import json # noqa: E402
import os # noqa: E402
from monkey_island import config_loader # noqa: E402
from monkey_island.cc.server_utils.island_logger import setup_logging # noqa: E402 from monkey_island.cc.server_utils.island_logger import setup_logging # noqa: E402
if "__main__" == __name__: if "__main__" == __name__:
island_args = parse_cli_args() island_args = parse_cli_args()
# This is here in order to catch EVERYTHING, some functions are being called on setup_params = SetupParamFactory.build(island_args)
# imports, so the log init needs to be first.
try: try:
server_config_path = os.path.expanduser(island_args.server_config)
config = config_loader.load_server_config_from_file(server_config_path) # This is here in order to catch EVERYTHING, some functions are being called on
# imports, so the log init needs to be first.
setup_logging(config["data_dir"], config["log_level"]) setup_logging(setup_params.data_dir, setup_params.log_level)
except OSError as ex: except OSError as ex:
print(f"Error opening server config file: {ex}") print(f"Error opening server config file: {ex}")
@ -32,4 +30,4 @@ if "__main__" == __name__:
from monkey_island.cc.main import main # noqa: E402 from monkey_island.cc.main import main # noqa: E402
main(config["data_dir"], island_args.setup_only, island_args.server_config) main(setup_params.data_dir, setup_params.setup_only, setup_params.server_config_path)

View File

@ -1,12 +1,10 @@
from dataclasses import dataclass from dataclasses import dataclass
from monkey_island.cc.server_utils.consts import DEFAULT_SERVER_CONFIG_PATH
@dataclass @dataclass
class IslandArgs: class IslandArgs:
setup_only: bool setup_only: bool
server_config: str server_config_path: str
def parse_cli_args() -> IslandArgs: def parse_cli_args() -> IslandArgs:
@ -25,10 +23,7 @@ def parse_cli_args() -> IslandArgs:
"compiling/packaging Islands.", "compiling/packaging Islands.",
) )
parser.add_argument( parser.add_argument(
"--server-config", "--server-config", action="store", help="The path to the server configuration file."
action="store",
help="The path to the server configuration file.",
default=DEFAULT_SERVER_CONFIG_PATH,
) )
args = parser.parse_args() args = parser.parse_args()

View File

@ -5,6 +5,7 @@ __author__ = "itay.mizeretz"
MONKEY_ISLAND_ABS_PATH = os.path.join(os.getcwd(), "monkey_island") MONKEY_ISLAND_ABS_PATH = os.path.join(os.getcwd(), "monkey_island")
DEFAULT_MONKEY_TTL_EXPIRY_DURATION_IN_SECONDS = 60 * 5 DEFAULT_MONKEY_TTL_EXPIRY_DURATION_IN_SECONDS = 60 * 5
# TODO move setup consts
DEFAULT_SERVER_CONFIG_PATH = os.path.join(MONKEY_ISLAND_ABS_PATH, "cc", "server_config.json") DEFAULT_SERVER_CONFIG_PATH = os.path.join(MONKEY_ISLAND_ABS_PATH, "cc", "server_config.json")
DEFAULT_DEVELOP_SERVER_CONFIG_PATH = os.path.join( DEFAULT_DEVELOP_SERVER_CONFIG_PATH = os.path.join(
@ -12,3 +13,6 @@ DEFAULT_DEVELOP_SERVER_CONFIG_PATH = os.path.join(
) )
DEFAULT_DATA_DIR = os.path.join(MONKEY_ISLAND_ABS_PATH, "cc") DEFAULT_DATA_DIR = os.path.join(MONKEY_ISLAND_ABS_PATH, "cc")
DEFAULT_LOG_LEVEL = "INFO"
DEFAULT_START_MONGO_DB = True
DEFAULT_SHOULD_SETUP_ONLY = False

View File

@ -0,0 +1,8 @@
import json
def load_server_config_from_file(server_config_path):
with open(server_config_path, "r") as f:
config_content = f.read()
config = json.loads(config_content)
return config

View File

@ -1,25 +0,0 @@
import json
import os
from monkey_island.cc.server_utils.consts import DEFAULT_DATA_DIR
DEFAULT_LOG_LEVEL = "INFO"
def load_server_config_from_file(server_config_path):
with open(server_config_path, "r") as f:
config_content = f.read()
config = json.loads(config_content)
add_default_values_to_config(config)
return config
def add_default_values_to_config(config):
config["data_dir"] = os.path.abspath(
os.path.expanduser(os.path.expandvars(config.get("data_dir", DEFAULT_DATA_DIR)))
)
config.setdefault("log_level", DEFAULT_LOG_LEVEL)
return config

View File

@ -0,0 +1,43 @@
import os
from setup_params import SetupParams
from monkey_island import config_file_parser
from monkey_island.cc.arg_parser import IslandArgs
class SetupParamFactory:
@staticmethod
def build(cmd_args: IslandArgs) -> SetupParams:
setup_params = SetupParams()
setup_params = SetupParamFactory._update_by_cmd_args(setup_params, cmd_args)
setup_params = SetupParamFactory._update_by_config_file(setup_params)
return setup_params
@staticmethod
def _update_by_cmd_args(setup_params: SetupParams, cmd_args: IslandArgs) -> SetupParams:
if type(cmd_args.setup_only) == bool:
setup_params.setup_only = cmd_args.setup_only
if cmd_args.server_config_path:
setup_params.server_config_path = os.path.expanduser(cmd_args.server_config_path)
return setup_params
@staticmethod
def _update_by_config_file(setup_params: SetupParams):
config = config_file_parser.load_server_config_from_file(setup_params.server_config_path)
if "data_dir" in config:
setup_params.data_dir = config["data_dir"]
if "log_level" in config:
setup_params.log_level = config["log_level"]
if "mongodb" in config and "start_mongodb" in config["mongodb"]:
setup_params.start_mongodb = config["mongodb"]["start_mongodb"]
return setup_params

18
monkey/setup_params.py Normal file
View File

@ -0,0 +1,18 @@
from dataclasses import dataclass
from monkey_island.cc.server_utils.consts import (
DEFAULT_DATA_DIR,
DEFAULT_LOG_LEVEL,
DEFAULT_SERVER_CONFIG_PATH,
DEFAULT_SHOULD_SETUP_ONLY,
DEFAULT_START_MONGO_DB,
)
@dataclass
class SetupParams:
server_config_path = DEFAULT_SERVER_CONFIG_PATH
log_level = DEFAULT_LOG_LEVEL
data_dir = DEFAULT_DATA_DIR
start_mongodb = DEFAULT_START_MONGO_DB
setup_only = DEFAULT_SHOULD_SETUP_ONLY