mirror of https://github.com/hashicorp/packer
parent
39a5e4e612
commit
9e3a179c0d
@ -0,0 +1,37 @@
|
||||
package rpc
|
||||
|
||||
import (
|
||||
baserpc "net/rpc"
|
||||
|
||||
"github.com/keegancsmith/rpc"
|
||||
)
|
||||
|
||||
type Server = rpc.Server
|
||||
type Client = rpc.Client
|
||||
type Request = rpc.Request
|
||||
type Response = rpc.Response
|
||||
|
||||
type ClientCodec interface {
|
||||
WriteRequest(*baserpc.Request, interface{}) error
|
||||
ReadResponseHeader(*baserpc.Response) error
|
||||
ReadResponseBody(interface{}) error
|
||||
|
||||
Close() error
|
||||
}
|
||||
|
||||
type ServerCodec interface {
|
||||
ReadRequestHeader(*baserpc.Request) error
|
||||
ReadRequestBody(interface{}) error
|
||||
WriteResponse(*baserpc.Response, interface{}) error
|
||||
|
||||
// Close can be called multiple times and must be idempotent.
|
||||
Close() error
|
||||
}
|
||||
|
||||
func NewClientWithCodec(codec rpc.ClientCodec) *Client {
|
||||
return rpc.NewClientWithCodec(codec)
|
||||
}
|
||||
|
||||
func NewServer() *Server {
|
||||
return rpc.NewServer()
|
||||
}
|
||||
@ -0,0 +1,51 @@
|
||||
package codec
|
||||
|
||||
import (
|
||||
"io"
|
||||
baserpc "net/rpc"
|
||||
|
||||
"github.com/hashicorp/packer/common/net/rpc"
|
||||
"github.com/ugorji/go/codec"
|
||||
)
|
||||
|
||||
type Handle = codec.Handle
|
||||
|
||||
var msgpackHandle = &codec.MsgpackHandle{
|
||||
RawToString: true,
|
||||
WriteExt: true,
|
||||
}
|
||||
|
||||
type serverCodec struct {
|
||||
baserpc.ServerCodec
|
||||
}
|
||||
|
||||
func (s *serverCodec) ReadRequestHeader(r *rpc.Request) error {
|
||||
return s.ServerCodec.ReadRequestHeader(r)
|
||||
}
|
||||
|
||||
func (s *serverCodec) WriteResponse(r *baserpc.Response, v interface{}) error {
|
||||
return s.ServerCodec.WriteResponse(r, v)
|
||||
}
|
||||
|
||||
func MsgpackServerCodec(conn io.ReadWriteCloser) rpc.ServerCodec {
|
||||
c := codec.GoRpc.ServerCodec(conn, msgpackHandle)
|
||||
return &serverCodec{c}
|
||||
}
|
||||
|
||||
type clientCodec struct {
|
||||
baserpc.ClientCodec
|
||||
}
|
||||
|
||||
func (c *clientCodec) WriteRequest(req *baserpc.Request, v interface{}) error {
|
||||
return c.ClientCodec.WriteRequest(req, v)
|
||||
}
|
||||
|
||||
func (c *clientCodec) ReadResponseHeader(res *rpc.Response) error {
|
||||
r := baserpc.Response(*res)
|
||||
return c.ClientCodec.ReadResponseHeader()
|
||||
}
|
||||
|
||||
func MsgpackClientCodec(conn io.ReadWriteCloser) rpc.ClientCodec {
|
||||
c := codec.GoRpc.ClientCodec(conn, msgpackHandle)
|
||||
return &clientCodec{c}
|
||||
}
|
||||
Loading…
Reference in new issue