mirror of
https://github.com/hinto-janai/gupax.git
synced 2025-01-09 19:59:24 +00:00
node.rs: randomly send [1-5] RPC calls to prevent fingerprinting
This commit is contained in:
parent
c93a07b7a5
commit
dafb8fc18e
2 changed files with 21 additions and 16 deletions
|
@ -16,6 +16,7 @@ log = "0.4.17"
|
||||||
monero = "0.18.0"
|
monero = "0.18.0"
|
||||||
num_cpus = "1.13.1"
|
num_cpus = "1.13.1"
|
||||||
num-format = "0.4.0"
|
num-format = "0.4.0"
|
||||||
|
rand = "0.8.5"
|
||||||
regex = "1.6.0"
|
regex = "1.6.0"
|
||||||
reqwest = { version = "0.11.12", features = ["blocking", "json"] }
|
reqwest = { version = "0.11.12", features = ["blocking", "json"] }
|
||||||
serde = "1.0.145"
|
serde = "1.0.145"
|
||||||
|
|
36
src/node.rs
36
src/node.rs
|
@ -21,6 +21,7 @@ use std::collections::HashMap;
|
||||||
use std::error::Error;
|
use std::error::Error;
|
||||||
use std::thread;
|
use std::thread;
|
||||||
use egui::Color32;
|
use egui::Color32;
|
||||||
|
use rand::Rng;
|
||||||
use log::*;
|
use log::*;
|
||||||
|
|
||||||
// Community Monerod nodes. All of these have ZMQ on 18083.
|
// Community Monerod nodes. All of these have ZMQ on 18083.
|
||||||
|
@ -69,19 +70,21 @@ pub struct PingResult {
|
||||||
impl NodeStruct {
|
impl NodeStruct {
|
||||||
pub fn default() -> Self {
|
pub fn default() -> Self {
|
||||||
use crate::NodeEnum::*;
|
use crate::NodeEnum::*;
|
||||||
|
let ms = 0;
|
||||||
|
let color = Color32::GRAY;
|
||||||
Self {
|
Self {
|
||||||
c3pool: Data { ms: 0, color: Color32::GRAY, id: C3pool, ip: C3POOL.to_string(), },
|
c3pool: Data { ms, color, id: C3pool, ip: C3POOL.to_string(), },
|
||||||
cake: Data { ms: 0, color: Color32::GRAY, id: Cake, ip: CAKE.to_string(), },
|
cake: Data { ms, color, id: Cake, ip: CAKE.to_string(), },
|
||||||
cake_eu: Data { ms: 0, color: Color32::GRAY, id: CakeEu, ip: CAKE_EU.to_string(), },
|
cake_eu: Data { ms, color, id: CakeEu, ip: CAKE_EU.to_string(), },
|
||||||
cake_uk: Data { ms: 0, color: Color32::GRAY, id: CakeUk, ip: CAKE_UK.to_string(), },
|
cake_uk: Data { ms, color, id: CakeUk, ip: CAKE_UK.to_string(), },
|
||||||
cake_us: Data { ms: 0, color: Color32::GRAY, id: CakeUs, ip: CAKE_US.to_string(), },
|
cake_us: Data { ms, color, id: CakeUs, ip: CAKE_US.to_string(), },
|
||||||
monerujo: Data { ms: 0, color: Color32::GRAY, id: Monerujo, ip: MONERUJO.to_string(), },
|
monerujo: Data { ms, color, id: Monerujo, ip: MONERUJO.to_string(), },
|
||||||
rino: Data { ms: 0, color: Color32::GRAY, id: Rino, ip: RINO.to_string(), },
|
rino: Data { ms, color, id: Rino, ip: RINO.to_string(), },
|
||||||
selsta: Data { ms: 0, color: Color32::GRAY, id: Selsta, ip: SELSTA.to_string(), },
|
selsta: Data { ms, color, id: Selsta, ip: SELSTA.to_string(), },
|
||||||
seth: Data { ms: 0, color: Color32::GRAY, id: Seth, ip: SETH.to_string(), },
|
seth: Data { ms, color, id: Seth, ip: SETH.to_string(), },
|
||||||
supportxmr: Data { ms: 0, color: Color32::GRAY, id: SupportXmr, ip: SUPPORTXMR.to_string(), },
|
supportxmr: Data { ms, color, id: SupportXmr, ip: SUPPORTXMR.to_string(), },
|
||||||
supportxmr_ir: Data { ms: 0, color: Color32::GRAY, id: SupportXmrIr, ip: SUPPORTXMR_IR.to_string(), },
|
supportxmr_ir: Data { ms, color, id: SupportXmrIr, ip: SUPPORTXMR_IR.to_string(), },
|
||||||
xmrvsbeast: Data { ms: 0, color: Color32::GRAY, id: XmrVsBeast, ip: XMRVSBEAST.to_string(), },
|
xmrvsbeast: Data { ms, color, id: XmrVsBeast, ip: XMRVSBEAST.to_string(), },
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +99,8 @@ impl NodeStruct {
|
||||||
// This is for pinging the community nodes to
|
// This is for pinging the community nodes to
|
||||||
// find the fastest/slowest one for the user.
|
// find the fastest/slowest one for the user.
|
||||||
// The process:
|
// The process:
|
||||||
// - Send 3x [get_info] JSON-RPC requests over HTTP
|
// - Send [get_info] JSON-RPC requests over HTTP
|
||||||
|
// - To prevent fingerprinting, randomly send [1-5] calls
|
||||||
// - Measure each request in milliseconds as [u128]
|
// - Measure each request in milliseconds as [u128]
|
||||||
// - Timeout on requests over 5 seconds
|
// - Timeout on requests over 5 seconds
|
||||||
// - Calculate average time
|
// - Calculate average time
|
||||||
|
@ -142,7 +146,7 @@ impl NodeStruct {
|
||||||
};
|
};
|
||||||
let mut timeout = false;
|
let mut timeout = false;
|
||||||
let mut mid = Duration::new(0, 0);
|
let mut mid = Duration::new(0, 0);
|
||||||
let max = 3;
|
let max = rng::thread_rng().gen_range(1..5);
|
||||||
for i in 1..=max {
|
for i in 1..=max {
|
||||||
let client = reqwest::blocking::ClientBuilder::new();
|
let client = reqwest::blocking::ClientBuilder::new();
|
||||||
let client = reqwest::blocking::ClientBuilder::timeout(client, timeout_sec);
|
let client = reqwest::blocking::ClientBuilder::timeout(client, timeout_sec);
|
||||||
|
@ -152,7 +156,7 @@ impl NodeStruct {
|
||||||
match client.post(http).json(&get_info).send() {
|
match client.post(http).json(&get_info).send() {
|
||||||
Ok(r) => mid += now.elapsed(),
|
Ok(r) => mid += now.elapsed(),
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
error!("Timeout on [{}] (over 3 seconds)", ip);
|
error!("Timeout on [{}: {}] (over 5 seconds)", id, ip);
|
||||||
mid += timeout_sec;
|
mid += timeout_sec;
|
||||||
timeout = true;
|
timeout = true;
|
||||||
},
|
},
|
||||||
|
@ -160,7 +164,7 @@ impl NodeStruct {
|
||||||
}
|
}
|
||||||
let ms = mid.as_millis() / 3;
|
let ms = mid.as_millis() / 3;
|
||||||
vec.push((ms, id));
|
vec.push((ms, id));
|
||||||
info!("{}ms ... {}", ms, ip);
|
info!("{}ms ... {} calls ... {}", ms, max, ip);
|
||||||
let color: Color32;
|
let color: Color32;
|
||||||
if timeout == true {
|
if timeout == true {
|
||||||
color = Color32::BLACK
|
color = Color32::BLACK
|
||||||
|
|
Loading…
Reference in a new issue