mirror of
https://github.com/zeromicro/go-zero.git
synced 2025-01-25 02:08:44 +08:00
151 lines
3.2 KiB
Go
151 lines
3.2 KiB
Go
package gogen
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"os"
|
|
"path"
|
|
"path/filepath"
|
|
"strconv"
|
|
"strings"
|
|
"sync"
|
|
"time"
|
|
|
|
"github.com/logrusorgru/aurora"
|
|
"github.com/zeromicro/go-zero/core/logx"
|
|
apiformat "github.com/zeromicro/go-zero/tools/goctl/api/format"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/parser"
|
|
apiutil "github.com/zeromicro/go-zero/tools/goctl/api/util"
|
|
"github.com/zeromicro/go-zero/tools/goctl/config"
|
|
"github.com/zeromicro/go-zero/tools/goctl/util"
|
|
"github.com/zeromicro/go-zero/tools/goctl/util/pathx"
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
const tmpFile = "%s-%d"
|
|
|
|
var tmpDir = path.Join(os.TempDir(), "goctl")
|
|
|
|
// GoCommand gen go project files from command line
|
|
func GoCommand(c *cli.Context) error {
|
|
apiFile := c.String("api")
|
|
dir := c.String("dir")
|
|
namingStyle := c.String("style")
|
|
home := c.String("home")
|
|
remote := c.String("remote")
|
|
if len(remote) > 0 {
|
|
repo, _ := util.CloneIntoGitHome(remote)
|
|
if len(repo) > 0 {
|
|
home = repo
|
|
}
|
|
}
|
|
|
|
if len(home) > 0 {
|
|
pathx.RegisterGoctlHome(home)
|
|
}
|
|
if len(apiFile) == 0 {
|
|
return errors.New("missing -api")
|
|
}
|
|
if len(dir) == 0 {
|
|
return errors.New("missing -dir")
|
|
}
|
|
|
|
return DoGenProject(apiFile, dir, namingStyle)
|
|
}
|
|
|
|
// DoGenProject gen go project files with api file
|
|
func DoGenProject(apiFile, dir, style string) error {
|
|
api, err := parser.Parse(apiFile)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
cfg, err := config.NewConfig(style)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
logx.Must(pathx.MkdirIfNotExist(dir))
|
|
rootPkg, err := getParentPackage(dir)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
logx.Must(genEtc(dir, cfg, api))
|
|
logx.Must(genConfig(dir, cfg, api))
|
|
logx.Must(genMain(dir, rootPkg, cfg, api))
|
|
logx.Must(genServiceContext(dir, rootPkg, cfg, api))
|
|
logx.Must(genTypes(dir, cfg, api))
|
|
logx.Must(genRoutes(dir, rootPkg, cfg, api))
|
|
logx.Must(genHandlers(dir, rootPkg, cfg, api))
|
|
logx.Must(genLogic(dir, rootPkg, cfg, api))
|
|
logx.Must(genMiddleware(dir, cfg, api))
|
|
|
|
if err := backupAndSweep(apiFile); err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := apiformat.ApiFormatByPath(apiFile); err != nil {
|
|
return err
|
|
}
|
|
|
|
fmt.Println(aurora.Green("Done."))
|
|
return nil
|
|
}
|
|
|
|
func backupAndSweep(apiFile string) error {
|
|
var err error
|
|
var wg sync.WaitGroup
|
|
|
|
wg.Add(2)
|
|
_ = os.MkdirAll(tmpDir, os.ModePerm)
|
|
|
|
go func() {
|
|
_, fileName := filepath.Split(apiFile)
|
|
_, e := apiutil.Copy(apiFile, fmt.Sprintf(path.Join(tmpDir, tmpFile), fileName, time.Now().Unix()))
|
|
if e != nil {
|
|
err = e
|
|
}
|
|
wg.Done()
|
|
}()
|
|
go func() {
|
|
if e := sweep(); e != nil {
|
|
err = e
|
|
}
|
|
wg.Done()
|
|
}()
|
|
wg.Wait()
|
|
|
|
return err
|
|
}
|
|
|
|
func sweep() error {
|
|
keepTime := time.Now().AddDate(0, 0, -7)
|
|
return filepath.Walk(tmpDir, func(fpath string, info os.FileInfo, err error) error {
|
|
if info.IsDir() {
|
|
return nil
|
|
}
|
|
|
|
pos := strings.LastIndexByte(info.Name(), '-')
|
|
if pos > 0 {
|
|
timestamp := info.Name()[pos+1:]
|
|
seconds, err := strconv.ParseInt(timestamp, 10, 64)
|
|
if err != nil {
|
|
// print error and ignore
|
|
fmt.Println(aurora.Red(fmt.Sprintf("sweep ignored file: %s", fpath)))
|
|
return nil
|
|
}
|
|
|
|
tm := time.Unix(seconds, 0)
|
|
if tm.Before(keepTime) {
|
|
if err := os.Remove(fpath); err != nil {
|
|
fmt.Println(aurora.Red(fmt.Sprintf("failed to remove file: %s", fpath)))
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
|
|
return nil
|
|
})
|
|
}
|