feat: enable xmrig with remote control and token, generate token

This commit is contained in:
Louis-Marie Baer 2024-03-16 16:43:51 +01:00
parent 2499953725
commit 87eb738ca8
6 changed files with 52 additions and 12 deletions

View file

@ -59,7 +59,7 @@ So 1kH/s is given to XvB node so that the miner participate in the Donor round.
P2pool node (PN) local API show only found shares and not current. It is not also showing the current height block of p2pool. P2pool node (PN) local API show only found shares and not current. It is not also showing the current height block of p2pool.
Gupaxx process will check every minute when a new share is found, and how much time passed since the last. While verifying if mining on mini or main chain, it will calculate if the last share found is still valid. Gupaxx process will check every minute when a new share is found, and how much time passed since the last. While verifying if mining on mini or main chain, it will calculate if the last share found is still valid.
This way Gupaxx will know if a share is currently in the window. This way Gupaxx will know if a share is currently in the window.
This method is only an estimation, a better way would be to know at which block the share is found and which block height the network is currently at. But P2pool API doesn't offer these informations by API but by command. This method is only an estimation, a better way would be to know at which block the share is found and which block height the network is currently at. But P2pool API doesn't offer these information by API but by command.
### Knowing the HR generated by Gupaxx ### Knowing the HR generated by Gupaxx

View file

@ -26,8 +26,8 @@
- [ ] distribute hashrate conforming to the algorithm. - [ ] distribute hashrate conforming to the algorithm.
- [x] check every 10 minutes average Xmrig HR of last 15 minutes - [x] check every 10 minutes average Xmrig HR of last 15 minutes
- [ ] ask Xmrig to mine on p2pool - [ ] ask Xmrig to mine on p2pool
- [ ] generate token for xmrig - [x] generate token for xmrig
- [ ] enable xmrig with remote access control - [x] enable xmrig with remote access control
- [x] check if at least a share in pplns Window - [x] check if at least a share in pplns Window
- [ ] calculate spared HR - [ ] calculate spared HR
- [ ] calculate time to be spared - [ ] calculate time to be spared

View file

@ -1,7 +1,5 @@
use anyhow::{Result}; use anyhow::Result;
use rand::{distributions::Alphanumeric, thread_rng, Rng};
use super::*; use super::*;
use crate::{components::node::RemoteNode, disk::status::*}; use crate::{components::node::RemoteNode, disk::status::*};
@ -242,6 +240,7 @@ pub struct Xmrig {
pub selected_rig: String, pub selected_rig: String,
pub selected_ip: String, pub selected_ip: String,
pub selected_port: String, pub selected_port: String,
pub token: String,
} }
#[derive(Clone, Eq, PartialEq, Debug, Deserialize, Serialize, Default)] #[derive(Clone, Eq, PartialEq, Debug, Deserialize, Serialize, Default)]
@ -363,6 +362,11 @@ impl Default for Xmrig {
keepalive: false, keepalive: false,
current_threads: 1, current_threads: 1,
max_threads: 1, max_threads: 1,
token: thread_rng()
.sample_iter(Alphanumeric)
.take(16)
.map(char::from)
.collect(),
} }
} }
} }

View file

