diff options
author | Raúl Benencia <rbenencia@linti.unlp.edu.ar> | 2012-08-02 20:10:03 -0300 |
---|---|---|
committer | Raúl Benencia <rbenencia@linti.unlp.edu.ar> | 2012-08-02 20:10:03 -0300 |
commit | 849895f9f94b70d55f3b69db07f23ba93468bca4 (patch) | |
tree | abf258d1fdf369d8ecba8fa22f2d375a0c070b59 /model.py | |
parent | 4d30bf280dbdb68ad72e01e911bf039b48ccb869 (diff) |
Change ipcalc to ipaddr
Diffstat (limited to 'model.py')
-rw-r--r-- | model.py | 71 |
1 files changed, 71 insertions, 0 deletions
@@ -1,3 +1,5 @@ +from xml.etree import ElementTree + class Network(): """A simple network definition""" @@ -76,3 +78,72 @@ class Data(): self.load_data() return self.persons + +class DataXML(model.Data): + """Reads network information from a XML file""" + + def parse_config(self): + """Reads and sets up XML config file fields""" + + self.data_file = self.config['Storage']['xml_file'] + + def load_data(self): + """Parse XML for getting network information""" + + root = ElementTree(file=self.data_file).getroot() + + for elem in root: + if elem.tag == 'person': + self.add_person(elem) + elif elem.tag == 'domain': + self.add_domain(elem) + elif elem.tag == 'network': + self.add_network(elem) + else: + pass # raise TagNotFoundError + + def add_person(self, elem): + """Adds a new person""" + + person = model.Person() + for e in elem: + if e.tag == 'name': + person.name = e.text + elif e.tag == 'surname': + person.surname = e.text + elif e.tag == 'email': + person.email = e.text + else: + person.data[e.tag] = e.text + + self.persons[elem.attrib['id']] = person + + def add_domain(self, elem): + """Adds a new domain""" + + domain = model.Domain() + for e in elem: + if e.tag == 'name': + domain.name == e.text + else: + domain.data[e.tag] = e.text + + self.domains[elem.attrib['id']] = domain + + def add_network(self, elem): + """Adds a new network""" + + network = model.Network() + for e in elem: + if e.tag == 'name': + network.name = e.text + elif e.tag == 'domain': + network.domains.append(e.text) + elif e.tag == 'ip_block': + network.ip_blocks.append(e.text) + elif e.tag == 'admin': + network.admins.append(e.text) + else: + network.data[e.tag] = e.text + + self.networks[elem.attrib['id']] = network |