podman_client/networks/
list.rs1use std::collections::HashMap;
2
3use http_body_util::Empty;
4use hyper::body::Bytes;
5use url::form_urlencoded::byte_serialize;
6
7use crate::{
8 client::Client,
9 models::{
10 connection::SendRequestOptions,
11 lib::Error,
12 podman::networks::list::{NetworkList, NetworkListOptions},
13 },
14};
15
16impl Client {
17 pub async fn network_list(
18 &self,
19 options: Option<NetworkListOptions<'_>>,
20 ) -> Result<NetworkList, Error> {
21 let mut path = "/libpod/networks/json".to_owned();
22
23 if let Some(options) = options {
24 if let Some(opt_filters) = options.filters {
25 let mut filters = HashMap::new();
26 if let Some(name) = opt_filters.name {
27 filters.insert("name", name);
28 }
29 if let Some(id) = opt_filters.id {
30 filters.insert("id", id);
31 }
32 if let Some(driver) = opt_filters.driver {
33 filters.insert("driver", driver);
34 }
35 if let Some(label) = opt_filters.label {
36 filters.insert("label", label);
37 }
38 if let Some(until) = opt_filters.until {
39 filters.insert("until", until);
40 }
41 if !filters.is_empty() {
42 let filters_json = serde_json::to_string(&filters)?;
43 let filters_encoded: String = byte_serialize(filters_json.as_bytes()).collect();
44 path += &["?filters=", &filters_encoded].concat();
45 }
46 }
47 }
48
49 let (_, data) = self
50 .send_request::<_, (), _>(SendRequestOptions {
51 method: "GET",
52 path: &path,
53 header: None,
54 body: Empty::<Bytes>::new(),
55 })
56 .await?;
57
58 Ok(data)
59 }
60}