@ -27,6 +27,13 @@ import (
"helm.sh/helm/pkg/storage/driver"
"helm.sh/helm/pkg/storage/driver"
)
)
// The type field of the Kubernetes storage object which stores the Helm release
// version. It is modified slightly replacing the '/': sh.helm/release.v1
// Note: The version 'v1' is incremented if the release object metadata is
// modified between major releases.
// This constant is used as a prefix for the Kubernetes storage object name.
const HelmStorageType = "sh.helm.release.v1"
// Storage represents a storage engine for a Release.
// Storage represents a storage engine for a Release.
type Storage struct {
type Storage struct {
driver . Driver
driver . Driver
@ -205,11 +212,14 @@ func (s *Storage) Last(name string) (*rspb.Release, error) {
return h [ 0 ] , nil
return h [ 0 ] , nil
}
}
// makeKey concatenates a release name and version into
// makeKey concatenates the Kubernetes storage object type, a release name and version
// a string with format ```<release_name>#v<version>```.
// into a string with format:```<helm_storage_type>.<release_name>.v<release_version>```.
// The storage type is prepended to keep name uniqueness between different
// release storage types. An example of clash when not using the type:
// https://github.com/helm/helm/issues/6435.
// This key is used to uniquely identify storage objects.
// This key is used to uniquely identify storage objects.
func makeKey ( rlsname string , version int ) string {
func makeKey ( rlsname string , version int ) string {
return fmt . Sprintf ( "%s.v%d" , rlsname , version )
return fmt . Sprintf ( "%s. %s. v%d", HelmStorageType , rlsname , version )
}
}
// Init initializes a new storage backend with the driver d.
// Init initializes a new storage backend with the driver d.