mirror of
https://github.com/zeromicro/go-zero.git
synced 2025-01-23 17:20:24 +08:00
5383e29ce6
* Replace cli * Replace cli * Replace cli * Format code * Add compare case * Add compare case * Add compare case * Support go style flag * Support go style flag * Add test case
177 lines
7.3 KiB
Go
177 lines
7.3 KiB
Go
package api
|
|
|
|
import (
|
|
"github.com/spf13/cobra"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/apigen"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/dartgen"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/docgen"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/format"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/gogen"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/javagen"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/ktgen"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/new"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/tsgen"
|
|
"github.com/zeromicro/go-zero/tools/goctl/api/validate"
|
|
"github.com/zeromicro/go-zero/tools/goctl/plugin"
|
|
)
|
|
|
|
var (
|
|
// Cmd describes a api command.
|
|
Cmd = &cobra.Command{
|
|
Use: "api",
|
|
Short: "Generate api related files",
|
|
RunE: apigen.CreateApiTemplate,
|
|
}
|
|
|
|
dartCmd = &cobra.Command{
|
|
Use: "dart",
|
|
Short: "Generate dart files for provided api in api file",
|
|
RunE: dartgen.DartCommand,
|
|
}
|
|
|
|
docCmd = &cobra.Command{
|
|
Use: "doc",
|
|
Short: "Generate doc files",
|
|
RunE: docgen.DocCommand,
|
|
}
|
|
|
|
formatCmd = &cobra.Command{
|
|
Use: "format",
|
|
Short: "Format api files",
|
|
RunE: format.GoFormatApi,
|
|
}
|
|
|
|
goCmd = &cobra.Command{
|
|
Use: "go",
|
|
Short: "Generate go files for provided api in yaml file",
|
|
RunE: gogen.GoCommand,
|
|
}
|
|
|
|
newCmd = &cobra.Command{
|
|
Use: "new",
|
|
Short: "Fast create api service",
|
|
Example: "goctl api new [options] service-name",
|
|
Args: cobra.ExactValidArgs(1),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
return new.CreateServiceCommand(args)
|
|
},
|
|
}
|
|
|
|
validateCmd = &cobra.Command{
|
|
Use: "validate",
|
|
Short: "Validate api file",
|
|
RunE: validate.GoValidateApi,
|
|
}
|
|
|
|
javaCmd = &cobra.Command{
|
|
Use: "java",
|
|
Short: "Generate java files for provided api in api file",
|
|
RunE: javagen.JavaCommand,
|
|
}
|
|
|
|
ktCmd = &cobra.Command{
|
|
Use: "kt",
|
|
Short: "Generate kotlin code for provided api file",
|
|
RunE: ktgen.KtCommand,
|
|
}
|
|
|
|
pluginCmd = &cobra.Command{
|
|
Use: "plugin",
|
|
Short: "Custom file generator",
|
|
RunE: plugin.PluginCommand,
|
|
}
|
|
|
|
tsCmd = &cobra.Command{
|
|
Use: "ts",
|
|
Short: "Generate ts files for provided api in api file",
|
|
RunE: tsgen.TsCommand,
|
|
}
|
|
)
|
|
|
|
func init() {
|
|
Cmd.Flags().StringVar(&apigen.VarStringOutput, "o", "", "Output a sample api file")
|
|
Cmd.Flags().StringVar(&apigen.VarStringHome, "home", "", "The goctl home path of the"+
|
|
" template, --home and --remote cannot be set at the same time, if they are, --remote has "+
|
|
"higher priority")
|
|
Cmd.Flags().StringVar(&apigen.VarStringRemote, "remote", "", "The remote git repo of the"+
|
|
" template, --home and --remote cannot be set at the same time, if they are, --remote has higher"+
|
|
" priority\n\tThe git repo directory must be consistent with the"+
|
|
" https://github.com/zeromicro/go-zero-template directory structure")
|
|
Cmd.Flags().StringVar(&apigen.VarStringBranch, "branch", "master", "The branch of the "+
|
|
"remote repo, it does work with --remote")
|
|
|
|
dartCmd.Flags().StringVar(&dartgen.VarStringDir, "dir", "", "The target dir")
|
|
dartCmd.Flags().StringVar(&dartgen.VarStringAPI, "api", "", "The api file")
|
|
dartCmd.Flags().BoolVar(&dartgen.VarStringLegacy, "legacy", false, "Legacy generator for flutter v1")
|
|
dartCmd.Flags().StringVar(&dartgen.VarStringHostname, "hostname", "", "hostname of the server")
|
|
|
|
docCmd.Flags().StringVar(&docgen.VarStringDir, "dir", "", "The target dir")
|
|
docCmd.Flags().StringVar(&docgen.VarStringOutput, "o", "", "The output markdown directory")
|
|
|
|
formatCmd.Flags().StringVar(&format.VarStringDir, "dir", "", "The format target dir")
|
|
formatCmd.Flags().BoolVar(&format.VarBoolIgnore, "iu", false, "Ignore update")
|
|
formatCmd.Flags().BoolVar(&format.VarBoolUseStdin, "stdin", false, "Use stdin to input api"+
|
|
" doc content, press \"ctrl + d\" to send EOF")
|
|
formatCmd.Flags().BoolVar(&format.VarBoolSkipCheckDeclare, "declare", false, "Use to skip check "+
|
|
"api types already declare")
|
|
|
|
goCmd.Flags().StringVar(&gogen.VarStringDir, "dir", "", "The target dir")
|
|
goCmd.Flags().StringVar(&gogen.VarStringAPI, "api", "", "The api file")
|
|
goCmd.Flags().StringVar(&gogen.VarStringHome, "home", "", "The goctl home path of "+
|
|
"the template, --home and --remote cannot be set at the same time, if they are, --remote "+
|
|
"has higher priority")
|
|
goCmd.Flags().StringVar(&gogen.VarStringRemote, "remote", "", "The remote git repo "+
|
|
"of the template, --home and --remote cannot be set at the same time, if they are, --remote"+
|
|
" has higher priority\n\tThe git repo directory must be consistent with the "+
|
|
"https://github.com/zeromicro/go-zero-template directory structure")
|
|
goCmd.Flags().StringVar(&gogen.VarStringBranch, "branch", "master", "The branch of "+
|
|
"the remote repo, it does work with --remote")
|
|
goCmd.Flags().StringVar(&gogen.VarStringStyle, "style", "gozero", "The file naming format,"+
|
|
" see [https://github.com/zeromicro/go-zero/blob/master/tools/goctl/config/readme.md]")
|
|
|
|
javaCmd.Flags().StringVar(&javagen.VarStringDir, "dir", "", "The target dir")
|
|
javaCmd.Flags().StringVar(&javagen.VarStringAPI, "api", "", "The api file")
|
|
|
|
ktCmd.Flags().StringVar(&ktgen.VarStringDir, "dir", "", "The target dir")
|
|
ktCmd.Flags().StringVar(&ktgen.VarStringAPI, "api", "", "The api file")
|
|
ktCmd.Flags().StringVar(&ktgen.VarStringPKG, "pkg", "", "Define package name for kotlin file")
|
|
|
|
newCmd.Flags().StringVar(&new.VarStringHome, "home", "", "The goctl home path of "+
|
|
"the template, --home and --remote cannot be set at the same time, if they are, --remote "+
|
|
"has higher priority")
|
|
newCmd.Flags().StringVar(&new.VarStringRemote, "remote", "", "The remote git repo "+
|
|
"of the template, --home and --remote cannot be set at the same time, if they are, --remote"+
|
|
" has higher priority\n\tThe git repo directory must be consistent with the "+
|
|
"https://github.com/zeromicro/go-zero-template directory structure")
|
|
newCmd.Flags().StringVar(&new.VarStringBranch, "branch", "master", "The branch of "+
|
|
"the remote repo, it does work with --remote")
|
|
newCmd.Flags().StringVar(&new.VarStringStyle, "style", "gozero", "The file naming format,"+
|
|
" see [https://github.com/zeromicro/go-zero/blob/master/tools/goctl/config/readme.md]")
|
|
|
|
pluginCmd.Flags().StringVarP(&plugin.VarStringPlugin, "plugin", "p", "", "The plugin file")
|
|
pluginCmd.Flags().StringVar(&plugin.VarStringDir, "dir", "", "The target dir")
|
|
pluginCmd.Flags().StringVar(&plugin.VarStringAPI, "api", "", "The api file")
|
|
pluginCmd.Flags().StringVar(&plugin.VarStringStyle, "style", "",
|
|
"The file naming format, see [https://github.com/zeromicro/go-zero/tree/master/tools/goctl/config/readme.md]")
|
|
|
|
tsCmd.Flags().StringVar(&tsgen.VarStringDir, "dir", "", "The target dir")
|
|
tsCmd.Flags().StringVar(&tsgen.VarStringAPI, "api", "", "The api file")
|
|
tsCmd.Flags().StringVar(&tsgen.VarStringWebAPI, "webapi", "", "The web api file path")
|
|
tsCmd.Flags().StringVar(&tsgen.VarStringCaller, "caller", "", "The web api caller")
|
|
tsCmd.Flags().BoolVar(&tsgen.VarBoolUnWrap, "unwrap", false, "Unwrap the webapi caller for import")
|
|
|
|
validateCmd.Flags().StringVar(&validate.VarStringAPI, "api", "", "Validate target api file")
|
|
|
|
// Add sub-commands
|
|
Cmd.AddCommand(dartCmd)
|
|
Cmd.AddCommand(docCmd)
|
|
Cmd.AddCommand(formatCmd)
|
|
Cmd.AddCommand(goCmd)
|
|
Cmd.AddCommand(javaCmd)
|
|
Cmd.AddCommand(ktCmd)
|
|
Cmd.AddCommand(newCmd)
|
|
Cmd.AddCommand(pluginCmd)
|
|
Cmd.AddCommand(tsCmd)
|
|
Cmd.AddCommand(validateCmd)
|
|
}
|