forked from p15670423/monkey
Minor readability changes in config service
This commit is contained in:
parent
6c97b44b69
commit
f9c4b3e180
|
@ -55,15 +55,11 @@ class AttackConfig(object):
|
||||||
for key, definition in monkey_schema['definitions'].items():
|
for key, definition in monkey_schema['definitions'].items():
|
||||||
for array_field in definition['anyOf']:
|
for array_field in definition['anyOf']:
|
||||||
# Check if current array field has attack_techniques assigned to it
|
# Check if current array field has attack_techniques assigned to it
|
||||||
if 'attack_techniques' not in array_field:
|
if 'attack_techniques' in array_field:
|
||||||
continue
|
should_remove = not AttackConfig.should_enable_field(array_field['attack_techniques'],
|
||||||
try:
|
attack_techniques)
|
||||||
should_remove = not AttackConfig.should_enable_field(array_field['attack_techniques'], attack_techniques)
|
# If exploiter's attack technique is disabled, disable the exploiter/scanner/PBA
|
||||||
except KeyError:
|
AttackConfig.r_alter_array(monkey_config, key, array_field['enum'][0], remove=should_remove)
|
||||||
# Monkey schema field contains not yet implemented technique
|
|
||||||
continue
|
|
||||||
# If exploiter's attack technique is disabled, disable the exploiter/scanner/PBA
|
|
||||||
AttackConfig.r_alter_array(monkey_config, key, array_field['enum'][0], remove=should_remove)
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def set_booleans(attack_techniques, monkey_config, monkey_schema):
|
def set_booleans(attack_techniques, monkey_config, monkey_schema):
|
||||||
|
@ -106,8 +102,8 @@ class AttackConfig(object):
|
||||||
for key, item in dictionary.items():
|
for key, item in dictionary.items():
|
||||||
path.append(key)
|
path.append(key)
|
||||||
AttackConfig.r_set_booleans(path, item, attack_techniques, monkey_config)
|
AttackConfig.r_set_booleans(path, item, attack_techniques, monkey_config)
|
||||||
# Method enumerated everything in current path, goes back a level.
|
# Method enumerated everything in current path, goes back a level.
|
||||||
del path[-1]
|
del path[-1]
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def set_bool_conf_val(path, val, monkey_config):
|
def set_bool_conf_val(path, val, monkey_config):
|
||||||
|
@ -127,9 +123,6 @@ class AttackConfig(object):
|
||||||
:param users_techniques: ATT&CK techniques that user chose
|
:param users_techniques: ATT&CK techniques that user chose
|
||||||
:return: True, if user enabled all techniques used by the field, false otherwise
|
:return: True, if user enabled all techniques used by the field, false otherwise
|
||||||
"""
|
"""
|
||||||
# Method can't decide field value because it has no attack techniques assign to it.
|
|
||||||
if not field_techniques:
|
|
||||||
raise KeyError
|
|
||||||
for technique in field_techniques:
|
for technique in field_techniques:
|
||||||
if not users_techniques[technique]:
|
if not users_techniques[technique]:
|
||||||
return False
|
return False
|
||||||
|
|
Loading…
Reference in New Issue