diff --git a/internal/messenger/messenger.go b/internal/messenger/messenger.go index f5a69d73..2ce0eee6 100644 --- a/internal/messenger/messenger.go +++ b/internal/messenger/messenger.go @@ -36,6 +36,7 @@ type Messenger struct { AdvancedTaskDeployTokenInjection bool DeletionHandler *deletions.Deletions EnableDebug bool + SupportK8upV2 bool Cache *expirable.LRU[string, string] } @@ -51,6 +52,7 @@ func New(config mq.Config, advancedTaskDeployTokenInjection bool, deletionHandler *deletions.Deletions, enableDebug bool, + supportK8upV2 bool, cache *expirable.LRU[string, string], ) *Messenger { return &Messenger{ @@ -65,6 +67,7 @@ func New(config mq.Config, AdvancedTaskDeployTokenInjection: advancedTaskDeployTokenInjection, DeletionHandler: deletionHandler, EnableDebug: enableDebug, + SupportK8upV2: supportK8upV2, Cache: cache, } } diff --git a/internal/messenger/tasks_restore.go b/internal/messenger/tasks_restore.go index 0048b29f..315ddb4d 100644 --- a/internal/messenger/tasks_restore.go +++ b/internal/messenger/tasks_restore.go @@ -53,20 +53,28 @@ func (m *Messenger) ResticRestore(namespace string, jobSpec *lagoonv1beta1.Lagoo k8upv1Exists = true } // check the version, if there is no version in the payload, assume it is k8up v2 - if vers == "backup.appuio.ch/v1alpha1" { - if k8upv1alpha1Exists { - return m.createv1alpha1Restore(opLog, namespace, jobSpec) - } - } else { - if k8upv1Exists { - if err := m.createv1Restore(opLog, namespace, jobSpec); err != nil { - return err + if m.SupportK8upV2 { + if vers == "backup.appuio.ch/v1alpha1" { + if k8upv1alpha1Exists { + return m.createv1alpha1Restore(opLog, namespace, jobSpec) } } else { - if k8upv1alpha1Exists { - if err := m.createv1alpha1Restore(opLog, namespace, jobSpec); err != nil { + if k8upv1Exists { + if err := m.createv1Restore(opLog, namespace, jobSpec); err != nil { return err } + } else { + if k8upv1alpha1Exists { + if err := m.createv1alpha1Restore(opLog, namespace, jobSpec); err != nil { + return err + } + } + } + } + } else { + if k8upv1alpha1Exists { + if err := m.createv1alpha1Restore(opLog, namespace, jobSpec); err != nil { + return err } } } diff --git a/main.go b/main.go index d709103c..7238b1ab 100644 --- a/main.go +++ b/main.go @@ -136,6 +136,7 @@ func main() { var taskPodsToKeep int var lffBackupWeeklyRandom bool var lffHarborEnabled bool + var lffSupportK8UPv2 bool var harborURL string var harborAPI string var harborUsername string @@ -281,6 +282,8 @@ func main() { flag.IntVar(&taskPodsToKeep, "num-task-pods-to-keep", 1, "The number of task pods to keep per namespace.") flag.BoolVar(&lffBackupWeeklyRandom, "lagoon-feature-flag-backup-weekly-random", false, "Tells Lagoon whether or not to use the \"weekly-random\" schedule for k8up backups.") + flag.BoolVar(&lffSupportK8UPv2, "lagoon-feature-flag-support-k8upv2", false, + "Tells Lagoon whether or not it can support k8up v2.") flag.BoolVar(&tlsSkipVerify, "skip-tls-verify", false, "Flag to skip tls verification for http clients (harbor).") @@ -644,6 +647,7 @@ func main() { advancedTaskDeployToken, deletion, enableDebug, + lffSupportK8UPv2, cache, )