* WIP: add filtered message * updated `Accept` interface method * fix tests * add cli tests for filtered fee allowance * fix tests * review changes * rename `filteredFeeAllowance` message * review changes * review changes * review changes * review changes * review changes * update errors * remove validation * fix conflicts * add `ctx` to `Accept` method * fix test * add gas consumption * review changes * review changes * revert * review changes * improve error handling * fix test * Merge branch 'master' of github.com:cosmos/cosmos-sdk into atheesh/feegrant-filtered-msgs * review changes * update gas * update type * review changes Co-authored-by: Alessio Treglia <alessio@tendermint.com> Co-authored-by: SaReN <sahithnarahari@gmail.com> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
77 lines
1.7 KiB
Go
77 lines
1.7 KiB
Go
package keeper
|
|
|
|
import (
|
|
"context"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
|
|
"github.com/cosmos/cosmos-sdk/x/feegrant/types"
|
|
)
|
|
|
|
type msgServer struct {
|
|
Keeper
|
|
}
|
|
|
|
// NewMsgServerImpl returns an implementation of the feegrant MsgServer interface
|
|
// for the provided Keeper.
|
|
func NewMsgServerImpl(k Keeper) types.MsgServer {
|
|
return &msgServer{
|
|
Keeper: k,
|
|
}
|
|
}
|
|
|
|
var _ types.MsgServer = msgServer{}
|
|
|
|
func (k msgServer) GrantFeeAllowance(goCtx context.Context, msg *types.MsgGrantFeeAllowance) (*types.MsgGrantFeeAllowanceResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(goCtx)
|
|
|
|
grantee, err := sdk.AccAddressFromBech32(msg.Grantee)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
granter, err := sdk.AccAddressFromBech32(msg.Granter)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
// Checking for duplicate entry
|
|
if f, _ := k.Keeper.GetFeeAllowance(ctx, granter, grantee); f != nil {
|
|
return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidRequest, "fee allowance already exists")
|
|
}
|
|
|
|
allowance, err := msg.GetFeeAllowanceI()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
err = k.Keeper.GrantFeeAllowance(ctx, granter, grantee, allowance)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &types.MsgGrantFeeAllowanceResponse{}, nil
|
|
}
|
|
|
|
func (k msgServer) RevokeFeeAllowance(goCtx context.Context, msg *types.MsgRevokeFeeAllowance) (*types.MsgRevokeFeeAllowanceResponse, error) {
|
|
ctx := sdk.UnwrapSDKContext(goCtx)
|
|
|
|
grantee, err := sdk.AccAddressFromBech32(msg.Grantee)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
granter, err := sdk.AccAddressFromBech32(msg.Granter)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
err = k.Keeper.RevokeFeeAllowance(ctx, granter, grantee)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &types.MsgRevokeFeeAllowanceResponse{}, nil
|
|
}
|