supabase_management_rs/
postgres_configs.rs1use serde::{Deserialize, Serialize};
2
3#[derive(Debug, Clone, Deserialize, Serialize, Default)]
14pub struct PostgresConfig {
15 #[serde(skip_serializing_if = "Option::is_none")]
16 pub effective_cache_size: Option<String>,
17 #[serde(skip_serializing_if = "Option::is_none")]
18 pub logical_decoding_work_mem: Option<String>,
19 #[serde(skip_serializing_if = "Option::is_none")]
20 pub maintenance_work_mem: Option<String>,
21 #[serde(skip_serializing_if = "Option::is_none")]
22 pub track_activity_query_size: Option<String>,
23 #[serde(skip_serializing_if = "Option::is_none")]
24 pub max_connections: Option<i32>,
25 #[serde(skip_serializing_if = "Option::is_none")]
26 pub max_locks_per_transaction: Option<i32>,
27 #[serde(skip_serializing_if = "Option::is_none")]
28 pub max_parallel_maintenance_workers: Option<i32>,
29 #[serde(skip_serializing_if = "Option::is_none")]
30 pub max_parallel_workers: Option<i32>,
31 #[serde(skip_serializing_if = "Option::is_none")]
32 pub max_parallel_workers_per_gather: Option<i32>,
33 #[serde(skip_serializing_if = "Option::is_none")]
34 pub max_replication_slots: Option<i32>,
35 #[serde(skip_serializing_if = "Option::is_none")]
36 pub max_slot_wal_keep_size: Option<String>,
37 #[serde(skip_serializing_if = "Option::is_none")]
38 pub max_standby_archive_delay: Option<String>,
39 #[serde(skip_serializing_if = "Option::is_none")]
40 pub max_standby_streaming_delay: Option<String>,
41 #[serde(skip_serializing_if = "Option::is_none")]
42 pub max_wal_size: Option<String>,
43 #[serde(skip_serializing_if = "Option::is_none")]
44 pub max_wal_senders: Option<i32>,
45 #[serde(skip_serializing_if = "Option::is_none")]
46 pub max_worker_processes: Option<i32>,
47 #[serde(skip_serializing_if = "Option::is_none")]
48 pub shared_buffers: Option<String>,
49 #[serde(skip_serializing_if = "Option::is_none")]
50 pub statement_timeout: Option<String>,
51 #[serde(skip_serializing_if = "Option::is_none")]
52 pub track_commit_timestamp: Option<bool>,
53 #[serde(skip_serializing_if = "Option::is_none")]
54 pub wal_keep_size: Option<String>,
55 #[serde(skip_serializing_if = "Option::is_none")]
56 pub wal_sender_timeout: Option<String>,
57 #[serde(skip_serializing_if = "Option::is_none")]
58 pub work_mem: Option<String>,
59 #[serde(skip_serializing_if = "Option::is_none")]
60 pub session_replication_role: Option<SessionReplicationRole>,
61}
62
63#[derive(Debug, Clone, Deserialize, Serialize)]
64#[serde(rename_all = "lowercase")]
65pub enum SessionReplicationRole {
66 Origin,
67 Replica,
68 Local,
69}
70
71impl crate::Client {
72 pub async fn get_postgres_config(
74 &self,
75 project_id: &str,
76 ) -> Result<PostgresConfig, crate::Error> {
77 self.get(format_args!(
78 "projects/{project_id}/config/database/postgres"
79 ))
80 .await
81 }
82
83 pub async fn set_postgres_config(
84 &self,
85 project_id: &str,
86 config: &PostgresConfig,
87 ) -> Result<PostgresConfig, crate::Error> {
88 self.put(
89 format_args!("projects/{project_id}/config/database/postgres"),
90 Some(config),
91 )
92 .await
93 }
94}
95
96#[cfg(test)]
97mod tests {
98 use super::PostgresConfig;
99
100 #[test]
101 fn deserializes_pg_config() {
102 let json_data = r#"
103 {
104 "effective_cache_size": "4GB",
105 "logical_decoding_work_mem": "64MB",
106 "maintenance_work_mem": "256MB",
107 "track_activity_query_size": "2048",
108 "max_connections": 100,
109 "max_locks_per_transaction": 128,
110 "max_parallel_maintenance_workers": 2,
111 "max_parallel_workers": 4,
112 "max_parallel_workers_per_gather": 2,
113 "max_replication_slots": 10,
114 "max_slot_wal_keep_size": "1GB",
115 "max_standby_archive_delay": "30s",
116 "max_standby_streaming_delay": "30s",
117 "max_wal_size": "2GB",
118 "max_wal_senders": 5,
119 "max_worker_processes": 8,
120 "shared_buffers": "2GB",
121 "statement_timeout": "60s",
122 "track_commit_timestamp": true,
123 "wal_keep_size": "512MB",
124 "wal_sender_timeout": "60s",
125 "work_mem": "4MB",
126 "session_replication_role": "replica"
127 }
128 "#;
129
130 let _config: PostgresConfig =
131 serde_json::from_str(json_data).expect("JSON was not well-formatted");
132 }
133}