Struct gapi_grpc::google::api::servicecontrol::v1::QuotaOperation[][src]

pub struct QuotaOperation {
    pub operation_id: String,
    pub method_name: String,
    pub consumer_id: String,
    pub labels: HashMap<String, String>,
    pub quota_metrics: Vec<MetricValueSet>,
    pub quota_mode: i32,
}

Represents information regarding a quota operation.

Fields

operation_id: String

Identity of the operation. 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

method_name: 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

consumer_id: String

Identity of the consumer for whom this quota operation is being performed.

This can be in one of the following formats: project:<project_id>, project_number:<project_number>, api_key:<api_key>.

labels: HashMap<String, String>

Labels describing the operation.

quota_metrics: 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: i32

Quota mode for this operation.

Implementations

impl QuotaOperation[src]

pub fn quota_mode(&self) -> QuotaMode[src]

Returns the enum value of quota_mode, or the default if the field is set to an invalid enum value.

pub fn set_quota_mode(&mut self, value: QuotaMode)[src]

Sets quota_mode to the provided enum value.

Trait Implementations

impl Clone for QuotaOperation[src]

impl Debug for QuotaOperation[src]

impl Default for QuotaOperation[src]

impl Message for QuotaOperation[src]

impl PartialEq<QuotaOperation> for QuotaOperation[src]

impl StructuralPartialEq for QuotaOperation[src]

Auto Trait Implementations

impl RefUnwindSafe for QuotaOperation

impl Send for QuotaOperation

impl Sync for QuotaOperation

impl Unpin for QuotaOperation

impl UnwindSafe for QuotaOperation

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T> Instrument for T[src]

impl<T> Instrument for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> IntoRequest<T> for T[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 
[src]

impl<T> WithSubscriber for T[src]