mirror of
https://git.wownero.com/wownero/onion-wownero-blockchain-explorer.git
synced 2024-08-15 00:33:12 +00:00
searching by amount idx and amount added
This commit is contained in:
parent
33bc9f2f4c
commit
78e7c4d064
3 changed files with 99 additions and 7 deletions
|
@ -31,6 +31,7 @@ The key features of the Onion Monero Blockchain Explorer are
|
|||
- the only explorer showing encrypted payments ID,
|
||||
- the only explorer with the ability to search by encrypted payments ID, tx public
|
||||
keys, outputs public keys, input key images, output global indices,
|
||||
output amount index and its amount,
|
||||
- the only explorer showing ring signatures,
|
||||
- the only explorer that can show which outputs belong to the given Monero address and viewkey,
|
||||
- the only explorer showing detailed information about mixins, such as, mixins'
|
||||
|
|
87
src/page.h
87
src/page.h
|
@ -1387,8 +1387,14 @@ namespace xmreg {
|
|||
// such search start with "goi_", e.g., "goi_543"
|
||||
bool search_for_global_output_idx = (search_text.substr(0, 4) == "goi_");
|
||||
|
||||
// check if we look for output with amout index and amount
|
||||
// such search start with "aoi_", e.g., "aoi_444-23.00"
|
||||
bool search_for_amount_output_idx = (search_text.substr(0, 4) == "aoi_");
|
||||
|
||||
// first check if searching for block of given height
|
||||
if (search_text.size() < 12 && search_for_global_output_idx == false)
|
||||
if (search_text.size() < 12 &&
|
||||
(search_for_global_output_idx == false
|
||||
||search_for_amount_output_idx == false))
|
||||
{
|
||||
uint64_t blk_height;
|
||||
|
||||
|
@ -1510,9 +1516,8 @@ namespace xmreg {
|
|||
make_pair("output_public_keys",
|
||||
tx_search_results["output_public_keys"]));
|
||||
|
||||
// seach for output using output global index
|
||||
|
||||
cout << "search_text.substr(4): " << search_text.substr(4) << endl;
|
||||
// seach for output using output global index
|
||||
|
||||
if (search_for_global_output_idx)
|
||||
{
|
||||
|
@ -1522,7 +1527,7 @@ namespace xmreg {
|
|||
search_text.substr(4));
|
||||
|
||||
|
||||
cout << "global_idx: " << global_idx << endl;
|
||||
//cout << "global_idx: " << global_idx << endl;
|
||||
|
||||
// get info about output of a given global index
|
||||
output_data_t output_data = core_storage->get_db()
|
||||
|
@ -1536,7 +1541,7 @@ namespace xmreg {
|
|||
|
||||
string output_pub_key = pod_to_hex(output_data.pubkey);
|
||||
|
||||
cout << "output_pub_key: " << output_pub_key << endl;
|
||||
//cout << "output_pub_key: " << output_pub_key << endl;
|
||||
|
||||
vector<string> found_outputs;
|
||||
|
||||
|
@ -1544,7 +1549,7 @@ namespace xmreg {
|
|||
found_outputs,
|
||||
"output_public_keys");
|
||||
|
||||
cout << "found_outputs.size(): " << found_outputs.size() << endl;
|
||||
//cout << "found_outputs.size(): " << found_outputs.size() << endl;
|
||||
|
||||
all_possible_tx_hashes.push_back(
|
||||
make_pair("output_public_keys_based_on_global_idx",
|
||||
|
@ -1553,7 +1558,75 @@ namespace xmreg {
|
|||
}
|
||||
catch(boost::bad_lexical_cast &e)
|
||||
{
|
||||
cerr << "Cant cast global_idx string: " << search_text.substr(3) << endl;
|
||||
cerr << "Cant cast global_idx string: "
|
||||
<< search_text.substr(4) << endl;
|
||||
}
|
||||
}
|
||||
|
||||
// seach for output using output amount index and amount
|
||||
|
||||
if (search_for_amount_output_idx)
|
||||
{
|
||||
try
|
||||
{
|
||||
|
||||
string str_to_split = search_text.substr(4);
|
||||
|
||||
vector<string> string_parts;
|
||||
|
||||
boost::split(string_parts, str_to_split,
|
||||
boost::is_any_of("-"));
|
||||
|
||||
if (string_parts.size() != 2)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
|
||||
uint64_t amount_idx = boost::lexical_cast<uint64_t>(
|
||||
string_parts[0]);
|
||||
|
||||
uint64_t amount = static_cast<uint64_t>
|
||||
(boost::lexical_cast<double>(
|
||||
string_parts[1]) * 1e12);
|
||||
|
||||
|
||||
//cout << "amount_idx: " << amount_idx << endl;
|
||||
//cout << "amount: " << amount << endl;
|
||||
|
||||
// get info about output of a given global index
|
||||
output_data_t output_data = core_storage->get_db()
|
||||
.get_output_key(
|
||||
amount, amount_idx);
|
||||
|
||||
string output_pub_key = pod_to_hex(output_data.pubkey);
|
||||
|
||||
//cout << "output_pub_key: " << output_pub_key << endl;
|
||||
|
||||
vector<string> found_outputs;
|
||||
|
||||
mylmdb.search(output_pub_key,
|
||||
found_outputs,
|
||||
"output_public_keys");
|
||||
|
||||
//cout << "found_outputs.size(): " << found_outputs.size() << endl;
|
||||
|
||||
all_possible_tx_hashes.push_back(
|
||||
make_pair("output_public_keys_based_on_amount_idx",
|
||||
found_outputs));
|
||||
|
||||
}
|
||||
catch(boost::bad_lexical_cast& e)
|
||||
{
|
||||
cerr << "Cant parse amout index and amout string: "
|
||||
<< search_text.substr(4) << endl;
|
||||
}
|
||||
catch(OUTPUT_DNE& e)
|
||||
{
|
||||
cerr << "Output not found in the blockchain: "
|
||||
<< search_text.substr(4) << endl;
|
||||
|
||||
return(string("Output not found in the blockchain: ")
|
||||
+ search_text.substr(4));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -110,3 +110,21 @@
|
|||
{{/has_output_public_keys_based_on_global_idx}}
|
||||
|
||||
</div>
|
||||
|
||||
<div>
|
||||
|
||||
{{#has_output_public_keys_based_on_amount_idx}}
|
||||
|
||||
<h3>The search term matches amount index and an amount of an output
|
||||
in the following transaction(s)</h3>
|
||||
|
||||
<table class="center" style="width:90%">
|
||||
{{>tx_table_head}}
|
||||
{{#output_public_keys_based_on_amount_idx}}
|
||||
{{>tx_table_row}}
|
||||
{{/output_public_keys_based_on_amount_idx}}
|
||||
</table>
|
||||
|
||||
{{/has_output_public_keys_based_on_amount_idx}}
|
||||
|
||||
</div>
|
||||
|
|
Loading…
Reference in a new issue