Use strongly-typed objects
This commit is contained in:
parent
c14900dbb0
commit
d53e5646ec
@ -222,14 +222,13 @@ func (s *Ethereum) MaxPeers() int {
|
|||||||
|
|
||||||
// Start the ethereum
|
// Start the ethereum
|
||||||
func (s *Ethereum) Start(seed bool) error {
|
func (s *Ethereum) Start(seed bool) error {
|
||||||
evd := map[string]interface{}{
|
jsonlogger.LogJson("starting", ðlogger.LogStarting{
|
||||||
"version_string": s.ClientIdentity().String(),
|
ClientString: s.ClientIdentity().String(),
|
||||||
"guid": ethutil.Bytes2Hex(s.ClientIdentity().Pubkey()),
|
Guid: ethutil.Bytes2Hex(s.ClientIdentity().Pubkey()),
|
||||||
"level": "debug",
|
Coinbase: ethutil.Bytes2Hex(s.KeyManager().Address()),
|
||||||
"coinbase": ethutil.Bytes2Hex(s.KeyManager().Address()),
|
ProtocolVersion: ProtocolVersion,
|
||||||
"eth_version": ProtocolVersion,
|
})
|
||||||
}
|
|
||||||
jsonlogger.LogJson("starting", evd)
|
|
||||||
err := s.net.Start()
|
err := s.net.Start()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -16,7 +16,6 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"time"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type LogLevel uint32
|
type LogLevel uint32
|
||||||
@ -121,20 +120,12 @@ func NewJsonLogger() *JsonLogger {
|
|||||||
return &JsonLogger{}
|
return &JsonLogger{}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (logger *JsonLogger) LogJson(msgname string, dict map[string]interface{}) {
|
func (logger *JsonLogger) LogJson(msgname string, v interface{}) {
|
||||||
if _, ok := dict["ts"]; !ok {
|
|
||||||
dict["ts"] = time.Now().Local().Format(time.RFC3339Nano)
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIX
|
|
||||||
if _, ok := dict["level"]; !ok {
|
|
||||||
dict["level"] = "debug"
|
|
||||||
}
|
|
||||||
|
|
||||||
obj := map[string]interface{}{
|
obj := map[string]interface{}{
|
||||||
msgname: dict,
|
msgname: v,
|
||||||
}
|
}
|
||||||
|
|
||||||
jsontxt, _ := json.Marshal(obj)
|
jsontxt, _ := json.Marshal(obj)
|
||||||
logMessageC <- message{JsonLevel, fmt.Sprintf("%s", jsontxt)}
|
logMessageC <- message{JsonLevel, string(jsontxt)}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
294
logger/types.go
Normal file
294
logger/types.go
Normal file
@ -0,0 +1,294 @@
|
|||||||
|
package logger
|
||||||
|
|
||||||
|
import (
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
type utctime8601 struct{}
|
||||||
|
|
||||||
|
func (utctime8601) MarshalJSON() ([]byte, error) {
|
||||||
|
// FIX This should be re-formated for proper ISO 8601
|
||||||
|
return []byte(`"` + time.Now().UTC().Format(time.RFC3339Nano)[:26] + `Z"`), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
//"starting"
|
||||||
|
type LogStarting struct {
|
||||||
|
ClientString string `json:"version_string"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
Coinbase string `json:"coinbase"`
|
||||||
|
ProtocolVersion int `json:"eth_version"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.connecting"
|
||||||
|
type P2PConnecting struct {
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
RemoteEndpoint string `json:"remote_endpoint"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.connected"
|
||||||
|
type P2PConnected struct {
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.handshaked"
|
||||||
|
type P2PHandshaked struct {
|
||||||
|
RemoteCapabilities []string `json:"remote_capabilities"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts string `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.disconnected"
|
||||||
|
type P2PDisconnected struct {
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.disconnecting"
|
||||||
|
type P2PDisconnecting struct {
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.disconnecting.bad_handshake"
|
||||||
|
type P2PDisconnectingBadHandshake struct {
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.disconnecting.bad_protocol"
|
||||||
|
type P2PDisconnectingBadProtocol struct {
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.disconnecting.reputation"
|
||||||
|
type P2PDisconnectingReputation struct {
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.disconnecting.dht"
|
||||||
|
type P2PDisconnectingDHT struct {
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.eth.disconnecting.bad_block"
|
||||||
|
type P2PEthDisconnectingBadBlock struct {
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"p2p.eth.disconnecting.bad_tx"
|
||||||
|
type P2PEthDisconnectingBadTx struct {
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
NumConnections int `json:"num_connections"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.mined"
|
||||||
|
type EthNewBlockMined struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockHexRlp string `json:"block_hexrlp"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.broadcasted"
|
||||||
|
type EthNewBlockBroadcasted struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.received"
|
||||||
|
type EthNewBlockReceived struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.is_known"
|
||||||
|
type EthNewBlockIsKnown struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.is_new"
|
||||||
|
type EthNewBlockIsNew struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.missing_parent"
|
||||||
|
type EthNewBlockMissingParent struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.is_invalid"
|
||||||
|
type EthNewBlockIsInvalid struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.chain.is_older"
|
||||||
|
type EthNewBlockChainIsOlder struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.chain.is_cannonical"
|
||||||
|
type EthNewBlockChainIsCanonical struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.chain.not_cannonical"
|
||||||
|
type EthNewBlockChainNotCanonical struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.newblock.chain.switched"
|
||||||
|
type EthNewBlockChainSwitched struct {
|
||||||
|
BlockNumber int `json:"block_number"`
|
||||||
|
HeadHash string `json:"head_hash"`
|
||||||
|
OldHeadHash string `json:"old_head_hash"`
|
||||||
|
BlockHash string `json:"block_hash"`
|
||||||
|
BlockDifficulty int `json:"block_difficulty"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
BlockPrevHash string `json:"block_prev_hash"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.tx.created"
|
||||||
|
type EthTxCreated struct {
|
||||||
|
TxHash string `json:"tx_hash"`
|
||||||
|
TxSender string `json:"tx_sender"`
|
||||||
|
TxAddress string `json:"tx_address"`
|
||||||
|
TxHexRLP string `json:"tx_hexrlp"`
|
||||||
|
TxNonce int `json:"tx_nonce"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.tx.received"
|
||||||
|
type EthTxReceived struct {
|
||||||
|
TxHash string `json:"tx_hash"`
|
||||||
|
TxAddress string `json:"tx_address"`
|
||||||
|
TxHexRLP string `json:"tx_hexrlp"`
|
||||||
|
RemoteId string `json:"remote_id"`
|
||||||
|
TxNonce int `json:"tx_nonce"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.tx.broadcasted"
|
||||||
|
type EthTxBroadcasted struct {
|
||||||
|
TxHash string `json:"tx_hash"`
|
||||||
|
TxSender string `json:"tx_sender"`
|
||||||
|
TxAddress string `json:"tx_address"`
|
||||||
|
TxNonce int `json:"tx_nonce"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.tx.validated"
|
||||||
|
type EthTxValidated struct {
|
||||||
|
TxHash string `json:"tx_hash"`
|
||||||
|
TxSender string `json:"tx_sender"`
|
||||||
|
TxAddress string `json:"tx_address"`
|
||||||
|
TxNonce int `json:"tx_nonce"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
||||||
|
|
||||||
|
//"eth.tx.is_invalid"
|
||||||
|
type EthTxIsInvalid struct {
|
||||||
|
TxHash string `json:"tx_hash"`
|
||||||
|
TxSender string `json:"tx_sender"`
|
||||||
|
TxAddress string `json:"tx_address"`
|
||||||
|
Reason string `json:"reason"`
|
||||||
|
TxNonce int `json:"tx_nonce"`
|
||||||
|
Guid string `json:"guid"`
|
||||||
|
Ts utctime8601 `json:"ts"`
|
||||||
|
}
|
@ -8,7 +8,6 @@ import (
|
|||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/ethutil"
|
|
||||||
"github.com/ethereum/go-ethereum/logger"
|
"github.com/ethereum/go-ethereum/logger"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -356,25 +355,9 @@ func (srv *Server) dialLoop() {
|
|||||||
// connect to peer via dial out
|
// connect to peer via dial out
|
||||||
func (srv *Server) dialPeer(desc *peerAddr, slot int) {
|
func (srv *Server) dialPeer(desc *peerAddr, slot int) {
|
||||||
srvlog.Debugf("Dialing %v (slot %d)\n", desc, slot)
|
srvlog.Debugf("Dialing %v (slot %d)\n", desc, slot)
|
||||||
evd := map[string]interface{}{
|
|
||||||
"remote_id": ethutil.Bytes2Hex(desc.Pubkey),
|
|
||||||
"remote_endpoint": desc.String(),
|
|
||||||
"level": "debug",
|
|
||||||
"guid": ethutil.Bytes2Hex(srv.Identity.Pubkey()),
|
|
||||||
"num_connections": srv.PeerCount(),
|
|
||||||
}
|
|
||||||
jsonlogger.LogJson("p2p.connecting", evd)
|
|
||||||
conn, err := srv.Dialer.Dial(desc.Network(), desc.String())
|
conn, err := srv.Dialer.Dial(desc.Network(), desc.String())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
srvlog.DebugDetailf("dial error: %v", err)
|
srvlog.DebugDetailf("dial error: %v", err)
|
||||||
evd := map[string]interface{}{
|
|
||||||
"reason": "dial error",
|
|
||||||
"remote_id": desc.String(),
|
|
||||||
"level": "debug",
|
|
||||||
"guid": ethutil.Bytes2Hex(srv.Identity.Pubkey()),
|
|
||||||
"num_connections": srv.PeerCount(),
|
|
||||||
}
|
|
||||||
jsonlogger.LogJson("p2p.disconnecting", evd)
|
|
||||||
srv.peerSlots <- slot
|
srv.peerSlots <- slot
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -395,13 +378,6 @@ func (srv *Server) addPeer(conn net.Conn, desc *peerAddr, slot int) *Peer {
|
|||||||
srv.peers[slot] = peer
|
srv.peers[slot] = peer
|
||||||
srv.peerCount++
|
srv.peerCount++
|
||||||
go func() {
|
go func() {
|
||||||
evd := map[string]interface{}{
|
|
||||||
"guid": ethutil.Bytes2Hex(srv.Identity.Pubkey()),
|
|
||||||
"num_connections": srv.PeerCount(),
|
|
||||||
"remote_id": desc.String(),
|
|
||||||
"level": "debug",
|
|
||||||
}
|
|
||||||
jsonlogger.LogJson("p2p.connected", evd)
|
|
||||||
peer.loop()
|
peer.loop()
|
||||||
srv.peerDisconnect <- peer
|
srv.peerDisconnect <- peer
|
||||||
}()
|
}()
|
||||||
@ -422,36 +398,13 @@ func (srv *Server) removePeer(peer *Peer) {
|
|||||||
srv.peers[peer.slot] = nil
|
srv.peers[peer.slot] = nil
|
||||||
// release slot to signal need for a new peer, last!
|
// release slot to signal need for a new peer, last!
|
||||||
srv.peerSlots <- peer.slot
|
srv.peerSlots <- peer.slot
|
||||||
evd := map[string]interface{}{
|
|
||||||
"guid": ethutil.Bytes2Hex(srv.Identity.Pubkey()),
|
|
||||||
"num_connections": srv.PeerCount(),
|
|
||||||
"remote_id": ethutil.Bytes2Hex(peer.Identity().Pubkey()),
|
|
||||||
"level": "debug",
|
|
||||||
}
|
|
||||||
jsonlogger.LogJson("p2p.disconnected", evd)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (srv *Server) verifyPeer(addr *peerAddr) error {
|
func (srv *Server) verifyPeer(addr *peerAddr) error {
|
||||||
if srv.Blacklist.Exists(addr.Pubkey) {
|
if srv.Blacklist.Exists(addr.Pubkey) {
|
||||||
evd := map[string]interface{}{
|
|
||||||
"reason": "blacklisted",
|
|
||||||
"remote_id": addr.String(),
|
|
||||||
"level": "debug",
|
|
||||||
"guid": ethutil.Bytes2Hex(srv.Identity.Pubkey()),
|
|
||||||
"num_connections": srv.PeerCount(),
|
|
||||||
}
|
|
||||||
jsonlogger.LogJson("p2p.disconnecting.reputation", evd)
|
|
||||||
return errors.New("blacklisted")
|
return errors.New("blacklisted")
|
||||||
}
|
}
|
||||||
if bytes.Equal(srv.Identity.Pubkey()[1:], addr.Pubkey) {
|
if bytes.Equal(srv.Identity.Pubkey()[1:], addr.Pubkey) {
|
||||||
evd := map[string]interface{}{
|
|
||||||
"reason": "not allowed to connect to srv",
|
|
||||||
"remote_id": addr.String(),
|
|
||||||
"level": "debug",
|
|
||||||
"guid": ethutil.Bytes2Hex(srv.Identity.Pubkey()),
|
|
||||||
"num_connections": srv.PeerCount(),
|
|
||||||
}
|
|
||||||
jsonlogger.LogJson("p2p.disconnecting", evd)
|
|
||||||
return newPeerError(errPubkeyForbidden, "not allowed to connect to srv")
|
return newPeerError(errPubkeyForbidden, "not allowed to connect to srv")
|
||||||
}
|
}
|
||||||
srv.lock.RLock()
|
srv.lock.RLock()
|
||||||
@ -460,14 +413,6 @@ func (srv *Server) verifyPeer(addr *peerAddr) error {
|
|||||||
if peer != nil {
|
if peer != nil {
|
||||||
id := peer.Identity()
|
id := peer.Identity()
|
||||||
if id != nil && bytes.Equal(id.Pubkey(), addr.Pubkey) {
|
if id != nil && bytes.Equal(id.Pubkey(), addr.Pubkey) {
|
||||||
evd := map[string]interface{}{
|
|
||||||
"reason": "already connected",
|
|
||||||
"remote_id": addr.String(),
|
|
||||||
"level": "debug",
|
|
||||||
"guid": ethutil.Bytes2Hex(srv.Identity.Pubkey()),
|
|
||||||
"num_connections": srv.PeerCount(),
|
|
||||||
}
|
|
||||||
jsonlogger.LogJson("p2p.disconnecting", evd)
|
|
||||||
return errors.New("already connected")
|
return errors.New("already connected")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user