2022-09-05 03:06:08 -04:00
|
|
|
/*
|
|
|
|
Copyright (c) Edgeless Systems GmbH
|
|
|
|
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2022-04-13 07:01:38 -04:00
|
|
|
package cloudcmd
|
2022-03-22 11:03:15 -04:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2023-02-07 06:56:25 -05:00
|
|
|
"errors"
|
2022-03-22 11:03:15 -04:00
|
|
|
"fmt"
|
|
|
|
"io"
|
2023-04-14 08:15:07 -04:00
|
|
|
|
|
|
|
"github.com/edgelesssys/constellation/v2/cli/internal/terraform"
|
2023-08-24 10:38:02 -04:00
|
|
|
"github.com/edgelesssys/constellation/v2/internal/constants"
|
2022-03-22 11:03:15 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// rollbacker does a rollback.
|
|
|
|
type rollbacker interface {
|
2023-08-24 10:38:02 -04:00
|
|
|
rollback(ctx context.Context, w io.Writer, logLevel terraform.LogLevel) error
|
2022-03-22 11:03:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// rollbackOnError calls rollback on the rollbacker if the handed error is not nil,
|
|
|
|
// and writes logs to the writer w.
|
2023-04-14 08:15:07 -04:00
|
|
|
func rollbackOnError(w io.Writer, onErr *error, roll rollbacker, logLevel terraform.LogLevel) {
|
2022-03-22 11:03:15 -04:00
|
|
|
if *onErr == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
fmt.Fprintf(w, "An error occurred: %s\n", *onErr)
|
|
|
|
fmt.Fprintln(w, "Attempting to roll back.")
|
2023-08-24 10:38:02 -04:00
|
|
|
if err := roll.rollback(context.Background(), w, logLevel); err != nil {
|
2023-06-01 06:33:06 -04:00
|
|
|
*onErr = errors.Join(*onErr, fmt.Errorf("on rollback: %w", err)) // TODO(katexochen): print the error, or return it?
|
2022-03-22 11:03:15 -04:00
|
|
|
return
|
|
|
|
}
|
|
|
|
fmt.Fprintln(w, "Rollback succeeded.")
|
|
|
|
}
|
|
|
|
|
2022-09-27 03:22:29 -04:00
|
|
|
type rollbackerTerraform struct {
|
2023-07-31 04:53:05 -04:00
|
|
|
client tfCommonClient
|
2022-09-26 09:52:31 -04:00
|
|
|
}
|
|
|
|
|
2023-08-24 10:38:02 -04:00
|
|
|
func (r *rollbackerTerraform) rollback(ctx context.Context, w io.Writer, logLevel terraform.LogLevel) error {
|
2023-04-14 08:15:07 -04:00
|
|
|
if err := r.client.Destroy(ctx, logLevel); err != nil {
|
2023-08-24 10:38:02 -04:00
|
|
|
fmt.Fprintf(w, "Could not destroy the resources. Please delete the %q directory manually if no resources were created\n",
|
|
|
|
constants.TerraformWorkingDir)
|
2023-02-07 09:19:59 -05:00
|
|
|
return err
|
2022-10-26 09:57:00 -04:00
|
|
|
}
|
2023-02-07 09:19:59 -05:00
|
|
|
return r.client.CleanUpWorkspace()
|
2022-09-26 09:52:31 -04:00
|
|
|
}
|
2022-10-05 03:11:30 -04:00
|
|
|
|
|
|
|
type rollbackerQEMU struct {
|
2023-07-31 04:53:05 -04:00
|
|
|
client tfResourceClient
|
2022-11-15 08:00:44 -05:00
|
|
|
libvirt libvirtRunner
|
|
|
|
createdWorkspace bool
|
2022-10-05 03:11:30 -04:00
|
|
|
}
|
|
|
|
|
2023-08-24 10:38:02 -04:00
|
|
|
func (r *rollbackerQEMU) rollback(ctx context.Context, w io.Writer, logLevel terraform.LogLevel) (retErr error) {
|
2022-11-15 08:00:44 -05:00
|
|
|
if r.createdWorkspace {
|
2023-04-14 08:15:07 -04:00
|
|
|
retErr = r.client.Destroy(ctx, logLevel)
|
2022-11-15 08:00:44 -05:00
|
|
|
}
|
2023-02-07 09:19:59 -05:00
|
|
|
if retErr := errors.Join(retErr, r.libvirt.Stop(ctx)); retErr != nil {
|
2023-08-24 10:38:02 -04:00
|
|
|
fmt.Fprintf(w, "Could not destroy the resources. Please delete the %q directory manually if no resources were created\n",
|
|
|
|
constants.TerraformWorkingDir)
|
2023-02-07 09:19:59 -05:00
|
|
|
return retErr
|
2022-10-26 09:57:00 -04:00
|
|
|
}
|
2023-02-07 09:19:59 -05:00
|
|
|
return r.client.CleanUpWorkspace()
|
2022-10-05 03:11:30 -04:00
|
|
|
}
|