2015-01-03 07:52:21 +01:00
|
|
|
// Copyright (c) 2014-2015 Conformal Systems LLC.
|
2014-06-10 02:49:41 +02:00
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package btcrpcclient
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"errors"
|
2014-07-03 02:33:54 +02:00
|
|
|
|
2014-06-10 02:49:41 +02:00
|
|
|
"github.com/conformal/btcjson"
|
|
|
|
)
|
|
|
|
|
|
|
|
// rawRequest satisifies the btcjson.Cmd interface for btcjson raw commands.
|
|
|
|
// This type exists here rather than making btcjson.RawCmd satisify the Cmd
|
|
|
|
// interface due to conflict between the Id and Method field names vs method
|
|
|
|
// names.
|
|
|
|
type rawRequest struct {
|
|
|
|
btcjson.RawCmd
|
|
|
|
}
|
|
|
|
|
|
|
|
// Enforce that rawRequest is a btcjson.Cmd.
|
|
|
|
var _ btcjson.Cmd = &rawRequest{}
|
|
|
|
|
|
|
|
// Id returns the JSON-RPC id of the request.
|
|
|
|
func (r *rawRequest) Id() interface{} {
|
|
|
|
return r.RawCmd.Id
|
|
|
|
}
|
|
|
|
|
|
|
|
// Method returns the method string of the request.
|
|
|
|
func (r *rawRequest) Method() string {
|
|
|
|
return r.RawCmd.Method
|
|
|
|
}
|
|
|
|
|
|
|
|
// MarshalJSON marshals the raw request as a JSON-RPC 1.0 object.
|
|
|
|
func (r *rawRequest) MarshalJSON() ([]byte, error) {
|
|
|
|
return json.Marshal(r.RawCmd)
|
|
|
|
}
|
|
|
|
|
|
|
|
// UnmarshalJSON unmarshals a JSON-RPC 1.0 object into the raw request.
|
|
|
|
func (r *rawRequest) UnmarshalJSON(b []byte) error {
|
|
|
|
return json.Unmarshal(b, &r.RawCmd)
|
|
|
|
}
|
|
|
|
|
|
|
|
// FutureRawResult is a future promise to deliver the result of a RawRequest RPC
|
|
|
|
// invocation (or an applicable error).
|
|
|
|
type FutureRawResult chan *response
|
|
|
|
|
|
|
|
// Receive waits for the response promised by the future and returns the raw
|
|
|
|
// response, or an error if the request was unsuccessful.
|
|
|
|
func (r FutureRawResult) Receive() (json.RawMessage, error) {
|
|
|
|
return receiveFuture(r)
|
|
|
|
}
|
|
|
|
|
|
|
|
// RawRequestAsync returns an instance of a type that can be used to get the
|
|
|
|
// result of a custom RPC request at some future time by invoking the Receive
|
|
|
|
// function on the returned instance.
|
|
|
|
//
|
|
|
|
// See RawRequest for the blocking version and more details.
|
|
|
|
func (c *Client) RawRequestAsync(method string, params []json.RawMessage) FutureRawResult {
|
|
|
|
// Method may not be empty.
|
|
|
|
if method == "" {
|
|
|
|
return newFutureError(errors.New("no method"))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Marshal parameters as "[]" instead of "null" when no parameters
|
|
|
|
// are passed.
|
|
|
|
if params == nil {
|
|
|
|
params = []json.RawMessage{}
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd := &rawRequest{
|
|
|
|
RawCmd: btcjson.RawCmd{
|
|
|
|
Jsonrpc: "1.0",
|
|
|
|
Id: c.NextID(),
|
|
|
|
Method: method,
|
|
|
|
Params: params,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
return c.sendCmd(cmd)
|
|
|
|
}
|
|
|
|
|
|
|
|
// RawRequest allows the caller to send a raw or custom request to the server.
|
|
|
|
// This method may be used to send and receive requests and responses for
|
|
|
|
// requests that are not handled by this client package, or to proxy partially
|
|
|
|
// unmarshaled requests to another JSON-RPC server if a request cannot be
|
|
|
|
// handled directly.
|
|
|
|
func (c *Client) RawRequest(method string, params []json.RawMessage) (json.RawMessage, error) {
|
|
|
|
return c.RawRequestAsync(method, params).Receive()
|
|
|
|
}
|