control-panel-dns/main.go

112 lines
2.1 KiB
Go
Raw Normal View History

// GNU GENERAL PUBLIC LICENSE Version 3, 29 June 2007
// Copyright (c) 2023 WIT.COM, Inc.
// This is a control panel for DNS
2023-02-08 11:04:04 -06:00
package main
import (
"strconv"
"runtime"
"time"
2023-02-08 11:04:04 -06:00
arg "github.com/alexflint/go-arg"
"git.wit.org/wit/gui"
2023-02-08 11:04:04 -06:00
)
var p *arg.Parser
var myGui *gui.Node
2023-02-08 11:04:04 -06:00
func main() {
p = arg.MustParse(&args)
parsedown()
// initialize the maps to track IP addresses and network interfaces
me.ipmap = make(map[string]*IPtype)
me.dnsmap = make(map[string]*IPtype)
me.ifmap = make(map[int]*IFtype)
me.dnsTTL = 5 // recheck DNS is working every 2 minutes // TODO: watch rx packets?
log()
log(true, "this is true")
log(false, "this is false")
sleep(.4)
sleep(.3)
sleep(.2)
sleep("done scanning net")
// Example_listLink()
log("Toolkit = ", args.Toolkit)
for i, t := range args.Toolkit {
log("trying to load plugin", i, t)
myGui.LoadToolkit(t)
}
// will set all debugging flags
gui.SetDebug(true)
myGui = gui.New().LoadToolkit("gocui")
sleep(1)
setupControlPanelWindow()
sleep(1)
// sleep(1)
if (args.GuiDebug) {
gui.DebugWindow()
}
gui.ShowDebugValues()
go gui.Watchdog()
// forever monitor for network and dns changes
checkNetworkChanges()
}
/*
Poll for changes to the networking settings
*/
func checkNetworkChanges() {
var ttl int = 0
var ttlsleep int = 5
for {
sleep(ttlsleep)
ttl -= 1
if (ttl < 0) {
if (runtime.GOOS == "linux") {
dnsTTL()
} else {
log("Windows and MacOS don't work yet")
}
ttl = me.dnsTTL
}
}
}
// This checks for changes to the network settings
// and verifies that DNS is working or not working
func dnsTTL() {
me.changed = false
log("FQDN =", me.fqdn.GetText())
getHostname()
scanInterfaces()
for i, t := range me.ifmap {
log(strconv.Itoa(i) + " iface = " + t.iface.Name)
}
var aaaa []string
aaaa = realAAAA()
var all string
for _, s := range aaaa {
log("my actual AAAA = ",s)
all += s + "\n"
}
// me.IPv6.SetText(all)
if (me.changed) {
stamp := time.Now().Format("2006/01/02 15:04:05")
s := stamp + " Network things changed"
log(logError, "Network things changed on", stamp)
updateDNS()
me.output.SetText(s)
}
}