mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-05-17 18:25:26 +00:00
[doc]: https://github.com/golang/go/wiki/Modules#releasing-modules-v2-or-higher Per this Go modules [doc] a repo or branch that's already tagged v2 or higher should increment the major version (e.g. go to v3) when releasing their first Go module-based packages. At the moment, the kustomize repo has these top level packages in the sigs.k8s.io/kustomize module: - `cmd` - holds main program for kustomize Conceivably someone can depend on this package for integration tests. - `internal` - intentionally unreleased subpackages - `k8sdeps` - an adapter wrapping k8s dependencies This exists only for use in pre-Go-modules kustomize-into-kubectl integration and won't live much longer (as everything involved is switching to Go modules). - `pkg` - kustomize packages for export This should shrink in later versions, since the surface area is too large, containing sub-packages that should be in 'internal'. - `plugin` - holds main programs for plugins This PR changes the top level go.mod file from ``` module sigs.k8s.io/kustomize ``` to ``` module sigs.k8s.io/kustomize/v3 ``` and adjusts all import statements to reflect the change.
57 lines
1.4 KiB
Go
57 lines
1.4 KiB
Go
// Copyright 2019 The Kubernetes Authors.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package main
|
|
|
|
import (
|
|
"sigs.k8s.io/kustomize/v3/pkg/ifc"
|
|
"sigs.k8s.io/kustomize/v3/pkg/resmap"
|
|
"sigs.k8s.io/kustomize/v3/pkg/types"
|
|
"sigs.k8s.io/yaml"
|
|
)
|
|
|
|
// A secret generator example that gets data
|
|
// from a database (simulated by a hardcoded map).
|
|
type plugin struct {
|
|
rf *resmap.Factory
|
|
ldr ifc.Loader
|
|
Name string `json:"name,omitempty" yaml:"name,omitempty"`
|
|
Namespace string `json:"namespace,omitempty" yaml:"namespace,omitempty"`
|
|
// List of keys to use in database lookups
|
|
Keys []string `json:"keys,omitempty" yaml:"keys,omitempty"`
|
|
}
|
|
|
|
//noinspection GoUnusedGlobalVariable
|
|
//nolint: golint
|
|
var KustomizePlugin plugin
|
|
|
|
var database = map[string]string{
|
|
"TREE": "oak",
|
|
"ROCKET": "SaturnV",
|
|
"FRUIT": "apple",
|
|
"VEGETABLE": "carrot",
|
|
"SIMPSON": "homer",
|
|
}
|
|
|
|
func (p *plugin) Config(
|
|
ldr ifc.Loader, rf *resmap.Factory, c []byte) error {
|
|
p.rf = rf
|
|
p.ldr = ldr
|
|
return yaml.Unmarshal(c, p)
|
|
}
|
|
|
|
// The plan here is to convert the plugin's input
|
|
// into the format used by the builtin secret generator plugin.
|
|
func (p *plugin) Generate() (resmap.ResMap, error) {
|
|
args := types.SecretArgs{}
|
|
args.Name = p.Name
|
|
args.Namespace = p.Namespace
|
|
for _, k := range p.Keys {
|
|
if v, ok := database[k]; ok {
|
|
args.LiteralSources = append(
|
|
args.LiteralSources, k+"="+v)
|
|
}
|
|
}
|
|
return p.rf.FromSecretArgs(p.ldr, nil, args)
|
|
}
|