智慧食堂
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.

130 lines
3.6 KiB

  1. package main
  2. import (
  3. "applet/app/db"
  4. "context"
  5. "fmt"
  6. "log"
  7. "net/http"
  8. "os"
  9. "os/signal"
  10. "syscall"
  11. "time"
  12. "applet/app/cfg"
  13. "applet/app/router"
  14. )
  15. //系统初始化
  16. func init() {
  17. cfg.InitCfg() //配置初始化
  18. cfg.InitLog() //日志初始化
  19. cfg.InitCache() //缓存初始化
  20. cfg.InitMq() //队列初始化
  21. if cfg.Debug { //判断是否是debug
  22. if err := db.InitDB(cfg.DB); err != nil { //主数据库初始化
  23. panic(err)
  24. }
  25. }
  26. fmt.Println("init success")
  27. }
  28. func main() {
  29. //svc.CentralKitchenForSchoolAlipayTradeFastpayRefundQuery(db.Db)
  30. //var list []model.CentralKitchenForSchoolUserRefundDay
  31. //if err := db.Db.Where("create_at >= '2024-01-15 18:00:00' AND state = 4 and uid < 0").Desc("id").Find(&list); err != nil {
  32. // fmt.Println(err)
  33. //}
  34. //
  35. //var notCanUserIds []int
  36. //for _, v := range list {
  37. // v.RecordsId = -v.RecordsId
  38. // v.OutTradeNo = "-" + v.OutTradeNo
  39. // affected1, err := db.Db.Where("id=?", v.Id).Cols("records_id", "out_trade_no").Update(&v)
  40. // if err != nil {
  41. // fmt.Println(err)
  42. // }
  43. // fmt.Println(">>>>>>>>>>>>>>>>>affected1<<<<<<<<<<<<<<<<<<<", affected1)
  44. // continue
  45. // var mm []model.CentralKitchenForSchoolUserRefundDay
  46. // if err := db.Db.Where("uid = ?", v.Uid).And("state = 1").Desc("records_id").Find(&mm); err != nil {
  47. // fmt.Println(err)
  48. // }
  49. //
  50. // if len(mm) > 0 {
  51. // mmm := new(model.CentralKitchenForSchoolUserWithDay)
  52. // _, err := db.Db.Where("id =?", mm[0].RecordsId).Get(mmm)
  53. // if err != nil {
  54. // fmt.Println(err)
  55. // }
  56. // //if mmm.Date == "2024-01-31" {
  57. // //1、更改当前记录
  58. // v.Uid = -v.Uid
  59. // affected1, err := db.Db.Where("id=?", v.Id).Cols("uid").Update(&v)
  60. // if err != nil {
  61. // fmt.Println(err)
  62. // }
  63. // fmt.Println(">>>>>>>>>>>>>>>>>affected1<<<<<<<<<<<<<<<<<<<", affected1)
  64. // vv := new(model.CentralKitchenForSchoolUserWithDay)
  65. // _, err = db.Db.Where("id =?", v.RecordsId).Get(vv)
  66. // if err != nil {
  67. // fmt.Println(err)
  68. // }
  69. // vv.State = 2
  70. // affected11, err := db.Db.Where("id=?", vv.Id).Cols("state").Update(vv)
  71. // if err != nil {
  72. // fmt.Println(err)
  73. // }
  74. // fmt.Println(">>>>>>>>>>>>>>>>>affected11<<<<<<<<<<<<<<<<<<<", affected11)
  75. //
  76. // //2、更改兑换记录
  77. // mm[0].OutRequestNo = v.OutRequestNo
  78. // mm[0].State = v.State
  79. // mm[0].RefundDate = v.RefundDate
  80. // mm[0].Memo = "exchange"
  81. // affected2, err := db.Db.Where("id=?", mm[0].Id).Cols("out_request_no", "state", "refund_date", "memo").Update(mm[0])
  82. // if err != nil {
  83. // fmt.Println(err)
  84. // }
  85. // fmt.Println(">>>>>>>>>>>>>>>>>affected2<<<<<<<<<<<<<<<<<<<", affected2)
  86. // mmm.State = 4
  87. // affected22, err := db.Db.Where("id=?", mmm.Id).Cols("state").Update(mmm)
  88. // if err != nil {
  89. // fmt.Println(err)
  90. // }
  91. // fmt.Println(">>>>>>>>>>>>>>>>>affected22<<<<<<<<<<<<<<<<<<<", affected22)
  92. //
  93. // //}
  94. // } else {
  95. // notCanUserIds = append(notCanUserIds, v.Uid)
  96. // }
  97. //}
  98. r := router.Init() //创建路由
  99. srv := &http.Server{ //设置http服务参数
  100. Addr: cfg.SrvAddr, //指定ip和端口
  101. Handler: r, //指定路由
  102. }
  103. go func() { //协程启动监听http服务
  104. fmt.Println("Listening and serving HTTP on " + cfg.SrvAddr)
  105. if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
  106. log.Fatalf("listen: %s\n", err)
  107. }
  108. }()
  109. //退出go守护进程
  110. quit := make(chan os.Signal)
  111. signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
  112. <-quit
  113. log.Println("Shutting down server...")
  114. ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
  115. defer cancel()
  116. if err := srv.Shutdown(ctx); err != nil {
  117. log.Fatal("Server forced to shutdown:", err)
  118. }
  119. log.Println("Server exiting")
  120. }