kappanhang/main.go
2020-10-26 09:44:12 +01:00

110 lines
1.9 KiB
Go

package main
import (
"os"
"os/signal"
"strings"
"syscall"
"time"
)
var gitTag string
var gitHash string
var gotErrChan = make(chan bool)
func getAboutStr() string {
var v string
if gitTag != "" {
v = gitTag
} else if gitHash != "" {
v = gitTag
} else {
v = "debug"
}
return "kappanhang " + v + " by Norbert Varga HA2NON and Akos Marton ES1AKOS https://github.com/nonoo/kappanhang"
}
func runControlStream(osSignal chan os.Signal) (shouldExit bool, exitCode int) {
// Depleting gotErrChan.
var finished bool
for !finished {
select {
case <-gotErrChan:
default:
finished = true
}
}
c := controlStream{}
if err := c.init(); err != nil {
log.Error(err)
c.deinit()
return false, 0
}
select {
case <-gotErrChan:
c.deinit()
// Need to wait before reinit because the IC-705 will disconnect our audio stream eventually if we relogin
// in a too short interval without a deauth...
t := time.NewTicker(time.Second)
for sec := 65; sec > 0; sec-- {
log.Print("waiting ", sec, " seconds...")
select {
case <-t.C:
case <-osSignal:
return true, 0
}
}
return
case <-osSignal:
log.Print("sigterm received")
c.deinit()
return true, 0
}
}
func reportError(err error) {
if !strings.Contains(err.Error(), "use of closed network connection") {
log.ErrorC(log.GetCallerFileName(true), ": ", err)
}
// Non-blocking notify.
select {
case gotErrChan <- false:
default:
}
}
func main() {
parseArgs()
log.Init()
log.Print(getAboutStr())
osSignal := make(chan os.Signal, 1)
signal.Notify(osSignal, os.Interrupt, syscall.SIGTERM)
var shouldExit bool
var exitCode int
for !shouldExit {
shouldExit, exitCode = runControlStream(osSignal)
select {
case <-osSignal:
log.Print("sigterm received")
shouldExit = true
default:
}
if !shouldExit {
log.Print("restarting control stream...")
}
}
log.Print("exiting")
os.Exit(exitCode)
}