pulumi/pkg/codegen/docs/gen_kubernetes.go

166 lines
4.4 KiB
Go

// Copyright 2016-2024, Pulumi Corporation.
//
// 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.
//go:generate go run bundler.go
// Pulling out some of the repeated strings tokens into constants would harm readability, so we just ignore the
// goconst linter's warning.
//
//nolint:lll, goconst
package docs
import (
"fmt"
"path"
"strings"
"github.com/pulumi/pulumi/pkg/v3/codegen/schema"
)
func isKubernetesPackage(pkg schema.PackageReference) bool {
return pkg.Name() == "kubernetes"
}
func (mod *modContext) isKubernetesOverlayModule() bool {
// The CustomResource overlay resource is directly under the apiextensions module
// and not under a version, so we include that. The Directory overlay resource is directly under the
// kustomize module. The resources under helm and yaml are always under a version.
return mod.mod == "apiextensions" || mod.mod == "kustomize" ||
strings.HasPrefix(mod.mod, "helm") || strings.HasPrefix(mod.mod, "yaml")
}
func (mod *modContext) isComponentResource() bool {
// TODO: Support this more generally. For now, only the Helm, Kustomize, and YAML overlays use ComponentResources.
return strings.HasPrefix(mod.mod, "helm") ||
strings.HasPrefix(mod.mod, "kustomize") ||
strings.HasPrefix(mod.mod, "yaml")
}
// getKubernetesOverlayPythonFormalParams returns the formal params to render
// for a Kubernetes overlay resource. These resources do not follow convention
// that other resources do, so it is best to manually set these.
func getKubernetesOverlayPythonFormalParams(modName string) []formalParam {
var params []formalParam
switch modName {
case "helm.sh/v2", "helm.sh/v3":
// Chart options.
params = []formalParam{
{
Name: "release_name",
Type: propertyType{Name: "str"},
Comment: "Name of the Chart (e.g., nginx-ingress).",
},
{
Name: "config",
Comment: "Configuration options for the Chart.",
},
{
Name: "opts",
DefaultValue: "=None",
Comment: "A bag of options that control this resource's behavior.",
},
}
case "kustomize":
params = []formalParam{
{
Name: "directory",
},
{
Name: "opts",
DefaultValue: "=None",
},
{
Name: "transformations",
DefaultValue: "=None",
},
{
Name: "resource_prefix",
DefaultValue: "=None",
},
}
case "yaml":
params = []formalParam{
{
Name: "file",
},
{
Name: "opts",
DefaultValue: "=None",
},
{
Name: "transformations",
DefaultValue: "=None",
},
{
Name: "resource_prefix",
DefaultValue: "=None",
},
}
case "apiextensions":
params = []formalParam{
{
Name: "api_version",
},
{
Name: "kind",
},
{
Name: "metadata",
DefaultValue: "=None",
},
{
Name: "opts",
DefaultValue: "=None",
},
}
default:
panic(fmt.Sprintf("Unknown kubernetes overlay module %q", modName))
}
return params
}
func getKubernetesMod(pkg *schema.Package, token string, modules map[string]*modContext, tool string) *modContext {
modName := pkg.TokenToModule(token)
// Kubernetes' moduleFormat in the schema will match everything
// in the token. So strip some well-known domain name parts from the module
// names.
modName = strings.TrimSuffix(modName, ".k8s.io")
modName = strings.TrimSuffix(modName, ".apiserver")
modName = strings.TrimSuffix(modName, ".authorization")
mod, ok := modules[modName]
if !ok {
mod = &modContext{
pkg: pkg.Reference(),
mod: modName,
tool: tool,
}
if modName != "" {
parentName := path.Dir(modName)
// If the parent name is blank, it means this is the package-level.
if parentName == "." || parentName == "" {
parentName = ":index:"
} else {
parentName = ":" + parentName + ":"
}
parent := getKubernetesMod(pkg, parentName, modules, tool)
parent.children = append(parent.children, mod)
}
modules[modName] = mod
}
return mod
}