go-ethereum/rpc/comms/ipc_unix.go

80 lines
2.2 KiB
Go
Raw Normal View History

2015-07-06 19:54:22 -05:00
// Copyright 2015 The go-ethereum Authors
// This file is part of the go-ethereum library.
2015-07-06 19:54:22 -05:00
//
// go-ethereum is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// The go-ethereum library is distributed in the hope that it will be useful,
2015-07-06 19:54:22 -05:00
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2015-07-06 19:54:22 -05:00
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
2015-07-06 19:54:22 -05:00
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
}