Refactor peer message sending into single interface method .Send() (#40)
* Adds Send method to Peer interface and removes redundant methods * Fix imports * Bumps version
This commit is contained in:
parent
e09c870f7f
commit
42195b1af4
6 changed files with 30 additions and 101 deletions
2
VERSION
2
VERSION
|
@ -1 +1 @@
|
||||||
0.21.0
|
0.23.0
|
||||||
|
|
|
@ -11,13 +11,8 @@ type Peer interface {
|
||||||
id() uint32
|
id() uint32
|
||||||
addr() util.Endpoint
|
addr() util.Endpoint
|
||||||
disconnect()
|
disconnect()
|
||||||
|
Send(*Message) error
|
||||||
version() *payload.Version
|
version() *payload.Version
|
||||||
callVersion(*Message) error
|
|
||||||
callGetaddr(*Message) error
|
|
||||||
callVerack(*Message) error
|
|
||||||
callGetdata(*Message) error
|
|
||||||
callGetblocks(*Message) error
|
|
||||||
callGetheaders(*Message) error
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// LocalPeer is the simplest kind of peer, mapped to a server in the
|
// LocalPeer is the simplest kind of peer, mapped to a server in the
|
||||||
|
@ -35,36 +30,23 @@ func NewLocalPeer(s *Server) *LocalPeer {
|
||||||
return &LocalPeer{endpoint: e, s: s}
|
return &LocalPeer{endpoint: e, s: s}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *LocalPeer) Send(msg *Message) error {
|
||||||
|
switch msg.commandType() {
|
||||||
|
case cmdVersion:
|
||||||
|
version := msg.Payload.(*payload.Version)
|
||||||
|
return p.s.handleVersionCmd(version, p)
|
||||||
|
case cmdGetAddr:
|
||||||
|
return p.s.handleGetaddrCmd(msg, p)
|
||||||
|
default:
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Version implements the Peer interface.
|
// Version implements the Peer interface.
|
||||||
func (p *LocalPeer) version() *payload.Version {
|
func (p *LocalPeer) version() *payload.Version {
|
||||||
return p.pVersion
|
return p.pVersion
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *LocalPeer) callVersion(msg *Message) error {
|
|
||||||
version := msg.Payload.(*payload.Version)
|
|
||||||
return p.s.handleVersionCmd(version, p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *LocalPeer) callVerack(msg *Message) error {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *LocalPeer) callGetaddr(msg *Message) error {
|
|
||||||
return p.s.handleGetaddrCmd(msg, p)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *LocalPeer) callGetblocks(msg *Message) error {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *LocalPeer) callGetheaders(msg *Message) error {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *LocalPeer) callGetdata(msg *Message) error {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *LocalPeer) id() uint32 { return p.nonce }
|
func (p *LocalPeer) id() uint32 { return p.nonce }
|
||||||
func (p *LocalPeer) addr() util.Endpoint { return p.endpoint }
|
func (p *LocalPeer) addr() util.Endpoint { return p.endpoint }
|
||||||
func (p *LocalPeer) disconnect() {}
|
func (p *LocalPeer) disconnect() {}
|
||||||
|
|
|
@ -209,7 +209,7 @@ func (s *Server) handlePeerConnected(p Peer) error {
|
||||||
// TODO: get the blockheight of this server once core implemented this.
|
// TODO: get the blockheight of this server once core implemented this.
|
||||||
payload := payload.NewVersion(s.id, s.port, s.userAgent, s.bc.HeaderHeight(), s.relay)
|
payload := payload.NewVersion(s.id, s.port, s.userAgent, s.bc.HeaderHeight(), s.relay)
|
||||||
msg := newMessage(s.net, cmdVersion, payload)
|
msg := newMessage(s.net, cmdVersion, payload)
|
||||||
return p.callVersion(msg)
|
return p.Send(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Server) handleVersionCmd(version *payload.Version, p Peer) error {
|
func (s *Server) handleVersionCmd(version *payload.Version, p Peer) error {
|
||||||
|
@ -220,7 +220,9 @@ func (s *Server) handleVersionCmd(version *payload.Version, p Peer) error {
|
||||||
return fmt.Errorf("port mismatch: %d and %d", version.Port, p.addr().Port)
|
return fmt.Errorf("port mismatch: %d and %d", version.Port, p.addr().Port)
|
||||||
}
|
}
|
||||||
|
|
||||||
return p.callVerack(newMessage(s.net, cmdVerack, nil))
|
return p.Send(
|
||||||
|
newMessage(s.net, cmdVerack, nil),
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Server) handleGetaddrCmd(msg *Message, p Peer) error {
|
func (s *Server) handleGetaddrCmd(msg *Message, p Peer) error {
|
||||||
|
@ -242,7 +244,7 @@ func (s *Server) handleInvCmd(inv *payload.Inventory, p Peer) error {
|
||||||
payload := payload.NewInventory(inv.Type, inv.Hashes)
|
payload := payload.NewInventory(inv.Type, inv.Hashes)
|
||||||
resp := newMessage(s.net, cmdGetData, payload)
|
resp := newMessage(s.net, cmdGetData, payload)
|
||||||
|
|
||||||
return p.callGetdata(resp)
|
return p.Send(resp)
|
||||||
}
|
}
|
||||||
|
|
||||||
// handleBlockCmd processes the received block.
|
// handleBlockCmd processes the received block.
|
||||||
|
@ -297,7 +299,7 @@ func (s *Server) askMoreHeaders(p Peer) error {
|
||||||
payload := payload.NewGetBlocks(start, util.Uint256{})
|
payload := payload.NewGetBlocks(start, util.Uint256{})
|
||||||
msg := newMessage(s.net, cmdGetHeaders, payload)
|
msg := newMessage(s.net, cmdGetHeaders, payload)
|
||||||
|
|
||||||
return p.callGetheaders(msg)
|
return p.Send(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
// check if the addr is already connected to the server.
|
// check if the addr is already connected to the server.
|
||||||
|
@ -318,7 +320,7 @@ func (s *Server) startProtocol(p Peer) {
|
||||||
}
|
}
|
||||||
for {
|
for {
|
||||||
getaddrMsg := newMessage(s.net, cmdGetAddr, nil)
|
getaddrMsg := newMessage(s.net, cmdGetAddr, nil)
|
||||||
p.callGetaddr(getaddrMsg)
|
p.Send(getaddrMsg)
|
||||||
|
|
||||||
time.Sleep(30 * time.Second)
|
time.Sleep(30 * time.Second)
|
||||||
}
|
}
|
||||||
|
@ -351,10 +353,10 @@ type StartOpts struct {
|
||||||
|
|
||||||
func logo() string {
|
func logo() string {
|
||||||
return `
|
return `
|
||||||
_ ____________ __________
|
_ ____________ __________
|
||||||
/ | / / ____/ __ \ / ____/ __ \
|
/ | / / ____/ __ \ / ____/ __ \
|
||||||
/ |/ / __/ / / / /_____/ / __/ / / /
|
/ |/ / __/ / / / /_____/ / __/ / / /
|
||||||
/ /| / /___/ /_/ /_____/ /_/ / /_/ /
|
/ /| / /___/ /_/ /_____/ /_/ / /_/ /
|
||||||
/_/ |_/_____/\____/ \____/\____/
|
/_/ |_/_____/\____/ \____/\____/
|
||||||
`
|
`
|
||||||
}
|
}
|
||||||
|
|
|
@ -181,7 +181,10 @@ func NewTCPPeer(conn net.Conn, s *Server) *TCPPeer {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *TCPPeer) callVersion(msg *Message) error {
|
// Send needed to implement the network.Peer interface
|
||||||
|
// and provide the functionality to send a message to
|
||||||
|
// the current peer.
|
||||||
|
func (p *TCPPeer) Send(msg *Message) error {
|
||||||
t := sendTuple{
|
t := sendTuple{
|
||||||
msg: msg,
|
msg: msg,
|
||||||
err: make(chan error),
|
err: make(chan error),
|
||||||
|
@ -206,64 +209,6 @@ func (p *TCPPeer) addr() util.Endpoint {
|
||||||
return p.endpoint
|
return p.endpoint
|
||||||
}
|
}
|
||||||
|
|
||||||
// callGetaddr will send the "getaddr" command to the remote.
|
|
||||||
func (p *TCPPeer) callGetaddr(msg *Message) error {
|
|
||||||
t := sendTuple{
|
|
||||||
msg: msg,
|
|
||||||
err: make(chan error),
|
|
||||||
}
|
|
||||||
|
|
||||||
p.send <- t
|
|
||||||
|
|
||||||
return <-t.err
|
|
||||||
}
|
|
||||||
|
|
||||||
// callGetblocks will send the "getblocks" command to the remote.
|
|
||||||
func (p *TCPPeer) callGetblocks(msg *Message) error {
|
|
||||||
t := sendTuple{
|
|
||||||
msg: msg,
|
|
||||||
err: make(chan error),
|
|
||||||
}
|
|
||||||
|
|
||||||
p.send <- t
|
|
||||||
|
|
||||||
return <-t.err
|
|
||||||
}
|
|
||||||
|
|
||||||
// callGetheaders will send the "getheaders" command to the remote.
|
|
||||||
func (p *TCPPeer) callGetheaders(msg *Message) error {
|
|
||||||
t := sendTuple{
|
|
||||||
msg: msg,
|
|
||||||
err: make(chan error),
|
|
||||||
}
|
|
||||||
|
|
||||||
p.send <- t
|
|
||||||
|
|
||||||
return <-t.err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *TCPPeer) callVerack(msg *Message) error {
|
|
||||||
t := sendTuple{
|
|
||||||
msg: msg,
|
|
||||||
err: make(chan error),
|
|
||||||
}
|
|
||||||
|
|
||||||
p.send <- t
|
|
||||||
|
|
||||||
return <-t.err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (p *TCPPeer) callGetdata(msg *Message) error {
|
|
||||||
t := sendTuple{
|
|
||||||
msg: msg,
|
|
||||||
err: make(chan error),
|
|
||||||
}
|
|
||||||
|
|
||||||
p.send <- t
|
|
||||||
|
|
||||||
return <-t.err
|
|
||||||
}
|
|
||||||
|
|
||||||
// disconnect disconnects the peer, cleaning up all its resources.
|
// disconnect disconnects the peer, cleaning up all its resources.
|
||||||
// 3 goroutines needs to be cleanup (writeLoop, handleConnection and handleMessage)
|
// 3 goroutines needs to be cleanup (writeLoop, handleConnection and handleMessage)
|
||||||
func (p *TCPPeer) disconnect() {
|
func (p *TCPPeer) disconnect() {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package wallet
|
package wallet
|
||||||
|
|
||||||
import "github.com/anthdm/neo-go/pkg/util"
|
import "github.com/CityOfZion/neo-go/pkg/util"
|
||||||
|
|
||||||
// Account represents a NEO account. It holds the private and public key
|
// Account represents a NEO account. It holds the private and public key
|
||||||
// along with some metadata.
|
// along with some metadata.
|
||||||
|
|
|
@ -3,7 +3,7 @@ package wallet
|
||||||
import (
|
import (
|
||||||
"math/big"
|
"math/big"
|
||||||
|
|
||||||
"github.com/anthdm/neo-go/pkg/util"
|
"github.com/CityOfZion/neo-go/pkg/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TransferOutput respresents the output of a transaction.
|
// TransferOutput respresents the output of a transaction.
|
||||||
|
|
Loading…
Reference in a new issue