X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfatables%2Fxmlrule.py;h=c363ab925a42775b45dea4882903e7dcd0bba66b;hb=e57b7150dee76d42fc15f9477a3045e5171c8878;hp=d787c15ebe391fb6a46a99a6937b8b8e8e64601c;hpb=a4a914c48938c95b54449ba151b93da369453167;p=sfa.git diff --git a/sfatables/xmlrule.py b/sfatables/xmlrule.py index d787c15e..c363ab92 100644 --- a/sfatables/xmlrule.py +++ b/sfatables/xmlrule.py @@ -1,4 +1,5 @@ import libxml2 +import libxslt from sfatables.globals import * class XMLRule: @@ -6,11 +7,80 @@ class XMLRule: chain = None xmldoc = None terminal = 0 + final_processor = '__sfatables_wrap_up__.xsl' arguments = {'match':None,'target':None} processors = {'match':None,'target':None} context = {'match':None,'target':None} + def apply_processor(self, type, rspec, output_xpath_filter=None): + processor = self.processors[type] + + # XXX TO CLEAN UP + filepath = os.path.join(sfatables_config, 'processors', processor) + # XXX + + styledoc = libxml2.parseFile(filepath) + style = libxslt.parseStylesheetDoc(styledoc) + doc = libxml2.parseDoc(rspec) + result = style.applyStylesheet(doc, None) + if (output_xpath_filter): + p = result.xpathNewContext() + xpath_result = p.xpathEval(output_xpath_filter) + if (xpath_result == []): + raise Exception("Could not apply processor %s."%processor) + + stylesheet_result = xpath_result[0].content + p.xpathFreeContext() + else: + stylesheet_result = style.saveResultToString(result) + + style.freeStylesheet() + doc.freeDoc() + result.freeDoc() + + return stylesheet_result + + def wrap_up(self, rspec): + filepath = 'processors/' + self.final_processor + + styledoc = libxml2.parseFile(filepath) + style = libxslt.parseStylesheetDoc(styledoc) + doc = libxml2.parseDoc(rspec) + result = style.applyStylesheet(doc, None) + stylesheet_result = style.saveResultToString(result) + style.freeStylesheet() + doc.freeDoc() + result.freeDoc() + + return stylesheet_result + + def match(self, rspec): + match_result = self.apply_processor('match',rspec,"//result/@verdict") + return (match_result=='True') + + def target(self, rspec): + target_result = self.apply_processor('target',rspec,None) + return target_result + + def apply_interpreted(self, rspec): + # Interpreted + # + # output = + # if (match(match_args, rspec) + # then target(target_args, rspec) + # else rspec + + if (self.match(rspec)): + return self.target(rspec) + else: + return rspec + + + def apply_compiled(rspec): + # Not supported yet + return None + def load_xml_extension (self, type, chain, rule_number): filename = sfatables_config+"/"+chain+"/"+"sfatables-%d-%s"%(rule_number,type) @@ -42,13 +112,12 @@ class XMLRule: root_node.addChild(arguments[type]) return rspec - def __init__(self, chain, rule_number): - - self.load_xml_extension('match', chain, rule_number) - self.load_xml_extension('target',chain, rule_number) - self.rule_number = rule_number - self.chain = chain - + def __init__(self, chain=None, rule_number=None): + if (chain and rule_number): + self.load_xml_extension('match', chain, rule_number) + self.load_xml_extension('target',chain, rule_number) + self.rule_number = rule_number + self.chain = chain return def free(self):