X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;ds=sidebyside;f=sfatables%2Fxmlrule.py;h=d137e4e6d3b28f9363c3dc7457f3f69280ed3629;hb=429e5214b5e839964e10d540bea97480fb6fcd74;hp=5eb5891186337c51e0042c6b3946092f1adfbb1e;hpb=50d80230b924e20e028ed3c0f13ddd6f98cfbe54;p=sfa.git diff --git a/sfatables/xmlrule.py b/sfatables/xmlrule.py index 5eb58911..d137e4e6 100644 --- a/sfatables/xmlrule.py +++ b/sfatables/xmlrule.py @@ -3,16 +3,6 @@ import libxslt from sfatables.globals import * class XMLRule: - rule_number = None - 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, doc, output_xpath_filter=None): processor = self.processors[type] @@ -20,6 +10,7 @@ class XMLRule: filepath = os.path.join(sfatables_config, 'processors', processor) # XXX + print filepath styledoc = libxml2.parseFile(filepath) style = libxslt.parseStylesheetDoc(styledoc) result = style.applyStylesheet(doc, None) @@ -44,14 +35,12 @@ class XMLRule: filepath = os.path.join(sfatables_config, 'processors', self.final_processor) if not os.path.exists(filepath): - # TODO: final_processor is not there yet - return doc#rspec + raise Exception('Could not find final rule filter') styledoc = libxml2.parseFile(filepath) style = libxslt.parseStylesheetDoc(styledoc) - #doc = libxml2.parseDoc(rspec) result = style.applyStylesheet(doc, None) - stylesheet_result = result #style.saveResultToString(result) + stylesheet_result = result#style.saveResultToString(result) style.freeStylesheet() #doc.freeDoc() #result.freeDoc() @@ -66,18 +55,36 @@ class XMLRule: target_result = self.apply_processor('target',rspec,None) return target_result + def add_rule_context_to_rspec(self, doc): + p = doc.xpathNewContext() + context = p.xpathEval("//rspec") + if (not context): + raise Exception('Request is not an rspec') + else: + # Add the request context + matchNode = libxml2.newNode('match-context') + matchNode.addChild(self.arguments['match']) + targetNode = libxml2.newNode('target-context') + targetNode.addChild(self.arguments['target']) + context[0].addChild(matchNode) + context[0].addChild(targetNode) + p.xpathFreeContext() + + return doc + def apply_interpreted(self, rspec): + self.add_rule_context_to_rspec(rspec) # Interpreted # # output = # if (match(match_args, rspec) # then target(target_args, rspec) # else rspec - + if (self.match(rspec)): - return self.target(rspec) + return self.wrap_up(self.target(rspec)) else: - return rspec + return self.wrap_up(rspec) def apply_compiled(rspec): @@ -116,6 +123,16 @@ class XMLRule: return rspec def __init__(self, chain=None, rule_number=None): + self.rule_number = None + self.chain = None + self.xmldoc = None + self.terminal = 0 + self.final_processor = '__sfatables_rule_wrap_up__.xsl' + + self.arguments = {'match':None,'target':None} + self.processors = {'match':None,'target':None} + self.context = {'match':None,'target':None} + if (chain and rule_number): self.load_xml_extension('match', chain, rule_number) self.load_xml_extension('target',chain, rule_number)