111 lines
2.8 KiB
Go
111 lines
2.8 KiB
Go
package internal
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"coopcloud.tech/abra/pkg/formatter"
|
|
"coopcloud.tech/abra/pkg/recipe"
|
|
"github.com/AlecAivazis/survey/v2"
|
|
"github.com/distribution/reference"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
// PromptBumpType prompts for version bump type
|
|
func PromptBumpType(tagString, latestRelease string) error {
|
|
if (!Major && !Minor && !Patch) && tagString == "" {
|
|
fmt.Printf(`
|
|
You need to make a decision about what kind of an update this new recipe
|
|
version is. If someone else performs this upgrade, do they have to do some
|
|
migration work or take care of some breaking changes? This can be signaled in
|
|
the version you specify on the recipe deploy label and is called a semantic
|
|
version.
|
|
|
|
The latest published version is %s.
|
|
|
|
Here is a semver cheat sheet (more on https://semver.org):
|
|
|
|
major: new features/bug fixes, backwards incompatible (e.g 1.0.0 -> 2.0.0).
|
|
the upgrade won't work without some preparation work and others need
|
|
to take care when performing it. "it could go wrong".
|
|
|
|
minor: new features/bug fixes, backwards compatible (e.g. 0.1.0 -> 0.2.0).
|
|
the upgrade should Just Work and there are no breaking changes in
|
|
the app and the recipe config. "it should go fine".
|
|
|
|
patch: bug fixes, backwards compatible (e.g. 0.0.1 -> 0.0.2). this upgrade
|
|
should also Just Work and is mostly to do with minor bug fixes
|
|
and/or security patches. "nothing to worry about".
|
|
|
|
`, latestRelease)
|
|
|
|
var chosenBumpType string
|
|
prompt := &survey.Select{
|
|
Message: fmt.Sprintf("select recipe version increment type"),
|
|
Options: []string{"major", "minor", "patch"},
|
|
}
|
|
|
|
if err := survey.AskOne(prompt, &chosenBumpType); err != nil {
|
|
return err
|
|
}
|
|
|
|
SetBumpType(chosenBumpType)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// GetBumpType figures out which bump type is specified
|
|
func GetBumpType() string {
|
|
var bumpType string
|
|
|
|
if Major {
|
|
bumpType = "major"
|
|
} else if Minor {
|
|
bumpType = "minor"
|
|
} else if Patch {
|
|
bumpType = "patch"
|
|
} else {
|
|
logrus.Fatal("no version bump type specififed?")
|
|
}
|
|
|
|
return bumpType
|
|
}
|
|
|
|
// SetBumpType figures out which bump type is specified
|
|
func SetBumpType(bumpType string) {
|
|
if bumpType == "major" {
|
|
Major = true
|
|
} else if bumpType == "minor" {
|
|
Minor = true
|
|
} else if bumpType == "patch" {
|
|
Patch = true
|
|
} else {
|
|
logrus.Fatal("no version bump type specififed?")
|
|
}
|
|
}
|
|
|
|
// GetMainAppImage retrieves the main 'app' image name
|
|
func GetMainAppImage(recipe recipe.Recipe) (string, error) {
|
|
var path string
|
|
|
|
for _, service := range recipe.Config.Services {
|
|
if service.Name == "app" {
|
|
img, err := reference.ParseNormalizedNamed(service.Image)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
path = reference.Path(img)
|
|
path = formatter.StripTagMeta(path)
|
|
|
|
return path, nil
|
|
}
|
|
}
|
|
|
|
if path == "" {
|
|
return path, fmt.Errorf("%s has no main 'app' service?", recipe.Name)
|
|
}
|
|
|
|
return path, nil
|
|
}
|