mirror of
https://github.com/portainer/portainer.git
synced 2025-07-19 13:29:41 +02:00
feat(oci): oci helm support [r8s-361] (#787)
This commit is contained in:
parent
b6a6ce9aaf
commit
2697d6c5d7
80 changed files with 4264 additions and 812 deletions
|
@ -4,6 +4,7 @@ import (
|
|||
"time"
|
||||
|
||||
"github.com/pkg/errors"
|
||||
"github.com/portainer/portainer/pkg/libhelm/cache"
|
||||
"github.com/portainer/portainer/pkg/libhelm/options"
|
||||
"github.com/portainer/portainer/pkg/libhelm/release"
|
||||
"github.com/rs/zerolog/log"
|
||||
|
@ -66,6 +67,12 @@ func (hspm *HelmSDKPackageManager) Upgrade(upgradeOpts options.InstallOptions) (
|
|||
return nil, errors.Wrap(err, "failed to initialize helm configuration for helm release upgrade")
|
||||
}
|
||||
|
||||
// Setup chart source
|
||||
err = authenticateChartSource(actionConfig, upgradeOpts.Registry)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "failed to setup chart source for helm release upgrade")
|
||||
}
|
||||
|
||||
upgradeClient, err := initUpgradeClient(actionConfig, upgradeOpts)
|
||||
if err != nil {
|
||||
log.Error().
|
||||
|
@ -75,7 +82,7 @@ func (hspm *HelmSDKPackageManager) Upgrade(upgradeOpts options.InstallOptions) (
|
|||
return nil, errors.Wrap(err, "failed to initialize helm upgrade client for helm release upgrade")
|
||||
}
|
||||
|
||||
values, err := hspm.GetHelmValuesFromFile(upgradeOpts.ValuesFile)
|
||||
values, err := hspm.getHelmValuesFromFile(upgradeOpts.ValuesFile)
|
||||
if err != nil {
|
||||
log.Error().
|
||||
Str("context", "HelmClient").
|
||||
|
@ -84,15 +91,36 @@ func (hspm *HelmSDKPackageManager) Upgrade(upgradeOpts options.InstallOptions) (
|
|||
return nil, errors.Wrap(err, "failed to get Helm values from file for helm release upgrade")
|
||||
}
|
||||
|
||||
chart, err := hspm.loadAndValidateChartWithPathOptions(&upgradeClient.ChartPathOptions, upgradeOpts.Chart, upgradeOpts.Version, upgradeOpts.Repo, upgradeClient.DependencyUpdate, "release upgrade")
|
||||
chartRef, repoURL, err := parseChartRef(upgradeOpts.Chart, upgradeOpts.Repo, upgradeOpts.Registry)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "failed to parse chart reference for helm release upgrade")
|
||||
}
|
||||
chart, err := hspm.loadAndValidateChartWithPathOptions(&upgradeClient.ChartPathOptions, chartRef, upgradeOpts.Version, repoURL, upgradeClient.DependencyUpdate, "release upgrade")
|
||||
if err != nil {
|
||||
log.Error().
|
||||
Str("context", "HelmClient").
|
||||
Err(err).
|
||||
Msg("Failed to load and validate chart for helm release upgrade")
|
||||
|
||||
// Check if this is an authentication error and flush cache if needed
|
||||
if upgradeOpts.Registry != nil && shouldFlushCacheOnError(err, upgradeOpts.Registry.ID) {
|
||||
cache.FlushRegistryByID(upgradeOpts.Registry.ID)
|
||||
log.Info().
|
||||
Int("registry_id", int(upgradeOpts.Registry.ID)).
|
||||
Str("context", "HelmClient").
|
||||
Msg("Flushed registry cache due to chart loading authentication error during upgrade")
|
||||
}
|
||||
|
||||
return nil, errors.Wrap(err, "failed to load and validate chart for helm release upgrade")
|
||||
}
|
||||
|
||||
// Add chart references to annotations
|
||||
var registryID int
|
||||
if upgradeOpts.Registry != nil {
|
||||
registryID = int(upgradeOpts.Registry.ID)
|
||||
}
|
||||
chart.Metadata.Annotations = appendChartReferenceAnnotations(upgradeOpts.Chart, upgradeOpts.Repo, registryID, chart.Metadata.Annotations)
|
||||
|
||||
log.Info().
|
||||
Str("context", "HelmClient").
|
||||
Str("chart", upgradeOpts.Chart).
|
||||
|
@ -117,9 +145,10 @@ func (hspm *HelmSDKPackageManager) Upgrade(upgradeOpts options.InstallOptions) (
|
|||
Namespace: helmRelease.Namespace,
|
||||
Chart: release.Chart{
|
||||
Metadata: &release.Metadata{
|
||||
Name: helmRelease.Chart.Metadata.Name,
|
||||
Version: helmRelease.Chart.Metadata.Version,
|
||||
AppVersion: helmRelease.Chart.Metadata.AppVersion,
|
||||
Name: helmRelease.Chart.Metadata.Name,
|
||||
Version: helmRelease.Chart.Metadata.Version,
|
||||
AppVersion: helmRelease.Chart.Metadata.AppVersion,
|
||||
Annotations: helmRelease.Chart.Metadata.Annotations,
|
||||
},
|
||||
},
|
||||
Labels: helmRelease.Labels,
|
||||
|
@ -134,12 +163,20 @@ func initUpgradeClient(actionConfig *action.Configuration, upgradeOpts options.I
|
|||
upgradeClient := action.NewUpgrade(actionConfig)
|
||||
upgradeClient.DependencyUpdate = true
|
||||
upgradeClient.Atomic = upgradeOpts.Atomic
|
||||
upgradeClient.ChartPathOptions.RepoURL = upgradeOpts.Repo
|
||||
upgradeClient.Wait = upgradeOpts.Wait
|
||||
upgradeClient.Version = upgradeOpts.Version
|
||||
err := configureChartPathOptions(&upgradeClient.ChartPathOptions, upgradeOpts.Version, upgradeOpts.Repo, upgradeOpts.Registry)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "failed to configure chart path options for helm release upgrade")
|
||||
}
|
||||
|
||||
// Set default values if not specified
|
||||
if upgradeOpts.Timeout == 0 {
|
||||
upgradeClient.Timeout = 5 * time.Minute
|
||||
if upgradeClient.Atomic {
|
||||
upgradeClient.Timeout = 30 * time.Minute // the atomic flag significantly increases the upgrade time
|
||||
} else {
|
||||
upgradeClient.Timeout = 15 * time.Minute
|
||||
}
|
||||
} else {
|
||||
upgradeClient.Timeout = upgradeOpts.Timeout
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue