/
upgrades.go
91 lines (81 loc) · 3.68 KB
/
upgrades.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
package v12
import (
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/types/module"
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
distrtypes "github.com/cosmos/cosmos-sdk/x/distribution/types"
govtypes "github.com/cosmos/cosmos-sdk/x/gov/types"
stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types"
upgradetypes "github.com/cosmos/cosmos-sdk/x/upgrade/types"
icahosttypes "github.com/cosmos/ibc-go/v4/modules/apps/27-interchain-accounts/host/types"
ibctransfertypes "github.com/cosmos/ibc-go/v4/modules/apps/transfer/types"
gammtypes "github.com/osmosis-labs/osmosis/v17/x/gamm/types"
superfluidtypes "github.com/osmosis-labs/osmosis/v17/x/superfluid/types"
"github.com/osmosis-labs/osmosis/v17/app/keepers"
"github.com/osmosis-labs/osmosis/v17/app/upgrades"
twaptypes "github.com/osmosis-labs/osmosis/v17/x/twap/types"
)
// We set the app version to pre-upgrade because it will be incremented by one
// after the upgrade is applied by the handler.
const preUpgradeAppVersion = 11
func CreateUpgradeHandler(
mm *module.Manager,
configurator module.Configurator,
bpm upgrades.BaseAppParamManager,
keepers *keepers.AppKeepers,
) upgradetypes.UpgradeHandler {
return func(ctx sdk.Context, plan upgradetypes.Plan, fromVM module.VersionMap) (module.VersionMap, error) {
// Although the app version was already set during the v9 upgrade, our v10 was a fork and
// v11 was decided to be limited to the "gauge creation minimum fee" change only:
// https://github.com/osmosis-labs/osmosis/pull/2202
//
// As a result, the upgrade handler was not executed to increment the app version.
// This change helps to correctly set the app version for v12.
if err := keepers.UpgradeKeeper.SetAppVersion(ctx, preUpgradeAppVersion); err != nil {
return nil, err
}
// Specifying the whole list instead of adding and removing. Less fragile.
hostParams := icahosttypes.Params{
HostEnabled: true,
AllowMessages: []string{
// Change: Added MsgTrasnsfer
sdk.MsgTypeURL(&ibctransfertypes.MsgTransfer{}),
sdk.MsgTypeURL(&banktypes.MsgSend{}),
sdk.MsgTypeURL(&stakingtypes.MsgDelegate{}),
sdk.MsgTypeURL(&stakingtypes.MsgBeginRedelegate{}),
sdk.MsgTypeURL(&stakingtypes.MsgCreateValidator{}),
sdk.MsgTypeURL(&stakingtypes.MsgEditValidator{}),
// Change: Added MsgUndelegate
sdk.MsgTypeURL(&stakingtypes.MsgUndelegate{}),
sdk.MsgTypeURL(&distrtypes.MsgWithdrawDelegatorReward{}),
sdk.MsgTypeURL(&distrtypes.MsgSetWithdrawAddress{}),
sdk.MsgTypeURL(&distrtypes.MsgWithdrawValidatorCommission{}),
sdk.MsgTypeURL(&distrtypes.MsgFundCommunityPool{}),
sdk.MsgTypeURL(&govtypes.MsgVote{}),
// Change: Removed authz messages
sdk.MsgTypeURL(&gammtypes.MsgJoinPool{}),
sdk.MsgTypeURL(&gammtypes.MsgExitPool{}),
sdk.MsgTypeURL(&gammtypes.MsgSwapExactAmountIn{}),
sdk.MsgTypeURL(&gammtypes.MsgSwapExactAmountOut{}),
sdk.MsgTypeURL(&gammtypes.MsgJoinSwapExternAmountIn{}),
sdk.MsgTypeURL(&gammtypes.MsgJoinSwapShareAmountOut{}),
sdk.MsgTypeURL(&gammtypes.MsgExitSwapExternAmountOut{}),
sdk.MsgTypeURL(&gammtypes.MsgExitSwapShareAmountIn{}),
// Change: Added superfluid unbound
sdk.MsgTypeURL(&superfluidtypes.MsgSuperfluidUnbondLock{}),
},
}
keepers.ICAHostKeeper.SetParams(ctx, hostParams)
// Initialize TWAP state
// N.B.: deprecation nolint
// nolint: staticcheck
latestPoolId := keepers.GAMMKeeper.GetNextPoolId(ctx) - 1
err := keepers.TwapKeeper.MigrateExistingPools(ctx, latestPoolId)
if err != nil {
return nil, err
}
// Set TWAP parameters to default values.
keepers.TwapKeeper.SetParams(ctx, twaptypes.DefaultParams())
return mm.RunMigrations(ctx, configurator, fromVM)
}
}