Files
kubevela/references/docgen/openapi.go
Amit Singh 4d6fa58c0f Chore: switches to new oapi type field type (#6794)
* chore: switches to new oapi type field type

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* chore: updates gen_sdk to use the new schema type

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* chore: updates gen_sdk_test to use the new schema type

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* chore: updates schema to use the new schema type

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* fix: updates chart urls

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* chore: changes from make reviewable

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* chore: fixes linting errors

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* debugging test failure

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* fix: fixes schema type nil check

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* chore: replaces literals with constants

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* debugging test failure

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* test: switches to the new addon registry url

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* chore: extra line removal

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* fix: replaces deprecated urls

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* fix: removes extra quotes form marshaljson

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

* fix: updates chart url in mock resource

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>

---------

Signed-off-by: Amit Singh <singhamitch@outlook.com>
Signed-off-by: semmet95 <singhamitch@outlook.com>
Co-authored-by: Vishal Kumar <vishal210893@gmail.com>
2025-06-15 20:44:58 -07:00

90 lines
2.5 KiB
Go

/*
Copyright 2022 The KubeVela Authors.
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.
*/
package docgen
import (
"bytes"
"fmt"
"strconv"
"strings"
"github.com/getkin/kin-openapi/openapi3"
"github.com/olekukonko/tablewriter"
)
// GenerateConsoleDocument generate the document shown on the console.
func GenerateConsoleDocument(title string, schema *openapi3.Schema) (string, error) {
var buffer = &bytes.Buffer{}
var printSubProperties []*openapi3.Schema
if len(schema.Properties) > 0 {
var propertiesTable = tablewriter.NewWriter(buffer)
propertiesTable.SetHeader([]string{"NAME", "TYPE", "DESCRIPTION", "REQUIRED", "OPTIONS", "DEFAULT"})
for key, subSchema := range schema.Properties {
name := subSchema.Value.Title
if title != "" {
name = fmt.Sprintf("(%s).%s", title, name)
}
defaultValue := fmt.Sprintf("%v", subSchema.Value.Default)
if subSchema.Value.Default == nil {
defaultValue = ""
}
var options = ""
for _, enum := range subSchema.Value.Enum {
options += fmt.Sprintf("%v", enum)
}
jsonType, err := subSchema.Value.Type.MarshalJSON()
if err != nil {
return "", fmt.Errorf("error while marshalling openapi schema type:%w", err)
}
typeStr, err := strconv.Unquote(string(jsonType))
if err != nil {
return "", fmt.Errorf("error while unquoting opai schema type:%w", err)
}
propertiesTable.Append([]string{
name,
typeStr,
subSchema.Value.Description,
fmt.Sprintf("%t", strings.Contains(strings.Join(schema.Required, "/"), subSchema.Value.Title)),
options,
defaultValue,
})
if len(subSchema.Value.Properties) > 0 {
printSubProperties = append(printSubProperties, schema.Properties[key].Value)
}
}
buffer.WriteString(title + "\n")
propertiesTable.Render()
}
for _, sub := range printSubProperties {
next := strings.Join([]string{title, sub.Title}, ".")
if title == "" {
next = sub.Title
}
re, err := GenerateConsoleDocument(next, sub)
if err != nil {
return "", err
}
buffer.WriteString(re)
}
return buffer.String(), nil
}