// This creates a simple hello world window package main import ( "log" "fmt" "os" "os/user" "strconv" "net" "strings" "go.wit.com/gui" "go.wit.com/shell" "github.com/davecgh/go-spew/spew" ) // This setups up the dns control panel window func setupControlPanelWindow() { me.window = myGui.NewWindow("DNS and IPv6 Control Panel") // me.window.Dump() // will dump out some info debug("artificial sleep of:", me.artificialSleep) sleep(me.artificialSleep) dnsTab("DNS") detailsTab("Details") debugTab("Debug") } func detailsTab(title string) { var g2 *gui.Node tab := me.window.NewTab(title) g2 = tab.NewGroup("Real Stuff") grid := g2.NewGrid("gridnuts", 2, 2) grid.SetNext(1,1) grid.NewLabel("domainname =") me.domainname = grid.NewLabel("domainname") grid.NewLabel("hostname -s =") me.hostshort = grid.NewLabel("hostname -s") grid.NewLabel("NS records =") me.NSrr = grid.NewLabel("NS RR's") grid.NewLabel("UID =") me.uid = grid.NewLabel("my uid") grid.NewLabel("Current IPv4 =") me.IPv4 = grid.NewLabel("?") grid.NewLabel("Current IPv6 =") me.IPv6 = grid.NewLabel("?") grid.NewLabel("interfaces =") me.Interfaces = grid.NewCombobox("Interfaces") grid.NewLabel("refresh speed") me.LocalSpeedActual = grid.NewLabel("unknown") tab.Margin() tab.Pad() grid.Margin() grid.Pad() } func debugTab(title string) { var g2 *gui.Node tab := me.window.NewTab(title) g2 = tab.NewGroup("Real Stuff") g2.NewButton("gui.DebugWindow()", func () { gui.DebugWindow() }) g2.NewButton("Load 'gocui'", func () { // this set the xterm and mate-terminal window title. maybe works generally? fmt.Println("\033]0;" + title + "blah \007") myGui.LoadToolkit("gocui") }) g2.NewButton("Network Interfaces", func () { for i, t := range me.ifmap { log.Println("name =", t.iface.Name) log.Println("int =", i, "name =", t.name, t.iface) log.Println("iface = " + t.iface.Name) } }) g2.NewButton("Hostname", func () { getHostname() }) g2.NewButton("Actual AAAA & A", func () { displayDNS() // doesn't re-query anything }) g2.NewButton("dig A & AAAA DNS records", func () { log.Println("updateDNS()") updateDNS() }) g2.NewButton("checkDNS:", func () { ipv6s, ipv4s := checkDNS() for s, _ := range ipv6s { debug(LogNow, "check if", s, "is in DNS") } for s, _ := range ipv4s { debug(LogNow, "check if", s, "is in DNS") } }) g2.NewButton("os.User()", func () { user, _ := user.Current() spew.Dump(user) log.Println("os.Getuid =", user.Username, os.Getuid()) if (me.uid != nil) { me.uid.SetText(user.Username + " (" + strconv.Itoa(os.Getuid()) + ")") } }) g2.NewButton("dig +trace", func () { o := shell.Run("dig +trace +noadditional DS " + me.hostname + " @8.8.8.8") log.Println(o) // log.Println(o) }) g2.NewButton("Example_listLink()", func () { Example_listLink() }) g2.NewButton("Escalate()", func () { Escalate() }) g2.NewButton("LookupAddr() == fire from /etc/hosts", func () { host, err := net.LookupAddr("2600:1700:afd5:6000:b26e:bfff:fe80:3c52") if err != nil { return } log.Println("host =", host) }) g2.NewButton("DumpPublicDNSZone(apple.com)", func () { DumpPublicDNSZone("apple.com") dumpIPs("www.apple.com") }) g2 = tab.NewGroup("debugging options") // DEBUG flags me.dbOn = g2.NewCheckbox("turn on debugging (will override all flags below)") me.dbOn.Custom = func() { DEBUGON = me.dbOn.B } me.dbNet = g2.NewCheckbox("turn on network debugging)") me.dbNet.Custom = func() { LogNet = me.dbNet.B } me.dbProc = g2.NewCheckbox("turn on /proc debugging)") me.dbProc.Custom = func() { LogProc = me.dbProc.B } // various timeout settings g2.NewLabel("control panel TTL (in tenths of seconds)") ttl := g2.NewSlider("dnsTTL", 1, 100) ttl.Set(int(me.dnsTTL * 10)) ttl.Custom = func () { me.dnsTTL = ttl.I / 10 log.Println("dnsTTL =", me.dnsTTL) } g2.NewLabel("control panel loop delay (in tenths of seconds)") ttl2 := g2.NewSlider("dnsTTL", 1, 100) ttl2.Set(int(me.dnsTTLsleep * 10)) ttl2.Custom = func () { me.dnsTTLsleep = float64(ttl2.I) / 10 log.Println("dnsTTLsleep =", me.dnsTTLsleep) } g2.Margin() g2.Pad() } // doesn't actually do any network traffic // it just updates the GUI func displayDNS() int { var aaaa []string aaaa = realAAAA() // your AAAA records right now h := me.hostname var all string var broken int = 0 for _, s := range aaaa { debug(LogNow, "host", h, "DNS AAAA =", s, "ipmap[s] =", me.ipmap[s]) all += s + "\n" if ( me.ipmap[s] == nil) { debug(LogError, "THIS IS THE WRONG AAAA DNS ENTRY: host", h, "DNS AAAA =", s) broken = 2 } else { if (broken == 0) { broken = 1 } } } all = sortLines(all) if (me.DnsAAAA.S != all) { debug(LogError, "DnsAAAA.SetText() to:", all) me.DnsAAAA.SetText(all) } var a []string a = realA() all = sortLines(strings.Join(a, "\n")) if (all == "") { debug(LogInfo, "THERE IS NOT a real A DNS ENTRY") all = "CNAME ipv6.wit.com" } if (me.DnsA.S != all) { debug(LogError, "DnsA.SetText() to:", all) me.DnsA.SetText(all) } return broken } func myDefaultExit(n *gui.Node) { log.Println("You can Do exit() things here") os.Exit(0) } func dnsTab(title string) { tab := me.window.NewTab(title) me.mainStatus = tab.NewGroup("dns update") grid := me.mainStatus.NewGrid("gridnuts", 2, 2) grid.SetNext(1,1) grid.NewLabel("hostname =") me.fqdn = grid.NewLabel("?") me.hostname = "" grid.NewLabel("DNS AAAA =") me.DnsAAAA = grid.NewLabel("?") grid.NewLabel("DNS A =") me.DnsA = grid.NewLabel("?") me.fix = me.mainStatus.NewButton("Fix", func () { if (goodHostname(me.hostname)) { debug(LogInfo, "hostname is good:", me.hostname) } else { debug(LogError, "FIX: you need to fix your hostname here", me.hostname) return } // check to see if the cloudflare window exists /* if (me.cloudflareW != nil) { newRR.NameNode.SetText(me.hostname) newRR.TypeNode.SetText("AAAA") for s, t := range me.ipmap { if (t.IsReal()) { if (t.ipv6) { newRR.ValueNode.SetText(s) cloudflare.CreateCurlRR() return } } } cloudflare.CreateCurlRR() return } else { // nsupdate() // me.fixProc.Disable() } */ }) me.fix.Disable() grid.Margin() grid.Pad() statusGrid(tab) } func statusGrid(n *gui.Node) { problems := n.NewGroup("status") gridP := problems.NewGrid("nuts", 2, 2) gridP.NewLabel("DNS Status =") me.DnsStatus = gridP.NewLabel("unknown") gridP.NewLabel("hostname =") me.hostnameStatus = gridP.NewLabel("invalid") gridP.NewLabel("dns resolution") me.DnsSpeed = gridP.NewLabel("unknown") gridP.NewLabel("dns resolution speed") me.DnsSpeedActual = gridP.NewLabel("unknown") gridP.NewLabel("dns API provider =") me.DnsAPI = gridP.NewLabel("unknown") gridP.Margin() gridP.Pad() // TODO: these are notes for me things to figure out ng := n.NewGroup("TODO:") gridP = ng.NewGrid("nut2", 2, 2) gridP.NewLabel("IPv6 working =") gridP.NewLabel("unknown") gridP.NewLabel("ping.wit.com =") gridP.NewLabel("unknown") gridP.NewLabel("ping6.wit.com =") gridP.NewLabel("unknown") problems.Margin() problems.Pad() gridP.Margin() gridP.Pad() } // run everything because something has changed func updateDNS() { var aaaa []string h := me.hostname if (h == "") { h = "test.wit.com" } // log.Println("digAAAA()") aaaa = digAAAA(h) debug(LogNow, "digAAAA() =", aaaa) // log.Println(SPEW, me) if (aaaa == nil) { debug(LogError, "There are no DNS AAAA records for hostname: ", h) } broken := displayDNS() // update the GUI based on dig results if (broken == 1) { me.DnsStatus.SetText("PARTLY WORKING") } else if (broken == 2) { me.DnsStatus.SetText("WORKING") } else { me.DnsStatus.SetText("BROKEN") me.fix.Enable() } user, _ := user.Current() spew.Dump(user) log.Println("os.Getuid =", user.Username, os.Getuid()) if (me.uid != nil) { me.uid.SetText(user.Username + " (" + strconv.Itoa(os.Getuid()) + ")") } // lookup the NS records for your domain // if your host is test.wit.com, find the NS resource records for wit.com lookupNS(me.domainname.S) log.Println("updateDNS() END") } func suggestProcDebugging() { if (me.fixProc != nil) { // me.fixProc.Disable() return } me.fixProc = me.mainStatus.NewButton("Try debugging Slow DNS lookups", func () { debug("You're DNS lookups are very slow") me.dbOn.Set(true) me.dbProc.Set(true) DEBUGON = true LogProc = true processName := getProcessNameByPort(53) log.Println("Process with port 53:", processName) }) // me.fixProc.Disable() }