From 58841cc3b9c5438c864926cde6ef086241bdd7b3 Mon Sep 17 00:00:00 2001 From: shreddedbacon Date: Mon, 13 Nov 2023 14:37:33 +1100 Subject: [PATCH] chore: add more support for newer active-standby switch task --- internal/messenger/consumer.go | 21 +++++++++++++++++++++ internal/messenger/tasks_handler.go | 7 ++++++- 2 files changed, 27 insertions(+), 1 deletion(-) diff --git a/internal/messenger/consumer.go b/internal/messenger/consumer.go index 49ed3210..a0b90853 100644 --- a/internal/messenger/consumer.go +++ b/internal/messenger/consumer.go @@ -365,6 +365,13 @@ func (m *Messenger) Consumer(targetName string) { //error { ) err := m.IngressRouteMigration(namespace, jobSpec) if err != nil { + opLog.Error(err, + fmt.Sprintf( + "Route migration / activestandby switch for project %s, environment %s failed to be created", + jobSpec.Project.Name, + jobSpec.Environment.Name, + ), + ) //@TODO: send msg back to lagoon and update task to failed? message.Ack(false) // ack to remove from queue return @@ -378,6 +385,13 @@ func (m *Messenger) Consumer(targetName string) { //error { ) err := m.AdvancedTask(namespace, jobSpec) if err != nil { + opLog.Error(err, + fmt.Sprintf( + "Advanced task for project %s, environment %s failed to be created", + jobSpec.Project.Name, + jobSpec.Environment.Name, + ), + ) //@TODO: send msg back to lagoon and update task to failed? message.Ack(false) // ack to remove from queue return @@ -391,6 +405,13 @@ func (m *Messenger) Consumer(targetName string) { //error { ) err := m.ActiveStandbySwitch(namespace, jobSpec) if err != nil { + opLog.Error(err, + fmt.Sprintf( + "Active/Standby switch for project %s, environment %s failed to be created", + jobSpec.Project.Name, + jobSpec.Environment.Name, + ), + ) //@TODO: send msg back to lagoon and update task to failed? message.Ack(false) // ack to remove from queue return diff --git a/internal/messenger/tasks_handler.go b/internal/messenger/tasks_handler.go index ded60952..a5ff074a 100644 --- a/internal/messenger/tasks_handler.go +++ b/internal/messenger/tasks_handler.go @@ -2,6 +2,7 @@ package messenger import ( "context" + "encoding/base64" "encoding/json" "fmt" "sort" @@ -251,7 +252,11 @@ func (m *Messenger) ActiveStandbySwitch(namespace string, jobSpec *lagoonv1beta1 jobSpec.AdvancedTask.DeployerToken = true jobSpec.AdvancedTask.SSHKey = true asPayload := &ActiveStandbyPayload{} - err := json.Unmarshal([]byte(jobSpec.AdvancedTask.JSONPayload), asPayload) + asPayloadDecoded, err := base64.StdEncoding.DecodeString(jobSpec.AdvancedTask.JSONPayload) + if err != nil { + return fmt.Errorf("Unable to base64 decode payload: %v", err) + } + err = json.Unmarshal([]byte(asPayloadDecoded), asPayload) if err != nil { return fmt.Errorf("Unable to unmarshal json payload: %v", err) }