-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathzonefile.go
92 lines (73 loc) · 1.8 KB
/
zonefile.go
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
package main
import (
"database/sql"
"fmt"
"io/fs"
"os"
"regexp"
"strings"
"sync"
"github.com/miekg/dns"
)
type zoneData struct {
zone, filename string
}
func readZonefiles(zoneDataChan <-chan zoneData, rrDataChan chan<- rrData, wg *sync.WaitGroup) {
defer wg.Done()
for zoneD := range zoneDataChan {
zoneName, filename := zoneD.zone, zoneD.filename
fp := check1(os.Open(filename))
zp := dns.NewZoneParser(fp, zoneName, filename)
zoneLower := strings.ToLower(zoneName)
for rr, running := zp.Next(); running; rr, running = zp.Next() {
switch rr.(type) {
case *dns.NSEC, *dns.NSEC3, *dns.RRSIG:
continue
}
normalizeRR(rr)
rrValue := rr.String()
header := rr.Header()
rrD := rrData{
zone: zoneLower,
rrValue: rrValue,
rrType: dns.TypeToString[header.Rrtype],
rrName: header.Name,
msgtype: rrDataRegular,
parentZone: tldZone,
}
rrDataChan <- rrD
}
rrDataChan <- rrData{
zone: zoneLower,
msgtype: rrDataZoneDone,
}
fmt.Printf("inserted %s\n", zoneName)
check(fp.Close())
}
}
func parseZoneFiles(db *sql.DB) {
var matches []string
if len(args) > 0 {
matches = args
} else {
matches = check1(fs.Glob(os.DirFS("."), "zones/*.zone"))
}
pattern := regexp.MustCompile("zones/([a-z0-9.-]+)zone")
rrDataChan := make(chan rrData, BUFLEN)
zoneDataChan := make(chan zoneData, BUFLEN)
go func(matches []string) {
for _, match := range matches {
reMatch := pattern.FindAllStringSubmatch(match, 1)
zone := reMatch[0][1]
zoneDataChan <- zoneData{filename: match, zone: zone}
}
close(zoneDataChan)
}(matches)
var wg sync.WaitGroup
wg.Add(numProcs)
for range numProcs {
go readZonefiles(zoneDataChan, rrDataChan, &wg)
}
closeChanWait(&wg, rrDataChan)
insertRRWorker(db, chanToSeq(rrDataChan))
}