-
Notifications
You must be signed in to change notification settings - Fork 0
/
keeper.go
74 lines (65 loc) · 2.29 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
package keeper
import (
"fmt"
"github.com/cosmos/cosmos-sdk/codec"
storetypes "github.com/cosmos/cosmos-sdk/store/types"
sdk "github.com/cosmos/cosmos-sdk/types"
capabilitytypes "github.com/cosmos/cosmos-sdk/x/capability/types"
paramtypes "github.com/cosmos/cosmos-sdk/x/params/types"
"github.com/tendermint/tendermint/libs/log"
"github.com/merlin-network/petri/x/interchaintxs/types"
)
const (
LabelSubmitTx = "submit_tx"
LabelHandleAcknowledgment = "handle_ack"
LabelLabelHandleChanOpenAck = "handle_chan_open_ack"
LabelRegisterInterchainAccount = "register_interchain_account"
LabelHandleTimeout = "handle_timeout"
)
type (
Keeper struct {
Codec codec.BinaryCodec
storeKey storetypes.StoreKey
memKey storetypes.StoreKey
paramstore paramtypes.Subspace
scopedKeeper types.ScopedKeeper
channelKeeper types.ChannelKeeper
feeKeeper types.FeeRefunderKeeper
icaControllerKeeper types.ICAControllerKeeper
contractManagerKeeper types.ContractManagerKeeper
}
)
func NewKeeper(
cdc codec.BinaryCodec,
storeKey,
memKey storetypes.StoreKey,
paramstore paramtypes.Subspace,
channelKeeper types.ChannelKeeper,
icaControllerKeeper types.ICAControllerKeeper,
scopedKeeper types.ScopedKeeper,
contractManagerKeeper types.ContractManagerKeeper,
feeKeeper types.FeeRefunderKeeper,
) *Keeper {
// set KeyTable if it has not already been set
if !paramstore.HasKeyTable() {
paramstore = paramstore.WithKeyTable(types.ParamKeyTable())
}
return &Keeper{
Codec: cdc,
storeKey: storeKey,
memKey: memKey,
paramstore: paramstore,
channelKeeper: channelKeeper,
icaControllerKeeper: icaControllerKeeper,
scopedKeeper: scopedKeeper,
contractManagerKeeper: contractManagerKeeper,
feeKeeper: feeKeeper,
}
}
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)
}