podman_client/containers/
delete.rs1use 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}