peer.go 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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/diff"
  22. "github.com/ethereum/go-ethereum/eth/protocols/eth"
  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. diffExt *diffPeer
  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. // diffPeerInfo represents a short summary of the `diff` sub-protocol metadata known
  56. // about a connected peer.
  57. type diffPeerInfo struct {
  58. Version uint `json:"version"` // diff protocol version negotiated
  59. DiffSync bool `json:"diff_sync"`
  60. }
  61. // snapPeer is a wrapper around snap.Peer to maintain a few extra metadata.
  62. type snapPeer struct {
  63. *snap.Peer
  64. }
  65. // diffPeer is a wrapper around diff.Peer to maintain a few extra metadata.
  66. type diffPeer struct {
  67. *diff.Peer
  68. }
  69. // info gathers and returns some `diff` protocol metadata known about a peer.
  70. func (p *diffPeer) info() *diffPeerInfo {
  71. return &diffPeerInfo{
  72. Version: p.Version(),
  73. DiffSync: p.DiffSync(),
  74. }
  75. }
  76. // info gathers and returns some `snap` protocol metadata known about a peer.
  77. func (p *snapPeer) info() *snapPeerInfo {
  78. return &snapPeerInfo{
  79. Version: p.Version(),
  80. }
  81. }