mirror of
https://git.wownero.com/wownero/wownero.git
synced 2024-08-15 01:03:23 +00:00
Initial commit
This commit is contained in:
parent
a486cae407
commit
d78da837ae
13 changed files with 95 additions and 184 deletions
10
README.md
10
README.md
|
@ -1,4 +1,4 @@
|
||||||
# Monero
|
# ~~Mo~~Wownero
|
||||||
|
|
||||||
Copyright (c) 2014-2018 The Monero Project.
|
Copyright (c) 2014-2018 The Monero Project.
|
||||||
Portions Copyright (c) 2012-2013 The Cryptonote developers.
|
Portions Copyright (c) 2012-2013 The Cryptonote developers.
|
||||||
|
@ -99,13 +99,7 @@ Dates are provided in the format YYYY-MM-DD.
|
||||||
|
|
||||||
| Software upgrade block height | Date | Fork version | Minimum Monero version | Recommended Monero version | Details |
|
| Software upgrade block height | Date | Fork version | Minimum Monero version | Recommended Monero version | Details |
|
||||||
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
||||||
| 1009827 | 2016-03-22 | v2 | v0.9.4 | v0.9.4 | Allow only >= ringsize 3, blocktime = 120 seconds, fee-free blocksize 60 kb |
|
| 1 | 2018-04-01 | v7 | v0.1.0.0 | v0.1.0.0 | Cryptonight variant 1, ringsize >= 8, sorted inputs
|
||||||
| 1141317 | 2016-09-21 | v3 | v0.9.4 | v0.10.0 | Splits coinbase into denominations |
|
|
||||||
| 1220516 | 2017-01-05 | v4 | v0.10.1 | v0.10.2.1 | Allow normal and RingCT transactions |
|
|
||||||
| 1288616 | 2017-04-15 | v5 | v0.10.3.0 | v0.10.3.1 | Adjusted minimum blocksize and fee algorithm |
|
|
||||||
| 1400000 | 2017-09-16 | v6 | v0.11.0.0 | v0.11.0.0 | Allow only RingCT transactions, allow only >= ringsize 5 |
|
|
||||||
| 1546000 | 2018-04-06 | v7 | v0.12.0.0 | v0.12.2.0 | Cryptonight variant 1, ringsize >= 7, sorted inputs
|
|
||||||
| XXXXXXX | 2018-10-XX | XX | XXXXXXXXX | XXXXXXXXX | X
|
|
||||||
|
|
||||||
X's indicate that these details have not been determined as of commit date.
|
X's indicate that these details have not been determined as of commit date.
|
||||||
|
|
||||||
|
|
|
@ -116,7 +116,7 @@ endif()
|
||||||
|
|
||||||
set_property(TARGET blockchain_import
|
set_property(TARGET blockchain_import
|
||||||
PROPERTY
|
PROPERTY
|
||||||
OUTPUT_NAME "monero-blockchain-import")
|
OUTPUT_NAME "wownero-blockchain-import")
|
||||||
install(TARGETS blockchain_import DESTINATION bin)
|
install(TARGETS blockchain_import DESTINATION bin)
|
||||||
|
|
||||||
monero_add_executable(blockchain_export
|
monero_add_executable(blockchain_export
|
||||||
|
@ -138,7 +138,7 @@ target_link_libraries(blockchain_export
|
||||||
|
|
||||||
set_property(TARGET blockchain_export
|
set_property(TARGET blockchain_export
|
||||||
PROPERTY
|
PROPERTY
|
||||||
OUTPUT_NAME "monero-blockchain-export")
|
OUTPUT_NAME "wownero-blockchain-export")
|
||||||
install(TARGETS blockchain_export DESTINATION bin)
|
install(TARGETS blockchain_export DESTINATION bin)
|
||||||
|
|
||||||
monero_add_executable(blockchain_blackball
|
monero_add_executable(blockchain_blackball
|
||||||
|
@ -161,7 +161,7 @@ target_link_libraries(blockchain_blackball
|
||||||
|
|
||||||
set_property(TARGET blockchain_blackball
|
set_property(TARGET blockchain_blackball
|
||||||
PROPERTY
|
PROPERTY
|
||||||
OUTPUT_NAME "monero-blockchain-blackball")
|
OUTPUT_NAME "wownero-blockchain-blackball")
|
||||||
install(TARGETS blockchain_blackball DESTINATION bin)
|
install(TARGETS blockchain_blackball DESTINATION bin)
|
||||||
|
|
||||||
|
|
||||||
|
@ -184,6 +184,6 @@ target_link_libraries(blockchain_usage
|
||||||
|
|
||||||
set_property(TARGET blockchain_usage
|
set_property(TARGET blockchain_usage
|
||||||
PROPERTY
|
PROPERTY
|
||||||
OUTPUT_NAME "monero-blockchain-usage")
|
OUTPUT_NAME "wownero-blockchain-usage")
|
||||||
install(TARGETS blockchain_usage DESTINATION bin)
|
install(TARGETS blockchain_usage DESTINATION bin)
|
||||||
|
|
||||||
|
|
82
src/checkpoints/checkpoints.cpp
Normal file → Executable file
82
src/checkpoints/checkpoints.cpp
Normal file → Executable file
|
@ -160,59 +160,20 @@ namespace cryptonote
|
||||||
}
|
}
|
||||||
|
|
||||||
bool checkpoints::init_default_checkpoints(network_type nettype)
|
bool checkpoints::init_default_checkpoints(network_type nettype)
|
||||||
{
|
{
|
||||||
if (nettype == TESTNET)
|
if (nettype == TESTNET) {
|
||||||
{
|
return true;
|
||||||
ADD_CHECKPOINT(0, "48ca7cd3c8de5b6a4d53d2861fbdaedca141553559f9be9520068053cda8430b");
|
}
|
||||||
ADD_CHECKPOINT(1000000, "46b690b710a07ea051bc4a6b6842ac37be691089c0f7758cfeec4d5fc0b4a258");
|
if (nettype == STAGENET) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (nettype == STAGENET)
|
|
||||||
{
|
|
||||||
ADD_CHECKPOINT(0, "76ee3cc98646292206cd3e86f74d88b4dcc1d937088645e9b0cbca84b7ce74eb");
|
|
||||||
ADD_CHECKPOINT(10000, "1f8b0ce313f8b9ba9a46108bfd285c45ad7c2176871fd41c3a690d4830ce2fd5");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
ADD_CHECKPOINT(1, "771fbcd656ec1464d3a02ead5e18644030007a0fc664c0a964d30922821a8148");
|
|
||||||
ADD_CHECKPOINT(10, "c0e3b387e47042f72d8ccdca88071ff96bff1ac7cde09ae113dbb7ad3fe92381");
|
|
||||||
ADD_CHECKPOINT(100, "ac3e11ca545e57c49fca2b4e8c48c03c23be047c43e471e1394528b1f9f80b2d");
|
|
||||||
ADD_CHECKPOINT(1000, "5acfc45acffd2b2e7345caf42fa02308c5793f15ec33946e969e829f40b03876");
|
|
||||||
ADD_CHECKPOINT(10000, "c758b7c81f928be3295d45e230646de8b852ec96a821eac3fea4daf3fcac0ca2");
|
|
||||||
ADD_CHECKPOINT(22231, "7cb10e29d67e1c069e6e11b17d30b809724255fee2f6868dc14cfc6ed44dfb25");
|
|
||||||
ADD_CHECKPOINT(29556, "53c484a8ed91e4da621bb2fa88106dbde426fe90d7ef07b9c1e5127fb6f3a7f6");
|
|
||||||
ADD_CHECKPOINT(50000, "0fe8758ab06a8b9cb35b7328fd4f757af530a5d37759f9d3e421023231f7b31c");
|
|
||||||
ADD_CHECKPOINT(80000, "a62dcd7b536f22e003ebae8726e9e7276f63d594e264b6f0cd7aab27b66e75e3");
|
|
||||||
ADD_CHECKPOINT(202612, "bbd604d2ba11ba27935e006ed39c9bfdd99b76bf4a50654bc1e1e61217962698");
|
|
||||||
ADD_CHECKPOINT(202613, "e2aa337e78df1f98f462b3b1e560c6b914dec47b610698b7b7d1e3e86b6197c2");
|
|
||||||
ADD_CHECKPOINT(202614, "c29e3dc37d8da3e72e506e31a213a58771b24450144305bcba9e70fa4d6ea6fb");
|
|
||||||
ADD_CHECKPOINT(205000, "5d3d7a26e6dc7535e34f03def711daa8c263785f73ec1fadef8a45880fde8063");
|
|
||||||
ADD_CHECKPOINT(220000, "9613f455933c00e3e33ac315cc6b455ee8aa0c567163836858c2d9caff111553");
|
|
||||||
ADD_CHECKPOINT(230300, "bae7a80c46859db355556e3a9204a337ae8f24309926a1312323fdecf1920e61");
|
|
||||||
ADD_CHECKPOINT(230700, "93e631240ceac831da1aebfc5dac8f722c430463024763ebafa888796ceaeedf");
|
|
||||||
ADD_CHECKPOINT(231350, "b5add137199b820e1ea26640e5c3e121fd85faa86a1e39cf7e6cc097bdeb1131");
|
|
||||||
ADD_CHECKPOINT(232150, "955de8e6b6508af2c24f7334f97beeea651d78e9ade3ab18fec3763be3201aa8");
|
|
||||||
ADD_CHECKPOINT(249380, "654fb0a81ce3e5caf7e3264a70f447d4bd07586c08fa50f6638cc54da0a52b2d");
|
|
||||||
ADD_CHECKPOINT(460000, "75037a7aed3e765db96c75bcf908f59d690a5f3390baebb9edeafd336a1c4831");
|
|
||||||
ADD_CHECKPOINT(500000, "2428f0dbe49796be05ed81b347f53e1f7f44aed0abf641446ec2b94cae066b02");
|
|
||||||
ADD_CHECKPOINT(600000, "f5828ebf7d7d1cb61762c4dfe3ccf4ecab2e1aad23e8113668d981713b7a54c5");
|
|
||||||
ADD_CHECKPOINT(700000, "12be9b3d210b93f574d2526abb9c1ab2a881b479131fd0d4f7dac93875f503cd");
|
|
||||||
ADD_CHECKPOINT(825000, "56503f9ad766774b575be3aff73245e9d159be88132c93d1754764f28da2ff60");
|
|
||||||
ADD_CHECKPOINT(900000, "d9958d0e7dcf91a5a7b11de225927bf7efc6eb26240315ce12372be902cc1337");
|
|
||||||
ADD_CHECKPOINT(913193, "5292d5d56f6ba4de33a58d9a34d263e2cb3c6fee0aed2286fd4ac7f36d53c85f");
|
|
||||||
ADD_CHECKPOINT(1000000, "a886ef5149902d8342475fee9bb296341b891ac67c4842f47a833f23c00ed721");
|
|
||||||
ADD_CHECKPOINT(1100000, "3fd720c5c8b3072fc1ccda922dec1ef25f9ed88a1e6ad4103d0fe00b180a5903");
|
|
||||||
ADD_CHECKPOINT(1150000, "1dd16f626d18e1e988490dfd06de5920e22629c972c58b4d8daddea0038627b2");
|
|
||||||
ADD_CHECKPOINT(1200000, "fa7d13a90850882060479d100141ff84286599ae39c3277c8ea784393f882d1f");
|
|
||||||
ADD_CHECKPOINT(1300000, "31b34272343a44a9f4ac7de7a8fcf3b7d8a3124d7d6870affd510d2f37e74cd0");
|
|
||||||
ADD_CHECKPOINT(1390000, "a8f5649dd4ded60eedab475f2bec8c934681c07e3cf640e9be0617554f13ff6c");
|
|
||||||
ADD_CHECKPOINT(1450000, "ac94e8860093bc7c83e4e91215cba1d663421ecf4067a0ae609c3a8b52bcfac2");
|
|
||||||
ADD_CHECKPOINT(1530000, "01759bce497ec38e63c78b1038892169203bb78f87e488172f6b854fcd63ba7e");
|
|
||||||
ADD_CHECKPOINT(1579000, "7d0d7a2346373afd41ed1e744a939fc5d474a7dbaa257be5c6fff4009e789241");
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool checkpoints::load_checkpoints_from_json(const std::string &json_hashfile_fullpath)
|
||||||
|
|
||||||
bool checkpoints::load_checkpoints_from_json(const std::string &json_hashfile_fullpath)
|
|
||||||
{
|
{
|
||||||
boost::system::error_code errcode;
|
boost::system::error_code errcode;
|
||||||
if (! (boost::filesystem::exists(json_hashfile_fullpath, errcode)))
|
if (! (boost::filesystem::exists(json_hashfile_fullpath, errcode)))
|
||||||
|
@ -253,17 +214,13 @@ namespace cryptonote
|
||||||
std::vector<std::string> records;
|
std::vector<std::string> records;
|
||||||
|
|
||||||
// All four MoneroPulse domains have DNSSEC on and valid
|
// All four MoneroPulse domains have DNSSEC on and valid
|
||||||
static const std::vector<std::string> dns_urls = { "checkpoints.moneropulse.se"
|
static const std::vector<std::string> dns_urls = {
|
||||||
, "checkpoints.moneropulse.org"
|
};
|
||||||
, "checkpoints.moneropulse.net"
|
|
||||||
, "checkpoints.moneropulse.co"
|
|
||||||
};
|
static const std::vector<std::string> testnet_dns_urls = {
|
||||||
|
};
|
||||||
|
|
||||||
static const std::vector<std::string> testnet_dns_urls = { "testpoints.moneropulse.se"
|
|
||||||
, "testpoints.moneropulse.org"
|
|
||||||
, "testpoints.moneropulse.net"
|
|
||||||
, "testpoints.moneropulse.co"
|
|
||||||
};
|
|
||||||
|
|
||||||
static const std::vector<std::string> stagenet_dns_urls = { "stagenetpoints.moneropulse.se"
|
static const std::vector<std::string> stagenet_dns_urls = { "stagenetpoints.moneropulse.se"
|
||||||
, "stagenetpoints.moneropulse.org"
|
, "stagenetpoints.moneropulse.org"
|
||||||
|
@ -317,3 +274,6 @@ namespace cryptonote
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
50
src/cryptonote_config.h
Normal file → Executable file
50
src/cryptonote_config.h
Normal file → Executable file
|
@ -42,8 +42,8 @@
|
||||||
#define CRYPTONOTE_PUBLIC_ADDRESS_TEXTBLOB_VER 0
|
#define CRYPTONOTE_PUBLIC_ADDRESS_TEXTBLOB_VER 0
|
||||||
#define CRYPTONOTE_MINED_MONEY_UNLOCK_WINDOW 60
|
#define CRYPTONOTE_MINED_MONEY_UNLOCK_WINDOW 60
|
||||||
#define CURRENT_TRANSACTION_VERSION 2
|
#define CURRENT_TRANSACTION_VERSION 2
|
||||||
#define CURRENT_BLOCK_MAJOR_VERSION 1
|
#define CURRENT_BLOCK_MAJOR_VERSION 7
|
||||||
#define CURRENT_BLOCK_MINOR_VERSION 0
|
#define CURRENT_BLOCK_MINOR_VERSION 7
|
||||||
#define CRYPTONOTE_BLOCK_FUTURE_TIME_LIMIT 60*60*2
|
#define CRYPTONOTE_BLOCK_FUTURE_TIME_LIMIT 60*60*2
|
||||||
#define CRYPTONOTE_DEFAULT_TX_SPENDABLE_AGE 10
|
#define CRYPTONOTE_DEFAULT_TX_SPENDABLE_AGE 10
|
||||||
|
|
||||||
|
@ -51,17 +51,17 @@
|
||||||
|
|
||||||
// MONEY_SUPPLY - total number coins to be generated
|
// MONEY_SUPPLY - total number coins to be generated
|
||||||
#define MONEY_SUPPLY ((uint64_t)(-1))
|
#define MONEY_SUPPLY ((uint64_t)(-1))
|
||||||
#define EMISSION_SPEED_FACTOR_PER_MINUTE (20)
|
#define EMISSION_SPEED_FACTOR_PER_MINUTE (24)
|
||||||
#define FINAL_SUBSIDY_PER_MINUTE ((uint64_t)300000000000) // 3 * pow(10, 11)
|
#define FINAL_SUBSIDY_PER_MINUTE ((uint64_t)(0))
|
||||||
|
|
||||||
#define CRYPTONOTE_REWARD_BLOCKS_WINDOW 100
|
#define CRYPTONOTE_REWARD_BLOCKS_WINDOW 100
|
||||||
#define CRYPTONOTE_BLOCK_GRANTED_FULL_REWARD_ZONE_V2 60000 //size of block (bytes) after which reward for block calculated using block size
|
#define CRYPTONOTE_BLOCK_GRANTED_FULL_REWARD_ZONE_V2 60000 //size of block (bytes) after which reward for block calculated using block size
|
||||||
#define CRYPTONOTE_BLOCK_GRANTED_FULL_REWARD_ZONE_V1 20000 //size of block (bytes) after which reward for block calculated using block size - before first fork
|
#define CRYPTONOTE_BLOCK_GRANTED_FULL_REWARD_ZONE_V1 20000 //size of block (bytes) after which reward for block calculated using block size - before first fork
|
||||||
#define CRYPTONOTE_BLOCK_GRANTED_FULL_REWARD_ZONE_V5 300000 //size of block (bytes) after which reward for block calculated using block size - second change, from v5
|
#define CRYPTONOTE_BLOCK_GRANTED_FULL_REWARD_ZONE_V5 300000 //size of block (bytes) after which reward for block calculated using block size - second change, from v5
|
||||||
#define CRYPTONOTE_COINBASE_BLOB_RESERVED_SIZE 600
|
#define CRYPTONOTE_COINBASE_BLOB_RESERVED_SIZE 600
|
||||||
#define CRYPTONOTE_DISPLAY_DECIMAL_POINT 12
|
#define CRYPTONOTE_DISPLAY_DECIMAL_POINT 11
|
||||||
// COIN - number of smallest units in one coin
|
// COIN - number of smallest units in one coin
|
||||||
#define COIN ((uint64_t)1000000000000) // pow(10, 12)
|
#define COIN ((uint64_t)(100000000000))
|
||||||
|
|
||||||
#define FEE_PER_KB_OLD ((uint64_t)10000000000) // pow(10, 10)
|
#define FEE_PER_KB_OLD ((uint64_t)10000000000) // pow(10, 10)
|
||||||
#define FEE_PER_KB ((uint64_t)2000000000) // 2 * pow(10, 9)
|
#define FEE_PER_KB ((uint64_t)2000000000) // 2 * pow(10, 9)
|
||||||
|
@ -72,8 +72,8 @@
|
||||||
#define ORPHANED_BLOCKS_MAX_COUNT 100
|
#define ORPHANED_BLOCKS_MAX_COUNT 100
|
||||||
|
|
||||||
|
|
||||||
#define DIFFICULTY_TARGET_V2 120 // seconds
|
#define DIFFICULTY_TARGET_V2 300
|
||||||
#define DIFFICULTY_TARGET_V1 60 // seconds - before first fork
|
#define DIFFICULTY_TARGET_V1 300
|
||||||
#define DIFFICULTY_WINDOW 720 // blocks
|
#define DIFFICULTY_WINDOW 720 // blocks
|
||||||
#define DIFFICULTY_LAG 15 // !!!
|
#define DIFFICULTY_LAG 15 // !!!
|
||||||
#define DIFFICULTY_CUT 60 // timestamps to cut after sorting
|
#define DIFFICULTY_CUT 60 // timestamps to cut after sorting
|
||||||
|
@ -121,7 +121,7 @@
|
||||||
|
|
||||||
#define ALLOW_DEBUG_COMMANDS
|
#define ALLOW_DEBUG_COMMANDS
|
||||||
|
|
||||||
#define CRYPTONOTE_NAME "bitmonero"
|
#define CRYPTONOTE_NAME "wownero"
|
||||||
#define CRYPTONOTE_POOLDATA_FILENAME "poolstate.bin"
|
#define CRYPTONOTE_POOLDATA_FILENAME "poolstate.bin"
|
||||||
#define CRYPTONOTE_BLOCKCHAINDATA_FILENAME "data.mdb"
|
#define CRYPTONOTE_BLOCKCHAINDATA_FILENAME "data.mdb"
|
||||||
#define CRYPTONOTE_BLOCKCHAINDATA_LOCK_FILENAME "lock.mdb"
|
#define CRYPTONOTE_BLOCKCHAINDATA_LOCK_FILENAME "lock.mdb"
|
||||||
|
@ -132,7 +132,7 @@
|
||||||
|
|
||||||
#define HF_VERSION_DYNAMIC_FEE 4
|
#define HF_VERSION_DYNAMIC_FEE 4
|
||||||
#define HF_VERSION_MIN_MIXIN_4 6
|
#define HF_VERSION_MIN_MIXIN_4 6
|
||||||
#define HF_VERSION_MIN_MIXIN_6 7
|
#define HF_VERSION_MIN_MIXIN_7 7
|
||||||
#define HF_VERSION_ENFORCE_RCT 6
|
#define HF_VERSION_ENFORCE_RCT 6
|
||||||
|
|
||||||
#define PER_KB_FEE_QUANTIZATION_DECIMALS 8
|
#define PER_KB_FEE_QUANTIZATION_DECIMALS 8
|
||||||
|
@ -150,31 +150,31 @@ namespace config
|
||||||
uint64_t const BASE_REWARD_CLAMP_THRESHOLD = ((uint64_t)100000000); // pow(10, 8)
|
uint64_t const BASE_REWARD_CLAMP_THRESHOLD = ((uint64_t)100000000); // pow(10, 8)
|
||||||
std::string const P2P_REMOTE_DEBUG_TRUSTED_PUB_KEY = "0000000000000000000000000000000000000000000000000000000000000000";
|
std::string const P2P_REMOTE_DEBUG_TRUSTED_PUB_KEY = "0000000000000000000000000000000000000000000000000000000000000000";
|
||||||
|
|
||||||
uint64_t const CRYPTONOTE_PUBLIC_ADDRESS_BASE58_PREFIX = 18;
|
uint64_t const CRYPTONOTE_PUBLIC_ADDRESS_BASE58_PREFIX = 4146;
|
||||||
uint64_t const CRYPTONOTE_PUBLIC_INTEGRATED_ADDRESS_BASE58_PREFIX = 19;
|
uint64_t const CRYPTONOTE_PUBLIC_INTEGRATED_ADDRESS_BASE58_PREFIX = 6810;
|
||||||
uint64_t const CRYPTONOTE_PUBLIC_SUBADDRESS_BASE58_PREFIX = 42;
|
uint64_t const CRYPTONOTE_PUBLIC_SUBADDRESS_BASE58_PREFIX = 12208;
|
||||||
uint16_t const P2P_DEFAULT_PORT = 18080;
|
uint16_t const P2P_DEFAULT_PORT = 34567;
|
||||||
uint16_t const RPC_DEFAULT_PORT = 18081;
|
uint16_t const RPC_DEFAULT_PORT = 34568;
|
||||||
uint16_t const ZMQ_RPC_DEFAULT_PORT = 18082;
|
uint16_t const ZMQ_RPC_DEFAULT_PORT = 34569;
|
||||||
boost::uuids::uuid const NETWORK_ID = { {
|
boost::uuids::uuid const NETWORK_ID = { {
|
||||||
0x12 ,0x30, 0xF1, 0x71 , 0x61, 0x04 , 0x41, 0x61, 0x17, 0x31, 0x00, 0x82, 0x16, 0xA1, 0xA1, 0x10
|
0x11, 0x33, 0xFF, 0x77, 0x61, 0x04, 0x41, 0x61, 0x17, 0x31, 0x00, 0x82, 0x16, 0xA1, 0xA1, 0x10
|
||||||
} }; // Bender's nightmare
|
} }; // Bender's nightmare
|
||||||
std::string const GENESIS_TX = "013c01ff0001ffffffffffff03029b2e4c0281c0b02e7c53291a94d1d0cbff8883f8024f5142ee494ffbbd08807121017767aafcde9be00dcfd098715ebcf7f410daebc582fda69d24a28e9d0bc890d1";
|
std::string const GENESIS_TX = "013c01ff0001ffffffffff1f029b2e4c0281c0b02e7c53291a94d1d0cbff8883f8024f5142ee494ffbbd08807121012a1a936be5d91c01ee876e38c13fab0ee11cbe86011a2bf7740fb5ebd39d267d";
|
||||||
uint32_t const GENESIS_NONCE = 10000;
|
uint32_t const GENESIS_NONCE = 70;
|
||||||
|
|
||||||
namespace testnet
|
namespace testnet
|
||||||
{
|
{
|
||||||
uint64_t const CRYPTONOTE_PUBLIC_ADDRESS_BASE58_PREFIX = 53;
|
uint64_t const CRYPTONOTE_PUBLIC_ADDRESS_BASE58_PREFIX = 53;
|
||||||
uint64_t const CRYPTONOTE_PUBLIC_INTEGRATED_ADDRESS_BASE58_PREFIX = 54;
|
uint64_t const CRYPTONOTE_PUBLIC_INTEGRATED_ADDRESS_BASE58_PREFIX = 54;
|
||||||
uint64_t const CRYPTONOTE_PUBLIC_SUBADDRESS_BASE58_PREFIX = 63;
|
uint64_t const CRYPTONOTE_PUBLIC_SUBADDRESS_BASE58_PREFIX = 63;
|
||||||
uint16_t const P2P_DEFAULT_PORT = 28080;
|
uint16_t const P2P_DEFAULT_PORT = 11180;
|
||||||
uint16_t const RPC_DEFAULT_PORT = 28081;
|
uint16_t const RPC_DEFAULT_PORT = 11181;
|
||||||
uint16_t const ZMQ_RPC_DEFAULT_PORT = 28082;
|
uint16_t const ZMQ_RPC_DEFAULT_PORT = 11182;
|
||||||
boost::uuids::uuid const NETWORK_ID = { {
|
boost::uuids::uuid const NETWORK_ID = { {
|
||||||
0x12 ,0x30, 0xF1, 0x71 , 0x61, 0x04 , 0x41, 0x61, 0x17, 0x31, 0x00, 0x82, 0x16, 0xA1, 0xA1, 0x11
|
0x11, 0x33, 0xFF, 0x77, 0x61, 0x04, 0x41, 0x61, 0x17, 0x31, 0x00, 0x82, 0x16, 0xA1, 0xA1, 0x11
|
||||||
} }; // Bender's daydream
|
} }; // Bender's daydream
|
||||||
std::string const GENESIS_TX = "013c01ff0001ffffffffffff03029b2e4c0281c0b02e7c53291a94d1d0cbff8883f8024f5142ee494ffbbd08807121017767aafcde9be00dcfd098715ebcf7f410daebc582fda69d24a28e9d0bc890d1";
|
std::string const GENESIS_TX = "013c01ff0001ffffffffff1f029b2e4c0281c0b02e7c53291a94d1d0cbff8883f8024f5142ee494ffbbd088071210160eb755f618a2336055dee60f307fe0ded81c5b37b53d310175ca9ee69b0c8ad";
|
||||||
uint32_t const GENESIS_NONCE = 10001;
|
uint32_t const GENESIS_NONCE = 70;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace stagenet
|
namespace stagenet
|
||||||
|
|
53
src/cryptonote_core/blockchain.cpp
Normal file → Executable file
53
src/cryptonote_core/blockchain.cpp
Normal file → Executable file
|
@ -89,28 +89,11 @@ static const struct {
|
||||||
uint8_t threshold;
|
uint8_t threshold;
|
||||||
time_t time;
|
time_t time;
|
||||||
} mainnet_hard_forks[] = {
|
} mainnet_hard_forks[] = {
|
||||||
// version 1 from the start of the blockchain
|
//{ 1, 1, 0, 1341378000 },
|
||||||
{ 1, 1, 0, 1341378000 },
|
{ 7, 1, 0, 1519605000 }
|
||||||
|
|
||||||
// version 2 starts from block 1009827, which is on or around the 20th of March, 2016. Fork time finalised on 2015-09-20. No fork voting occurs for the v2 fork.
|
|
||||||
{ 2, 1009827, 0, 1442763710 },
|
|
||||||
|
|
||||||
// version 3 starts from block 1141317, which is on or around the 24th of September, 2016. Fork time finalised on 2016-03-21.
|
|
||||||
{ 3, 1141317, 0, 1458558528 },
|
|
||||||
|
|
||||||
// version 4 starts from block 1220516, which is on or around the 5th of January, 2017. Fork time finalised on 2016-09-18.
|
|
||||||
{ 4, 1220516, 0, 1483574400 },
|
|
||||||
|
|
||||||
// version 5 starts from block 1288616, which is on or around the 15th of April, 2017. Fork time finalised on 2017-03-14.
|
|
||||||
{ 5, 1288616, 0, 1489520158 },
|
|
||||||
|
|
||||||
// version 6 starts from block 1400000, which is on or around the 16th of September, 2017. Fork time finalised on 2017-08-18.
|
|
||||||
{ 6, 1400000, 0, 1503046577 },
|
|
||||||
|
|
||||||
// version 7 starts from block 1546000, which is on or around the 6th of April, 2018. Fork time finalised on 2018-03-17.
|
|
||||||
{ 7, 1546000, 0, 1521303150 },
|
|
||||||
};
|
};
|
||||||
static const uint64_t mainnet_hard_fork_version_1_till = 1009826;
|
|
||||||
|
static const uint64_t mainnet_hard_fork_version_1_till = ((uint64_t)(0));
|
||||||
|
|
||||||
static const struct {
|
static const struct {
|
||||||
uint8_t version;
|
uint8_t version;
|
||||||
|
@ -118,22 +101,11 @@ static const struct {
|
||||||
uint8_t threshold;
|
uint8_t threshold;
|
||||||
time_t time;
|
time_t time;
|
||||||
} testnet_hard_forks[] = {
|
} testnet_hard_forks[] = {
|
||||||
// version 1 from the start of the blockchain
|
//{ 1, 1, 0, 1341378000 },
|
||||||
{ 1, 1, 0, 1341378000 },
|
{ 7, 1, 0, 1519605000 }
|
||||||
|
|
||||||
// version 2 starts from block 624634, which is on or around the 23rd of November, 2015. Fork time finalised on 2015-11-20. No fork voting occurs for the v2 fork.
|
|
||||||
{ 2, 624634, 0, 1445355000 },
|
|
||||||
|
|
||||||
// versions 3-5 were passed in rapid succession from September 18th, 2016
|
|
||||||
{ 3, 800500, 0, 1472415034 },
|
|
||||||
{ 4, 801219, 0, 1472415035 },
|
|
||||||
{ 5, 802660, 0, 1472415036 + 86400*180 }, // add 5 months on testnet to shut the update warning up since there's a large gap to v6
|
|
||||||
|
|
||||||
{ 6, 971400, 0, 1501709789 },
|
|
||||||
{ 7, 1057027, 0, 1512211236 },
|
|
||||||
{ 8, 1057058, 0, 1515967497 },
|
|
||||||
};
|
};
|
||||||
static const uint64_t testnet_hard_fork_version_1_till = 624633;
|
|
||||||
|
static const uint64_t testnet_hard_fork_version_1_till = ((uint64_t)(1));
|
||||||
|
|
||||||
static const struct {
|
static const struct {
|
||||||
uint8_t version;
|
uint8_t version;
|
||||||
|
@ -2614,7 +2586,7 @@ bool Blockchain::check_tx_inputs(transaction& tx, tx_verification_context &tvc,
|
||||||
{
|
{
|
||||||
size_t n_unmixable = 0, n_mixable = 0;
|
size_t n_unmixable = 0, n_mixable = 0;
|
||||||
size_t mixin = std::numeric_limits<size_t>::max();
|
size_t mixin = std::numeric_limits<size_t>::max();
|
||||||
const size_t min_mixin = hf_version >= HF_VERSION_MIN_MIXIN_6 ? 6 : hf_version >= HF_VERSION_MIN_MIXIN_4 ? 4 : 2;
|
const size_t min_mixin = hf_version >= HF_VERSION_MIN_MIXIN_7 ? 7 : hf_version >= HF_VERSION_MIN_MIXIN_4 ? 4 : 2;
|
||||||
for (const auto& txin : tx.vin)
|
for (const auto& txin : tx.vin)
|
||||||
{
|
{
|
||||||
// non txin_to_key inputs will be rejected below
|
// non txin_to_key inputs will be rejected below
|
||||||
|
@ -3695,7 +3667,7 @@ void Blockchain::check_against_checkpoints(const checkpoints& points, bool enfor
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LOG_ERROR("WARNING: local blockchain failed to pass a MoneroPulse checkpoint, and you could be on a fork. You should either sync up from scratch, OR download a fresh blockchain bootstrap, OR enable checkpoint enforcing with the --enforce-dns-checkpointing command-line option");
|
LOG_ERROR("WARNING: local blockchain failed to pass a WowneroPulse checkpoint, and you could be on a fork. You should either sync up from scratch, OR download a fresh blockchain bootstrap, OR enable checkpoint enforcing with the --enforce-dns-checkpointing command-line option");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3913,6 +3885,9 @@ uint64_t Blockchain::prevalidate_block_hashes(uint64_t height, const std::list<c
|
||||||
|
|
||||||
crypto::hash hash;
|
crypto::hash hash;
|
||||||
cn_fast_hash(data.data() + (n - first_index) * HASH_OF_HASHES_STEP, HASH_OF_HASHES_STEP * sizeof(crypto::hash), hash);
|
cn_fast_hash(data.data() + (n - first_index) * HASH_OF_HASHES_STEP, HASH_OF_HASHES_STEP * sizeof(crypto::hash), hash);
|
||||||
|
MWARNING("block: " << height << " - " << epee::string_tools::pod_to_hex(hashes.front()));
|
||||||
|
MWARNING("block: " << height + hashes.size() << " - " << epee::string_tools::pod_to_hex(hashes.back()));
|
||||||
|
MWARNING("first_index: " << first_index << " - " << last_index);
|
||||||
bool valid = hash == m_blocks_hash_of_hashes[n];
|
bool valid = hash == m_blocks_hash_of_hashes[n];
|
||||||
|
|
||||||
// add to the known hashes array
|
// add to the known hashes array
|
||||||
|
@ -4545,3 +4520,5 @@ bool Blockchain::for_all_outputs(uint64_t amount, std::function<bool(uint64_t he
|
||||||
namespace cryptonote {
|
namespace cryptonote {
|
||||||
template bool Blockchain::get_transactions(const std::vector<crypto::hash>&, std::list<transaction>&, std::list<crypto::hash>&) const;
|
template bool Blockchain::get_transactions(const std::vector<crypto::hash>&, std::list<transaction>&, std::list<crypto::hash>&) const;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -106,5 +106,5 @@ target_link_libraries(daemon
|
||||||
${EXTRA_LIBRARIES})
|
${EXTRA_LIBRARIES})
|
||||||
set_property(TARGET daemon
|
set_property(TARGET daemon
|
||||||
PROPERTY
|
PROPERTY
|
||||||
OUTPUT_NAME "monerod")
|
OUTPUT_NAME "wownerod")
|
||||||
install(TARGETS daemon DESTINATION bin)
|
install(TARGETS daemon DESTINATION bin)
|
||||||
|
|
0
src/p2p/net_node.cpp
Normal file → Executable file
0
src/p2p/net_node.cpp
Normal file → Executable file
31
src/p2p/net_node.inl
Normal file → Executable file
31
src/p2p/net_node.inl
Normal file → Executable file
|
@ -369,31 +369,13 @@ namespace nodetool
|
||||||
std::set<std::string> node_server<t_payload_net_handler>::get_seed_nodes(cryptonote::network_type nettype) const
|
std::set<std::string> node_server<t_payload_net_handler>::get_seed_nodes(cryptonote::network_type nettype) const
|
||||||
{
|
{
|
||||||
std::set<std::string> full_addrs;
|
std::set<std::string> full_addrs;
|
||||||
if (nettype == cryptonote::TESTNET)
|
if (nettype == cryptonote::TESTNET) {
|
||||||
{
|
} else {
|
||||||
full_addrs.insert("212.83.175.67:28080");
|
full_addrs.insert("66.70.218.230:34567");
|
||||||
full_addrs.insert("5.9.100.248:28080");
|
|
||||||
full_addrs.insert("163.172.182.165:28080");
|
|
||||||
full_addrs.insert("195.154.123.123:28080");
|
|
||||||
full_addrs.insert("212.83.172.165:28080");
|
|
||||||
}
|
|
||||||
else if (nettype == cryptonote::STAGENET)
|
|
||||||
{
|
|
||||||
full_addrs.insert("162.210.173.150:38080");
|
|
||||||
full_addrs.insert("162.210.173.151:38080");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
full_addrs.insert("107.152.130.98:18080");
|
|
||||||
full_addrs.insert("212.83.175.67:18080");
|
|
||||||
full_addrs.insert("5.9.100.248:18080");
|
|
||||||
full_addrs.insert("163.172.182.165:18080");
|
|
||||||
full_addrs.insert("161.67.132.39:18080");
|
|
||||||
full_addrs.insert("198.74.231.92:18080");
|
|
||||||
full_addrs.insert("195.154.123.123:18080");
|
|
||||||
full_addrs.insert("212.83.172.165:18080");
|
|
||||||
}
|
}
|
||||||
return full_addrs;
|
return full_addrs;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------------
|
||||||
|
@ -483,7 +465,7 @@ namespace nodetool
|
||||||
if (result.size())
|
if (result.size())
|
||||||
{
|
{
|
||||||
for (const auto& addr_string : result)
|
for (const auto& addr_string : result)
|
||||||
full_addrs.insert(addr_string + ":" + std::to_string(m_nettype == cryptonote::TESTNET ? ::config::testnet::P2P_DEFAULT_PORT : m_nettype == cryptonote::STAGENET ? ::config::stagenet::P2P_DEFAULT_PORT : ::config::P2P_DEFAULT_PORT));
|
full_addrs.insert(addr_string + ":34567");
|
||||||
}
|
}
|
||||||
++i;
|
++i;
|
||||||
}
|
}
|
||||||
|
@ -2060,3 +2042,4 @@ namespace nodetool
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
2
src/simplewallet/CMakeLists.txt
Normal file → Executable file
2
src/simplewallet/CMakeLists.txt
Normal file → Executable file
|
@ -61,5 +61,5 @@ target_link_libraries(simplewallet
|
||||||
${EXTRA_LIBRARIES})
|
${EXTRA_LIBRARIES})
|
||||||
set_property(TARGET simplewallet
|
set_property(TARGET simplewallet
|
||||||
PROPERTY
|
PROPERTY
|
||||||
OUTPUT_NAME "monero-wallet-cli")
|
OUTPUT_NAME "wownero-wallet-cli")
|
||||||
install(TARGETS simplewallet DESTINATION bin)
|
install(TARGETS simplewallet DESTINATION bin)
|
||||||
|
|
22
src/simplewallet/simplewallet.cpp
Normal file → Executable file
22
src/simplewallet/simplewallet.cpp
Normal file → Executable file
|
@ -134,7 +134,7 @@ namespace
|
||||||
const command_line::arg_descriptor<bool> arg_untrusted_daemon = {"untrusted-daemon", sw::tr("Disable commands which rely on a trusted daemon"), false};
|
const command_line::arg_descriptor<bool> arg_untrusted_daemon = {"untrusted-daemon", sw::tr("Disable commands which rely on a trusted daemon"), false};
|
||||||
const command_line::arg_descriptor<bool> arg_allow_mismatched_daemon_version = {"allow-mismatched-daemon-version", sw::tr("Allow communicating with a daemon that uses a different RPC version"), false};
|
const command_line::arg_descriptor<bool> arg_allow_mismatched_daemon_version = {"allow-mismatched-daemon-version", sw::tr("Allow communicating with a daemon that uses a different RPC version"), false};
|
||||||
const command_line::arg_descriptor<uint64_t> arg_restore_height = {"restore-height", sw::tr("Restore from specific blockchain height"), 0};
|
const command_line::arg_descriptor<uint64_t> arg_restore_height = {"restore-height", sw::tr("Restore from specific blockchain height"), 0};
|
||||||
const command_line::arg_descriptor<bool> arg_do_not_relay = {"do-not-relay", sw::tr("The newly created transaction will not be relayed to the monero network"), false};
|
const command_line::arg_descriptor<bool> arg_do_not_relay = {"do-not-relay", sw::tr("The newly created transaction will not be relayed to the wownero network"), false};
|
||||||
const command_line::arg_descriptor<bool> arg_create_address_file = {"create-address-file", sw::tr("Create an address file for new wallets"), false};
|
const command_line::arg_descriptor<bool> arg_create_address_file = {"create-address-file", sw::tr("Create an address file for new wallets"), false};
|
||||||
const command_line::arg_descriptor<std::string> arg_subaddress_lookahead = {"subaddress-lookahead", tools::wallet2::tr("Set subaddress lookahead sizes to <major>:<minor>"), ""};
|
const command_line::arg_descriptor<std::string> arg_subaddress_lookahead = {"subaddress-lookahead", tools::wallet2::tr("Set subaddress lookahead sizes to <major>:<minor>"), ""};
|
||||||
const command_line::arg_descriptor<bool> arg_use_english_language_names = {"use-english-language-names", sw::tr("Display English language names"), false};
|
const command_line::arg_descriptor<bool> arg_use_english_language_names = {"use-english-language-names", sw::tr("Display English language names"), false};
|
||||||
|
@ -337,7 +337,7 @@ namespace
|
||||||
std::stringstream prompt;
|
std::stringstream prompt;
|
||||||
prompt << tr("For URL: ") << url
|
prompt << tr("For URL: ") << url
|
||||||
<< ", " << dnssec_str << std::endl
|
<< ", " << dnssec_str << std::endl
|
||||||
<< tr(" Monero Address = ") << addresses[0]
|
<< tr(" Wownero Address = ") << addresses[0]
|
||||||
<< std::endl
|
<< std::endl
|
||||||
<< tr("Is this OK? (Y/n) ")
|
<< tr("Is this OK? (Y/n) ")
|
||||||
;
|
;
|
||||||
|
@ -749,7 +749,7 @@ bool simple_wallet::print_fee_info(const std::vector<std::string> &args/* = std:
|
||||||
}
|
}
|
||||||
const uint64_t per_kb_fee = m_wallet->get_per_kb_fee();
|
const uint64_t per_kb_fee = m_wallet->get_per_kb_fee();
|
||||||
const uint64_t typical_size_kb = 13;
|
const uint64_t typical_size_kb = 13;
|
||||||
message_writer() << (boost::format(tr("Current fee is %s %s per kB")) % print_money(per_kb_fee) % cryptonote::get_unit(cryptonote::get_default_decimal_point())).str();
|
message_writer() << (boost::format(tr("Current fee is %s wownero per kB")) % print_money(per_kb_fee)).str();
|
||||||
|
|
||||||
std::vector<uint64_t> fees;
|
std::vector<uint64_t> fees;
|
||||||
for (uint32_t priority = 1; priority <= 4; ++priority)
|
for (uint32_t priority = 1; priority <= 4; ++priority)
|
||||||
|
@ -1780,7 +1780,7 @@ bool simple_wallet::set_unit(const std::vector<std::string> &args/* = std::vecto
|
||||||
const std::string &unit = args[1];
|
const std::string &unit = args[1];
|
||||||
unsigned int decimal_point = CRYPTONOTE_DISPLAY_DECIMAL_POINT;
|
unsigned int decimal_point = CRYPTONOTE_DISPLAY_DECIMAL_POINT;
|
||||||
|
|
||||||
if (unit == "monero")
|
if (unit == "wownero")
|
||||||
decimal_point = CRYPTONOTE_DISPLAY_DECIMAL_POINT;
|
decimal_point = CRYPTONOTE_DISPLAY_DECIMAL_POINT;
|
||||||
else if (unit == "millinero")
|
else if (unit == "millinero")
|
||||||
decimal_point = CRYPTONOTE_DISPLAY_DECIMAL_POINT - 3;
|
decimal_point = CRYPTONOTE_DISPLAY_DECIMAL_POINT - 3;
|
||||||
|
@ -2145,8 +2145,8 @@ simple_wallet::simple_wallet()
|
||||||
" Set the fee too default/unimportant/normal/elevated/priority.\n "
|
" Set the fee too default/unimportant/normal/elevated/priority.\n "
|
||||||
"confirm-missing-payment-id <1|0>\n "
|
"confirm-missing-payment-id <1|0>\n "
|
||||||
"ask-password <1|0>\n "
|
"ask-password <1|0>\n "
|
||||||
"unit <monero|millinero|micronero|nanonero|piconero>\n "
|
"unit <wownero|millinero|micronero|nanonero|piconero>\n "
|
||||||
" Set the default monero (sub-)unit.\n "
|
" Set the default wownero (sub-)unit.\n "
|
||||||
"min-outputs-count [n]\n "
|
"min-outputs-count [n]\n "
|
||||||
" Try to keep at least that many outputs of value at least min-outputs-value.\n "
|
" Try to keep at least that many outputs of value at least min-outputs-value.\n "
|
||||||
"min-outputs-value [n]\n "
|
"min-outputs-value [n]\n "
|
||||||
|
@ -2414,7 +2414,7 @@ bool simple_wallet::set_variable(const std::vector<std::string> &args)
|
||||||
CHECK_SIMPLE_VARIABLE("priority", set_default_priority, tr("0, 1, 2, 3, or 4"));
|
CHECK_SIMPLE_VARIABLE("priority", set_default_priority, tr("0, 1, 2, 3, or 4"));
|
||||||
CHECK_SIMPLE_VARIABLE("confirm-missing-payment-id", set_confirm_missing_payment_id, tr("0 or 1"));
|
CHECK_SIMPLE_VARIABLE("confirm-missing-payment-id", set_confirm_missing_payment_id, tr("0 or 1"));
|
||||||
CHECK_SIMPLE_VARIABLE("ask-password", set_ask_password, tr("0 or 1"));
|
CHECK_SIMPLE_VARIABLE("ask-password", set_ask_password, tr("0 or 1"));
|
||||||
CHECK_SIMPLE_VARIABLE("unit", set_unit, tr("monero, millinero, micronero, nanonero, piconero"));
|
CHECK_SIMPLE_VARIABLE("unit", set_unit, tr("wownero, millinero, micronero, nanonero, piconero"));
|
||||||
CHECK_SIMPLE_VARIABLE("min-outputs-count", set_min_output_count, tr("unsigned integer"));
|
CHECK_SIMPLE_VARIABLE("min-outputs-count", set_min_output_count, tr("unsigned integer"));
|
||||||
CHECK_SIMPLE_VARIABLE("min-outputs-value", set_min_output_value, tr("amount"));
|
CHECK_SIMPLE_VARIABLE("min-outputs-value", set_min_output_value, tr("amount"));
|
||||||
CHECK_SIMPLE_VARIABLE("merge-destinations", set_merge_destinations, tr("0 or 1"));
|
CHECK_SIMPLE_VARIABLE("merge-destinations", set_merge_destinations, tr("0 or 1"));
|
||||||
|
@ -3332,7 +3332,7 @@ bool simple_wallet::new_wallet(const boost::program_options::variables_map& vm,
|
||||||
"To start synchronizing with the daemon, use the \"refresh\" command.\n"
|
"To start synchronizing with the daemon, use the \"refresh\" command.\n"
|
||||||
"Use the \"help\" command to see the list of available commands.\n"
|
"Use the \"help\" command to see the list of available commands.\n"
|
||||||
"Use \"help <command>\" to see a command's documentation.\n"
|
"Use \"help <command>\" to see a command's documentation.\n"
|
||||||
"Always use the \"exit\" command when closing monero-wallet-cli to save \n"
|
"Always use the \"exit\" command when closing wownero-wallet-cli to save \n"
|
||||||
"your current session's state. Otherwise, you might need to synchronize \n"
|
"your current session's state. Otherwise, you might need to synchronize \n"
|
||||||
"your wallet again (your wallet keys are NOT at risk in any case).\n")
|
"your wallet again (your wallet keys are NOT at risk in any case).\n")
|
||||||
;
|
;
|
||||||
|
@ -7548,12 +7548,12 @@ int main(int argc, char* argv[])
|
||||||
|
|
||||||
const auto vm = wallet_args::main(
|
const auto vm = wallet_args::main(
|
||||||
argc, argv,
|
argc, argv,
|
||||||
"monero-wallet-cli [--wallet-file=<file>|--generate-new-wallet=<file>] [<COMMAND>]",
|
"wownero-wallet-cli [--wallet-file=<file>|--generate-new-wallet=<file>] [<COMMAND>]",
|
||||||
sw::tr("This is the command line monero wallet. It needs to connect to a monero\ndaemon to work correctly.\nWARNING: Do not reuse your Monero keys on an another fork, UNLESS this fork has key reuse mitigations built in. Doing so will harm your privacy."),
|
sw::tr("This is the command line wownero wallet. It needs to connect to a wownero\ndaemon to work correctly."),
|
||||||
desc_params,
|
desc_params,
|
||||||
positional_options,
|
positional_options,
|
||||||
[](const std::string &s, bool emphasis){ tools::scoped_message_writer(emphasis ? epee::console_color_white : epee::console_color_default, true) << s; },
|
[](const std::string &s, bool emphasis){ tools::scoped_message_writer(emphasis ? epee::console_color_white : epee::console_color_default, true) << s; },
|
||||||
"monero-wallet-cli.log"
|
"wownero-wallet-cli.log"
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!vm)
|
if (!vm)
|
||||||
|
|
4
src/version.cpp.in
Normal file → Executable file
4
src/version.cpp.in
Normal file → Executable file
|
@ -1,6 +1,6 @@
|
||||||
#define DEF_MONERO_VERSION_TAG "@VERSIONTAG@"
|
#define DEF_MONERO_VERSION_TAG "@VERSIONTAG@"
|
||||||
#define DEF_MONERO_VERSION "0.12.3.0"
|
#define DEF_MONERO_VERSION "0.1.0.0-master"
|
||||||
#define DEF_MONERO_RELEASE_NAME "Lithium Luna"
|
#define DEF_MONERO_RELEASE_NAME "Awesome Akita"
|
||||||
#define DEF_MONERO_VERSION_FULL DEF_MONERO_VERSION "-" DEF_MONERO_VERSION_TAG
|
#define DEF_MONERO_VERSION_FULL DEF_MONERO_VERSION "-" DEF_MONERO_VERSION_TAG
|
||||||
|
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
|
@ -99,7 +99,7 @@ target_link_libraries(wallet_rpc_server
|
||||||
${EXTRA_LIBRARIES})
|
${EXTRA_LIBRARIES})
|
||||||
set_property(TARGET wallet_rpc_server
|
set_property(TARGET wallet_rpc_server
|
||||||
PROPERTY
|
PROPERTY
|
||||||
OUTPUT_NAME "monero-wallet-rpc")
|
OUTPUT_NAME "wownero-wallet-rpc")
|
||||||
install(TARGETS wallet_rpc_server DESTINATION bin)
|
install(TARGETS wallet_rpc_server DESTINATION bin)
|
||||||
|
|
||||||
|
|
||||||
|
|
13
src/wallet/wallet2.cpp
Normal file → Executable file
13
src/wallet/wallet2.cpp
Normal file → Executable file
|
@ -662,8 +662,8 @@ wallet2::wallet2(network_type nettype, bool restricted):
|
||||||
m_confirm_backlog_threshold(0),
|
m_confirm_backlog_threshold(0),
|
||||||
m_confirm_export_overwrite(true),
|
m_confirm_export_overwrite(true),
|
||||||
m_auto_low_priority(true),
|
m_auto_low_priority(true),
|
||||||
m_segregate_pre_fork_outputs(true),
|
m_segregate_pre_fork_outputs(false),
|
||||||
m_key_reuse_mitigation2(true),
|
m_key_reuse_mitigation2(false),
|
||||||
m_segregation_height(0),
|
m_segregation_height(0),
|
||||||
m_is_initialized(false),
|
m_is_initialized(false),
|
||||||
m_restricted(restricted),
|
m_restricted(restricted),
|
||||||
|
@ -5344,9 +5344,9 @@ int wallet2::get_fee_algorithm() const
|
||||||
//------------------------------------------------------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------------------------------------------------------
|
||||||
uint64_t wallet2::adjust_mixin(uint64_t mixin) const
|
uint64_t wallet2::adjust_mixin(uint64_t mixin) const
|
||||||
{
|
{
|
||||||
if (mixin < 6 && use_fork_rules(7, 10)) {
|
if (mixin < 7 && use_fork_rules(7, 10)) {
|
||||||
MWARNING("Requested ring size " << (mixin + 1) << " too low for hard fork 7, using 7");
|
MWARNING("Requested ring size " << (mixin + 1) << " too low for hard fork 7, using 7");
|
||||||
mixin = 6;
|
mixin = 7;
|
||||||
}
|
}
|
||||||
else if (mixin < 4 && use_fork_rules(6, 10)) {
|
else if (mixin < 4 && use_fork_rules(6, 10)) {
|
||||||
MWARNING("Requested ring size " << (mixin + 1) << " too low for hard fork 6, using 5");
|
MWARNING("Requested ring size " << (mixin + 1) << " too low for hard fork 6, using 5");
|
||||||
|
@ -10497,10 +10497,7 @@ uint64_t wallet2::get_segregation_fork_height() const
|
||||||
{
|
{
|
||||||
// All four MoneroPulse domains have DNSSEC on and valid
|
// All four MoneroPulse domains have DNSSEC on and valid
|
||||||
static const std::vector<std::string> dns_urls = {
|
static const std::vector<std::string> dns_urls = {
|
||||||
"segheights.moneropulse.org",
|
|
||||||
"segheights.moneropulse.net",
|
|
||||||
"segheights.moneropulse.co",
|
|
||||||
"segheights.moneropulse.se"
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const uint64_t current_height = get_blockchain_current_height();
|
const uint64_t current_height = get_blockchain_current_height();
|
||||||
|
|
Loading…
Reference in a new issue