mirror of
https://github.com/k3s-io/k3s.git
synced 2024-06-07 19:41:36 +00:00
164 lines
4.3 KiB
Go
164 lines
4.3 KiB
Go
|
// Copyright 2019 The Kubernetes Authors.
|
||
|
// SPDX-License-Identifier: Apache-2.0
|
||
|
|
||
|
package resmap
|
||
|
|
||
|
import (
|
||
|
"github.com/pkg/errors"
|
||
|
"sigs.k8s.io/kustomize/api/ifc"
|
||
|
"sigs.k8s.io/kustomize/api/internal/kusterr"
|
||
|
"sigs.k8s.io/kustomize/api/resource"
|
||
|
"sigs.k8s.io/kustomize/api/types"
|
||
|
"sigs.k8s.io/kustomize/kyaml/yaml"
|
||
|
)
|
||
|
|
||
|
// Factory makes instances of ResMap.
|
||
|
type Factory struct {
|
||
|
// Makes resources.
|
||
|
resF *resource.Factory
|
||
|
// Makes ConflictDetectors.
|
||
|
cdf resource.ConflictDetectorFactory
|
||
|
}
|
||
|
|
||
|
// NewFactory returns a new resmap.Factory.
|
||
|
func NewFactory(
|
||
|
rf *resource.Factory, cdf resource.ConflictDetectorFactory) *Factory {
|
||
|
return &Factory{resF: rf, cdf: cdf}
|
||
|
}
|
||
|
|
||
|
// RF returns a resource.Factory.
|
||
|
func (rmF *Factory) RF() *resource.Factory {
|
||
|
return rmF.resF
|
||
|
}
|
||
|
|
||
|
func New() ResMap {
|
||
|
return newOne()
|
||
|
}
|
||
|
|
||
|
// FromResource returns a ResMap with one entry.
|
||
|
func (rmF *Factory) FromResource(res *resource.Resource) ResMap {
|
||
|
m, err := newResMapFromResourceSlice([]*resource.Resource{res})
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
return m
|
||
|
}
|
||
|
|
||
|
// FromResourceSlice returns a ResMap with a slice of resources.
|
||
|
func (rmF *Factory) FromResourceSlice(ress []*resource.Resource) ResMap {
|
||
|
m, err := newResMapFromResourceSlice(ress)
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
return m
|
||
|
}
|
||
|
|
||
|
// FromFile returns a ResMap given a resource path.
|
||
|
func (rmF *Factory) FromFile(
|
||
|
loader ifc.Loader, path string) (ResMap, error) {
|
||
|
content, err := loader.Load(path)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
m, err := rmF.NewResMapFromBytes(content)
|
||
|
if err != nil {
|
||
|
return nil, kusterr.Handler(err, path)
|
||
|
}
|
||
|
return m, nil
|
||
|
}
|
||
|
|
||
|
// NewResMapFromBytes decodes a list of objects in byte array format.
|
||
|
func (rmF *Factory) NewResMapFromBytes(b []byte) (ResMap, error) {
|
||
|
resources, err := rmF.resF.SliceFromBytes(b)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return newResMapFromResourceSlice(resources)
|
||
|
}
|
||
|
|
||
|
// NewResMapFromConfigMapArgs returns a Resource slice given
|
||
|
// a configmap metadata slice from kustomization file.
|
||
|
func (rmF *Factory) NewResMapFromConfigMapArgs(
|
||
|
kvLdr ifc.KvLoader, argList []types.ConfigMapArgs) (ResMap, error) {
|
||
|
var resources []*resource.Resource
|
||
|
for _, args := range argList {
|
||
|
res, err := rmF.resF.MakeConfigMap(kvLdr, &args)
|
||
|
if err != nil {
|
||
|
return nil, errors.Wrap(err, "NewResMapFromConfigMapArgs")
|
||
|
}
|
||
|
resources = append(resources, res)
|
||
|
}
|
||
|
return newResMapFromResourceSlice(resources)
|
||
|
}
|
||
|
|
||
|
// FromConfigMapArgs creates a new ResMap containing one ConfigMap.
|
||
|
func (rmF *Factory) FromConfigMapArgs(
|
||
|
kvLdr ifc.KvLoader, args types.ConfigMapArgs) (ResMap, error) {
|
||
|
res, err := rmF.resF.MakeConfigMap(kvLdr, &args)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return rmF.FromResource(res), nil
|
||
|
}
|
||
|
|
||
|
// NewResMapFromSecretArgs takes a SecretArgs slice, generates
|
||
|
// secrets from each entry, and accumulates them in a ResMap.
|
||
|
func (rmF *Factory) NewResMapFromSecretArgs(
|
||
|
kvLdr ifc.KvLoader, argsList []types.SecretArgs) (ResMap, error) {
|
||
|
var resources []*resource.Resource
|
||
|
for _, args := range argsList {
|
||
|
res, err := rmF.resF.MakeSecret(kvLdr, &args)
|
||
|
if err != nil {
|
||
|
return nil, errors.Wrap(err, "NewResMapFromSecretArgs")
|
||
|
}
|
||
|
resources = append(resources, res)
|
||
|
}
|
||
|
return newResMapFromResourceSlice(resources)
|
||
|
}
|
||
|
|
||
|
// FromSecretArgs creates a new ResMap containing one secret.
|
||
|
func (rmF *Factory) FromSecretArgs(
|
||
|
kvLdr ifc.KvLoader, args types.SecretArgs) (ResMap, error) {
|
||
|
res, err := rmF.resF.MakeSecret(kvLdr, &args)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return rmF.FromResource(res), nil
|
||
|
}
|
||
|
|
||
|
// ConflatePatches creates a new ResMap containing a merger of the
|
||
|
// incoming patches.
|
||
|
// Error if conflict found.
|
||
|
func (rmF *Factory) ConflatePatches(patches []*resource.Resource) (ResMap, error) {
|
||
|
return (&merginator{cdf: rmF.cdf}).ConflatePatches(patches)
|
||
|
}
|
||
|
|
||
|
func newResMapFromResourceSlice(
|
||
|
resources []*resource.Resource) (ResMap, error) {
|
||
|
result := New()
|
||
|
for _, res := range resources {
|
||
|
err := result.Append(res)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
}
|
||
|
return result, nil
|
||
|
}
|
||
|
|
||
|
// NewResMapFromRNodeSlice returns a ResMap from a slice of RNodes
|
||
|
func (rmF *Factory) NewResMapFromRNodeSlice(rnodes []*yaml.RNode) (ResMap, error) {
|
||
|
var resources []*resource.Resource
|
||
|
for _, rnode := range rnodes {
|
||
|
s, err := rnode.String()
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
r, err := rmF.resF.SliceFromBytes([]byte(s))
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
resources = append(resources, r...)
|
||
|
}
|
||
|
return newResMapFromResourceSlice(resources)
|
||
|
}
|