forked from TrueCloudLab/neoneo-go
rpc/client: separate out http-related functionality
This commit is contained in:
parent
6d202ad4c5
commit
a458a17748
1 changed files with 30 additions and 20 deletions
|
@ -160,47 +160,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.
|
||||||
|
|
Loading…
Reference in a new issue