File: digroot.rb

package info (click to toggle)
dnsruby 1.73.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,548 kB
  • sloc: ruby: 17,966; makefile: 3
file content (69 lines) | stat: -rwxr-xr-x 1,704 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#! /usr/bin/env ruby

# --
# Copyright 2007 Nominet UK
# 
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# 
#     http://www.apache.org/licenses/LICENSE-2.0
# 
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ++

# = NAME
# 
# digitar - Ruby script to perform DNS queries, validated against the IANA TAR
# (trust anchor repository).
# 
# = SYNOPSIS
# 
# digroot name [ type [ class ] ]
# 
# = DESCRIPTION
# 
# Performs a DNS query on the given name.  The record type
# and class can also be specified; if left blank they default
# to A and IN. The program firstly performs the requested DNS
# query. The response is then validated from the signed root.
# 
# = AUTHOR
# 
# Michael Fuhr <mike@fuhr.org>
# Alex D <alexd@nominet.org.uk>

require 'dnsruby'

def fatal_error(message)
  puts message
  exit -1
end

unless (1..3).include?(ARGV.length)
  fatal_error("Usage: #{$0}  name [ type [ class ] ]")
end


inner_resolver = Dnsruby::Resolver.new
inner_resolver.do_validation = true
inner_resolver.dnssec = true
resolver = Dnsruby::Recursor.new(inner_resolver)
resolver.dnssec = true

#    Dnsruby::TheLog.level=Logger::DEBUG

name, type, klass = ARGV
type  ||= 'A'
klass ||= 'IN'

begin
  answer = resolver.query(name, type, klass)
  print answer
rescue Exception => e
  fatal_error("query failed: #{e}")
end