pub struct AggregateNode { /* private fields */ }Expand description
Aggregate node - numeric aggregation.
Performs aggregation operations on numeric values from:
- An array field (aggregates all elements)
- Multiple specified fields (aggregates their values)
§Ports
- Input: “in” - Source data with numeric values
- Output: “out” - Object with aggregation result
- Output: “error” - Emitted on errors
§Example Configuration
nodes:
calculate_total:
type: std::aggregate
config:
operation: sum
source: $.items[*].price # Array field
output_field: total
inputs:
- from: cart.out -> in
outputs:
out: -> checkout.inImplementations§
Source§impl AggregateNode
impl AggregateNode
Sourcepub fn array(
array_path: impl Into<String>,
operation: AggregateOperation,
output_field: impl Into<String>,
) -> Self
pub fn array( array_path: impl Into<String>, operation: AggregateOperation, output_field: impl Into<String>, ) -> Self
Create an aggregate node that operates on an array field.
Sourcepub fn array_field(
array_path: impl Into<String>,
value_field: impl Into<String>,
operation: AggregateOperation,
output_field: impl Into<String>,
) -> Self
pub fn array_field( array_path: impl Into<String>, value_field: impl Into<String>, operation: AggregateOperation, output_field: impl Into<String>, ) -> Self
Create an aggregate node that operates on an array of objects, extracting a specific field from each.
Sourcepub fn fields(
fields: Vec<String>,
operation: AggregateOperation,
output_field: impl Into<String>,
) -> Self
pub fn fields( fields: Vec<String>, operation: AggregateOperation, output_field: impl Into<String>, ) -> Self
Create an aggregate node that operates on multiple fields.
Sourcepub fn sum(
array_path: impl Into<String>,
output_field: impl Into<String>,
) -> Self
pub fn sum( array_path: impl Into<String>, output_field: impl Into<String>, ) -> Self
Create a sum aggregation over an array.
Trait Implementations§
Source§impl Debug for AggregateNode
impl Debug for AggregateNode
Auto Trait Implementations§
impl Freeze for AggregateNode
impl RefUnwindSafe for AggregateNode
impl Send for AggregateNode
impl Sync for AggregateNode
impl Unpin for AggregateNode
impl UnwindSafe for AggregateNode
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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
Mutably borrows from an owned value. Read more
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.