2015-01-13 15:13:43 +00:00
|
|
|
/*
|
|
|
|
This file is part of go-ethereum
|
|
|
|
|
|
|
|
go-ethereum is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
go-ethereum is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2014-10-21 11:24:48 +00:00
|
|
|
package rpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
2015-01-25 20:50:43 +00:00
|
|
|
"github.com/ethereum/go-ethereum/logger"
|
2014-10-21 11:24:48 +00:00
|
|
|
"io"
|
2015-01-13 05:25:29 +00:00
|
|
|
"net/http"
|
2014-10-21 11:24:48 +00:00
|
|
|
)
|
|
|
|
|
2015-01-25 20:50:43 +00:00
|
|
|
var rpclogger = logger.NewLogger("RPC")
|
2014-10-21 11:24:48 +00:00
|
|
|
|
2015-01-25 20:50:43 +00:00
|
|
|
type JsonWrapper struct{}
|
|
|
|
|
|
|
|
func (self JsonWrapper) Send(writer io.Writer, v interface{}) (n int, err error) {
|
2014-10-21 11:24:48 +00:00
|
|
|
var payload []byte
|
|
|
|
payload, err = json.Marshal(v)
|
|
|
|
if err != nil {
|
2015-01-25 20:50:43 +00:00
|
|
|
rpclogger.Fatalln("Error marshalling JSON", err)
|
2014-10-21 11:24:48 +00:00
|
|
|
return 0, err
|
|
|
|
}
|
2015-01-25 20:50:43 +00:00
|
|
|
rpclogger.Infof("Sending payload: %s", payload)
|
2014-10-21 11:24:48 +00:00
|
|
|
|
|
|
|
return writer.Write(payload)
|
|
|
|
}
|
|
|
|
|
2015-01-25 20:50:43 +00:00
|
|
|
func (self JsonWrapper) ParseRequestBody(req *http.Request) (RpcRequest, error) {
|
2015-01-13 05:25:29 +00:00
|
|
|
var reqParsed RpcRequest
|
|
|
|
|
|
|
|
// Convert JSON to native types
|
|
|
|
d := json.NewDecoder(req.Body)
|
|
|
|
// d.UseNumber()
|
|
|
|
defer req.Body.Close()
|
|
|
|
err := d.Decode(&reqParsed)
|
|
|
|
|
|
|
|
if err != nil {
|
2015-01-25 20:50:43 +00:00
|
|
|
rpclogger.Errorln("Error decoding JSON: ", err)
|
2015-01-13 05:25:29 +00:00
|
|
|
return reqParsed, err
|
|
|
|
}
|
2015-01-25 20:50:43 +00:00
|
|
|
rpclogger.DebugDetailf("Parsed request: %s", reqParsed)
|
2015-01-13 05:25:29 +00:00
|
|
|
|
|
|
|
return reqParsed, nil
|
|
|
|
}
|