wireguard-go/src/main.go

48 lines
694 B
Go
Raw Normal View History

package main
2017-06-26 11:14:02 +00:00
import (
"fmt"
"log"
"net"
"os"
2017-06-26 11:14:02 +00:00
)
/* TODO: Fix logging
* TODO: Fix daemon
*/
func main() {
if len(os.Args) != 2 {
return
}
deviceName := os.Args[1]
2017-07-10 15:20:43 +00:00
// open TUN device
tun, err := CreateTUN(deviceName)
log.Println(tun, err)
if err != nil {
return
}
device := NewDevice(tun, LogLevelDebug)
2017-07-10 15:20:43 +00:00
device.log.Info.Println("Starting device")
2017-07-10 15:20:43 +00:00
// start configuration lister
socketPath := fmt.Sprintf("/var/run/wireguard/%s.sock", deviceName)
l, err := net.Listen("unix", socketPath)
if err != nil {
log.Fatal("listen error:", err)
}
for {
conn, err := l.Accept()
if err != nil {
log.Fatal("accept error:", err)
}
go ipcHandle(device, conn)
}
}