X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfatables%2Fruntime.py;h=d7eb6d49722c71c984336ec9b36b9f4136e83deb;hb=31cc4fa991896f000abb106916662923f37bc3a6;hp=f9263fb1261cb5b621505ac95770b00d45c3066b;hpb=a7a01a6a19f91fccb0bda1c60454ebe2cc848d2d;p=sfa.git diff --git a/sfatables/runtime.py b/sfatables/runtime.py index f9263fb1..d7eb6d49 100644 --- a/sfatables/runtime.py +++ b/sfatables/runtime.py @@ -1,15 +1,14 @@ -#!/usr/bin/python +#!/usr/bin/env python2 import sys import os -import pdb + import libxml2 +import libxslt -from optparse import OptionParser -from sfatables import commands -from sfatables.globals import * -from sfatables.commands.List import * -from sfatables.xmlrule import * +from sfatables.globals import sfatables_config +from sfatables.commands.List import List +from sfatables.xmlrule import XMLRule class SFATablesRules: def __init__(self, chain_name): @@ -57,8 +56,8 @@ class SFATablesRules: def add_request_context_to_rspec(self, doc): p = doc.xpathNewContext() - context = p.xpathEval("//RSpec") - if (not context): + context = p.xpathEval("//*") + if not context or context[0].name not in ['RSpec', 'rspec']: raise Exception('Request is not an rspec') else: # Add the request context @@ -86,16 +85,20 @@ class SFATablesRules: return final_rspec + def print_rules(self): + for rule in self.sorted_rule_list: + print rule.processors + def main(): incoming = SFATablesRules('INCOMING') incoming.set_context({'sfa':{'user':{'hrn':'plc.princeton.sapanb'}}}) outgoing = SFATablesRules('OUTGOING') print "%d rules loaded for INCOMING chain"%len(incoming.sorted_rule_list) - print incoming.sorted_rule_list[0].processors + incoming.print_rules() print "%d rules loaded for OUTGOING chain"%len(outgoing.sorted_rule_list) - print outgoing.sorted_rule_list[0].processors + outgoing.print_rules() rspec = open(sys.argv[1]).read() newrspec = incoming.apply(rspec)