Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use cryptonote::reward_money in db_sqlite #1802

Open
wants to merge 73 commits into
base: dev
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
3646d08
WIP oxen->sent transition code
jagerman Jun 27, 2024
c4dc9b2
HF21 transition code mostly finished
tewinget Jul 9, 2024
7b5a0ee
Post-hf21 purge and deactivation limit
tewinget Dec 5, 2024
42754cc
Final HF20 block payout
tewinget Dec 6, 2024
e2deeeb
correct removal of nodes which did not go past hf21
tewinget Jan 9, 2025
5d07ebc
HF21 fixes and debug logging
tewinget Jan 9, 2025
f156496
rough-but-complete script for hf21 transition info
tewinget Jan 9, 2025
180866b
change localdev initial staking req to match contract
tewinget Jan 9, 2025
9d6006c
testnet hf21 height
tewinget Jan 9, 2025
b34f4bd
change testnet netid for chain restart
tewinget Jan 9, 2025
527645d
Don't apply HF dereg grace period to zombie nodes
tewinget Jan 10, 2025
f41787f
make hf21 zombies not payable
tewinget Jan 10, 2025
a5ea7d9
remove erroneous hf21 transition change
tewinget Jan 10, 2025
dd03f86
add hf21 dry run rpc method
tewinget Jan 23, 2025
b20b10f
local devnet retry on json-rpc 'error'
tewinget Jan 27, 2025
5a54706
hf21 transition: always set bls key if present, even if node fails tr…
tewinget Jan 27, 2025
c77429c
devnet restart for hf21 testing
tewinget Jan 27, 2025
5353058
add devnet reset old block hashes
tewinget Jan 27, 2025
7108ee1
fix inverted condition in daemon command
tewinget Jan 28, 2025
30f4c56
devnet temp hf heights, double staking req
tewinget Jan 28, 2025
8c649df
devnet timings underflow fix (and slow it down a little)
tewinget Jan 29, 2025
01b8b19
devnet hf20 height
tewinget Jan 30, 2025
96d60ce
(reverted later) devnet hf21 height and stop chain before
tewinget Feb 4, 2025
ca7844b
redo/fix pre-hf21 bulk payout for non-registrants
tewinget Feb 5, 2025
a6cffca
push devnet hf21 back a little
tewinget Feb 5, 2025
dfacb71
devnet hf21 parameters
tewinget Feb 5, 2025
ca70c19
fix uptime proofs using hf rules one block too early
tewinget Feb 5, 2025
f4e51bd
stop using old monero-style keys altogether at HF21
tewinget Feb 5, 2025
5d23fcb
fix stake scaling for hf21 transition for over-funded nodes
tewinget Feb 5, 2025
bb4d997
fix hf21_info stake scaling for over-funded nodes
tewinget Feb 5, 2025
25153b0
change devnet l2 tracker parameters
tewinget Feb 5, 2025
c19c5e1
remove devnet stall-before-hf21 code
tewinget Feb 5, 2025
f4e6743
devnet hf dereg grace period 100 blocks
tewinget Feb 5, 2025
374529e
devnet reboot for testing mainnet test contracts
tewinget Feb 6, 2025
4243e9f
cleanup
tewinget Feb 8, 2025
2819955
clang format
tewinget Feb 8, 2025
20b1323
hf21 ensure 'zombies' do not linger in recently removed
tewinget Feb 11, 2025
9828720
Move network config args into command_line.cpp
Doy-lee Feb 11, 2025
4912e71
Rmove unused offline field in Blockchain
Doy-lee Feb 13, 2025
a8b8a90
Move network config args into command_line.cpp
Doy-lee Feb 11, 2025
ddf7a1b
Remove unused macro BINARY_ARCHIVE_STREAM
Doy-lee Feb 11, 2025
331fb7b
Optimize/remove unused headers in command_line.h
Doy-lee Feb 12, 2025
f899062
Remove unused headers from core
Doy-lee Feb 12, 2025
f20952f
Remove unused headers in blockchain
Doy-lee Feb 13, 2025
e9407af
Make stacktrace a cmake build option, WITH_STACKTRACE
Doy-lee Feb 19, 2025
1c82e08
Add mocknet support via --fork-to-mocknet
Doy-lee Feb 13, 2025
bb9da36
Enable mocknet through CMake option WITH_MOCKNET
Doy-lee Feb 19, 2025
f7f8244
Mocknet changes to work on mainnet
Doy-lee Feb 24, 2025
95cb23d
Final HF21 payments must not payout 0 OXEN when truncated from DB OXEN
Doy-lee Feb 26, 2025
cb5c050
Gen data for making transition CSVs, block purging in mocknet
Doy-lee Feb 24, 2025
bffd366
Allow money printing to take custom decimal places
Doy-lee Feb 28, 2025
80b3268
Add more detail to the CSV dumps of the token transition
Doy-lee Feb 28, 2025
8a1aa91
Hide mocknet impl, pull transition parameters into struct
Doy-lee Feb 28, 2025
be2c586
Pass the transition context into the transition function
Doy-lee Mar 3, 2025
4f8180b
Remove unused parse_oxen/eth_address from sent_transition.h
Doy-lee Mar 3, 2025
a845879
Calc transition STAKING_RATIO at runtime, make conversion ratio 64bits
Doy-lee Mar 3, 2025
beb1b5e
Simplify mocknet construction of the transition parameters
Doy-lee Mar 3, 2025
7695a36
Revert some incorrect transition stat calculations
Doy-lee Mar 4, 2025
9d21326
Add sanity check of HF transition code when producing CSV reports
Doy-lee Mar 4, 2025
a2afb79
Add option to dump the transition CSVs, fix incorrect mocknet convers…
Doy-lee Mar 4, 2025
8835a49
SESH rewards need to be stored in DB units
Doy-lee Mar 4, 2025
6f284c0
Remove debugging hardforks for testing mocknet
Doy-lee Mar 5, 2025
3a13a86
Adjust mocknet to fork at chain height to follow codebase convention
Doy-lee Mar 5, 2025
cc395aa
Add braces around no-op macro when mocknet is disabled
Doy-lee Mar 5, 2025
16e03ed
Fix mocknet comment, use oxen::array_count
Doy-lee Mar 5, 2025
273767b
Linting pass
Doy-lee Mar 5, 2025
da5f3e8
Avoid querying block height before miner_tx is instantiated
Doy-lee Mar 5, 2025
cfe33df
Use constexpr bitset size in bytes to avoid clang-format bug
Doy-lee Mar 6, 2025
0318b5d
Use strong-typed reward_money in DB SQLite
Doy-lee Mar 5, 2025
42f4ece
Linting pass for reward_money change
Doy-lee Mar 6, 2025
ea82e61
Fix unit test for SQLite.CalculateRewards to use reward_money correctly
Doy-lee Mar 6, 2025
7b6dc7c
Handle N = 0 for reward handler
Doy-lee Mar 6, 2025
5a87795
Cross compile windows has a lowercase windows.h
Doy-lee Mar 6, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Linting pass
Doy-lee committed Mar 5, 2025
commit 273767b5ea233794764a0981f474c383b21dc43e
4 changes: 2 additions & 2 deletions src/blockchain_db/sqlite/db_sqlite.cpp
Original file line number Diff line number Diff line change
@@ -645,11 +645,11 @@ std::vector<cryptonote::batch_sn_payment> BlockchainSQLite::get_sn_payments(uint
const auto& address = pair.first;
const auto& amount = pair.second;
const uint64_t truncated_db_amount =
amount / BATCH_REWARD_FACTOR * BATCH_REWARD_FACTOR; // truncate to atomic OXEN
amount / BATCH_REWARD_FACTOR * BATCH_REWARD_FACTOR; // truncate to atomic OXEN

if (pre_hf21_final_payout) {
log::debug(logcat, "address {} has amount {}", address, amount);
if (sent_addr_map.contains(std::string{address})) // Registered for transition
if (sent_addr_map.contains(std::string{address})) // Registered for transition
continue;

if (truncated_db_amount > 0) {
1 change: 1 addition & 0 deletions src/common/exception.cpp
Original file line number Diff line number Diff line change
@@ -2,6 +2,7 @@
#include "exception.h"

#include <fmt/core.h>

#include <cstdio>
#include <sstream>

3 changes: 1 addition & 2 deletions src/crypto/crypto.cpp
Original file line number Diff line number Diff line change
@@ -755,8 +755,7 @@ bool check_key_image_signature(
return sc_isnonzero(h.data()) == 0;
}

secret_key ed25519_to_monero_secret_key(const ed25519_secret_key& skey)
{
secret_key ed25519_to_monero_secret_key(const ed25519_secret_key& skey) {
epee::wipeable_string privkey_signhash;
privkey_signhash.resize(crypto_hash_sha512_BYTES);
unsigned char* pk_sh_data = reinterpret_cast<unsigned char*>(privkey_signhash.data());
10 changes: 8 additions & 2 deletions src/cryptonote_basic/cryptonote_format_utils.h
Original file line number Diff line number Diff line change
@@ -298,10 +298,16 @@ constexpr std::string_view get_unit() {
return "OXEN"sv;
}
// Returns a monetary value with a decimal point; optionally strips insignificant trailing 0s.
std::string print_money(uint64_t amount, size_t decimal_places = oxen::DISPLAY_DECIMAL_POINT, bool strip_zeros = false);
std::string print_money(
uint64_t amount,
size_t decimal_places = oxen::DISPLAY_DECIMAL_POINT,
bool strip_zeros = false);
// Returns a formatted monetary value including the unit, e.g. "1.234567 OXEN"; strips
// insignificant trailing 0s by default (unlike the above) but can be overridden to not do that.
std::string format_money(uint64_t amount, size_t decimal_places = oxen::DISPLAY_DECIMAL_POINT, bool strip_zeros = true);
std::string format_money(
uint64_t amount,
size_t decimal_places = oxen::DISPLAY_DECIMAL_POINT,
bool strip_zeros = true);

std::string print_tx_verification_context(
tx_verification_context const& tvc, transaction const* tx = nullptr);
7 changes: 1 addition & 6 deletions src/cryptonote_core/blockchain.h
Original file line number Diff line number Diff line change
@@ -182,12 +182,7 @@ class Blockchain {
const cryptonote::test_options& test_options,
cryptonote::BlockchainSQLite* sqlite_db = nullptr) {
return init(
std::move(db),
network_type::FAKECHAIN,
nullptr,
sqlite_db,
nullptr,
&test_options);
std::move(db), network_type::FAKECHAIN, nullptr, sqlite_db, nullptr, &test_options);
}

/**
2 changes: 1 addition & 1 deletion src/cryptonote_core/cryptonote_core.cpp
Original file line number Diff line number Diff line change
@@ -66,11 +66,11 @@ extern "C" {
#include "epee/string_tools.h"
#include "epee/warnings.h"
#include "logging/oxen_logger.h"
#include "network_config/mocknet.h"
#include "ringct/rctSigs.h"
#include "ringct/rctTypes.h"
#include "uptime_proof.h"
#include "version.h"
#include "network_config/mocknet.h"

DISABLE_VS_WARNINGS(4355)

5 changes: 2 additions & 3 deletions src/cryptonote_core/pulse.cpp
Original file line number Diff line number Diff line change
@@ -8,12 +8,11 @@
#include "epee/memwipe.h"
#include "epee/wipeable_string.h"
#include "ethereum_transactions.h"
#include "network_config/mocknet.h"
#include "service_node_list.h"
#include "service_node_quorum_cop.h"
#include "service_node_rules.h"

#include "network_config/mocknet.h"

extern "C" {
#include <sodium/crypto_generichash.h>
};
@@ -239,7 +238,7 @@ namespace {
}

std::bitset<sizeof(uint16_t) * 8> bitset_view16(uint16_t val) {
std::bitset<sizeof(uint16_t)* 8> result = val;
std::bitset<sizeof(uint16_t) * 8> result = val;
return result;
}

13 changes: 7 additions & 6 deletions src/cryptonote_core/service_node_list.cpp
Original file line number Diff line number Diff line change
@@ -65,19 +65,19 @@
#include "epee/net/local_ip.h"
#include "ethereum_transactions.h"
#include "l2_tracker/events.h"
#include "network_config/mocknet.h"
#include "oxen/log.hpp"
#include "oxen_economy.h"
#include "pulse.h"
#include "ringct/rctSigs.h"
#include "ringct/rctTypes.h"
#include "sent_transition/sent_transition.h"
#include "serialization/deque.h"
#include "serialization/string.h"
#include "sent_transition/sent_transition.h"
#include "service_node_quorum_cop.h"
#include "service_node_rules.h"
#include "service_node_swarm.h"
#include "uptime_proof.h"
#include "network_config/mocknet.h"

using cryptonote::hf;
namespace feature = cryptonote::feature;
@@ -2559,8 +2559,7 @@ static std::string dump_pulse_block_data(
return s;
}

static bool check_pulse_timestamps(cryptonote::network_type nettype, uint64_t height)
{
static bool check_pulse_timestamps(cryptonote::network_type nettype, uint64_t height) {
// TODO(doyle): Core tests don't generate proper timestamps for detecting
// timeout yet. So we don't do a timeout check and assume all blocks
// incoming from Pulse are valid if they have the correct signatures
@@ -3787,7 +3786,8 @@ block_add_result service_node_list::state_t::update_from_block(
(uint8_t)nettype);
print_sns();
auto& sqlite_db = *sqlite_db_ptr;
oxen::sent::transition_context context = oxen::sent::get_transition_context(nettype, height);
oxen::sent::transition_context context =
oxen::sent::get_transition_context(nettype, height);
oxen::sent::transition(context, *this, sqlite_db, nettype);
print_sns();
}
@@ -6719,7 +6719,8 @@ service_node_list::hf21_transition_result service_node_list::hf21_dry_run(
insert_payment->reset();
}

oxen::sent::transition_context context = oxen::sent::get_transition_context(nettype, state_copy.height);
oxen::sent::transition_context context =
oxen::sent::get_transition_context(nettype, state_copy.height);
oxen::sent::transition(context, state_copy, db_copy, nettype);

return {state_copy.service_nodes_infos, db_copy.get_all_accrued_rewards()};
6 changes: 4 additions & 2 deletions src/l2_tracker/l2_tracker.cpp
Original file line number Diff line number Diff line change
@@ -639,8 +639,10 @@ void L2Tracker::update_purge_list(bool curr_height_fallback) {
// validator) even if we don't have it in our mempool as long as the
// purgeable conditions are met when we vote on it.
std::vector<std::pair<crypto::public_key, bls_public_key>> to_purge;
if (mocknet_has_forked(core.blockchain.get_current_blockchain_height() - 1) ||
mocknet_is_forking(core.blockchain.get_current_blockchain_height() - 1)) {
if (mocknet_has_forked(
core.blockchain.get_current_blockchain_height() - 1) ||
mocknet_is_forking(
core.blockchain.get_current_blockchain_height() - 1)) {
} else {
core.service_node_list.for_each_service_node(
[this, &to_purge](
16 changes: 9 additions & 7 deletions src/network_config/mocknet.cpp
Original file line number Diff line number Diff line change
@@ -256,7 +256,8 @@ void mocknet_inject_nodes(uint8_t nettype_u8, void* snl_state_ptr, uint8_t hf_ve

// NOTE: Log that we hit the mocknet pre-conditions
cryptonote::account_public_address zero_cn_address = {};
std::string zero_cn_address_str = cryptonote::get_account_address_as_str(nettype, false, zero_cn_address);
std::string zero_cn_address_str =
cryptonote::get_account_address_as_str(nettype, false, zero_cn_address);

fmt::memory_buffer debug_log;
fmt::format_to(
@@ -343,7 +344,8 @@ void mocknet_push_mock_pulse_block(cryptonote::core& core) {
std::memcpy(mock_producer.data(), MOCKNET_KEYS[0].ed25519_pubkey.data(), sizeof(mock_producer));

[[maybe_unused]] crypto::public_key mock_validator0;
std::memcpy(mock_validator0.data(), MOCKNET_KEYS[1].ed25519_pubkey.data(), sizeof(mock_validator0));
std::memcpy(
mock_validator0.data(), MOCKNET_KEYS[1].ed25519_pubkey.data(), sizeof(mock_validator0));

assert(quorum.workers.size());
assert(mock_producer == quorum.workers[0]);
@@ -369,7 +371,7 @@ void mocknet_push_mock_pulse_block(cryptonote::core& core) {
/*pulse round*/ 0,
/*validator handshake bitset*/ 0b0111'1111'1111, // Full participation
generated_height);
} catch(const std::exception& e) {
} catch (const std::exception& e) {
oxen::log::error(logcat, "Failed to generate block: {}", e.what());
}

@@ -432,7 +434,8 @@ void mocknet_push_mock_pulse_block(cryptonote::core& core) {
auto hf20_begins =
cryptonote::hard_fork_begins(net, cryptonote::hf::hf20_eth_transition).value_or(0);
if (block.get_height() == hf20_begins) {
std::vector<service_nodes::service_node_pubkey_info> snl_list = core.service_node_list.get_service_node_list_state();
std::vector<service_nodes::service_node_pubkey_info> snl_list =
core.service_node_list.get_service_node_list_state();

oxen::log::info(
globallogcat,
@@ -453,9 +456,8 @@ void mocknet_push_mock_pulse_block(cryptonote::core& core) {
}
}

void mocknet_get_transition_context(oxen::sent::transition_context& context)
{
context.conv_ratio = {1, 120}; // X SESH per Y OXEN
void mocknet_get_transition_context(oxen::sent::transition_context& context) {
context.conv_ratio = {1, 120}; // X SESH per Y OXEN
context.addresses = &globals.transition_addr_map;
context.bls_keys = &globals.transition_bls_keys;
context.transition_bonus = &globals.transition_bonus_map;
26 changes: 12 additions & 14 deletions src/sent_transition/sent_transition.cpp
Original file line number Diff line number Diff line change
@@ -93,8 +93,7 @@ static void dump_transition_outcome_csv(
network_type net,
std::span<node_transition> node_list,
const std::unordered_map<eth::address, uint64_t>& final_allocation_before_distrib,
const std::unordered_map<eth::address, uint64_t>& final_unlocked_tokens)
{
const std::unordered_map<eth::address, uint64_t>& final_unlocked_tokens) {
uint64_t now = time(nullptr);
oxen::log::debug(logcat, "Writing SESH->ETH allocation to disk");
uint64_t total_bonus_sesh = 0;
@@ -109,12 +108,12 @@ static void dump_transition_outcome_csv(

const size_t decimal_places = oxen::DISPLAY_DECIMAL_POINT;
{
auto file = fmt::output_file("{:%Y%m%d_%H%M%S}_sesh_transition_result_stake_req_{}_conv_ratio_{}_oxen_per_{}_sesh_eth_addr_allocation.csv"_format(
fmt::localtime(now),
cryptonote::print_money(context.staking_requirement, decimal_places, true),
cryptonote::print_money(context.conv_ratio.second),
cryptonote::print_money(context.conv_ratio.first))
);
auto file = fmt::output_file(
"{:%Y%m%d_%H%M%S}_sesh_transition_result_stake_req_{}_conv_ratio_{}_oxen_per_{}_sesh_eth_addr_allocation.csv"_format(
fmt::localtime(now),
cryptonote::print_money(context.staking_requirement, decimal_places, true),
cryptonote::print_money(context.conv_ratio.second),
cryptonote::print_money(context.conv_ratio.first)));
file.print("height,{}\n", snl_state.height);
file.print("rewards_program_snapshot_date,2025-02-27\n");
file.print(
@@ -146,17 +145,15 @@ static void dump_transition_outcome_csv(
for (auto it : final_unlocked_tokens) {
total_unlocked_sesh += it.second;
}
file.print(
"total_unlocked_sesh,{}\n", cryptonote::print_money(total_unlocked_sesh));
file.print("total_unlocked_sesh,{}\n", cryptonote::print_money(total_unlocked_sesh));
}

// NOTE: Calculate the amount of tokens generated
{
uint64_t total_generated_sesh = 0;
for (auto it : final_allocation_before_distrib)
total_generated_sesh += it.second;
file.print(
"total_generated_sesh,{}\n", cryptonote::print_money(total_generated_sesh));
file.print("total_generated_sesh,{}\n", cryptonote::print_money(total_generated_sesh));
}

// NOTE: Sort the final token allocations, highest to lowest
@@ -218,7 +215,6 @@ static void dump_transition_outcome_csv(
}
}
}

}
std::sort(
sorted.begin(),
@@ -234,7 +230,9 @@ static void dump_transition_outcome_csv(
cryptonote::print_money(context.conv_ratio.first));

// NOTE: Print out the allocation for each address
file.print("eth_addr,pre_transition_sn_count,post_transition_sn_count,bonus_sesh,staked_sesh,unlocked_sesh,total_sesh (staked+unlocked)\n");
file.print(
"eth_addr,pre_transition_sn_count,post_transition_sn_count,bonus_sesh,staked_sesh,"
"unlocked_sesh,total_sesh (staked+unlocked)\n");
size_t index = 0;
for (auto sorted_it : sorted) {