33 lines
1.1 KiB
Go
33 lines
1.1 KiB
Go
package evidence
|
|
|
|
import (
|
|
"fmt"
|
|
"time"
|
|
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
|
|
|
"github.com/cosmos/cosmos-sdk/telemetry"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/x/evidence/keeper"
|
|
"github.com/cosmos/cosmos-sdk/x/evidence/types"
|
|
)
|
|
|
|
// BeginBlocker iterates through and handles any newly discovered evidence of
|
|
// misbehavior submitted by Tendermint. Currently, only equivocation is handled.
|
|
func BeginBlocker(ctx sdk.Context, req abci.RequestBeginBlock, k keeper.Keeper) {
|
|
defer telemetry.ModuleMeasureSince(types.ModuleName, time.Now(), telemetry.MetricKeyBeginBlocker)
|
|
|
|
for _, tmEvidence := range req.ByzantineValidators {
|
|
switch tmEvidence.Type {
|
|
// It's still ongoing discussion how should we treat and slash attacks with
|
|
// premeditation. So for now we agree to treat them in the same way.
|
|
case abci.EvidenceType_DUPLICATE_VOTE, abci.EvidenceType_LIGHT_CLIENT_ATTACK:
|
|
evidence := types.FromABCIEvidence(tmEvidence)
|
|
k.HandleEquivocationEvidence(ctx, evidence.(*types.Equivocation))
|
|
|
|
default:
|
|
k.Logger(ctx).Error(fmt.Sprintf("ignored unknown evidence type: %s", tmEvidence.Type))
|
|
}
|
|
}
|
|
}
|