slice whitelist
[sfa.git] / sfatables / exec.py
1 #!/usr/bin/python
2
3 import sys
4 import os
5 import pdb
6 import libxml2
7
8 from optparse import OptionParser
9 from sfatables import commands, matches, targets
10 from sfatables.xmlextension import Xmlextension
11 from sfatables.globals import *
12 from sfatables.commands.List import *
13 from sfatables.xmlrule import *
14
15 class SFATablesRules:
16     def __init__(self, chain_name):
17         self.sorted_rule_list = []
18         chain_dir_path = "%s/%s"%(sfatables_config,chain_name)
19         rule_list = List().get_rule_list(chain_dir_path)
20         for rule_number in rule_list:
21             self.sorted_rule_list.append(XMLRule(chain_name, rule_number))
22         return
23
24     def apply(self, rspec):
25         intermediate_rspec = rspec
26         for rule in self.sorted_rule_list:
27             intermediate_rspec  = rule.apply_interpreted(intermediate_rspec)
28
29         return intermediate_rspec
30
31 def main():
32     incoming = SFATablesRules('INCOMING')
33     outgoing = SFATablesRules('OUTGOING')
34
35     rspec = """
36 <rspec>
37     <context-input>
38         <sfa><user><hrn>plc.princeton.sapan</hrn></user></sfa>
39     </context-input>
40
41     <sfatables-input>
42         <rule>
43             <argument>
44                 <name>hrn</name>
45                 <value>plc</value>
46             </argument>
47             <argument>
48                 <name>whitelist</name>
49                 <value>plc.princeton</value>
50             </argument>
51             <argument>
52                 <name>blacklist</name>
53                 <value>plc.tp</value>
54             </argument>
55         </rule>
56     </sfatables-input>
57     <request>
58         <nodespec>
59             <node name="plc.princeton.planetlab-01"/>
60             <node name="plc.princeton.planetlab-02"/>
61             <node name="plc.princeton.planetlab-03"/>
62             <node name="plc.princeton.planetlab-04"/>
63             <node name="plc.tp.planetlab3"/>
64         </nodespec>
65     </request>
66 </rspec>
67     """
68
69     
70     print "%d rules loaded for INCOMING chain\n"%len(incoming.sorted_rule_list)
71     print "%d rules loaded for OUTGOING chain\n"%len(outgoing.sorted_rule_list)
72
73     newrspec = incoming.apply(rspec)
74     print newrspec
75     return
76
77 if __name__=="__main__":
78     main()