package ipc import ( "errors" "net" "net/http" "net/rpc" "os" "github.com/tim-beatham/wgmesh/pkg/ctrlserver" ) type NewMeshArgs struct { // IfName is the interface that the mesh instance will run on IfName string // WgPort is the WireGuard port to expose WgPort int // Endpoint is the routable alias of the machine. Can be an IP // or DNS entry Endpoint string } type JoinMeshArgs struct { // MeshId is the ID of the mesh to join MeshId string // IpAddress is a routable IP in another mesh IpAdress string // IfName is the interface name of the mesh IfName string // Port is the WireGuard port to expose Port int // Endpoint is the routable address of this machine. If not provided // defaults to the default address Endpoint string } type GetMeshReply struct { Nodes []ctrlserver.MeshNode } type ListMeshReply struct { Meshes []string } type QueryMesh struct { MeshId string Query string } type MeshIpc interface { CreateMesh(args *NewMeshArgs, reply *string) error ListMeshes(name string, reply *ListMeshReply) error JoinMesh(args JoinMeshArgs, reply *string) error LeaveMesh(meshId string, reply *string) error GetMesh(meshId string, reply *GetMeshReply) error EnableInterface(meshId string, reply *string) error GetDOT(meshId string, reply *string) error Query(query QueryMesh, reply *string) error PutDescription(description string, reply *string) error } const SockAddr = "/tmp/wgmesh_ipc.sock" func RunIpcHandler(server MeshIpc) error { if err := os.RemoveAll(SockAddr); err != nil { return errors.New("could not find to address") } rpc.Register(server) rpc.HandleHTTP() l, e := net.Listen("unix", SockAddr) if e != nil { return e } http.Serve(l, nil) return nil }