mirror of
https://github.com/creating2morrow/neveko.git
synced 2025-01-18 16:54:38 +00:00
add some more daemon methods
This commit is contained in:
parent
e9ef5778d1
commit
dea7a3a52a
5 changed files with 272 additions and 22 deletions
5
nevmes-core/.rustfmt.toml
Normal file
5
nevmes-core/.rustfmt.toml
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
# cargo +nightly fmt
|
||||||
|
format_code_in_doc_comments = true
|
||||||
|
imports_granularity = "Crate"
|
||||||
|
imports_layout = "Vertical"
|
||||||
|
wrap_comments = true
|
|
@ -9,8 +9,8 @@ pub mod models; // db structs
|
||||||
pub mod monero; // monero-wallet-rpc interface
|
pub mod monero; // monero-wallet-rpc interface
|
||||||
pub mod proof; // external auth/payment proof module
|
pub mod proof; // external auth/payment proof module
|
||||||
pub mod reqres; // http request/responses
|
pub mod reqres; // http request/responses
|
||||||
pub mod user;
|
pub mod user; // misc.
|
||||||
pub mod utils; // misc. // user rep/service layer
|
pub mod utils; // user rep/service layer
|
||||||
|
|
||||||
pub const NEVMES_JWP_SECRET_KEY: &str = "NEVMES_JWP_SECRET_KEY";
|
pub const NEVMES_JWP_SECRET_KEY: &str = "NEVMES_JWP_SECRET_KEY";
|
||||||
pub const NEVMES_JWT_SECRET_KEY: &str = "NEVMES_JWT_SECRET_KEY";
|
pub const NEVMES_JWT_SECRET_KEY: &str = "NEVMES_JWT_SECRET_KEY";
|
||||||
|
|
|
@ -2,11 +2,7 @@ use crate::{
|
||||||
args,
|
args,
|
||||||
proof,
|
proof,
|
||||||
reqres,
|
reqres,
|
||||||
utils::{
|
utils,
|
||||||
self,
|
|
||||||
get_release_env,
|
|
||||||
ReleaseEnvironment,
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
use clap::Parser;
|
use clap::Parser;
|
||||||
use diqwest::WithDigestAuth;
|
use diqwest::WithDigestAuth;
|
||||||
|
@ -80,7 +76,10 @@ impl RpcFields {
|
||||||
}
|
}
|
||||||
|
|
||||||
enum DaemonFields {
|
enum DaemonFields {
|
||||||
|
GetBlock,
|
||||||
|
GetHeight,
|
||||||
GetInfo,
|
GetInfo,
|
||||||
|
GetTransactions,
|
||||||
Id,
|
Id,
|
||||||
Version,
|
Version,
|
||||||
}
|
}
|
||||||
|
@ -88,7 +87,10 @@ enum DaemonFields {
|
||||||
impl DaemonFields {
|
impl DaemonFields {
|
||||||
pub fn value(&self) -> String {
|
pub fn value(&self) -> String {
|
||||||
match *self {
|
match *self {
|
||||||
|
DaemonFields::GetBlock => String::from("get_block"),
|
||||||
|
DaemonFields::GetHeight => String::from("get_height"),
|
||||||
DaemonFields::GetInfo => String::from("get_info"),
|
DaemonFields::GetInfo => String::from("get_info"),
|
||||||
|
DaemonFields::GetTransactions => String::from("get_transactions"),
|
||||||
DaemonFields::Id => String::from("0"),
|
DaemonFields::Id => String::from("0"),
|
||||||
DaemonFields::Version => String::from("2.0"),
|
DaemonFields::Version => String::from("2.0"),
|
||||||
}
|
}
|
||||||
|
@ -114,8 +116,8 @@ pub fn start_daemon() {
|
||||||
info!("starting monerod");
|
info!("starting monerod");
|
||||||
let blockchain_dir = get_blockchain_dir();
|
let blockchain_dir = get_blockchain_dir();
|
||||||
let bin_dir = get_monero_location();
|
let bin_dir = get_monero_location();
|
||||||
let release_env = get_release_env();
|
let release_env = utils::get_release_env();
|
||||||
if release_env == ReleaseEnvironment::Development {
|
if release_env == utils::ReleaseEnvironment::Development {
|
||||||
let args = ["--data-dir", &blockchain_dir, "--stagenet", "--detach"];
|
let args = ["--data-dir", &blockchain_dir, "--stagenet", "--detach"];
|
||||||
let output = Command::new(format!("{}/monerod", bin_dir))
|
let output = Command::new(format!("{}/monerod", bin_dir))
|
||||||
.args(args)
|
.args(args)
|
||||||
|
@ -144,8 +146,8 @@ pub fn start_rpc() {
|
||||||
"/home/{}/.nevmes/stagenet/wallet/",
|
"/home/{}/.nevmes/stagenet/wallet/",
|
||||||
std::env::var("USER").unwrap_or(String::from("user")),
|
std::env::var("USER").unwrap_or(String::from("user")),
|
||||||
);
|
);
|
||||||
let release_env = get_release_env();
|
let release_env = utils::get_release_env();
|
||||||
if release_env == ReleaseEnvironment::Development {
|
if release_env == utils::ReleaseEnvironment::Development {
|
||||||
let args = [
|
let args = [
|
||||||
"--rpc-bind-port",
|
"--rpc-bind-port",
|
||||||
&port,
|
&port,
|
||||||
|
@ -942,3 +944,73 @@ pub async fn get_info() -> reqres::XmrDaemonGetInfoResponse {
|
||||||
Err(_) => Default::default(),
|
Err(_) => Default::default(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Performs the xmr daemon 'get_height' method
|
||||||
|
pub async fn get_height() -> reqres::XmrDaemonGetHeightResponse {
|
||||||
|
info!("fetching daemon height");
|
||||||
|
let client = reqwest::Client::new();
|
||||||
|
let host = get_rpc_daemon();
|
||||||
|
let req = reqres::XmrRpcRequest {
|
||||||
|
jsonrpc: DaemonFields::Version.value(),
|
||||||
|
id: DaemonFields::Id.value(),
|
||||||
|
method: DaemonFields::GetHeight.value(),
|
||||||
|
};
|
||||||
|
match client.post(host).json(&req).send().await {
|
||||||
|
Ok(response) => {
|
||||||
|
let res = response.json::<reqres::XmrDaemonGetHeightResponse>().await;
|
||||||
|
debug!("{} response: {:?}", DaemonFields::GetHeight.value(), res);
|
||||||
|
match res {
|
||||||
|
Ok(res) => res,
|
||||||
|
_ => Default::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(_) => Default::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Performs the xmr daemon 'get_block' method
|
||||||
|
pub async fn get_block(height: u64) -> reqres::XmrDaemonGetBlockResponse {
|
||||||
|
info!("fetching block at height: {}", height);
|
||||||
|
let client = reqwest::Client::new();
|
||||||
|
let host = get_rpc_daemon();
|
||||||
|
let params: reqres::XmrDaemonGetBlockParams = reqres::XmrDaemonGetBlockParams { height };
|
||||||
|
let req = reqres::XmrDaemonGetBlockRequest {
|
||||||
|
jsonrpc: DaemonFields::Version.value(),
|
||||||
|
id: DaemonFields::Id.value(),
|
||||||
|
method: DaemonFields::GetBlock.value(),
|
||||||
|
params,
|
||||||
|
};
|
||||||
|
match client.post(host).json(&req).send().await {
|
||||||
|
Ok(response) => {
|
||||||
|
let res = response.json::<reqres::XmrDaemonGetBlockResponse>().await;
|
||||||
|
debug!("{} response: {:?}", DaemonFields::GetBlock.value(), res);
|
||||||
|
match res {
|
||||||
|
Ok(res) => res,
|
||||||
|
_ => Default::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(_) => Default::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Performs the xmr daemon 'get_transactions' method
|
||||||
|
pub async fn get_transactions(txs_hashes: Vec<String>) -> reqres::XmrDaemonGetTransactionsResponse {
|
||||||
|
info!("fetching {} transactions", txs_hashes.len());
|
||||||
|
let client = reqwest::Client::new();
|
||||||
|
let host = get_rpc_daemon();
|
||||||
|
let req = reqres::XmrDaemonGetTransactionsRequest {
|
||||||
|
txs_hashes,
|
||||||
|
decode_as_json: true,
|
||||||
|
};
|
||||||
|
match client.post(host).json(&req).send().await {
|
||||||
|
Ok(response) => {
|
||||||
|
let res = response.json::<reqres::XmrDaemonGetTransactionsResponse>().await;
|
||||||
|
debug!("{} response: {:?}", DaemonFields::GetTransactions.value(), res);
|
||||||
|
match res {
|
||||||
|
Ok(res) => res,
|
||||||
|
_ => Default::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(_) => Default::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -7,6 +7,8 @@ use serde::{
|
||||||
// All http requests and responses are here
|
// All http requests and responses are here
|
||||||
|
|
||||||
// START XMR Structs
|
// START XMR Structs
|
||||||
|
// Reference: https://www.getmonero.org/resources/developer-guides/wallet-rpc.html
|
||||||
|
// https://www.getmonero.org/resources/developer-guides/daemon-rpc.html
|
||||||
|
|
||||||
// params
|
// params
|
||||||
#[derive(Deserialize, Serialize, Debug)]
|
#[derive(Deserialize, Serialize, Debug)]
|
||||||
|
@ -121,6 +123,11 @@ pub struct XmrRpcCreateAddressParams {
|
||||||
pub account_index: u8,
|
pub account_index: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Deserialize, Serialize, Debug)]
|
||||||
|
pub struct XmrDaemonGetBlockParams {
|
||||||
|
pub height: u64,
|
||||||
|
}
|
||||||
|
|
||||||
// requests
|
// requests
|
||||||
#[derive(Deserialize, Serialize, Debug)]
|
#[derive(Deserialize, Serialize, Debug)]
|
||||||
pub struct XmrRpcValidateAddressRequest {
|
pub struct XmrRpcValidateAddressRequest {
|
||||||
|
@ -153,6 +160,20 @@ pub struct XmrRpcRequest {
|
||||||
pub method: String,
|
pub method: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Deserialize, Serialize, Debug)]
|
||||||
|
pub struct XmrDaemonGetBlockRequest {
|
||||||
|
pub jsonrpc: String,
|
||||||
|
pub id: String,
|
||||||
|
pub method: String,
|
||||||
|
pub params: XmrDaemonGetBlockParams,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Deserialize, Serialize, Debug)]
|
||||||
|
pub struct XmrDaemonGetTransactionsRequest {
|
||||||
|
pub txs_hashes: Vec<String>,
|
||||||
|
pub decode_as_json: bool,
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Deserialize, Serialize, Debug)]
|
#[derive(Deserialize, Serialize, Debug)]
|
||||||
pub struct XmrRpcAddressRequest {
|
pub struct XmrRpcAddressRequest {
|
||||||
pub jsonrpc: String,
|
pub jsonrpc: String,
|
||||||
|
@ -478,7 +499,94 @@ pub struct XmrDaemonGetInfoResult {
|
||||||
pub wide_difficulty: String,
|
pub wide_difficulty: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Serialize, Deserialize, Debug)]
|
||||||
|
pub struct BlockHeader {
|
||||||
|
pub block_size: u32,
|
||||||
|
pub block_weight: u32,
|
||||||
|
pub cumulative_difficulty: u128,
|
||||||
|
pub cumulative_difficulty_top64: u128,
|
||||||
|
pub depth: u32,
|
||||||
|
pub difficulty: u128,
|
||||||
|
pub difficulty_top64: u128,
|
||||||
|
pub hash: String,
|
||||||
|
pub height: u64,
|
||||||
|
pub long_term_weight: u64,
|
||||||
|
pub major_version: u32,
|
||||||
|
pub miner_tx_hash: String,
|
||||||
|
pub minor_version: u32,
|
||||||
|
pub nonce: u32,
|
||||||
|
pub num_txes: u64,
|
||||||
|
pub orphan_status: bool,
|
||||||
|
pub pow_hash: String,
|
||||||
|
pub prev_hash: String,
|
||||||
|
pub reward: u64,
|
||||||
|
pub timestamp: u64,
|
||||||
|
pub wide_cumulative_difficulty: String,
|
||||||
|
pub wide_difficulty: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for BlockHeader {
|
||||||
|
fn default() -> Self {
|
||||||
|
BlockHeader {
|
||||||
|
block_size: 0,
|
||||||
|
block_weight: 0,
|
||||||
|
cumulative_difficulty: 0,
|
||||||
|
cumulative_difficulty_top64: 0,
|
||||||
|
depth: 0,
|
||||||
|
difficulty: 0,
|
||||||
|
difficulty_top64: 0,
|
||||||
|
hash: utils::empty_string(),
|
||||||
|
height: 0,
|
||||||
|
long_term_weight: 0,
|
||||||
|
major_version: 0,
|
||||||
|
miner_tx_hash: utils::empty_string(),
|
||||||
|
minor_version: 0,
|
||||||
|
nonce: 0,
|
||||||
|
num_txes: 0,
|
||||||
|
orphan_status: false,
|
||||||
|
pow_hash: utils::empty_string(),
|
||||||
|
prev_hash: utils::empty_string(),
|
||||||
|
reward: 0,
|
||||||
|
timestamp: 0,
|
||||||
|
wide_cumulative_difficulty: utils::empty_string(),
|
||||||
|
wide_difficulty: utils::empty_string(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Deserialize, Debug)]
|
||||||
|
pub struct XmrDaemonGetBlockResult {
|
||||||
|
pub blob: String,
|
||||||
|
pub block_header: BlockHeader,
|
||||||
|
pub credits: u64,
|
||||||
|
pub json: String,
|
||||||
|
pub miner_tx_hash: String,
|
||||||
|
pub status: String,
|
||||||
|
pub top_hash: String,
|
||||||
|
pub tx_hashes: Vec<String>,
|
||||||
|
pub untrusted: bool,
|
||||||
|
}
|
||||||
// responses
|
// responses
|
||||||
|
|
||||||
|
#[derive(Deserialize, Debug)]
|
||||||
|
pub struct XmrDaemonGetHeightResponse {
|
||||||
|
pub hash: String,
|
||||||
|
pub height: u64,
|
||||||
|
pub status: String,
|
||||||
|
pub untrusted: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for XmrDaemonGetHeightResponse {
|
||||||
|
fn default() -> Self {
|
||||||
|
XmrDaemonGetHeightResponse {
|
||||||
|
hash: utils::empty_string(),
|
||||||
|
height: 0,
|
||||||
|
status: utils::empty_string(),
|
||||||
|
untrusted: false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize, Debug)]
|
#[derive(Serialize, Deserialize, Debug)]
|
||||||
pub struct XmrDaemonGetInfoResponse {
|
pub struct XmrDaemonGetInfoResponse {
|
||||||
pub result: XmrDaemonGetInfoResult,
|
pub result: XmrDaemonGetInfoResult,
|
||||||
|
@ -535,6 +643,42 @@ impl Default for XmrDaemonGetInfoResponse {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Deserialize, Debug)]
|
||||||
|
pub struct XmrDaemonGetBlockResponse {
|
||||||
|
pub result: XmrDaemonGetBlockResult,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for XmrDaemonGetBlockResponse {
|
||||||
|
fn default() -> Self {
|
||||||
|
XmrDaemonGetBlockResponse {
|
||||||
|
result: XmrDaemonGetBlockResult {
|
||||||
|
blob: utils::empty_string(),
|
||||||
|
block_header: Default::default(),
|
||||||
|
credits: 0,
|
||||||
|
json: utils::empty_string(),
|
||||||
|
miner_tx_hash: utils::empty_string(),
|
||||||
|
status: utils::empty_string(),
|
||||||
|
top_hash: utils::empty_string(),
|
||||||
|
tx_hashes: Vec::new(),
|
||||||
|
untrusted: false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Serialize, Deserialize, Debug)]
|
||||||
|
pub struct XmrDaemonGetTransactionsResponse {
|
||||||
|
pub txs_as_json: Vec<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for XmrDaemonGetTransactionsResponse {
|
||||||
|
fn default() -> Self {
|
||||||
|
XmrDaemonGetTransactionsResponse {
|
||||||
|
txs_as_json: Vec::new(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Deserialize, Debug)]
|
#[derive(Deserialize, Debug)]
|
||||||
pub struct XmrRpcVerifyResponse {
|
pub struct XmrRpcVerifyResponse {
|
||||||
pub result: XmrRpcVerifyResult,
|
pub result: XmrRpcVerifyResult,
|
||||||
|
|
|
@ -592,3 +592,32 @@ fn validate_installation_hash(sw: ExternalSoftware, filename: &String) -> bool {
|
||||||
debug!("expected hash: {}", expected_hash);
|
debug!("expected hash: {}", expected_hash);
|
||||||
actual_hash == expected_hash
|
actual_hash == expected_hash
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// The highly ineffecient fee estimator.
|
||||||
|
///
|
||||||
|
/// Get the current height. Start fetching blocks
|
||||||
|
///
|
||||||
|
/// and checking the number of transactions. If
|
||||||
|
///
|
||||||
|
/// there were non-coinbase transactions in the block
|
||||||
|
///
|
||||||
|
/// extract the `txnFee` from the `as_json` field.
|
||||||
|
///
|
||||||
|
/// Once we have accumulated n=30 fees paid return the
|
||||||
|
///
|
||||||
|
/// average fee paid from the most recent 30 transactions.
|
||||||
|
///
|
||||||
|
/// Note, it may take more than one block to do this,
|
||||||
|
///
|
||||||
|
/// especially on stagenet.
|
||||||
|
pub fn estimate_fee() -> u128 {
|
||||||
|
|
||||||
|
0
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Combine the results `estimate_fee()` and `get_balance()` to
|
||||||
|
///
|
||||||
|
/// determine whether or not a transfer is possible.
|
||||||
|
pub fn can_transfer() -> bool {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue