diff options
author | obscuren <geffobscura@gmail.com> | 2014-01-10 07:39:16 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2014-01-10 07:39:16 +0800 |
commit | bd0abe2a8187c0ae948bba6a90cbaac07f479cc8 (patch) | |
tree | cf3fea9cb3cc09d75609aaffe11374f7e9a72d8b /peer.go | |
parent | 849408dda60fe32d7abb78d103b09ca0bc7b5a60 (diff) | |
download | go-tangerine-bd0abe2a8187c0ae948bba6a90cbaac07f479cc8.tar go-tangerine-bd0abe2a8187c0ae948bba6a90cbaac07f479cc8.tar.gz go-tangerine-bd0abe2a8187c0ae948bba6a90cbaac07f479cc8.tar.bz2 go-tangerine-bd0abe2a8187c0ae948bba6a90cbaac07f479cc8.tar.lz go-tangerine-bd0abe2a8187c0ae948bba6a90cbaac07f479cc8.tar.xz go-tangerine-bd0abe2a8187c0ae948bba6a90cbaac07f479cc8.tar.zst go-tangerine-bd0abe2a8187c0ae948bba6a90cbaac07f479cc8.zip |
Updated server and peers and mining processing
Diffstat (limited to 'peer.go')
-rw-r--r-- | peer.go | 40 |
1 files changed, 31 insertions, 9 deletions
@@ -11,6 +11,11 @@ type InMsg struct { data []byte // RLP encoded data } +type OutMsg struct { + msgType string + data []byte +} + func ReadMessage(conn net.Conn) (*InMsg, error) { buff := make([]byte, 4069) @@ -23,6 +28,7 @@ func ReadMessage(conn net.Conn) (*InMsg, error) { } // Read the header (MAX n) + // XXX The data specification is made up. This will change once more details have been released on the specification of the format decoder := NewRlpDecoder(buff[:n]) t := decoder.Get(0).AsString() if t == "" { @@ -32,10 +38,6 @@ func ReadMessage(conn net.Conn) (*InMsg, error) { return &InMsg{msgType: t, data: decoder.Get(1).AsBytes()}, nil } -type OutMsg struct { - data []byte -} - type Peer struct { server *Server conn net.Conn @@ -54,22 +56,34 @@ func NewPeer(conn net.Conn, server *Server) *Peer { } // Outputs any RLP encoded data to the peer -func (p *Peer) QueueMessage(data []byte) { - p.outputQueue <- OutMsg{data: data} +func (p *Peer) QueueMessage(msgType string, data []byte) { + p.outputQueue <- OutMsg{msgType: msgType, data: data} } func (p *Peer) HandleOutbound() { out: for { - switch { + select { + case msg := <-p.outputQueue: + p.WriteMessage(msg) + case <- p.quit: break out } } } +func (p *Peer) WriteMessage(msg OutMsg) { + encoded := Encode([]interface{}{ msg.msgType, msg.data }) + _, err := p.conn.Write(encoded) + if err != nil { + log.Println(err) + p.Stop() + } +} + func (p *Peer) HandleInbound() { - defer p.conn.Close() + defer p.Stop() out: for { @@ -80,7 +94,9 @@ out: break out } - log.Println(msg) + // TODO + data, _ := Decode(msg.data, 0) + log.Printf("%s, %s\n", msg.msgType, data) } // Notify the out handler we're quiting @@ -91,3 +107,9 @@ func (p *Peer) Start() { go p.HandleOutbound() go p.HandleInbound() } + +func (p *Peer) Stop() { + defer p.conn.Close() + + p.quit <- true +} |