use crate::Result;
#[allow(unused_imports)]
use gax::error::Error;
#[derive(Clone)]
pub struct Connectors {
inner: gaxi::http::ReqwestClient,
}
impl std::fmt::Debug for Connectors {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::result::Result<(), std::fmt::Error> {
f.debug_struct("Connectors")
.field("inner", &self.inner)
.finish()
}
}
impl Connectors {
pub async fn new(config: gaxi::options::ClientConfig) -> gax::client_builder::Result<Self> {
let inner = gaxi::http::ReqwestClient::new(config, crate::DEFAULT_HOST).await?;
Ok(Self { inner })
}
}
impl super::stub::Connectors for Connectors {
async fn list_connections(
&self,
req: crate::model::ListConnectionsRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ListConnectionsResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/connections",
try_match(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = builder.query(&[("filter", &req.filter)]);
let builder = builder.query(&[("orderBy", &req.order_by)]);
let builder = builder.query(&[("view", &req.view)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
],
"parent",
"projects/*/locations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_connection(
&self,
req: crate::model::GetConnectionRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::Connection>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("view", &req.view)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn create_connection(
&self,
req: crate::model::CreateConnectionRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<longrunning::model::Operation>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/connections",
try_match(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::POST, path);
let builder = builder.query(&[("connectionId", &req.connection_id)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::POST)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
],
"parent",
"projects/*/locations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, Some(req.connection), options)
.await
}
async fn update_connection(
&self,
req: crate::model::UpdateConnectionRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<longrunning::model::Operation>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req)
.and_then(|m| m.connection.as_ref())
.map(|m| &m.name)
.map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::PATCH, path);
let builder = (|| {
let builder = req
.update_mask
.as_ref()
.map(|p| serde_json::to_value(p).map_err(Error::ser))
.transpose()?
.into_iter()
.fold(builder, |builder, v| {
use gaxi::query_parameter::QueryParameter;
v.add(builder, "updateMask")
});
Ok(builder)
})();
Some(builder.map(|b| (b, reqwest::Method::PATCH)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req)
.and_then(|m| m.connection.as_ref())
.map(|m| &m.name)
.map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"connection.name",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, Some(req.connection), options)
.await
}
async fn delete_connection(
&self,
req: crate::model::DeleteConnectionRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<longrunning::model::Operation>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::DELETE, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::DELETE)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn list_providers(
&self,
req: crate::model::ListProvidersRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ListProvidersResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/providers",
try_match(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
],
"parent",
"projects/*/locations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_provider(
&self,
req: crate::model::GetProviderRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::Provider>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/providers/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn list_connectors(
&self,
req: crate::model::ListConnectorsRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ListConnectorsResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/connectors",
try_match(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
],
"parent",
"projects/*/locations/*/providers/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_connector(
&self,
req: crate::model::GetConnectorRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::Connector>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
Segment::Literal("/connectors/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
Segment::Literal("/connectors/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/providers/*/connectors/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn list_connector_versions(
&self,
req: crate::model::ListConnectorVersionsRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ListConnectorVersionsResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/versions",
try_match(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
Segment::Literal("/connectors/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = builder.query(&[("view", &req.view)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
Segment::Literal("/connectors/"),
Segment::SingleWildcard,
],
"parent",
"projects/*/locations/*/providers/*/connectors/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_connector_version(
&self,
req: crate::model::GetConnectorVersionRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ConnectorVersion>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
Segment::Literal("/connectors/"),
Segment::SingleWildcard,
Segment::Literal("/versions/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("view", &req.view)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
Segment::Literal("/connectors/"),
Segment::SingleWildcard,
Segment::Literal("/versions/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/providers/*/connectors/*/versions/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_connection_schema_metadata(
&self,
req: crate::model::GetConnectionSchemaMetadataRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ConnectionSchemaMetadata>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
Segment::Literal("/connectionSchemaMetadata")
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
Segment::Literal("/connectionSchemaMetadata"),
],
"name",
"projects/*/locations/*/connections/*/connectionSchemaMetadata",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn refresh_connection_schema_metadata(
&self,
req: crate::model::RefreshConnectionSchemaMetadataRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<longrunning::model::Operation>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}:refresh",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
Segment::Literal("/connectionSchemaMetadata")
]
)?,
);
let builder = self.inner.builder(reqwest::Method::POST, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::POST)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
Segment::Literal("/connectionSchemaMetadata"),
],
"name",
"projects/*/locations/*/connections/*/connectionSchemaMetadata",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner.execute(builder, Some(req), options).await
}
async fn list_runtime_entity_schemas(
&self,
req: crate::model::ListRuntimeEntitySchemasRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ListRuntimeEntitySchemasResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/runtimeEntitySchemas",
try_match(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = builder.query(&[("filter", &req.filter)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"parent",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn list_runtime_action_schemas(
&self,
req: crate::model::ListRuntimeActionSchemasRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::ListRuntimeActionSchemasResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/runtimeActionSchemas",
try_match(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = builder.query(&[("filter", &req.filter)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.parent).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"parent",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_runtime_config(
&self,
req: crate::model::GetRuntimeConfigRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::RuntimeConfig>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/runtimeConfig")
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/runtimeConfig"),
],
"name",
"projects/*/locations/*/runtimeConfig",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_global_settings(
&self,
req: crate::model::GetGlobalSettingsRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<crate::model::Settings>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/global/settings")
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/global/settings"),
],
"name",
"projects/*/locations/global/settings",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn list_locations(
&self,
req: location::model::ListLocationsRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<location::model::ListLocationsResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/locations",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[Segment::Literal("projects/"), Segment::SingleWildcard]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("filter", &req.filter)]);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[Segment::Literal("projects/"), Segment::SingleWildcard],
"name",
"projects/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_location(
&self,
req: location::model::GetLocationRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<location::model::Location>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn set_iam_policy(
&self,
req: iam_v1::model::SetIamPolicyRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<iam_v1::model::Policy>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}:setIamPolicy",
try_match(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::POST, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::POST)))
})
.or_else(|| {
let path = format!(
"/v1/{}:setIamPolicy",
try_match(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::POST, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::POST)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"resource",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
],
"resource",
"projects/*/locations/*/providers/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner.execute(builder, Some(req), options).await
}
async fn get_iam_policy(
&self,
req: iam_v1::model::GetIamPolicyRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<iam_v1::model::Policy>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}:getIamPolicy",
try_match(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = (|| {
let builder = req
.options
.as_ref()
.map(|p| serde_json::to_value(p).map_err(Error::ser))
.transpose()?
.into_iter()
.fold(builder, |builder, v| {
use gaxi::query_parameter::QueryParameter;
v.add(builder, "options")
});
Ok(builder)
})();
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.or_else(|| {
let path = format!(
"/v1/{}:getIamPolicy",
try_match(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = (|| {
let builder = req
.options
.as_ref()
.map(|p| serde_json::to_value(p).map_err(Error::ser))
.transpose()?
.into_iter()
.fold(builder, |builder, v| {
use gaxi::query_parameter::QueryParameter;
v.add(builder, "options")
});
Ok(builder)
})();
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"resource",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
],
"resource",
"projects/*/locations/*/providers/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn test_iam_permissions(
&self,
req: iam_v1::model::TestIamPermissionsRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<iam_v1::model::TestIamPermissionsResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}:testIamPermissions",
try_match(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::POST, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::POST)))
})
.or_else(|| {
let path = format!(
"/v1/{}:testIamPermissions",
try_match(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::POST, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::POST)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/connections/"),
Segment::SingleWildcard,
],
"resource",
"projects/*/locations/*/connections/*",
);
paths.push(builder.build());
}
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.resource).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/providers/"),
Segment::SingleWildcard,
],
"resource",
"projects/*/locations/*/providers/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner.execute(builder, Some(req), options).await
}
async fn list_operations(
&self,
req: longrunning::model::ListOperationsRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<longrunning::model::ListOperationsResponse>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}/operations",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = builder.query(&[("filter", &req.filter)]);
let builder = builder.query(&[("pageSize", &req.page_size)]);
let builder = builder.query(&[("pageToken", &req.page_token)]);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn get_operation(
&self,
req: longrunning::model::GetOperationRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<longrunning::model::Operation>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/operations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::GET, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::GET)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/operations/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/operations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
}
async fn delete_operation(
&self,
req: longrunning::model::DeleteOperationRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<()>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/operations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::DELETE, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::DELETE)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/operations/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/operations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner
.execute(builder, gaxi::http::NoBody::new(&method), options)
.await
.map(|r: gax::response::Response<wkt::Empty>| {
let (parts, _) = r.into_parts();
gax::response::Response::from_parts(parts, ())
})
}
async fn cancel_operation(
&self,
req: longrunning::model::CancelOperationRequest,
options: gax::options::RequestOptions,
) -> Result<gax::response::Response<()>> {
use gax::error::binding::BindingError;
use gaxi::path_parameter::PathMismatchBuilder;
use gaxi::path_parameter::try_match;
use gaxi::routing_parameter::Segment;
let (builder, method) = None
.or_else(|| {
let path = format!(
"/v1/{}:cancel",
try_match(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/operations/"),
Segment::SingleWildcard
]
)?,
);
let builder = self.inner.builder(reqwest::Method::POST, path);
let builder = Ok(builder);
Some(builder.map(|b| (b, reqwest::Method::POST)))
})
.ok_or_else(|| {
let mut paths = Vec::new();
{
let builder = PathMismatchBuilder::default();
let builder = builder.maybe_add(
Some(&req).map(|m| &m.name).map(|s| s.as_str()),
&[
Segment::Literal("projects/"),
Segment::SingleWildcard,
Segment::Literal("/locations/"),
Segment::SingleWildcard,
Segment::Literal("/operations/"),
Segment::SingleWildcard,
],
"name",
"projects/*/locations/*/operations/*",
);
paths.push(builder.build());
}
gax::error::Error::binding(BindingError { paths })
})??;
let options = gax::options::internal::set_default_idempotency(
options,
gaxi::http::default_idempotency(&method),
);
let builder = builder.query(&[("$alt", "json;enum-encoding=int")]).header(
"x-goog-api-client",
reqwest::header::HeaderValue::from_static(&crate::info::X_GOOG_API_CLIENT_HEADER),
);
self.inner.execute(builder, Some(req), options).await.map(
|r: gax::response::Response<wkt::Empty>| {
let (parts, _) = r.into_parts();
gax::response::Response::from_parts(parts, ())
},
)
}
fn get_polling_error_policy(
&self,
options: &gax::options::RequestOptions,
) -> std::sync::Arc<dyn gax::polling_error_policy::PollingErrorPolicy> {
self.inner.get_polling_error_policy(options)
}
fn get_polling_backoff_policy(
&self,
options: &gax::options::RequestOptions,
) -> std::sync::Arc<dyn gax::polling_backoff_policy::PollingBackoffPolicy> {
self.inner.get_polling_backoff_policy(options)
}
}