Documentation ¶
Overview ¶
Copyright 2019 The Knative Authors
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Index ¶
- Constants
- Variables
- func AppendAdditionalManifests(ctx context.Context, manifest *mf.Manifest, instance base.KComponent) error
- func AppendInstalled(ctx context.Context, manifest *mf.Manifest, instance base.KComponent) error
- func AppendTarget(ctx context.Context, manifest *mf.Manifest, instance base.KComponent) error
- func CheckDeployments(ctx context.Context, manifest *mf.Manifest, instance base.KComponent) error
- func ClearCache()
- func ClusterScopedResource(apiVersion, kind, name string) *unstructured.Unstructured
- func ConfigMapTransform(config base.ConfigMapData, log *zap.SugaredLogger) mf.Transformer
- func DeploymentsTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
- func FetchManifest(path string) (mf.Manifest, error)
- func FinalizerRemovalPatch(obj base.KComponent, toRemove string) ([]byte, error)
- func GetLatestIngressRelease(version string) string
- func HighAvailabilityTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
- func ImageTransform(registry *base.Registry, log *zap.SugaredLogger) mf.Transformer
- func Install(ctx context.Context, manifest *mf.Manifest, instance base.KComponent) error
- func InstalledManifest(instance base.KComponent) (mf.Manifest, error)
- func IsVersionValidMigrationEligible(instance base.KComponent) error
- func JobTransform(obj base.KComponent) mf.Transformer
- func MigrateCustomResource(ctx context.Context, dynamicClient dynamic.Interface, ...) error
- func NamespacedResource(apiVersion, kind, ns, name string) *unstructured.Unstructured
- func NoOp(context.Context, *mf.Manifest, base.KComponent) error
- func ResourceRequirementsTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
- func SanitizeSemver(version string) string
- func ServicesTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
- func TargetAdditionalManifest(instance base.KComponent) (mf.Manifest, error)
- func TargetManifest(instance base.KComponent) (mf.Manifest, error)
- func TargetVersion(instance base.KComponent) string
- func Transform(ctx context.Context, manifest *mf.Manifest, instance base.KComponent, ...) error
- func Uninstall(manifest *mf.Manifest) error
- func UpdateConfigMap(cm *unstructured.Unstructured, data map[string]string, log *zap.SugaredLogger) error
- type Extension
- type ExtensionGenerator
- type ManifestFetcher
- type Stage
- type Stages
Constants ¶
const ( // KoEnvKey is the key of the environment variable to specify the path to the ko data directory KoEnvKey = "KO_DATA_PATH" // VersionVariable is a string, which can be replaced with the value of spec.version VersionVariable = "${VERSION}" // COMMA is the character comma COMMA = "," // LATEST_VERSION is the special version Knative Operator support, besides all semantic versions of Knative. LATEST_VERSION = "latest" )
Variables ¶
var (
OperatorCRDs = []string{"knativeservings.operator.knative.dev", "knativeeventings.operator.knative.dev"}
)
Functions ¶
func AppendAdditionalManifests ¶ added in v0.22.0
func AppendAdditionalManifests(ctx context.Context, manifest *mf.Manifest, instance base.KComponent) error
AppendAdditionalManifests mutates the passed manifest by appending the manifests specified with the field spec.additionalManifests.
func AppendInstalled ¶ added in v0.16.0
AppendInstalled mutates the passed manifest by appending one appropriate for the passed KComponent, which may not be the one corresponding to status.version
func AppendTarget ¶ added in v0.16.0
AppendTarget mutates the passed manifest by appending one appropriate for the passed KComponent
func CheckDeployments ¶
CheckDeployments checks all deployments in the given manifest and updates the given status with the status of the deployments.
func ClearCache ¶ added in v0.22.0
func ClearCache()
ClearCache removes all the records saved in the cache.
func ClusterScopedResource ¶
func ClusterScopedResource(apiVersion, kind, name string) *unstructured.Unstructured
ClusterScopedResource is an unstructured resource with the given apiVersion, kind and name.
func ConfigMapTransform ¶
func ConfigMapTransform(config base.ConfigMapData, log *zap.SugaredLogger) mf.Transformer
ConfigMapTransform updates the ConfigMap with the values specified in operator CR
func DeploymentsTransform ¶ added in v0.21.0
func DeploymentsTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
DeploymentTransform transforms deployments based on the configuration in `spec.deployment`.
func FetchManifest ¶ added in v0.21.0
FetchManifest returns the manifest by either getting it from the cache, or reading them from the path. The manifest is saved in the cache, if it is not available.
func FinalizerRemovalPatch ¶
func FinalizerRemovalPatch(obj base.KComponent, toRemove string) ([]byte, error)
FinalizerRemovalPatch generates a patch for removing the given finalizer.
func GetLatestIngressRelease ¶ added in v0.23.0
GetLatestIngressRelease returns the latest release tag available under kodata directory for the ingress based on spec.version.
func HighAvailabilityTransform ¶ added in v0.21.0
func HighAvailabilityTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
HighAvailabilityTransform mutates configmaps and replicacounts of certain controllers when HA control plane is specified.
func ImageTransform ¶
func ImageTransform(registry *base.Registry, log *zap.SugaredLogger) mf.Transformer
ImageTransform updates image with a new registry and tag
func Install ¶
Install applies the manifest resources for the given version and updates the given status accordingly.
func InstalledManifest ¶ added in v0.16.0
func InstalledManifest(instance base.KComponent) (mf.Manifest, error)
InstalledManifest returns the version currently installed, which is harder than it sounds, since status.version isn't set until the target version is successfully installed, which can take some time. So we return the target manifest if status.version is empty.
func IsVersionValidMigrationEligible ¶ added in v0.19.0
func IsVersionValidMigrationEligible(instance base.KComponent) error
IsVersionValidMigrationEligible returns the bool indicate whether the target version is valid and the installed manifest is able to upgrade or downgrade to the target manifest.
func JobTransform ¶ added in v0.16.0
func JobTransform(obj base.KComponent) mf.Transformer
JobTransform updates the job with the expected value for the key app in the label
func MigrateCustomResource ¶ added in v0.32.2
func MigrateCustomResource(ctx context.Context, dynamicClient dynamic.Interface, apixClient apixclient.Interface) error
MigrateCustomResource migrates the existing custom resource from v1alpha1 to v1beta1.
func NamespacedResource ¶
func NamespacedResource(apiVersion, kind, ns, name string) *unstructured.Unstructured
NamespacedResource is an unstructured resource with the given apiVersion, kind, ns and name.
func ResourceRequirementsTransform ¶
func ResourceRequirementsTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
ResourceRequirementsTransform configures the resource requests for all containers within all deployments in the manifest
func SanitizeSemver ¶ added in v0.21.0
SanitizeSemver always adds `v` in front of the version. x.y.z is the standard format we use as the semantic version for Knative. The letter `v` is added for comparison purpose.
func ServicesTransform ¶ added in v0.31.0
func ServicesTransform(obj base.KComponent, log *zap.SugaredLogger) mf.Transformer
ServicesTransform transforms services based on the configuration in `spec.service`.
func TargetAdditionalManifest ¶ added in v0.22.0
func TargetAdditionalManifest(instance base.KComponent) (mf.Manifest, error)
TargetAdditionalManifest returns the manifest for the TargetVersion specified with spec.additionalManifests.
func TargetManifest ¶ added in v0.16.0
func TargetManifest(instance base.KComponent) (mf.Manifest, error)
TargetManifest returns the default manifest for the TargetVersion or the manifest for the TargetVersion specified with spec.manifests
func TargetVersion ¶ added in v0.16.0
func TargetVersion(instance base.KComponent) string
TargetVersion returns the version of the manifest to be installed per the spec in the component. If spec.version is empty, the latest version known to the operator is returned.
func Transform ¶ added in v0.16.0
func Transform(ctx context.Context, manifest *mf.Manifest, instance base.KComponent, extra ...mf.Transformer) error
Transform will mutate the passed-by-reference manifest with one transformed by platform, common, and any extra passed in
func Uninstall ¶
Uninstall removes all resources except CRDs, which are never deleted automatically.
func UpdateConfigMap ¶
func UpdateConfigMap(cm *unstructured.Unstructured, data map[string]string, log *zap.SugaredLogger) error
UpdateConfigMap set some data in a configmap, only overwriting common keys if they differ
Types ¶
type Extension ¶ added in v0.16.0
type Extension interface { Manifests(base.KComponent) ([]mf.Manifest, error) Transformers(base.KComponent) []mf.Transformer Reconcile(context.Context, base.KComponent) error Finalize(context.Context, base.KComponent) error }
Extension enables platform-specific features
func NoExtension ¶ added in v0.16.0
func NoExtension(context.Context, *controller.Impl) Extension
NoPlatform "generates" a NilExtension
type ExtensionGenerator ¶ added in v0.16.0
type ExtensionGenerator func(context.Context, *controller.Impl) Extension
ExtensionGenerator creates an Extension from a Context
type ManifestFetcher ¶ added in v0.16.0
ManifestFetcher returns a manifest appropriate for the instance
type Stage ¶ added in v0.16.0
Stage represents a step in the reconcile process
func DeleteObsoleteResources ¶ added in v0.16.0
func DeleteObsoleteResources(ctx context.Context, instance base.KComponent, fetch ManifestFetcher) Stage
DeleteObsoleteResources returns a Stage after calculating the installed manifest from the instance. This is meant to be called *before* executing the reconciliation stages so that the proper manifest is captured in a closure before any stage might mutate the instance status, e.g. Install.