server.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. package cmd
  2. import (
  3. "fmt"
  4. "git.wanbits.cc/sin/flytalk/config"
  5. "git.wanbits.cc/sin/flytalk/controller"
  6. "git.wanbits.cc/sin/flytalk/g"
  7. "git.wanbits.cc/sin/flytalk/models"
  8. "git.wanbits.cc/sin/flytalk/router"
  9. "git.wanbits.cc/sin/flytalk/tools"
  10. "git.wanbits.cc/sin/flytalk/user/provider/twong"
  11. "github.com/gin-contrib/cors"
  12. "github.com/gin-gonic/gin"
  13. "github.com/spf13/cobra"
  14. "log"
  15. "os"
  16. "os/exec"
  17. "path/filepath"
  18. )
  19. var (
  20. Addr string
  21. Confile string
  22. Daemon bool
  23. )
  24. var serverCmd = &cobra.Command{
  25. Use: "serve",
  26. Short: "start serving",
  27. Example: "flytalk serve -c config",
  28. Run: func(cmd *cobra.Command, args []string) {
  29. run()
  30. },
  31. }
  32. func run() {
  33. // load config
  34. _, err := config.LoadConf(Confile)
  35. if err != nil {
  36. panic(fmt.Sprintf("load config file failed:%v", Confile))
  37. }
  38. fmt.Println("============Config============")
  39. fmt.Printf("Basic:%+v\n", config.C.Basic)
  40. fmt.Printf("Database:%+v\n", config.C.Database)
  41. fmt.Printf("Imap:%+v\n", config.C.Imap)
  42. fmt.Printf("Twong:%+v\n", config.C.Twong)
  43. if config.C.Basic.Daemon {
  44. if os.Getppid() != 1 {
  45. // 将命令行参数中执行文件路径转换成可用路径
  46. filePath, _ := filepath.Abs(os.Args[0])
  47. cmd := exec.Command(filePath, os.Args[1:]...)
  48. // 将其他命令传入生成出的进程
  49. cmd.Stdin = os.Stdin // 给新进程设置文件描述符,可以重定向到文件中
  50. cmd.Stdout = os.Stdout
  51. cmd.Stderr = os.Stderr
  52. cmd.Start() // 开始执行新进程,不等待新进程退出
  53. os.Exit(0)
  54. }
  55. }
  56. // load i18n
  57. l := g.NewLang(config.C.Basic.LangDir)
  58. g.SetDefaultLang(l)
  59. // connect to db
  60. models.InitDb()
  61. twong.InitDb()
  62. controller.Init()
  63. log.Println("start server at " + config.C.Basic.Addr)
  64. gin.SetMode(gin.ReleaseMode)
  65. engine := gin.Default()
  66. engine.Use(cors.Default())
  67. //htmlGlobDir := filepath.Join(config.C.Basic.ResDir, "html/*")
  68. engine.LoadHTMLGlob("static/html/*")
  69. engine.Static("/static", "./static")
  70. //记录日志
  71. engine.Use(tools.LoggerToFile())
  72. router.InitViewRouter(engine)
  73. router.InitApiRouter(engine)
  74. //文档服务
  75. //docs.SwaggerInfo.Title = "接口文档"
  76. //docs.SwaggerInfo.Description = "flytalk 客服系统 , 测试账户:kefu2 测试密码:123 类型:kefu"
  77. //docs.SwaggerInfo.Version = "0.0.7"
  78. ////docs.SwaggerInfo.Host = "127.0.0.1:"+port
  79. //docs.SwaggerInfo.Host = "flytalk.sopans.com"
  80. //docs.SwaggerInfo.BasePath = "/"
  81. //docs.SwaggerInfo.Schemes = []string{"https"}
  82. //engine.GET("/docs/*any", ginSwagger.WrapHandler(swaggerFiles.Handler))
  83. err = engine.Run(config.C.Basic.Addr)
  84. fmt.Println("quit:", err)
  85. }