mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-05 14:37:45 +00:00
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, " && ")
|
||
|
}
|