use serde::{Deserialize, Serialize};
use crate::{Field, common};
use super::Filter;
#[derive(Debug, Clone, Hash, Serialize, Deserialize)]
pub struct Join {
pub table: common::TableName,
pub kind: JoinKind,
pub primary_key: common::ColumnName,
#[serde(default)]
pub nullable: bool,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub filters: Option<Vec<Filter>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub order_by: Option<Vec<OrderBy>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub limit: Option<u64>,
pub fields: Vec<Field>,
}
#[derive(Debug, Clone, Hash, Serialize, Deserialize)]
#[serde(rename_all = "snake_case")]
pub enum JoinKind {
BelongsTo { column: common::ColumnName },
HasOne { foreign_key: common::ColumnName },
HasMany { foreign_key: common::ColumnName },
ManyToMany { through: Through },
}
impl JoinKind {
pub fn is_to_many(&self) -> bool {
matches!(self, JoinKind::HasMany { .. } | JoinKind::ManyToMany { .. })
}
}
#[derive(Debug, Clone, Hash, Serialize, Deserialize)]
#[serde(rename_all = "snake_case")]
pub enum AggregateKey {
Direct(common::ColumnName),
Through(Through),
}
#[derive(Debug, Clone, Hash, Serialize, Deserialize)]
pub struct Through {
pub table: common::TableName,
pub left_key: common::ColumnName,
pub right_key: common::ColumnName,
}
#[derive(Debug, Clone, Hash, Serialize, Deserialize)]
pub struct OrderBy {
pub column: common::ColumnName,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub direction: Option<Direction>,
}
#[derive(Debug, Clone, Copy, Hash, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "snake_case")]
pub enum Direction {
Asc,
Desc,
}