mirror of
https://github.com/coredns/coredns.git
synced 2025-11-02 02:03:13 -05:00
Fix Corefile parsing
Fix some file/secondary issues when parsing a Corefile, also allow for multiple origins to be specified. Also don't fail on startup when a zonetransfer fails. Fixes: #54
This commit is contained in:
@@ -13,7 +13,6 @@ func File(c *Controller) (middleware.Middleware, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
// Set start function is transfer is specified
|
|
||||||
|
|
||||||
return func(next middleware.Handler) middleware.Handler {
|
return func(next middleware.Handler) middleware.Handler {
|
||||||
return file.File{Next: next, Zones: zones}
|
return file.File{Next: next, Zones: zones}
|
||||||
@@ -32,22 +31,25 @@ func fileParse(c *Controller) (file.Zones, error) {
|
|||||||
}
|
}
|
||||||
fileName := c.Val()
|
fileName := c.Val()
|
||||||
|
|
||||||
origin := c.ServerBlockHosts[c.ServerBlockHostIndex]
|
origins := []string{c.ServerBlockHosts[c.ServerBlockHostIndex]}
|
||||||
if c.NextArg() {
|
args := c.RemainingArgs()
|
||||||
origin = c.Val()
|
if len(args) > 0 {
|
||||||
|
origins = args
|
||||||
}
|
}
|
||||||
origin = middleware.Host(origin).Normalize()
|
|
||||||
|
|
||||||
// TODO(miek): we should allow more. Issue #54.
|
|
||||||
reader, err := os.Open(fileName)
|
reader, err := os.Open(fileName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return file.Zones{}, err
|
return file.Zones{}, err
|
||||||
}
|
}
|
||||||
zone, err := file.Parse(reader, origin, fileName)
|
|
||||||
if err == nil {
|
for i, _ := range origins {
|
||||||
z[origin] = zone
|
origins[i] = middleware.Host(origins[i]).Normalize()
|
||||||
|
zone, err := file.Parse(reader, origins[i], fileName)
|
||||||
|
if err == nil {
|
||||||
|
z[origins[i]] = zone
|
||||||
|
}
|
||||||
|
names = append(names, origins[i])
|
||||||
}
|
}
|
||||||
names = append(names, origin)
|
|
||||||
|
|
||||||
for c.NextBlock() {
|
for c.NextBlock() {
|
||||||
t, _, e := parseTransfer(c)
|
t, _, e := parseTransfer(c)
|
||||||
@@ -55,7 +57,9 @@ func fileParse(c *Controller) (file.Zones, error) {
|
|||||||
return file.Zones{}, e
|
return file.Zones{}, e
|
||||||
}
|
}
|
||||||
// discard from, here, maybe check and show log when we do?
|
// discard from, here, maybe check and show log when we do?
|
||||||
z[origin].TransferTo = append(z[origin].TransferTo, t)
|
for _, origin := range origins {
|
||||||
|
z[origin].TransferTo = append(z[origin].TransferTo, t)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -35,23 +35,26 @@ func secondaryParse(c *Controller) (file.Zones, error) {
|
|||||||
for c.Next() {
|
for c.Next() {
|
||||||
if c.Val() == "secondary" {
|
if c.Val() == "secondary" {
|
||||||
// secondary [origin]
|
// secondary [origin]
|
||||||
origin := c.ServerBlockHosts[c.ServerBlockHostIndex]
|
origins := []string{c.ServerBlockHosts[c.ServerBlockHostIndex]}
|
||||||
if c.NextArg() {
|
args := c.RemainingArgs()
|
||||||
origin = c.Val()
|
if len(args) > 0 {
|
||||||
|
origins = args
|
||||||
|
}
|
||||||
|
for i, _ := range origins {
|
||||||
|
origins[i] = middleware.Host(origins[i]).Normalize()
|
||||||
|
z[origins[i]] = file.NewZone(origins[i])
|
||||||
|
names = append(names, origins[i])
|
||||||
}
|
}
|
||||||
// TODO(miek): we should allow more. Issue #54.
|
|
||||||
origin = middleware.Host(origin).Normalize()
|
|
||||||
|
|
||||||
z[origin] = file.NewZone(origin)
|
|
||||||
names = append(names, origin)
|
|
||||||
|
|
||||||
for c.NextBlock() {
|
for c.NextBlock() {
|
||||||
t, f, e := parseTransfer(c)
|
t, f, e := parseTransfer(c)
|
||||||
if e != nil {
|
if e != nil {
|
||||||
return file.Zones{}, e
|
return file.Zones{}, e
|
||||||
}
|
}
|
||||||
z[origin].TransferTo = append(z[origin].TransferTo, t)
|
for _, origin := range origins {
|
||||||
z[origin].TransferFrom = append(z[origin].TransferFrom, f)
|
z[origin].TransferTo = append(z[origin].TransferTo, t)
|
||||||
|
z[origin].TransferFrom = append(z[origin].TransferFrom, f)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
2
main.go
2
main.go
@@ -207,7 +207,7 @@ func setVersion() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const appName = "Caddy"
|
const appName = "CoreDNS"
|
||||||
|
|
||||||
// Flags that control program flow or startup
|
// Flags that control program flow or startup
|
||||||
var (
|
var (
|
||||||
|
|||||||
@@ -14,10 +14,6 @@ func (z *Zone) TransferIn() error {
|
|||||||
t := new(dns.Transfer)
|
t := new(dns.Transfer)
|
||||||
m := new(dns.Msg)
|
m := new(dns.Msg)
|
||||||
m.SetAxfr(z.name)
|
m.SetAxfr(z.name)
|
||||||
/*
|
|
||||||
t.TsigSecret = map[string]string{"axfr.": "so6ZGir4GPAqINNh9U5c3A=="}
|
|
||||||
m.SetTsig("axfr.", dns.HmacMD5, 300, time.Now().Unix())
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Err error
|
var Err error
|
||||||
Transfer:
|
Transfer:
|
||||||
@@ -48,16 +44,6 @@ Transfer:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return Err
|
return nil
|
||||||
|
return Err // ignore errors for now. TODO(miek)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
28800 ; refresh (8 hours)
|
|
||||||
7200 ; retry (2 hours)
|
|
||||||
604800 ; expire (1 week)
|
|
||||||
3600 ; minimum (1 hour)
|
|
||||||
// Check SOA
|
|
||||||
// Just check every refresh hours, if fail set to retry until succeeds
|
|
||||||
// expire is need: to give SERVFAIL.
|
|
||||||
*/
|
|
||||||
|
|||||||
@@ -273,6 +273,7 @@ func (s *Server) ServeDNS(w dns.ResponseWriter, r *dns.Msg) {
|
|||||||
b := make([]byte, len(q))
|
b := make([]byte, len(q))
|
||||||
off, end := 0, false
|
off, end := 0, false
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
|
|
||||||
for {
|
for {
|
||||||
l := len(q[off:])
|
l := len(q[off:])
|
||||||
for i := 0; i < l; i++ {
|
for i := 0; i < l; i++ {
|
||||||
|
|||||||
Reference in New Issue
Block a user