# frozen_string_literal: true # Copyright 2021 Google LLC # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # https://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # Auto-generated by gapic-generator-ruby. DO NOT EDIT! module Google module Api # Quota configuration helps to achieve fairness and budgeting in service # usage. # # The metric based quota configuration works this way: # - The service configuration defines a set of metrics. # - For API calls, the quota.metric_rules maps methods to metrics with # corresponding costs. # - The quota.limits defines limits on the metrics, which will be used for # quota checks at runtime. # # An example quota configuration in yaml format: # # quota: # limits: # # - name: apiWriteQpsPerProject # metric: library.googleapis.com/write_calls # unit: "1/min/\\{project}" # rate limit for consumer projects # values: # STANDARD: 10000 # # # # The metric rules bind all methods to the read_calls metric, # # except for the UpdateBook and DeleteBook methods. These two methods # # are mapped to the write_calls metric, with the UpdateBook method # # consuming at twice rate as the DeleteBook method. # metric_rules: # - selector: "*" # metric_costs: # library.googleapis.com/read_calls: 1 # - selector: google.example.library.v1.LibraryService.UpdateBook # metric_costs: # library.googleapis.com/write_calls: 2 # - selector: google.example.library.v1.LibraryService.DeleteBook # metric_costs: # library.googleapis.com/write_calls: 1 # # Corresponding Metric definition: # # metrics: # - name: library.googleapis.com/read_calls # display_name: Read requests # metric_kind: DELTA # value_type: INT64 # # - name: library.googleapis.com/write_calls # display_name: Write requests # metric_kind: DELTA # value_type: INT64 # @!attribute [rw] limits # @return [::Array<::Google::Api::QuotaLimit>] # List of `QuotaLimit` definitions for the service. # @!attribute [rw] metric_rules # @return [::Array<::Google::Api::MetricRule>] # List of `MetricRule` definitions, each one mapping a selected method to one # or more metrics. class Quota include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end # Bind API methods to metrics. Binding a method to a metric causes that # metric's configured quota behaviors to apply to the method call. # @!attribute [rw] selector # @return [::String] # Selects the methods to which this rule applies. # # Refer to {::Google::Api::DocumentationRule#selector selector} for syntax details. # @!attribute [rw] metric_costs # @return [::Google::Protobuf::Map{::String => ::Integer}] # Metrics to update when the selected methods are called, and the associated # cost applied to each metric. # # The key of the map is the metric name, and the values are the amount # increased for the metric against which the quota limits are defined. # The value must not be negative. class MetricRule include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # @!attribute [rw] key # @return [::String] # @!attribute [rw] value # @return [::Integer] class MetricCostsEntry include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end end # `QuotaLimit` defines a specific limit that applies over a specified duration # for a limit type. There can be at most one limit for a duration and limit # type combination defined within a `QuotaGroup`. # @!attribute [rw] name # @return [::String] # Name of the quota limit. # # The name must be provided, and it must be unique within the service. The # name can only include alphanumeric characters as well as '-'. # # The maximum length of the limit name is 64 characters. # @!attribute [rw] description # @return [::String] # Optional. User-visible, extended description for this quota limit. # Should be used only when more context is needed to understand this limit # than provided by the limit's display name (see: `display_name`). # @!attribute [rw] default_limit # @return [::Integer] # Default number of tokens that can be consumed during the specified # duration. This is the number of tokens assigned when a client # application developer activates the service for his/her project. # # Specifying a value of 0 will block all requests. This can be used if you # are provisioning quota to selected consumers and blocking others. # Similarly, a value of -1 will indicate an unlimited quota. No other # negative values are allowed. # # Used by group-based quotas only. # @!attribute [rw] max_limit # @return [::Integer] # Maximum number of tokens that can be consumed during the specified # duration. Client application developers can override the default limit up # to this maximum. If specified, this value cannot be set to a value less # than the default limit. If not specified, it is set to the default limit. # # To allow clients to apply overrides with no upper bound, set this to -1, # indicating unlimited maximum quota. # # Used by group-based quotas only. # @!attribute [rw] free_tier # @return [::Integer] # Free tier value displayed in the Developers Console for this limit. # The free tier is the number of tokens that will be subtracted from the # billed amount when billing is enabled. # This field can only be set on a limit with duration "1d", in a billable # group; it is invalid on any other limit. If this field is not set, it # defaults to 0, indicating that there is no free tier for this service. # # Used by group-based quotas only. # @!attribute [rw] duration # @return [::String] # Duration of this limit in textual notation. Must be "100s" or "1d". # # Used by group-based quotas only. # @!attribute [rw] metric # @return [::String] # The name of the metric this quota limit applies to. The quota limits with # the same metric will be checked together during runtime. The metric must be # defined within the service config. # @!attribute [rw] unit # @return [::String] # Specify the unit of the quota limit. It uses the same syntax as # [Metric.unit][]. The supported unit kinds are determined by the quota # backend system. # # Here are some examples: # * "1/min/\\{project}" for quota per minute per project. # # Note: the order of unit components is insignificant. # The "1" at the beginning is required to follow the metric unit syntax. # @!attribute [rw] values # @return [::Google::Protobuf::Map{::String => ::Integer}] # Tiered limit values. You must specify this as a key:value pair, with an # integer value that is the maximum number of requests allowed for the # specified unit. Currently only STANDARD is supported. # @!attribute [rw] display_name # @return [::String] # User-visible display name for this limit. # Optional. If not set, the UI will provide a default display name based on # the quota configuration. This field can be used to override the default # display name generated from the configuration. class QuotaLimit include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods # @!attribute [rw] key # @return [::String] # @!attribute [rw] value # @return [::Integer] class ValuesEntry include ::Google::Protobuf::MessageExts extend ::Google::Protobuf::MessageExts::ClassMethods end end end end