-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathmain.go
132 lines (119 loc) · 3.68 KB
/
main.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
// Copyright (c) 2013 The SkyDNS Authors. All rights reserved.
// Use of this source code is governed by The MIT License (MIT) that can be
// found in the LICENSE file.
package main
import (
"errors"
"flag"
"github.com/goraft/raft"
"github.com/miekg/dns"
"github.com/skynetservices/skydns1/server"
"github.com/skynetservices/skydns1/stats"
"log"
"net"
"os"
"strings"
"time"
)
var (
join, ldns, lhttp, dataDir, domain string
rtimeout, wtimeout time.Duration
discover, norr bool
secret string
nameserver string
dnssec string
tlskey string
tlspem string
)
func init() {
flag.StringVar(&join, "join", "", "Member of SkyDNS cluster to join can be comma separated list")
flag.BoolVar(&discover, "discover", false, "Auto discover SkyDNS cluster. Performs an NS lookup on the -domain to find SkyDNS members")
flag.StringVar(&domain, "domain",
func() string {
if x := os.Getenv("SKYDNS_DOMAIN"); x != "" {
return x
}
return "skydns.local"
}(), "Domain to anchor requests to or env. var. SKYDNS_DOMAIN")
flag.StringVar(&ldns, "dns",
func() string {
if x := os.Getenv("SKYDNS_DNS"); x != "" {
return x
}
return "127.0.0.1:53"
}(), "IP:Port to bind to for DNS or env. var SKYDNS_DNS")
flag.StringVar(&lhttp, "http",
func() string {
if x := os.Getenv("SKYDNS"); x != "" {
// get rid of http or https
x1 := strings.TrimPrefix(x, "https://")
x1 = strings.TrimPrefix(x1, "http://")
return x1
}
return "127.0.0.1:8080"
}(), "IP:Port to bind to for HTTP or env. var. SKYDNS")
flag.StringVar(&dataDir, "data", "./data", "SkyDNS data directory")
flag.DurationVar(&rtimeout, "rtimeout", 2*time.Second, "Read timeout")
flag.DurationVar(&wtimeout, "wtimeout", 2*time.Second, "Write timeout")
flag.StringVar(&secret, "secret", "", "Shared secret for use with http api")
flag.StringVar(&nameserver, "nameserver", "", "Nameserver address to forward (non-local) queries to e.g. 8.8.8.8:53,8.8.4.4:53")
flag.StringVar(&dnssec, "dnssec", "", "Basename of DNSSEC key file e.q. Kskydns.local.+005+38250")
flag.BoolVar(&norr, "no-round-robin", false, "Do not round robin A/AAAA replies")
flag.StringVar(&tlskey, "tls-key", "", "TLS Private Key Path")
flag.StringVar(&tlspem, "tls-pem", "", "X509 Certificate")
}
func main() {
members := make([]string, 0)
raft.SetLogLevel(0)
flag.Parse()
nameservers := strings.Split(nameserver, ",")
// empty argument given
if len(nameservers) == 1 && nameservers[0] == "" {
nameservers = make([]string, 0)
config, err := dns.ClientConfigFromFile("/etc/resolv.conf")
if err == nil {
for _, s := range config.Servers {
nameservers = append(nameservers, net.JoinHostPort(s, config.Port))
}
} else {
log.Fatal(err)
return
}
}
if discover {
ns, err := net.LookupNS(domain)
if err != nil {
log.Fatal(err)
return
}
if len(ns) < 1 {
log.Fatal("No NS records found for ", domain)
return
}
for _, n := range ns {
members = append(members, strings.TrimPrefix(n.Host, "."))
}
} else if join != "" {
members = strings.Split(join, ",")
}
s := server.NewServer(members, domain, ldns, lhttp, dataDir, rtimeout, wtimeout, secret, nameservers, !norr, tlskey, tlspem)
if dnssec != "" {
k, p, e := server.ParseKeyFile(dnssec)
if e != nil {
log.Fatal(e)
return
}
if k.Header().Name != dns.Fqdn(domain) {
log.Fatal(errors.New("Owner name of DNSKEY must match SkyDNS domain"))
return
}
s.SetKeys(k, p)
}
stats.Collect()
waiter, err := s.Start()
if err != nil {
log.Fatal(err)
return
}
waiter.Wait()
}