Line data Source code
1 : //! Postgres client connection code common to other crates (safekeeper and
2 : //! pageserver) which depends on tenant/timeline ids and thus not fitting into
3 : //! postgres_connection crate.
4 :
5 : use anyhow::Context;
6 : use postgres_connection::{parse_host_port, PgConnectionConfig};
7 :
8 : use crate::id::TenantTimelineId;
9 :
10 : /// Create client config for fetching WAL from safekeeper on particular timeline.
11 : /// listen_pg_addr_str is in form host:\[port\].
12 1082728 : pub fn wal_stream_connection_config(
13 1082728 : TenantTimelineId {
14 1082728 : tenant_id,
15 1082728 : timeline_id,
16 1082728 : }: TenantTimelineId,
17 1082728 : listen_pg_addr_str: &str,
18 1082728 : auth_token: Option<&str>,
19 1082728 : availability_zone: Option<&str>,
20 1082728 : ) -> anyhow::Result<PgConnectionConfig> {
21 1082728 : let (host, port) =
22 1082728 : parse_host_port(listen_pg_addr_str).context("Unable to parse listen_pg_addr_str")?;
23 1082728 : let port = port.unwrap_or(5432);
24 1082728 : let mut connstr = PgConnectionConfig::new_host_port(host, port)
25 1082728 : .extend_options([
26 1082728 : "-c".to_owned(),
27 1082728 : format!("timeline_id={}", timeline_id),
28 1082728 : format!("tenant_id={}", tenant_id),
29 1082728 : ])
30 1082728 : .set_password(auth_token.map(|s| s.to_owned()));
31 :
32 1082728 : if let Some(availability_zone) = availability_zone {
33 780 : connstr = connstr.extend_options([format!("availability_zone={}", availability_zone)]);
34 1081948 : }
35 :
36 1082728 : Ok(connstr)
37 1082728 : }
|