summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2024-02-01 08:49:16 -0600
committerJeff Carr <[email protected]>2024-02-01 08:49:16 -0600
commita26018c86d16e2e70459b4a10e00b0cf024aaba8 (patch)
treeb86d55f3234a9e4cf7abe5422dd7846b89341655
parent78927ede5d11c86c27de7eab91d67941c1444d18 (diff)
works within 30 seconds
Signed-off-by: Jeff Carr <[email protected]>
-rw-r--r--digStatus.go19
-rw-r--r--gui.go118
-rw-r--r--main.go24
-rw-r--r--resolverBox.go5
-rw-r--r--structs.go1
5 files changed, 78 insertions, 89 deletions
diff --git a/digStatus.go b/digStatus.go
index 15912ea..5722f47 100644
--- a/digStatus.go
+++ b/digStatus.go
@@ -336,3 +336,22 @@ func (ds *digStatus) Hide() {
}
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")
+ }
+ }
+ }
+}
diff --git a/gui.go b/gui.go
index d3833d9..be689f7 100644
--- a/gui.go
+++ b/gui.go
@@ -15,63 +15,65 @@ import (
)
// This setups up the dns control panel window
-func setupControlPanelWindow() {
+func setupControlPanelWindow(title string) {
log.Info("artificial sleep of:", me.artificialSleep)
log.Sleep(me.artificialSleep)
// setup the main tab
- mainWindow("DNS and IPv6 Control Panel")
- debugTab("Debug")
- me.window.Show()
+ me.window = gadgets.NewBasicWindow(me.myGui, title)
+ me.window.Vertical()
+ 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) {
- var g2 *gui.Node
+ // var g2 *gui.Node
me.debug = gadgets.NewBasicWindow(me.myGui, title)
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()
})
- 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:")
})
- g2 = me.debug.Box().NewGroup("debugging options")
- gridP := g2.NewGrid("nuts", 2, 1)
+ group = me.debug.Box().NewGroup("debugging options")
+ grid := group.NewGrid("nuts", 2, 1)
// 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)
// 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)
- gridP.NewLabel("dns resolution")
- me.DnsSpeed = gridP.NewLabel("unknown")
-
- gridP.NewLabel("dns resolution speed")
- me.DnsSpeedActual = gridP.NewLabel("unknown")
+ grid.NewLabel("dns resolution")
+ me.DnsSpeed = grid.NewLabel("unknown")
- gridP.NewLabel("Test speed")
- newGrid := gridP.NewGrid("nuts", 2, 1).Pad()
+ grid.NewLabel("dns resolution speed")
+ me.DnsSpeedActual = grid.NewLabel("unknown")
- g2.Margin()
- g2.Pad()
+ grid.NewLabel("Test speed")
+ newGrid := grid.NewGrid("nuts", 2, 1).Pad()
newGrid.NewLabel("ping.wit.com =")
newGrid.NewLabel("unknown")
newGrid.NewLabel("ping6.wit.com =")
newGrid.NewLabel("unknown")
-
- me.debug.Hide()
}
func myDefaultExit(n *gui.Node) {
@@ -79,85 +81,71 @@ func myDefaultExit(n *gui.Node) {
os.Exit(0)
}
-func mainWindow(title string) {
- me.window = gadgets.NewBasicWindow(me.myGui, title)
- me.window.Vertical()
- me.window.Make()
- me.window.Draw()
+func makeMainWindow() {
+ if me.window == nil {
+ return
+ }
hbox := me.window.Box().NewBox("bw hbox", true)
statusGrid(hbox)
// some artificial padding to make the last row of buttons look less wierd
- gr := hbox.NewGroup("Development and Debugging Windows")
- gr = gr.NewBox("vbox", false)
+ group := hbox.NewGroup("Development and Debugging Windows")
- gr.NewButton("Debug", func() {
+ group.NewButton("Debug", func() {
me.debug.Toggle()
})
- gr.NewButton("Logging Settings", func() {
+ group.NewButton("Logging Settings", func() {
logsettings.LogWindow()
})
- gr.NewButton("test smartwindow()", func() {
- if me.fixWindow == nil {
- me.fixWindow = gadgets.NewBasicWindow(me.myGui, "smart window test")
- me.fixWindow.Make()
- me.fixWindow.Draw()
- return
+ me.showErrorsB = group.NewCheckbox("Show Errors").SetChecked(true)
+ me.showErrorsB.Custom = func() {
+ if me.showErrorsB.Checked() {
+ me.problems.Show()
+ } else {
+ me.problems.Hide()
}
- me.fixWindow.Toggle()
- })
+ }
- gr.NewButton("Show Errors", func() {
- me.problems.Toggle()
- })
- me.autofix = gr.NewCheckbox("Auto-correct Errors")
+ me.autofix = group.NewCheckbox("Auto-correct Errors")
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) {
problems := n.NewGroup("status")
- problems.Margin()
- problems.Pad()
- gridP := problems.NewGrid("nuts", 3, 1)
- gridP.Margin()
- gridP.Pad()
+ grid := problems.NewGrid("nuts", 3, 1)
- gridP.NewLabel("hostname =")
- me.hostnameStatus = gridP.NewLabel("invalid")
- gridP.NewButton("Linux Status", func() {
+ grid.NewLabel("hostname =")
+ me.hostnameStatus = grid.NewLabel("invalid")
+ grid.NewButton("Linux Status", func() {
me.statusOS.Toggle()
})
- me.statusIPv6 = gadgets.NewOneLiner(gridP, "DNS Lookup")
+ me.statusIPv6 = gadgets.NewOneLiner(grid, "DNS Lookup")
me.statusIPv6.SetText("known")
- gridP.NewButton("resolver status", func() {
+ grid.NewButton("resolver status", func() {
if !me.digStatus.Ready() {
return
}
me.digStatus.window.Toggle()
})
- gridP.NewLabel("DNS Status")
- me.DnsStatus = gridP.NewLabel("unknown")
- me.statusDNSbutton = gridP.NewButton("hostname status", func() {
+ grid.NewLabel("DNS Status")
+ me.DnsStatus = grid.NewLabel("unknown")
+ me.statusDNSbutton = grid.NewButton("hostname status", func() {
if !me.statusDNS.Ready() {
return
}
me.statusDNS.window.Toggle()
})
- gridP.NewLabel("DNS API")
- me.DnsAPIstatus = gridP.NewLabel("unknown")
- me.apiButton = gridP.NewButton("unknown wit.com", func() {
+ grid.NewLabel("DNS API")
+ me.DnsAPIstatus = grid.NewLabel("unknown")
+ me.apiButton = grid.NewButton("unknown wit.com", func() {
log.Log(CHANGE, "WHAT API ARE YOU USING?")
provider := me.statusDNS.GetDNSapi()
if provider == "cloudflare" {
diff --git a/main.go b/main.go
index 0a89fe9..0fba361 100644
--- a/main.go
+++ b/main.go
@@ -47,9 +47,10 @@ func main() {
// log.Sleep(me.artificialSleep)
// setupControlPanelWindow()
// setup the main tab
- mainWindow("DNS and IPv6 Control Panel")
+ setupControlPanelWindow("DNS and IPv6 Control Panel")
debugTab("Debug")
- me.window.Show()
+
+ // TODO: track this bug down
log.Sleep(1)
me.window.Toggle()
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)
go myTicker(60*time.Second, "DNSloop", func() {
- 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")
- }
- }
- }
+ digLoop()
})
// checks if your DNS records are still broken
diff --git a/resolverBox.go b/resolverBox.go
index 8959a95..e285192 100644
--- a/resolverBox.go
+++ b/resolverBox.go
@@ -95,11 +95,6 @@ func NewResolverStatus(p *gui.Node, title string, server string, hostname string
rs.aaaaSuccess = rs.grid.NewLabel("?")
rs.aaaaFail = rs.grid.NewLabel("?")
- rs.group.Margin()
- rs.grid.Margin()
- rs.group.Pad()
- rs.grid.Pad()
-
return rs
}
diff --git a/structs.go b/structs.go
index f3fad50..99a97e7 100644
--- a/structs.go
+++ b/structs.go
@@ -63,6 +63,7 @@ type Host struct {
witcom *gadgets.BasicWindow
fixButton *gui.Node
fixWindow *gadgets.BasicWindow
+ showErrorsB *gui.Node
problems *errorBox
autofix *gui.Node