mirror of
https://github.com/status-im/status-go.git
synced 2025-01-15 01:05:06 +00:00
52a1bdfed6
This commit updates geth to 1.8.17 and adds a possibility to enable metrics during compilation time. The cascade of issues forced us to upgrade geth to 1.8.17 in order to allow enabling metrics during compilation time. 1.8.17 introduced `NodeID` refactoring and `enode` package which affected our peers pool and integration with Discovery V5.
45 lines
1.3 KiB
Go
45 lines
1.3 KiB
Go
package registry
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/ethereum/go-ethereum/accounts/abi/bind"
|
|
"github.com/ethereum/go-ethereum/common"
|
|
"github.com/ethereum/go-ethereum/log"
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
|
)
|
|
|
|
var logger = log.New("package", "mailserver/registry")
|
|
|
|
// Verifier verifies nodes based on a smart contract.
|
|
type Verifier struct {
|
|
rc *RegistryCaller
|
|
}
|
|
|
|
// NewVerifier returns a new Verifier instance.
|
|
func NewVerifier(contractCaller bind.ContractCaller, contractAddress common.Address) (*Verifier, error) {
|
|
logger.Debug("initializing mailserver registry verifier", "address", fmt.Sprintf("0x%x", contractAddress))
|
|
rc, err := NewRegistryCaller(contractAddress, contractCaller)
|
|
if err != nil {
|
|
logger.Debug("error initializing mailserver registry verifier", "address", fmt.Sprintf("0x%x", contractAddress))
|
|
return nil, err
|
|
}
|
|
|
|
return &Verifier{
|
|
rc: rc,
|
|
}, nil
|
|
}
|
|
|
|
// VerifyNode checks if a given node is trusted using a smart contract.
|
|
func (v *Verifier) VerifyNode(ctx context.Context, nodeID enode.ID) bool {
|
|
res, err := v.rc.Exists(&bind.CallOpts{Context: ctx}, nodeID.Bytes())
|
|
logger.Debug("verifying node", "id", nodeID, "verified", res)
|
|
if err != nil {
|
|
logger.Error("error verifying node", "id", nodeID, "error", err)
|
|
return false
|
|
}
|
|
|
|
return res
|
|
}
|