14 releases
0.5.2 | Jun 6, 2024 |
---|---|
0.5.1 | Sep 18, 2023 |
0.5.0 | Feb 1, 2022 |
0.4.3 | Mar 7, 2021 |
0.1.2 | Feb 11, 2017 |
#334 in Network programming
7,699 downloads per month
Used in netavark
20KB
442 lines
Rust iptables
This crate provides bindings for iptables application in Linux (inspired by go-iptables). This crate uses iptables binary to manipulate chains and tables. This source code is licensed under MIT license that can be found in the LICENSE file.
[dependencies]
iptables = "*"
Getting started
1- Import the crate iptables
and manipulate chains:
let ipt = iptables::new(false).unwrap();
assert!(ipt.new_chain("nat", "NEWCHAINNAME").is_ok());
assert!(ipt.append("nat", "NEWCHAINNAME", "-j ACCEPT").is_ok());
assert!(ipt.exists("nat", "NEWCHAINNAME", "-j ACCEPT").unwrap());
assert!(ipt.delete("nat", "NEWCHAINNAME", "-j ACCEPT").is_ok());
assert!(ipt.delete_chain("nat", "NEWCHAINNAME").is_ok());
For more information, please check the test file in tests
folder.
Dependencies
~5MB
~90K SLoC