Fixed bug: linux only PBA's throwing errors on Windows

This commit is contained in:
VakarisZ 2020-07-21 12:10:23 +03:00
parent 55a46baced
commit 3af6fff5ca
3 changed files with 9 additions and 10 deletions

View File

@ -2,12 +2,10 @@ from common.data.post_breach_consts import POST_BREACH_SETUID_SETGID
from infection_monkey.post_breach.pba import PBA from infection_monkey.post_breach.pba import PBA
from infection_monkey.post_breach.setuid_setgid.setuid_setgid import \ from infection_monkey.post_breach.setuid_setgid.setuid_setgid import \
get_commands_to_change_setuid_setgid get_commands_to_change_setuid_setgid
from infection_monkey.utils.environment import is_windows_os
class ChangeSetuidSetgid(PBA): class ChangeSetuidSetgid(PBA):
def __init__(self): def __init__(self):
if not is_windows_os(): linux_cmds = get_commands_to_change_setuid_setgid()
linux_cmds = get_commands_to_change_setuid_setgid() super(ChangeSetuidSetgid, self).__init__(POST_BREACH_SETUID_SETGID,
super(ChangeSetuidSetgid, self).__init__(POST_BREACH_SETUID_SETGID, linux_cmd=' '.join(linux_cmds))
linux_cmd=' '.join(linux_cmds))

View File

@ -7,7 +7,6 @@ from infection_monkey.utils.environment import is_windows_os
class TrapCommand(PBA): class TrapCommand(PBA):
def __init__(self): def __init__(self):
if not is_windows_os(): linux_cmds = get_trap_commands()
linux_cmds = get_trap_commands() super(TrapCommand, self).__init__(POST_BREACH_TRAP_COMMAND,
super(TrapCommand, self).__init__(POST_BREACH_TRAP_COMMAND, linux_cmd=linux_cmds)
linux_cmd=linux_cmds)

View File

@ -62,8 +62,10 @@ class PBA(Plugin):
exec_funct = self._execute_default exec_funct = self._execute_default
result = exec_funct() result = exec_funct()
if self.scripts_were_used_successfully(result): if self.scripts_were_used_successfully(result):
T1064Telem(ScanStatus.USED, "Scripts were used to execute %s post breach action." % self.name).send() T1064Telem(ScanStatus.USED, f"Scripts were used to execute {self.name} post breach action.").send()
PostBreachTelem(self, result).send() PostBreachTelem(self, result).send()
else:
LOG.debug(f"No command available for PBA '{self.name}' on current OS, skipping.")
def is_script(self): def is_script(self):
""" """