works within 30 seconds
Signed-off-by: Jeff Carr <jcarr@wit.com>
This commit is contained in:
parent
78927ede5d
commit
a26018c86d
19
digStatus.go
19
digStatus.go
|
@ -336,3 +336,22 @@ func (ds *digStatus) Hide() {
|
||||||
}
|
}
|
||||||
me.digStatus.hidden = true
|
me.digStatus.hidden = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func digLoop() {
|
||||||
|
me.digStatus.Update()
|
||||||
|
|
||||||
|
if me.digStatus.Ready() {
|
||||||
|
current := me.statusIPv6.String()
|
||||||
|
if me.digStatus.IPv6() {
|
||||||
|
if current != "WORKING" {
|
||||||
|
log.Log(CHANGE, "IPv6 resolution is WORKING")
|
||||||
|
me.statusIPv6.SetText("WORKING")
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if current != "Need VPN" {
|
||||||
|
log.Log(CHANGE, "IPv6 resolution seems to have broken")
|
||||||
|
me.statusIPv6.SetText("Need VPN")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
118
gui.go
118
gui.go
|
@ -15,63 +15,65 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
// This setups up the dns control panel window
|
// This setups up the dns control panel window
|
||||||
func setupControlPanelWindow() {
|
func setupControlPanelWindow(title string) {
|
||||||
log.Info("artificial sleep of:", me.artificialSleep)
|
log.Info("artificial sleep of:", me.artificialSleep)
|
||||||
log.Sleep(me.artificialSleep)
|
log.Sleep(me.artificialSleep)
|
||||||
|
|
||||||
// setup the main tab
|
// setup the main tab
|
||||||
mainWindow("DNS and IPv6 Control Panel")
|
me.window = gadgets.NewBasicWindow(me.myGui, title)
|
||||||
debugTab("Debug")
|
me.window.Vertical()
|
||||||
me.window.Show()
|
me.window.Make()
|
||||||
|
|
||||||
|
makeMainWindow()
|
||||||
|
|
||||||
|
// These are your problems
|
||||||
|
me.problems = NewErrorBox(me.window.Box(), "Errors", "has problems?")
|
||||||
|
me.problems.addIPerror(RR, USER, "1:1:1:1")
|
||||||
|
|
||||||
|
me.window.Draw()
|
||||||
}
|
}
|
||||||
|
|
||||||
func debugTab(title string) {
|
func debugTab(title string) {
|
||||||
var g2 *gui.Node
|
// var g2 *gui.Node
|
||||||
|
|
||||||
me.debug = gadgets.NewBasicWindow(me.myGui, title)
|
me.debug = gadgets.NewBasicWindow(me.myGui, title)
|
||||||
me.debug.Make()
|
me.debug.Make()
|
||||||
// me.debug.Draw()
|
|
||||||
|
|
||||||
g2 = me.debug.Box().NewGroup("Real Stuff")
|
group := me.debug.Box().NewGroup("Real Stuff")
|
||||||
|
|
||||||
g2.NewButton("GO GUI Debug Window", func() {
|
group.NewButton("GO GUI Debug Window", func() {
|
||||||
debugger.DebugWindow()
|
debugger.DebugWindow()
|
||||||
})
|
})
|
||||||
|
|
||||||
g2.NewButton("dig A & AAAA DNS records (updateDNS())", func() {
|
group.NewButton("dig A & AAAA DNS records (updateDNS())", func() {
|
||||||
log.Log(CHANGE, "updateDNS() going to run:")
|
log.Log(CHANGE, "updateDNS() going to run:")
|
||||||
})
|
})
|
||||||
|
|
||||||
g2 = me.debug.Box().NewGroup("debugging options")
|
group = me.debug.Box().NewGroup("debugging options")
|
||||||
gridP := g2.NewGrid("nuts", 2, 1)
|
grid := group.NewGrid("nuts", 2, 1)
|
||||||
|
|
||||||
// makes a slider widget
|
// makes a slider widget
|
||||||
me.ttl = gadgets.NewDurationSlider(gridP, "Loop Timeout", 10*time.Millisecond, 5*time.Second)
|
me.ttl = gadgets.NewDurationSlider(grid, "Loop Timeout", 10*time.Millisecond, 5*time.Second)
|
||||||
me.ttl.Set(300 * time.Millisecond)
|
me.ttl.Set(300 * time.Millisecond)
|
||||||
|
|
||||||
// makes a slider widget
|
// makes a slider widget
|
||||||
me.dnsTtl = gadgets.NewDurationSlider(gridP, "DNS Timeout", 800*time.Millisecond, 300*time.Second)
|
me.dnsTtl = gadgets.NewDurationSlider(grid, "DNS Timeout", 800*time.Millisecond, 300*time.Second)
|
||||||
me.dnsTtl.Set(60 * time.Second)
|
me.dnsTtl.Set(60 * time.Second)
|
||||||
|
|
||||||
gridP.NewLabel("dns resolution")
|
grid.NewLabel("dns resolution")
|
||||||
me.DnsSpeed = gridP.NewLabel("unknown")
|
me.DnsSpeed = grid.NewLabel("unknown")
|
||||||
|
|
||||||
gridP.NewLabel("dns resolution speed")
|
grid.NewLabel("dns resolution speed")
|
||||||
me.DnsSpeedActual = gridP.NewLabel("unknown")
|
me.DnsSpeedActual = grid.NewLabel("unknown")
|
||||||
|
|
||||||
gridP.NewLabel("Test speed")
|
grid.NewLabel("Test speed")
|
||||||
newGrid := gridP.NewGrid("nuts", 2, 1).Pad()
|
newGrid := grid.NewGrid("nuts", 2, 1).Pad()
|
||||||
|
|
||||||
g2.Margin()
|
|
||||||
g2.Pad()
|
|
||||||
|
|
||||||
newGrid.NewLabel("ping.wit.com =")
|
newGrid.NewLabel("ping.wit.com =")
|
||||||
newGrid.NewLabel("unknown")
|
newGrid.NewLabel("unknown")
|
||||||
|
|
||||||
newGrid.NewLabel("ping6.wit.com =")
|
newGrid.NewLabel("ping6.wit.com =")
|
||||||
newGrid.NewLabel("unknown")
|
newGrid.NewLabel("unknown")
|
||||||
|
|
||||||
me.debug.Hide()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func myDefaultExit(n *gui.Node) {
|
func myDefaultExit(n *gui.Node) {
|
||||||
|
@ -79,85 +81,71 @@ func myDefaultExit(n *gui.Node) {
|
||||||
os.Exit(0)
|
os.Exit(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
func mainWindow(title string) {
|
func makeMainWindow() {
|
||||||
me.window = gadgets.NewBasicWindow(me.myGui, title)
|
if me.window == nil {
|
||||||
me.window.Vertical()
|
return
|
||||||
me.window.Make()
|
}
|
||||||
me.window.Draw()
|
|
||||||
|
|
||||||
hbox := me.window.Box().NewBox("bw hbox", true)
|
hbox := me.window.Box().NewBox("bw hbox", true)
|
||||||
|
|
||||||
statusGrid(hbox)
|
statusGrid(hbox)
|
||||||
|
|
||||||
// some artificial padding to make the last row of buttons look less wierd
|
// some artificial padding to make the last row of buttons look less wierd
|
||||||
gr := hbox.NewGroup("Development and Debugging Windows")
|
group := hbox.NewGroup("Development and Debugging Windows")
|
||||||
gr = gr.NewBox("vbox", false)
|
|
||||||
|
|
||||||
gr.NewButton("Debug", func() {
|
group.NewButton("Debug", func() {
|
||||||
me.debug.Toggle()
|
me.debug.Toggle()
|
||||||
})
|
})
|
||||||
|
|
||||||
gr.NewButton("Logging Settings", func() {
|
group.NewButton("Logging Settings", func() {
|
||||||
logsettings.LogWindow()
|
logsettings.LogWindow()
|
||||||
})
|
})
|
||||||
|
|
||||||
gr.NewButton("test smartwindow()", func() {
|
me.showErrorsB = group.NewCheckbox("Show Errors").SetChecked(true)
|
||||||
if me.fixWindow == nil {
|
me.showErrorsB.Custom = func() {
|
||||||
me.fixWindow = gadgets.NewBasicWindow(me.myGui, "smart window test")
|
if me.showErrorsB.Checked() {
|
||||||
me.fixWindow.Make()
|
me.problems.Show()
|
||||||
me.fixWindow.Draw()
|
} else {
|
||||||
return
|
me.problems.Hide()
|
||||||
}
|
}
|
||||||
me.fixWindow.Toggle()
|
}
|
||||||
})
|
|
||||||
|
|
||||||
gr.NewButton("Show Errors", func() {
|
me.autofix = group.NewCheckbox("Auto-correct Errors")
|
||||||
me.problems.Toggle()
|
|
||||||
})
|
|
||||||
me.autofix = gr.NewCheckbox("Auto-correct Errors")
|
|
||||||
me.autofix.SetChecked(false)
|
me.autofix.SetChecked(false)
|
||||||
|
|
||||||
// These are your problems
|
|
||||||
me.problems = NewErrorBox(me.window.Box(), "Errors", "has problems?")
|
|
||||||
me.problems.addIPerror(RR, USER, "1:1:1:1")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func statusGrid(n *gui.Node) {
|
func statusGrid(n *gui.Node) {
|
||||||
problems := n.NewGroup("status")
|
problems := n.NewGroup("status")
|
||||||
problems.Margin()
|
|
||||||
problems.Pad()
|
|
||||||
|
|
||||||
gridP := problems.NewGrid("nuts", 3, 1)
|
grid := problems.NewGrid("nuts", 3, 1)
|
||||||
gridP.Margin()
|
|
||||||
gridP.Pad()
|
|
||||||
|
|
||||||
gridP.NewLabel("hostname =")
|
grid.NewLabel("hostname =")
|
||||||
me.hostnameStatus = gridP.NewLabel("invalid")
|
me.hostnameStatus = grid.NewLabel("invalid")
|
||||||
gridP.NewButton("Linux Status", func() {
|
grid.NewButton("Linux Status", func() {
|
||||||
me.statusOS.Toggle()
|
me.statusOS.Toggle()
|
||||||
})
|
})
|
||||||
|
|
||||||
me.statusIPv6 = gadgets.NewOneLiner(gridP, "DNS Lookup")
|
me.statusIPv6 = gadgets.NewOneLiner(grid, "DNS Lookup")
|
||||||
me.statusIPv6.SetText("known")
|
me.statusIPv6.SetText("known")
|
||||||
gridP.NewButton("resolver status", func() {
|
grid.NewButton("resolver status", func() {
|
||||||
if !me.digStatus.Ready() {
|
if !me.digStatus.Ready() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
me.digStatus.window.Toggle()
|
me.digStatus.window.Toggle()
|
||||||
})
|
})
|
||||||
|
|
||||||
gridP.NewLabel("DNS Status")
|
grid.NewLabel("DNS Status")
|
||||||
me.DnsStatus = gridP.NewLabel("unknown")
|
me.DnsStatus = grid.NewLabel("unknown")
|
||||||
me.statusDNSbutton = gridP.NewButton("hostname status", func() {
|
me.statusDNSbutton = grid.NewButton("hostname status", func() {
|
||||||
if !me.statusDNS.Ready() {
|
if !me.statusDNS.Ready() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
me.statusDNS.window.Toggle()
|
me.statusDNS.window.Toggle()
|
||||||
})
|
})
|
||||||
|
|
||||||
gridP.NewLabel("DNS API")
|
grid.NewLabel("DNS API")
|
||||||
me.DnsAPIstatus = gridP.NewLabel("unknown")
|
me.DnsAPIstatus = grid.NewLabel("unknown")
|
||||||
me.apiButton = gridP.NewButton("unknown wit.com", func() {
|
me.apiButton = grid.NewButton("unknown wit.com", func() {
|
||||||
log.Log(CHANGE, "WHAT API ARE YOU USING?")
|
log.Log(CHANGE, "WHAT API ARE YOU USING?")
|
||||||
provider := me.statusDNS.GetDNSapi()
|
provider := me.statusDNS.GetDNSapi()
|
||||||
if provider == "cloudflare" {
|
if provider == "cloudflare" {
|
||||||
|
|
24
main.go
24
main.go
|
@ -47,9 +47,10 @@ func main() {
|
||||||
// log.Sleep(me.artificialSleep)
|
// log.Sleep(me.artificialSleep)
|
||||||
// setupControlPanelWindow()
|
// setupControlPanelWindow()
|
||||||
// setup the main tab
|
// setup the main tab
|
||||||
mainWindow("DNS and IPv6 Control Panel")
|
setupControlPanelWindow("DNS and IPv6 Control Panel")
|
||||||
debugTab("Debug")
|
debugTab("Debug")
|
||||||
me.window.Show()
|
|
||||||
|
// TODO: track this bug down
|
||||||
log.Sleep(1)
|
log.Sleep(1)
|
||||||
me.window.Toggle()
|
me.window.Toggle()
|
||||||
log.Sleep(1)
|
log.Sleep(1)
|
||||||
|
@ -67,26 +68,11 @@ func main() {
|
||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
log.Sleep(me.artificialSleep)
|
digLoop()
|
||||||
|
|
||||||
// TCP & UDP port 53 lookups + DNS over HTTP lookups + os.Exec(dig)
|
// TCP & UDP port 53 lookups + DNS over HTTP lookups + os.Exec(dig)
|
||||||
go myTicker(60*time.Second, "DNSloop", func() {
|
go myTicker(60*time.Second, "DNSloop", func() {
|
||||||
me.digStatus.Update()
|
digLoop()
|
||||||
|
|
||||||
if me.digStatus.Ready() {
|
|
||||||
current := me.statusIPv6.String()
|
|
||||||
if me.digStatus.IPv6() {
|
|
||||||
if current != "WORKING" {
|
|
||||||
log.Log(CHANGE, "IPv6 resolution is WORKING")
|
|
||||||
me.statusIPv6.SetText("WORKING")
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if current != "Need VPN" {
|
|
||||||
log.Log(CHANGE, "IPv6 resolution seems to have broken")
|
|
||||||
me.statusIPv6.SetText("Need VPN")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
|
|
||||||
// checks if your DNS records are still broken
|
// checks if your DNS records are still broken
|
||||||
|
|
|
@ -95,11 +95,6 @@ func NewResolverStatus(p *gui.Node, title string, server string, hostname string
|
||||||
rs.aaaaSuccess = rs.grid.NewLabel("?")
|
rs.aaaaSuccess = rs.grid.NewLabel("?")
|
||||||
rs.aaaaFail = rs.grid.NewLabel("?")
|
rs.aaaaFail = rs.grid.NewLabel("?")
|
||||||
|
|
||||||
rs.group.Margin()
|
|
||||||
rs.grid.Margin()
|
|
||||||
rs.group.Pad()
|
|
||||||
rs.grid.Pad()
|
|
||||||
|
|
||||||
return rs
|
return rs
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -63,6 +63,7 @@ type Host struct {
|
||||||
witcom *gadgets.BasicWindow
|
witcom *gadgets.BasicWindow
|
||||||
fixButton *gui.Node
|
fixButton *gui.Node
|
||||||
fixWindow *gadgets.BasicWindow
|
fixWindow *gadgets.BasicWindow
|
||||||
|
showErrorsB *gui.Node
|
||||||
|
|
||||||
problems *errorBox
|
problems *errorBox
|
||||||
autofix *gui.Node
|
autofix *gui.Node
|
||||||
|
|
Loading…
Reference in New Issue