2022-04-05 07:09:27 +00:00
|
|
|
package keeper
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-04-03 08:40:05 +00:00
|
|
|
"fmt"
|
2022-04-05 07:09:27 +00:00
|
|
|
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
|
2024-04-03 06:14:03 +00:00
|
|
|
"github.com/cerc-io/laconicd/utils"
|
2022-09-07 06:36:11 +00:00
|
|
|
"github.com/cerc-io/laconicd/x/auction/types"
|
2022-04-05 07:09:27 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type msgServer struct {
|
|
|
|
Keeper
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewMsgServer(keeper Keeper) types.MsgServer {
|
|
|
|
return &msgServer{Keeper: keeper}
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ types.MsgServer = msgServer{}
|
|
|
|
|
|
|
|
func (s msgServer) CreateAuction(c context.Context, msg *types.MsgCreateAuction) (*types.MsgCreateAuctionResponse, error) {
|
|
|
|
ctx := sdk.UnwrapSDKContext(c)
|
2024-04-03 06:14:03 +00:00
|
|
|
ctx = *utils.CtxWithCustomKVGasConfig(&ctx)
|
2022-04-05 07:09:27 +00:00
|
|
|
|
|
|
|
signerAddress, err := sdk.AccAddressFromBech32(msg.Signer)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := s.Keeper.CreateAuction(ctx, *msg)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx.EventManager().EmitEvents(sdk.Events{
|
|
|
|
sdk.NewEvent(
|
|
|
|
types.EventTypeCreateAuction,
|
|
|
|
sdk.NewAttribute(types.AttributeKeyCommitsDuration, msg.CommitsDuration.String()),
|
|
|
|
sdk.NewAttribute(types.AttributeKeyCommitFee, msg.CommitFee.String()),
|
|
|
|
sdk.NewAttribute(types.AttributeKeyRevealFee, msg.RevealFee.String()),
|
|
|
|
sdk.NewAttribute(types.AttributeKeyMinimumBid, msg.MinimumBid.String()),
|
|
|
|
),
|
|
|
|
sdk.NewEvent(
|
|
|
|
sdk.EventTypeMessage,
|
|
|
|
sdk.NewAttribute(sdk.AttributeKeyModule, types.AttributeValueCategory),
|
|
|
|
sdk.NewAttribute(types.AttributeKeySigner, signerAddress.String()),
|
|
|
|
),
|
|
|
|
})
|
|
|
|
|
2024-04-03 08:40:05 +00:00
|
|
|
s.logTxGasConsumed(ctx, "CreateAuction")
|
|
|
|
|
2022-04-05 07:09:27 +00:00
|
|
|
return &types.MsgCreateAuctionResponse{Auction: resp}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// CommitBid is the command for committing a bid
|
|
|
|
func (s msgServer) CommitBid(c context.Context, msg *types.MsgCommitBid) (*types.MsgCommitBidResponse, error) {
|
|
|
|
ctx := sdk.UnwrapSDKContext(c)
|
2024-04-03 06:14:03 +00:00
|
|
|
ctx = *utils.CtxWithCustomKVGasConfig(&ctx)
|
2022-04-05 07:09:27 +00:00
|
|
|
|
|
|
|
signerAddress, err := sdk.AccAddressFromBech32(msg.Signer)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := s.Keeper.CommitBid(ctx, *msg)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx.EventManager().EmitEvents(sdk.Events{
|
|
|
|
sdk.NewEvent(
|
|
|
|
types.EventTypeCommitBid,
|
|
|
|
sdk.NewAttribute(types.AttributeKeyAuctionID, msg.AuctionId),
|
|
|
|
sdk.NewAttribute(types.AttributeKeyCommitHash, msg.CommitHash),
|
|
|
|
),
|
|
|
|
sdk.NewEvent(
|
|
|
|
sdk.EventTypeMessage,
|
|
|
|
sdk.NewAttribute(sdk.AttributeKeyModule, types.AttributeValueCategory),
|
|
|
|
sdk.NewAttribute(types.AttributeKeySigner, signerAddress.String()),
|
|
|
|
),
|
|
|
|
})
|
|
|
|
|
2024-04-03 08:40:05 +00:00
|
|
|
s.logTxGasConsumed(ctx, "CommitBid")
|
|
|
|
|
2022-04-05 07:09:27 +00:00
|
|
|
return &types.MsgCommitBidResponse{Bid: resp}, nil
|
|
|
|
}
|
|
|
|
|
2024-04-03 06:14:03 +00:00
|
|
|
// RevealBid is the command for revealing a bid
|
2022-04-05 07:09:27 +00:00
|
|
|
func (s msgServer) RevealBid(c context.Context, msg *types.MsgRevealBid) (*types.MsgRevealBidResponse, error) {
|
|
|
|
ctx := sdk.UnwrapSDKContext(c)
|
2024-04-03 06:14:03 +00:00
|
|
|
ctx = *utils.CtxWithCustomKVGasConfig(&ctx)
|
2022-04-05 07:09:27 +00:00
|
|
|
|
|
|
|
signerAddress, err := sdk.AccAddressFromBech32(msg.Signer)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := s.Keeper.RevealBid(ctx, *msg)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx.EventManager().EmitEvents(sdk.Events{
|
|
|
|
sdk.NewEvent(
|
|
|
|
types.EventTypeRevealBid,
|
|
|
|
sdk.NewAttribute(types.AttributeKeyAuctionID, msg.AuctionId),
|
|
|
|
sdk.NewAttribute(types.AttributeKeyReveal, msg.Reveal),
|
|
|
|
),
|
|
|
|
sdk.NewEvent(
|
|
|
|
sdk.EventTypeMessage,
|
|
|
|
sdk.NewAttribute(sdk.AttributeKeyModule, types.AttributeValueCategory),
|
|
|
|
sdk.NewAttribute(types.AttributeKeySigner, signerAddress.String()),
|
|
|
|
),
|
|
|
|
})
|
|
|
|
|
2024-04-03 08:40:05 +00:00
|
|
|
s.logTxGasConsumed(ctx, "RevealBid")
|
|
|
|
|
2022-04-05 07:09:27 +00:00
|
|
|
return &types.MsgRevealBidResponse{Auction: resp}, nil
|
|
|
|
}
|
2024-04-03 08:40:05 +00:00
|
|
|
|
2024-04-03 09:09:59 +00:00
|
|
|
func (s msgServer) logTxGasConsumed(ctx sdk.Context, tx string) {
|
2024-04-03 08:40:05 +00:00
|
|
|
gasConsumed := ctx.GasMeter().GasConsumed()
|
2024-04-03 09:09:59 +00:00
|
|
|
s.Keeper.Logger(ctx).Info("tx executed", "method", tx, "gas_consumed", fmt.Sprintf("%d", gasConsumed))
|
2024-04-03 08:40:05 +00:00
|
|
|
}
|