peer.go 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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. snapExt *snapPeer // Satellite `snap` connection
  35. syncDrop *time.Timer // Connection dropper if `eth` sync progress isn't validated in time
  36. snapWait chan struct{} // Notification channel for snap connections
  37. lock sync.RWMutex // Mutex protecting the internal fields
  38. }
  39. // info gathers and returns some `eth` protocol metadata known about a peer.
  40. func (p *ethPeer) info() *ethPeerInfo {
  41. hash, td := p.Head()
  42. return &ethPeerInfo{
  43. Version: p.Version(),
  44. Difficulty: td,
  45. Head: hash.Hex(),
  46. }
  47. }
  48. // snapPeerInfo represents a short summary of the `snap` sub-protocol metadata known
  49. // about a connected peer.
  50. type snapPeerInfo struct {
  51. Version uint `json:"version"` // Snapshot protocol version negotiated
  52. }
  53. // snapPeer is a wrapper around snap.Peer to maintain a few extra metadata.
  54. type snapPeer struct {
  55. *snap.Peer
  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. }