Skip to main content

atlassian_rust_api/jira/endpoints/cluster/
delete_node.rs

1use 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	/// Delete the node from the cluster if the state of the node is OFFLINE.
39	pub fn delete_node(&self, node_id: impl Into<String>) -> DeleteNodeBuilder {
40		DeleteNodeBuilder::new(Arc::clone(&self.client)).node_id(node_id)
41	}
42}