peer.go 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // Copyright 2015 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package eth
  17. import (
  18. "math/big"
  19. "sync"
  20. "time"
  21. "github.com/ethereum/go-ethereum/eth/protocols/eth"
  22. "github.com/ethereum/go-ethereum/eth/protocols/snap"
  23. )
  24. // ethPeerInfo represents a short summary of the `eth` sub-protocol metadata known
  25. // about a connected peer.
  26. type ethPeerInfo struct {
  27. Version uint `json:"version"` // Ethereum protocol version negotiated
  28. Difficulty *big.Int `json:"difficulty"` // Total difficulty of the peer's blockchain
  29. Head string `json:"head"` // Hex hash of the peer's best owned block
  30. }
  31. // ethPeer is a wrapper around eth.Peer to maintain a few extra metadata.
  32. type ethPeer struct {
  33. *eth.Peer
  34. syncDrop *time.Timer // Connection dropper if `eth` sync progress isn't validated in time
  35. lock sync.RWMutex // Mutex protecting the internal fields
  36. }
  37. // info gathers and returns some `eth` protocol metadata known about a peer.
  38. func (p *ethPeer) info() *ethPeerInfo {
  39. hash, td := p.Head()
  40. return &ethPeerInfo{
  41. Version: p.Version(),
  42. Difficulty: td,
  43. Head: hash.Hex(),
  44. }
  45. }
  46. // snapPeerInfo represents a short summary of the `snap` sub-protocol metadata known
  47. // about a connected peer.
  48. type snapPeerInfo struct {
  49. Version uint `json:"version"` // Snapshot protocol version negotiated
  50. }
  51. // snapPeer is a wrapper around snap.Peer to maintain a few extra metadata.
  52. type snapPeer struct {
  53. *snap.Peer
  54. ethDrop *time.Timer // Connection dropper if `eth` doesn't connect in time
  55. lock sync.RWMutex // Mutex protecting the internal fields
  56. }
  57. // info gathers and returns some `snap` protocol metadata known about a peer.
  58. func (p *snapPeer) info() *snapPeerInfo {
  59. return &snapPeerInfo{
  60. Version: p.Version(),
  61. }
  62. }