From 76c06a1df2ab86a676f5aec10cb74b41b7418aab Mon Sep 17 00:00:00 2001 From: Tamal Saha Date: Wed, 18 Oct 2023 12:15:21 -0700 Subject: [PATCH] Add enum definition for apiVersion and kind schema Signed-off-by: Tamal Saha --- cmd/gen-docs/main.go | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/cmd/gen-docs/main.go b/cmd/gen-docs/main.go index 90713aead..f0c7d0e46 100644 --- a/cmd/gen-docs/main.go +++ b/cmd/gen-docs/main.go @@ -59,8 +59,6 @@ func GenDescriptor(dir string) error { rdir := filepath.Join(dir, g, r) os.MkdirAll(rdir, 0o755) - // os.WriteFile(filepath.Join(rdir, "crd.yaml"), []byte("crd.yaml"), 0644) - vdir := filepath.Join(rdir, rd.Spec.Resource.Version) os.MkdirAll(vdir, 0o755) @@ -71,7 +69,21 @@ func GenDescriptor(dir string) error { os.WriteFile(filepath.Join(vdir, "resourcedescriptor.yaml"), data, 0o644) if rd.Spec.Validation != nil && rd.Spec.Validation.OpenAPIV3Schema != nil { - data, err := yaml.Marshal(rd.Spec.Validation.OpenAPIV3Schema) + schema := rd.Spec.Validation.OpenAPIV3Schema + if prop, ok := schema.Properties["apiVersion"]; ok { + prop.Enum = []crdv1.JSON{ + {[]byte(fmt.Sprintf("%q", rd.Spec.Resource.GroupVersion()))}, + } + schema.Properties["apiVersion"] = prop + } + if prop, ok := schema.Properties["kind"]; ok { + prop.Enum = []crdv1.JSON{ + {[]byte(fmt.Sprintf("%q", rd.Spec.Resource.Kind))}, + } + schema.Properties["kind"] = prop + } + + data, err := yaml.Marshal(schema) if err != nil { return err }