use serde::{Deserialize, Serialize};
use crate::common;
use super::{AggregateKey, Filter, FlussoType};
#[derive(Debug, Clone, Hash, Serialize, Deserialize)]
pub struct Aggregate {
pub table: common::TableName,
pub op: AggregateOp,
pub key: AggregateKey,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub value_type: Option<FlussoType>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub filters: Option<Vec<Filter>>,
}
#[derive(Debug, Clone, Hash, Serialize, Deserialize)]
#[serde(rename_all = "snake_case")]
pub enum AggregateOp {
Count,
Sum(common::ColumnName),
Avg(common::ColumnName),
Min(common::ColumnName),
Max(common::ColumnName),
}