Skip to content

Commit

Permalink
Update controls to parse and validate the few fields
Browse files Browse the repository at this point in the history
  • Loading branch information
Mab879 committed Jul 20, 2023
1 parent a11e01f commit 1bbd798
Showing 1 changed file with 14 additions and 3 deletions.
17 changes: 14 additions & 3 deletions ssg/controls.py
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,11 @@ class Control(ssg.entities.common.SelectionHandler, ssg.entities.common.XCCDFEnt
status_justification=str,
fixtext=str,
check=str,
tickets=list,
original_title=str,
related_rules=list,
controls=list,
rules=list,
)

MANDATORY_KEYS = {
Expand All @@ -108,6 +113,9 @@ def __init__(self):
self.fixtext = ""
self.check = ""
self.controls = []
self.tickets = []
self.original_title = ""
self.related_rules = []

def __hash__(self):
""" Controls are meant to be unique, so using the
Expand All @@ -117,9 +125,8 @@ def __hash__(self):
@classmethod
def _check_keys(cls, control_dict):
for key in control_dict.keys():
if key not in cls.KEYS.keys() and key not in [
'controls', 'original_title', 'related_rules', 'rules']:
raise ValueError("Key %s is not a valid for a control." % key)
if key not in cls.KEYS.keys():
raise ValueError("Key %s is not allowed in a control file." % key)

@classmethod
def from_control_dict(cls, control_dict, env_yaml=None, default_level=["default"]):
Expand All @@ -136,6 +143,10 @@ def from_control_dict(cls, control_dict, env_yaml=None, default_level=["default"
control.mitigation = control_dict.get('mitigation')
control.fixtext = control_dict.get('fixtext')
control.check = control_dict.get('check')
control.tickets = control_dict.get('tickets')
control.original_title = control_dict.get('original_title')
control.related_rules = control_dict.get('related_rules')

if control.status == "automated":
control.automated = "yes"
if control.automated not in ["yes", "no", "partially"]:
Expand Down

0 comments on commit 1bbd798

Please sign in to comment.