client: add list-cidrs function

Closes #99
pull/121/head
Jake McGinty 2021-06-14 18:50:21 +09:00
parent 647ec7ca3e
commit 2fa7524def
1 changed files with 25 additions and 0 deletions

View File

@ -171,6 +171,15 @@ enum Command {
opts: DeleteCidrOpts, opts: DeleteCidrOpts,
}, },
/// List CIDRs.
ListCidrs {
interface: Interface,
/// Display CIDRs in tree format
#[structopt(short, long)]
tree: bool,
},
/// Disable an enabled peer. /// Disable an enabled peer.
DisablePeer { interface: Interface }, DisablePeer { interface: Interface },
@ -604,6 +613,21 @@ fn delete_cidr(interface: &InterfaceName, opts: DeleteCidrOpts) -> Result<(), Er
Ok(()) Ok(())
} }
fn list_cidrs(interface: &InterfaceName, tree: bool) -> Result<(), Error> {
let data_store = DataStore::open(interface)?;
if tree {
let cidr_tree = CidrTree::new(data_store.cidrs());
colored::control::set_override(false);
print_tree(&cidr_tree, &[], 0);
colored::control::unset_override();
} else {
for cidr in data_store.cidrs() {
println!("{} {}", cidr.cidr, cidr.name);
}
}
Ok(())
}
fn add_peer(interface: &InterfaceName, opts: AddPeerOpts) -> Result<(), Error> { fn add_peer(interface: &InterfaceName, opts: AddPeerOpts) -> Result<(), Error> {
let InterfaceConfig { server, .. } = InterfaceConfig::from_interface(interface)?; let InterfaceConfig { server, .. } = InterfaceConfig::from_interface(interface)?;
let api = Api::new(&server); let api = Api::new(&server);
@ -1036,6 +1060,7 @@ fn run(opt: Opts) -> Result<(), Error> {
Command::RenamePeer { interface, opts } => rename_peer(&interface, opts)?, Command::RenamePeer { interface, opts } => rename_peer(&interface, opts)?,
Command::AddCidr { interface, opts } => add_cidr(&interface, opts)?, Command::AddCidr { interface, opts } => add_cidr(&interface, opts)?,
Command::DeleteCidr { interface, opts } => delete_cidr(&interface, opts)?, Command::DeleteCidr { interface, opts } => delete_cidr(&interface, opts)?,
Command::ListCidrs { interface, tree } => list_cidrs(&interface, tree)?,
Command::DisablePeer { interface } => enable_or_disable_peer(&interface, false)?, Command::DisablePeer { interface } => enable_or_disable_peer(&interface, false)?,
Command::EnablePeer { interface } => enable_or_disable_peer(&interface, true)?, Command::EnablePeer { interface } => enable_or_disable_peer(&interface, true)?,
Command::AddAssociation { interface, opts } => add_association(&interface, opts)?, Command::AddAssociation { interface, opts } => add_association(&interface, opts)?,