/
keeper.go
57 lines (46 loc) · 1.38 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
package keeper
import (
"github.com/cometbft/cometbft/libs/log"
"github.com/cosmos/cosmos-sdk/codec"
storetypes "github.com/cosmos/cosmos-sdk/store/types"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/desmos-labs/desmos/v7/x/posts/types"
)
// Keeper maintains the link to data storage and exposes getter/setter methods for the various parts of the state machine
type Keeper struct {
storeKey storetypes.StoreKey
cdc codec.BinaryCodec
hooks types.PostsHooks
ak types.ProfilesKeeper
sk types.SubspacesKeeper
rk types.RelationshipsKeeper
// the address capable of executing a MsgUpdateParams message. Typically, this
// should be the x/gov module account.
authority string
}
// NewKeeper creates a new instance of the Posts Keeper.
func NewKeeper(
cdc codec.BinaryCodec, storeKey storetypes.StoreKey,
ak types.ProfilesKeeper, sk types.SubspacesKeeper, rk types.RelationshipsKeeper, authority string,
) *Keeper {
return &Keeper{
storeKey: storeKey,
cdc: cdc,
ak: ak,
sk: sk,
rk: rk,
authority: authority,
}
}
// Logger returns a module-specific logger
func (k Keeper) Logger(ctx sdk.Context) log.Logger {
return ctx.Logger().With("module", "x/"+types.ModuleName)
}
// SetHooks allows to set the posts hooks
func (k *Keeper) SetHooks(sh types.PostsHooks) *Keeper {
if k.hooks != nil {
panic("cannot set posts hooks twice")
}
k.hooks = sh
return k
}