aboutsummaryrefslogtreecommitdiffstats
path: root/ethrpc/server.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-05-05 21:55:43 +0800
committerobscuren <geffobscura@gmail.com>2014-05-05 21:55:43 +0800
commit2096b3a9edb3289a8f30da81704181dec7b39917 (patch)
tree1a38e845f32ecfc94a73546ec4cfdb971b740830 /ethrpc/server.go
parent6a86c517c4f4b372cad0ae1d92e926a482eac5ba (diff)
parentfedd4c906ff9f6139cb2d88e4f1adefbf6ea81a6 (diff)
downloadgo-tangerine-2096b3a9edb3289a8f30da81704181dec7b39917.tar.gz
go-tangerine-2096b3a9edb3289a8f30da81704181dec7b39917.tar.zst
go-tangerine-2096b3a9edb3289a8f30da81704181dec7b39917.zip
Merge branch 'release/poc5-rc1'
Diffstat (limited to 'ethrpc/server.go')
-rw-r--r--ethrpc/server.go62
1 files changed, 62 insertions, 0 deletions
diff --git a/ethrpc/server.go b/ethrpc/server.go
new file mode 100644
index 000000000..40787fade
--- /dev/null
+++ b/ethrpc/server.go
@@ -0,0 +1,62 @@
+package ethrpc
+
+import (
+ "github.com/ethereum/eth-go/ethpub"
+ "github.com/ethereum/eth-go/ethutil"
+ "net"
+ "net/rpc"
+ "net/rpc/jsonrpc"
+)
+
+type JsonRpcServer struct {
+ quit chan bool
+ listener net.Listener
+ ethp *ethpub.PEthereum
+}
+
+func (s *JsonRpcServer) exitHandler() {
+out:
+ for {
+ select {
+ case <-s.quit:
+ s.listener.Close()
+ break out
+ }
+ }
+
+ ethutil.Config.Log.Infoln("[JSON] Shutdown JSON-RPC server")
+}
+
+func (s *JsonRpcServer) Stop() {
+ close(s.quit)
+}
+
+func (s *JsonRpcServer) Start() {
+ ethutil.Config.Log.Infoln("[JSON] Starting JSON-RPC server")
+ go s.exitHandler()
+ rpc.Register(&EthereumApi{ethp: s.ethp})
+ rpc.HandleHTTP()
+
+ for {
+ conn, err := s.listener.Accept()
+ if err != nil {
+ ethutil.Config.Log.Infoln("[JSON] Error starting JSON-RPC:", err)
+ break
+ }
+ ethutil.Config.Log.Debugln("[JSON] Incoming request.")
+ go jsonrpc.ServeConn(conn)
+ }
+}
+
+func NewJsonRpcServer(ethp *ethpub.PEthereum) *JsonRpcServer {
+ l, err := net.Listen("tcp", ":30304")
+ if err != nil {
+ ethutil.Config.Log.Infoln("Error starting JSON-RPC")
+ }
+
+ return &JsonRpcServer{
+ listener: l,
+ quit: make(chan bool),
+ ethp: ethp,
+ }
+}