| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | package reverse
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import (
 | 
					
						
							|  |  |  | 	"net"
 | 
					
						
							|  |  |  | 	"reflect"
 | 
					
						
							|  |  |  | 	"regexp"
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 	"testing"
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/mholt/caddy"
 | 
					
						
							|  |  |  | )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestSetupParse(t *testing.T) {
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, net4, _ := net.ParseCIDR("10.1.1.0/24")
 | 
					
						
							|  |  |  | 	_, net6, _ := net.ParseCIDR("fd01::/64")
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-11 00:49:24 -04:00
										 |  |  | 	regexIP4wildcard, _ := regexp.Compile("^.*ip-" + regexMatchV4 + "\\.domain\\.com\\.$")
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 	regexIP6, _ := regexp.Compile("^ip-" + regexMatchV6 + "\\.domain\\.com\\.$")
 | 
					
						
							|  |  |  | 	regexIpv4dynamic, _ := regexp.Compile("^dynamic-" + regexMatchV4 + "-intern\\.dynamic\\.domain\\.com\\.$")
 | 
					
						
							|  |  |  | 	regexIpv6dynamic, _ := regexp.Compile("^dynamic-" + regexMatchV6 + "-intern\\.dynamic\\.domain\\.com\\.$")
 | 
					
						
							|  |  |  | 	regexIpv4vpndynamic, _ := regexp.Compile("^dynamic-" + regexMatchV4 + "-vpn\\.dynamic\\.domain\\.com\\.$")
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 	serverBlockKeys := []string{"domain.com.:8053", "dynamic.domain.com.:8053"}
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	tests := []struct {
 | 
					
						
							|  |  |  | 		inputFileRules string
 | 
					
						
							|  |  |  | 		shouldErr      bool
 | 
					
						
							|  |  |  | 		networks       networks
 | 
					
						
							|  |  |  | 	}{
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// with defaults
 | 
					
						
							|  |  |  | 			`reverse fd01::/64`,
 | 
					
						
							|  |  |  | 			false,
 | 
					
						
							|  |  |  | 			networks{network{
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				IPnet:        net6,
 | 
					
						
							|  |  |  | 				Template:     "ip-{ip}.domain.com.",
 | 
					
						
							|  |  |  | 				Zone:         "domain.com.",
 | 
					
						
							|  |  |  | 				TTL:          60,
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 				RegexMatchIP: regexIP6,
 | 
					
						
							|  |  |  | 			}},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			`reverse`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			//no cidr
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.1`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			//no cidr
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.0/16 fd00::`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// invalid key
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.0/24 {
 | 
					
						
							|  |  |  | 				notavailable
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// no domain suffix
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.0/24 {
 | 
					
						
							|  |  |  | 				hostname ip-{ip}.
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// hostname requires an second arg
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.0/24 {
 | 
					
						
							|  |  |  | 				hostname
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// template breaks regex compile
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.0/24 {
 | 
					
						
							|  |  |  | 				hostname ip-{[-x
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// ttl requires an (u)int
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.0/24 {
 | 
					
						
							|  |  |  | 				ttl string
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			true,
 | 
					
						
							|  |  |  | 			networks{},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			`reverse fd01::/64 {
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				hostname dynamic-{ip}-intern.{zone[2]}
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 				ttl 50
 | 
					
						
							|  |  |  | 			}
 | 
					
						
							|  |  |  | 			reverse 10.1.1.0/24 {
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				hostname dynamic-{ip}-vpn.{zone[2]}
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 				fallthrough
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			false,
 | 
					
						
							|  |  |  | 			networks{network{
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				IPnet:        net6,
 | 
					
						
							|  |  |  | 				Template:     "dynamic-{ip}-intern.dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				Zone:         "dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				TTL:          50,
 | 
					
						
							|  |  |  | 				RegexMatchIP: regexIpv6dynamic,
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 			}, network{
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				IPnet:        net4,
 | 
					
						
							|  |  |  | 				Template:     "dynamic-{ip}-vpn.dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				Zone:         "dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				TTL:          60,
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 				RegexMatchIP: regexIpv4vpndynamic,
 | 
					
						
							|  |  |  | 			}},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// multiple networks in one stanza
 | 
					
						
							|  |  |  | 			`reverse fd01::/64 10.1.1.0/24 {
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				hostname dynamic-{ip}-intern.{zone[2]}
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 				ttl 50
 | 
					
						
							|  |  |  | 				fallthrough
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			false,
 | 
					
						
							|  |  |  | 			networks{network{
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				IPnet:        net6,
 | 
					
						
							|  |  |  | 				Template:     "dynamic-{ip}-intern.dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				Zone:         "dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				TTL:          50,
 | 
					
						
							|  |  |  | 				RegexMatchIP: regexIpv6dynamic,
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 			}, network{
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				IPnet:        net4,
 | 
					
						
							|  |  |  | 				Template:     "dynamic-{ip}-intern.dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				Zone:         "dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				TTL:          50,
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 				RegexMatchIP: regexIpv4dynamic,
 | 
					
						
							|  |  |  | 			}},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							|  |  |  | 		{
 | 
					
						
							|  |  |  | 			// fix domain in template
 | 
					
						
							|  |  |  | 			`reverse fd01::/64 {
 | 
					
						
							|  |  |  | 				hostname dynamic-{ip}-intern.dynamic.domain.com
 | 
					
						
							|  |  |  | 				ttl 300
 | 
					
						
							|  |  |  | 				fallthrough
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			false,
 | 
					
						
							|  |  |  | 			networks{network{
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | 				IPnet:        net6,
 | 
					
						
							|  |  |  | 				Template:     "dynamic-{ip}-intern.dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				Zone:         "dynamic.domain.com.",
 | 
					
						
							|  |  |  | 				TTL:          300,
 | 
					
						
							|  |  |  | 				RegexMatchIP: regexIpv6dynamic,
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 			}},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							| 
									
										
										
										
											2017-07-11 00:49:24 -04:00
										 |  |  | 		{
 | 
					
						
							|  |  |  | 			`reverse 10.1.1.0/24 {
 | 
					
						
							|  |  |  | 				hostname ip-{ip}.{zone[1]}
 | 
					
						
							|  |  |  | 				ttl 50
 | 
					
						
							|  |  |  | 			    wildcard
 | 
					
						
							|  |  |  | 				fallthrough
 | 
					
						
							|  |  |  | 			}`,
 | 
					
						
							|  |  |  | 			false,
 | 
					
						
							|  |  |  | 			networks{network{
 | 
					
						
							|  |  |  | 				IPnet:        net4,
 | 
					
						
							|  |  |  | 				Template:     "ip-{ip}.domain.com.",
 | 
					
						
							|  |  |  | 				Zone:         "domain.com.",
 | 
					
						
							|  |  |  | 				TTL:          50,
 | 
					
						
							|  |  |  | 				RegexMatchIP: regexIP4wildcard,
 | 
					
						
							|  |  |  | 			}},
 | 
					
						
							|  |  |  | 		},
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 	}
 | 
					
						
							|  |  |  | 	for i, test := range tests {
 | 
					
						
							|  |  |  | 		c := caddy.NewTestController("dns", test.inputFileRules)
 | 
					
						
							|  |  |  | 		c.ServerBlockKeys = serverBlockKeys
 | 
					
						
							| 
									
										
										
										
											2017-02-20 21:00:00 +00:00
										 |  |  | 		networks, _, err := reverseParse(c)
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if err == nil && test.shouldErr {
 | 
					
						
							|  |  |  | 			t.Fatalf("Test %d expected errors, but got no error", i)
 | 
					
						
							|  |  |  | 		} else if err != nil && !test.shouldErr {
 | 
					
						
							|  |  |  | 			t.Fatalf("Test %d expected no errors, but got '%v'", i, err)
 | 
					
						
							| 
									
										
										
										
											2017-02-20 21:00:00 +00:00
										 |  |  | 		}
 | 
					
						
							|  |  |  | 		for j, n := range networks {
 | 
					
						
							|  |  |  | 			reflect.DeepEqual(test.networks[j], n)
 | 
					
						
							|  |  |  | 			if !reflect.DeepEqual(test.networks[j], n) {
 | 
					
						
							|  |  |  | 				t.Fatalf("Test %d/%d expected %v, got %v", i, j, test.networks[j], n)
 | 
					
						
							| 
									
										
										
										
											2017-02-09 20:39:48 +01:00
										 |  |  | 			}
 | 
					
						
							|  |  |  | 		}
 | 
					
						
							|  |  |  | 	}
 | 
					
						
							| 
									
										
										
										
											2017-02-10 12:48:51 +00:00
										 |  |  | }
 |