mirror of
https://github.com/EnterpriseDB/repmgr.git
synced 2026-03-28 01:16:29 +00:00
"standby clone": ensure replication user is used when conninfo str provided
This commit is contained in:
38
dbutils.c
38
dbutils.c
@@ -434,6 +434,44 @@ conn_to_param_list(PGconn *conn, t_conninfo_param_list *param_list)
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Converts param list to string; caller must free returned pointer
|
||||
*/
|
||||
char *
|
||||
param_list_to_string(t_conninfo_param_list *param_list)
|
||||
{
|
||||
int c;
|
||||
PQExpBufferData conninfo_buf;
|
||||
char *conninfo_str;
|
||||
int len;
|
||||
|
||||
initPQExpBuffer(&conninfo_buf);
|
||||
|
||||
for (c = 0; c < param_list->size && param_list->keywords[c] != NULL; c++)
|
||||
{
|
||||
if (param_list->values[c] != NULL && param_list->values[c][0] != '\0')
|
||||
{
|
||||
if (c > 0)
|
||||
appendPQExpBufferChar(&conninfo_buf, ' ');
|
||||
|
||||
appendPQExpBuffer(&conninfo_buf,
|
||||
"%s=%s",
|
||||
param_list->keywords[c],
|
||||
param_list->values[c]);
|
||||
}
|
||||
}
|
||||
|
||||
len = strlen(conninfo_buf.data) + 1;
|
||||
conninfo_str = pg_malloc0(len);
|
||||
|
||||
strncpy(conninfo_str, conninfo_buf.data, len);
|
||||
|
||||
termPQExpBuffer(&conninfo_buf);
|
||||
|
||||
return conninfo_str;
|
||||
}
|
||||
|
||||
|
||||
/* ===================== */
|
||||
/* transaction functions */
|
||||
/* ===================== */
|
||||
|
||||
@@ -143,6 +143,7 @@ void conn_to_param_list(PGconn *conn, t_conninfo_param_list *param_list);
|
||||
void param_set(t_conninfo_param_list *param_list, const char *param, const char *value);
|
||||
char *param_get(t_conninfo_param_list *param_list, const char *param);
|
||||
bool parse_conninfo_string(const char *conninfo_str, t_conninfo_param_list *param_list, char *errmsg, bool ignore_application_name);
|
||||
char *param_list_to_string(t_conninfo_param_list *param_list);
|
||||
|
||||
/* transaction functions */
|
||||
bool begin_transaction(PGconn *conn);
|
||||
|
||||
@@ -1100,8 +1100,22 @@ run_basebackup(void)
|
||||
*/
|
||||
if (runtime_options.conninfo_provided == true)
|
||||
{
|
||||
// XXX need to override user with runtime_options.replication_user!
|
||||
appendPQExpBuffer(¶ms, " -d '%s'", runtime_options.dbname);
|
||||
t_conninfo_param_list conninfo;
|
||||
char *conninfo_str;
|
||||
|
||||
initialize_conninfo_params(&conninfo, false);
|
||||
|
||||
/* string will already have been parsed */
|
||||
(void) parse_conninfo_string(runtime_options.dbname, &conninfo, NULL, false);
|
||||
|
||||
if (*runtime_options.replication_user)
|
||||
param_set(&conninfo, "user", runtime_options.replication_user);
|
||||
|
||||
conninfo_str = param_list_to_string(&conninfo);
|
||||
|
||||
appendPQExpBuffer(¶ms, " -d '%s'", conninfo_str);
|
||||
|
||||
pfree(conninfo_str);
|
||||
}
|
||||
|
||||
/*
|
||||
|
||||
Reference in New Issue
Block a user