X-Git-Url: http://git.onelab.eu/?p=sfa.git;a=blobdiff_plain;f=sfatables%2Fruntime.py;h=e2b57877ecfffd05da795b2c2a29d1c22a4759dc;hp=b155809bfca3b7a55c688df9de889065d6be5f0c;hb=7f5d4eef337809e0e0e802ca8c0cc8f695dc0837;hpb=022458c172f0fa883401665d444e874eef04f215 diff --git a/sfatables/runtime.py b/sfatables/runtime.py index b155809b..e2b57877 100644 --- a/sfatables/runtime.py +++ b/sfatables/runtime.py @@ -13,21 +13,24 @@ from sfatables.xmlrule import * class SFATablesRules: def __init__(self, chain_name): + self.active_context = None self.contexts = None # placeholder for rspec_manger self.sorted_rule_list = [] chain_dir_path = os.path.join(sfatables_config,chain_name) rule_list = List().get_rule_list(chain_dir_path) for rule_number in rule_list: - self.sorted_rule_list.append(XMLRule(chain_name, rule_number)) + self.sorted_rule_list = self.sorted_rule_list + [XMLRule(chain_name, rule_number)] return def set_context(self, request_context): + self.active_context = request_context return def apply(self, rspec): doc = libxml2.parseDoc(rspec) intermediate_rspec = doc + for rule in self.sorted_rule_list: intermediate_rspec = rule.apply_interpreted(intermediate_rspec) if (rule.terminal): @@ -38,10 +41,13 @@ class SFATablesRules: def main(): incoming = SFATablesRules('INCOMING') - outgoing = SFATablesRules('OUTGOING') + outgoing = SFATablesRules('OUTGOING') print "%d rules loaded for INCOMING chain"%len(incoming.sorted_rule_list) + print incoming.sorted_rule_list[0].processors + print "%d rules loaded for OUTGOING chain"%len(outgoing.sorted_rule_list) + print outgoing.sorted_rule_list[0].processors rspec = open(sys.argv[1]).read() newrspec = incoming.apply(rspec)