mirror of
https://github.com/stashapp/stash.git
synced 2025-12-18 12:54:38 +03:00
* Upgrade gqlgen to v0.17.2 This enables builds on Go 1.18. github.com/vektah/gqlparser is upgraded to the newest version too. Getting this to work is a bit of a hazzle. I had to first remove vendoring from the repository, perform the upgrade and then re-introduce the vendor directory. I think gqlgens analysis went wrong for some reason on the upgrade. It would seem a clean-room installation fixed it. * Bump project to 1.18 * Update all packages, address gqlgenc breaking changes * Let `go mod tidy` handle the go.mod file * Upgrade linter to 1.45.2 * Introduce v1.45.2 of the linter The linter now correctly warns on `strings.Title` because it isn't unicode-aware. Fix this by using the suggested fix from x/text/cases to produce unicode-aware strings. The mapping isn't entirely 1-1 as this new approach has a larger iface: it spans all of unicode rather than just ASCII. It coincides for ASCII however, so things should be largely the same. * Ready ourselves for errchkjson and contextcheck. * Revert dockerfile golang version changes for now Co-authored-by: Kermie <kermie@isinthe.house> Co-authored-by: WithoutPants <53250216+WithoutPants@users.noreply.github.com>
126 lines
2.9 KiB
Go
126 lines
2.9 KiB
Go
package api
|
|
|
|
import (
|
|
"fmt"
|
|
"syscall"
|
|
|
|
"github.com/99designs/gqlgen/codegen"
|
|
"github.com/99designs/gqlgen/codegen/config"
|
|
"github.com/99designs/gqlgen/plugin"
|
|
"github.com/99designs/gqlgen/plugin/federation"
|
|
"github.com/99designs/gqlgen/plugin/modelgen"
|
|
"github.com/99designs/gqlgen/plugin/resolvergen"
|
|
)
|
|
|
|
func Generate(cfg *config.Config, option ...Option) error {
|
|
_ = syscall.Unlink(cfg.Exec.Filename)
|
|
if cfg.Model.IsDefined() {
|
|
_ = syscall.Unlink(cfg.Model.Filename)
|
|
}
|
|
|
|
plugins := []plugin.Plugin{}
|
|
if cfg.Model.IsDefined() {
|
|
plugins = append(plugins, modelgen.New())
|
|
}
|
|
plugins = append(plugins, resolvergen.New())
|
|
if cfg.Federation.IsDefined() {
|
|
plugins = append([]plugin.Plugin{federation.New()}, plugins...)
|
|
}
|
|
|
|
for _, o := range option {
|
|
o(cfg, &plugins)
|
|
}
|
|
|
|
for _, p := range plugins {
|
|
if inj, ok := p.(plugin.EarlySourceInjector); ok {
|
|
if s := inj.InjectSourceEarly(); s != nil {
|
|
cfg.Sources = append(cfg.Sources, s)
|
|
}
|
|
}
|
|
}
|
|
|
|
if err := cfg.LoadSchema(); err != nil {
|
|
return fmt.Errorf("failed to load schema: %w", err)
|
|
}
|
|
|
|
for _, p := range plugins {
|
|
if inj, ok := p.(plugin.LateSourceInjector); ok {
|
|
if s := inj.InjectSourceLate(cfg.Schema); s != nil {
|
|
cfg.Sources = append(cfg.Sources, s)
|
|
}
|
|
}
|
|
}
|
|
|
|
// LoadSchema again now we have everything
|
|
if err := cfg.LoadSchema(); err != nil {
|
|
return fmt.Errorf("failed to load schema: %w", err)
|
|
}
|
|
|
|
if err := cfg.Init(); err != nil {
|
|
return fmt.Errorf("generating core failed: %w", err)
|
|
}
|
|
|
|
for _, p := range plugins {
|
|
if mut, ok := p.(plugin.ConfigMutator); ok {
|
|
err := mut.MutateConfig(cfg)
|
|
if err != nil {
|
|
return fmt.Errorf("%s: %w", p.Name(), err)
|
|
}
|
|
}
|
|
}
|
|
// Merge again now that the generated models have been injected into the typemap
|
|
data, err := codegen.BuildData(cfg)
|
|
if err != nil {
|
|
return fmt.Errorf("merging type systems failed: %w", err)
|
|
}
|
|
|
|
if err = codegen.GenerateCode(data); err != nil {
|
|
return fmt.Errorf("generating core failed: %w", err)
|
|
}
|
|
|
|
if !cfg.SkipModTidy {
|
|
if err = cfg.Packages.ModTidy(); err != nil {
|
|
return fmt.Errorf("tidy failed: %w", err)
|
|
}
|
|
}
|
|
|
|
for _, p := range plugins {
|
|
if mut, ok := p.(plugin.CodeGenerator); ok {
|
|
err := mut.GenerateCode(data)
|
|
if err != nil {
|
|
return fmt.Errorf("%s: %w", p.Name(), err)
|
|
}
|
|
}
|
|
}
|
|
|
|
if err = codegen.GenerateCode(data); err != nil {
|
|
return fmt.Errorf("generating core failed: %w", err)
|
|
}
|
|
|
|
if !cfg.SkipValidation {
|
|
if err := validate(cfg); err != nil {
|
|
return fmt.Errorf("validation failed: %w", err)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func validate(cfg *config.Config) error {
|
|
roots := []string{cfg.Exec.ImportPath()}
|
|
if cfg.Model.IsDefined() {
|
|
roots = append(roots, cfg.Model.ImportPath())
|
|
}
|
|
|
|
if cfg.Resolver.IsDefined() {
|
|
roots = append(roots, cfg.Resolver.ImportPath())
|
|
}
|
|
|
|
cfg.Packages.LoadAll(roots...)
|
|
errs := cfg.Packages.Errors()
|
|
if len(errs) > 0 {
|
|
return errs
|
|
}
|
|
return nil
|
|
}
|