5
0
mirror of https://github.com/cwinfo/yggdrasil-go.git synced 2024-12-01 20:41:45 +00:00

Merge pull request #154 from neilalexander/unixsockets

Add support for UNIX domain admin sockets
This commit is contained in:
Arceliar 2018-07-07 14:28:40 -05:00 committed by GitHub
commit face270298
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 44 additions and 7 deletions

View File

@ -22,6 +22,7 @@ import (
type admin struct { type admin struct {
core *Core core *Core
listenaddr string listenaddr string
listener net.Listener
handlers []admin_handlerInfo handlers []admin_handlerInfo
} }
@ -229,17 +230,36 @@ func (a *admin) start() error {
return nil return nil
} }
// cleans up when stopping
func (a *admin) close() error {
return a.listener.Close()
}
// listen is run by start and manages API connections. // listen is run by start and manages API connections.
func (a *admin) listen() { func (a *admin) listen() {
l, err := net.Listen("tcp", a.listenaddr) u, err := url.Parse(a.listenaddr)
if err == nil {
switch strings.ToLower(u.Scheme) {
case "unix":
a.listener, err = net.Listen("unix", a.listenaddr[7:])
case "tcp":
a.listener, err = net.Listen("tcp", u.Host)
default:
err = errors.New("protocol not supported")
}
} else {
a.listener, err = net.Listen("tcp", a.listenaddr)
}
if err != nil { if err != nil {
a.core.log.Printf("Admin socket failed to listen: %v", err) a.core.log.Printf("Admin socket failed to listen: %v", err)
os.Exit(1) os.Exit(1)
} }
defer l.Close() a.core.log.Printf("%s admin socket listening on %s",
a.core.log.Printf("Admin socket listening on %s", l.Addr().String()) strings.ToUpper(a.listener.Addr().Network()),
a.listener.Addr().String())
defer a.listener.Close()
for { for {
conn, err := l.Accept() conn, err := a.listener.Accept()
if err == nil { if err == nil {
a.handleRequest(conn) a.handleRequest(conn)
} }

View File

@ -136,6 +136,7 @@ func (c *Core) Start(nc *config.NodeConfig, log *log.Logger) error {
func (c *Core) Stop() { func (c *Core) Stop() {
c.log.Println("Stopping...") c.log.Println("Stopping...")
c.tun.close() c.tun.close()
c.admin.close()
} }
// Generates a new encryption keypair. The encryption keys are used to // Generates a new encryption keypair. The encryption keys are used to

View File

@ -1,9 +1,11 @@
package main package main
import "errors"
import "flag" import "flag"
import "fmt" import "fmt"
import "strings" import "strings"
import "net" import "net"
import "net/url"
import "sort" import "sort"
import "encoding/json" import "encoding/json"
import "strconv" import "strconv"
@ -20,14 +22,28 @@ func main() {
args := flag.Args() args := flag.Args()
if len(args) == 0 { if len(args) == 0 {
fmt.Println("usage:", os.Args[0], "[-endpoint=localhost:9001] [-json] command [key=value] [...]") fmt.Println("usage:", os.Args[0], "[-endpoint=proto://server] [-json] command [key=value] [...]")
fmt.Println("example:", os.Args[0], "getPeers") fmt.Println("example:", os.Args[0], "getPeers")
fmt.Println("example:", os.Args[0], "setTunTap name=auto mtu=1500 tap_mode=false") fmt.Println("example:", os.Args[0], "setTunTap name=auto mtu=1500 tap_mode=false")
fmt.Println("example:", os.Args[0], "-endpoint=localhost:9001 getDHT") fmt.Println("example:", os.Args[0], "-endpoint=tcp://localhost:9001 getDHT")
fmt.Println("example:", os.Args[0], "-endpoint=unix:///var/run/ygg.sock getDHT")
return return
} }
conn, err := net.Dial("tcp", *server) var conn net.Conn
u, err := url.Parse(*server)
if err == nil {
switch strings.ToLower(u.Scheme) {
case "unix":
conn, err = net.Dial("unix", (*server)[7:])
case "tcp":
conn, err = net.Dial("tcp", u.Host)
default:
err = errors.New("protocol not supported")
}
} else {
conn, err = net.Dial("tcp", *server)
}
if err != nil { if err != nil {
panic(err) panic(err)
} }