mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-27 15:35:17 +00:00
x/auction: types validation
This commit is contained in:
parent
04cb414593
commit
32213ed56c
@ -1,7 +1,9 @@
|
|||||||
package types
|
package types
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
@ -66,15 +68,39 @@ func (a BaseAuction) GetType() string { return "base" }
|
|||||||
|
|
||||||
// Validate verifies that the auction end time is before max end time
|
// Validate verifies that the auction end time is before max end time
|
||||||
func (a BaseAuction) Validate() error {
|
func (a BaseAuction) Validate() error {
|
||||||
if a.EndTime.After(a.MaxEndTime) {
|
if a.ID == 0 {
|
||||||
return fmt.Errorf("MaxEndTime < EndTime (%s < %s)", a.MaxEndTime, a.EndTime)
|
return errors.New("auction id cannot be zero")
|
||||||
|
}
|
||||||
|
if strings.TrimSpace(a.Initiator) == "" {
|
||||||
|
return errors.New("auction initiator cannot be blank")
|
||||||
}
|
}
|
||||||
if !a.Lot.IsValid() {
|
if !a.Lot.IsValid() {
|
||||||
return fmt.Errorf("invalid lot: %s", a.Lot)
|
return fmt.Errorf("invalid lot: %s", a.Lot)
|
||||||
}
|
}
|
||||||
|
if a.Bidder.Empty() {
|
||||||
|
return errors.New("auction bidder cannot be empty")
|
||||||
|
}
|
||||||
|
if len(a.Bidder) != sdk.AddrLen {
|
||||||
|
return fmt.Errorf("the expected bidder address length is %d, actual length is %d", sdk.AddrLen, len(a.Bidder))
|
||||||
|
}
|
||||||
|
if len(a.Bidder.Bytes()) != sdk.AddrLen {
|
||||||
|
return errors.New("auction bidder cannot be empty")
|
||||||
|
}
|
||||||
if !a.Bid.IsValid() {
|
if !a.Bid.IsValid() {
|
||||||
return fmt.Errorf("invalid bid: %s", a.Bid)
|
return fmt.Errorf("invalid bid: %s", a.Bid)
|
||||||
}
|
}
|
||||||
|
if a.EndTime.IsZero() || a.MaxEndTime.IsZero() {
|
||||||
|
return errors.New("end time cannot be zero")
|
||||||
|
}
|
||||||
|
if a.EndTime.After(a.MaxEndTime) {
|
||||||
|
return fmt.Errorf("MaxEndTime < EndTime (%s < %s)", a.MaxEndTime, a.EndTime)
|
||||||
|
}
|
||||||
|
if a.HasReceivedBids && !a.Bid.IsPositive() {
|
||||||
|
return fmt.Errorf("cannot have a zero value bid when auction has a true HasReceivedBids flag value")
|
||||||
|
}
|
||||||
|
if !a.HasReceivedBids && a.Bid.IsPositive() {
|
||||||
|
return fmt.Errorf("cannot have a positive value bid when auction has a false HasReceivedBids flag value")
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,6 +180,7 @@ func (a DebtAuction) GetModuleAccountCoins() sdk.Coins {
|
|||||||
// GetPhase returns the direction of a debt auction, which never changes.
|
// GetPhase returns the direction of a debt auction, which never changes.
|
||||||
func (a DebtAuction) GetPhase() string { return "reverse" }
|
func (a DebtAuction) GetPhase() string { return "reverse" }
|
||||||
|
|
||||||
|
// Validate validates the DebtAuction fields values.
|
||||||
func (a DebtAuction) Validate() error {
|
func (a DebtAuction) Validate() error {
|
||||||
if !a.CorrespondingDebt.IsValid() {
|
if !a.CorrespondingDebt.IsValid() {
|
||||||
return fmt.Errorf("invalid corresponding debt: %s", a.CorrespondingDebt)
|
return fmt.Errorf("invalid corresponding debt: %s", a.CorrespondingDebt)
|
||||||
@ -221,6 +248,7 @@ func (a CollateralAuction) GetPhase() string {
|
|||||||
return "forward"
|
return "forward"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Validate validates the CollateralAuction fields values.
|
||||||
func (a CollateralAuction) Validate() error {
|
func (a CollateralAuction) Validate() error {
|
||||||
if !a.CorrespondingDebt.IsValid() {
|
if !a.CorrespondingDebt.IsValid() {
|
||||||
return fmt.Errorf("invalid corresponding debt: %s", a.CorrespondingDebt)
|
return fmt.Errorf("invalid corresponding debt: %s", a.CorrespondingDebt)
|
||||||
@ -292,9 +320,16 @@ func (wa WeightedAddresses) Validate() error {
|
|||||||
if len(wa.Addresses) != len(wa.Weights) {
|
if len(wa.Addresses) != len(wa.Weights) {
|
||||||
return fmt.Errorf("number of addresses doesn't match number of weights, %d ≠ %d", len(wa.Addresses), len(wa.Weights))
|
return fmt.Errorf("number of addresses doesn't match number of weights, %d ≠ %d", len(wa.Addresses), len(wa.Weights))
|
||||||
}
|
}
|
||||||
for _, w := range wa.Weights {
|
|
||||||
if w.IsNegative() {
|
for i := range wa.Addresses {
|
||||||
return fmt.Errorf("weights contain a negative amount: %s", w)
|
if wa.Addresses[i].Empty() {
|
||||||
|
return fmt.Errorf("address %d cannot be empty", i)
|
||||||
|
}
|
||||||
|
if len(wa.Addresses[i]) != sdk.AddrLen {
|
||||||
|
return fmt.Errorf("address %d has an invalid length: expectd %d, got %d", i, sdk.AddrLen, len(wa.Addresses[i]))
|
||||||
|
}
|
||||||
|
if wa.Weights[i].IsNegative() {
|
||||||
|
return fmt.Errorf("weight %d contains a negative amount: %s", i, wa.Weights[i])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package types
|
package types
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
sdk "github.com/cosmos/cosmos-sdk/types"
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||||||
@ -34,9 +35,15 @@ func (msg MsgPlaceBid) Type() string { return "place_bid" }
|
|||||||
|
|
||||||
// ValidateBasic does a simple validation check that doesn't require access to state.
|
// ValidateBasic does a simple validation check that doesn't require access to state.
|
||||||
func (msg MsgPlaceBid) ValidateBasic() error {
|
func (msg MsgPlaceBid) ValidateBasic() error {
|
||||||
|
if msg.AuctionID == 0 {
|
||||||
|
return errors.New("auction id cannot be zero")
|
||||||
|
}
|
||||||
if msg.Bidder.Empty() {
|
if msg.Bidder.Empty() {
|
||||||
return sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, "bidder address cannot be empty")
|
return sdkerrors.Wrap(sdkerrors.ErrInvalidAddress, "bidder address cannot be empty")
|
||||||
}
|
}
|
||||||
|
if len(msg.Bidder) != sdk.AddrLen {
|
||||||
|
return fmt.Errorf("the expected bidder address length is %d, actual length is %d", sdk.AddrLen, len(msg.Bidder))
|
||||||
|
}
|
||||||
if !msg.Amount.IsValid() {
|
if !msg.Amount.IsValid() {
|
||||||
return sdkerrors.Wrapf(sdkerrors.ErrInvalidCoins, "bid amount %s", msg.Amount)
|
return sdkerrors.Wrapf(sdkerrors.ErrInvalidCoins, "bid amount %s", msg.Amount)
|
||||||
}
|
}
|
||||||
|
@ -56,8 +56,8 @@ func (gs GenesisState) Validate() error {
|
|||||||
if err := gs.Params.Validate(); err != nil {
|
if err := gs.Params.Validate(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if gs.PreviousBlockTime.Equal(time.Time{}) {
|
if gs.PreviousBlockTime.IsZero() {
|
||||||
return fmt.Errorf("previous block time not set")
|
return fmt.Errorf("previous block time not set or zero")
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user