use crate::{
apis::postgres_parameters::PgConfig,
defaults::default_image,
extensions::types::{Extension, TrunkInstall},
postgres_exporter::QueryConfig,
stacks::config_engines::{olap_config_engine, standard_config_engine, ConfigEngine},
};
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
use utoipa::ToSchema;
#[derive(Clone, Debug, Default, Serialize, Deserialize, JsonSchema, PartialEq, ToSchema)]
pub enum StackType {
Standard,
MessageQueue,
MachineLearning,
OLAP,
#[default]
OLTP,
}
impl std::str::FromStr for StackType {
type Err = &'static str;
fn from_str(value: &str) -> Result<Self, Self::Err> {
match value {
"CoreDB" => Ok(StackType::Standard),
"Standard" => Ok(StackType::Standard),
"MessageQueue" => Ok(StackType::MessageQueue),
"MachineLearning" => Ok(StackType::MachineLearning),
"OLAP" => Ok(StackType::OLAP),
"OLTP" => Ok(StackType::OLTP),
_ => Err("invalid value"),
}
}
}
impl StackType {
pub fn as_str(&self) -> &str {
match self {
StackType::Standard => "Standard",
StackType::MessageQueue => "MessageQueue",
StackType::MachineLearning => "MachineLearning",
StackType::OLAP => "OLAP",
StackType::OLTP => "OLTP",
}
}
}
#[derive(Clone, Debug, Default, Serialize, Deserialize, JsonSchema, PartialEq, ToSchema)]
pub struct Stack {
pub name: String,
pub compute_templates: Option<Vec<ComputeTemplate>>,
pub description: Option<String>,
#[serde(default = "default_stack_image")]
pub image: Option<String>,
pub stack_version: Option<String>,
pub trunk_installs: Option<Vec<TrunkInstall>>,
pub extensions: Option<Vec<Extension>>,
pub postgres_metrics: Option<QueryConfig>,
pub postgres_config: Option<Vec<PgConfig>>,
#[serde(default = "default_config_engine")]
pub postgres_config_engine: Option<ConfigEngine>,
pub infrastructure: Option<Infrastructure>,
}
impl Stack {
pub fn runtime_config(&self) -> Option<Vec<PgConfig>> {
match &self.postgres_config_engine {
Some(ConfigEngine::Standard) => Some(standard_config_engine(self)),
Some(ConfigEngine::OLAP) => Some(olap_config_engine(self)),
None => Some(standard_config_engine(self)),
}
}
}
fn default_stack_image() -> Option<String> {
Some(default_image())
}
fn default_config_engine() -> Option<ConfigEngine> {
Some(ConfigEngine::Standard)
}
#[derive(Clone, Debug, Default, Serialize, Deserialize, JsonSchema, PartialEq, ToSchema)]
pub struct Infrastructure {
#[serde(default = "default_cpu")]
pub cpu: String,
#[serde(default = "default_memory")]
pub memory: String,
#[serde(default = "default_storage")]
pub storage: String,
}
fn default_cpu() -> String {
"1".to_owned()
}
fn default_memory() -> String {
"1Gi".to_owned()
}
fn default_storage() -> String {
"10Gi".to_owned()
}
#[derive(Clone, Debug, Serialize, Deserialize, ToSchema, JsonSchema, PartialEq)]
pub struct ComputeTemplate {
pub cpu: String,
pub memory: String,
}
#[cfg(test)]
mod tests {
use crate::stacks::{get_stack, types::Infrastructure, StackType};
#[test]
fn test_stacks_definitions() {
let mut mq = get_stack(StackType::MessageQueue);
let infra = Infrastructure {
cpu: "1".to_string(),
memory: "1Gi".to_string(),
storage: "10Gi".to_string(),
};
mq.infrastructure = Some(infra);
let runtime_configs = mq.runtime_config().expect("expected configs");
assert_eq!(runtime_configs[0].name, "shared_buffers");
assert_eq!(runtime_configs[0].value.to_string(), "256MB");
assert_eq!(runtime_configs[1].name, "max_connections");
assert_eq!(runtime_configs[1].value.to_string(), "107");
assert!(mq.postgres_metrics.is_some());
assert!(mq.postgres_config.is_some());
let mq_metrics = mq.postgres_metrics.unwrap();
assert_eq!(mq_metrics.queries.len(), 1);
assert!(mq_metrics.queries.contains_key("pgmq"));
assert!(mq_metrics.queries["pgmq"].master);
assert_eq!(mq_metrics.queries["pgmq"].metrics.len(), 5);
let mut std = get_stack(StackType::Standard);
let infra = Infrastructure {
cpu: "1".to_string(),
memory: "2Gi".to_string(),
storage: "10Gi".to_string(),
};
std.infrastructure = Some(infra);
println!("STD: {:#?}", std);
let runtime_configs = std.runtime_config().expect("expected configs");
assert_eq!(runtime_configs[0].name, "shared_buffers");
assert_eq!(runtime_configs[0].value.to_string(), "512MB");
}
}