main.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "log"
  6. "net/http"
  7. "os"
  8. "os/signal"
  9. "path/filepath"
  10. "strconv"
  11. "syscall"
  12. "time"
  13. console "imuslab.com/arozos/mod/console"
  14. )
  15. /*
  16. arozos
  17. author: tobychui
  18. To edit startup flags, see main.flag.go
  19. To edit main routing logic, see main.router.go
  20. To edit startup sequence, see startup.go
  21. P.S. Try to keep this file < 300 lines
  22. */
  23. // Close handler, close db and clearn up everything before exit
  24. func SetupCloseHandler() {
  25. c := make(chan os.Signal, 2)
  26. signal.Notify(c, os.Interrupt, syscall.SIGTERM)
  27. go func() {
  28. <-c
  29. executeShutdownSequence()
  30. }()
  31. }
  32. func executeShutdownSequence() {
  33. //Shutdown authAgent
  34. systemWideLogger.PrintAndLog("System", "<!> Shutting down auth gateway", nil)
  35. authAgent.Close()
  36. //Shutdown all storage pools
  37. systemWideLogger.PrintAndLog("System", "<!> Shutting down storage pools", nil)
  38. closeAllStoragePools()
  39. //Shutdown Logger
  40. systemWideLogger.Close()
  41. //Shutdown database
  42. systemWideLogger.PrintAndLog("System", "<!> Shutting down database", nil)
  43. sysdb.Close()
  44. //Shutdown network services
  45. StopNetworkServices()
  46. //Shutdown FTP Server
  47. if FTPManager != nil {
  48. systemWideLogger.PrintAndLog("System", "<!> Shutting down FTP Server", nil)
  49. FTPManager.StopFtpServer()
  50. }
  51. //Cleaning up tmp files
  52. systemWideLogger.PrintAndLog("System", "<!> Cleaning up tmp folder", nil)
  53. os.RemoveAll(*tmp_directory)
  54. //Do other things
  55. os.Exit(0)
  56. }
  57. func main() {
  58. //Parse startup flags and paramters
  59. flag.Parse()
  60. //Handle version printing
  61. if *show_version {
  62. fmt.Println("ArozOS " + build_version + " Revision " + internal_version)
  63. fmt.Println("Developed by tobychui and other co-developers, Licensed to " + deviceVendor)
  64. //fmt.Println("THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.")
  65. os.Exit(0)
  66. }
  67. //Handle flag assignments
  68. max_upload_size = int64(*max_upload) << 20 //Parse the max upload size
  69. //Clean up previous tmp files
  70. final_tmp_directory := filepath.Clean(*tmp_directory) + "/tmp/"
  71. tmp_directory = &final_tmp_directory
  72. os.RemoveAll(*tmp_directory)
  73. os.Mkdir(*tmp_directory, 0777)
  74. //Print copyRight information
  75. log.Println("ArozOS(C) " + strconv.Itoa(time.Now().Year()) + " " + deviceVendor + ".")
  76. log.Println("ArozOS " + build_version + " Revision " + internal_version)
  77. /*
  78. New Implementation of the ArOZ Online System, Sept 2020
  79. */
  80. RunStartup()
  81. /*
  82. Development build test execution
  83. */
  84. Run_Test()
  85. //Initiate all the static files transfer
  86. fs := http.FileServer(http.Dir("./web"))
  87. //Updates 2022-09-06: Gzip handler moved inside the master router
  88. http.Handle("/", mrouter(fs))
  89. //Setup handler for Ctrl +C
  90. SetupCloseHandler()
  91. //Start http server
  92. go func() {
  93. if *use_tls {
  94. if !*disable_http {
  95. go func() {
  96. address := fmt.Sprintf("%s:%d", *listen_host, *listen_port)
  97. log.Println("Standard (HTTP) Web server listening at", address)
  98. http.ListenAndServe(address, nil)
  99. }()
  100. }
  101. address := fmt.Sprintf("%s:%d", *listen_host, *tls_listen_port)
  102. log.Println("Secure (HTTPS) Web server listening at", address)
  103. http.ListenAndServeTLS(address, *tls_cert, *tls_key, nil)
  104. } else {
  105. address := fmt.Sprintf("%s:%d", *listen_host, *listen_port)
  106. log.Println("Web server listening at", address)
  107. http.ListenAndServe(address, nil)
  108. }
  109. }()
  110. if *enable_console {
  111. //Startup interactive shell for debug and basic controls
  112. Console := console.NewConsole(consoleCommandHandler)
  113. Console.ListenAndHandle()
  114. } else {
  115. //Just do a blocking loop here
  116. select {}
  117. }
  118. }