pub struct QuotaOperation {
pub consumer_id: Option<String>,
pub labels: Option<HashMap<String, String>>,
pub method_name: Option<String>,
pub operation_id: Option<String>,
pub quota_metrics: Option<Vec<MetricValueSet>>,
pub quota_mode: Option<String>,
}Expand description
Represents information regarding a quota operation.
This type is not used in any activity, and only used as part of another schema.
Fields§
§consumer_id: Option<String>Identity of the consumer for whom this quota operation is being performed. This can be in one of the following formats: project:, project_number:, api_key:.
labels: Option<HashMap<String, String>>Labels describing the operation.
method_name: Option<String>Fully qualified name of the API method for which this quota operation is requested. This name is used for matching quota rules or metric rules and billing status rules defined in service configuration. This field should not be set if any of the following is true: (1) the quota operation is performed on non-API resources. (2) quota_metrics is set because the caller is doing quota override. Example of an RPC method name: google.example.library.v1.LibraryService.CreateShelf
operation_id: Option<String>Identity of the operation. For Allocation Quota, this is expected to be unique within the scope of the service that generated the operation, and guarantees idempotency in case of retries. In order to ensure best performance and latency in the Quota backends, operation_ids are optimally associated with time, so that related operations can be accessed fast in storage. For this reason, the recommended token for services that intend to operate at a high QPS is Unix time in nanos + UUID
quota_metrics: Option<Vec<MetricValueSet>>Represents information about this operation. Each MetricValueSet corresponds to a metric defined in the service configuration. The data type used in the MetricValueSet must agree with the data type specified in the metric definition. Within a single operation, it is not allowed to have more than one MetricValue instances that have the same metric names and identical label value combinations. If a request has such duplicated MetricValue instances, the entire request is rejected with an invalid argument error. This field is mutually exclusive with method_name.
quota_mode: Option<String>Quota mode for this operation.
Trait Implementations§
Source§impl Clone for QuotaOperation
impl Clone for QuotaOperation
Source§fn clone(&self) -> QuotaOperation
fn clone(&self) -> QuotaOperation
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for QuotaOperation
impl Debug for QuotaOperation
Source§impl Default for QuotaOperation
impl Default for QuotaOperation
Source§fn default() -> QuotaOperation
fn default() -> QuotaOperation
Source§impl<'de> Deserialize<'de> for QuotaOperation
impl<'de> Deserialize<'de> for QuotaOperation
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl Serialize for QuotaOperation
impl Serialize for QuotaOperation
impl Part for QuotaOperation
Auto Trait Implementations§
impl Freeze for QuotaOperation
impl RefUnwindSafe for QuotaOperation
impl Send for QuotaOperation
impl Sync for QuotaOperation
impl Unpin for QuotaOperation
impl UnwindSafe for QuotaOperation
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more