api.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. //go:build !migrate && !createApp && !project
  2. package server
  3. import (
  4. "IotAdmin/app/router"
  5. "IotAdmin/app/schedule/jobs"
  6. "IotAdmin/app/system/models"
  7. "IotAdmin/common/database"
  8. "IotAdmin/common/global"
  9. "IotAdmin/common/middleware"
  10. "IotAdmin/common/storage"
  11. ext "IotAdmin/config"
  12. "IotAdmin/core/config/source/file"
  13. "IotAdmin/core/sdk"
  14. "IotAdmin/core/sdk/config"
  15. "IotAdmin/core/sdk/pkg"
  16. "context"
  17. "errors"
  18. "fmt"
  19. "log"
  20. "net/http"
  21. "os"
  22. "os/signal"
  23. "time"
  24. "github.com/gin-gonic/gin"
  25. "github.com/spf13/pflag"
  26. )
  27. var (
  28. apiCheck = pflag.BoolP("api", "a", false, "启动服务器检查 API 数据")
  29. )
  30. // 初始化
  31. func init() {
  32. // 注入配置扩展项
  33. config.ExtendConfig = &ext.ExtConfig
  34. //1. 读取配置
  35. config.Setup(
  36. file.NewSource(file.WithPath(*configYml)),
  37. database.Setup,
  38. storage.Setup,
  39. )
  40. //2. 注册监听函数
  41. queue := sdk.Runtime.GetMemoryQueue("")
  42. queue.Register(global.LoginLog, models.SaveLoginLog)
  43. queue.Register(global.OperateLog, models.SaveOperaLog)
  44. queue.Register(global.ApiCheck, models.SaveSysApi)
  45. go queue.Run()
  46. //3. 注册路由
  47. // 在app/router目录下新建文件 放在init方法 参考system
  48. usageStr := `正在启动API服务...`
  49. log.Println(usageStr)
  50. }
  51. func Init() {
  52. if config.ApplicationConfig.Mode == pkg.ModeProd.String() {
  53. gin.SetMode(gin.ReleaseMode)
  54. }
  55. initWebServer()
  56. srv := &http.Server{
  57. Addr: fmt.Sprintf("%s:%d", config.ApplicationConfig.Host, config.ApplicationConfig.Port),
  58. Handler: sdk.Runtime.GetEngine(),
  59. }
  60. // 定时任务
  61. go jobs.InitJob()
  62. if *apiCheck {
  63. var routers = sdk.Runtime.GetRouter()
  64. q := sdk.Runtime.GetMemoryQueue("")
  65. mp := make(map[string]interface{})
  66. mp["List"] = routers
  67. message, err := sdk.Runtime.GetStreamMessage("", global.ApiCheck, mp)
  68. if err != nil {
  69. log.Printf("GetStreamMessage 错误, %s \n", err.Error())
  70. //日志报错错误,不中断请求
  71. } else {
  72. err = q.Append(message)
  73. if err != nil {
  74. log.Printf("Append Message 错误, %s \n", err.Error())
  75. }
  76. }
  77. }
  78. go func() {
  79. // 服务连接
  80. if config.SslConfig.Enable {
  81. if err := srv.ListenAndServeTLS(config.SslConfig.Pem, config.SslConfig.KeyStr); err != nil && !errors.Is(err, http.ErrServerClosed) {
  82. log.Fatal("监听TLS错误: ", err)
  83. }
  84. } else {
  85. if err := srv.ListenAndServe(); err != nil && !errors.Is(err, http.ErrServerClosed) {
  86. log.Fatal("监听错误: ", err)
  87. }
  88. }
  89. }()
  90. fmt.Println(pkg.Green("Server Run At:"))
  91. fmt.Printf("- Local: %s://localhost:%d/ \r\n", "http", config.ApplicationConfig.Port)
  92. fmt.Printf("- Network: %s://%s:%d/ \r\n", "http", pkg.GetLocalHost(), config.ApplicationConfig.Port)
  93. fmt.Println(pkg.Green("Swagger Run At:"))
  94. fmt.Printf("- Local: http://localhost:%d/swagger/admin/index.html \r\n", config.ApplicationConfig.Port)
  95. fmt.Printf("- Network: %s://%s:%d/swagger/system/index.html \r\n", "http", pkg.GetLocalHost(), config.ApplicationConfig.Port)
  96. fmt.Printf("%s 输入 Control + C 关闭服务 \r\n", pkg.GetCurrentTimeStr())
  97. // 等待中断信号以优雅地关闭服务器(设置 5 秒的超时时间)
  98. quit := make(chan os.Signal, 1)
  99. signal.Notify(quit, os.Interrupt)
  100. <-quit
  101. ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
  102. defer cancel()
  103. fmt.Printf("%s 关闭服务... \r\n", pkg.GetCurrentTimeStr())
  104. if err := srv.Shutdown(ctx); err != nil {
  105. log.Fatal("服务关闭:", err)
  106. }
  107. log.Println("服务退出")
  108. }
  109. func initWebServer() {
  110. var r *gin.Engine
  111. h := sdk.Runtime.GetEngine()
  112. if h == nil {
  113. h = gin.New()
  114. sdk.Runtime.SetEngine(h)
  115. }
  116. switch h.(type) {
  117. case *gin.Engine:
  118. r = h.(*gin.Engine)
  119. // 注册中间件
  120. middleware.UseGinMiddleware(r)
  121. // 注册路由
  122. router.RegisterRouter()
  123. default:
  124. log.Fatal("不支持其他 Engine")
  125. //os.Exit(-1)
  126. }
  127. }