From a079c76ec47d5684848e69f04fff0dc947ef31e8 Mon Sep 17 00:00:00 2001 From: Abu Sayed <82162518+sayedppqq@users.noreply.github.com> Date: Thu, 12 Sep 2024 12:40:11 +0600 Subject: [PATCH] Fix --oplog and --db arguments error (#2173) /cherry-pick Signed-off-by: sayedppqq Signed-off-by: Tamal Saha --- pkg/backup.go | 13 +++++-------- pkg/restore.go | 13 +++++-------- pkg/utils.go | 14 ++++++++------ 3 files changed, 18 insertions(+), 22 deletions(-) diff --git a/pkg/backup.go b/pkg/backup.go index 8115e6042..8fc41e234 100644 --- a/pkg/backup.go +++ b/pkg/backup.go @@ -443,13 +443,7 @@ func (opt *mongoOptions) backupMongoDB(targetRef api_v1beta1.TargetRef) (*restic fmt.Sprintf("--sslPEMKeyFile=%s", getOptionValue(dumpCreds, "--sslPEMKeyFile"))) } - var userArgs []string - for _, arg := range strings.Fields(opt.mongoArgs) { - // illegal argument combination: cannot specify --db and --uri - if !strings.Contains(arg, "--db") { - userArgs = append(userArgs, arg) - } - } + userArgs := strings.Fields(opt.mongoArgs) if !isStandalone { // - port is already added in mongoDSN with replicasetName/host:port format. @@ -468,7 +462,10 @@ func (opt *mongoOptions) backupMongoDB(targetRef api_v1beta1.TargetRef) (*restic } for _, arg := range userArgs { - backupCmd.Args = append(backupCmd.Args, arg) + // illegal argument combination: cannot specify --db and --uri + if !strings.Contains(arg, "--db") { + backupCmd.Args = append(backupCmd.Args, arg) + } } // append the backup command into the pipe diff --git a/pkg/restore.go b/pkg/restore.go index 7487c72c2..7bde96670 100644 --- a/pkg/restore.go +++ b/pkg/restore.go @@ -364,13 +364,7 @@ func (opt *mongoOptions) restoreMongoDB(targetRef api_v1beta1.TargetRef) (*resti fmt.Sprintf("--sslPEMKeyFile=%s", getOptionValue(dumpCreds, "--sslPEMKeyFile"))) } - var userArgs []string - for _, arg := range strings.Fields(opt.mongoArgs) { - // illegal argument combination: cannot specify --db and --uri - if !strings.Contains(arg, "--db") { - userArgs = append(userArgs, arg) - } - } + userArgs := strings.Fields(opt.mongoArgs) if !isStandalone { // - port is already added in mongoDSN with replicasetName/host:port format. @@ -393,7 +387,10 @@ func (opt *mongoOptions) restoreMongoDB(targetRef api_v1beta1.TargetRef) (*resti } for _, arg := range userArgs { - restoreCmd.Args = append(restoreCmd.Args, arg) + // illegal argument combination: cannot specify --db and --uri + if !strings.Contains(arg, "--db") { + restoreCmd.Args = append(restoreCmd.Args, arg) + } } // add the restore command to the pipeline diff --git a/pkg/utils.go b/pkg/utils.go index 16ae85121..f60e0bb99 100644 --- a/pkg/utils.go +++ b/pkg/utils.go @@ -175,21 +175,23 @@ func (opt *mongoOptions) buildMongoURI(mongoDSN string, port int32, isStandalone // remove "shard0/" prefix from shard0/simple-shard0-0.simple-shard0-pods.demo.svc:27017,simple-shard0-1.simple-shard0-pods.demo.svc:27017 func extractHost(host string) string { index := strings.Index(host, "/") - if index != -1 { + if index != -1 && index+1 < len(host) { host = host[index+1:] } + if index+1 >= len(host) { + host = "" + } return host } func getBackupDB(mongoArgs string) string { - backupdb := "" // full - if strings.Contains(mongoArgs, "--db") { + if strings.Contains(mongoArgs, "--db=") { args := strings.Fields(mongoArgs) for _, arg := range args { - if strings.Contains(arg, "--db") { - backupdb = strings.Split(arg, "=")[1] + if strings.HasPrefix(arg, "--db=") { + return strings.TrimPrefix(arg, "--db=") } } } - return backupdb + return "" }