mukan-ibc/modules/light-clients/06-solomachine/misbehaviour.go
Mukan Erkin Törük 88dd97a9f8
Some checks failed
CodeQL / Analyze (push) Waiting to run
golangci-lint / lint (push) Waiting to run
Tests / Code Coverage / build (amd64) (push) Waiting to run
Tests / Code Coverage / build (arm64) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[additional-args:-tags="test_e2e" name:e2e path:./e2e]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:08-wasm path:./modules/light-clients/08-wasm]) (push) Waiting to run
Tests / Code Coverage / unit-tests (map[name:ibc-go path:.]) (push) Waiting to run
Docker Build & Push Simapp (main) / docker-build (push) Has been cancelled
refactor: replace all github.com upstream refs with git.cw.tr/mukan-network
2026-05-11 03:36:22 +03:00

63 lines
2.1 KiB
Go

package solomachine
import (
"bytes"
errorsmod "cosmossdk.io/errors"
clienttypes "git.cw.tr/mukan-network/mukan-ibc/modules/core/02-client/types"
"git.cw.tr/mukan-network/mukan-ibc/modules/core/exported"
)
var _ exported.ClientMessage = (*Misbehaviour)(nil)
// ClientType is a Solo Machine light client.
func (Misbehaviour) ClientType() string {
return exported.Solomachine
}
// ValidateBasic implements Misbehaviour interface.
func (misbehaviour Misbehaviour) ValidateBasic() error {
if misbehaviour.Sequence == 0 {
return errorsmod.Wrap(clienttypes.ErrInvalidMisbehaviour, "sequence cannot be 0")
}
if err := misbehaviour.SignatureOne.ValidateBasic(); err != nil {
return errorsmod.Wrap(err, "signature one failed basic validation")
}
if err := misbehaviour.SignatureTwo.ValidateBasic(); err != nil {
return errorsmod.Wrap(err, "signature two failed basic validation")
}
// misbehaviour signatures cannot be identical.
if bytes.Equal(misbehaviour.SignatureOne.Signature, misbehaviour.SignatureTwo.Signature) {
return errorsmod.Wrap(clienttypes.ErrInvalidMisbehaviour, "misbehaviour signatures cannot be equal")
}
// message data signed cannot be identical if both paths are the same.
if bytes.Equal(misbehaviour.SignatureOne.Path, misbehaviour.SignatureTwo.Path) &&
bytes.Equal(misbehaviour.SignatureOne.Data, misbehaviour.SignatureTwo.Data) {
return errorsmod.Wrap(clienttypes.ErrInvalidMisbehaviour, "misbehaviour signature data must be signed over different messages")
}
return nil
}
// ValidateBasic ensures that the signature and data fields are non-empty.
func (sd SignatureAndData) ValidateBasic() error {
if len(sd.Signature) == 0 {
return errorsmod.Wrap(ErrInvalidSignatureAndData, "signature cannot be empty")
}
if len(sd.Data) == 0 {
return errorsmod.Wrap(ErrInvalidSignatureAndData, "data for signature cannot be empty")
}
if len(sd.Path) == 0 {
return errorsmod.Wrap(ErrInvalidSignatureAndData, "path for signature cannot be empty")
}
if sd.Timestamp == 0 {
return errorsmod.Wrap(ErrInvalidSignatureAndData, "timestamp cannot be 0")
}
return nil
}