1
0

iptables-save every minute

This commit is contained in:
2024-05-12 14:54:47 +02:00
parent ada1a8793a
commit 6a54d6edf2
5 changed files with 17 additions and 93 deletions

View File

@ -2,7 +2,6 @@ use std::process::Command;
pub fn save_iptables() {
let _ = Command::new("iptables-save")
.arg(">")
.arg("/host_iptables/rules.v4")
.args(&["-f", "/host_iptables/rules.v4"])
.output();
}

View File

@ -3,7 +3,7 @@ pub mod login_attempt;
use linemux::MuxedLines;
use login_attempt::LoginAttempt;
use std::collections::HashMap;
use std::{collections::HashMap, thread::sleep, time::Duration};
#[tokio::main]
async fn main() -> std::io::Result<()> {
@ -12,6 +12,19 @@ async fn main() -> std::io::Result<()> {
lines.add_file("/host_ssh/auth.log").await?;
let mut login_attempts: HashMap<String, usize> = HashMap::new();
let seconds_iptables = Duration::from_secs(60);
println!(
"starting iptables-save, run every {} seconds",
seconds_iptables.as_secs()
);
tokio::spawn(async move {
loop {
sleep(seconds_iptables);
iptables_save::save_iptables();
println!("saved iptables rules");
}
});
println!("listening to changes over /host_ssh/auth.log");
while let Ok(Some(line)) = lines.next_line().await {
if let Some(login_attempt) = LoginAttempt::capture(line.line()) {