rpc/client: separate out http-related functionality

This commit is contained in:
Roman Khimov 2020-04-29 18:39:24 +03:00
parent 38f9b511ae
commit 6333060897

View file

@ -145,47 +145,57 @@ func (c *Client) CalculateInputs(address string, asset util.Uint256, cost util.F
} }
func (c *Client) performRequest(method string, p request.RawParams, v interface{}) error { func (c *Client) performRequest(method string, p request.RawParams, v interface{}) error {
var ( var r = request.Raw{
r = request.Raw{
JSONRPC: request.JSONRPCVersion, JSONRPC: request.JSONRPCVersion,
Method: method, Method: method,
RawParams: p.Values, RawParams: p.Values,
ID: 1, ID: 1,
} }
raw, err := c.makeHTTPRequest(&r)
if raw != nil && raw.Error != nil {
return raw.Error
} else if err != nil {
return err
}
return json.Unmarshal(raw.Result, v)
}
func (c *Client) makeHTTPRequest(r *request.Raw) (*response.Raw, error) {
var (
buf = new(bytes.Buffer) buf = new(bytes.Buffer)
raw = &response.Raw{} raw = new(response.Raw)
) )
if err := json.NewEncoder(buf).Encode(r); err != nil { if err := json.NewEncoder(buf).Encode(r); err != nil {
return err return nil, err
} }
req, err := http.NewRequest("POST", c.endpoint.String(), buf) req, err := http.NewRequest("POST", c.endpoint.String(), buf)
if err != nil { if err != nil {
return err return nil, err
} }
resp, err := c.cli.Do(req) resp, err := c.cli.Do(req)
if err != nil { if err != nil {
return err return nil, err
} }
defer resp.Body.Close() defer resp.Body.Close()
// The node might send us proper JSON anyway, so look there first and if // The node might send us proper JSON anyway, so look there first and if
// it parses, then it has more relevant data than HTTP error code. // it parses, then it has more relevant data than HTTP error code.
err = json.NewDecoder(resp.Body).Decode(raw) err = json.NewDecoder(resp.Body).Decode(raw)
if err == nil { if err != nil {
if raw.Error != nil { if resp.StatusCode != http.StatusOK {
err = raw.Error
} else {
err = json.Unmarshal(raw.Result, v)
}
} else if resp.StatusCode != http.StatusOK {
err = fmt.Errorf("HTTP %d/%s", resp.StatusCode, http.StatusText(resp.StatusCode)) err = fmt.Errorf("HTTP %d/%s", resp.StatusCode, http.StatusText(resp.StatusCode))
} else { } else {
err = errors.Wrap(err, "JSON decoding") err = errors.Wrap(err, "JSON decoding")
} }
}
return err if err != nil {
return nil, err
}
return raw, nil
} }
// Ping attempts to create a connection to the endpoint. // Ping attempts to create a connection to the endpoint.