#[async_trait::async_trait]
pub trait AccessContextManager: std::fmt::Debug + Send + Sync {
async fn list_access_policies(
&self,
req: crate::model::ListAccessPoliciesRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListAccessPoliciesResponse>>;
async fn get_access_policy(
&self,
req: crate::model::GetAccessPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::AccessPolicy>>;
async fn create_access_policy(
&self,
req: crate::model::AccessPolicy,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn update_access_policy(
&self,
req: crate::model::UpdateAccessPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn delete_access_policy(
&self,
req: crate::model::DeleteAccessPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn list_access_levels(
&self,
req: crate::model::ListAccessLevelsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListAccessLevelsResponse>>;
async fn get_access_level(
&self,
req: crate::model::GetAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::AccessLevel>>;
async fn create_access_level(
&self,
req: crate::model::CreateAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn update_access_level(
&self,
req: crate::model::UpdateAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn delete_access_level(
&self,
req: crate::model::DeleteAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn replace_access_levels(
&self,
req: crate::model::ReplaceAccessLevelsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn list_service_perimeters(
&self,
req: crate::model::ListServicePerimetersRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListServicePerimetersResponse>>;
async fn get_service_perimeter(
&self,
req: crate::model::GetServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ServicePerimeter>>;
async fn create_service_perimeter(
&self,
req: crate::model::CreateServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn update_service_perimeter(
&self,
req: crate::model::UpdateServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn delete_service_perimeter(
&self,
req: crate::model::DeleteServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn replace_service_perimeters(
&self,
req: crate::model::ReplaceServicePerimetersRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn commit_service_perimeters(
&self,
req: crate::model::CommitServicePerimetersRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn list_gcp_user_access_bindings(
&self,
req: crate::model::ListGcpUserAccessBindingsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListGcpUserAccessBindingsResponse>>;
async fn get_gcp_user_access_binding(
&self,
req: crate::model::GetGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::GcpUserAccessBinding>>;
async fn create_gcp_user_access_binding(
&self,
req: crate::model::CreateGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn update_gcp_user_access_binding(
&self,
req: crate::model::UpdateGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn delete_gcp_user_access_binding(
&self,
req: crate::model::DeleteGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
async fn set_iam_policy(
&self,
req: google_cloud_iam_v1::model::SetIamPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_iam_v1::model::Policy>>;
async fn get_iam_policy(
&self,
req: google_cloud_iam_v1::model::GetIamPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_iam_v1::model::Policy>>;
async fn test_iam_permissions(
&self,
req: google_cloud_iam_v1::model::TestIamPermissionsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_iam_v1::model::TestIamPermissionsResponse>>;
async fn get_operation(
&self,
req: google_cloud_longrunning::model::GetOperationRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>>;
fn get_polling_error_policy(
&self,
options: &crate::RequestOptions,
) -> std::sync::Arc<dyn google_cloud_gax::polling_error_policy::PollingErrorPolicy>;
fn get_polling_backoff_policy(
&self,
options: &crate::RequestOptions,
) -> std::sync::Arc<dyn google_cloud_gax::polling_backoff_policy::PollingBackoffPolicy>;
}
#[async_trait::async_trait]
impl<T: super::AccessContextManager> AccessContextManager for T {
async fn list_access_policies(
&self,
req: crate::model::ListAccessPoliciesRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListAccessPoliciesResponse>> {
T::list_access_policies(self, req, options).await
}
async fn get_access_policy(
&self,
req: crate::model::GetAccessPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::AccessPolicy>> {
T::get_access_policy(self, req, options).await
}
async fn create_access_policy(
&self,
req: crate::model::AccessPolicy,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::create_access_policy(self, req, options).await
}
async fn update_access_policy(
&self,
req: crate::model::UpdateAccessPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::update_access_policy(self, req, options).await
}
async fn delete_access_policy(
&self,
req: crate::model::DeleteAccessPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::delete_access_policy(self, req, options).await
}
async fn list_access_levels(
&self,
req: crate::model::ListAccessLevelsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListAccessLevelsResponse>> {
T::list_access_levels(self, req, options).await
}
async fn get_access_level(
&self,
req: crate::model::GetAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::AccessLevel>> {
T::get_access_level(self, req, options).await
}
async fn create_access_level(
&self,
req: crate::model::CreateAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::create_access_level(self, req, options).await
}
async fn update_access_level(
&self,
req: crate::model::UpdateAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::update_access_level(self, req, options).await
}
async fn delete_access_level(
&self,
req: crate::model::DeleteAccessLevelRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::delete_access_level(self, req, options).await
}
async fn replace_access_levels(
&self,
req: crate::model::ReplaceAccessLevelsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::replace_access_levels(self, req, options).await
}
async fn list_service_perimeters(
&self,
req: crate::model::ListServicePerimetersRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListServicePerimetersResponse>> {
T::list_service_perimeters(self, req, options).await
}
async fn get_service_perimeter(
&self,
req: crate::model::GetServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ServicePerimeter>> {
T::get_service_perimeter(self, req, options).await
}
async fn create_service_perimeter(
&self,
req: crate::model::CreateServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::create_service_perimeter(self, req, options).await
}
async fn update_service_perimeter(
&self,
req: crate::model::UpdateServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::update_service_perimeter(self, req, options).await
}
async fn delete_service_perimeter(
&self,
req: crate::model::DeleteServicePerimeterRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::delete_service_perimeter(self, req, options).await
}
async fn replace_service_perimeters(
&self,
req: crate::model::ReplaceServicePerimetersRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::replace_service_perimeters(self, req, options).await
}
async fn commit_service_perimeters(
&self,
req: crate::model::CommitServicePerimetersRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::commit_service_perimeters(self, req, options).await
}
async fn list_gcp_user_access_bindings(
&self,
req: crate::model::ListGcpUserAccessBindingsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::ListGcpUserAccessBindingsResponse>> {
T::list_gcp_user_access_bindings(self, req, options).await
}
async fn get_gcp_user_access_binding(
&self,
req: crate::model::GetGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<crate::model::GcpUserAccessBinding>> {
T::get_gcp_user_access_binding(self, req, options).await
}
async fn create_gcp_user_access_binding(
&self,
req: crate::model::CreateGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::create_gcp_user_access_binding(self, req, options).await
}
async fn update_gcp_user_access_binding(
&self,
req: crate::model::UpdateGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::update_gcp_user_access_binding(self, req, options).await
}
async fn delete_gcp_user_access_binding(
&self,
req: crate::model::DeleteGcpUserAccessBindingRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::delete_gcp_user_access_binding(self, req, options).await
}
async fn set_iam_policy(
&self,
req: google_cloud_iam_v1::model::SetIamPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_iam_v1::model::Policy>> {
T::set_iam_policy(self, req, options).await
}
async fn get_iam_policy(
&self,
req: google_cloud_iam_v1::model::GetIamPolicyRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_iam_v1::model::Policy>> {
T::get_iam_policy(self, req, options).await
}
async fn test_iam_permissions(
&self,
req: google_cloud_iam_v1::model::TestIamPermissionsRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_iam_v1::model::TestIamPermissionsResponse>>
{
T::test_iam_permissions(self, req, options).await
}
async fn get_operation(
&self,
req: google_cloud_longrunning::model::GetOperationRequest,
options: crate::RequestOptions,
) -> crate::Result<crate::Response<google_cloud_longrunning::model::Operation>> {
T::get_operation(self, req, options).await
}
fn get_polling_error_policy(
&self,
options: &crate::RequestOptions,
) -> std::sync::Arc<dyn google_cloud_gax::polling_error_policy::PollingErrorPolicy> {
T::get_polling_error_policy(self, options)
}
fn get_polling_backoff_policy(
&self,
options: &crate::RequestOptions,
) -> std::sync::Arc<dyn google_cloud_gax::polling_backoff_policy::PollingBackoffPolicy> {
T::get_polling_backoff_policy(self, options)
}
}