2 releases

0.1.1 Oct 13, 2023
0.1.0 Oct 13, 2023

#5 in #quiet

Download history 4/week @ 2024-11-16 1/week @ 2024-11-23 1/week @ 2024-11-30 23/week @ 2024-12-07 21/week @ 2024-12-14 2/week @ 2024-12-21 3/week @ 2025-01-04 8/week @ 2025-01-11 6/week @ 2025-01-18 7/week @ 2025-01-25 46/week @ 2025-02-01 60/week @ 2025-02-08 22/week @ 2025-02-15 11/week @ 2025-02-22 14/week @ 2025-03-01

137 downloads per month
Used in ipset

MIT license

3KB

IPSet

Build Status GitHub issues GitHub license Releases

A library wrapper for libipset.
Support the following options:

  • sorted -> EnvOption::Sorted
  • exist -> EnvOption::Exist
  • quiet -> EnvOption::Quiet
  • resolve -> EnvOption::Resolve
  • name -> EnvOption::ListSetName
  • terse -> EnvOption::ListHeader

Support the following commands:

  • add
  • del
  • test
  • create
  • list
  • destroy
  • flush
  • save
  • restore

Support the following type:

  • BitmapIp
  • BitmapIpMac
  • BitmapPort
  • HashIp
  • HashIpMac
  • HashIpMark
  • HashIpPort
  • HashIpPortIp
  • HashIpPortNet
  • HashMac
  • HashNet
  • HashNetIface
  • HashNetNet
  • HashNetPort
  • HashNetPortNet
  • ListSet,

Example

use std::net::IpAddr;

use ipset::{Error, HashIp, IPSet, Session};

fn main() -> Result<(), Error> {
  let mut session: Session<HashIp> = Session::<HashIp>::new("test".to_string());
  let ip: IpAddr = "192.168.3.1".parse().unwrap();
  session.create(|builder| builder.with_ipv6(false)?.build())?;

  let ret = session.add(ip, &[])?;
  println!("add {}", ret);

  let exists = session.test(ip)?;
  println!("test {}", exists);

  let ips = session.list()?;
  for ip in ips {
      println!("list {}", ip);
  }

  let ret = session.save("test.ipset".into())?;
  println!("save {}", ret);

  let ret = session.del(ip)?;
  println!("del {}", ret);

  let ret = session.flush()?;
  println!("flush {}", ret);

  let ret = session.destroy()?;
  println!("destroy {}", ret);

  let set = IPSet::new();
  set.restore("test.ipset")?;

  Ok(())
}

Dependencies

~190–620KB
~15K SLoC