basic index page
This commit is contained in:
parent
28a7df74e0
commit
9ea9dfdf7b
35
main.cpp
35
main.cpp
|
@ -37,45 +37,14 @@ int main() {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
xmreg::page xmrblocks(&mcore, core_storage);
|
||||||
// get the current blockchain height. Just to check if it reads ok.
|
|
||||||
uint64_t height = core_storage->get_current_blockchain_height() - 1;
|
|
||||||
|
|
||||||
fmt::print("\n\n"
|
|
||||||
"Top block height : {:d}\n", height);
|
|
||||||
|
|
||||||
|
|
||||||
xmreg::page xmrblocks;
|
|
||||||
|
|
||||||
std::string view = xmrblocks.index();
|
|
||||||
|
|
||||||
mstch::map context {
|
|
||||||
{"height", fmt::format("{:d}", height)},
|
|
||||||
{"blocks", mstch::array()}
|
|
||||||
};
|
|
||||||
|
|
||||||
size_t no_of_last_blocks {50};
|
|
||||||
|
|
||||||
mstch::array& blocks = boost::get<mstch::array>(context["blocks"]);
|
|
||||||
|
|
||||||
for (size_t i = height; i > height - no_of_last_blocks; --i)
|
|
||||||
{
|
|
||||||
//cryptonote::block blk;
|
|
||||||
//core_storage.get_block_by_hash(block_id, blk);
|
|
||||||
|
|
||||||
crypto::hash blk_hash = core_storage->get_block_id_by_height(i);
|
|
||||||
blocks.push_back(mstch::map {
|
|
||||||
{"height", to_string(i)},
|
|
||||||
{"hash" , fmt::format("{:s}", blk_hash)}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
crow::SimpleApp app;
|
crow::SimpleApp app;
|
||||||
|
|
||||||
CROW_ROUTE(app, "/")
|
CROW_ROUTE(app, "/")
|
||||||
([&]() {
|
([&]() {
|
||||||
return mstch::render(view, context);
|
return xmrblocks.index();
|
||||||
});
|
});
|
||||||
|
|
||||||
app.port(8080).multithreaded().run();
|
app.port(8080).multithreaded().run();
|
||||||
|
|
67
src/page.h
67
src/page.h
|
@ -7,34 +7,93 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include "../ext/minicsv.h"
|
#include "mstch/mstch.hpp"
|
||||||
|
#include "../ext/format.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include "monero_headers.h"
|
#include "monero_headers.h"
|
||||||
|
|
||||||
|
#include "MicroCore.h"
|
||||||
#include "tools.h"
|
#include "tools.h"
|
||||||
|
|
||||||
|
|
||||||
#define TMPL_DIR "./templates"
|
#define TMPL_DIR "./templates"
|
||||||
#define TMPL_INDEX TMPL_DIR "/index.html"
|
#define TMPL_INDEX TMPL_DIR "/index.html"
|
||||||
|
#define TMPL_HEADER TMPL_DIR "/header.html"
|
||||||
|
#define TMPL_FOOTER TMPL_DIR "/footer.html"
|
||||||
|
|
||||||
#define READ_TMPL(tmpl_path) xmreg::read(tmpl_path)
|
#define READ_TMPL(tmpl_path) xmreg::read(tmpl_path)
|
||||||
|
|
||||||
namespace xmreg {
|
namespace xmreg {
|
||||||
|
|
||||||
|
using namespace cryptonote;
|
||||||
|
using namespace crypto;
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
class page {
|
class page {
|
||||||
|
|
||||||
|
|
||||||
|
MicroCore* mcore;
|
||||||
|
Blockchain* core_storage;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
page(MicroCore* _mcore, Blockchain* _core_storage)
|
||||||
|
: mcore {_mcore}, core_storage {_core_storage}
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
string
|
string
|
||||||
index()
|
index()
|
||||||
{
|
{
|
||||||
|
// get the current blockchain height. Just to check if it reads ok.
|
||||||
|
uint64_t height = core_storage->get_current_blockchain_height() - 1;
|
||||||
|
|
||||||
|
mstch::map context {
|
||||||
|
{"height", fmt::format("{:d}", height)},
|
||||||
|
{"blocks", mstch::array()}
|
||||||
|
};
|
||||||
|
|
||||||
|
size_t no_of_last_blocks {50};
|
||||||
|
|
||||||
|
mstch::array& blocks = boost::get<mstch::array>(context["blocks"]);
|
||||||
|
|
||||||
|
for (size_t i = height; i > height - no_of_last_blocks; --i)
|
||||||
|
{
|
||||||
|
block blk;
|
||||||
|
|
||||||
|
mcore->get_block_by_height(i, blk);
|
||||||
|
|
||||||
|
crypto::hash blk_hash = core_storage->get_block_id_by_height(i);
|
||||||
|
|
||||||
|
blocks.push_back(mstch::map {
|
||||||
|
{"height" , to_string(i)},
|
||||||
|
{"timestamp" , xmreg::timestamp_to_str(blk.timestamp)},
|
||||||
|
{"hash" , fmt::format("{:s}", blk_hash)},
|
||||||
|
{"notx" , fmt::format("{:d}", blk.tx_hashes.size())}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
std::string view = READ_TMPL(TMPL_INDEX);
|
std::string view = READ_TMPL(TMPL_INDEX);
|
||||||
|
|
||||||
return view;
|
string full_page = get_full_page(view);
|
||||||
|
|
||||||
|
return mstch::render(view, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
string
|
||||||
|
get_full_page(string& middle)
|
||||||
|
{
|
||||||
|
return READ_TMPL(TMPL_HEADER)
|
||||||
|
+ middle
|
||||||
|
+ READ_TMPL(TMPL_FOOTER);
|
||||||
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,8 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>Monero blocks</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div>
|
|
@ -1,21 +1,19 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
<h1>Hidden Monero blockchain explorer</h1>
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<title>Monero blocks</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div>
|
|
||||||
<h1>Detailed Monero blockchain explorer</h1>
|
|
||||||
<h2>Current height: {{height}}</h2>
|
<h2>Current height: {{height}}</h2>
|
||||||
<div>
|
<div>
|
||||||
<ul>
|
<ul>
|
||||||
{{#blocks}}
|
<table>
|
||||||
<li> {{height}}: {{hash}} </li>
|
{{#blocks}}
|
||||||
{{/blocks}}
|
<tr>
|
||||||
|
<td>{{height}}</td>
|
||||||
|
<td>{{timestamp}}</td>
|
||||||
|
<td>{{hash}}</td>
|
||||||
|
<td>{{notx}}</td>
|
||||||
|
</tr>
|
||||||
|
{{/blocks}}
|
||||||
|
</table>
|
||||||
|
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
Loading…
Reference in New Issue