pub struct ConfigState {
    pub clusters: BTreeMap<ClusterId, Cluster>,
    pub backends: BTreeMap<ClusterId, Vec<Backend>>,
    pub http_listeners: BTreeMap<String, HttpListenerConfig>,
    pub https_listeners: BTreeMap<String, HttpsListenerConfig>,
    pub tcp_listeners: BTreeMap<String, TcpListenerConfig>,
    pub http_fronts: BTreeMap<String, HttpFrontend>,
    pub https_fronts: BTreeMap<String, HttpFrontend>,
    pub tcp_fronts: HashMap<ClusterId, Vec<TcpFrontend>>,
    pub certificates: HashMap<SocketAddr, HashMap<Fingerprint, CertificateAndKey>>,
    pub request_counts: BTreeMap<String, i32>,
}
Expand description

The ConfigState represents the state of Sōzu’s business, which is to forward traffic from frontends to backends. Hence, it contains all details about:

  • listeners (socket addresses, for TCP and HTTP connections)
  • frontends (bind to a listener)
  • backends (to forward connections to)
  • clusters (routing rules from frontends to backends)
  • TLS certificates

Fields§

§clusters: BTreeMap<ClusterId, Cluster>§backends: BTreeMap<ClusterId, Vec<Backend>>§http_listeners: BTreeMap<String, HttpListenerConfig>

socket address -> HTTP listener

§https_listeners: BTreeMap<String, HttpsListenerConfig>

socket address -> HTTPS listener

§tcp_listeners: BTreeMap<String, TcpListenerConfig>

socket address -> TCP listener

§http_fronts: BTreeMap<String, HttpFrontend>

HTTP frontends, indexed by a summary of each front’s address;hostname;path, for uniqueness. For example: "0.0.0.0:8080;lolcatho.st;P/api"

§https_fronts: BTreeMap<String, HttpFrontend>

indexed by (address, hostname, path)

§tcp_fronts: HashMap<ClusterId, Vec<TcpFrontend>>§certificates: HashMap<SocketAddr, HashMap<Fingerprint, CertificateAndKey>>§request_counts: BTreeMap<String, i32>

A census of requests that were received. Name of the request -> number of occurences

Implementations§

source§

impl ConfigState

source

pub fn new() -> Self

source

pub fn dispatch(&mut self, request: &Request) -> Result<(), StateError>

source

pub fn get_request_counts(&self) -> RequestCounts

source

pub fn generate_requests(&self) -> Vec<Request>

source

pub fn generate_activate_requests(&self) -> Vec<Request>

source

pub fn diff(&self, other: &ConfigState) -> Vec<Request>

source

pub fn hash_state(&self) -> BTreeMap<ClusterId, u64>

source

pub fn cluster_state(&self, cluster_id: &str) -> Option<ClusterInformation>

Gives details about a given cluster. Types like HttpFrontend are converted into protobuf ones, like RequestHttpFrontend

source

pub fn count_backends(&self) -> usize

source

pub fn count_frontends(&self) -> usize

source

pub fn get_cluster_ids_by_domain( &self, hostname: String, path: Option<String> ) -> HashSet<ClusterId>

source

pub fn get_certificates( &self, filters: QueryCertificatesFilters ) -> BTreeMap<String, CertificateAndKey>

source

pub fn list_frontends(&self, filters: FrontendFilters) -> ListedFrontends

source

pub fn list_listeners(&self) -> ListenersList

source

pub fn write_requests_to_file( &self, file: &mut File ) -> Result<usize, StateError>

generate requests necessary to recreate the state, write them in a JSON form in a file, separated by \n\0, returns the number of written requests

Trait Implementations§

source§

impl Clone for ConfigState

source§

fn clone(&self) -> ConfigState

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for ConfigState

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for ConfigState

source§

fn default() -> ConfigState

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for ConfigState

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl PartialEq for ConfigState

source§

fn eq(&self, other: &ConfigState) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for ConfigState

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Eq for ConfigState

source§

impl StructuralEq for ConfigState

source§

impl StructuralPartialEq for ConfigState

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32 ) -> TaggedParser<'a, Implicit, Self, E>

source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Reset for T
where T: Default + Clone,

source§

fn reset(&mut self)

source§

impl<T> Reset for T
where T: Default + Clone,

source§

fn reset(&mut self)

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,