mirror of
https://github.com/0glabs/0g-chain.git
synced 2024-12-26 00:05:18 +00:00
Bep3 migration (#662)
* draft kava-4 bep3 migration * add busd, btcb, xrpb to bep3 migration * add deputy addresses * update xrp unit conversion * harmonize fees * set min swap relative to fees * fix: missing zero in min swap amount * set busd fees equal to other assets * improve comments * set new bep3 asset limits to 1000 usd equivalent
This commit is contained in:
parent
495898170c
commit
00f2068d1b
@ -14,7 +14,7 @@ import (
|
|||||||
|
|
||||||
v38_5auth "github.com/kava-labs/kava/migrate/v0_11/legacy/cosmos-sdk/v0.38.5/auth"
|
v38_5auth "github.com/kava-labs/kava/migrate/v0_11/legacy/cosmos-sdk/v0.38.5/auth"
|
||||||
v38_5supply "github.com/kava-labs/kava/migrate/v0_11/legacy/cosmos-sdk/v0.38.5/supply"
|
v38_5supply "github.com/kava-labs/kava/migrate/v0_11/legacy/cosmos-sdk/v0.38.5/supply"
|
||||||
v0_11bep3 "github.com/kava-labs/kava/x/bep3/legacy/v0_11"
|
v0_11bep3 "github.com/kava-labs/kava/x/bep3"
|
||||||
v0_9bep3 "github.com/kava-labs/kava/x/bep3/legacy/v0_9"
|
v0_9bep3 "github.com/kava-labs/kava/x/bep3/legacy/v0_9"
|
||||||
v0_11cdp "github.com/kava-labs/kava/x/cdp"
|
v0_11cdp "github.com/kava-labs/kava/x/cdp"
|
||||||
v0_9cdp "github.com/kava-labs/kava/x/cdp/legacy/v0_9"
|
v0_9cdp "github.com/kava-labs/kava/x/cdp/legacy/v0_9"
|
||||||
@ -37,13 +37,13 @@ func MigrateBep3(oldGenState v0_9bep3.GenesisState) v0_11bep3.GenesisState {
|
|||||||
v0_9Params := oldGenState.Params
|
v0_9Params := oldGenState.Params
|
||||||
|
|
||||||
for _, asset := range v0_9Params.SupportedAssets {
|
for _, asset := range v0_9Params.SupportedAssets {
|
||||||
v10AssetParam := v0_11bep3.AssetParam{
|
v11AssetParam := v0_11bep3.AssetParam{
|
||||||
Active: asset.Active,
|
Active: asset.Active,
|
||||||
Denom: asset.Denom,
|
Denom: asset.Denom,
|
||||||
CoinID: asset.CoinID,
|
CoinID: asset.CoinID,
|
||||||
DeputyAddress: v0_9Params.BnbDeputyAddress,
|
DeputyAddress: v0_9Params.BnbDeputyAddress,
|
||||||
FixedFee: v0_9Params.BnbDeputyFixedFee,
|
FixedFee: v0_9Params.BnbDeputyFixedFee,
|
||||||
MinSwapAmount: sdk.OneInt(), // set min swap to one - prevents accounts that hold zero bnb from creating spam txs
|
MinSwapAmount: v0_9Params.BnbDeputyFixedFee.Add(sdk.OneInt()), // set min swap to one (after fees)- prevents accounts that hold zero bnb from creating spam txs
|
||||||
MaxSwapAmount: v0_9Params.MaxAmount,
|
MaxSwapAmount: v0_9Params.MaxAmount,
|
||||||
MinBlockLock: v0_9Params.MinBlockLock,
|
MinBlockLock: v0_9Params.MinBlockLock,
|
||||||
MaxBlockLock: v0_9Params.MaxBlockLock,
|
MaxBlockLock: v0_9Params.MaxBlockLock,
|
||||||
@ -54,7 +54,7 @@ func MigrateBep3(oldGenState v0_9bep3.GenesisState) v0_11bep3.GenesisState {
|
|||||||
TimeBasedLimit: sdk.ZeroInt(),
|
TimeBasedLimit: sdk.ZeroInt(),
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
assetParams = append(assetParams, v10AssetParam)
|
assetParams = append(assetParams, v11AssetParam)
|
||||||
}
|
}
|
||||||
for _, supply := range oldGenState.AssetSupplies {
|
for _, supply := range oldGenState.AssetSupplies {
|
||||||
newSupply := v0_11bep3.NewAssetSupply(supply.IncomingSupply, supply.OutgoingSupply, supply.CurrentSupply, sdk.NewCoin(supply.CurrentSupply.Denom, sdk.ZeroInt()), time.Duration(0))
|
newSupply := v0_11bep3.NewAssetSupply(supply.IncomingSupply, supply.OutgoingSupply, supply.CurrentSupply, sdk.NewCoin(supply.CurrentSupply.Denom, sdk.ZeroInt()), time.Duration(0))
|
||||||
@ -78,9 +78,86 @@ func MigrateBep3(oldGenState v0_9bep3.GenesisState) v0_11bep3.GenesisState {
|
|||||||
}
|
}
|
||||||
swaps = append(swaps, newSwap)
|
swaps = append(swaps, newSwap)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// -------------- ADD BTCB To BEP3 params --------------------
|
||||||
|
btcbAssetParam := v0_11bep3.NewAssetParam(
|
||||||
|
"btcb",
|
||||||
|
0,
|
||||||
|
v0_11bep3.SupplyLimit{
|
||||||
|
Limit: sdk.NewInt(100000000), // 1 BTC limit at launch
|
||||||
|
TimeLimited: false,
|
||||||
|
TimePeriod: time.Duration(0),
|
||||||
|
TimeBasedLimit: sdk.ZeroInt()},
|
||||||
|
true,
|
||||||
|
mustAccAddressFromBech32("kava14qsmvzprqvhwmgql9fr0u3zv9n2qla8zhnm5pc"),
|
||||||
|
sdk.NewInt(2), // 2 satoshi fee
|
||||||
|
sdk.NewInt(3),
|
||||||
|
sdk.NewInt(1000000000),
|
||||||
|
220,
|
||||||
|
270,
|
||||||
|
)
|
||||||
|
btcbAssetSupply := v0_11bep3.NewAssetSupply(
|
||||||
|
sdk.NewCoin("btcb", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("btcb", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("btcb", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("btcb", sdk.ZeroInt()),
|
||||||
|
time.Duration(0))
|
||||||
|
assetParams = append(assetParams, btcbAssetParam)
|
||||||
|
assetSupplies = append(assetSupplies, btcbAssetSupply)
|
||||||
|
|
||||||
|
// -------------- ADD XRPB To BEP3 params --------------------
|
||||||
|
xrpbAssetParam := v0_11bep3.NewAssetParam(
|
||||||
|
"xrpb", // NOTE: XRPB has 8 decimals on binance chain, whereas XRP has 6 decimals natively
|
||||||
|
144,
|
||||||
|
v0_11bep3.SupplyLimit{
|
||||||
|
Limit: sdk.NewInt(1000000000000), // 10,000 XRP limit at launch
|
||||||
|
TimeLimited: false,
|
||||||
|
TimePeriod: time.Duration(0),
|
||||||
|
TimeBasedLimit: sdk.ZeroInt()},
|
||||||
|
true,
|
||||||
|
mustAccAddressFromBech32("kava1c0ju5vnwgpgxnrktfnkccuth9xqc68dcdpzpas"),
|
||||||
|
sdk.NewInt(100000), // 0.001 XRP fee
|
||||||
|
sdk.NewInt(100001),
|
||||||
|
sdk.NewInt(10000000000000),
|
||||||
|
220,
|
||||||
|
270,
|
||||||
|
)
|
||||||
|
xrpbAssetSupply := v0_11bep3.NewAssetSupply(
|
||||||
|
sdk.NewCoin("xrpb", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("xrpb", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("xrpb", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("xrpb", sdk.ZeroInt()),
|
||||||
|
time.Duration(0))
|
||||||
|
assetParams = append(assetParams, xrpbAssetParam)
|
||||||
|
assetSupplies = append(assetSupplies, xrpbAssetSupply)
|
||||||
|
|
||||||
|
// -------------- ADD BUSD To BEP3 params --------------------
|
||||||
|
busdAssetParam := v0_11bep3.NewAssetParam(
|
||||||
|
"busd",
|
||||||
|
727, // note - no official SLIP 44 ID
|
||||||
|
v0_11bep3.SupplyLimit{
|
||||||
|
Limit: sdk.NewInt(100000000000), // 1,000 BUSD limit at launch
|
||||||
|
TimeLimited: false,
|
||||||
|
TimePeriod: time.Duration(0),
|
||||||
|
TimeBasedLimit: sdk.ZeroInt()},
|
||||||
|
true,
|
||||||
|
mustAccAddressFromBech32("kava1hh4x3a4suu5zyaeauvmv7ypf7w9llwlfufjmuu"),
|
||||||
|
sdk.NewInt(20000),
|
||||||
|
sdk.NewInt(20001),
|
||||||
|
sdk.NewInt(1000000000000),
|
||||||
|
220,
|
||||||
|
270,
|
||||||
|
)
|
||||||
|
busdAssetSupply := v0_11bep3.NewAssetSupply(
|
||||||
|
sdk.NewCoin("busd", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("busd", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("busd", sdk.ZeroInt()),
|
||||||
|
sdk.NewCoin("busd", sdk.ZeroInt()),
|
||||||
|
time.Duration(0))
|
||||||
|
assetParams = append(assetParams, busdAssetParam)
|
||||||
|
assetSupplies = append(assetSupplies, busdAssetSupply)
|
||||||
return v0_11bep3.GenesisState{
|
return v0_11bep3.GenesisState{
|
||||||
Params: v0_11bep3.Params{
|
Params: v0_11bep3.NewParams(assetParams),
|
||||||
AssetParams: assetParams},
|
|
||||||
AtomicSwaps: swaps,
|
AtomicSwaps: swaps,
|
||||||
Supplies: assetSupplies,
|
Supplies: assetSupplies,
|
||||||
PreviousBlockTime: v0_11bep3.DefaultPreviousBlockTime,
|
PreviousBlockTime: v0_11bep3.DefaultPreviousBlockTime,
|
||||||
|
Loading…
Reference in New Issue
Block a user