Browse Source

gip: add google and modify structure

Signed-off-by: Nagy Károly Gábriel <k@jpi.io>
master
Nagy Károly Gábriel 6 years ago
parent
commit
cf79e2e8f0
Signed by: karasz
GPG Key ID: C6BA1070A8CBDA0C
  1. 112
      gip.go

112
gip.go

@ -2,8 +2,8 @@ package main
import ( import (
"fmt" "fmt"
"github.com/miekg/dns" "github.com/miekg/dns"
"os"
) )
/* /*
@ -11,58 +11,102 @@ dig {-4,-6} +short myip.opendns.com @resolver1.opendns.com
dig {-4,-6} TXT +short o-o.myaddr.l.google.com @ns1.google.com dig {-4,-6} TXT +short o-o.myaddr.l.google.com @ns1.google.com
*/ */
func get4(c *dns.Client, m *dns.Msg, nameserver string) (*dns.Msg, error) { func getO() (ipv4 string, ipv6 string) {
nameserver := dns.Fqdn("resolver1.opendns.com") + ":53"
c := new(dns.Client)
m := &dns.Msg{
MsgHdr: dns.MsgHdr{
RecursionDesired: true,
},
Question: make([]dns.Question, 1),
}
// get IPv4 first
c.Net = "udp4" c.Net = "udp4"
m.SetQuestion("myip.opendns.com.", dns.TypeA) m.SetQuestion("myip.opendns.com.", dns.TypeA)
r4, _, e4 := c.Exchange(m, nameserver)
r, _, err := c.Exchange(m, nameserver) if e4 != nil {
return r, err ipv4 = ""
} } else {
ipv4 = getIP(r4.Answer)
func get6(c *dns.Client, m *dns.Msg, nameserver string) (*dns.Msg, error) { }
// now IPv6
c.Net = "udp6" c.Net = "udp6"
m.SetQuestion("myip.opendns.com.", dns.TypeAAAA) m.SetQuestion("myip.opendns.com.", dns.TypeAAAA)
r6, _, e6 := c.Exchange(m, nameserver)
if e6 != nil {
ipv6 = ""
} else {
ipv6 = getIP(r6.Answer)
}
return ipv4, ipv6
}
r, _, err := c.Exchange(m, nameserver) func getG() (ipv4 string, ipv6 string) {
return r, err nameserver := dns.Fqdn("ns1.google.com") + ":53"
c := new(dns.Client)
m := &dns.Msg{
MsgHdr: dns.MsgHdr{
RecursionDesired: true,
},
Question: make([]dns.Question, 1),
}
// get IPv4 first
c.Net = "udp4"
m.SetQuestion("o-o.myaddr.l.google.com.", dns.TypeTXT)
r4, _, e4 := c.Exchange(m, nameserver)
if e4 != nil {
ipv4 = ""
} else {
ipv4 = getIP(r4.Answer)
}
// now IPv6
c.Net = "udp6"
m.SetQuestion("o-o.myaddr.l.google.com.", dns.TypeTXT)
r6, _, e6 := c.Exchange(m, nameserver)
if e6 != nil {
ipv6 = ""
} else {
ipv6 = getIP(r6.Answer)
}
return ipv4, ipv6
} }
func printIP(ra []dns.RR) []string { func getIP(ra []dns.RR) string {
var ips []string //the answer will always be one IP or none
var ip string
for _, ansa := range ra { for _, ansa := range ra {
switch ansb := ansa.(type) { switch ansb := ansa.(type) {
case *dns.A: case *dns.A:
ips = append(ips, ansb.A.String()) ip = ansb.A.String()
case *dns.AAAA: case *dns.AAAA:
ips = append(ips, ansb.AAAA.String()) ip = ansb.AAAA.String()
case *dns.TXT:
// we always expect only one IP in the field
ip = ansb.Txt[0]
} }
} }
return ips return ip
} }
func main() { func main() {
nameserver := dns.Fqdn("resolver1.opendns.com") + ":53" var ipv4, ipv6 string
exit := 0
c := new(dns.Client) o4, o6 := getO()
c.Net = "udp4" g4, g6 := getG()
m := &dns.Msg{ if o4 == g4 {
MsgHdr: dns.MsgHdr{ ipv4 = o4
RecursionDesired: true,
},
Question: make([]dns.Question, 1),
}
r4, err := get4(c, m, nameserver)
if err != nil {
fmt.Println(err)
} else { } else {
fmt.Println(printIP(r4.Answer)) ipv4 = ""
exit = 111
} }
r6, e6 := get6(c, m, nameserver) if o6 == g6 {
if err != nil { ipv6 = o6
fmt.Println(e6)
} else { } else {
fmt.Println(printIP(r6.Answer)) ipv6 = ""
exit = 111
} }
fmt.Printf("%s\t%s\n", ipv4, ipv6)
os.Exit(exit)
} }

Loading…
Cancel
Save