1 1.1 christos #!/usr/bin/python 2 1.1 christos ''' 3 1.1 christos dnssec-valid.py: DNSSEC validation 4 1.1 christos 5 1.1 christos Authors: Zdenek Vasicek (vasicek AT fit.vutbr.cz) 6 1.1 christos Marek Vavrusa (xvavru00 AT stud.fit.vutbr.cz) 7 1.1 christos 8 1.1 christos Copyright (c) 2008. All rights reserved. 9 1.1 christos 10 1.1 christos This software is open source. 11 1.1 christos 12 1.1 christos Redistribution and use in source and binary forms, with or without 13 1.1 christos modification, are permitted provided that the following conditions 14 1.1 christos are met: 15 1.1 christos 16 1.1 christos Redistributions of source code must retain the above copyright notice, 17 1.1 christos this list of conditions and the following disclaimer. 18 1.1 christos 19 1.1 christos Redistributions in binary form must reproduce the above copyright notice, 20 1.1 christos this list of conditions and the following disclaimer in the documentation 21 1.1 christos and/or other materials provided with the distribution. 22 1.1 christos 23 1.1 christos THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 24 1.1 christos "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 25 1.1 christos TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 26 1.1 christos PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE 27 1.1 christos LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 28 1.1 christos CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 29 1.1 christos SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 30 1.1 christos INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 31 1.1 christos CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 32 1.1 christos ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 33 1.1 christos POSSIBILITY OF SUCH DAMAGE. 34 1.1 christos ''' 35 1.1 christos from __future__ import print_function 36 1.1 christos import os 37 1.1 christos from unbound import ub_ctx,RR_TYPE_A,RR_CLASS_IN 38 1.1 christos 39 1.1 christos ctx = ub_ctx() 40 1.1 christos ctx.resolvconf("/etc/resolv.conf") 41 1.1 christos 42 1.1 christos fw = open("dnssec-valid.txt","wb") 43 1.1 christos ctx.debugout(fw) 44 1.1 christos ctx.debuglevel(2) 45 1.1 christos 46 1.1 christos if os.path.isfile("keys"): 47 1.1 christos ctx.add_ta_file("keys") #read public keys for DNSSEC verification 48 1.1 christos 49 1.1 christos status, result = ctx.resolve("www.nic.cz", RR_TYPE_A, RR_CLASS_IN) 50 1.1 christos if status == 0 and result.havedata: 51 1.1 christos 52 1.1 christos print("Result:", sorted(result.data.address_list)) 53 1.1 christos 54 1.1 christos if result.secure: 55 1.1 christos print("Result is secure") 56 1.1 christos elif result.bogus: 57 1.1 christos print("Result is bogus") 58 1.1 christos else: 59 1.1 christos print("Result is insecure") 60 1.1 christos 61