use k8s_openapi::{
api::core::v1::ResourceRequirements,
apimachinery::pkg::{api::resource::Quantity, util::intstr::IntOrString},
};
use std::collections::BTreeMap;
use crate::{
apis::coredb_types::{Backup, ConnectionPooler, PgBouncer, S3Credentials, ServiceAccountTemplate},
cloudnativepg::poolers::{PoolerPgbouncerPoolMode, PoolerTemplateSpecContainersResources},
extensions::types::{Extension, TrunkInstall},
};
pub fn default_replicas() -> i32 {
1
}
pub fn default_resources() -> ResourceRequirements {
let limits: BTreeMap<String, Quantity> = BTreeMap::from([
("cpu".to_owned(), Quantity("2".to_string())),
("memory".to_owned(), Quantity("2Gi".to_string())),
]);
let requests: BTreeMap<String, Quantity> = BTreeMap::from([
("cpu".to_owned(), Quantity("500m".to_string())),
("memory".to_owned(), Quantity("512Mi".to_string())),
]);
ResourceRequirements {
limits: Some(limits),
requests: Some(requests),
}
}
pub fn default_postgres_exporter_enabled() -> bool {
true
}
pub fn default_uid() -> i32 {
999
}
pub fn default_port() -> i32 {
5432
}
pub fn default_image() -> String {
"quay.io/tembo/standard-cnpg:15.3.0-1-0c19c7e".to_owned()
}
pub fn default_llm_image() -> String {
"quay.io/tembo/ml-cnpg:15.3.0-1-63e32a1".to_owned()
}
pub fn default_storage() -> Quantity {
Quantity("8Gi".to_string())
}
pub fn default_sharedir_storage() -> Quantity {
Quantity("1Gi".to_string())
}
pub fn default_pkglibdir_storage() -> Quantity {
Quantity("1Gi".to_string())
}
pub fn default_postgres_exporter_image() -> String {
"quay.io/prometheuscommunity/postgres-exporter:v0.12.0".to_owned()
}
pub fn default_extensions() -> Vec<Extension> {
vec![]
}
pub fn default_trunk_installs() -> Vec<TrunkInstall> {
vec![]
}
pub fn default_database() -> String {
"postgres".to_owned()
}
pub fn default_schema() -> String {
"public".to_owned()
}
pub fn default_description() -> Option<String> {
Some("No description provided".to_owned())
}
pub fn default_stop() -> bool {
false
}
pub fn default_extensions_updating() -> bool {
false
}
pub fn default_service_account_template() -> ServiceAccountTemplate {
ServiceAccountTemplate { metadata: None }
}
pub fn default_backup() -> Backup {
Backup {
destinationPath: default_destination_path(),
encryption: default_encryption(),
retentionPolicy: default_retention_policy(),
schedule: default_backup_schedule(),
s3_credentials: default_s3_credentials(),
..Default::default()
}
}
pub fn default_destination_path() -> Option<String> {
Some("s3://".to_string())
}
pub fn default_encryption() -> Option<String> {
Some("AES256".to_owned())
}
pub fn default_retention_policy() -> Option<String> {
Some("30".to_owned())
}
pub fn default_backup_schedule() -> Option<String> {
Some("0 0 * * *".to_owned())
}
pub fn default_conn_pooler() -> ConnectionPooler {
ConnectionPooler {
enabled: default_conn_pooler_enabled(),
pooler: default_pgbouncer(),
}
}
pub fn default_conn_pooler_enabled() -> bool {
false
}
pub fn default_pool_mode() -> PoolerPgbouncerPoolMode {
PoolerPgbouncerPoolMode::Transaction
}
pub fn default_pooler_parameters() -> BTreeMap<String, String> {
BTreeMap::from([
("default_pool_size".to_string(), "50".to_string()),
("max_client_conn".to_string(), "5000".to_string()),
])
}
pub fn default_pooler_resources() -> PoolerTemplateSpecContainersResources {
PoolerTemplateSpecContainersResources {
claims: None,
limits: Some(BTreeMap::from([
("cpu".to_owned(), IntOrString::String("1".to_owned())),
("memory".to_owned(), IntOrString::String("1Gi".to_owned())),
])),
requests: Some(BTreeMap::from([
("cpu".to_owned(), IntOrString::String("500m".to_owned())),
("memory".to_owned(), IntOrString::String("512Mi".to_owned())),
])),
}
}
pub fn default_pgbouncer() -> PgBouncer {
PgBouncer {
poolMode: default_pool_mode(),
parameters: Some(default_pooler_parameters()),
resources: Some(default_pooler_resources()),
}
}
pub fn default_s3_credentials() -> Option<S3Credentials> {
Some(S3Credentials {
inherit_from_iam_role: Some(true),
..Default::default()
})
}