Feat: Fügt Funktionen hinzu, um zu testen, ob eine Adresse erreichbar ist.

This commit is contained in:
2025-08-18 15:11:47 +02:00
parent 9f7fbdf8e2
commit 020e964b13
3 changed files with 110 additions and 4 deletions

View File

@@ -4,6 +4,7 @@ use std::time::Duration;
use crate::log::LogLevel;
use crate::log::log;
use crate::network::network_interface::{get_active_network_interface, get_interface_ip_address};
use crate::network::utils::{get_network_address, is_reachable};
mod log;
mod network;
@@ -29,12 +30,28 @@ fn main() {
count = count+1;
sleep(Duration::from_secs(1));
}
log("main", &*format!("Active network interface found: {}", network_interface), LogLevel::Info);
let interface_address = get_interface_ip_address(network_interface.as_str()).unwrap().trim().to_string();
log("main", &*format!("Interface address: {}", interface_address), LogLevel::Info);
let network_address = get_network_address(interface_address.as_str()).unwrap().trim().to_string();
log("main", &*format!("Network address: {}", network_address), LogLevel::Info);
count = 0;
loop {
if is_reachable(network_address.as_str()) {
break;
} else if count >= 10 {
log("main", "Couldn't reach network address, exiting.", LogLevel::Error);
exit(1);
}
log("main", "Network address not reachable, waiting 1 second.", LogLevel::Warn);
count = count+1;
sleep(Duration::from_secs(1));
}
log("main", "Network address is reachable.", LogLevel::Info);
log("main", "========== PROGRAMM END ==========", LogLevel::Info);
}

View File

@@ -1,2 +1,2 @@
pub mod network_card;
pub mod network_interface;
pub mod network_interface;
pub mod utils;

89
src/network/utils.rs Normal file
View File

@@ -0,0 +1,89 @@
use std::process::Command;
use std::net::Ipv4Addr;
use crate::log;
use crate::log::LogLevel;
/// Prüft, ob eine angegebene IP-Adresse oder URL erreichbar ist
///
/// # Parameter
/// - `address`: Eine IP-Adresse oder vollständige HTTPS-URL
///
/// # Rückgabe
/// - `bool`: True wenn die Adresse erreichbar ist, False wenn nicht
pub fn is_reachable(address: &str) -> bool {
let addr = &*if let Some(parts) = address.split('/').nth(0) {
if let Ok(ip) = parts.parse::<Ipv4Addr>() {
let next_ip = Ipv4Addr::from(u32::from(ip) + 1);
next_ip.to_string()
} else {
address.to_string()
}
} else {
address.to_string()
};
#[cfg(target_os = "linux")]
{
let output = Command::new("ping")
.args(["-c", "1", "-W", "2", addr])
.output();
if let Ok(out) = output {
out.status.success()
} else {
log::log("network_utils", &*format!("Couldn't reach address {}!", addr), LogLevel::Error);
false
}
}
#[cfg(target_os = "windows")]
{
let output = Command::new("ping")
.args(["-n", "1", "-w", "2000", addr])
.output();
if let Ok(out) = output {
out.status.success()
} else {
log::log("network_utils", &*format!("Couldn't reach address {}!", addr), LogLevel::Error);
false
}
}
#[cfg(not(any(target_os = "linux", target_os = "windows")))]
{
log::log("network_utils", "OS not supported.", LogLevel::Error);
false
}
}
/// Berechnet die Netzwerkadresse aus einer IP-Adresse mit Subnetzmaske
///
/// # Parameter
/// - `address`: Eine IPv4-Adresse mit Subnetzmaske im Format "xxx.xxx.xxx.xxx/yy"
///
/// # Rückgabe
/// - Option<String>: Die Netzwerkadresse im gleichen Format oder None bei ungültiger Eingabe
pub fn get_network_address(address: &str) -> Option<String> {
let parts: Vec<&str> = address.split('/').collect();
if parts.len() != 2 {
return None;
}
if let Ok(ip) = parts[0].parse::<Ipv4Addr>() {
if let Ok(mask) = parts[1].parse::<u8>() {
if mask > 32 {
return None;
}
let ip_bits: u32 = u32::from(ip);
let mask_bits: u32 = !0u32 << (32 - mask);
let network = Ipv4Addr::from(ip_bits & mask_bits);
return Some(format!("{}/{}", network, mask));
}
}
None
}