hardware.power.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. package main
  2. import (
  3. "log"
  4. "net/http"
  5. "os/exec"
  6. "runtime"
  7. )
  8. func HardwarePowerInit() {
  9. if *allow_hardware_management {
  10. //Only register these paths when hardware management is enabled
  11. http.HandleFunc("/system/power/shutdown", hardware_power_poweroff)
  12. http.HandleFunc("/system/power/restart", hardware_power_restart)
  13. //Register a power handler in system setting menu
  14. registerSetting(settingModule{
  15. Name: "Power",
  16. Desc: "Set the power state of the host device",
  17. IconPath: "SystemAO/boot/img/boot.png",
  18. Group: "Info",
  19. StartDir: "SystemAO/boot/poweroff.html",
  20. RequireAdmin: true,
  21. })
  22. }
  23. http.HandleFunc("/system/power/accessCheck", hardware_power_checkIfHardware)
  24. }
  25. func hardware_power_checkIfHardware(w http.ResponseWriter, r *http.Request) {
  26. if *allow_hardware_management {
  27. sendJSONResponse(w, "true")
  28. } else {
  29. sendJSONResponse(w, "false")
  30. }
  31. }
  32. func hardware_power_poweroff(w http.ResponseWriter, r *http.Request) {
  33. userinfo, err := userHandler.GetUserInfoFromRequest(w, r)
  34. if err != nil {
  35. w.WriteHeader(http.StatusUnauthorized)
  36. w.Write([]byte("401 Unauthorized"))
  37. return
  38. }
  39. if !userinfo.IsAdmin() {
  40. sendErrorResponse(w, "Permission Denied")
  41. return
  42. }
  43. if !sudo_mode {
  44. sendErrorResponse(w, "Sudo mode required")
  45. return
  46. }
  47. //Double check password for this user
  48. password, err := mv(r, "password", true)
  49. if err != nil {
  50. sendErrorResponse(w, "Password Incorrect")
  51. return
  52. }
  53. passwordCorrect := authAgent.ValidateUsernameAndPassword(userinfo.Username, password)
  54. if !passwordCorrect {
  55. sendErrorResponse(w, "Password Incorrect")
  56. return
  57. }
  58. if runtime.GOOS == "windows" {
  59. //Only allow Linux to do power operation
  60. cmd := exec.Command("shutdown", "-s", "-t", "20")
  61. out, err := cmd.CombinedOutput()
  62. if err != nil {
  63. log.Println(string(out))
  64. sendErrorResponse(w, string(out))
  65. }
  66. log.Println(string(out))
  67. }
  68. if runtime.GOOS == "linux" {
  69. //Only allow Linux to do power operation
  70. cmd := exec.Command("/sbin/shutdown")
  71. out, err := cmd.CombinedOutput()
  72. if err != nil {
  73. log.Println(string(out))
  74. sendErrorResponse(w, string(out))
  75. }
  76. log.Println(string(out))
  77. }
  78. if runtime.GOOS == "darwin" {
  79. //Only allow Linux to do power operation
  80. cmd := exec.Command("sudo", "shutdown", "-h", "+1")
  81. out, err := cmd.CombinedOutput()
  82. if err != nil {
  83. log.Println(string(out))
  84. sendErrorResponse(w, string(out))
  85. }
  86. log.Println(string(out))
  87. }
  88. sendOK(w)
  89. }
  90. func hardware_power_restart(w http.ResponseWriter, r *http.Request) {
  91. userinfo, err := userHandler.GetUserInfoFromRequest(w, r)
  92. if err != nil {
  93. w.WriteHeader(http.StatusUnauthorized)
  94. w.Write([]byte("401 Unauthorized"))
  95. return
  96. }
  97. if !userinfo.IsAdmin() {
  98. sendErrorResponse(w, "Permission Denied")
  99. return
  100. }
  101. if !sudo_mode {
  102. sendErrorResponse(w, "Sudo mode required")
  103. return
  104. }
  105. //Double check password for this user
  106. password, err := mv(r, "password", true)
  107. if err != nil {
  108. sendErrorResponse(w, "Password Incorrect")
  109. return
  110. }
  111. passwordCorrect := authAgent.ValidateUsernameAndPassword(userinfo.Username, password)
  112. if !passwordCorrect {
  113. sendErrorResponse(w, "Password Incorrect")
  114. return
  115. }
  116. if runtime.GOOS == "windows" {
  117. //Only allow Linux to do power operation
  118. cmd := exec.Command("shutdown", "-r", "-t", "20")
  119. out, err := cmd.CombinedOutput()
  120. if err != nil {
  121. log.Println(string(out))
  122. sendErrorResponse(w, string(out))
  123. }
  124. log.Println(string(out))
  125. }
  126. if runtime.GOOS == "linux" {
  127. //Only allow Linux to do power operation
  128. cmd := exec.Command("systemctl", "reboot")
  129. out, err := cmd.CombinedOutput()
  130. if err != nil {
  131. log.Println(string(out))
  132. sendErrorResponse(w, string(out))
  133. }
  134. log.Println(string(out))
  135. }
  136. if runtime.GOOS == "darwin" {
  137. //Only allow Linux to do power operation
  138. cmd := exec.Command("shutdown", "-r", "+1")
  139. out, err := cmd.CombinedOutput()
  140. if err != nil {
  141. log.Println(string(out))
  142. sendErrorResponse(w, string(out))
  143. }
  144. log.Println(string(out))
  145. }
  146. sendOK(w)
  147. }