diff --git a/src/configuration.rs b/src/configuration.rs index 9526f8cd..907df1c8 100644 --- a/src/configuration.rs +++ b/src/configuration.rs @@ -1,10 +1,12 @@ use std::cell::OnceCell; +use std::collections::HashMap; use std::fmt::{Debug, Display, Formatter}; use std::sync::Arc; use cel_interpreter::objects::ValueType; use cel_interpreter::{Context, Expression, Value}; use cel_parser::{Atom, RelationOp}; +use prost::Message; use serde::Deserialize; use crate::attribute::Attribute; @@ -504,8 +506,16 @@ pub enum ExtensionType { #[derive(Deserialize, Debug, Clone)] #[serde(rename_all = "camelCase")] pub struct PluginConfiguration { - #[serde(rename = "rateLimitPolicies")] + pub extensions: HashMap, pub policies: Vec, +} + +#[derive(Deserialize, Debug, Clone)] +#[serde(rename_all = "camelCase")] +pub struct Extension { + #[serde(rename = "type")] + pub extension_type: ExtensionType, + pub endpoint: String, // Deny/Allow request when faced with an irrecoverable failure. pub failure_mode: FailureMode, } diff --git a/src/policy.rs b/src/policy.rs index 7b894c16..ee869ac8 100644 --- a/src/policy.rs +++ b/src/policy.rs @@ -1,5 +1,5 @@ use crate::attribute::Attribute; -use crate::configuration::{DataItem, DataType, PatternExpression}; +use crate::configuration::{DataItem, DataType, ExtensionType, PatternExpression}; use crate::envoy::{RateLimitDescriptor, RateLimitDescriptor_Entry}; use crate::filter::http_context::Filter; use log::debug; @@ -14,39 +14,29 @@ pub struct Condition { #[derive(Deserialize, Debug, Clone)] pub struct Rule { - // #[serde(default)] pub conditions: Vec, - // + pub actions: Vec, +} + +#[derive(Deserialize, Debug, Clone)] +#[serde(rename_all = "camelCase")] +pub struct Action { + pub extension: String, pub data: Vec, } #[derive(Deserialize, Debug, Clone)] #[serde(rename_all = "camelCase")] pub struct Policy { - pub name: String, - pub domain: String, - pub service: String, - pub hostnames: Vec, + pub hostname: String, pub rules: Vec, } impl Policy { #[cfg(test)] - pub fn new( - name: String, - domain: String, - service: String, - hostnames: Vec, - rules: Vec, - ) -> Self { - Policy { - name, - domain, - service, - hostnames, - rules, - } + pub fn new(hostname: String, rules: Vec) -> Self { + Policy { hostname, rules } } pub fn build_descriptors(