Files
coredns/plugin/etcd/msg/path.go

52 lines
1.5 KiB
Go
Raw Normal View History

package msg
2016-03-21 07:20:22 +00:00
import (
"path"
"strings"
"github.com/coredns/coredns/plugin/pkg/dnsutil"
2016-03-21 07:20:22 +00:00
"github.com/miekg/dns"
)
// Path converts a domainname to an etcd path. If s looks like service.staging.skydns.local.,
// the resulting key will be /skydns/local/skydns/staging/service .
func Path(s, prefix string) string {
2016-03-21 07:20:22 +00:00
l := dns.SplitDomainName(s)
for i, j := 0, len(l)-1; i < j; i, j = i+1, j-1 {
l[i], l[j] = l[j], l[i]
}
return path.Join(append([]string{"/" + prefix + "/"}, l...)...)
2016-03-21 07:20:22 +00:00
}
// Domain is the opposite of Path.
func Domain(s string) string {
2016-03-21 07:20:22 +00:00
l := strings.Split(s, "/")
if l[len(l)-1] == "" {
l = l[:len(l)-1]
}
2016-03-21 07:20:22 +00:00
// start with 1, to strip /skydns
for i, j := 1, len(l)-1; i < j; i, j = i+1, j-1 {
l[i], l[j] = l[j], l[i]
}
return dnsutil.Join(l[1 : len(l)-1]...)
2016-03-21 07:20:22 +00:00
}
// PathWithWildcard acts as Path, but if a name contains wildcards (* or any), the name will be
// chopped of before the (first) wildcard, and we do a higher level search and
2016-03-21 07:20:22 +00:00
// later find the matching names. So service.*.skydns.local, will look for all
// services under skydns.local and will later check for names that match
// service.*.skydns.local. If a wildcard is found the returned bool is true.
func PathWithWildcard(s, prefix string) (string, bool) {
2016-03-21 07:20:22 +00:00
l := dns.SplitDomainName(s)
for i, j := 0, len(l)-1; i < j; i, j = i+1, j-1 {
l[i], l[j] = l[j], l[i]
}
for i, k := range l {
if k == "*" || k == "any" {
return path.Join(append([]string{"/" + prefix + "/"}, l[:i]...)...), true
2016-03-21 07:20:22 +00:00
}
}
return path.Join(append([]string{"/" + prefix + "/"}, l...)...), false
2016-03-21 07:20:22 +00:00
}