|
|
@ -21,6 +21,7 @@ import (
|
|
|
|
"io"
|
|
|
|
"io"
|
|
|
|
"os"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
|
|
|
|
"github.com/Masterminds/semver/v3"
|
|
|
|
"github.com/Masterminds/semver/v3"
|
|
|
|
"github.com/gosuri/uitable"
|
|
|
|
"github.com/gosuri/uitable"
|
|
|
@ -61,6 +62,7 @@ func (d *Dependency) List(chartpath string, out io.Writer) error {
|
|
|
|
return nil
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// dependecyStatus returns a string describing the status of a dependency viz a viz the parent chart.
|
|
|
|
func (d *Dependency) dependencyStatus(chartpath string, dep *chart.Dependency, parent *chart.Chart) string {
|
|
|
|
func (d *Dependency) dependencyStatus(chartpath string, dep *chart.Dependency, parent *chart.Chart) string {
|
|
|
|
filename := fmt.Sprintf("%s-%s.tgz", dep.Name, "*")
|
|
|
|
filename := fmt.Sprintf("%s-%s.tgz", dep.Name, "*")
|
|
|
|
|
|
|
|
|
|
|
@ -75,35 +77,40 @@ func (d *Dependency) dependencyStatus(chartpath string, dep *chart.Dependency, p
|
|
|
|
case err != nil:
|
|
|
|
case err != nil:
|
|
|
|
return "bad pattern"
|
|
|
|
return "bad pattern"
|
|
|
|
case len(archives) > 1:
|
|
|
|
case len(archives) > 1:
|
|
|
|
return "too many matches"
|
|
|
|
// See if the second part is a SemVer
|
|
|
|
case len(archives) == 1:
|
|
|
|
found := []string{}
|
|
|
|
archive := archives[0]
|
|
|
|
for _, arc := range archives {
|
|
|
|
if _, err := os.Stat(archive); err == nil {
|
|
|
|
// we need to trip the prefix dirs and the extension off.
|
|
|
|
c, err := loader.Load(archive)
|
|
|
|
filename = strings.TrimSuffix(filepath.Base(arc), ".tgz")
|
|
|
|
if err != nil {
|
|
|
|
maybeVersion := strings.TrimPrefix(filename, fmt.Sprintf("%s-", dep.Name))
|
|
|
|
return "corrupt"
|
|
|
|
|
|
|
|
|
|
|
|
if _, err := semver.StrictNewVersion(maybeVersion); err == nil {
|
|
|
|
|
|
|
|
// If the version parsed without an error, it is possibly a valid
|
|
|
|
|
|
|
|
// version.
|
|
|
|
|
|
|
|
found = append(found, arc)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if c.Name() != dep.Name {
|
|
|
|
|
|
|
|
return "misnamed"
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if c.Metadata.Version != dep.Version {
|
|
|
|
if l := len(found); l == 1 {
|
|
|
|
constraint, err := semver.NewConstraint(dep.Version)
|
|
|
|
// If we get here, we do the same thing as in len(archives) == 1.
|
|
|
|
if err != nil {
|
|
|
|
if r := statArchiveForStatus(found[0], dep); r != "" {
|
|
|
|
return "invalid version"
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
v, err := semver.NewVersion(c.Metadata.Version)
|
|
|
|
// Fall through and look for directories
|
|
|
|
if err != nil {
|
|
|
|
} else if l > 1 {
|
|
|
|
return "invalid version"
|
|
|
|
return "too many matches"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if !constraint.Check(v) {
|
|
|
|
// The sanest thing to do here is to fall through and see if we have any directory
|
|
|
|
return "wrong version"
|
|
|
|
// matches.
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
case len(archives) == 1:
|
|
|
|
return "ok"
|
|
|
|
archive := archives[0]
|
|
|
|
|
|
|
|
if r := statArchiveForStatus(archive, dep); r != "" {
|
|
|
|
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// End unnecessary code.
|
|
|
|
// End unnecessary code.
|
|
|
|
|
|
|
|
|
|
|
@ -137,6 +144,40 @@ func (d *Dependency) dependencyStatus(chartpath string, dep *chart.Dependency, p
|
|
|
|
return "unpacked"
|
|
|
|
return "unpacked"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// stat an archive and return a message if the stat is successful
|
|
|
|
|
|
|
|
//
|
|
|
|
|
|
|
|
// This is a refactor of the code originally in dependencyStatus. It is here to
|
|
|
|
|
|
|
|
// support legacy behavior, and should be removed in Helm 4.
|
|
|
|
|
|
|
|
func statArchiveForStatus(archive string, dep *chart.Dependency) string {
|
|
|
|
|
|
|
|
if _, err := os.Stat(archive); err == nil {
|
|
|
|
|
|
|
|
c, err := loader.Load(archive)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return "corrupt"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if c.Name() != dep.Name {
|
|
|
|
|
|
|
|
return "misnamed"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if c.Metadata.Version != dep.Version {
|
|
|
|
|
|
|
|
constraint, err := semver.NewConstraint(dep.Version)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return "invalid version"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
v, err := semver.NewVersion(c.Metadata.Version)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
return "invalid version"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if !constraint.Check(v) {
|
|
|
|
|
|
|
|
return "wrong version"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return "ok"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return ""
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// printDependencies prints all of the dependencies in the yaml file.
|
|
|
|
// printDependencies prints all of the dependencies in the yaml file.
|
|
|
|
func (d *Dependency) printDependencies(chartpath string, out io.Writer, c *chart.Chart) {
|
|
|
|
func (d *Dependency) printDependencies(chartpath string, out io.Writer, c *chart.Chart) {
|
|
|
|
table := uitable.New()
|
|
|
|
table := uitable.New()
|
|
|
|