-
Notifications
You must be signed in to change notification settings - Fork 2
/
msg_server.go
93 lines (79 loc) · 2.52 KB
/
msg_server.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package keeperadapter
import (
"context"
sdk "github.com/fibonacci-chain/fbc/libs/cosmos-sdk/types"
sdkerrors "github.com/fibonacci-chain/fbc/libs/cosmos-sdk/types/errors"
"github.com/fibonacci-chain/fbc/libs/cosmos-sdk/x/bank/internal/types"
"github.com/fibonacci-chain/fbc/libs/cosmos-sdk/x/bank/internal/typesadapter"
)
type msgServer struct {
MsgServerBankKeeper
}
// NewMsgServerImpl returns an implementation of the bank MsgServer interface
// for the provided Keeper.
func NewMsgServerImpl(keeper MsgServerBankKeeper) typesadapter.MsgServer {
return &msgServer{MsgServerBankKeeper: keeper}
}
var _ typesadapter.MsgServer = msgServer{}
func (k msgServer) Send(goCtx context.Context, msg *typesadapter.MsgSend) (*typesadapter.MsgSendResponse, error) {
ctx := sdk.UnwrapSDKContext(goCtx)
if !k.GetSendEnabled(ctx) {
return nil, types.ErrSendDisabled
}
from, err := sdk.AccAddressFromBech32(msg.FromAddress)
if err != nil {
return nil, err
}
to, err := sdk.AccAddressFromBech32(msg.ToAddress)
if err != nil {
return nil, err
}
if k.BlacklistedAddr(to) {
return nil, sdkerrors.Wrapf(sdkerrors.ErrUnauthorized, "%s is not allowed to receive funds", msg.ToAddress)
}
err = k.SendCoins(ctx, from, to, sdk.CoinAdaptersToCoins(msg.Amount))
if err != nil {
return nil, err
}
ctx.EventManager().EmitEvent(
sdk.NewEvent(
sdk.EventTypeMessage,
sdk.NewAttribute(sdk.AttributeKeyModule, types.AttributeValueCategory),
),
)
return &typesadapter.MsgSendResponse{}, nil
}
func (k msgServer) MultiSend(goCtx context.Context, msg *typesadapter.MsgMultiSend) (*typesadapter.MsgMultiSendResponse, error) {
//ctx := sdk.UnwrapSDKContext(goCtx)
//
//// NOTE: totalIn == totalOut should already have been checked
//for _, in := range msg.Inputs {
// k.GetSendEnabled(ctx)
// if err := k.IsSendEnabledCoins(ctx, in.Coins...); err != nil {
// return nil, err
// }
//}
//
//for _, out := range msg.Outputs {
// accAddr, err := sdk.AccAddressFromBech32(out.Address)
// if err != nil {
// panic(err)
// }
// if k.BlacklistedAddr(accAddr) {
// return nil, sdkerrors.Wrapf(sdkerrors.ErrUnauthorized, "%s is not allowed to receive transactions", out.Address)
// }
//}
//
//err := k.InputOutputCoins(ctx, msg.Inputs, msg.Outputs)
//if err != nil {
// return nil, err
//}
//
//ctx.EventManager().EmitEvent(
// sdk.NewEvent(
// sdk.EventTypeMessage,
// sdk.NewAttribute(sdk.AttributeKeyModule, types.AttributeValueCategory),
// ),
//)
return nil, sdkerrors.Wrap(types.ErrSendDisabled, "MultiSend is not support")
}