init.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package res_init
  2. import (
  3. "encoding/json"
  4. log "github.com/sirupsen/logrus"
  5. "os"
  6. "pmail/config"
  7. "pmail/db"
  8. "pmail/dto/parsemail"
  9. "pmail/hooks"
  10. "pmail/http_server"
  11. "pmail/models"
  12. "pmail/pop3_server"
  13. "pmail/services/setup/ssl"
  14. "pmail/session"
  15. "pmail/signal"
  16. "pmail/smtp_server"
  17. "pmail/utils/file"
  18. )
  19. func Init(serverVersion string) {
  20. if !config.IsInit {
  21. dirInit()
  22. go http_server.SetupStart()
  23. <-signal.InitChan
  24. http_server.SetupStop()
  25. }
  26. for {
  27. config.Init()
  28. // 启动前检查一遍证书
  29. ssl.Update(false)
  30. parsemail.Init()
  31. err := db.Init()
  32. if err != nil {
  33. panic(err)
  34. }
  35. models.SyncTables()
  36. session.Init()
  37. hooks.Init(serverVersion)
  38. // smtp server start
  39. go smtp_server.Start()
  40. go smtp_server.StartWithTLS()
  41. // http server start
  42. go http_server.HttpsStart()
  43. go http_server.HttpStart()
  44. // pop3 server start
  45. go pop3_server.Start()
  46. go pop3_server.StartWithTls()
  47. configStr, _ := json.Marshal(config.Instance)
  48. log.Warnf("Config File Info: %s", configStr)
  49. <-signal.RestartChan
  50. log.Infof("Server Restart!")
  51. smtp_server.Stop()
  52. http_server.HttpsStop()
  53. http_server.HttpStop()
  54. pop3_server.Stop()
  55. }
  56. }
  57. func dirInit() {
  58. if !file.PathExist("./config") {
  59. err := os.MkdirAll("./config", 0744)
  60. if err != nil {
  61. panic(err)
  62. }
  63. }
  64. if !file.PathExist("./config/dkim") {
  65. err := os.MkdirAll("./config/dkim", 0744)
  66. if err != nil {
  67. panic(err)
  68. }
  69. }
  70. if !file.PathExist("./config/ssl") {
  71. err := os.MkdirAll("./config/ssl", 0744)
  72. if err != nil {
  73. panic(err)
  74. }
  75. }
  76. }