http.go 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. package rpc
  2. import (
  3. "net/http"
  4. "github.com/ethereum/go-ethereum/logger"
  5. "github.com/ethereum/go-ethereum/xeth"
  6. )
  7. var rpchttplogger = logger.NewLogger("RPC-HTTP")
  8. // JSONRPC returns a handler that implements the Ethereum JSON-RPC API.
  9. func JSONRPC(pipe *xeth.XEth, dataDir string) http.Handler {
  10. var json JsonWrapper
  11. const jsonrpcver = "2.0"
  12. api := NewEthereumApi(pipe, dataDir)
  13. return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
  14. w.Header().Set("Access-Control-Allow-Origin", "*")
  15. rpchttplogger.DebugDetailln("Handling request")
  16. reqParsed, reqerr := json.ParseRequestBody(req)
  17. if reqerr != nil {
  18. jsonerr := &RpcErrorObject{-32700, "Error: Could not parse request"}
  19. json.Send(w, &RpcErrorResponse{JsonRpc: jsonrpcver, ID: nil, Error: jsonerr})
  20. return
  21. }
  22. var response interface{}
  23. reserr := api.GetRequestReply(&reqParsed, &response)
  24. if reserr != nil {
  25. rpchttplogger.Warnln(reserr)
  26. jsonerr := &RpcErrorObject{-32603, reserr.Error()}
  27. json.Send(w, &RpcErrorResponse{JsonRpc: jsonrpcver, ID: reqParsed.ID, Error: jsonerr})
  28. return
  29. }
  30. rpchttplogger.DebugDetailf("Generated response: %T %s", response, response)
  31. json.Send(w, &RpcSuccessResponse{JsonRpc: jsonrpcver, ID: reqParsed.ID, Result: response})
  32. })
  33. }