From 194e34d4e1b28957d8310ea1205989fadb1b44c7 Mon Sep 17 00:00:00 2001 From: Quentin Dufour Date: Wed, 22 May 2024 10:05:52 +0200 Subject: first full filter implementation --- aero-proto/src/dav/controller.rs | 55 +++++++++++++++++++++++++++------------- 1 file changed, 38 insertions(+), 17 deletions(-) (limited to 'aero-proto/src') diff --git a/aero-proto/src/dav/controller.rs b/aero-proto/src/dav/controller.rs index a1c2660..e5a1cff 100644 --- a/aero-proto/src/dav/controller.rs +++ b/aero-proto/src/dav/controller.rs @@ -353,25 +353,31 @@ fn apply_filter<'a>( }; // Do checks - //@FIXME VCalendar root component is hardcoded let root_filter = &filter.0; - if root_filter.name != cal::Component::VCalendar { - return None; - } - - let matcher = match &root_filter.additional_rules { - None => return Some(Ok(single_node)), - Some(cal::CompFilterRules::IsNotDefined) => return None, - Some(cal::CompFilterRules::Matches(m)) => m, - }; - let is_keep = ics + // Find the component in the filter + let maybe_comp = ics .components .iter() - .any(|single_comp| is_component_match(single_comp, matcher)); + .find(|candidate| candidate.name.as_str() == root_filter.name.as_str()); + + // Apply additional rules + let is_keep = match (maybe_comp, &root_filter.additional_rules) { + (Some(_), None) => true, + (None, Some(cal::CompFilterRules::IsNotDefined)) => true, + (None, None) => false, + (None, Some(cal::CompFilterRules::Matches(_))) => false, + (Some(_), Some(cal::CompFilterRules::IsNotDefined)) => false, + (Some(inner_comp), Some(cal::CompFilterRules::Matches(filter))) => { + is_component_match(inner_comp, filter) + } + }; - // Object has been kept - Some(Ok(single_node)) + // Adjust return value according to filter + match is_keep { + true => Some(Ok(single_node)), + _ => None, + } }) } @@ -499,8 +505,23 @@ fn is_component_match( return false; } - //component.components.iter().any - matcher.comp_filter.iter().any(|single_comp_filter| { - true //@TODO find component, find + matcher.comp_filter.iter().all(|single_comp_filter| { + // Find the component + let maybe_comp = component + .components + .iter() + .find(|candidate| candidate.name.as_str() == single_comp_filter.name.as_str()); + + // Filter according to rules + match (maybe_comp, &single_comp_filter.additional_rules) { + (Some(_), None) => true, + (None, Some(cal::CompFilterRules::IsNotDefined)) => true, + (None, None) => false, + (Some(_), Some(cal::CompFilterRules::IsNotDefined)) => false, + (None, Some(cal::CompFilterRules::Matches(_))) => false, + (Some(inner_comp), Some(cal::CompFilterRules::Matches(comp_match))) => { + is_component_match(inner_comp, comp_match) + } + } }) } -- cgit v1.2.3