@ -96,6 +96,7 @@ mod test {
selected_rig = "Gupax" selected_rig = "Gupax"
selected_ip = "192.168.1.122" selected_ip = "192.168.1.122"
selected_port = "3333" selected_port = "3333"
token = "testtoken"
[xvb] [xvb]
token = "" token = ""

View file

@ -141,8 +141,18 @@ impl Helper {
let gui_api = Arc::clone(&lock!(helper).gui_api_xmrig); let gui_api = Arc::clone(&lock!(helper).gui_api_xmrig);
let pub_api = Arc::clone(&lock!(helper).pub_api_xmrig); let pub_api = Arc::clone(&lock!(helper).pub_api_xmrig);
let path = path.to_path_buf(); let path = path.to_path_buf();
let token = state.token.clone();
thread::spawn(move || { thread::spawn(move || {
Self::spawn_xmrig_watchdog(process, gui_api, pub_api, args, path, sudo, api_ip_port); Self::spawn_xmrig_watchdog(
process,
gui_api,
pub_api,
args,
path,
sudo,
api_ip_port,
&token,
);
}); });
} }
@ -189,6 +199,8 @@ impl Helper {
args.push("127.0.0.1".to_string()); // HTTP API IP args.push("127.0.0.1".to_string()); // HTTP API IP
args.push("--http-port".to_string()); args.push("--http-port".to_string());
args.push("18088".to_string()); // HTTP API Port args.push("18088".to_string()); // HTTP API Port
args.push(format!("--http-access-token={}", state.token)); // HTTP API Port
args.push("--http-no-restricted".to_string());
if state.pause != 0 { if state.pause != 0 {
args.push("--pause-on-active".to_string()); args.push("--pause-on-active".to_string());
args.push(state.pause.to_string()); args.push(state.pause.to_string());
@ -313,6 +325,7 @@ impl Helper {
path: std::path::PathBuf, path: std::path::PathBuf,
sudo: Arc<Mutex<SudoState>>, sudo: Arc<Mutex<SudoState>>,
mut api_ip_port: String, mut api_ip_port: String,
token: &str,
) { ) {
// 1a. Create PTY // 1a. Create PTY
debug!("XMRig | Creating PTY..."); debug!("XMRig | Creating PTY...");
@ -543,10 +556,11 @@ impl Helper {
start.elapsed(), start.elapsed(),
&process, &process,
); );
// Send an HTTP API request // Send an HTTP API request
debug!("XMRig Watchdog | Attempting HTTP API request..."); debug!("XMRig Watchdog | Attempting HTTP API request...");
if let Ok(priv_api) = PrivXmrigApi::request_xmrig_api(client.clone(), &api_uri).await { if let Ok(priv_api) =
PrivXmrigApi::request_xmrig_api(client.clone(), &api_uri, token).await
{
debug!("XMRig Watchdog | HTTP API request OK, attempting [update_from_priv()]"); debug!("XMRig Watchdog | HTTP API request OK, attempting [update_from_priv()]");
PubXmrigApi::update_from_priv(&pub_api, priv_api); PubXmrigApi::update_from_priv(&pub_api, priv_api);
} else { } else {
@ -729,9 +743,11 @@ impl PrivXmrigApi {
async fn request_xmrig_api( async fn request_xmrig_api(
client: hyper::Client<hyper::client::HttpConnector>, client: hyper::Client<hyper::client::HttpConnector>,
api_uri: &str, api_uri: &str,
token: &str,
) -> std::result::Result<Self, anyhow::Error> { ) -> std::result::Result<Self, anyhow::Error> {
let request = hyper::Request::builder() let request = hyper::Request::builder()
.method("GET") .method("GET")
.header("Authorization", ["Bearer ", token].concat())
.uri(api_uri) .uri(api_uri)
.body(hyper::Body::empty())?; .body(hyper::Body::empty())?;
let response = tokio::time::timeout( let response = tokio::time::timeout(

View file

@ -244,9 +244,9 @@ impl Helper {
break; break;
} }
} }
debug!("XvB Watchdog | Attempting HTTP private API request..."); // only if private API is accessible, NotMining here means that the token and address is not registered on the XvB website and Syncing means P2pool node is not running and so that some information for private info are not available.
// only if private API is accessible, NotMining here means that the token and address is not registered on the XvB website.
if lock!(process).state == ProcessState::Alive { if lock!(process).state == ProcessState::Alive {
debug!("XvB Watchdog | Attempting HTTP private API request...");
// reload private stats // reload private stats
match XvbPrivStats::request_api( match XvbPrivStats::request_api(
&client, &client,
@ -328,6 +328,22 @@ impl Helper {
{ {
lock!(pub_api).stats_priv.win_current = true lock!(pub_api).stats_priv.win_current = true
} }
// if 10 minutes passed since last check
if lock!(gui_api).tick_distribute_hr > (60 * 10) {
// request XMrig to mine on P2pool
}
// if share is in PW,
// check average HR of last 15 minutes from XMrig.
// if HR + buffer >= mHR,
// calculate how much time can be spared
// if not hero option
// calculate how much time needed to be spared to be in most round type minimum HR + buffer
// fi
// sleep 10m less spared time then request XMrig to mine on XvB
// fi
// fi
// instant saved for next check
// fi
} }
lock!(gui_api).tick = 0; lock!(gui_api).tick = 0;
@ -356,6 +372,7 @@ pub struct PubXvbApi {
pub output: String, pub output: String,
pub uptime: u64, pub uptime: u64,
pub tick: u8, pub tick: u8,
pub tick_distribute_hr: u16,
pub stats_pub: XvbPubStats, pub stats_pub: XvbPubStats,
pub stats_priv: XvbPrivStats, pub stats_priv: XvbPrivStats,
} }
@ -479,9 +496,11 @@ impl PubXvbApi {
output.push_str(&buf); output.push_str(&buf);
} }
let tick = std::mem::take(&mut gui_api.tick); let tick = std::mem::take(&mut gui_api.tick);
let tick_distribute_hr = std::mem::take(&mut gui_api.tick_distribute_hr);
*gui_api = Self { *gui_api = Self {
output, output,
tick, tick,
tick_distribute_hr,
..pub_api.clone() ..pub_api.clone()
}; };
} }