mirror of
https://codeberg.org/mclemens/esm2markdown.git
synced 2024-09-28 02:26:11 -04:00
integrated trigger into rule, fixed parameters, doesn't show root rule anymore
This commit is contained in:
parent
694f9249e4
commit
70aeee0e00
@ -20,6 +20,7 @@ Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os.path
|
import os.path
|
||||||
|
import re
|
||||||
from configparser import ConfigParser
|
from configparser import ConfigParser
|
||||||
from lxml import etree
|
from lxml import etree
|
||||||
|
|
||||||
@ -54,6 +55,8 @@ def line(level,key,value):
|
|||||||
value_style + value + value_style + "\n"
|
value_style + value + value_style + "\n"
|
||||||
else: output = ""
|
else: output = ""
|
||||||
|
|
||||||
|
output = re.sub('\$\$$',"]",output)
|
||||||
|
output = re.sub('\$\$',"PARAMETER:[",output)
|
||||||
return output
|
return output
|
||||||
|
|
||||||
|
|
||||||
@ -133,38 +136,36 @@ def main(xmlfile,outfile):
|
|||||||
file.write(line(1,param.get('name'),"N/A"))
|
file.write(line(1,param.get('name'),"N/A"))
|
||||||
file.write(line(2,"Description:",param.get('description')))
|
file.write(line(2,"Description:",param.get('description')))
|
||||||
file.write(line(2,"Default Value:",param.get('defaultvalue')))
|
file.write(line(2,"Default Value:",param.get('defaultvalue')))
|
||||||
# Print trigger information (Sequence, Timeout, Time Unit, Threshold)
|
|
||||||
triggers = False
|
|
||||||
for trigger in cdata.getiterator('trigger'):
|
|
||||||
if not triggers:
|
|
||||||
file.write("\n### Triggers\n")
|
|
||||||
triggers = True
|
|
||||||
file.write(line(1,trigger.get('name'),"N/A"))
|
|
||||||
file.write(line(2,"Timeout:",trigger.get('timeout')))
|
|
||||||
file.write(line(2,"Time Units:",trigger.get('timeUnit')))
|
|
||||||
file.write(line(2,"Threshold:",trigger.get('threshold')))
|
|
||||||
file.write(line(2,"Sequence:",trigger.get('ordered')))
|
|
||||||
file.write("\n### Rules\n")
|
file.write("\n### 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'):
|
||||||
o = ""
|
o = ""
|
||||||
v = ""
|
v = ""
|
||||||
t = ""
|
t = ""
|
||||||
|
if not r.get('name') == "Root Rule":
|
||||||
file.write("\n#### " + r.get('name') + "\n")
|
file.write("\n#### " + r.get('name') + "\n")
|
||||||
for e in r.iter():
|
for e in r.iter():
|
||||||
if str(e.tag) == 'activate':
|
if str(e.tag) == 'activate':
|
||||||
file.write(line(1,"Activate:",e.get('type')))
|
file.write(line(1,"Activate:",e.get('type')))
|
||||||
if str(e.tag) == 'action':
|
if str(e.tag) == 'action':
|
||||||
|
if e.get('type') == "TRIGGER":
|
||||||
|
file.write(line(1,"Action:","Trigger"))
|
||||||
|
for trigger in cdata.getiterator('trigger'):
|
||||||
|
if e.get('trigger') == trigger.get('name'):
|
||||||
|
file.write(line(2,"Timeout:",trigger.get('timeout')))
|
||||||
|
file.write(line(2,"Time Units:",trigger.get('timeUnit')))
|
||||||
|
file.write(line(2,"Threshold:",trigger.get('threshold')))
|
||||||
|
file.write(line(2,"Sequence:",trigger.get('ordered')))
|
||||||
|
else:
|
||||||
file.write(line(1,"Action","N/A"))
|
file.write(line(1,"Action","N/A"))
|
||||||
file.write(line(2,"Type:",e.get('type')))
|
file.write(line(2,"NOT IMPLEMENTED","N/A"))
|
||||||
file.write(line(2,"Trigger:",e.get('trigger')))
|
|
||||||
if str(e.tag) == 'match':
|
if str(e.tag) == 'match':
|
||||||
file.write(line(1,"Match","N/A"))
|
file.write(line(1,"Match Type:",e.get('matchType')))
|
||||||
file.write(line(2,"Count:",e.get('count')))
|
file.write(line(2,"Count:",e.get('count')))
|
||||||
file.write(line(2,"Match Type:",e.get('matchType')))
|
#file.write(line(2,"Match Type:",e.get('matchType')))
|
||||||
if str(e.tag) == 'matchFilter':
|
if str(e.tag) == 'matchFilter':
|
||||||
file.write(line(1,"Match Filter","N/A"))
|
file.write(line(1,"Match Filter:",e.get('type').upper()))
|
||||||
file.write(line(2,"Logical Element Type:",e.get('type')))
|
#file.write(line(2,"Logical Element Type:",e.get('type').upper()))
|
||||||
if str(e.tag) == 'singleFilterComponent':
|
if str(e.tag) == 'singleFilterComponent':
|
||||||
t = e.get('type')
|
t = e.get('type')
|
||||||
if str(e.tag) == 'filterData':
|
if str(e.tag) == 'filterData':
|
||||||
|
Loading…
Reference in New Issue
Block a user