mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* Update thema to latest * Deal with s/Library/*Runtime/ * Commit new, working results of codegen * We like pointers now * Always take runtime arg for NewBase() * Sketchy handwavy pass at entity meta framework * Little nibbles * Update pkg/framework/coremodel/entityframework.cue Co-authored-by: Artur Wierzbicki <wierzbicki.artur.94@gmail.com> * Move file into new framework location * Introduce loaders, Go code * Complete rename to kind * Flesh out framework, add svg/dashboard examples * Cruft removal * Remove generated kind go files from gitignore * Refine maturity concept, add SlotKind * Update embed and go deps * Export PrefixWithGrafanaCUE * Make the loader actually work, holy crap * Many small tweaks to type.cue * Add Apache 2 licensing exceptions for kinds * Add new kinds dir, start of generator * Roll back to earlier oapi-codegen * Introduce new grafana-specific CUE loaders * Introduce new tidy code generators framework * Catch up kind framework with tinkering * Add slices for the generators * Add write/verify step to main generator * Many renames * Split up kind framework cue files * Use kind.Decl within generated kinds * Create kind.SomeDecl wrapper type to cache lineages * Better names again * Get one generated implemented, hopefully * Copy dashboard schema into new kind.cue * Small fixes to make the initial gen work * Put svg kind in its new home * Add generated Go dashboard type * More renames and cleanups * Add base kind registry and generator * Stop blacklisting *_gen.go files This is not the Go best practice, anyway. All we actually want to ignore for enterprise is generated wire files. * Change codegen output directories pkg/kind -> pkg/kinds pkg/registry/kindreg -> pkg/registry/corekind * Rename pkg/framework/kind to pkg/kindsys * Add core structured kind generator * Add plural and machine names to kind spec * Copy playlist over to kind system * Consolidate kindsys files * Add raw kind generator * Update CODEOWNERS for kind framework * Touch up comments a bit * More docs tweaks * Remove generated types to reduce noise for review * Split each generator into its own file * Rename Slot kind to Composable kind * Add handwavy types for customkind loading * Guard against init calls to framework loader * First pass at doc on extending the kind system * Improve attribute example in docs * Fix wire imports * Add basic TS types generator * Fix composable kind category def * No need for a separate file with generate directive * Catch dashboard schema up * Rename generator types to something saner and generic * Make version configurable in ts/go generators * Add CommonMeta to ease property access * Add kindsys prop indicating whether lineage is group * Put all kind categories back in a single file * Finish with kindsys group props * Refactor maturity progression per discussion - Replace "committed" with "merged" - All kindcats can use all maturity levels, at least for now * Convert ts veneer index generator to modular system * Move over to new jennywrites framework * Strip down old coremodel generator * Use public version of jennywrites * Pull latest thema * Commit generated Go types * Add header injection postprocessor * Move sdboyer/jennywrites to grafana/codejen * Tweak header output * Remove dashboard and playlist coremodels * Fix up backend dashboards devenv test * Fix TS import patterns to new gen filename * Update internal imports, remove coremodel registry * Fix compilation errors, wire generation * Export and replace the prefix dropper * More Go struct and field name changes * Last name fixes, hopefully * Fix lint errors * Last lint error Co-authored-by: Artur Wierzbicki <wierzbicki.artur.94@gmail.com>
140 lines
3.8 KiB
Go
140 lines
3.8 KiB
Go
//go:build ignore
|
|
// +build ignore
|
|
|
|
package main
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"os"
|
|
"path/filepath"
|
|
"sort"
|
|
"strings"
|
|
|
|
"github.com/grafana/grafana/pkg/codegen"
|
|
"github.com/grafana/grafana/pkg/cuectx"
|
|
"github.com/grafana/grafana/pkg/plugins/pfs"
|
|
)
|
|
|
|
var skipPlugins = map[string]bool{
|
|
"canvas": true,
|
|
"heatmap": true,
|
|
"heatmap-old": true,
|
|
"candlestick": true,
|
|
"state-timeline": true,
|
|
"status-history": true,
|
|
"table": true,
|
|
"timeseries": true,
|
|
"influxdb": true, // plugin.json fails validation (defaultMatchFormat)
|
|
"mixed": true, // plugin.json fails validation (mixed)
|
|
"opentsdb": true, // plugin.json fails validation (defaultMatchFormat)
|
|
}
|
|
|
|
const sep = string(filepath.Separator)
|
|
|
|
func main() {
|
|
if len(os.Args) > 1 {
|
|
fmt.Fprintf(os.Stderr, "plugin thema code generator does not currently accept any arguments\n, got %q", os.Args)
|
|
os.Exit(1)
|
|
}
|
|
|
|
cwd, err := os.Getwd()
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "could not get working directory: %s", err)
|
|
os.Exit(1)
|
|
}
|
|
grootp := strings.Split(cwd, sep)
|
|
groot := filepath.Join(sep, filepath.Join(grootp[:len(grootp)-3]...))
|
|
|
|
wd := codegen.NewWriteDiffer()
|
|
lib := cuectx.GrafanaThemaRuntime()
|
|
|
|
type ptreepath struct {
|
|
Path string
|
|
Tree *codegen.PluginTree
|
|
}
|
|
var ptrees []codegen.TreeAndPath
|
|
for _, typ := range []string{"datasource", "panel"} {
|
|
dir := filepath.Join(cwd, typ)
|
|
treeor, err := codegen.ExtractPluginTrees(os.DirFS(dir), lib)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "extracting plugin trees failed for %s: %s\n", dir, err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
for name, option := range treeor {
|
|
if skipPlugins[name] {
|
|
continue
|
|
}
|
|
|
|
if option.Tree != nil {
|
|
ptrees = append(ptrees, codegen.TreeAndPath{
|
|
Path: filepath.Join(typ, name),
|
|
Tree: option.Tree,
|
|
})
|
|
} else if !errors.Is(option.Err, pfs.ErrNoRootFile) {
|
|
fmt.Fprintf(os.Stderr, "error parsing plugin directory %s: %s\n", filepath.Join(dir, name), option.Err)
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
}
|
|
|
|
// Ensure ptrees are sorted, so that visit order is deterministic. Otherwise
|
|
// having multiple core plugins with errors can cause confusing error
|
|
// flip-flopping
|
|
sort.Slice(ptrees, func(i, j int) bool {
|
|
return ptrees[i].Path < ptrees[j].Path
|
|
})
|
|
|
|
var wdm codegen.WriteDiffer
|
|
for _, ptp := range ptrees {
|
|
tfast, err := ptp.Tree.GenerateTypeScriptAST()
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "generating typescript failed for %s: %s\n", ptp.Path, err)
|
|
os.Exit(1)
|
|
}
|
|
// nil return if there was nothing to generate (no slot implementations)
|
|
if tfast != nil {
|
|
wd[filepath.Join(ptp.Path, "models.gen.ts")] = []byte(tfast.String())
|
|
}
|
|
|
|
relp, _ := filepath.Rel(groot, ptp.Path)
|
|
wdm, err = ptp.Tree.GenerateGo(ptp.Path, codegen.GoGenConfig{
|
|
Types: isDatasource(ptp.Tree),
|
|
// TODO false until we decide on a consistent codegen format for core and external plugins
|
|
ThemaBindings: false,
|
|
DocPathPrefix: relp,
|
|
})
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "generating Go failed for %s: %s\n", ptp.Path, err)
|
|
os.Exit(1)
|
|
}
|
|
wd.Merge(wdm)
|
|
}
|
|
|
|
wdm, err = codegen.GenPluginTreeList(ptrees, "github.com/grafana/grafana/public/app/plugins", filepath.Join(groot, "pkg", "plugins", "pfs", "corelist", "loadlist_gen.go"), false)
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "generating plugin loader registry failed: %s\n", err)
|
|
os.Exit(1)
|
|
}
|
|
wd.Merge(wdm)
|
|
|
|
if _, set := os.LookupEnv("CODEGEN_VERIFY"); set {
|
|
err = wd.Verify()
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "generated code is out of sync with inputs:\n%s\nrun `make gen-cue` to regenerate\n\n", err)
|
|
os.Exit(1)
|
|
}
|
|
} else {
|
|
err = wd.Write()
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "error while writing generated code to disk:\n%s\n", err)
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
}
|
|
|
|
func isDatasource(pt *codegen.PluginTree) bool {
|
|
return string((*pfs.Tree)(pt).RootPlugin().Meta().Type) == "datasource"
|
|
}
|