main.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "net/http"
  6. "time"
  7. "github.com/IceWhaleTech/CasaOS/pkg/cache"
  8. "github.com/IceWhaleTech/CasaOS/pkg/config"
  9. "github.com/IceWhaleTech/CasaOS/pkg/sqlite"
  10. loger2 "github.com/IceWhaleTech/CasaOS/pkg/utils/loger"
  11. "github.com/IceWhaleTech/CasaOS/route"
  12. "github.com/IceWhaleTech/CasaOS/service"
  13. model2 "github.com/IceWhaleTech/CasaOS/service/model"
  14. "github.com/IceWhaleTech/CasaOS/types"
  15. "github.com/robfig/cron"
  16. "gorm.io/gorm"
  17. )
  18. var sqliteDB *gorm.DB
  19. var configFlag = flag.String("c", "", "config address")
  20. var dbFlag = flag.String("db", "", "db path")
  21. var showUserInfo = flag.Bool("show-user-info", false, "show user info")
  22. func init() {
  23. flag.Parse()
  24. config.InitSetup(*configFlag)
  25. config.UpdateSetup()
  26. loger2.LogSetup()
  27. if len(*dbFlag) == 0 {
  28. *dbFlag = config.AppInfo.ProjectPath + "/db"
  29. }
  30. sqliteDB = sqlite.GetDb(*dbFlag)
  31. //gredis.GetRedisConn(config.RedisInfo),
  32. service.MyService = service.NewService(sqliteDB, loger2.NewOLoger())
  33. service.Cache = cache.Init()
  34. go service.UDPService()
  35. fmt.Println("token", service.GetToken())
  36. service.UDPAddressMap = make(map[string]string)
  37. //go service.SocketConnect()
  38. service.CancelList = make(map[string]string)
  39. service.InternalInspection = make(map[string][]string)
  40. service.NewVersionApp = make(map[string]string)
  41. route.InitFunction()
  42. go service.SendIPToServer()
  43. // go service.LoopFriend()
  44. // go service.MyService.App().CheckNewImage()
  45. }
  46. // @title casaOS API
  47. // @version 1.0.0
  48. // @contact.name lauren.pan
  49. // @contact.url https://www.zimaboard.com
  50. // @contact.email lauren.pan@icewhale.org
  51. // @description casaOS v1版本api
  52. // @host 192.168.2.217:8089
  53. // @securityDefinitions.apikey ApiKeyAuth
  54. // @in header
  55. // @name Authorization
  56. // @BasePath /v1
  57. func main() {
  58. if *showUserInfo {
  59. fmt.Println("CasaOS User Info")
  60. fmt.Println("UserName:" + config.UserInfo.UserName)
  61. fmt.Println("Password:" + config.UserInfo.PWD)
  62. return
  63. }
  64. //model.Setup()
  65. //gredis.Setup()
  66. r := route.InitRouter()
  67. //service.SyncTask(sqliteDB)
  68. cron2 := cron.New()
  69. //every day execution
  70. err := cron2.AddFunc("0 0/5 * * * *", func() {
  71. //service.PushIpInfo(*&config.ServerInfo.Token)
  72. //service.UpdataDDNSList(mysqldb)
  73. //service.SyncTask(sqliteDB)
  74. service.SendIPToServer()
  75. service.LoopFriend()
  76. service.MyService.App().CheckNewImage()
  77. })
  78. if err != nil {
  79. fmt.Println(err)
  80. }
  81. err = cron2.AddFunc("0/1 * * * * *", func() {
  82. notify := model2.AppNotify{}
  83. notify.CustomId = ""
  84. notify.Type = types.NOTIFY_TYPE_HEALTH_CHECK
  85. go service.MyService.Notify().SendText(notify)
  86. })
  87. if err != nil {
  88. fmt.Println(err)
  89. }
  90. cron2.Start()
  91. defer cron2.Stop()
  92. s := &http.Server{
  93. Addr: fmt.Sprintf(":%v", config.ServerInfo.HttpPort),
  94. Handler: r,
  95. ReadTimeout: 60 * time.Second,
  96. WriteTimeout: 60 * time.Second,
  97. MaxHeaderBytes: 1 << 20,
  98. }
  99. s.ListenAndServe()
  100. }