podman_client/containers/
delete.rs

1use http_body_util::Empty;
2use hyper::body::Bytes;
3use url::form_urlencoded;
4
5use crate::{
6    client::Client,
7    models::{
8        connection::SendRequestOptions,
9        lib::Error,
10        podman::containers::delete::{ContainerDelete, ContainerDeleteOptions},
11    },
12    utils::bool_to_str::bool_to_str,
13};
14
15impl Client {
16    pub async fn container_delete(
17        &self,
18        options: ContainerDeleteOptions<'_>,
19    ) -> Result<ContainerDelete, Error> {
20        let mut path = ["/libpod/containers/", options.name].concat();
21
22        let mut query = form_urlencoded::Serializer::new(String::new());
23        if let Some(depend) = options.depend {
24            query.append_pair("depend", bool_to_str(depend));
25        }
26        if let Some(force) = options.force {
27            query.append_pair("force", bool_to_str(force));
28        }
29        if let Some(ignore) = options.ignore {
30            query.append_pair("ignore", bool_to_str(ignore));
31        }
32        if let Some(timeout) = options.timeout {
33            query.append_pair("timeout", itoa::Buffer::new().format(timeout));
34        }
35        if let Some(v) = options.v {
36            query.append_pair("v", bool_to_str(v));
37        }
38        let query_string = query.finish();
39        if !query_string.is_empty() {
40            path += &["?", &query_string].concat();
41        }
42
43        let (_, data) = self
44            .send_request::<_, (), _>(SendRequestOptions {
45                method: "DELETE",
46                path: &path,
47                header: None,
48                body: Empty::<Bytes>::new(),
49            })
50            .await?;
51
52        Ok(data)
53    }
54}