Skip to content

Commit

Permalink
fix bug on network (#23)
Browse files Browse the repository at this point in the history
* fix bug on network

Signed-off-by: andrewmatilde <[email protected]>

* minor fix

Signed-off-by: andrewmatilde <[email protected]>

* block none port

Signed-off-by: andrewmatilde <[email protected]>

* block none port

Signed-off-by: andrewmatilde <[email protected]>

* main > all

Signed-off-by: andrewmatilde <[email protected]>
  • Loading branch information
Andrewmatilde authored Nov 26, 2021
1 parent 50e1d1c commit 0ed1821
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 5 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ Support json and yaml config.
Example of config could be found in `./config-examples`
## Yaml config file example
```yaml
proxy_ports: [80] # option u16 vec ; proxy all tcp packet if not provided
proxy_ports: [80] # option u16 vec ; Do nothing if not provided
interface: eth33 # option string
rules: # option rule vec
- target: Request # Request or Response.
Expand Down
3 changes: 3 additions & 0 deletions rs-tproxy-controller/src/proxy/exec.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,9 @@ impl Proxy {

pub async fn reload(&mut self, config: ProxyRawConfig) -> anyhow::Result<()> {
self.stop().await?;
if config.proxy_ports.is_none() {
return Ok(());
}
if self.task.is_none() {
let mut new = Self::new(self.opt.verbose);
self.opt = new.opt;
Expand Down
42 changes: 38 additions & 4 deletions rs-tproxy-controller/src/proxy/net/bridge.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
use std::process::Command;
use std::net::Ipv4Addr;

use anyhow::{anyhow, Result};
use default_net;
Expand Down Expand Up @@ -38,7 +39,7 @@ impl NetEnv {
break key;
}
};
let ip_route_store = Uuid::new_v4().to_string();
let ip_route_store = "ip_route_store".to_string() + &Uuid::new_v4().to_string();
let device = get_default_interface().unwrap();
let netns = prefix.clone() + "ns";
let bridge1 = prefix.clone() + "b1";
Expand Down Expand Up @@ -177,19 +178,33 @@ impl NetEnv {
}

pub fn clear_bridge(&self) -> Result<()> {
let restore = format!("ip route restore < {}", &self.ip_route_store);
let restore_dns = "cp /etc/resolv.conf.bak /etc/resolv.conf";
let remove_store = format!("rm -f {}", &self.ip_route_store);

let net: Ipv4Network = self.ip.parse().unwrap();
let net_domain = Ipv4Addr::from(u32::from(net.ip()) & u32::from(net.mask())).to_string()
+ "/"
+ &net.prefix().to_string();
let del_default_route = format!("ip route del {} dev {} proto kernel scope link src {}", &net_domain, &self.device, &net.ip().to_string());

let cmdvv = vec![
ip_netns_del(&self.netns),
ip_link_del_bridge(&self.bridge1),
ip_address("add", &self.ip, &self.device),
bash_c(restore_dns),
bash_c(&restore),
bash_c(&remove_store),
bash_c(&del_default_route),
clear_ebtables(),
];
execute_all_with_log_error(cmdvv)?;

let ip_routes= restore_all_ip_routes(&self.ip_route_store)?;
let iproute_cmds: Vec<Vec<&str>> = ip_routes.iter().map(|s| bash_c(&**s)).collect();
execute_all_with_log_error(iproute_cmds)?;

let cmdvv = vec![
bash_c(&remove_store),
];
execute_all_with_log_error(cmdvv)?;
Ok(())
}
}
Expand Down Expand Up @@ -353,3 +368,22 @@ pub fn get_default_interface() -> Result<NetworkInterface> {
}
Err(anyhow!("no valid interface"))
}

pub fn restore_all_ip_routes(path : &str) -> Result<Vec<String>> {
let cmd_string = format!("ip route showdump < {}", path);
let mut cmd = Command::new("sh");
cmd.arg("-c")
.arg(cmd_string);
let stdo = cmd.output()?.stdout;
let out = String::from_utf8_lossy(stdo.as_slice());

let mut ip_routes: Vec<_> = out.split('\n').collect();
ip_routes.reverse();
let mut route_cmds: Vec<String> = Vec::new();
for ip_route in ip_routes {
if !ip_route.is_empty() {
route_cmds.push(format!("{} {}", "ip route add", ip_route));
}
}
Ok(route_cmds)
}

0 comments on commit 0ed1821

Please sign in to comment.