mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2025-12-31 01:10:20 -06:00
add env var yaml generator
Signed-off-by: Christian Richter <crichter@owncloud.com>
This commit is contained in:
@@ -12,9 +12,10 @@ import (
|
||||
)
|
||||
|
||||
var targets = map[string]string{
|
||||
"adoc-generator.go.tmpl": "output/adoc/adoc-generator.go",
|
||||
"example-config-generator.go.tmpl": "output/exampleconfig/example-config-generator.go",
|
||||
"environment-variable-docs-generator.go.tmpl": "output/env/environment-variable-docs-generator.go",
|
||||
"templates/adoc-generator.go.tmpl": "output/adoc/adoc-generator.go",
|
||||
"templates/example-config-generator.go.tmpl": "output/exampleconfig/example-config-generator.go",
|
||||
"templates/environment-variable-docs-generator.go.tmpl": "output/env/environment-variable-docs-generator.go",
|
||||
"templates/envar-delta-table.go.tmpl": "output/env/envvar-delta-table.go",
|
||||
}
|
||||
|
||||
// RenderTemplates does something with templates
|
||||
@@ -37,7 +38,10 @@ func RenderTemplates() {
|
||||
runIntermediateCode(output)
|
||||
}
|
||||
fmt.Println("Cleaning up")
|
||||
os.RemoveAll("output")
|
||||
err = os.RemoveAll("output")
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
}
|
||||
}
|
||||
|
||||
func generateIntermediateCode(templatePath string, intermediateCodePath string, paths []string) {
|
||||
|
||||
@@ -1,7 +0,0 @@
|
||||
package main
|
||||
|
||||
import "fmt"
|
||||
|
||||
func RenderEnvVarDeltas() {
|
||||
fmt.Println("RenderEnvVarDeltas")
|
||||
}
|
||||
@@ -16,18 +16,15 @@ func main() {
|
||||
RenderGlobalVarsTemplate()
|
||||
case "service-index":
|
||||
GenerateServiceIndexMarkdowns()
|
||||
case "envvar-deltas":
|
||||
RenderEnvVarDeltas()
|
||||
case "all":
|
||||
RenderTemplates()
|
||||
GetRogueEnvs()
|
||||
RenderGlobalVarsTemplate()
|
||||
GenerateServiceIndexMarkdowns()
|
||||
RenderEnvVarDeltas()
|
||||
case "help":
|
||||
fallthrough
|
||||
default:
|
||||
fmt.Println("Usage: [templates|rogue|globals|service-index|envvar-deltas|all]")
|
||||
fmt.Println("Usage: [templates|rogue|globals|service-index|all]")
|
||||
}
|
||||
} else {
|
||||
// Left here, even though present in the switch case, for backwards compatibility
|
||||
@@ -35,6 +32,5 @@ func main() {
|
||||
GetRogueEnvs()
|
||||
RenderGlobalVarsTemplate()
|
||||
GenerateServiceIndexMarkdowns()
|
||||
RenderEnvVarDeltas()
|
||||
}
|
||||
}
|
||||
|
||||
120
docs/helpers/templates/envar-delta-table.go.tmpl
Normal file
120
docs/helpers/templates/envar-delta-table.go.tmpl
Normal file
@@ -0,0 +1,120 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"gopkg.in/yaml.v2"
|
||||
"html"
|
||||
"reflect"
|
||||
"strings"
|
||||
"log"
|
||||
"os"
|
||||
"path/filepath"
|
||||
|
||||
{{- range $key, $value :=.}}
|
||||
pkg{{$key}} "{{$value}}"
|
||||
{{- end}}
|
||||
)
|
||||
|
||||
const yamlSource = "env_vars.yaml"
|
||||
|
||||
type ConfigField struct {
|
||||
Name string `yaml:"name"`
|
||||
DefaultValue string `yaml:"defaultValue"`
|
||||
Type string `yaml:"type"`
|
||||
Description string `yaml:"description"`
|
||||
IntroductionVersion string `yaml:"introductionVersion"`
|
||||
DeprecationVersion string `yaml:"deprecationVersion"`
|
||||
RemovalVersion string `yaml:"removalVersion"`
|
||||
DeprecationInfo string `yaml:"deprecationInfo"`
|
||||
}
|
||||
|
||||
func main() {
|
||||
fmt.Println("Generating tables for env-var deltas")
|
||||
var fields []ConfigField
|
||||
configFields := make(map[string]ConfigField)
|
||||
m := map[string]interface{}{
|
||||
{{- range $key, $value := .}}
|
||||
"{{$value}}": *pkg{{$key}}.FullDefaultConfig(),
|
||||
{{- end }}
|
||||
}
|
||||
for _, conf := range m {
|
||||
fields = GetAnnotatedVariables(conf)
|
||||
for _, field := range fields {
|
||||
variants := strings.Split(field.Name, ";")
|
||||
for _, variant := range variants {
|
||||
if configFields[variant].Name == "" {
|
||||
configFields[variant] = field
|
||||
} else {
|
||||
fmt.Println("Duplicate key: ", variant)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
curdir, err := os.Getwd()
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
fullYamlPath := filepath.Join(curdir, yamlSource)
|
||||
output, err := yaml.Marshal(configFields)
|
||||
if err != nil {
|
||||
log.Fatalf("Could not marshall variables: %v", err)
|
||||
}
|
||||
err = os.WriteFile(fullYamlPath, output, 0666)
|
||||
if err != nil {
|
||||
log.Fatalf("could not write %s", fullYamlPath)
|
||||
}
|
||||
if err := os.Chdir(curdir); err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
}
|
||||
|
||||
func GetAnnotatedVariables(s interface{}) []ConfigField {
|
||||
t := reflect.TypeOf(s)
|
||||
v := reflect.ValueOf(s)
|
||||
|
||||
var fields []ConfigField
|
||||
for i := 0; i < t.NumField(); i++ {
|
||||
field := t.Field(i)
|
||||
value := v.Field(i)
|
||||
|
||||
switch value.Kind() {
|
||||
default:
|
||||
desc := field.Tag.Get("desc")
|
||||
env, ok := field.Tag.Lookup("env")
|
||||
if !ok {
|
||||
continue
|
||||
}
|
||||
introductionVersion := field.Tag.Get("introductionVersion")
|
||||
deprecationVersion := field.Tag.Get("deprecationVersion")
|
||||
removalVersion := field.Tag.Get("removalVersion")
|
||||
deprecationInfo := field.Tag.Get("deprecationInfo")
|
||||
v := fmt.Sprintf("%v", value.Interface())
|
||||
typeName := value.Type().Name()
|
||||
if typeName == "" {
|
||||
typeName = value.Type().String()
|
||||
}
|
||||
//fields = append(fields, ConfigField{Name: strings.ReplaceAll(env, ";", "<br/>"), DefaultValue: html.EscapeString(strings.Replace(v, "|", "\\|", -1)), Description: desc, Type: typeName})
|
||||
fields = append(fields, ConfigField{
|
||||
Name: env,
|
||||
DefaultValue: html.EscapeString(strings.Replace(v, "|", "\\|", -1)),
|
||||
Description: desc,
|
||||
Type: typeName,
|
||||
IntroductionVersion: introductionVersion,
|
||||
DeprecationVersion: deprecationVersion,
|
||||
RemovalVersion: removalVersion,
|
||||
DeprecationInfo: deprecationInfo,
|
||||
})
|
||||
case reflect.Ptr:
|
||||
// PolicySelectors in the Proxy are being skipped atm
|
||||
// they are not configurable via env vars, if that changes
|
||||
// they are probably added to the Sanitize() function
|
||||
// and this should not be an issue then
|
||||
if !value.IsZero() && value.Elem().CanInterface() {
|
||||
fields = append(fields, GetAnnotatedVariables(value.Elem().Interface())...)
|
||||
}
|
||||
case reflect.Struct:
|
||||
fields = append(fields, GetAnnotatedVariables(value.Interface())...)
|
||||
}
|
||||
}
|
||||
return fields
|
||||
}
|
||||
Reference in New Issue
Block a user