Skip to content

Commit

Permalink
Validate options when using pg_backupapi mode.
Browse files Browse the repository at this point in the history
When `pg_backupapi` is enabled, we should validate if the remote ssh
command, node name and backup_id are also defined.
  • Loading branch information
gonzalemario committed Mar 7, 2023
1 parent 03c2ae1 commit 167d166
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 1 deletion.
31 changes: 31 additions & 0 deletions repmgr-action-standby.c
Original file line number Diff line number Diff line change
Expand Up @@ -7795,6 +7795,7 @@ run_pg_backupapi(t_node_info *local_node_record)
CURL *curl = curl_easy_init();
CURLcode ret;

check_pg_backupapi_standby_clone_options();

task->host = malloc(strlen(config_file_options.pg_backupapi_host)+1);
task->remote_ssh_command = malloc(strlen(config_file_options.pg_backupapi_remote_ssh_command)+1);
Expand Down Expand Up @@ -7858,6 +7859,36 @@ run_pg_backupapi(t_node_info *local_node_record)
return r;
}

/*
* pg_backupapi mode is enabled when config_file_options.pg_backupapi_host is set hence, we
* should also check the other required variables too.
*/

void check_pg_backupapi_standby_clone_options() {

bool error = false;

if (*config_file_options.pg_backupapi_remote_ssh_command == '\0') {
log_hint("Check config: remote ssh command is required");
error = true;
}
if (*config_file_options.pg_backupapi_node_name == '\0') {
log_hint("Check config: node name is required");
error = true;
}
if (*config_file_options.pg_backupapi_backup_id == '\0') {
log_hint("Check config: backup_id is required");
error = true;
}

if (error == true) {
log_error("Please fix the errors and try again");
exit(ERR_BAD_CONFIG);
}

}



static char *
make_barman_ssh_command(char *buf)
Expand Down
2 changes: 1 addition & 1 deletion repmgr-action-standby.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,6 @@ extern void do_standby_help(void);

extern bool do_standby_follow_internal(PGconn *primary_conn, PGconn *follow_target_conn, t_node_info *follow_target_node_record, PQExpBufferData *output, int general_error_code, int *error_code);


void check_pg_backupapi_standby_clone_options(void);

#endif /* _REPMGR_ACTION_STANDBY_H_ */

0 comments on commit 167d166

Please sign in to comment.