pub struct RateLimitDescriptor {
pub entries: Vec<Entry>,
pub limit: Option<RateLimitOverride>,
}
Expand description
A RateLimitDescriptor is a list of hierarchical entries that are used by the service to determine the final rate limit key and overall allowed limit. Here are some examples of how they might be used for the domain “envoy”.
.. code-block:: cpp
[“authenticated”: “false”], [“remote_address”: “10.0.0.1”]
What it does: Limits all unauthenticated traffic for the IP address 10.0.0.1. The configuration supplies a default limit for the remote_address key. If there is a desire to raise the limit for 10.0.0.1 or block it entirely it can be specified directly in the configuration.
.. code-block:: cpp
[“authenticated”: “false”], [“path”: “/foo/bar”]
What it does: Limits all unauthenticated traffic globally for a specific path (or prefix if configured that way in the service).
.. code-block:: cpp
[“authenticated”: “false”], [“path”: “/foo/bar”], [“remote_address”: “10.0.0.1”]
What it does: Limits unauthenticated traffic to a specific path for a specific IP address. Like (1) we can raise/block specific IP addresses if we want with an override configuration.
.. code-block:: cpp
[“authenticated”: “true”], [“client_id”: “foo”]
What it does: Limits all traffic for an authenticated client “foo”
.. code-block:: cpp
[“authenticated”: “true”], [“client_id”: “foo”], [“path”: “/foo/bar”]
What it does: Limits traffic to a specific path for an authenticated client “foo”
The idea behind the API is that (1)/(2)/(3) and (4)/(5) can be sent in 1 request if desired. This enables building complex application scenarios with a generic backend.
Optionally the descriptor can contain a limit override under a “limit” key, that specifies the number of requests per unit to use instead of the number configured in the rate limiting service.
Fields§
§entries: Vec<Entry>
Descriptor entries.
limit: Option<RateLimitOverride>
Optional rate limit override to supply to the ratelimit service.
Trait Implementations§
Source§impl Clone for RateLimitDescriptor
impl Clone for RateLimitDescriptor
Source§fn clone(&self) -> RateLimitDescriptor
fn clone(&self) -> RateLimitDescriptor
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for RateLimitDescriptor
impl Debug for RateLimitDescriptor
Source§impl Default for RateLimitDescriptor
impl Default for RateLimitDescriptor
Source§impl Message for RateLimitDescriptor
impl Message for RateLimitDescriptor
Source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
Source§fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
Source§fn encode_to_vec(&self) -> Vec<u8> ⓘwhere
Self: Sized,
fn encode_to_vec(&self) -> Vec<u8> ⓘwhere
Self: Sized,
Source§fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
Source§fn encode_length_delimited_to_vec(&self) -> Vec<u8> ⓘwhere
Self: Sized,
fn encode_length_delimited_to_vec(&self) -> Vec<u8> ⓘwhere
Self: Sized,
Source§fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
Source§fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
Source§fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
. Read moreSource§fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
.Source§impl Name for RateLimitDescriptor
impl Name for RateLimitDescriptor
Source§const NAME: &'static str = "RateLimitDescriptor"
const NAME: &'static str = "RateLimitDescriptor"
Message
.
This name is the same as it appears in the source .proto file, e.g. FooBar
.Source§const PACKAGE: &'static str = "envoy.extensions.common.ratelimit.v3"
const PACKAGE: &'static str = "envoy.extensions.common.ratelimit.v3"
.
, e.g. google.protobuf
.Source§fn full_name() -> String
fn full_name() -> String
Message
.
It’s prefixed with the package name and names of any parent messages,
e.g. google.rpc.BadRequest.FieldViolation
.
By default, this is the package name followed by the message name.
Fully-qualified names must be unique within a domain of Type URLs.Source§impl PartialEq for RateLimitDescriptor
impl PartialEq for RateLimitDescriptor
impl StructuralPartialEq for RateLimitDescriptor
Auto Trait Implementations§
impl Freeze for RateLimitDescriptor
impl RefUnwindSafe for RateLimitDescriptor
impl Send for RateLimitDescriptor
impl Sync for RateLimitDescriptor
impl Unpin for RateLimitDescriptor
impl UnwindSafe for RateLimitDescriptor
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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request