forked from cerc-io/plugeth
ethwire => wire
This commit is contained in:
parent
af34749a6b
commit
4914a78c8c
@ -11,8 +11,8 @@ import (
|
|||||||
|
|
||||||
"github.com/ethereum/go-ethereum/chain"
|
"github.com/ethereum/go-ethereum/chain"
|
||||||
"github.com/ethereum/go-ethereum/ethutil"
|
"github.com/ethereum/go-ethereum/ethutil"
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
|
"github.com/ethereum/go-ethereum/wire"
|
||||||
)
|
)
|
||||||
|
|
||||||
var poollogger = logger.NewLogger("BPOOL")
|
var poollogger = logger.NewLogger("BPOOL")
|
||||||
@ -103,7 +103,7 @@ func (self *BlockPool) FetchHashes(peer *Peer) bool {
|
|||||||
|
|
||||||
const amount = 256
|
const amount = 256
|
||||||
peerlogger.Debugf("Fetching hashes (%d) %x...\n", amount, peer.lastReceivedHash[0:4])
|
peerlogger.Debugf("Fetching hashes (%d) %x...\n", amount, peer.lastReceivedHash[0:4])
|
||||||
peer.QueueMessage(ethwire.NewMessage(ethwire.MsgGetBlockHashesTy, []interface{}{peer.lastReceivedHash, uint32(amount)}))
|
peer.QueueMessage(wire.NewMessage(wire.MsgGetBlockHashesTy, []interface{}{peer.lastReceivedHash, uint32(amount)}))
|
||||||
}
|
}
|
||||||
|
|
||||||
return true
|
return true
|
||||||
@ -150,7 +150,7 @@ func (self *BlockPool) addBlock(b *chain.Block, peer *Peer, newBlock bool) {
|
|||||||
fmt.Println("3.", !self.fetchingHashes)
|
fmt.Println("3.", !self.fetchingHashes)
|
||||||
if !self.eth.ChainManager().HasBlock(b.PrevHash) && self.pool[string(b.PrevHash)] == nil && !self.fetchingHashes {
|
if !self.eth.ChainManager().HasBlock(b.PrevHash) && self.pool[string(b.PrevHash)] == nil && !self.fetchingHashes {
|
||||||
poollogger.Infof("Unknown chain, requesting (%x...)\n", b.PrevHash[0:4])
|
poollogger.Infof("Unknown chain, requesting (%x...)\n", b.PrevHash[0:4])
|
||||||
peer.QueueMessage(ethwire.NewMessage(ethwire.MsgGetBlockHashesTy, []interface{}{b.Hash(), uint32(256)}))
|
peer.QueueMessage(wire.NewMessage(wire.MsgGetBlockHashesTy, []interface{}{b.Hash(), uint32(256)}))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if self.pool[hash] != nil {
|
} else if self.pool[hash] != nil {
|
||||||
|
@ -11,10 +11,10 @@ import (
|
|||||||
|
|
||||||
"github.com/ethereum/go-ethereum/crypto"
|
"github.com/ethereum/go-ethereum/crypto"
|
||||||
"github.com/ethereum/go-ethereum/ethutil"
|
"github.com/ethereum/go-ethereum/ethutil"
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/event"
|
"github.com/ethereum/go-ethereum/event"
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
"github.com/ethereum/go-ethereum/state"
|
"github.com/ethereum/go-ethereum/state"
|
||||||
|
"github.com/ethereum/go-ethereum/wire"
|
||||||
)
|
)
|
||||||
|
|
||||||
var statelogger = logger.NewLogger("BLOCK")
|
var statelogger = logger.NewLogger("BLOCK")
|
||||||
@ -35,13 +35,13 @@ type EthManager interface {
|
|||||||
StateManager() *StateManager
|
StateManager() *StateManager
|
||||||
ChainManager() *ChainManager
|
ChainManager() *ChainManager
|
||||||
TxPool() *TxPool
|
TxPool() *TxPool
|
||||||
Broadcast(msgType ethwire.MsgType, data []interface{})
|
Broadcast(msgType wire.MsgType, data []interface{})
|
||||||
PeerCount() int
|
PeerCount() int
|
||||||
IsMining() bool
|
IsMining() bool
|
||||||
IsListening() bool
|
IsListening() bool
|
||||||
Peers() *list.List
|
Peers() *list.List
|
||||||
KeyManager() *crypto.KeyManager
|
KeyManager() *crypto.KeyManager
|
||||||
ClientIdentity() ethwire.ClientIdentity
|
ClientIdentity() wire.ClientIdentity
|
||||||
Db() ethutil.Database
|
Db() ethutil.Database
|
||||||
EventMux() *event.TypeMux
|
EventMux() *event.TypeMux
|
||||||
}
|
}
|
||||||
|
@ -7,9 +7,9 @@ import (
|
|||||||
"math/big"
|
"math/big"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
"github.com/ethereum/go-ethereum/state"
|
"github.com/ethereum/go-ethereum/state"
|
||||||
|
"github.com/ethereum/go-ethereum/wire"
|
||||||
)
|
)
|
||||||
|
|
||||||
var txplogger = logger.NewLogger("TXP")
|
var txplogger = logger.NewLogger("TXP")
|
||||||
@ -93,7 +93,7 @@ func (pool *TxPool) addTransaction(tx *Transaction) {
|
|||||||
pool.pool.PushBack(tx)
|
pool.pool.PushBack(tx)
|
||||||
|
|
||||||
// Broadcast the transaction to the rest of the peers
|
// Broadcast the transaction to the rest of the peers
|
||||||
pool.Ethereum.Broadcast(ethwire.MsgTxTy, []interface{}{tx.RlpData()})
|
pool.Ethereum.Broadcast(wire.MsgTxTy, []interface{}{tx.RlpData()})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pool *TxPool) ValidateTransaction(tx *Transaction) error {
|
func (pool *TxPool) ValidateTransaction(tx *Transaction) error {
|
||||||
|
@ -35,8 +35,8 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/ethdb"
|
"github.com/ethereum/go-ethereum/ethdb"
|
||||||
"github.com/ethereum/go-ethereum/ethminer"
|
"github.com/ethereum/go-ethereum/ethminer"
|
||||||
"github.com/ethereum/go-ethereum/ethutil"
|
"github.com/ethereum/go-ethereum/ethutil"
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
|
"github.com/ethereum/go-ethereum/wire"
|
||||||
"github.com/ethereum/go-ethereum/xeth"
|
"github.com/ethereum/go-ethereum/xeth"
|
||||||
"gopkg.in/qml.v1"
|
"gopkg.in/qml.v1"
|
||||||
)
|
)
|
||||||
@ -87,7 +87,7 @@ type Gui struct {
|
|||||||
pipe *xeth.JSXEth
|
pipe *xeth.JSXEth
|
||||||
|
|
||||||
Session string
|
Session string
|
||||||
clientIdentity *ethwire.SimpleClientIdentity
|
clientIdentity *wire.SimpleClientIdentity
|
||||||
config *ethutil.ConfigManager
|
config *ethutil.ConfigManager
|
||||||
|
|
||||||
plugins map[string]plugin
|
plugins map[string]plugin
|
||||||
@ -97,7 +97,7 @@ type Gui struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create GUI, but doesn't start it
|
// Create GUI, but doesn't start it
|
||||||
func NewWindow(ethereum *eth.Ethereum, config *ethutil.ConfigManager, clientIdentity *ethwire.SimpleClientIdentity, session string, logLevel int) *Gui {
|
func NewWindow(ethereum *eth.Ethereum, config *ethutil.ConfigManager, clientIdentity *wire.SimpleClientIdentity, session string, logLevel int) *Gui {
|
||||||
db, err := ethdb.NewLDBDatabase("tx_database")
|
db, err := ethdb.NewLDBDatabase("tx_database")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
@ -18,9 +18,9 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/ethdb"
|
"github.com/ethereum/go-ethereum/ethdb"
|
||||||
"github.com/ethereum/go-ethereum/ethminer"
|
"github.com/ethereum/go-ethereum/ethminer"
|
||||||
"github.com/ethereum/go-ethereum/ethutil"
|
"github.com/ethereum/go-ethereum/ethutil"
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
"github.com/ethereum/go-ethereum/rpc"
|
"github.com/ethereum/go-ethereum/rpc"
|
||||||
|
"github.com/ethereum/go-ethereum/wire"
|
||||||
"github.com/ethereum/go-ethereum/xeth"
|
"github.com/ethereum/go-ethereum/xeth"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -144,12 +144,12 @@ func NewDatabase() ethutil.Database {
|
|||||||
return db
|
return db
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewClientIdentity(clientIdentifier, version, customIdentifier string) *ethwire.SimpleClientIdentity {
|
func NewClientIdentity(clientIdentifier, version, customIdentifier string) *wire.SimpleClientIdentity {
|
||||||
clilogger.Infoln("identity created")
|
clilogger.Infoln("identity created")
|
||||||
return ethwire.NewSimpleClientIdentity(clientIdentifier, version, customIdentifier)
|
return wire.NewSimpleClientIdentity(clientIdentifier, version, customIdentifier)
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewEthereum(db ethutil.Database, clientIdentity ethwire.ClientIdentity, keyManager *crypto.KeyManager, usePnp bool, OutboundPort string, MaxPeer int) *eth.Ethereum {
|
func NewEthereum(db ethutil.Database, clientIdentity wire.ClientIdentity, keyManager *crypto.KeyManager, usePnp bool, OutboundPort string, MaxPeer int) *eth.Ethereum {
|
||||||
ethereum, err := eth.New(db, clientIdentity, keyManager, eth.CapDefault, usePnp)
|
ethereum, err := eth.New(db, clientIdentity, keyManager, eth.CapDefault, usePnp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
clilogger.Fatalln("eth start err:", err)
|
clilogger.Fatalln("eth start err:", err)
|
||||||
|
14
ethereum.go
14
ethereum.go
@ -17,11 +17,11 @@ import (
|
|||||||
"github.com/ethereum/go-ethereum/chain"
|
"github.com/ethereum/go-ethereum/chain"
|
||||||
"github.com/ethereum/go-ethereum/crypto"
|
"github.com/ethereum/go-ethereum/crypto"
|
||||||
"github.com/ethereum/go-ethereum/ethutil"
|
"github.com/ethereum/go-ethereum/ethutil"
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/event"
|
"github.com/ethereum/go-ethereum/event"
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
"github.com/ethereum/go-ethereum/rpc"
|
"github.com/ethereum/go-ethereum/rpc"
|
||||||
"github.com/ethereum/go-ethereum/state"
|
"github.com/ethereum/go-ethereum/state"
|
||||||
|
"github.com/ethereum/go-ethereum/wire"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -88,7 +88,7 @@ type Ethereum struct {
|
|||||||
|
|
||||||
keyManager *crypto.KeyManager
|
keyManager *crypto.KeyManager
|
||||||
|
|
||||||
clientIdentity ethwire.ClientIdentity
|
clientIdentity wire.ClientIdentity
|
||||||
|
|
||||||
isUpToDate bool
|
isUpToDate bool
|
||||||
|
|
||||||
@ -97,7 +97,7 @@ type Ethereum struct {
|
|||||||
filters map[int]*chain.Filter
|
filters map[int]*chain.Filter
|
||||||
}
|
}
|
||||||
|
|
||||||
func New(db ethutil.Database, clientIdentity ethwire.ClientIdentity, keyManager *crypto.KeyManager, caps Caps, usePnp bool) (*Ethereum, error) {
|
func New(db ethutil.Database, clientIdentity wire.ClientIdentity, keyManager *crypto.KeyManager, caps Caps, usePnp bool) (*Ethereum, error) {
|
||||||
var err error
|
var err error
|
||||||
var nat NAT
|
var nat NAT
|
||||||
|
|
||||||
@ -142,7 +142,7 @@ func (s *Ethereum) KeyManager() *crypto.KeyManager {
|
|||||||
return s.keyManager
|
return s.keyManager
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Ethereum) ClientIdentity() ethwire.ClientIdentity {
|
func (s *Ethereum) ClientIdentity() wire.ClientIdentity {
|
||||||
return s.clientIdentity
|
return s.clientIdentity
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -338,12 +338,12 @@ func (s *Ethereum) InOutPeers() []*Peer {
|
|||||||
return inboundPeers[:length]
|
return inboundPeers[:length]
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Ethereum) Broadcast(msgType ethwire.MsgType, data []interface{}) {
|
func (s *Ethereum) Broadcast(msgType wire.MsgType, data []interface{}) {
|
||||||
msg := ethwire.NewMessage(msgType, data)
|
msg := wire.NewMessage(msgType, data)
|
||||||
s.BroadcastMsg(msg)
|
s.BroadcastMsg(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Ethereum) BroadcastMsg(msg *ethwire.Msg) {
|
func (s *Ethereum) BroadcastMsg(msg *wire.Msg) {
|
||||||
eachPeer(s.peers, func(p *Peer, e *list.Element) {
|
eachPeer(s.peers, func(p *Peer, e *list.Element) {
|
||||||
p.QueueMessage(msg)
|
p.QueueMessage(msg)
|
||||||
})
|
})
|
||||||
|
@ -1,217 +0,0 @@
|
|||||||
package ethminer
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"sort"
|
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/chain"
|
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/event"
|
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
|
||||||
)
|
|
||||||
|
|
||||||
var minerlogger = logger.NewLogger("MINER")
|
|
||||||
|
|
||||||
type Miner struct {
|
|
||||||
pow chain.PoW
|
|
||||||
ethereum chain.EthManager
|
|
||||||
coinbase []byte
|
|
||||||
txs chain.Transactions
|
|
||||||
uncles []*chain.Block
|
|
||||||
block *chain.Block
|
|
||||||
|
|
||||||
events event.Subscription
|
|
||||||
powQuitChan chan struct{}
|
|
||||||
powDone chan struct{}
|
|
||||||
|
|
||||||
turbo bool
|
|
||||||
}
|
|
||||||
|
|
||||||
const (
|
|
||||||
Started = iota
|
|
||||||
Stopped
|
|
||||||
)
|
|
||||||
|
|
||||||
type Event struct {
|
|
||||||
Type int // Started || Stopped
|
|
||||||
Miner *Miner
|
|
||||||
}
|
|
||||||
|
|
||||||
func (self *Miner) GetPow() chain.PoW {
|
|
||||||
return self.pow
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewDefaultMiner(coinbase []byte, ethereum chain.EthManager) *Miner {
|
|
||||||
miner := Miner{
|
|
||||||
pow: &chain.EasyPow{},
|
|
||||||
ethereum: ethereum,
|
|
||||||
coinbase: coinbase,
|
|
||||||
}
|
|
||||||
|
|
||||||
return &miner
|
|
||||||
}
|
|
||||||
|
|
||||||
func (self *Miner) ToggleTurbo() {
|
|
||||||
self.turbo = !self.turbo
|
|
||||||
|
|
||||||
self.pow.Turbo(self.turbo)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (miner *Miner) Start() {
|
|
||||||
|
|
||||||
// Insert initial TXs in our little miner 'pool'
|
|
||||||
miner.txs = miner.ethereum.TxPool().Flush()
|
|
||||||
miner.block = miner.ethereum.ChainManager().NewBlock(miner.coinbase)
|
|
||||||
|
|
||||||
mux := miner.ethereum.EventMux()
|
|
||||||
miner.events = mux.Subscribe(chain.NewBlockEvent{}, chain.TxPreEvent{})
|
|
||||||
|
|
||||||
// Prepare inital block
|
|
||||||
//miner.ethereum.StateManager().Prepare(miner.block.State(), miner.block.State())
|
|
||||||
go miner.listener()
|
|
||||||
|
|
||||||
minerlogger.Infoln("Started")
|
|
||||||
mux.Post(Event{Started, miner})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (miner *Miner) Stop() {
|
|
||||||
minerlogger.Infoln("Stopping...")
|
|
||||||
miner.events.Unsubscribe()
|
|
||||||
miner.ethereum.EventMux().Post(Event{Stopped, miner})
|
|
||||||
}
|
|
||||||
|
|
||||||
func (miner *Miner) listener() {
|
|
||||||
miner.startMining()
|
|
||||||
|
|
||||||
for {
|
|
||||||
select {
|
|
||||||
case event := <-miner.events.Chan():
|
|
||||||
switch event := event.(type) {
|
|
||||||
case chain.NewBlockEvent:
|
|
||||||
miner.stopMining()
|
|
||||||
|
|
||||||
block := event.Block
|
|
||||||
//minerlogger.Infoln("Got new block via Reactor")
|
|
||||||
if bytes.Compare(miner.ethereum.ChainManager().CurrentBlock.Hash(), block.Hash()) == 0 {
|
|
||||||
// TODO: Perhaps continue mining to get some uncle rewards
|
|
||||||
//minerlogger.Infoln("New top block found resetting state")
|
|
||||||
|
|
||||||
// Filter out which Transactions we have that were not in this block
|
|
||||||
var newtxs []*chain.Transaction
|
|
||||||
for _, tx := range miner.txs {
|
|
||||||
found := false
|
|
||||||
for _, othertx := range block.Transactions() {
|
|
||||||
if bytes.Compare(tx.Hash(), othertx.Hash()) == 0 {
|
|
||||||
found = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if found == false {
|
|
||||||
newtxs = append(newtxs, tx)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
miner.txs = newtxs
|
|
||||||
} else {
|
|
||||||
if bytes.Compare(block.PrevHash, miner.ethereum.ChainManager().CurrentBlock.PrevHash) == 0 {
|
|
||||||
minerlogger.Infoln("Adding uncle block")
|
|
||||||
miner.uncles = append(miner.uncles, block)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
miner.startMining()
|
|
||||||
|
|
||||||
case chain.TxPreEvent:
|
|
||||||
miner.stopMining()
|
|
||||||
|
|
||||||
found := false
|
|
||||||
for _, ctx := range miner.txs {
|
|
||||||
if found = bytes.Compare(ctx.Hash(), event.Tx.Hash()) == 0; found {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
miner.startMining()
|
|
||||||
}
|
|
||||||
if found == false {
|
|
||||||
// Undo all previous commits
|
|
||||||
miner.block.Undo()
|
|
||||||
// Apply new transactions
|
|
||||||
miner.txs = append(miner.txs, event.Tx)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
case <-miner.powDone:
|
|
||||||
miner.startMining()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (miner *Miner) startMining() {
|
|
||||||
if miner.powDone == nil {
|
|
||||||
miner.powDone = make(chan struct{})
|
|
||||||
}
|
|
||||||
miner.powQuitChan = make(chan struct{})
|
|
||||||
go miner.mineNewBlock()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (miner *Miner) stopMining() {
|
|
||||||
println("stop mining")
|
|
||||||
_, isopen := <-miner.powQuitChan
|
|
||||||
if isopen {
|
|
||||||
close(miner.powQuitChan)
|
|
||||||
}
|
|
||||||
//<-miner.powDone
|
|
||||||
}
|
|
||||||
|
|
||||||
func (self *Miner) mineNewBlock() {
|
|
||||||
stateManager := self.ethereum.StateManager()
|
|
||||||
|
|
||||||
self.block = self.ethereum.ChainManager().NewBlock(self.coinbase)
|
|
||||||
|
|
||||||
// Apply uncles
|
|
||||||
if len(self.uncles) > 0 {
|
|
||||||
self.block.SetUncles(self.uncles)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sort the transactions by nonce in case of odd network propagation
|
|
||||||
sort.Sort(chain.TxByNonce{self.txs})
|
|
||||||
|
|
||||||
// Accumulate all valid transactions and apply them to the new state
|
|
||||||
// Error may be ignored. It's not important during mining
|
|
||||||
parent := self.ethereum.ChainManager().GetBlock(self.block.PrevHash)
|
|
||||||
coinbase := self.block.State().GetOrNewStateObject(self.block.Coinbase)
|
|
||||||
coinbase.SetGasPool(self.block.CalcGasLimit(parent))
|
|
||||||
receipts, txs, unhandledTxs, erroneous, err := stateManager.ProcessTransactions(coinbase, self.block.State(), self.block, self.block, self.txs)
|
|
||||||
if err != nil {
|
|
||||||
minerlogger.Debugln(err)
|
|
||||||
}
|
|
||||||
self.ethereum.TxPool().RemoveSet(erroneous)
|
|
||||||
self.txs = append(txs, unhandledTxs...)
|
|
||||||
|
|
||||||
self.block.SetTransactions(txs)
|
|
||||||
self.block.SetReceipts(receipts)
|
|
||||||
|
|
||||||
// Accumulate the rewards included for this block
|
|
||||||
stateManager.AccumelateRewards(self.block.State(), self.block, parent)
|
|
||||||
|
|
||||||
self.block.State().Update()
|
|
||||||
|
|
||||||
minerlogger.Infof("Mining on block. Includes %v transactions", len(self.txs))
|
|
||||||
|
|
||||||
// Find a valid nonce
|
|
||||||
nonce := self.pow.Search(self.block, self.powQuitChan)
|
|
||||||
if nonce != nil {
|
|
||||||
self.block.Nonce = nonce
|
|
||||||
err := self.ethereum.StateManager().Process(self.block)
|
|
||||||
if err != nil {
|
|
||||||
minerlogger.Infoln(err)
|
|
||||||
} else {
|
|
||||||
self.ethereum.Broadcast(ethwire.MsgBlockTy, []interface{}{self.block.Value().Val})
|
|
||||||
minerlogger.Infof("🔨 Mined block %x\n", self.block.Hash())
|
|
||||||
minerlogger.Infoln(self.block)
|
|
||||||
// Gather the new batch of transactions currently in the tx pool
|
|
||||||
self.txs = self.ethereum.TxPool().CurrentTransactions()
|
|
||||||
self.ethereum.EventMux().Post(chain.NewBlockEvent{self.block})
|
|
||||||
}
|
|
||||||
|
|
||||||
// Continue mining on the next block
|
|
||||||
self.startMining()
|
|
||||||
}
|
|
||||||
}
|
|
90
peer.go
90
peer.go
@ -14,8 +14,8 @@ import (
|
|||||||
|
|
||||||
"github.com/ethereum/go-ethereum/chain"
|
"github.com/ethereum/go-ethereum/chain"
|
||||||
"github.com/ethereum/go-ethereum/ethutil"
|
"github.com/ethereum/go-ethereum/ethutil"
|
||||||
"github.com/ethereum/go-ethereum/ethwire"
|
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
|
"github.com/ethereum/go-ethereum/wire"
|
||||||
)
|
)
|
||||||
|
|
||||||
var peerlogger = logger.NewLogger("PEER")
|
var peerlogger = logger.NewLogger("PEER")
|
||||||
@ -112,7 +112,7 @@ type Peer struct {
|
|||||||
// Net connection
|
// Net connection
|
||||||
conn net.Conn
|
conn net.Conn
|
||||||
// Output queue which is used to communicate and handle messages
|
// Output queue which is used to communicate and handle messages
|
||||||
outputQueue chan *ethwire.Msg
|
outputQueue chan *wire.Msg
|
||||||
// Quit channel
|
// Quit channel
|
||||||
quit chan bool
|
quit chan bool
|
||||||
// Determines whether it's an inbound or outbound peer
|
// Determines whether it's an inbound or outbound peer
|
||||||
@ -164,7 +164,7 @@ func NewPeer(conn net.Conn, ethereum *Ethereum, inbound bool) *Peer {
|
|||||||
pubkey := ethereum.KeyManager().PublicKey()[1:]
|
pubkey := ethereum.KeyManager().PublicKey()[1:]
|
||||||
|
|
||||||
return &Peer{
|
return &Peer{
|
||||||
outputQueue: make(chan *ethwire.Msg, outputBufferSize),
|
outputQueue: make(chan *wire.Msg, outputBufferSize),
|
||||||
quit: make(chan bool),
|
quit: make(chan bool),
|
||||||
ethereum: ethereum,
|
ethereum: ethereum,
|
||||||
conn: conn,
|
conn: conn,
|
||||||
@ -184,7 +184,7 @@ func NewPeer(conn net.Conn, ethereum *Ethereum, inbound bool) *Peer {
|
|||||||
|
|
||||||
func NewOutboundPeer(addr string, ethereum *Ethereum, caps Caps) *Peer {
|
func NewOutboundPeer(addr string, ethereum *Ethereum, caps Caps) *Peer {
|
||||||
p := &Peer{
|
p := &Peer{
|
||||||
outputQueue: make(chan *ethwire.Msg, outputBufferSize),
|
outputQueue: make(chan *wire.Msg, outputBufferSize),
|
||||||
quit: make(chan bool),
|
quit: make(chan bool),
|
||||||
ethereum: ethereum,
|
ethereum: ethereum,
|
||||||
inbound: false,
|
inbound: false,
|
||||||
@ -266,14 +266,14 @@ func (p *Peer) SetVersion(version string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Outputs any RLP encoded data to the peer
|
// Outputs any RLP encoded data to the peer
|
||||||
func (p *Peer) QueueMessage(msg *ethwire.Msg) {
|
func (p *Peer) QueueMessage(msg *wire.Msg) {
|
||||||
if atomic.LoadInt32(&p.connected) != 1 {
|
if atomic.LoadInt32(&p.connected) != 1 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
p.outputQueue <- msg
|
p.outputQueue <- msg
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Peer) writeMessage(msg *ethwire.Msg) {
|
func (p *Peer) writeMessage(msg *wire.Msg) {
|
||||||
// Ignore the write if we're not connected
|
// Ignore the write if we're not connected
|
||||||
if atomic.LoadInt32(&p.connected) != 1 {
|
if atomic.LoadInt32(&p.connected) != 1 {
|
||||||
return
|
return
|
||||||
@ -281,7 +281,7 @@ func (p *Peer) writeMessage(msg *ethwire.Msg) {
|
|||||||
|
|
||||||
if !p.versionKnown {
|
if !p.versionKnown {
|
||||||
switch msg.Type {
|
switch msg.Type {
|
||||||
case ethwire.MsgHandshakeTy: // Ok
|
case wire.MsgHandshakeTy: // Ok
|
||||||
default: // Anything but ack is allowed
|
default: // Anything but ack is allowed
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -289,7 +289,7 @@ func (p *Peer) writeMessage(msg *ethwire.Msg) {
|
|||||||
/*
|
/*
|
||||||
if !p.statusKnown {
|
if !p.statusKnown {
|
||||||
switch msg.Type {
|
switch msg.Type {
|
||||||
case ethwire.MsgStatusTy: // Ok
|
case wire.MsgStatusTy: // Ok
|
||||||
default: // Anything but ack is allowed
|
default: // Anything but ack is allowed
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -299,7 +299,7 @@ func (p *Peer) writeMessage(msg *ethwire.Msg) {
|
|||||||
|
|
||||||
peerlogger.DebugDetailf("(%v) <= %v\n", p.conn.RemoteAddr(), formatMessage(msg))
|
peerlogger.DebugDetailf("(%v) <= %v\n", p.conn.RemoteAddr(), formatMessage(msg))
|
||||||
|
|
||||||
err := ethwire.WriteMessage(p.conn, msg)
|
err := wire.WriteMessage(p.conn, msg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
peerlogger.Debugln(" Can't send message:", err)
|
peerlogger.Debugln(" Can't send message:", err)
|
||||||
// Stop the client if there was an error writing to it
|
// Stop the client if there was an error writing to it
|
||||||
@ -322,7 +322,7 @@ out:
|
|||||||
case msg := <-p.outputQueue:
|
case msg := <-p.outputQueue:
|
||||||
if !p.statusKnown {
|
if !p.statusKnown {
|
||||||
switch msg.Type {
|
switch msg.Type {
|
||||||
case ethwire.MsgTxTy, ethwire.MsgGetBlockHashesTy, ethwire.MsgBlockHashesTy, ethwire.MsgGetBlocksTy, ethwire.MsgBlockTy:
|
case wire.MsgTxTy, wire.MsgGetBlockHashesTy, wire.MsgBlockHashesTy, wire.MsgGetBlocksTy, wire.MsgBlockTy:
|
||||||
break skip
|
break skip
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -340,13 +340,13 @@ out:
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
p.writeMessage(ethwire.NewMessage(ethwire.MsgPingTy, ""))
|
p.writeMessage(wire.NewMessage(wire.MsgPingTy, ""))
|
||||||
p.pingStartTime = time.Now()
|
p.pingStartTime = time.Now()
|
||||||
|
|
||||||
// Service timer takes care of peer broadcasting, transaction
|
// Service timer takes care of peer broadcasting, transaction
|
||||||
// posting or block posting
|
// posting or block posting
|
||||||
case <-serviceTimer.C:
|
case <-serviceTimer.C:
|
||||||
p.QueueMessage(ethwire.NewMessage(ethwire.MsgGetPeersTy, ""))
|
p.QueueMessage(wire.NewMessage(wire.MsgGetPeersTy, ""))
|
||||||
|
|
||||||
case <-p.quit:
|
case <-p.quit:
|
||||||
// Break out of the for loop if a quit message is posted
|
// Break out of the for loop if a quit message is posted
|
||||||
@ -366,7 +366,7 @@ clean:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func formatMessage(msg *ethwire.Msg) (ret string) {
|
func formatMessage(msg *wire.Msg) (ret string) {
|
||||||
ret = fmt.Sprintf("%v %v", msg.Type, msg.Data)
|
ret = fmt.Sprintf("%v %v", msg.Type, msg.Data)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -375,12 +375,12 @@ func formatMessage(msg *ethwire.Msg) (ret string) {
|
|||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
switch msg.Type {
|
switch msg.Type {
|
||||||
case ethwire.MsgPeersTy:
|
case wire.MsgPeersTy:
|
||||||
ret += fmt.Sprintf("(%d entries)", msg.Data.Len())
|
ret += fmt.Sprintf("(%d entries)", msg.Data.Len())
|
||||||
case ethwire.MsgBlockTy:
|
case wire.MsgBlockTy:
|
||||||
b1, b2 := chain.NewBlockFromRlpValue(msg.Data.Get(0)), ethchain.NewBlockFromRlpValue(msg.Data.Get(msg.Data.Len()-1))
|
b1, b2 := chain.NewBlockFromRlpValue(msg.Data.Get(0)), ethchain.NewBlockFromRlpValue(msg.Data.Get(msg.Data.Len()-1))
|
||||||
ret += fmt.Sprintf("(%d entries) %x - %x", msg.Data.Len(), b1.Hash()[0:4], b2.Hash()[0:4])
|
ret += fmt.Sprintf("(%d entries) %x - %x", msg.Data.Len(), b1.Hash()[0:4], b2.Hash()[0:4])
|
||||||
case ethwire.MsgBlockHashesTy:
|
case wire.MsgBlockHashesTy:
|
||||||
h1, h2 := msg.Data.Get(0).Bytes(), msg.Data.Get(msg.Data.Len()-1).Bytes()
|
h1, h2 := msg.Data.Get(0).Bytes(), msg.Data.Get(msg.Data.Len()-1).Bytes()
|
||||||
ret += fmt.Sprintf("(%d entries) %x - %x", msg.Data.Len(), h1, h2)
|
ret += fmt.Sprintf("(%d entries) %x - %x", msg.Data.Len(), h1, h2)
|
||||||
}
|
}
|
||||||
@ -396,7 +396,7 @@ func (p *Peer) HandleInbound() {
|
|||||||
// HMM?
|
// HMM?
|
||||||
time.Sleep(50 * time.Millisecond)
|
time.Sleep(50 * time.Millisecond)
|
||||||
// Wait for a message from the peer
|
// Wait for a message from the peer
|
||||||
msgs, err := ethwire.ReadMessages(p.conn)
|
msgs, err := wire.ReadMessages(p.conn)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
peerlogger.Debugln(err)
|
peerlogger.Debugln(err)
|
||||||
}
|
}
|
||||||
@ -404,27 +404,27 @@ func (p *Peer) HandleInbound() {
|
|||||||
peerlogger.DebugDetailf("(%v) => %v\n", p.conn.RemoteAddr(), formatMessage(msg))
|
peerlogger.DebugDetailf("(%v) => %v\n", p.conn.RemoteAddr(), formatMessage(msg))
|
||||||
|
|
||||||
switch msg.Type {
|
switch msg.Type {
|
||||||
case ethwire.MsgHandshakeTy:
|
case wire.MsgHandshakeTy:
|
||||||
// Version message
|
// Version message
|
||||||
p.handleHandshake(msg)
|
p.handleHandshake(msg)
|
||||||
|
|
||||||
//if p.caps.IsCap(CapPeerDiscTy) {
|
//if p.caps.IsCap(CapPeerDiscTy) {
|
||||||
p.QueueMessage(ethwire.NewMessage(ethwire.MsgGetPeersTy, ""))
|
p.QueueMessage(wire.NewMessage(wire.MsgGetPeersTy, ""))
|
||||||
//}
|
//}
|
||||||
|
|
||||||
case ethwire.MsgDiscTy:
|
case wire.MsgDiscTy:
|
||||||
p.Stop()
|
p.Stop()
|
||||||
peerlogger.Infoln("Disconnect peer: ", DiscReason(msg.Data.Get(0).Uint()))
|
peerlogger.Infoln("Disconnect peer: ", DiscReason(msg.Data.Get(0).Uint()))
|
||||||
case ethwire.MsgPingTy:
|
case wire.MsgPingTy:
|
||||||
// Respond back with pong
|
// Respond back with pong
|
||||||
p.QueueMessage(ethwire.NewMessage(ethwire.MsgPongTy, ""))
|
p.QueueMessage(wire.NewMessage(wire.MsgPongTy, ""))
|
||||||
case ethwire.MsgPongTy:
|
case wire.MsgPongTy:
|
||||||
// If we received a pong back from a peer we set the
|
// If we received a pong back from a peer we set the
|
||||||
// last pong so the peer handler knows this peer is still
|
// last pong so the peer handler knows this peer is still
|
||||||
// active.
|
// active.
|
||||||
p.lastPong = time.Now().Unix()
|
p.lastPong = time.Now().Unix()
|
||||||
p.pingTime = time.Since(p.pingStartTime)
|
p.pingTime = time.Since(p.pingStartTime)
|
||||||
case ethwire.MsgTxTy:
|
case wire.MsgTxTy:
|
||||||
// If the message was a transaction queue the transaction
|
// If the message was a transaction queue the transaction
|
||||||
// in the TxPool where it will undergo validation and
|
// in the TxPool where it will undergo validation and
|
||||||
// processing when a new block is found
|
// processing when a new block is found
|
||||||
@ -432,10 +432,10 @@ func (p *Peer) HandleInbound() {
|
|||||||
tx := chain.NewTransactionFromValue(msg.Data.Get(i))
|
tx := chain.NewTransactionFromValue(msg.Data.Get(i))
|
||||||
p.ethereum.TxPool().QueueTransaction(tx)
|
p.ethereum.TxPool().QueueTransaction(tx)
|
||||||
}
|
}
|
||||||
case ethwire.MsgGetPeersTy:
|
case wire.MsgGetPeersTy:
|
||||||
// Peer asked for list of connected peers
|
// Peer asked for list of connected peers
|
||||||
//p.pushPeers()
|
//p.pushPeers()
|
||||||
case ethwire.MsgPeersTy:
|
case wire.MsgPeersTy:
|
||||||
// Received a list of peers (probably because MsgGetPeersTy was send)
|
// Received a list of peers (probably because MsgGetPeersTy was send)
|
||||||
data := msg.Data
|
data := msg.Data
|
||||||
// Create new list of possible peers for the ethereum to process
|
// Create new list of possible peers for the ethereum to process
|
||||||
@ -449,7 +449,7 @@ func (p *Peer) HandleInbound() {
|
|||||||
// Connect to the list of peers
|
// Connect to the list of peers
|
||||||
p.ethereum.ProcessPeerList(peers)
|
p.ethereum.ProcessPeerList(peers)
|
||||||
|
|
||||||
case ethwire.MsgStatusTy:
|
case wire.MsgStatusTy:
|
||||||
// Handle peer's status msg
|
// Handle peer's status msg
|
||||||
p.handleStatus(msg)
|
p.handleStatus(msg)
|
||||||
}
|
}
|
||||||
@ -458,7 +458,7 @@ func (p *Peer) HandleInbound() {
|
|||||||
if p.statusKnown {
|
if p.statusKnown {
|
||||||
switch msg.Type {
|
switch msg.Type {
|
||||||
/*
|
/*
|
||||||
case ethwire.MsgGetTxsTy:
|
case wire.MsgGetTxsTy:
|
||||||
// Get the current transactions of the pool
|
// Get the current transactions of the pool
|
||||||
txs := p.ethereum.TxPool().CurrentTransactions()
|
txs := p.ethereum.TxPool().CurrentTransactions()
|
||||||
// Get the RlpData values from the txs
|
// Get the RlpData values from the txs
|
||||||
@ -467,10 +467,10 @@ func (p *Peer) HandleInbound() {
|
|||||||
txsInterface[i] = tx.RlpData()
|
txsInterface[i] = tx.RlpData()
|
||||||
}
|
}
|
||||||
// Broadcast it back to the peer
|
// Broadcast it back to the peer
|
||||||
p.QueueMessage(ethwire.NewMessage(ethwire.MsgTxTy, txsInterface))
|
p.QueueMessage(wire.NewMessage(wire.MsgTxTy, txsInterface))
|
||||||
*/
|
*/
|
||||||
|
|
||||||
case ethwire.MsgGetBlockHashesTy:
|
case wire.MsgGetBlockHashesTy:
|
||||||
if msg.Data.Len() < 2 {
|
if msg.Data.Len() < 2 {
|
||||||
peerlogger.Debugln("err: argument length invalid ", msg.Data.Len())
|
peerlogger.Debugln("err: argument length invalid ", msg.Data.Len())
|
||||||
}
|
}
|
||||||
@ -480,9 +480,9 @@ func (p *Peer) HandleInbound() {
|
|||||||
|
|
||||||
hashes := p.ethereum.ChainManager().GetChainHashesFromHash(hash, amount)
|
hashes := p.ethereum.ChainManager().GetChainHashesFromHash(hash, amount)
|
||||||
|
|
||||||
p.QueueMessage(ethwire.NewMessage(ethwire.MsgBlockHashesTy, ethutil.ByteSliceToInterface(hashes)))
|
p.QueueMessage(wire.NewMessage(wire.MsgBlockHashesTy, ethutil.ByteSliceToInterface(hashes)))
|
||||||
|
|
||||||
case ethwire.MsgGetBlocksTy:
|
case wire.MsgGetBlocksTy:
|
||||||
// Limit to max 300 blocks
|
// Limit to max 300 blocks
|
||||||
max := int(math.Min(float64(msg.Data.Len()), 300.0))
|
max := int(math.Min(float64(msg.Data.Len()), 300.0))
|
||||||
var blocks []interface{}
|
var blocks []interface{}
|
||||||
@ -495,9 +495,9 @@ func (p *Peer) HandleInbound() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p.QueueMessage(ethwire.NewMessage(ethwire.MsgBlockTy, blocks))
|
p.QueueMessage(wire.NewMessage(wire.MsgBlockTy, blocks))
|
||||||
|
|
||||||
case ethwire.MsgBlockHashesTy:
|
case wire.MsgBlockHashesTy:
|
||||||
p.catchingUp = true
|
p.catchingUp = true
|
||||||
|
|
||||||
blockPool := p.ethereum.blockPool
|
blockPool := p.ethereum.blockPool
|
||||||
@ -528,7 +528,7 @@ func (p *Peer) HandleInbound() {
|
|||||||
p.doneFetchingHashes = true
|
p.doneFetchingHashes = true
|
||||||
}
|
}
|
||||||
|
|
||||||
case ethwire.MsgBlockTy:
|
case wire.MsgBlockTy:
|
||||||
p.catchingUp = true
|
p.catchingUp = true
|
||||||
|
|
||||||
blockPool := p.ethereum.blockPool
|
blockPool := p.ethereum.blockPool
|
||||||
@ -540,7 +540,7 @@ func (p *Peer) HandleInbound() {
|
|||||||
|
|
||||||
p.lastBlockReceived = time.Now()
|
p.lastBlockReceived = time.Now()
|
||||||
}
|
}
|
||||||
case ethwire.MsgNewBlockTy:
|
case wire.MsgNewBlockTy:
|
||||||
var (
|
var (
|
||||||
blockPool = p.ethereum.blockPool
|
blockPool = p.ethereum.blockPool
|
||||||
block = chain.NewBlockFromRlpValue(msg.Data.Get(0))
|
block = chain.NewBlockFromRlpValue(msg.Data.Get(0))
|
||||||
@ -563,7 +563,7 @@ func (self *Peer) FetchBlocks(hashes [][]byte) {
|
|||||||
if len(hashes) > 0 {
|
if len(hashes) > 0 {
|
||||||
peerlogger.Debugf("Fetching blocks (%d)\n", len(hashes))
|
peerlogger.Debugf("Fetching blocks (%d)\n", len(hashes))
|
||||||
|
|
||||||
self.QueueMessage(ethwire.NewMessage(ethwire.MsgGetBlocksTy, ethutil.ByteSliceToInterface(hashes)))
|
self.QueueMessage(wire.NewMessage(wire.MsgGetBlocksTy, ethutil.ByteSliceToInterface(hashes)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -629,7 +629,7 @@ func (p *Peer) Start() {
|
|||||||
|
|
||||||
// Wait a few seconds for startup and then ask for an initial ping
|
// Wait a few seconds for startup and then ask for an initial ping
|
||||||
time.Sleep(2 * time.Second)
|
time.Sleep(2 * time.Second)
|
||||||
p.writeMessage(ethwire.NewMessage(ethwire.MsgPingTy, ""))
|
p.writeMessage(wire.NewMessage(wire.MsgPingTy, ""))
|
||||||
p.pingStartTime = time.Now()
|
p.pingStartTime = time.Now()
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -648,12 +648,12 @@ func (p *Peer) StopWithReason(reason DiscReason) {
|
|||||||
|
|
||||||
close(p.quit)
|
close(p.quit)
|
||||||
if atomic.LoadInt32(&p.connected) != 0 {
|
if atomic.LoadInt32(&p.connected) != 0 {
|
||||||
p.writeMessage(ethwire.NewMessage(ethwire.MsgDiscTy, reason))
|
p.writeMessage(wire.NewMessage(wire.MsgDiscTy, reason))
|
||||||
p.conn.Close()
|
p.conn.Close()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Peer) peersMessage() *ethwire.Msg {
|
func (p *Peer) peersMessage() *wire.Msg {
|
||||||
outPeers := make([]interface{}, len(p.ethereum.InOutPeers()))
|
outPeers := make([]interface{}, len(p.ethereum.InOutPeers()))
|
||||||
// Serialise each peer
|
// Serialise each peer
|
||||||
for i, peer := range p.ethereum.InOutPeers() {
|
for i, peer := range p.ethereum.InOutPeers() {
|
||||||
@ -664,7 +664,7 @@ func (p *Peer) peersMessage() *ethwire.Msg {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Return the message to the peer with the known list of connected clients
|
// Return the message to the peer with the known list of connected clients
|
||||||
return ethwire.NewMessage(ethwire.MsgPeersTy, outPeers)
|
return wire.NewMessage(wire.MsgPeersTy, outPeers)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Pushes the list of outbound peers to the client when requested
|
// Pushes the list of outbound peers to the client when requested
|
||||||
@ -673,7 +673,7 @@ func (p *Peer) pushPeers() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (self *Peer) pushStatus() {
|
func (self *Peer) pushStatus() {
|
||||||
msg := ethwire.NewMessage(ethwire.MsgStatusTy, []interface{}{
|
msg := wire.NewMessage(wire.MsgStatusTy, []interface{}{
|
||||||
uint32(ProtocolVersion),
|
uint32(ProtocolVersion),
|
||||||
uint32(NetVersion),
|
uint32(NetVersion),
|
||||||
self.ethereum.ChainManager().TD,
|
self.ethereum.ChainManager().TD,
|
||||||
@ -684,7 +684,7 @@ func (self *Peer) pushStatus() {
|
|||||||
self.QueueMessage(msg)
|
self.QueueMessage(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (self *Peer) handleStatus(msg *ethwire.Msg) {
|
func (self *Peer) handleStatus(msg *wire.Msg) {
|
||||||
c := msg.Data
|
c := msg.Data
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -729,7 +729,7 @@ func (self *Peer) handleStatus(msg *ethwire.Msg) {
|
|||||||
|
|
||||||
func (p *Peer) pushHandshake() error {
|
func (p *Peer) pushHandshake() error {
|
||||||
pubkey := p.ethereum.KeyManager().PublicKey()
|
pubkey := p.ethereum.KeyManager().PublicKey()
|
||||||
msg := ethwire.NewMessage(ethwire.MsgHandshakeTy, []interface{}{
|
msg := wire.NewMessage(wire.MsgHandshakeTy, []interface{}{
|
||||||
P2PVersion, []byte(p.version), []interface{}{[]interface{}{"eth", ProtocolVersion}}, p.port, pubkey[1:],
|
P2PVersion, []byte(p.version), []interface{}{[]interface{}{"eth", ProtocolVersion}}, p.port, pubkey[1:],
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -738,7 +738,7 @@ func (p *Peer) pushHandshake() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Peer) handleHandshake(msg *ethwire.Msg) {
|
func (p *Peer) handleHandshake(msg *wire.Msg) {
|
||||||
c := msg.Data
|
c := msg.Data
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
0
ethwire/.gitignore → wire/.gitignore
vendored
0
ethwire/.gitignore → wire/.gitignore
vendored
@ -1,4 +1,4 @@
|
|||||||
package ethwire
|
package wire
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package ethwire
|
package wire
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package ethwire
|
package wire
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
@ -113,7 +113,7 @@ func (self *Connection) readMessages() (err error) {
|
|||||||
// The recovering function in case anything goes horribly wrong
|
// The recovering function in case anything goes horribly wrong
|
||||||
defer func() {
|
defer func() {
|
||||||
if r := recover(); r != nil {
|
if r := recover(); r != nil {
|
||||||
err = fmt.Errorf("ethwire.ReadMessage error: %v", r)
|
err = fmt.Errorf("wire.ReadMessage error: %v", r)
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
@ -1,6 +1,6 @@
|
|||||||
// Package ethwire provides low level access to the Ethereum network and allows
|
// Package wire provides low level access to the Ethereum network and allows
|
||||||
// you to broadcast data over the network.
|
// you to broadcast data over the network.
|
||||||
package ethwire
|
package wire
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
@ -85,7 +85,7 @@ func ReadMessages(conn net.Conn) (msgs []*Msg, err error) {
|
|||||||
// The recovering function in case anything goes horribly wrong
|
// The recovering function in case anything goes horribly wrong
|
||||||
defer func() {
|
defer func() {
|
||||||
if r := recover(); r != nil {
|
if r := recover(); r != nil {
|
||||||
err = fmt.Errorf("ethwire.ReadMessage error: %v", r)
|
err = fmt.Errorf("wire.ReadMessage error: %v", r)
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user