aboutsummaryrefslogtreecommitdiffstats
path: root/peer.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2014-09-14 19:42:02 +0800
committerobscuren <geffobscura@gmail.com>2014-09-14 19:42:02 +0800
commitf63cb278038dddd09aa4527529c43fdb8320f2fa (patch)
treea486e616e7f7fc5c625926b4a5965234fe18643f /peer.go
parent954ba211bf8ee63872b5e4d20b6aafb4400507c6 (diff)
downloadgo-tangerine-f63cb278038dddd09aa4527529c43fdb8320f2fa.tar
go-tangerine-f63cb278038dddd09aa4527529c43fdb8320f2fa.tar.gz
go-tangerine-f63cb278038dddd09aa4527529c43fdb8320f2fa.tar.bz2
go-tangerine-f63cb278038dddd09aa4527529c43fdb8320f2fa.tar.lz
go-tangerine-f63cb278038dddd09aa4527529c43fdb8320f2fa.tar.xz
go-tangerine-f63cb278038dddd09aa4527529c43fdb8320f2fa.tar.zst
go-tangerine-f63cb278038dddd09aa4527529c43fdb8320f2fa.zip
tmp
Diffstat (limited to 'peer.go')
-rw-r--r--peer.go29
1 files changed, 15 insertions, 14 deletions
diff --git a/peer.go b/peer.go
index 5ca3ed641..28b193e82 100644
--- a/peer.go
+++ b/peer.go
@@ -182,6 +182,7 @@ func NewOutboundPeer(addr string, ethereum *Ethereum, caps Caps) *Peer {
inbound: false,
connected: 0,
disconnect: 0,
+ port: 30303,
caps: caps,
version: ethereum.ClientIdentity().String(),
}
@@ -629,17 +630,6 @@ func (p *Peer) pushPeers() {
p.QueueMessage(p.peersMessage())
}
-func (p *Peer) pushHandshake() error {
- pubkey := p.ethereum.KeyManager().PublicKey()
- msg := ethwire.NewMessage(ethwire.MsgHandshakeTy, []interface{}{
- uint32(0), []byte(p.version), []string{"eth"}, p.port, pubkey[1:],
- })
-
- p.QueueMessage(msg)
-
- return nil
-}
-
func (self *Peer) pushStatus() {
const netVersion = 0
msg := ethwire.NewMessage(ethwire.MsgStatusTy, []interface{}{
@@ -673,8 +663,21 @@ func (self *Peer) handleStatus(msg *ethwire.Msg) {
ethlogger.Infof("Peer is [ETH] capable. (TD = %v ~ %x", self.td, self.bestHash)
}
+func (p *Peer) pushHandshake() error {
+ pubkey := p.ethereum.KeyManager().PublicKey()
+ fmt.Println("pubkey", pubkey)
+ msg := ethwire.NewMessage(ethwire.MsgHandshakeTy, []interface{}{
+ uint32(0), []byte(p.version), []string{"eth"}, uint32(p.port), pubkey[1:],
+ })
+
+ p.QueueMessage(msg)
+
+ return nil
+}
+
func (p *Peer) handleHandshake(msg *ethwire.Msg) {
c := msg.Data
+ fmt.Println(c, c.Len())
var (
p2pVersion = c.Get(0).Uint()
@@ -684,8 +687,6 @@ func (p *Peer) handleHandshake(msg *ethwire.Msg) {
pub = c.Get(4).Bytes()
)
- fmt.Println("PEER CAPS", caps)
-
// Check correctness of p2p protocol version
if p2pVersion != P2PVersion {
peerlogger.Debugf("Invalid P2P version. Require protocol %d, received %d\n", P2PVersion, p2pVersion)
@@ -735,7 +736,7 @@ func (p *Peer) handleHandshake(msg *ethwire.Msg) {
p.ethereum.PushPeer(p)
p.ethereum.reactor.Post("peerList", p.ethereum.Peers())
- ethlogger.Infof("Added peer (%s) %d / %d \n", p.conn.RemoteAddr(), p.ethereum.Peers().Len(), p.ethereum.MaxPeers)
+ ethlogger.Infof("Added peer (%s) %d / %d (%v)\n", p.conn.RemoteAddr(), p.ethereum.Peers().Len(), p.ethereum.MaxPeers, caps)
peerlogger.Debugln(p)