#![allow(rustdoc::redundant_explicit_links)]
#![allow(rustdoc::broken_intra_doc_links)]
#[derive(Clone, Debug)]
pub struct Parallelstore {
inner: std::sync::Arc<dyn super::stub::dynamic::Parallelstore>,
}
impl Parallelstore {
pub fn builder() -> super::builder::parallelstore::ClientBuilder {
crate::new_client_builder(super::builder::parallelstore::client::Factory)
}
pub fn from_stub<T>(stub: impl Into<std::sync::Arc<T>>) -> Self
where
T: super::stub::Parallelstore + 'static,
{
Self { inner: stub.into() }
}
pub(crate) async fn new(
config: gaxi::options::ClientConfig,
) -> crate::ClientBuilderResult<Self> {
let inner = Self::build_inner(config).await?;
Ok(Self { inner })
}
async fn build_inner(
conf: gaxi::options::ClientConfig,
) -> crate::ClientBuilderResult<std::sync::Arc<dyn super::stub::dynamic::Parallelstore>> {
if gaxi::options::tracing_enabled(&conf) {
return Ok(std::sync::Arc::new(Self::build_with_tracing(conf).await?));
}
Ok(std::sync::Arc::new(Self::build_transport(conf).await?))
}
async fn build_transport(
conf: gaxi::options::ClientConfig,
) -> crate::ClientBuilderResult<impl super::stub::Parallelstore> {
super::transport::Parallelstore::new(conf).await
}
async fn build_with_tracing(
conf: gaxi::options::ClientConfig,
) -> crate::ClientBuilderResult<impl super::stub::Parallelstore> {
Self::build_transport(conf)
.await
.map(super::tracing::Parallelstore::new)
}
pub fn list_instances(&self) -> super::builder::parallelstore::ListInstances {
super::builder::parallelstore::ListInstances::new(self.inner.clone())
}
pub fn get_instance(&self) -> super::builder::parallelstore::GetInstance {
super::builder::parallelstore::GetInstance::new(self.inner.clone())
}
pub fn create_instance(&self) -> super::builder::parallelstore::CreateInstance {
super::builder::parallelstore::CreateInstance::new(self.inner.clone())
}
pub fn update_instance(&self) -> super::builder::parallelstore::UpdateInstance {
super::builder::parallelstore::UpdateInstance::new(self.inner.clone())
}
pub fn delete_instance(&self) -> super::builder::parallelstore::DeleteInstance {
super::builder::parallelstore::DeleteInstance::new(self.inner.clone())
}
pub fn import_data(&self) -> super::builder::parallelstore::ImportData {
super::builder::parallelstore::ImportData::new(self.inner.clone())
}
pub fn export_data(&self) -> super::builder::parallelstore::ExportData {
super::builder::parallelstore::ExportData::new(self.inner.clone())
}
pub fn list_locations(&self) -> super::builder::parallelstore::ListLocations {
super::builder::parallelstore::ListLocations::new(self.inner.clone())
}
pub fn get_location(&self) -> super::builder::parallelstore::GetLocation {
super::builder::parallelstore::GetLocation::new(self.inner.clone())
}
pub fn list_operations(&self) -> super::builder::parallelstore::ListOperations {
super::builder::parallelstore::ListOperations::new(self.inner.clone())
}
pub fn get_operation(&self) -> super::builder::parallelstore::GetOperation {
super::builder::parallelstore::GetOperation::new(self.inner.clone())
}
pub fn delete_operation(&self) -> super::builder::parallelstore::DeleteOperation {
super::builder::parallelstore::DeleteOperation::new(self.inner.clone())
}
pub fn cancel_operation(&self) -> super::builder::parallelstore::CancelOperation {
super::builder::parallelstore::CancelOperation::new(self.inner.clone())
}
}