fixed parameter listing

This commit is contained in:
Michael Clemens 2018-03-17 15:53:05 +01:00
parent 6bd9e129cb
commit eaae0cb742
1 changed files with 14 additions and 18 deletions

View File

@ -35,29 +35,25 @@ def main(xmlfile,outfile):
file.write("## Correlation Details\n") file.write("## Correlation Details\n")
# Print rule parameters # Print rule parameters
file.write("### Parameters\n") file.write("### Parameters\n")
for p in cdata.getiterator('param'): for param in cdata.getiterator('param'):
file.write("* Name: " + p.get('name') + "\n") file.write("* Name: " + param.get('name') + "\n")
file.write(" - Description: " + p.get('description') + "\n") file.write(" - Description: " + param.get('description') + "\n")
file.write(" - Default Value: " + p.get('defaultvalue') + "\n") file.write(" - Default Value: " + param.get('defaultvalue') + "\n")
# Print trigger information (Ordered, Timeout, Time Unit, Threshold) # Print trigger information (Ordered, Timeout, Time Unit, Threshold)
file.write("### Trigger\n") file.write("### Trigger\n")
for t in cdata.getiterator('trigger'): for trigger in cdata.getiterator('trigger'):
if (t.get('ordered')): print(etree.tostring(trigger, pretty_print=True))
trigger_ordered = "* Ordered: " + str(t.get('ordered')) if (trigger.get('name')):
file.write(trigger_ordered + "\n") file.write("* Name: " + trigger.get('name') + "\n")
if (t.get('timeout')): file.write(" - Timeout: " + trigger.get('timeout') + "\n")
trigger_timeout = "* Timeout: " + str(t.get('timeout')) file.write(" - Time Unit: " + trigger.get('timeUnit') + "\n")
file.write(trigger_timeout + "\n") file.write(" - Threshold: " + trigger.get('threshold') + "\n")
if (t.get('timeUnit')): if (trigger.get('ordered')):
trigger_timeunit = "* Timeunit: " + str(t.get('timeUnit')) file.write(" - Ordered: " + trigger.get('ordered') + "\n")
file.write(trigger_timeunit + "\n")
if (t.get('threshold')):
trigger_threshold = "* Threshold: " + str(t.get('threshold'))
file.write(trigger_threshold + "\n")
file.write("### Rules\n") file.write("### Rules\n")
# Parse CDATA element and print correlation rule match blocks # Parse CDATA element and print correlation rule match blocks
for r in cdata.getiterator('rule'): for r in cdata.getiterator('rule'):
file.write("#### Name: " + r.get('name') + "\n") file.write("#### " + r.get('name') + "\n")
for e in r.iter(): for e in r.iter():
if str(e.tag) == 'match': if str(e.tag) == 'match':
file.write("* Match: \n") file.write("* Match: \n")