nifi-rust-client 0.4.0

Apache NiFi REST API client library
Documentation
// @generated — do not edit; run `cargo run -p nifi-openapi-gen`

#[allow(unused_imports)]
use crate::NifiError;
use crate::dynamic::traits::ProvenanceEventsApi;
use crate::dynamic::traits::ProvenanceEventsContentApi;
#[allow(unused_imports)]
use crate::dynamic::types;
/// Dynamic dispatch enum for the ProvenanceEvents API. Use via the [`ProvenanceEventsApi`] trait.
#[allow(private_interfaces)]
#[non_exhaustive]
pub enum ProvenanceEventsApiDispatch<'a> {
    V2_6_0(super::super::impls::v2_6_0::V2_6_0ProvenanceEventsApi<'a>),
    V2_7_2(super::super::impls::v2_7_2::V2_7_2ProvenanceEventsApi<'a>),
    V2_8_0(super::super::impls::v2_8_0::V2_8_0ProvenanceEventsApi<'a>),
}
impl<'a> ProvenanceEventsApiDispatch<'a> {
    fn client(&self) -> &'a crate::NifiClient {
        match self {
            Self::V2_6_0(api) => api.client,
            Self::V2_7_2(api) => api.client,
            Self::V2_8_0(api) => api.client,
        }
    }
    fn version(&self) -> crate::dynamic::DetectedVersion {
        match self {
            Self::V2_6_0(_) => crate::dynamic::DetectedVersion::V2_6_0,
            Self::V2_7_2(_) => crate::dynamic::DetectedVersion::V2_7_2,
            Self::V2_8_0(_) => crate::dynamic::DetectedVersion::V2_8_0,
        }
    }
}
impl ProvenanceEventsApi for ProvenanceEventsApiDispatch<'_> {
    fn content<'b>(&'b self, id: &'b str) -> impl ProvenanceEventsContentApi + 'b {
        ProvenanceEventsContentApiDispatch {
            client: self.client(),
            id: id.to_string(),
            version: self.version(),
        }
    }
    async fn get_latest_provenance_events(
        &self,
        component_id: &str,
        limit: Option<i32>,
    ) -> Result<types::LatestProvenanceEventsDto, NifiError> {
        match self {
            Self::V2_6_0(api) => api.get_latest_provenance_events(component_id, limit).await,
            Self::V2_7_2(api) => api.get_latest_provenance_events(component_id, limit).await,
            Self::V2_8_0(api) => api.get_latest_provenance_events(component_id, limit).await,
        }
    }
    async fn get_provenance_event(
        &self,
        id: &str,
        cluster_node_id: Option<&str>,
    ) -> Result<types::ProvenanceEventDto, NifiError> {
        match self {
            Self::V2_6_0(api) => api.get_provenance_event(id, cluster_node_id).await,
            Self::V2_7_2(api) => api.get_provenance_event(id, cluster_node_id).await,
            Self::V2_8_0(api) => api.get_provenance_event(id, cluster_node_id).await,
        }
    }
    async fn submit_replay(
        &self,
        body: &types::SubmitReplayRequestEntity,
    ) -> Result<types::ProvenanceEventDto, NifiError> {
        match self {
            Self::V2_6_0(api) => api.submit_replay(body).await,
            Self::V2_7_2(api) => api.submit_replay(body).await,
            Self::V2_8_0(api) => api.submit_replay(body).await,
        }
    }
    async fn submit_replay_latest_event(
        &self,
        body: &types::ReplayLastEventRequestEntity,
    ) -> Result<types::ReplayLastEventResponseEntity, NifiError> {
        match self {
            Self::V2_6_0(api) => api.submit_replay_latest_event(body).await,
            Self::V2_7_2(api) => api.submit_replay_latest_event(body).await,
            Self::V2_8_0(api) => api.submit_replay_latest_event(body).await,
        }
    }
}
/// Sub-resource dispatch struct for [ProvenanceEventsContentApi].
pub struct ProvenanceEventsContentApiDispatch<'a> {
    pub(crate) client: &'a crate::NifiClient,
    pub(crate) id: String,
    pub(crate) version: crate::dynamic::DetectedVersion,
}
impl ProvenanceEventsContentApi for ProvenanceEventsContentApiDispatch<'_> {
    async fn get_input_content(&self, cluster_node_id: Option<&str>) -> Result<(), NifiError> {
        #[allow(unreachable_patterns)]
        match self.version {
            crate::dynamic::DetectedVersion::V2_6_0 => {
                let api = crate::v2_6_0::api::provenanceevents::ProvenanceEventsContentApi {
                    client: self.client,
                    id: &self.id,
                };
                api.get_input_content(cluster_node_id).await
            }
            crate::dynamic::DetectedVersion::V2_7_2 => {
                let api = crate::v2_7_2::api::provenanceevents::ProvenanceEventsContentApi {
                    client: self.client,
                    id: &self.id,
                };
                api.get_input_content(cluster_node_id).await
            }
            crate::dynamic::DetectedVersion::V2_8_0 => {
                let api = crate::v2_8_0::api::provenanceevents::ProvenanceEventsContentApi {
                    client: self.client,
                    id: &self.id,
                };
                api.get_input_content(cluster_node_id).await
            }
            _ => Err(NifiError::UnsupportedEndpoint {
                endpoint: "get_input_content".to_string(),
                version: "unknown".to_string(),
            }),
        }
    }
    async fn get_output_content(&self, cluster_node_id: Option<&str>) -> Result<(), NifiError> {
        #[allow(unreachable_patterns)]
        match self.version {
            crate::dynamic::DetectedVersion::V2_6_0 => {
                let api = crate::v2_6_0::api::provenanceevents::ProvenanceEventsContentApi {
                    client: self.client,
                    id: &self.id,
                };
                api.get_output_content(cluster_node_id).await
            }
            crate::dynamic::DetectedVersion::V2_7_2 => {
                let api = crate::v2_7_2::api::provenanceevents::ProvenanceEventsContentApi {
                    client: self.client,
                    id: &self.id,
                };
                api.get_output_content(cluster_node_id).await
            }
            crate::dynamic::DetectedVersion::V2_8_0 => {
                let api = crate::v2_8_0::api::provenanceevents::ProvenanceEventsContentApi {
                    client: self.client,
                    id: &self.id,
                };
                api.get_output_content(cluster_node_id).await
            }
            _ => Err(NifiError::UnsupportedEndpoint {
                endpoint: "get_output_content".to_string(),
                version: "unknown".to_string(),
            }),
        }
    }
}