From 1cec6f739c6f8553e1c614595c69770140b5ade2 Mon Sep 17 00:00:00 2001 From: zoz <97761083+0xzoz@users.noreply.github.com> Date: Thu, 26 Oct 2023 07:07:24 +1100 Subject: [PATCH] [genesis] Final supply migration and documentation (#68) Co-authored-by: 0o-de-lally <1364012+0o-de-lally@users.noreply.github.com> --- Cargo.toml | 5 - .../sources/ol_sources/gas_coin.depr | 265 ------------------ .../sources/ol_sources/proof_of_fee.move | 12 + framework/releases/head.mrb | Bin 587406 -> 587594 bytes tools/genesis/Makefile | 7 + tools/genesis/README.md | 60 ++++ tools/genesis/src/genesis_functions.rs | 40 ++- tools/genesis/src/supply.rs | 10 + tools/genesis/src/vm.rs | 17 +- 9 files changed, 120 insertions(+), 296 deletions(-) delete mode 100644 framework/libra-framework/sources/ol_sources/gas_coin.depr create mode 100644 tools/genesis/README.md diff --git a/Cargo.toml b/Cargo.toml index 9f977f870..e00378ae2 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -347,8 +347,3 @@ incremental = true # # This will be removed once our pull requests land. [patch.crates-io] serde-reflection = { git = "https://github.com/aptos-labs/serde-reflection", rev = "839aed62a20ddccf043c08961cfe74875741ccba" } - -[env] -# set coin name for diem dependencies -RUST_DIEM_COIN_MODULE = "gas_coin" -RUST_DIEM_COIN_NAME = "LibraCoin" \ No newline at end of file diff --git a/framework/libra-framework/sources/ol_sources/gas_coin.depr b/framework/libra-framework/sources/ol_sources/gas_coin.depr deleted file mode 100644 index a3e212540..000000000 --- a/framework/libra-framework/sources/ol_sources/gas_coin.depr +++ /dev/null @@ -1,265 +0,0 @@ - -module ol_framework::gas_coin { - use std::string; - use std::error; - use std::signer; - use std::vector; - use std::option::{Self, Option}; - - use diem_framework::coin::{Self, MintCapability, BurnCapability}; - use diem_framework::system_addresses; - - use ol_framework::globals; - - friend diem_framework::genesis; - friend ol_framework::genesis_migration; - - /// Account does not have mint capability - const ENO_CAPABILITIES: u64 = 1; - /// Mint capability has already been delegated to this specified address - const EALREADY_DELEGATED: u64 = 2; - /// Cannot find delegation of mint capability to this account - const EDELEGATION_NOT_FOUND: u64 = 3; - - struct GasCoin has key {} - - struct MintCapStore has key { - mint_cap: MintCapability, - } - - /// Delegation token created by delegator and can be claimed by the delegatee as MintCapability. - struct DelegatedMintCapability has store { - to: address - } - - /// The container stores the current pending delegations. - struct Delegations has key { - inner: vector, - } - - /// Can only called during genesis to initialize the Diem coin. - public(friend) fun initialize(diem_framework: &signer) { - system_addresses::assert_diem_framework(diem_framework); - - let (burn_cap, freeze_cap, mint_cap) = coin::initialize_with_parallelizable_supply( - diem_framework, - string::utf8(b"Gas Coin"), - string::utf8(b"GAS"), - globals::get_coin_decimal_places(), /* decimals MATCHES LEGACY 0L */ - true, /* monitor_supply */ - ); - - // Diem framework needs mint cap to mint coins to initial validators. This will be revoked once the validators - // have been initialized. - move_to(diem_framework, MintCapStore { mint_cap }); - - coin::destroy_freeze_cap(freeze_cap); - coin::destroy_burn_cap(burn_cap); - // (burn_cap, mint_cap) - } - - /// FOR TESTS ONLY - /// Can only called during genesis to initialize the Diem coin. - public(friend) fun initialize_for_core(diem_framework: &signer): (BurnCapability, MintCapability) { - system_addresses::assert_diem_framework(diem_framework); - - let (burn_cap, freeze_cap, mint_cap) = coin::initialize_with_parallelizable_supply( - diem_framework, - string::utf8(b"Gas Coin"), - string::utf8(b"GAS"), - globals::get_coin_decimal_places(), /* decimals MATCHES LEGACY 0L */ - true, /* monitor_supply */ - ); - - // Diem framework needs mint cap to mint coins to initial validators. This will be revoked once the validators - // have been initialized. - move_to(diem_framework, MintCapStore { mint_cap }); - - coin::destroy_freeze_cap(freeze_cap); - - (burn_cap, mint_cap) - } - - public fun has_mint_capability(account: &signer): bool { - exists(signer::address_of(account)) - } - - /// Only called during genesis to destroy the diem framework account's mint capability once all initial validators - /// and accounts have been initialized during genesis. - public(friend) fun destroy_mint_cap(diem_framework: &signer) acquires MintCapStore { - system_addresses::assert_diem_framework(diem_framework); - let MintCapStore { mint_cap } = move_from(@diem_framework); - coin::destroy_mint_cap(mint_cap); - } - - - #[view] - /// get the gas coin supply. Helper which wraps coin::supply and extracts option type - // NOTE: there is casting between u128 and u64, but 0L has final supply below the u64. - public fun supply(): u64 { - let supply_opt = coin::supply(); - if (option::is_some(&supply_opt)) { - return (*option::borrow(&supply_opt) as u64) - }; - 0 - } - - - #[test_only] - public fun restore_mint_cap(diem_framework: &signer, mint_cap: MintCapability) { - system_addresses::assert_diem_framework(diem_framework); - move_to(diem_framework, MintCapStore { mint_cap }); - } - - /// FOR TESTS ONLY - /// The `core addresses` sudo account is used to execute system transactions for testing - /// Can only be called during genesis for tests to grant mint capability to diem framework and core resources - /// accounts. - public(friend) fun configure_accounts_for_test( - diem_framework: &signer, - core_resources: &signer, - mint_cap: MintCapability, - ){ - system_addresses::assert_diem_framework(diem_framework); - - // Mint the core resource account GasCoin for gas so it can execute system transactions. - coin::register(core_resources); - - let coins = coin::mint( - 18446744073709551615, - &mint_cap, - ); - coin::deposit(signer::address_of(core_resources), coins); - - move_to(core_resources, MintCapStore { mint_cap }); - move_to(core_resources, Delegations { inner: vector::empty() }); - } - - // /// Only callable in tests and testnets where the core resources account exists. - // /// Create new coins and deposit them into dst_addr's account. - // mint_impl( - // root: &signer, - // amount: u64, - // ): Coin acquires MintCapStore { - // system_addresses::assert_ol(root); - - // let mint_cap = &borrow_global(signer::address_of(root)).mint_cap; - // coin::mint(amount, mint_cap) - // } - - // NOTE: needed for smoke tests - // TODO: guard some other way besides using the testing root account. - /// Root account can mint to an address. Only used for genesis and tests. - /// The "root" account in smoke tests has some privileges. - public entry fun mint_to_impl( - root: &signer, - dst_addr: address, - amount: u64, - ) acquires MintCapStore { - - let account_addr = signer::address_of(root); - - assert!( - exists(account_addr), - error::not_found(ENO_CAPABILITIES), - ); - - let mint_cap = &borrow_global(account_addr).mint_cap; - let coins_minted = coin::mint(amount, mint_cap); - coin::deposit(dst_addr, coins_minted); - } - - #[test_only] - public entry fun test_mint_to( - root: &signer, - dst_addr: address, - amount: u64, - ) acquires MintCapStore { - system_addresses::assert_ol(root); - mint_to_impl(root, dst_addr, amount); - } - - /// Only callable in tests and testnets where the core resources account exists. - /// Create delegated token for the address so the account could claim MintCapability later. - public entry fun delegate_mint_capability(account: signer, to: address) acquires Delegations { - system_addresses::assert_core_resource(&account); - let delegations = &mut borrow_global_mut(@core_resources).inner; - let i = 0; - while (i < vector::length(delegations)) { - let element = vector::borrow(delegations, i); - assert!(element.to != to, error::invalid_argument(EALREADY_DELEGATED)); - i = i + 1; - }; - vector::push_back(delegations, DelegatedMintCapability { to }); - } - - /// Only callable in tests and testnets where the core resources account exists. - /// Claim the delegated mint capability and destroy the delegated token. - public entry fun claim_mint_capability(account: &signer) acquires Delegations, MintCapStore { - let maybe_index = find_delegation(signer::address_of(account)); - assert!(option::is_some(&maybe_index), EDELEGATION_NOT_FOUND); - let idx = *option::borrow(&maybe_index); - let delegations = &mut borrow_global_mut(@core_resources).inner; - let DelegatedMintCapability { to: _ } = vector::swap_remove(delegations, idx); - - // Make a copy of mint cap and give it to the specified account. - let mint_cap = borrow_global(@core_resources).mint_cap; - move_to(account, MintCapStore { mint_cap }); - } - - fun find_delegation(addr: address): Option acquires Delegations { - let delegations = &borrow_global(@core_resources).inner; - let i = 0; - let len = vector::length(delegations); - let index = option::none(); - while (i < len) { - let element = vector::borrow(delegations, i); - if (element.to == addr) { - index = option::some(i); - break - }; - i = i + 1; - }; - index - } - - #[view] - /// helper to get balance in gas coin - public fun get_balance(account: address): u64 { - coin::balance(account) - } - - - #[test_only] - use diem_framework::aggregator_factory; - - #[test_only] - public fun initialize_for_test(diem_framework: &signer): (BurnCapability, MintCapability) { - aggregator_factory::initialize_aggregator_factory_for_test(diem_framework); - let (burn_cap, freeze_cap, mint_cap) = coin::initialize_with_parallelizable_supply( - diem_framework, - string::utf8(b"Gas Coin"), - string::utf8(b"GAS"), - 8, /* decimals */ - true, /* monitor_supply */ - ); - move_to(diem_framework, MintCapStore { mint_cap }); - - coin::destroy_freeze_cap(freeze_cap); - (burn_cap, mint_cap) - } - - // This is particularly useful if the aggregator_factory is already initialized via another call path. - #[test_only] - public fun initialize_for_test_without_aggregator_factory(diem_framework: &signer): (BurnCapability, MintCapability) { - let (burn_cap, freeze_cap, mint_cap) = coin::initialize_with_parallelizable_supply( - diem_framework, - string::utf8(b"Gas Coin"), - string::utf8(b"GAS"), - 8, /* decimals */ - true, /* monitor_supply */ - ); - coin::destroy_freeze_cap(freeze_cap); - (burn_cap, mint_cap) - } -} diff --git a/framework/libra-framework/sources/ol_sources/proof_of_fee.move b/framework/libra-framework/sources/ol_sources/proof_of_fee.move index 6ac284938..7dfa67a8f 100644 --- a/framework/libra-framework/sources/ol_sources/proof_of_fee.move +++ b/framework/libra-framework/sources/ol_sources/proof_of_fee.move @@ -86,6 +86,18 @@ module ol_framework::proof_of_fee { } } + // on a migration genesis for mainnet the genesis reward needs to be calculated + // from supply data. + public fun genesis_migrate_reward(vm: &signer, nominal_reward: u64) acquires + ConsensusReward { + if (signer::address_of(vm) != @ol_framework) return; + + let state = borrow_global_mut(@ol_framework); + state.nominal_reward = nominal_reward; + state.net_reward = nominal_reward; // just for info purposes. It gets calculated + // on first epoch change. + } + public fun init(account_sig: &signer) { let acc = signer::address_of(account_sig); diff --git a/framework/releases/head.mrb b/framework/releases/head.mrb index 90402a0a4947d288986b459ee99366819f8bd6d6..fda2e129c5e89067b3b379039a25c216670243e4 100644 GIT binary patch delta 10337 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 diff --git a/tools/genesis/Makefile b/tools/genesis/Makefile index 05a9ac74b..4e6fd344c 100644 --- a/tools/genesis/Makefile +++ b/tools/genesis/Makefile @@ -14,6 +14,10 @@ RECOVERY_FILE = sample_end_user_single # RECOVERY_FILE = sample_rotated_auth endif +ifndef YEARS +YEARS = 7 +endif + ifndef CHAIN CHAIN = testing endif @@ -34,6 +38,7 @@ genesis: --json-legacy ./tests/fixtures/${RECOVERY_FILE}.json \ --target-supply ${TARGET_SUPPLY} \ --target-future-uses ${FUTURE_USES} \ + --years-escrow ${YEARS} \ --map-dd-to-slow 3A6C51A0B786D644590E8A21591FA8E2 \ --map-dd-to-slow 2B0E8325DEA5BE93D856CFDE2D0CBA12 @@ -45,6 +50,7 @@ wizard: --json-legacy ./tests/fixtures/${RECOVERY_FILE}.json \ --target-supply ${TARGET_SUPPLY} \ --target-future-uses ${FUTURE_USES} \ + --years-escrow ${YEARS} \ --map-dd-to-slow 3A6C51A0B786D644590E8A21591FA8E2 \ --map-dd-to-slow 2B0E8325DEA5BE93D856CFDE2D0CBA12 @@ -84,5 +90,6 @@ test-genesis: -i ${CAROL_IP} \ --target-supply ${TARGET_SUPPLY} \ --target-future-uses ${FUTURE_USES} \ + --years-escrow ${YEARS} \ --map-dd-to-slow 3A6C51A0B786D644590E8A21591FA8E2 \ --map-dd-to-slow 2B0E8325DEA5BE93D856CFDE2D0CBA12 diff --git a/tools/genesis/README.md b/tools/genesis/README.md new file mode 100644 index 000000000..377220c3c --- /dev/null +++ b/tools/genesis/README.md @@ -0,0 +1,60 @@ +## Genesis + + +### Migration Math + +#### `--target-supply ` Change in denomination (split) + +To adjust the count of coins, and how they get split, the genesis command offers +one input: `--target-supply`. + +If for example the supply will scale (pro-rata) from 2,000,000 to 100,000,000, +then the genesis supply calculator (`set_ratios_from_settings()`) will create a split of 50 redenominated coins +for 1 coin. Coins do not change name, no changes in ownership, and all policies +remain the same. + +#### `--years-escrow ` Provision an infrastructure escrow + +If the validators will set aside rewards for future validators this is done +with: `--years-escrow`. If for example this argument is used, the supply +calculator (`set_ratios_from_settings()`) will take the *remainder* of the +`--target-future-uses` which isn't already in a community-wallet. + +#### `--target-future-uses ` Community wallet and infra escrow target percentage of network supply +This parameter affects the expected funds available for infra-escrow pledges, +and the daily epoch reward budget. + +Note: this could have been implemented as a number targetting the infra-escrow percentage +(e.g. `target-infra-escrow`). However the user-experience of the validator at +genesis is more difficult in this case since the community wallet numbers are +not easily calculated in advance (it would require multiple steps with this tool). + +We calculate the infra-escrow budget by working backwards from one input the +community would already have: a target for "future users" (versus end-user +accounts). +If for example the community expected that the combined infra-escrow and +community wallets will represent 70% of the network as a target, we deduce that +infra-escrow will be the remainder of `((0.70 * total supply) - (sum of community +wallets))`. + +A lower amount of `--target-future-uses` means a lower amount available to +infrastructure escrow pledges to use over the time `--years-escrow`. i.e. if +target future uses is 55% (`--target-future-uses 0.55`) and the community +wallet balance is 45%, then there is +10% of supply to be spread over 7 years (`--years-escrow 7`). + +Note also we derive the baseline +daily validator rewards from those two parameters. In the example above the +daily reward baseline equals `(10% * Total +Supply) / 7 (years) * 100 validators (baseline) * 365 (days)` + +Troubleshooting. If the target percent % is below the proportion of the sum of community +accounts the program will exit with error. + + +#### `--map_dd_to_slow `. Adjusting the future-uses calculator + +Ususally in test-cases, there may be cases that the future-uses calculator gets +skewed because certain accounts are not in the expected state (a community +wallet wasn't expected to exist at that point). + diff --git a/tools/genesis/src/genesis_functions.rs b/tools/genesis/src/genesis_functions.rs index f09acb589..d5cb6e107 100644 --- a/tools/genesis/src/genesis_functions.rs +++ b/tools/genesis/src/genesis_functions.rs @@ -1,5 +1,5 @@ //! ol functions to run at genesis e.g. migration. -use crate::supply::{populate_supply_stats_from_legacy, SupplySettings}; +use crate::supply::{Supply, SupplySettings}; use anyhow::Context; use diem_types::account_config::CORE_CODE_ADDRESS; use diem_vm::move_vm_ext::SessionExt; @@ -15,13 +15,8 @@ use move_core_types::value::{serialize_values, MoveValue}; pub fn genesis_migrate_all_users( session: &mut SessionExt, user_recovery: &[LegacyRecovery], - supply_settings: &SupplySettings, + supply: &Supply, ) -> anyhow::Result<()> { - let mut supply = - populate_supply_stats_from_legacy(user_recovery, &supply_settings.map_dd_to_slow)?; - - supply.set_ratios_from_settings(supply_settings)?; - user_recovery .iter() .progress_with_style(OLProgress::bar()) @@ -179,7 +174,6 @@ pub fn genesis_migrate_infra_escrow( user_recovery: &LegacyRecovery, escrow_pct: f64, ) -> anyhow::Result<()> { - dbg!("infra"); if user_recovery.account.is_none() || user_recovery.auth_key.is_none() || user_recovery.balance.is_none() @@ -317,19 +311,17 @@ pub fn rounding_mint(session: &mut SessionExt, supply_settings: &SupplySettings) ); } -// pub fn mint_genesis_bootstrap_coin(session: &mut SessionExt, validators: &[Validator]) { -// validators.iter().for_each(|v| { -// let serialized_values = serialize_values(&vec![ -// MoveValue::Signer(AccountAddress::ZERO), // must be called by 0x0 -// MoveValue::Address(v.owner_address), -// ]); - -// exec_function( -// session, -// "infra_escrow", -// "genesis_coin_validator", -// vec![], -// serialized_values, -// ); -// }); -// } +pub fn set_validator_baseline_reward(session: &mut SessionExt, nominal_reward: u64) { + let serialized_values = serialize_values(&vec![ + MoveValue::Signer(AccountAddress::ZERO), // must be called by 0x0 + MoveValue::U64(nominal_reward), + ]); + + exec_function( + session, + "proof_of_fee", + "genesis_migrate_reward", + vec![], + serialized_values, + ); +} diff --git a/tools/genesis/src/supply.rs b/tools/genesis/src/supply.rs index aadd8571b..09dd24c5d 100644 --- a/tools/genesis/src/supply.rs +++ b/tools/genesis/src/supply.rs @@ -17,6 +17,9 @@ pub struct SupplySettings { /// for calculating escrow, what's the desired percent to future uses pub target_future_uses: f64, #[clap(long)] + /// for calculating base case validator reward + pub years_escrow: u64, + #[clap(long)] /// for future uses calc, are there any donor directed wallets which require mapping to slow wallets pub map_dd_to_slow: Vec, } @@ -26,6 +29,7 @@ impl Default for SupplySettings { Self { target_supply: 100_000_000_000.0, target_future_uses: 0.0, + years_escrow: 10, map_dd_to_slow: vec![], } } @@ -50,6 +54,7 @@ pub struct Supply { // which will compute later pub split_factor: f64, pub escrow_pct: f64, + pub epoch_reward_base_case: f64, } impl Supply { @@ -61,6 +66,9 @@ impl Supply { let target_future_uses = settings.target_future_uses * self.total; let remaining_to_fund = target_future_uses - self.donor_directed; self.escrow_pct = remaining_to_fund / self.slow_validator_locked; + self.epoch_reward_base_case = + remaining_to_fund / (365 * 100 * settings.years_escrow) as f64; // one hundred validators over 7 years every day. Note: discussed elsewhere: if this is an over estimate, the capital gets returned to community by the daily excess burn. + Ok(()) } } @@ -127,6 +135,7 @@ pub fn populate_supply_stats_from_legacy( donor_directed: 0.0, split_factor: 0.0, escrow_pct: 0.0, + epoch_reward_base_case: 0.0, }; let dd_wallets = rec @@ -162,6 +171,7 @@ fn test_genesis_math() { let settings = SupplySettings { target_supply: 10_000_000_000.0, target_future_uses: 0.70, + years_escrow: 10, map_dd_to_slow: vec![ // FTW "3A6C51A0B786D644590E8A21591FA8E2" diff --git a/tools/genesis/src/vm.rs b/tools/genesis/src/vm.rs index 313c57252..1f983fbc0 100644 --- a/tools/genesis/src/vm.rs +++ b/tools/genesis/src/vm.rs @@ -25,7 +25,10 @@ use diem_vm_genesis::{ }; use libra_types::{legacy_types::legacy_recovery::LegacyRecovery, ol_progress::OLProgress}; -use crate::{genesis_functions::rounding_mint, supply::SupplySettings}; +use crate::{ + genesis_functions::{rounding_mint, set_validator_baseline_reward}, + supply::{populate_supply_stats_from_legacy, SupplySettings}, +}; /// set the genesis parameters /// NOTE: many of the parameters are ignored in libra_framework @@ -131,8 +134,18 @@ pub fn encode_genesis_change_set( if let Some(r) = recovery { if !r.is_empty() { - crate::genesis_functions::genesis_migrate_all_users(&mut session, r, supply_settings) + let mut supply = populate_supply_stats_from_legacy(r, &supply_settings.map_dd_to_slow) + .expect("could not parse supply from legacy file"); + + supply + .set_ratios_from_settings(supply_settings) + .expect("could not set supply ratios from settings"); + + crate::genesis_functions::genesis_migrate_all_users(&mut session, r, &supply) .expect("could not migrate users"); + + // need to set the baseline reward based on supply settings + set_validator_baseline_reward(&mut session, supply.epoch_reward_base_case as u64); } } OLProgress::complete("user migration complete");