mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-20 23:07:33 +00:00
425a8b5fd5
* fix(zitadelctl): implement takedown command * fix(zitadelctl): correct destroy flow * fix(zitadelctl): correct backup commands to read crds beforehand * fix: add of destroyfile * fix: clean for userlist * fix: change backup and restore to crdb native * fix: timeout for delete pvc for cockroachdb * fix: corrected unit tests * fix: add ignored file for scale * fix: correct handling of gitops in backup command * feat: add s3 backup kind * fix: backuplist for s3 and timeout for pv deletion * fix(database): fix nil pointer with binary version * fix(database): cleanup of errors which cam with merging of the s3 logic * fix: correct unit tests * fix: cleanup monitor output Co-authored-by: Elio Bischof <eliobischof@gmail.com> * fix: backup imagepullpolixy to ifnotpresent Co-authored-by: Elio Bischof <eliobischof@gmail.com>
54 lines
1.2 KiB
Go
54 lines
1.2 KiB
Go
package backup
|
|
|
|
import (
|
|
"strconv"
|
|
"strings"
|
|
)
|
|
|
|
func getBackupCommand(
|
|
timestamp string,
|
|
bucketName string,
|
|
backupName string,
|
|
certsFolder string,
|
|
accessKeyIDPath string,
|
|
secretAccessKeyPath string,
|
|
sessionTokenPath string,
|
|
region string,
|
|
endpoint string,
|
|
dbURL string,
|
|
dbPort int32,
|
|
) string {
|
|
|
|
backupCommands := make([]string, 0)
|
|
if timestamp != "" {
|
|
backupCommands = append(backupCommands, "export "+backupNameEnv+"="+timestamp)
|
|
} else {
|
|
backupCommands = append(backupCommands, "export "+backupNameEnv+"=$(date +%Y-%m-%dT%H:%M:%SZ)")
|
|
}
|
|
|
|
parameters := []string{
|
|
"AWS_ACCESS_KEY_ID=$(cat " + accessKeyIDPath + ")",
|
|
"AWS_SECRET_ACCESS_KEY=$(cat " + secretAccessKeyPath + ")",
|
|
"AWS_SESSION_TOKEN=$(cat " + sessionTokenPath + ")",
|
|
"AWS_ENDPOINT=" + endpoint,
|
|
}
|
|
if region != "" {
|
|
parameters = append(parameters, "AWS_REGION="+region)
|
|
}
|
|
|
|
backupCommands = append(backupCommands,
|
|
strings.Join([]string{
|
|
"cockroach",
|
|
"sql",
|
|
"--certs-dir=" + certsFolder,
|
|
"--host=" + dbURL,
|
|
"--port=" + strconv.Itoa(int(dbPort)),
|
|
"-e",
|
|
"\"BACKUP TO \\\"s3://" + bucketName + "/" + backupName + "/${" + backupNameEnv + "}?" + strings.Join(parameters, "&") + "\\\";\"",
|
|
}, " ",
|
|
),
|
|
)
|
|
|
|
return strings.Join(backupCommands, " && ")
|
|
}
|