From 4005ea2924e2c254941ad062485488e3f08fb9f1 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Thu, 17 Feb 2022 14:29:07 -0500 Subject: [PATCH] Agent: Add caching to ControlChannel.get_credentials_for_propagation() --- monkey/infection_monkey/master/control_channel.py | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/monkey/infection_monkey/master/control_channel.py b/monkey/infection_monkey/master/control_channel.py index 52b565d55..d6781af7f 100644 --- a/monkey/infection_monkey/master/control_channel.py +++ b/monkey/infection_monkey/master/control_channel.py @@ -7,11 +7,14 @@ from common.common_consts.timeouts import SHORT_REQUEST_TIMEOUT from infection_monkey.config import WormConfiguration from infection_monkey.control import ControlClient from infection_monkey.i_control_channel import IControlChannel, IslandCommunicationError +from infection_monkey.utils.decorators import request_cache requests.packages.urllib3.disable_warnings() logger = logging.getLogger(__name__) +CREDENTIALS_POLL_PERIOD_SEC = 30 + class ControlChannel(IControlChannel): def __init__(self, server: str, agent_id: str): @@ -66,18 +69,21 @@ class ControlChannel(IControlChannel): ) as e: raise IslandCommunicationError(e) + @request_cache(CREDENTIALS_POLL_PERIOD_SEC) def get_credentials_for_propagation(self) -> dict: + propagation_credentials_url = ( + f"https://{self._control_channel_server}/api/propagation-credentials/{self._agent_id}" + ) try: response = requests.get( # noqa: DUO123 - f"{self._control_channel_server}/api/propagation-credentials/{self._agent_id}", + propagation_credentials_url, verify=False, proxies=ControlClient.proxies, timeout=SHORT_REQUEST_TIMEOUT, ) response.raise_for_status() - response = json.loads(response.content.decode())["propagation_credentials"] - return response + return json.loads(response.content.decode())["propagation_credentials"] except ( json.JSONDecodeError, requests.exceptions.ConnectionError,