/
keeper.go
112 lines (98 loc) · 3.67 KB
/
keeper.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package keeper
import (
"fmt"
ibckeeper "github.com/cosmos/ibc-go/v5/modules/core/keeper"
"github.com/tendermint/tendermint/libs/log"
"github.com/cosmos/cosmos-sdk/codec"
sdk "github.com/cosmos/cosmos-sdk/types"
capabilitykeeper "github.com/cosmos/cosmos-sdk/x/capability/keeper"
capabilitytypes "github.com/cosmos/cosmos-sdk/x/capability/types"
paramtypes "github.com/cosmos/cosmos-sdk/x/params/types"
ibctransferkeeper "github.com/cosmos/ibc-go/v5/modules/apps/transfer/keeper"
ibctypes "github.com/cosmos/ibc-go/v5/modules/apps/transfer/types"
"github.com/Stride-Labs/stride/v9/utils"
icacallbackskeeper "github.com/Stride-Labs/stride/v9/x/icacallbacks/keeper"
icacallbackstypes "github.com/Stride-Labs/stride/v9/x/icacallbacks/types"
storetypes "github.com/cosmos/cosmos-sdk/store/types"
"github.com/Stride-Labs/stride/v9/x/records/types"
)
type (
Keeper struct {
// *cosmosibckeeper.Keeper
Cdc codec.BinaryCodec
storeKey storetypes.StoreKey
memKey storetypes.StoreKey
paramstore paramtypes.Subspace
scopedKeeper capabilitykeeper.ScopedKeeper
AccountKeeper types.AccountKeeper
TransferKeeper ibctransferkeeper.Keeper
IBCKeeper ibckeeper.Keeper
ICACallbacksKeeper icacallbackskeeper.Keeper
}
)
func NewKeeper(
Cdc codec.BinaryCodec,
storeKey,
memKey storetypes.StoreKey,
ps paramtypes.Subspace,
scopedKeeper capabilitykeeper.ScopedKeeper,
AccountKeeper types.AccountKeeper,
TransferKeeper ibctransferkeeper.Keeper,
ibcKeeper ibckeeper.Keeper,
ICACallbacksKeeper icacallbackskeeper.Keeper,
) *Keeper {
// set KeyTable if it has not already been set
if !ps.HasKeyTable() {
ps = ps.WithKeyTable(types.ParamKeyTable())
}
return &Keeper{
Cdc: Cdc,
storeKey: storeKey,
memKey: memKey,
paramstore: ps,
scopedKeeper: scopedKeeper,
AccountKeeper: AccountKeeper,
TransferKeeper: TransferKeeper,
IBCKeeper: ibcKeeper,
ICACallbacksKeeper: ICACallbacksKeeper,
}
}
func (k Keeper) Logger(ctx sdk.Context) log.Logger {
return ctx.Logger().With("module", fmt.Sprintf("x/%s", types.ModuleName))
}
// ClaimCapability claims the channel capability passed via the OnOpenChanInit callback
func (k *Keeper) ClaimCapability(ctx sdk.Context, cap *capabilitytypes.Capability, name string) error {
return k.scopedKeeper.ClaimCapability(ctx, cap, name)
}
func (k Keeper) Transfer(ctx sdk.Context, msg *ibctypes.MsgTransfer, depositRecord types.DepositRecord) error {
goCtx := sdk.WrapSDKContext(ctx)
msgTransferResponse, err := k.TransferKeeper.Transfer(goCtx, msg)
if err != nil {
return err
}
sequence := msgTransferResponse.Sequence
// add callback data
transferCallback := types.TransferCallback{
DepositRecordId: depositRecord.Id,
}
k.Logger(ctx).Info(utils.LogWithHostZone(depositRecord.HostZoneId, "Marshalling TransferCallback args: %+v", transferCallback))
marshalledCallbackArgs, err := k.MarshalTransferCallbackArgs(ctx, transferCallback)
if err != nil {
return err
}
// Store the callback data
callback := icacallbackstypes.CallbackData{
CallbackKey: icacallbackstypes.PacketID(msg.SourcePort, msg.SourceChannel, sequence),
PortId: msg.SourcePort,
ChannelId: msg.SourceChannel,
Sequence: sequence,
CallbackId: TRANSFER,
CallbackArgs: marshalledCallbackArgs,
}
k.Logger(ctx).Info(utils.LogWithHostZone(depositRecord.HostZoneId, "Storing callback data: %+v", callback))
k.ICACallbacksKeeper.SetCallbackData(ctx, callback)
// update the record state to TRANSFER_IN_PROGRESS
depositRecord.Status = types.DepositRecord_TRANSFER_IN_PROGRESS
k.SetDepositRecord(ctx, depositRecord)
return nil
}