2019-12-28 21:07:03 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"net"
|
|
|
|
"sync"
|
|
|
|
)
|
|
|
|
|
|
|
|
type udpListener struct {
|
|
|
|
nconn *net.UDPConn
|
|
|
|
logPrefix string
|
2019-12-29 00:05:25 +00:00
|
|
|
cb func([]byte)
|
2019-12-28 21:07:03 +00:00
|
|
|
}
|
|
|
|
|
2019-12-29 00:05:25 +00:00
|
|
|
func newUdpListener(port int, logPrefix string, cb func([]byte)) (*udpListener, error) {
|
2019-12-28 21:07:03 +00:00
|
|
|
nconn, err := net.ListenUDP("udp", &net.UDPAddr{
|
|
|
|
Port: port,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
l := &udpListener{
|
|
|
|
nconn: nconn,
|
|
|
|
logPrefix: logPrefix,
|
|
|
|
cb: cb,
|
|
|
|
}
|
|
|
|
|
|
|
|
l.log("opened on :%d", port)
|
|
|
|
return l, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *udpListener) log(format string, args ...interface{}) {
|
|
|
|
log.Printf("["+l.logPrefix+" listener] "+format, args...)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l *udpListener) run(wg sync.WaitGroup) {
|
|
|
|
defer wg.Done()
|
|
|
|
|
|
|
|
buf := make([]byte, 2048) // UDP MTU is 1400
|
|
|
|
|
|
|
|
for {
|
|
|
|
n, _, err := l.nconn.ReadFromUDP(buf)
|
|
|
|
if err != nil {
|
|
|
|
l.log("ERR: %s", err)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
2019-12-29 00:05:25 +00:00
|
|
|
l.cb(buf[:n])
|
2019-12-28 21:07:03 +00:00
|
|
|
}
|
|
|
|
}
|