- Fix remaining 187 pkg/ files referencing core/cli → core/go - Move SDK library code from internal/cmd/sdk/ → pkg/sdk/ (new package) - Create pkg/rag/helpers.go with convenience functions from internal/cmd/rag/ - Fix pkg/mcp/tools_rag.go to use pkg/rag instead of internal/cmd/rag - Fix pkg/build/buildcmd/cmd_sdk.go and pkg/release/sdk.go to use pkg/sdk - Remove all non-library content: main.go, internal/, cmd/, docker/, scripts/, tasks/, tools/, .core/, .forgejo/, .woodpecker/, Taskfile.yml - Run go mod tidy to trim unused dependencies core/go is now a pure Go package suite (library only). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> Co-authored-by: Claude <developers@lethean.io> Reviewed-on: #3
90 lines
2.3 KiB
Go
90 lines
2.3 KiB
Go
package generators
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
"os/exec"
|
|
"path/filepath"
|
|
|
|
coreio "forge.lthn.ai/core/go/pkg/io"
|
|
"forge.lthn.ai/core/go/pkg/log"
|
|
)
|
|
|
|
// GoGenerator generates Go SDKs from OpenAPI specs.
|
|
type GoGenerator struct{}
|
|
|
|
// NewGoGenerator creates a new Go generator.
|
|
func NewGoGenerator() *GoGenerator {
|
|
return &GoGenerator{}
|
|
}
|
|
|
|
// Language returns the generator's target language identifier.
|
|
func (g *GoGenerator) Language() string {
|
|
return "go"
|
|
}
|
|
|
|
// Available checks if generator dependencies are installed.
|
|
func (g *GoGenerator) Available() bool {
|
|
_, err := exec.LookPath("oapi-codegen")
|
|
return err == nil
|
|
}
|
|
|
|
// Install returns instructions for installing the generator.
|
|
func (g *GoGenerator) Install() string {
|
|
return "go install github.com/oapi-codegen/oapi-codegen/v2/cmd/oapi-codegen@latest"
|
|
}
|
|
|
|
// Generate creates SDK from OpenAPI spec.
|
|
func (g *GoGenerator) Generate(ctx context.Context, opts Options) error {
|
|
if err := coreio.Local.EnsureDir(opts.OutputDir); err != nil {
|
|
return log.E("go.Generate", "failed to create output dir", err)
|
|
}
|
|
|
|
if g.Available() {
|
|
return g.generateNative(ctx, opts)
|
|
}
|
|
return g.generateDocker(ctx, opts)
|
|
}
|
|
|
|
func (g *GoGenerator) generateNative(ctx context.Context, opts Options) error {
|
|
outputFile := filepath.Join(opts.OutputDir, "client.go")
|
|
|
|
cmd := exec.CommandContext(ctx, "oapi-codegen",
|
|
"-package", opts.PackageName,
|
|
"-generate", "types,client",
|
|
"-o", outputFile,
|
|
opts.SpecPath,
|
|
)
|
|
cmd.Stdout = os.Stdout
|
|
cmd.Stderr = os.Stderr
|
|
|
|
if err := cmd.Run(); err != nil {
|
|
return log.E("go.generateNative", "oapi-codegen failed", err)
|
|
}
|
|
|
|
goMod := fmt.Sprintf("module %s\n\ngo 1.21\n", opts.PackageName)
|
|
return coreio.Local.Write(filepath.Join(opts.OutputDir, "go.mod"), goMod)
|
|
}
|
|
|
|
func (g *GoGenerator) generateDocker(ctx context.Context, opts Options) error {
|
|
specDir := filepath.Dir(opts.SpecPath)
|
|
specName := filepath.Base(opts.SpecPath)
|
|
|
|
args := []string{"run", "--rm"}
|
|
args = append(args, dockerUserArgs()...)
|
|
args = append(args,
|
|
"-v", specDir+":/spec",
|
|
"-v", opts.OutputDir+":/out",
|
|
"openapitools/openapi-generator-cli", "generate",
|
|
"-i", "/spec/"+specName,
|
|
"-g", "go",
|
|
"-o", "/out",
|
|
"--additional-properties=packageName="+opts.PackageName,
|
|
)
|
|
|
|
cmd := exec.CommandContext(ctx, "docker", args...)
|
|
cmd.Stdout = os.Stdout
|
|
cmd.Stderr = os.Stderr
|
|
return cmd.Run()
|
|
}
|