简易区域-DNS区域抽象模块
easyzone的Python项目详细描述
概述
easyzone是一个包,用于管理 区域文件,包括soa记录。这个模块位于 dnspython包并提供更高级别的抽象 对于公共区域文件操作用例。
http://www.psychofx.com/easyzone/http://pypi.python.org/pypi/easyzonehttps://bitbucket.org/chrismiles/easyzone/
主要功能:
- dnspython之上的高级抽象。
- 将分区文件加载到对象中。
- 修改/添加/删除区域/记录对象。
- 保存回区域文件。
- 自动更新序列号(如有必要)。
要求
- dnspython - http://www.dnspython.org/
构建/测试/安装
生成:
$ python setup.py build
测试:
$ python setup.py test
安装:
$ python setup.py install
或使用设置工具:
$ easy_install easyzone
示例
简易电话:
>>> from easyzone import easyzone >>> z = easyzone.zone_from_file('example.com', '/var/namedb/example.com') >>> z.domain 'example.com.' >>> z.root.soa.serial 2007012902L >>> z.root.records('NS').items ['ns1.example.com.', 'ns2.example.com.'] >>> z.root.records('MX').items [(10, 'mail.example.com.'), (20, 'mail2.example.com.')] >>> z.names['foo.example.com.'].records('A').items ['10.0.0.1'] >>> ns = z.root.records('NS') >>> ns.add('ns3.example.com.') >>> ns.items ['ns1.example.com.', 'ns2.example.com.', 'ns3.example.com.'] >>> ns.delete('ns2.example.com') >>> ns.items ['ns1.example.com.', 'ns3.example.com.'] >>> z.save(autoserial=True)
区域检查:
>>> from easyzone.zone_check import ZoneCheck >>> c = ZoneCheck() >>> c.isValid('example.com', '/var/named/zones/example.com') True >>> c.isValid('foo.com', '/var/named/zones/example.com') False >>> c.error 'Bad syntax' >>> >>> c = ZoneCheck(checkzone='/usr/sbin/named-checkzone') >>> c.isValid('example.com', '/var/named/zones/example.com') True >>>
分区加载:
>>> from easyzone.zone_reload import ZoneReload >>> r = ZoneReload() >>> r.reload('example.com') zone reload up-to-date >>> r.reload('foo.com') rndc: 'reload' failed: not found Traceback (most recent call last): File "<stdin>", line 1, in <module> File "easyzone/zone_reload.py", line 51, in reload raise ZoneReloadError("rndc failed with return code %d" % r) easyzone.zone_reload.ZoneReloadError: rndc failed with return code 1 >>> >>> r = ZoneReload(rndc='/usr/sbin/rndc') >>> r.reload('example.com') zone reload up-to-date >>>