atlassian_rust_api/jira/endpoints/cluster/
delete_node.rs1use std::sync::Arc;
2
3use crate::{Jira, Result, rest_client::RestClient, web::Endpoint};
4
5#[derive(Debug, Clone)]
6pub struct DeleteNodeBuilder {
7 client: Arc<RestClient>,
8 request: DeleteNodeRequest,
9}
10
11#[derive(Debug, Clone, Default)]
12struct DeleteNodeRequest {
13 node_id: String,
14}
15
16impl Endpoint for DeleteNodeRequest {
17 fn endpoint(&self) -> std::borrow::Cow<'static, str> {
18 format!("cluster/node/{}", &self.node_id).into()
19 }
20}
21
22impl DeleteNodeBuilder {
23 fn new(client: Arc<RestClient>) -> DeleteNodeBuilder {
24 DeleteNodeBuilder { client, request: DeleteNodeRequest::default() }
25 }
26
27 fn node_id(mut self, node_id: impl Into<String>) -> DeleteNodeBuilder {
28 self.request.node_id = node_id.into();
29 self
30 }
31
32 pub async fn send(self) -> Result<()> {
33 self.client.delete_ignore(self.request).await
34 }
35}
36
37impl Jira {
38 pub fn delete_node(&self, node_id: impl Into<String>) -> DeleteNodeBuilder {
40 DeleteNodeBuilder::new(Arc::clone(&self.client)).node_id(node_id)
41 }
42}