2020-04-16 23:03:17 -07:00
|
|
|
// (c) 2019-2020, Ava Labs, Inc. All rights reserved.
|
|
|
|
// See the file LICENSE for licensing terms.
|
|
|
|
|
|
|
|
package gwriter
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
|
2020-04-17 06:47:19 -07:00
|
|
|
"github.com/ava-labs/gecko/vms/rpcchainvm/ghttp/gwriter/gwriterproto"
|
2020-04-16 23:03:17 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
// Client is an implementation of a messenger channel that talks over RPC.
|
2020-04-17 06:47:19 -07:00
|
|
|
type Client struct{ client gwriterproto.WriterClient }
|
2020-04-16 23:03:17 -07:00
|
|
|
|
|
|
|
// NewClient returns a database instance connected to a remote database instance
|
2020-04-17 06:47:19 -07:00
|
|
|
func NewClient(client gwriterproto.WriterClient) *Client {
|
2020-04-16 23:03:17 -07:00
|
|
|
return &Client{client: client}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write ...
|
|
|
|
func (c *Client) Write(p []byte) (int, error) {
|
2020-04-17 06:47:19 -07:00
|
|
|
resp, err := c.client.Write(context.Background(), &gwriterproto.WriteRequest{
|
2020-04-16 23:03:17 -07:00
|
|
|
Payload: p,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp.Errored {
|
|
|
|
err = errors.New(resp.Error)
|
|
|
|
}
|
|
|
|
return int(resp.Written), err
|
|
|
|
}
|