peer.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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/qlight"
  23. "github.com/ethereum/go-ethereum/eth/protocols/snap"
  24. )
  25. // ethPeerInfo represents a short summary of the `eth` sub-protocol metadata known
  26. // about a connected peer.
  27. type ethPeerInfo struct {
  28. Version uint `json:"version"` // Ethereum protocol version negotiated
  29. Difficulty *big.Int `json:"difficulty"` // Total difficulty of the peer's blockchain
  30. Head string `json:"head"` // Hex hash of the peer's best owned block
  31. }
  32. // ethPeer is a wrapper around eth.Peer to maintain a few extra metadata.
  33. type ethPeer struct {
  34. *eth.Peer
  35. snapExt *snapPeer // Satellite `snap` connection
  36. qlight *qlight.Peer
  37. syncDrop *time.Timer // Connection dropper if `eth` sync progress isn't validated in time
  38. snapWait chan struct{} // Notification channel for snap connections
  39. lock sync.RWMutex // Mutex protecting the internal fields
  40. }
  41. // info gathers and returns some `eth` protocol metadata known about a peer.
  42. func (p *ethPeer) info() *ethPeerInfo {
  43. hash, td := p.Head()
  44. return &ethPeerInfo{
  45. Version: p.Version(),
  46. Difficulty: td,
  47. Head: hash.Hex(),
  48. }
  49. }
  50. // snapPeerInfo represents a short summary of the `snap` sub-protocol metadata known
  51. // about a connected peer.
  52. type snapPeerInfo struct {
  53. Version uint `json:"version"` // Snapshot protocol version negotiated
  54. }
  55. // snapPeer is a wrapper around snap.Peer to maintain a few extra metadata.
  56. type snapPeer struct {
  57. *snap.Peer
  58. }
  59. // info gathers and returns some `snap` protocol metadata known about a peer.
  60. func (p *snapPeer) info() *snapPeerInfo {
  61. return &snapPeerInfo{
  62. Version: p.Version(),
  63. }
  64. }