go-ethereum/rpc/comms/ipc_unix.go

64 lines
1.4 KiB
Go
Raw Normal View History

2015-06-08 03:41:04 -05:00
// +build darwin dragonfly freebsd linux nacl netbsd openbsd solaris
package comms
import (
"net"
2015-06-09 02:48:18 -05:00
"os"
2015-06-08 03:41:04 -05:00
"github.com/ethereum/go-ethereum/logger"
"github.com/ethereum/go-ethereum/logger/glog"
"github.com/ethereum/go-ethereum/rpc/codec"
2015-06-22 05:47:32 -05:00
"github.com/ethereum/go-ethereum/rpc/shared"
2015-06-08 03:41:04 -05:00
)
func newIpcClient(cfg IpcConfig, codec codec.Codec) (*ipcClient, error) {
c, err := net.DialUnix("unix", nil, &net.UnixAddr{cfg.Endpoint, "unix"})
if err != nil {
return nil, err
}
2015-06-25 06:18:10 -05:00
return &ipcClient{cfg.Endpoint, c, codec, codec.New(c)}, nil
2015-06-18 11:23:13 -05:00
}
func (self *ipcClient) reconnect() error {
self.coder.Close()
c, err := net.DialUnix("unix", nil, &net.UnixAddr{self.endpoint, "unix"})
if err == nil {
self.coder = self.codec.New(c)
}
return err
2015-06-08 03:41:04 -05:00
}
2015-06-22 05:47:32 -05:00
func startIpc(cfg IpcConfig, codec codec.Codec, api shared.EthereumApi) error {
2015-06-08 03:41:04 -05:00
os.Remove(cfg.Endpoint) // in case it still exists from a previous run
l, err := net.ListenUnix("unix", &net.UnixAddr{Name: cfg.Endpoint, Net: "unix"})
if err != nil {
return err
}
os.Chmod(cfg.Endpoint, 0600)
go func() {
for {
conn, err := l.AcceptUnix()
if err != nil {
glog.V(logger.Error).Infof("Error accepting ipc connection - %v\n", err)
continue
}
id := newIpcConnId()
glog.V(logger.Debug).Infof("New IPC connection with id %06d started\n", id)
go handle(id, conn, api, codec)
2015-06-08 03:41:04 -05:00
}
os.Remove(cfg.Endpoint)
}()
2015-06-09 02:48:18 -05:00
glog.V(logger.Info).Infof("IPC service started (%s)\n", cfg.Endpoint)
2015-06-08 03:41:04 -05:00
return nil
}