Brak opisu
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

main.go 2.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. package main
  2. import (
  3. "context"
  4. "log"
  5. "git.x2erp.com/qdy/go-base/auth"
  6. "git.x2erp.com/qdy/go-base/config"
  7. "git.x2erp.com/qdy/go-base/container"
  8. "git.x2erp.com/qdy/go-base/ctx"
  9. "git.x2erp.com/qdy/go-base/graceful"
  10. "git.x2erp.com/qdy/go-base/logger"
  11. "git.x2erp.com/qdy/go-base/model/response"
  12. "git.x2erp.com/qdy/go-base/webx"
  13. "git.x2erp.com/qdy/go-base/webx/router"
  14. "git.x2erp.com/qdy/go-db/factory/database"
  15. "git.x2erp.com/qdy/go-db/sqldef"
  16. "git.x2erp.com/qdy/go-svc-configure/internal/service"
  17. _ "git.x2erp.com/qdy/go-svc-configure/internal/tables" // 导入表定义包,触发 init() 函数
  18. )
  19. var (
  20. appName = "svc-configure"
  21. appVersion = "1"
  22. )
  23. func main() {
  24. // 0. 初始化日志
  25. logBootFactory := logger.InitBootLog()
  26. // 1. 获取配置文件
  27. cfg := config.GetConfig()
  28. cfg.SetAppName(appName)
  29. cfg.SetAppVersion(appVersion)
  30. // 2. 创建关闭容器
  31. ctr := container.NewContainer(cfg)
  32. // 注册日志,实现自动关闭
  33. container.Reg(ctr, logBootFactory)
  34. // 3. 创建数据库工厂
  35. dbFactory := container.Create(ctr, database.CreateDBFactory)
  36. dbFactory.TestConnection()
  37. // 创建表
  38. creteTabel(dbFactory)
  39. //启用运行日志
  40. container.Create(ctr, logger.InitRuntimeLogger)
  41. //建立httpservice
  42. //得到webservice服务工厂
  43. webxFactory := webx.GetWebServiceFactory()
  44. //建立hhtpService服务
  45. webServcie, _ := webxFactory.CreateService(cfg.GetServiceConfig())
  46. //建立路由-api
  47. routerService := router.NewWebService(webServcie.GetRouter())
  48. //注册路由--api
  49. registerRoutes(routerService, dbFactory)
  50. //启动服务
  51. webServcie.Run()
  52. //等待关闭
  53. graceful.WaitForShutdown(cfg.GetServiceConfig().ServiceName, ctr, webServcie.GetServer())
  54. }
  55. // 注册所有路由
  56. func registerRoutes(ws *router.RouterService, dbFactory *database.DBFactory) {
  57. // ws.POST("/api/query/yaml",
  58. // func(req request.QueryRequest, reqCtx *ctx.RequestContext) (*response.QueryResult[map[string]interface{}], error) {
  59. // result := service.QueryYamlConfigure(dbFactory, req, reqCtx)
  60. // return result, nil
  61. // },
  62. // ).Use(middleware.JWTAuthMiddleware).Register()
  63. ws.POST("/api/init/config/meta",
  64. func(ctx context.Context, reqCtx *ctx.RequestContext) (*response.QueryResult[map[string]interface{}], error) {
  65. result := service.SyncAllConfigMeta(ctx, dbFactory, reqCtx)
  66. return result, nil
  67. },
  68. ).Use(auth.TokenAuth).Register()
  69. }
  70. func creteTabel(factory *database.DBFactory) {
  71. // 获取数据库连接和类型
  72. db := factory.GetDB()
  73. dbType := factory.GetDBType()
  74. // 创建表同步器
  75. syncer, err := sqldef.NewTableSyncer(db, dbType)
  76. if err != nil {
  77. log.Printf("创建 - 建立器失败: %v", err)
  78. }
  79. // 创建表
  80. if err := syncer.CreateTables(); err != nil {
  81. log.Printf("建表失败: %v", err)
  82. }
  83. log.Println("数据库表建立完成!")
  84. }