Documentation ¶
Overview ¶
+k8s:deepcopy-gen=package,register +groupName=helm.fluxcd.io Package v1 is the v1 version of the API. The prior version was flux.weave.works/v1beta1.
Index ¶
- Constants
- Variables
- func Resource(resource string) schema.GroupResource
- type ChartFileSelector
- type ChartSource
- type ConditionStatus
- type ConfigMapKeySelector
- type ExternalSourceSelector
- type GitChartSource
- type HelmRelease
- func (in *HelmRelease) DeepCopy() *HelmRelease
- func (in *HelmRelease) DeepCopyInto(out *HelmRelease)
- func (in *HelmRelease) DeepCopyObject() runtime.Object
- func (hr HelmRelease) GetDefaultedNamespace() string
- func (hr HelmRelease) GetHelmVersion(defaultVersion string) string
- func (hr HelmRelease) GetMaxHistory() int
- func (hr HelmRelease) GetReleaseName() string
- func (hr HelmRelease) GetReuseValues() bool
- func (hr HelmRelease) GetTargetNamespace() string
- func (hr HelmRelease) GetTimeout() time.Duration
- func (hr HelmRelease) GetValuesFromSources() []ValuesFromSource
- func (hr HelmRelease) ResourceID() resource.ID
- type HelmReleaseCondition
- type HelmReleaseConditionType
- type HelmReleaseList
- type HelmReleasePhase
- type HelmReleaseSpec
- type HelmReleaseStatus
- type HelmValues
- type HelmVersion
- type LocalObjectReference
- type OptionalConfigMapKeySelector
- type OptionalSecretKeySelector
- type RepoChartSource
- type Rollback
- type SecretKeySelector
- type ValuesFromSource
Constants ¶
const AntecedentAnnotation = "helm.fluxcd.io/antecedent"
AntecedentAnnotation is an annotation on a resource indicating that the cause of that resource is a HelmRelease. We use this rather than the `OwnerReference` type built into Kubernetes as this does not allow cross-namespace references by design. The value is expected to be a serialised `resource.ID`.
const Version = "v1"
Variables ¶
var ( // SchemeBuilder will stay in k8s.io/kubernetes. SchemeBuilder runtime.SchemeBuilder // AddToScheme will stay in k8s.io/kubernetes. AddToScheme = localSchemeBuilder.AddToScheme )
var SchemeGroupVersion = schema.GroupVersion{Group: helm.GroupName, Version: Version}
SchemeGroupVersion is group version used to register these objects
Functions ¶
func Resource ¶
func Resource(resource string) schema.GroupResource
Resource takes an unqualified resource and returns a Group qualified GroupResource
Types ¶
type ChartFileSelector ¶
type ChartFileSelector struct { // Path is the file path to the source relative to the chart root. Path string `json:"path"` // Optional will mark this ChartFileSelector as optional. // The result of this are that operations are permitted without // the source, due to it e.g. being temporarily unavailable. // +optional Optional *bool `json:"optional,omitempty"` }
func (*ChartFileSelector) DeepCopy ¶
func (in *ChartFileSelector) DeepCopy() *ChartFileSelector
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ChartFileSelector.
func (*ChartFileSelector) DeepCopyInto ¶
func (in *ChartFileSelector) DeepCopyInto(out *ChartFileSelector)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type ChartSource ¶
type ChartSource struct { // +optional *GitChartSource `json:",inline"` // +optional *RepoChartSource `json:",inline"` }
func (*ChartSource) DeepCopy ¶
func (in *ChartSource) DeepCopy() *ChartSource
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ChartSource.
func (*ChartSource) DeepCopyInto ¶
func (in *ChartSource) DeepCopyInto(out *ChartSource)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type ConditionStatus ¶
type ConditionStatus string
+kubebuilder:validation:Enum="True";"False";"Unknown"
const ( ConditionTrue ConditionStatus = "True" ConditionFalse ConditionStatus = "False" ConditionUnknown ConditionStatus = "Unknown" )
These are valid condition statuses. "ConditionTrue" means a resource is in the condition, "ConditionFalse" means a resource is not in the condition, "ConditionUnknown" means the operator can't decide if a resource is in the condition or not.
type ConfigMapKeySelector ¶
type ConfigMapKeySelector struct { LocalObjectReference `json:",inline"` // +optional Namespace string `json:"namespace,omitempty"` // +optional Key string `json:"key,omitempty"` }
func (*ConfigMapKeySelector) DeepCopy ¶
func (in *ConfigMapKeySelector) DeepCopy() *ConfigMapKeySelector
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ConfigMapKeySelector.
func (*ConfigMapKeySelector) DeepCopyInto ¶
func (in *ConfigMapKeySelector) DeepCopyInto(out *ConfigMapKeySelector)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type ExternalSourceSelector ¶
type ExternalSourceSelector struct { // URL is the URL of the external source. URL string `json:"url"` // Optional will mark this ExternalSourceSelector as optional. // The result of this are that operations are permitted without // the source, due to it e.g. being temporarily unavailable. // +optional Optional *bool `json:"optional,omitempty"` }
func (*ExternalSourceSelector) DeepCopy ¶
func (in *ExternalSourceSelector) DeepCopy() *ExternalSourceSelector
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ExternalSourceSelector.
func (*ExternalSourceSelector) DeepCopyInto ¶
func (in *ExternalSourceSelector) DeepCopyInto(out *ExternalSourceSelector)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type GitChartSource ¶
type GitChartSource struct { // Git URL is the URL of the Git repository, e.g. // git@github.com:org/repo, http://github.com/org/repo, // or ssh://git@example.com:2222/org/repo.git. // +kubebuilder:validation:Optional GitURL string `json:"git"` // Ref is the Git branch (or other reference) to use. Defaults to // 'master', or the configured default Git ref. // +kubebuilder:validation:Optional Ref string `json:"ref"` // Path is the path to the chart relative to the repository root. // +kubebuilder:validation:Optional Path string `json:"path"` // SecretRef holds the authentication secret for accessing the Git // repository (over HTTPS). The credentials will be added to an // HTTPS GitURL before the mirror is started. // +optional SecretRef *LocalObjectReference `json:"secretRef,omitempty"` // SkipDepUpdate will tell the operator to skip running // 'helm dep update' before installing or upgrading the chart, the // chart dependencies _must_ be present for this to succeed. // +optional SkipDepUpdate bool `json:"skipDepUpdate,omitempty"` }
GitChartSource describes a Helm chart sourced from Git.
func (*GitChartSource) DeepCopy ¶
func (in *GitChartSource) DeepCopy() *GitChartSource
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new GitChartSource.
func (*GitChartSource) DeepCopyInto ¶
func (in *GitChartSource) DeepCopyInto(out *GitChartSource)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (GitChartSource) RefOrDefault ¶
func (s GitChartSource) RefOrDefault(defaultGitRef string) string
RefOrDefault returns the configured ref of the chart source. If the chart source does not specify a ref, the provided default is used instead.
type HelmRelease ¶
type HelmRelease struct { metav1.TypeMeta `json:",inline"` metav1.ObjectMeta `json:"metadata"` Spec HelmReleaseSpec `json:"spec"` Status HelmReleaseStatus `json:"status,omitempty"` }
HelmRelease is a type to represent a Helm release. +k8s:openapi-gen=true +kubebuilder:printcolumn:name="Release",type="string",JSONPath=".status.releaseName",description="Release is the name of the Helm release, as given by Helm." +kubebuilder:printcolumn:name="Phase",type="string",JSONPath=".status.phase",description="Phase is the current release phase being performed for the HelmRelease." +kubebuilder:printcolumn:name="ReleaseStatus",type="string",JSONPath=".status.releaseStatus",description="ReleaseStatus is the status of the Helm release, as given by Helm." +kubebuilder:printcolumn:name="Message",type="string",JSONPath=".status.conditions[?(@.type==\"Released\")].message",description="" +kubebuilder:printcolumn:name="Age",type="date",JSONPath=".metadata.creationTimestamp",description="CreationTimestamp is a timestamp representing the server time when this object was created. It is not guaranteed to be set in happens-before order across separate operations. Clients may not set this value. It is represented in RFC3339 form and is in UTC." +kubebuilder:subresource:status +kubebuilder:resource:path=helmreleases,shortName=hr;hrs
func (*HelmRelease) DeepCopy ¶
func (in *HelmRelease) DeepCopy() *HelmRelease
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HelmRelease.
func (*HelmRelease) DeepCopyInto ¶
func (in *HelmRelease) DeepCopyInto(out *HelmRelease)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (*HelmRelease) DeepCopyObject ¶
func (in *HelmRelease) DeepCopyObject() runtime.Object
DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
func (HelmRelease) GetDefaultedNamespace ¶
func (hr HelmRelease) GetDefaultedNamespace() string
GetDefaultedNamespace returns the HelmRelease's namespace defaulting to the "default" if not set.
func (HelmRelease) GetHelmVersion ¶
func (hr HelmRelease) GetHelmVersion(defaultVersion string) string
func (HelmRelease) GetMaxHistory ¶
func (hr HelmRelease) GetMaxHistory() int
GetMaxHistory returns the maximum number of release revisions to keep (defaults to 10)
func (HelmRelease) GetReleaseName ¶
func (hr HelmRelease) GetReleaseName() string
GetReleaseName returns the configured release name, or constructs and returns one based on the namespace and name of the HelmRelease. When the HelmRelease's metadata.namespace and spec.targetNamespace differ, both are used in the generated name. This name is used for naming and operating on the release in Helm.
func (HelmRelease) GetReuseValues ¶
func (hr HelmRelease) GetReuseValues() bool
GetReuseValues returns if the values of the previous release should be reused based on the value of `ResetValues`. When this value is not explicitly set, it is assumed values should not be reused, as this aligns with the declarative behaviour of the operator.
func (HelmRelease) GetTargetNamespace ¶
func (hr HelmRelease) GetTargetNamespace() string
GetTargetNamespace returns the configured release targetNamespace defaulting to the namespace of the HelmRelease if not set.
func (HelmRelease) GetTimeout ¶
func (hr HelmRelease) GetTimeout() time.Duration
GetTimeout returns the install or upgrade timeout (defaults to 300s)
func (HelmRelease) GetValuesFromSources ¶
func (hr HelmRelease) GetValuesFromSources() []ValuesFromSource
GetValuesFromSources maintains backwards compatibility with ValueFileSecrets by merging them into the ValuesFrom array.
func (HelmRelease) ResourceID ¶
func (hr HelmRelease) ResourceID() resource.ID
ResourceID returns an ID made from the identifying parts of the resource, as a convenience for Flux, which uses them everywhere.
type HelmReleaseCondition ¶
type HelmReleaseCondition struct { // Type of the condition, one of ('ChartFetched', 'Released', 'RolledBack'). Type HelmReleaseConditionType `json:"type"` // Status of the condition, one of ('True', 'False', 'Unknown'). Status ConditionStatus `json:"status"` // LastUpdateTime is the timestamp corresponding to the last status // update of this condition. // +optional LastUpdateTime *metav1.Time `json:"lastUpdateTime,omitempty"` // LastTransitionTime is the timestamp corresponding to the last status // change of this condition. // +optional LastTransitionTime *metav1.Time `json:"lastTransitionTime,omitempty"` // Reason is a brief machine readable explanation for the condition's last // transition. // +optional Reason string `json:"reason,omitempty"` // Message is a human readable description of the details of the last // transition, complementing reason. // +optional Message string `json:"message,omitempty"` }
func (*HelmReleaseCondition) DeepCopy ¶
func (in *HelmReleaseCondition) DeepCopy() *HelmReleaseCondition
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HelmReleaseCondition.
func (*HelmReleaseCondition) DeepCopyInto ¶
func (in *HelmReleaseCondition) DeepCopyInto(out *HelmReleaseCondition)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type HelmReleaseConditionType ¶
type HelmReleaseConditionType string
HelmReleaseConditionType represents an HelmRelease condition value. Valid HelmReleaseConditionType values are: "ChartFetched", "Released", "RolledBack" +kubebuilder:validation:Enum="ChartFetched";"Released";"RolledBack" +optional
const ( // ChartFetched means the chart to which the HelmRelease refers // has been fetched successfully. HelmReleaseChartFetched HelmReleaseConditionType = "ChartFetched" // Released means the chart release, as specified in this // HelmRelease, has been processed by Helm. HelmReleaseReleased HelmReleaseConditionType = "Released" // RolledBack means the chart to which the HelmRelease refers // has been rolled back. HelmReleaseRolledBack HelmReleaseConditionType = "RolledBack" )
type HelmReleaseList ¶
type HelmReleaseList struct { metav1.TypeMeta `json:",inline"` metav1.ListMeta `json:"metadata"` Items []HelmRelease `json:"items"` }
HelmReleaseList is a list of HelmReleases
func (*HelmReleaseList) DeepCopy ¶
func (in *HelmReleaseList) DeepCopy() *HelmReleaseList
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HelmReleaseList.
func (*HelmReleaseList) DeepCopyInto ¶
func (in *HelmReleaseList) DeepCopyInto(out *HelmReleaseList)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (*HelmReleaseList) DeepCopyObject ¶
func (in *HelmReleaseList) DeepCopyObject() runtime.Object
DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
type HelmReleasePhase ¶
type HelmReleasePhase string
HelmReleasePhase represents the phase a HelmRelease is in. Valid HelmReleasePhase values are: "ChartFetched", "ChartFetchFailed", "Installing", "Upgrading", "Succeeded", "Failed", "RollingBack", "RolledBack", "RollbackFailed", +kubebuilder:validation:Enum="ChartFetched";"ChartFetchFailed";"Installing";"Upgrading";"Succeeded";"Failed";"RollingBack";"RolledBack";"RollbackFailed" +optional
const ( // ChartFetched means the chart to which the HelmRelease refers // has been fetched successfully HelmReleasePhaseChartFetched HelmReleasePhase = "ChartFetched" // ChartFetchedFailed means the chart to which the HelmRelease // refers could not be fetched. HelmReleasePhaseChartFetchFailed HelmReleasePhase = "ChartFetchFailed" // Installing means the installation for the HelmRelease is running. HelmReleasePhaseInstalling HelmReleasePhase = "Installing" // Upgrading means the upgrade for the HelmRelease is running. HelmReleasePhaseUpgrading HelmReleasePhase = "Upgrading" // Succeeded means the installation or upgrade for the HelmRelease // succeeded. HelmReleasePhaseSucceeded HelmReleasePhase = "Succeeded" // Failed means the installation or upgrade for the HelmRelease // failed. HelmReleasePhaseFailed HelmReleasePhase = "Failed" // RollingBack means a rollback for the HelmRelease is running. HelmReleasePhaseRollingBack HelmReleasePhase = "RollingBack" // RolledBack means the HelmRelease has been rolled back. HelmReleasePhaseRolledBack HelmReleasePhase = "RolledBack" // RolledBackFailed means the rollback for the HelmRelease failed. HelmReleasePhaseRollbackFailed HelmReleasePhase = "RollbackFailed" )
type HelmReleaseSpec ¶
type HelmReleaseSpec struct { HelmVersion `json:"helmVersion,omitempty"` // +kubebuilder:validation:Required ChartSource `json:"chart"` // ReleaseName is the name of the The Helm release. If not supplied, // it will be generated by affixing the namespace to the resource // name. ReleaseName string `json:"releaseName,omitempty"` // MaxHistory is the maximum amount of revisions to keep for the // Helm release. If not supplied, it defaults to 10. MaxHistory *int `json:"maxHistory,omitempty"` // ValueFileSecrets holds the local name references to secrets. // DEPRECATED, use ValuesFrom.secretKeyRef instead. ValueFileSecrets []LocalObjectReference `json:"valueFileSecrets,omitempty"` ValuesFrom []ValuesFromSource `json:"valuesFrom,omitempty"` // TargetNamespace overrides the targeted namespace for the Helm // release. The default namespace equals to the namespace of the // HelmRelease resource. // +optional TargetNamespace string `json:"targetNamespace,omitempty"` // Timeout is the time to wait for any individual Kubernetes // operation (like Jobs for hooks) during installation and // upgrade operations. // +optional Timeout *int64 `json:"timeout,omitempty"` // ResetValues will mark this Helm release to reset the values // to the defaults of the targeted chart before performing // an upgrade. Not explicitly setting this to `false` equals // to `true` due to the declarative nature of the operator. // +optional ResetValues *bool `json:"resetValues,omitempty"` // SkipCRDs will mark this Helm release to skip the creation // of CRDs during a Helm 3 installation. // +optional SkipCRDs bool `json:"skipCRDs,omitempty"` // Wait will mark this Helm release to wait until all Pods, // PVCs, Services, and minimum number of Pods of a Deployment, // StatefulSet, or ReplicaSet are in a ready state before marking // the release as successful. // +optional Wait bool `json:"wait,omitempty"` // Force will mark this Helm release to `--force` upgrades. This // forces the resource updates through delete/recreate if needed. // +optional ForceUpgrade bool `json:"forceUpgrade,omitempty"` // The rollback settings for this Helm release. // +optional Rollback Rollback `json:"rollback,omitempty"` // Values holds the values for this Helm release. // +optional Values HelmValues `json:"values,omitempty"` }
func (*HelmReleaseSpec) DeepCopy ¶
func (in *HelmReleaseSpec) DeepCopy() *HelmReleaseSpec
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HelmReleaseSpec.
func (*HelmReleaseSpec) DeepCopyInto ¶
func (in *HelmReleaseSpec) DeepCopyInto(out *HelmReleaseSpec)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type HelmReleaseStatus ¶
type HelmReleaseStatus struct { // ObservedGeneration is the most recent generation observed by // the operator. // +optional ObservedGeneration int64 `json:"observedGeneration,omitempty"` // Phase the release is in, one of ('ChartFetched', // 'ChartFetchFailed', 'Installing', 'Upgrading', 'Succeeded', // 'RollingBack', 'RolledBack', 'RollbackFailed') // +optional Phase HelmReleasePhase `json:"phase,omitempty"` // ReleaseName is the name as either supplied or generated. // +optional ReleaseName string `json:"releaseName,omitempty"` // ReleaseStatus is the status as given by Helm for the release // managed by this resource. // +optional ReleaseStatus string `json:"releaseStatus,omitempty"` // Revision holds the Git hash or version of the chart currently // deployed. // +optional Revision string `json:"revision,omitempty"` // RollbackCount records the amount of rollback attempts made, // it is incremented after a rollback failure and reset after a // successful upgrade or revision change. // +optional RollbackCount int64 `json:"rollbackCount,omitempty"` // Conditions contains observations of the resource's state, e.g., // has the chart which it refers to been fetched. // +optional // +patchMergeKey=type // +patchStrategy=merge Conditions []HelmReleaseCondition `json:"conditions,omitempty" patchStrategy:"merge" patchMergeKey:"type"` }
HelmReleaseStatus contains status information about an HelmRelease.
func (*HelmReleaseStatus) DeepCopy ¶
func (in *HelmReleaseStatus) DeepCopy() *HelmReleaseStatus
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HelmReleaseStatus.
func (*HelmReleaseStatus) DeepCopyInto ¶
func (in *HelmReleaseStatus) DeepCopyInto(out *HelmReleaseStatus)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type HelmValues ¶
type HelmValues struct { // Data holds the configuration keys and values. // Work around for https://github.com/kubernetes-sigs/kubebuilder/issues/528 Data map[string]interface{} `json:"-"` }
func (*HelmValues) DeepCopy ¶
func (in *HelmValues) DeepCopy() *HelmValues
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HelmValues.
func (*HelmValues) DeepCopyInto ¶
func (in *HelmValues) DeepCopyInto(out *HelmValues)
DeepCopyInto is an deepcopy function, copying the receiver, writing into out. In must be non-nil. Declaring this here prevents it from being generated in `zz_generated.deepcopy.go`.
This exists here to work around https://github.com/kubernetes/code-generator/issues/50, and partially around https://github.com/kubernetes-sigs/controller-tools/pull/126 and https://github.com/kubernetes-sigs/controller-tools/issues/294.
func (HelmValues) MarshalJSON ¶
func (v HelmValues) MarshalJSON() ([]byte, error)
MarshalJSON marshals the HelmValues data to a JSON blob.
func (*HelmValues) UnmarshalJSON ¶
func (v *HelmValues) UnmarshalJSON(data []byte) error
UnmarshalJSON sets the HelmValues to a copy of data.
type HelmVersion ¶
type HelmVersion string
HelmVersion is the version of Helm to target. If not supplied, the lowest _enabled Helm version_ will be targeted. Valid HelmVersion values are: "v2", "v3" +kubebuilder:validation:Enum="v2";"v3" +optional
const ( HelmV2 HelmVersion = "v2" HelmV3 HelmVersion = "v3" )
type LocalObjectReference ¶
type LocalObjectReference struct {
Name string `json:"name"`
}
func (*LocalObjectReference) DeepCopy ¶
func (in *LocalObjectReference) DeepCopy() *LocalObjectReference
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new LocalObjectReference.
func (*LocalObjectReference) DeepCopyInto ¶
func (in *LocalObjectReference) DeepCopyInto(out *LocalObjectReference)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type OptionalConfigMapKeySelector ¶
type OptionalConfigMapKeySelector struct { ConfigMapKeySelector `json:",inline"` // +optional Optional bool `json:"optional,omitempty"` }
func (*OptionalConfigMapKeySelector) DeepCopy ¶
func (in *OptionalConfigMapKeySelector) DeepCopy() *OptionalConfigMapKeySelector
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new OptionalConfigMapKeySelector.
func (*OptionalConfigMapKeySelector) DeepCopyInto ¶
func (in *OptionalConfigMapKeySelector) DeepCopyInto(out *OptionalConfigMapKeySelector)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type OptionalSecretKeySelector ¶
type OptionalSecretKeySelector struct { SecretKeySelector `json:",inline"` // +optional Optional bool `json:"optional,omitempty"` }
func (*OptionalSecretKeySelector) DeepCopy ¶
func (in *OptionalSecretKeySelector) DeepCopy() *OptionalSecretKeySelector
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new OptionalSecretKeySelector.
func (*OptionalSecretKeySelector) DeepCopyInto ¶
func (in *OptionalSecretKeySelector) DeepCopyInto(out *OptionalSecretKeySelector)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type RepoChartSource ¶
type RepoChartSource struct { // RepoURL is the URL of the Helm repository, e.g. // https://kubernetes-charts.storage.googleapis.com or // https://charts.example.com. // +kubebuilder:validation:Optional RepoURL string `json:"repository"` // Name is the name of the Helm chart _without_ an alias, e.g. // redis (for `helm upgrade [flags] stable/redis`). // +kubebuilder:validation:Optional Name string `json:"name"` // Version is the targeted Helm chart version, e.g. 7.0.1. // +kubebuilder:validation:Optional Version string `json:"version"` // ChartPullSecret holds the reference to the authentication secret for accessing // the Helm repository using HTTPS basic auth. // NOT IMPLEMENTED! // +kubebuilder:validation:Optional // +optional ChartPullSecret *LocalObjectReference `json:"chartPullSecret,omitempty"` }
RepoChartSources describes a Helm chart sourced from a Helm repository.
func (RepoChartSource) CleanRepoURL ¶
func (s RepoChartSource) CleanRepoURL() string
CleanRepoURL returns the RepoURL but ensures it ends with a trailing slash.
func (*RepoChartSource) DeepCopy ¶
func (in *RepoChartSource) DeepCopy() *RepoChartSource
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RepoChartSource.
func (*RepoChartSource) DeepCopyInto ¶
func (in *RepoChartSource) DeepCopyInto(out *RepoChartSource)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type Rollback ¶
type Rollback struct { // Enable will mark this Helm release for rollbacks. // +optional Enable bool `json:"enable,omitempty"` // Retry will mark this Helm release for upgrade retries after a // rollback. // +optional Retry bool `json:"retry,omitempty"` // MaxRetries is the maximum amount of upgrade retries the operator // should make before bailing. // +optional MaxRetries *int64 `json:"maxRetries,omitempty"` // Force will mark this Helm release to `--force` rollbacks. This // forces the resource updates through delete/recreate if needed. // +optional Force bool `json:"force,omitempty"` // Recreate will mark this Helm release to `--recreate-pods` for // if applicable. This performs pod restarts. // +optional Recreate bool `json:"recreate,omitempty"` // DisableHooks will mark this Helm release to prevent hooks from // running during the rollback. // +optional DisableHooks bool `json:"disableHooks,omitempty"` // Timeout is the time to wait for any individual Kubernetes // operation (like Jobs for hooks) during rollback. // +optional Timeout *int64 `json:"timeout,omitempty"` // Wait will mark this Helm release to wait until all Pods, // PVCs, Services, and minimum number of Pods of a Deployment, // StatefulSet, or ReplicaSet are in a ready state before marking // the release as successful. // +optional Wait bool `json:"wait,omitempty"` }
func (*Rollback) DeepCopy ¶
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Rollback.
func (*Rollback) DeepCopyInto ¶
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (Rollback) GetMaxRetries ¶
GetMaxRetries returns the configured max retries for the Helm release, or the default of 5.
func (Rollback) GetTimeout ¶
GetTimeout returns the configured timout for the Helm release, or the default of 300s.
type SecretKeySelector ¶
type SecretKeySelector struct { LocalObjectReference `json:",inline"` // +optional Namespace string `json:"namespace,omitempty"` // +optional Key string `json:"key,omitempty"` }
func (*SecretKeySelector) DeepCopy ¶
func (in *SecretKeySelector) DeepCopy() *SecretKeySelector
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SecretKeySelector.
func (*SecretKeySelector) DeepCopyInto ¶
func (in *SecretKeySelector) DeepCopyInto(out *SecretKeySelector)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
type ValuesFromSource ¶
type ValuesFromSource struct { // The reference to a config map with release values. // +optional ConfigMapKeyRef *OptionalConfigMapKeySelector `json:"configMapKeyRef,omitempty"` // The reference to a secret with release values. // +optional SecretKeyRef *OptionalSecretKeySelector `json:"secretKeyRef,omitempty"` // The reference to an external source with release values. // +optional ExternalSourceRef *ExternalSourceSelector `json:"externalSourceRef,omitempty"` // The reference to a local chart file with release values. // +optional ChartFileRef *ChartFileSelector `json:"chartFileRef,omitempty"` }
func (*ValuesFromSource) DeepCopy ¶
func (in *ValuesFromSource) DeepCopy() *ValuesFromSource
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ValuesFromSource.
func (*ValuesFromSource) DeepCopyInto ¶
func (in *ValuesFromSource) DeepCopyInto(out *ValuesFromSource)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.