hardware.power.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  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. }
  14. http.HandleFunc("/system/power/accessCheck", hardware_power_checkIfHardware)
  15. }
  16. func hardware_power_checkIfHardware(w http.ResponseWriter, r *http.Request) {
  17. if *allow_hardware_management {
  18. sendJSONResponse(w, "true")
  19. } else {
  20. sendJSONResponse(w, "false")
  21. }
  22. }
  23. func hardware_power_poweroff(w http.ResponseWriter, r *http.Request) {
  24. userinfo, err := userHandler.GetUserInfoFromRequest(w, r)
  25. if err != nil {
  26. w.WriteHeader(http.StatusUnauthorized)
  27. w.Write([]byte("401 Unauthorized"))
  28. return
  29. }
  30. if !userinfo.IsAdmin() {
  31. sendErrorResponse(w, "Permission Denied")
  32. return
  33. }
  34. if !sudo_mode {
  35. sendErrorResponse(w, "Sudo mode required")
  36. return
  37. }
  38. //Double check password for this user
  39. password, err := mv(r, "pw", true)
  40. if err != nil {
  41. sendErrorResponse(w, "Password Incorrect")
  42. return
  43. }
  44. passwordCorrect := authAgent.ValidateUsernameAndPassword(userinfo.Username, password)
  45. if !passwordCorrect {
  46. sendErrorResponse(w, "Password Incorrect")
  47. return
  48. }
  49. log.Println("Shutting Down")
  50. return
  51. if runtime.GOOS == "windows" {
  52. //Only allow Linux to do power operation
  53. cmd := exec.Command("shutdown", "-s", "-t", "20")
  54. out, err := cmd.CombinedOutput()
  55. if err != nil {
  56. log.Println(string(out))
  57. sendErrorResponse(w, string(out))
  58. }
  59. log.Println(string(out))
  60. }
  61. if runtime.GOOS == "linux" {
  62. //Only allow Linux to do power operation
  63. cmd := exec.Command("/sbin/shutdown")
  64. out, err := cmd.CombinedOutput()
  65. if err != nil {
  66. log.Println(string(out))
  67. sendErrorResponse(w, string(out))
  68. }
  69. log.Println(string(out))
  70. }
  71. if runtime.GOOS == "darwin" {
  72. //Only allow Linux to do power operation
  73. cmd := exec.Command("sudo", "shutdown", "-h", "+1")
  74. out, err := cmd.CombinedOutput()
  75. if err != nil {
  76. log.Println(string(out))
  77. sendErrorResponse(w, string(out))
  78. }
  79. log.Println(string(out))
  80. }
  81. sendOK(w)
  82. }
  83. func hardware_power_restart(w http.ResponseWriter, r *http.Request) {
  84. userinfo, err := userHandler.GetUserInfoFromRequest(w, r)
  85. if err != nil {
  86. w.WriteHeader(http.StatusUnauthorized)
  87. w.Write([]byte("401 Unauthorized"))
  88. return
  89. }
  90. if !userinfo.IsAdmin() {
  91. sendErrorResponse(w, "Permission Denied")
  92. return
  93. }
  94. if !sudo_mode {
  95. sendErrorResponse(w, "Sudo mode required")
  96. return
  97. }
  98. //Double check password for this user
  99. password, err := mv(r, "pw", true)
  100. if err != nil {
  101. sendErrorResponse(w, "Password Incorrect")
  102. return
  103. }
  104. passwordCorrect := authAgent.ValidateUsernameAndPassword(userinfo.Username, password)
  105. if !passwordCorrect {
  106. sendErrorResponse(w, "Password Incorrect")
  107. return
  108. }
  109. log.Println("Restarting")
  110. return
  111. if runtime.GOOS == "windows" {
  112. //Only allow Linux to do power operation
  113. cmd := exec.Command("shutdown", "-r", "-t", "20")
  114. out, err := cmd.CombinedOutput()
  115. if err != nil {
  116. log.Println(string(out))
  117. sendErrorResponse(w, string(out))
  118. }
  119. log.Println(string(out))
  120. }
  121. if runtime.GOOS == "linux" {
  122. //Only allow Linux to do power operation
  123. cmd := exec.Command("systemctl", "reboot")
  124. out, err := cmd.CombinedOutput()
  125. if err != nil {
  126. log.Println(string(out))
  127. sendErrorResponse(w, string(out))
  128. }
  129. log.Println(string(out))
  130. }
  131. if runtime.GOOS == "darwin" {
  132. //Only allow Linux to do power operation
  133. cmd := exec.Command("shutdown", "-r", "+1")
  134. out, err := cmd.CombinedOutput()
  135. if err != nil {
  136. log.Println(string(out))
  137. sendErrorResponse(w, string(out))
  138. }
  139. log.Println(string(out))
  140. }
  141. sendOK(w)
  142. }