cookiev3

package
v1.36.3-20231211223035... Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: unknown License: Apache-2.0 Imports: 6 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var File_envoy_extensions_http_stateful_session_cookie_v3_cookie_proto protoreflect.FileDescriptor

Functions

This section is empty.

Types

type CookieBasedSessionState

type CookieBasedSessionState struct {

	// The cookie configuration used to track session state.
	Cookie *v3.Cookie `protobuf:"bytes,1,opt,name=cookie,proto3" json:"cookie,omitempty"`
	// contains filtered or unexported fields
}

This extension allows the session state to be tracked via cookies.

This extension first encodes the address of the upstream host selected by the load balancer into a “set-cookie“ response header with the :ref:`cookie configuration <envoy_v3_api_field_extensions.http.stateful_session.cookie.v3.CookieBasedSessionState.cookie>`. when new requests are incoming, this extension will try to parse the specific upstream host address by the cookie name. If the address parsed from the cookie corresponds to a valid upstream host, this upstream host will be selected first. See :ref:`stateful session filter <envoy_v3_api_msg_extensions.filters.http.stateful_session.v3.StatefulSession>`.

For example, if the cookie name is set to “sticky-host“, envoy will prefer “1.2.3.4:80“ as the upstream host when the request contains the following header:

.. code-block:: none

cookie: sticky-host="MS4yLjMuNDo4MA=="

When processing the upstream response, if “1.2.3.4:80“ is indeed the final choice the extension does nothing. If “1.2.3.4:80“ is not the final choice, the new selected host will be used to update the cookie (via the “set-cookie“ response header).

[#extension: envoy.http.stateful_session.cookie]

func (*CookieBasedSessionState) ClearCookie

func (x *CookieBasedSessionState) ClearCookie()

func (*CookieBasedSessionState) GetCookie

func (x *CookieBasedSessionState) GetCookie() *v3.Cookie

func (*CookieBasedSessionState) HasCookie

func (x *CookieBasedSessionState) HasCookie() bool

func (*CookieBasedSessionState) ProtoMessage

func (*CookieBasedSessionState) ProtoMessage()

func (*CookieBasedSessionState) ProtoReflect

func (x *CookieBasedSessionState) ProtoReflect() protoreflect.Message

func (*CookieBasedSessionState) Reset

func (x *CookieBasedSessionState) Reset()

func (*CookieBasedSessionState) SetCookie

func (x *CookieBasedSessionState) SetCookie(v *v3.Cookie)

func (*CookieBasedSessionState) String

func (x *CookieBasedSessionState) String() string

type CookieBasedSessionState_builder

type CookieBasedSessionState_builder struct {

	// The cookie configuration used to track session state.
	Cookie *v3.Cookie
	// contains filtered or unexported fields
}

func (CookieBasedSessionState_builder) Build

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL