provider

package
v0.0.0-...-59ba1d5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 21, 2021 License: Apache-2.0 Imports: 7 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type DepProvider

type DepProvider struct {
	// contains filtered or unexported fields
}

DepProvider is a dependency provider.

The instances it returns are either

  • old implementations backed by k8sdeps code,
  • new implementations backed by kyaml code.

History:

kubectl depends on k8s.io code, and at the time of writing, so does kustomize. Code that imports k8s.io/api* cannot be imported back into k8s.io/*, yet kustomize appears inside k8s.io/kubectl.

To allow kustomize to appear inside kubectl, yet still be developed outside kubectl, the kustomize code was divided into the following packages

api/
  k8sdeps/  (and internal/ks8deps/)
  ifc/
  krusty/
  everythingElse/

with the following rules:

  • Only k8sdeps/ may import k8s.io/api*.

  • Only krusty/ (and its internals) may import k8sdeps/. I.e., ifc/ and everythingElse/ must not import k8sdeps/ or k8s.io/api*.

  • Code in krusty/ may use code in k8sdeps/ to create objects then inject said objects into everythingElse/ behind dependency neutral interfaces.

The idea was to periodically copy, not import, the large k8sdeps/ tree (plus a snippet from krusty/kustomizer.go) into the kubectl codebase via a large PR, and have kubectl depend on the rest via normal importing.

Over 2019, however, kubectl underwent large changes including a switch to Go modules, and a concerted attempt to extract kubectl from the k8s repo. This made large kustomize integration PRs too intrusive to review.

In 2020, kubectl is based on Go modules, and almost entirely extracted from the k8s.io repositories, and further the kyaml library has a appeared as a viable replacement to k8s.io/api* KRM manipulation code.

The new plan is to eliminate k8sdeps/ entirely, along with its k8s.io/api* dependence, allowing kustomize code to be imported into kubectl via normal Go module imports. Then the kustomize API code can then move into the github.com/kubernetes-sigs/cli-utils repo. The kustomize CLI in github.com/kubernetes-sigs/kustomize and the kubectl CLI can then both depend on the kustomize API.

So, all code that depends on k8sdeps must go behind interfaces, and kustomize must be factored to choose the implementation.

That problem has been reduced to three interfaces, each having two implementations. (1) is k8sdeps-based, (2) is kyaml-based.

  • ifc.Kunstructured

    1) api/k8sdeps/kunstruct.UnstructAdapter

    This adapts structs in k8s.io/apimachinery/pkg/apis/meta/v1/unstructured to ifc.Kunstructured.

    2) api/wrappy.WNode

    This adapts sigs.k8s.io/kustomize/kyaml/yaml.RNode to ifc.Unstructured.

    At time of writing, implementation started. Further reducing the size of ifc.Kunstructed would really reduce the work (e.g. drop Vars, drop ReplacementTranformer).

  • resource.ConflictDetector

    1) api/internal/k8sdeps/conflict.conflictDetectorJson api/internal/k8sdeps/conflict.conflictDetectorSm

    Uses k8s.io/apimachinery/pkg/util/strategicpatch, apimachinery/pkg/util/mergepatch, etc. to merge resource.Resource instances.

    2) api/internal/conflict.smPatchMergeOnlyDetector

    At time of writing, this doesn't report conflicts, but it does know how to merge patches. Conflict reporting isn't vital to kustomize function. It's rare that a person would configure one transformer with many patches, much less so many that it became hard to spot conflicts. In the case of an undetected conflict, the last patch applied wins, likely what the user wants anyway. Regardless, the effect of this is plainly visible and usable in the output, even if a conflict happened but wasn't reported as an error.

  • ifc.Validator

    1) api/k8sdeps/validator.KustValidator

    Uses k8s.io/apimachinery/pkg/api/validation and friends to validate strings.

    2) api/internal/validate.FieldValidator

    See TODO inside the validator for status. At time of writing, this is a do-nothing validator as it's not critical to kustomize function.

Proposed plan:

[x] Ship kustomize with the ability to switch from 1 to 2 via
    an --enable_kyaml flag.
[x] Make --enable_kyaml true by default.
[x] When 2 is not noticeably more buggy than 1, delete 1.
    I.e. delete k8sdeps/, transitively deleting all k8s.io/api* deps.
    This DepProvider should be left in place to retain these
    comments, but it will have only one choice.
[x] The way is now clear to reintegrate into kubectl.
    This should be done ASAP; the last step is cleanup.
[ ] Cleanup.  With only one impl of Kunstructure remaining,
    that interface and WNode can be deleted, along with this
    DepProvider.  The other two interfaces could be dropped too.

When the above is done, kustomize will use yaml.RNode and/or KRM Config Functions directly and exclusively. If you're reading this, plan not done.

func NewDefaultDepProvider

func NewDefaultDepProvider() *DepProvider

func NewDepProvider

func NewDepProvider(useKyaml bool) *DepProvider

func (*DepProvider) GetConflictDetectorFactory

func (dp *DepProvider) GetConflictDetectorFactory() resource.ConflictDetectorFactory

func (*DepProvider) GetFieldValidator

func (dp *DepProvider) GetFieldValidator() ifc.Validator

func (*DepProvider) GetKunstructuredFactory

func (dp *DepProvider) GetKunstructuredFactory() ifc.KunstructuredFactory

func (*DepProvider) GetResourceFactory

func (dp *DepProvider) GetResourceFactory() *resource.Factory

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL