-
Notifications
You must be signed in to change notification settings - Fork 173
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Philip Laine <[email protected]>
- Loading branch information
1 parent
55adbb4
commit f36414b
Showing
4 changed files
with
462 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,197 @@ | ||
// SPDX-License-Identifier: Apache-2.0 | ||
// SPDX-FileCopyrightText: 2021-Present The Zarf Authors | ||
|
||
package layout | ||
|
||
import ( | ||
"fmt" | ||
"math" | ||
"slices" | ||
|
||
"github.com/zarf-dev/zarf/src/api/v1alpha1" | ||
) | ||
|
||
// List of migrations tracked in the zarf.yaml build data. | ||
const ( | ||
// This should be updated when a breaking change is introduced to the Zarf package structure. See: https://github.com/zarf-dev/zarf/releases/tag/v0.27.0 | ||
LastNonBreakingVersion = "v0.27.0" | ||
ScriptsToActionsMigrated = "scripts-to-actions" | ||
PluralizeSetVariable = "pluralize-set-variable" | ||
) | ||
|
||
func migrateDeprecated(pkg v1alpha1.ZarfPackage) (v1alpha1.ZarfPackage, []string) { | ||
warnings := []string{} | ||
|
||
migratedComponents := []v1alpha1.ZarfComponent{} | ||
for _, comp := range pkg.Components { | ||
if slices.Contains(pkg.Build.Migrations, ScriptsToActionsMigrated) { | ||
comp.DeprecatedScripts = v1alpha1.DeprecatedZarfComponentScripts{} | ||
} else { | ||
var warning string | ||
if comp, warning = migrateScriptsToActions(comp); warning != "" { | ||
warnings = append(warnings, warning) | ||
} | ||
} | ||
|
||
if slices.Contains(pkg.Build.Migrations, PluralizeSetVariable) { | ||
comp = clearSetVariables(comp) | ||
} else { | ||
var warning string | ||
if comp, warning = migrateSetVariableToSetVariables(comp); warning != "" { | ||
warnings = append(warnings, warning) | ||
} | ||
} | ||
|
||
// Show a warning if the component contains a group as that has been deprecated and will be removed. | ||
if comp.DeprecatedGroup != "" { | ||
warnings = append(warnings, fmt.Sprintf("Component %s is using group which has been deprecated and will be removed in v1.0.0. Please migrate to another solution.", comp.Name)) | ||
} | ||
|
||
migratedComponents = append(migratedComponents, comp) | ||
} | ||
pkg.Components = migratedComponents | ||
|
||
// Record the migrations that have been run on the package. | ||
pkg.Build.Migrations = []string{ | ||
ScriptsToActionsMigrated, | ||
PluralizeSetVariable, | ||
} | ||
|
||
// Record the latest version of Zarf without breaking changes to the package structure. | ||
pkg.Build.LastNonBreakingVersion = LastNonBreakingVersion | ||
|
||
return pkg, warnings | ||
} | ||
|
||
// migrateScriptsToActions coverts the deprecated scripts to the new actions | ||
// The following have no migration: | ||
// - Actions.Create.After | ||
// - Actions.Remove.* | ||
// - Actions.*.OnSuccess | ||
// - Actions.*.OnFailure | ||
// - Actions.*.*.Env | ||
func migrateScriptsToActions(c v1alpha1.ZarfComponent) (v1alpha1.ZarfComponent, string) { | ||
var hasScripts bool | ||
|
||
// Convert a script configs to action defaults. | ||
defaults := v1alpha1.ZarfComponentActionDefaults{ | ||
// ShowOutput (default false) -> Mute (default false) | ||
Mute: !c.DeprecatedScripts.ShowOutput, | ||
// TimeoutSeconds -> MaxSeconds | ||
MaxTotalSeconds: c.DeprecatedScripts.TimeoutSeconds, | ||
} | ||
|
||
// Retry is now an integer vs a boolean (implicit infinite retries), so set to an absurdly high number | ||
if c.DeprecatedScripts.Retry { | ||
defaults.MaxRetries = math.MaxInt | ||
} | ||
|
||
// Scripts.Prepare -> Actions.Create.Before | ||
if len(c.DeprecatedScripts.Prepare) > 0 { | ||
hasScripts = true | ||
c.Actions.OnCreate.Defaults = defaults | ||
for _, s := range c.DeprecatedScripts.Prepare { | ||
c.Actions.OnCreate.Before = append(c.Actions.OnCreate.Before, v1alpha1.ZarfComponentAction{Cmd: s}) | ||
} | ||
} | ||
|
||
// Scripts.Before -> Actions.Deploy.Before | ||
if len(c.DeprecatedScripts.Before) > 0 { | ||
hasScripts = true | ||
c.Actions.OnDeploy.Defaults = defaults | ||
for _, s := range c.DeprecatedScripts.Before { | ||
c.Actions.OnDeploy.Before = append(c.Actions.OnDeploy.Before, v1alpha1.ZarfComponentAction{Cmd: s}) | ||
} | ||
} | ||
|
||
// Scripts.After -> Actions.Deploy.After | ||
if len(c.DeprecatedScripts.After) > 0 { | ||
hasScripts = true | ||
c.Actions.OnDeploy.Defaults = defaults | ||
for _, s := range c.DeprecatedScripts.After { | ||
c.Actions.OnDeploy.After = append(c.Actions.OnDeploy.After, v1alpha1.ZarfComponentAction{Cmd: s}) | ||
} | ||
} | ||
|
||
// Leave deprecated scripts in place, but warn users | ||
if hasScripts { | ||
return c, fmt.Sprintf("Component '%s' is using scripts which will be removed in Zarf v1.0.0. Please migrate to actions.", c.Name) | ||
} | ||
|
||
return c, "" | ||
} | ||
|
||
func migrateSetVariableToSetVariables(c v1alpha1.ZarfComponent) (v1alpha1.ZarfComponent, string) { | ||
hasSetVariable := false | ||
|
||
migrate := func(actions []v1alpha1.ZarfComponentAction) []v1alpha1.ZarfComponentAction { | ||
for i := range actions { | ||
if actions[i].DeprecatedSetVariable != "" && len(actions[i].SetVariables) < 1 { | ||
hasSetVariable = true | ||
actions[i].SetVariables = []v1alpha1.Variable{ | ||
{ | ||
Name: actions[i].DeprecatedSetVariable, | ||
Sensitive: false, | ||
}, | ||
} | ||
} | ||
} | ||
|
||
return actions | ||
} | ||
|
||
// Migrate OnCreate SetVariables | ||
c.Actions.OnCreate.After = migrate(c.Actions.OnCreate.After) | ||
c.Actions.OnCreate.Before = migrate(c.Actions.OnCreate.Before) | ||
c.Actions.OnCreate.OnSuccess = migrate(c.Actions.OnCreate.OnSuccess) | ||
c.Actions.OnCreate.OnFailure = migrate(c.Actions.OnCreate.OnFailure) | ||
|
||
// Migrate OnDeploy SetVariables | ||
c.Actions.OnDeploy.After = migrate(c.Actions.OnDeploy.After) | ||
c.Actions.OnDeploy.Before = migrate(c.Actions.OnDeploy.Before) | ||
c.Actions.OnDeploy.OnSuccess = migrate(c.Actions.OnDeploy.OnSuccess) | ||
c.Actions.OnDeploy.OnFailure = migrate(c.Actions.OnDeploy.OnFailure) | ||
|
||
// Migrate OnRemove SetVariables | ||
c.Actions.OnRemove.After = migrate(c.Actions.OnRemove.After) | ||
c.Actions.OnRemove.Before = migrate(c.Actions.OnRemove.Before) | ||
c.Actions.OnRemove.OnSuccess = migrate(c.Actions.OnRemove.OnSuccess) | ||
c.Actions.OnRemove.OnFailure = migrate(c.Actions.OnRemove.OnFailure) | ||
|
||
// Leave deprecated setVariable in place, but warn users | ||
if hasSetVariable { | ||
return c, fmt.Sprintf("Component '%s' is using setVariable in actions which will be removed in Zarf v1.0.0. Please migrate to the list form of setVariables.", c.Name) | ||
} | ||
|
||
return c, "" | ||
} | ||
|
||
func clearSetVariables(c v1alpha1.ZarfComponent) v1alpha1.ZarfComponent { | ||
clear := func(actions []v1alpha1.ZarfComponentAction) []v1alpha1.ZarfComponentAction { | ||
for i := range actions { | ||
actions[i].DeprecatedSetVariable = "" | ||
} | ||
|
||
return actions | ||
} | ||
|
||
// Clear OnCreate SetVariables | ||
c.Actions.OnCreate.After = clear(c.Actions.OnCreate.After) | ||
c.Actions.OnCreate.Before = clear(c.Actions.OnCreate.Before) | ||
c.Actions.OnCreate.OnSuccess = clear(c.Actions.OnCreate.OnSuccess) | ||
c.Actions.OnCreate.OnFailure = clear(c.Actions.OnCreate.OnFailure) | ||
|
||
// Clear OnDeploy SetVariables | ||
c.Actions.OnDeploy.After = clear(c.Actions.OnDeploy.After) | ||
c.Actions.OnDeploy.Before = clear(c.Actions.OnDeploy.Before) | ||
c.Actions.OnDeploy.OnSuccess = clear(c.Actions.OnDeploy.OnSuccess) | ||
c.Actions.OnDeploy.OnFailure = clear(c.Actions.OnDeploy.OnFailure) | ||
|
||
// Clear OnRemove SetVariables | ||
c.Actions.OnRemove.After = clear(c.Actions.OnRemove.After) | ||
c.Actions.OnRemove.Before = clear(c.Actions.OnRemove.Before) | ||
c.Actions.OnRemove.OnSuccess = clear(c.Actions.OnRemove.OnSuccess) | ||
c.Actions.OnRemove.OnFailure = clear(c.Actions.OnRemove.OnFailure) | ||
|
||
return c | ||
} |
Oops, something went wrong.