dns/ex/axfr/axfr.go

43 lines
898 B
Go
Raw Normal View History

2011-01-02 05:10:07 +11:00
package main
import (
2011-03-29 01:03:47 +11:00
"dns"
"flag"
2011-12-20 22:52:46 +11:00
"fmt"
2012-03-05 02:35:21 +11:00
"strings"
"time"
2011-01-02 05:10:07 +11:00
)
func main() {
2012-03-05 02:35:21 +11:00
serial := flag.Int("serial", 0, "Perform an IXFR with the given serial")
nameserver := flag.String("ns", "127.0.0.1:53", "Query this nameserver")
2012-03-05 03:54:14 +11:00
tsig := flag.String("tsig", "", "request tsig with key: name:key (only hmac-md5)")
2011-03-29 01:03:47 +11:00
flag.Parse()
zone := flag.Arg(flag.NArg() - 1)
2011-02-26 07:17:17 +11:00
client := new(dns.Client)
client.Net = "tcp"
m := new(dns.Msg)
2011-03-29 01:03:47 +11:00
if *serial > 0 {
m.SetIxfr(zone, uint32(*serial))
} else {
m.SetAxfr(zone)
}
2012-03-05 02:35:21 +11:00
if *tsig != "" {
a := strings.SplitN(*tsig, ":", 2)
name, secret := a[0], a[1]
client.TsigSecret = map[string]string{name: secret}
m.SetTsig(name, dns.HmacMD5, 300, time.Now().Unix())
2012-03-05 02:35:21 +11:00
}
if t, e := client.XfrReceive(m, *nameserver); e == nil {
for r := range t {
if r.Error == nil {
fmt.Printf("%v\n", r.Reply)
2011-12-20 23:05:42 +11:00
}
}
} else {
fmt.Printf("Error %v\n", e)
2011-12-20 23:05:42 +11:00
}
2011-01-02 05:10:07 +11:00
}