pub struct RecommenderClient<T> { /* private fields */ }
Expand description

Provides insights and recommendations for cloud customers for various categories like performance optimization, cost savings, reliability, feature discovery, etc. Insights and recommendations are generated automatically based on analysis of user resources, configuration and monitoring metrics.

Implementations§

source§

impl<T> RecommenderClient<T>
where T: GrpcService<BoxBody>, T::Error: Into<StdError>, T::ResponseBody: Body<Data = Bytes> + Send + 'static, <T::ResponseBody as Body>::Error: Into<StdError> + Send,

source

pub fn new(inner: T) -> Self

source

pub fn with_origin(inner: T, origin: Uri) -> Self

source

pub fn with_interceptor<F>( inner: T, interceptor: F ) -> RecommenderClient<InterceptedService<T, F>>
where F: Interceptor, T::ResponseBody: Default, T: Service<Request<BoxBody>, Response = Response<<T as GrpcService<BoxBody>>::ResponseBody>>, <T as Service<Request<BoxBody>>>::Error: Into<StdError> + Send + Sync,

source

pub fn send_compressed(self, encoding: CompressionEncoding) -> Self

Compress requests with the given encoding.

This requires the server to support it otherwise it might respond with an error.

source

pub fn accept_compressed(self, encoding: CompressionEncoding) -> Self

Enable decompressing responses.

source

pub fn max_decoding_message_size(self, limit: usize) -> Self

Limits the maximum size of a decoded message.

Default: 4MB

source

pub fn max_encoding_message_size(self, limit: usize) -> Self

Limits the maximum size of an encoded message.

Default: usize::MAX

source

pub async fn list_insights( &mut self, request: impl IntoRequest<ListInsightsRequest> ) -> Result<Response<ListInsightsResponse>, Status>

Lists insights for the specified Cloud Resource. Requires the recommender.*.list IAM permission for the specified insight type.

source

pub async fn get_insight( &mut self, request: impl IntoRequest<GetInsightRequest> ) -> Result<Response<Insight>, Status>

Gets the requested insight. Requires the recommender.*.get IAM permission for the specified insight type.

source

pub async fn mark_insight_accepted( &mut self, request: impl IntoRequest<MarkInsightAcceptedRequest> ) -> Result<Response<Insight>, Status>

Marks the Insight State as Accepted. Users can use this method to indicate to the Recommender API that they have applied some action based on the insight. This stops the insight content from being updated.

MarkInsightAccepted can be applied to insights in ACTIVE state. Requires the recommender.*.update IAM permission for the specified insight.

source

pub async fn list_recommendations( &mut self, request: impl IntoRequest<ListRecommendationsRequest> ) -> Result<Response<ListRecommendationsResponse>, Status>

Lists recommendations for the specified Cloud Resource. Requires the recommender.*.list IAM permission for the specified recommender.

source

pub async fn get_recommendation( &mut self, request: impl IntoRequest<GetRecommendationRequest> ) -> Result<Response<Recommendation>, Status>

Gets the requested recommendation. Requires the recommender.*.get IAM permission for the specified recommender.

source

pub async fn mark_recommendation_claimed( &mut self, request: impl IntoRequest<MarkRecommendationClaimedRequest> ) -> Result<Response<Recommendation>, Status>

Marks the Recommendation State as Claimed. Users can use this method to indicate to the Recommender API that they are starting to apply the recommendation themselves. This stops the recommendation content from being updated. Associated insights are frozen and placed in the ACCEPTED state.

MarkRecommendationClaimed can be applied to recommendations in CLAIMED or ACTIVE state.

Requires the recommender.*.update IAM permission for the specified recommender.

source

pub async fn mark_recommendation_succeeded( &mut self, request: impl IntoRequest<MarkRecommendationSucceededRequest> ) -> Result<Response<Recommendation>, Status>

Marks the Recommendation State as Succeeded. Users can use this method to indicate to the Recommender API that they have applied the recommendation themselves, and the operation was successful. This stops the recommendation content from being updated. Associated insights are frozen and placed in the ACCEPTED state.

MarkRecommendationSucceeded can be applied to recommendations in ACTIVE, CLAIMED, SUCCEEDED, or FAILED state.

Requires the recommender.*.update IAM permission for the specified recommender.

source

pub async fn mark_recommendation_failed( &mut self, request: impl IntoRequest<MarkRecommendationFailedRequest> ) -> Result<Response<Recommendation>, Status>

Marks the Recommendation State as Failed. Users can use this method to indicate to the Recommender API that they have applied the recommendation themselves, and the operation failed. This stops the recommendation content from being updated. Associated insights are frozen and placed in the ACCEPTED state.

MarkRecommendationFailed can be applied to recommendations in ACTIVE, CLAIMED, SUCCEEDED, or FAILED state.

Requires the recommender.*.update IAM permission for the specified recommender.

source

pub async fn get_recommender_config( &mut self, request: impl IntoRequest<GetRecommenderConfigRequest> ) -> Result<Response<RecommenderConfig>, Status>

Gets the requested Recommender Config. There is only one instance of the config for each Recommender.

source

pub async fn update_recommender_config( &mut self, request: impl IntoRequest<UpdateRecommenderConfigRequest> ) -> Result<Response<RecommenderConfig>, Status>

Updates a Recommender Config. This will create a new revision of the config.

source

pub async fn get_insight_type_config( &mut self, request: impl IntoRequest<GetInsightTypeConfigRequest> ) -> Result<Response<InsightTypeConfig>, Status>

Gets the requested InsightTypeConfig. There is only one instance of the config for each InsightType.

source

pub async fn update_insight_type_config( &mut self, request: impl IntoRequest<UpdateInsightTypeConfigRequest> ) -> Result<Response<InsightTypeConfig>, Status>

Updates an InsightTypeConfig change. This will create a new revision of the config.

source

pub async fn list_recommenders( &mut self, request: impl IntoRequest<ListRecommendersRequest> ) -> Result<Response<ListRecommendersResponse>, Status>

Lists all available Recommenders. No IAM permissions are required.

source

pub async fn list_insight_types( &mut self, request: impl IntoRequest<ListInsightTypesRequest> ) -> Result<Response<ListInsightTypesResponse>, Status>

Lists available InsightTypes. No IAM permissions are required.

Trait Implementations§

source§

impl<T: Clone> Clone for RecommenderClient<T>

source§

fn clone(&self) -> RecommenderClient<T>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T: Debug> Debug for RecommenderClient<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<T> !Freeze for RecommenderClient<T>

§

impl<T> RefUnwindSafe for RecommenderClient<T>
where T: RefUnwindSafe,

§

impl<T> Send for RecommenderClient<T>
where T: Send,

§

impl<T> Sync for RecommenderClient<T>
where T: Sync,

§

impl<T> Unpin for RecommenderClient<T>
where T: Unpin,

§

impl<T> UnwindSafe for RecommenderClient<T>
where T: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more