mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Refactor towards template/codegen framework * Add templates for plugin gen * Add Go codegen for plugins; overhaul framework, too * Add new codegen output; assorted framework fixes * Regenerate after merge * Remove accidental commit file, update templates * Export the pfs.Tree loader from plugin types * Print details from cuetsy errors * Generate loaders for all plugins and list in registry * Use pfs_gen.go over lineage_gen.go * Un-un-ignore main file * Introduce simple List static registry for plugins * Last tweaks to codegen * remove unused tvars * Ensure loop-local instances for both vars * Generate pfs parsing in-place in registry * Stop generating pfs_gen.go * Move Tree into pfs, rename subdir * Change package name to match dir * Ignore gocyclo on HTTPServer.getNavTree
59 lines
1.6 KiB
Cheetah
59 lines
1.6 KiB
Cheetah
{{ template "autogen_header.tmpl" .Header }}
|
|
package registry
|
|
|
|
import (
|
|
"fmt"
|
|
"sync"
|
|
|
|
"github.com/google/wire"
|
|
{{range .Coremodels }}
|
|
"{{ .PkgPath }}"{{end}}
|
|
"github.com/grafana/grafana/pkg/cuectx"
|
|
"github.com/grafana/grafana/pkg/framework/coremodel"
|
|
"github.com/grafana/thema"
|
|
)
|
|
|
|
// Base is a registry of coremodel.Interface. It provides two modes for accessing
|
|
// coremodels: individually via literal named methods, or as a slice returned from All().
|
|
//
|
|
// Prefer the individual named methods for use cases where the particular coremodel(s) that
|
|
// are needed are known to the caller. For example, a dashboard linter can know that it
|
|
// specifically wants the dashboard coremodel.
|
|
//
|
|
// Prefer All() when performing operations generically across all coremodels. For example,
|
|
// a validation HTTP middleware for any coremodel-schematized object type.
|
|
type Base struct {
|
|
all []coremodel.Interface
|
|
{{- range .Coremodels }}
|
|
{{ .Name }} *{{ .Name }}.Coremodel{{end}}
|
|
}
|
|
|
|
// type guards
|
|
var (
|
|
{{- range .Coremodels }}
|
|
_ coremodel.Interface = &{{ .Name }}.Coremodel{}{{end}}
|
|
)
|
|
|
|
{{range .Coremodels }}
|
|
// {{ .TitleName }} returns the {{ .Name }} coremodel. The return value is guaranteed to
|
|
// implement coremodel.Interface.
|
|
func (b *Base) {{ .TitleName }}() *{{ .Name }}.Coremodel {
|
|
return b.{{ .Name }}
|
|
}
|
|
{{end}}
|
|
|
|
func doProvideBase(lib thema.Library) *Base {
|
|
var err error
|
|
reg := &Base{}
|
|
|
|
{{range .Coremodels }}
|
|
reg.{{ .Name }}, err = {{ .Name }}.New(lib)
|
|
if err != nil {
|
|
panic(fmt.Sprintf("error while initializing {{ .Name }} coremodel: %s", err))
|
|
}
|
|
reg.all = append(reg.all, reg.{{ .Name }})
|
|
{{end}}
|
|
|
|
return reg
|
|
}
|