hardware.power.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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, "password", 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. if runtime.GOOS == "windows" {
  50. //Only allow Linux to do power operation
  51. cmd := exec.Command("shutdown", "-s", "-t", "20")
  52. out, err := cmd.CombinedOutput()
  53. if err != nil {
  54. log.Println(string(out))
  55. sendErrorResponse(w, string(out))
  56. }
  57. log.Println(string(out))
  58. }
  59. if runtime.GOOS == "linux" {
  60. //Only allow Linux to do power operation
  61. cmd := exec.Command("/sbin/shutdown")
  62. out, err := cmd.CombinedOutput()
  63. if err != nil {
  64. log.Println(string(out))
  65. sendErrorResponse(w, string(out))
  66. }
  67. log.Println(string(out))
  68. }
  69. if runtime.GOOS == "darwin" {
  70. //Only allow Linux to do power operation
  71. cmd := exec.Command("sudo", "shutdown", "-h", "+1")
  72. out, err := cmd.CombinedOutput()
  73. if err != nil {
  74. log.Println(string(out))
  75. sendErrorResponse(w, string(out))
  76. }
  77. log.Println(string(out))
  78. }
  79. sendOK(w)
  80. }
  81. func hardware_power_restart(w http.ResponseWriter, r *http.Request) {
  82. userinfo, err := userHandler.GetUserInfoFromRequest(w, r)
  83. if err != nil {
  84. w.WriteHeader(http.StatusUnauthorized)
  85. w.Write([]byte("401 Unauthorized"))
  86. return
  87. }
  88. if !userinfo.IsAdmin() {
  89. sendErrorResponse(w, "Permission Denied")
  90. return
  91. }
  92. if !sudo_mode {
  93. sendErrorResponse(w, "Sudo mode required")
  94. return
  95. }
  96. //Double check password for this user
  97. password, err := mv(r, "password", true)
  98. if err != nil {
  99. sendErrorResponse(w, "Password Incorrect")
  100. return
  101. }
  102. passwordCorrect := authAgent.ValidateUsernameAndPassword(userinfo.Username, password)
  103. if !passwordCorrect {
  104. sendErrorResponse(w, "Password Incorrect")
  105. return
  106. }
  107. if runtime.GOOS == "windows" {
  108. //Only allow Linux to do power operation
  109. cmd := exec.Command("shutdown", "-r", "-t", "20")
  110. out, err := cmd.CombinedOutput()
  111. if err != nil {
  112. log.Println(string(out))
  113. sendErrorResponse(w, string(out))
  114. }
  115. log.Println(string(out))
  116. }
  117. if runtime.GOOS == "linux" {
  118. //Only allow Linux to do power operation
  119. cmd := exec.Command("systemctl", "reboot")
  120. out, err := cmd.CombinedOutput()
  121. if err != nil {
  122. log.Println(string(out))
  123. sendErrorResponse(w, string(out))
  124. }
  125. log.Println(string(out))
  126. }
  127. if runtime.GOOS == "darwin" {
  128. //Only allow Linux to do power operation
  129. cmd := exec.Command("shutdown", "-r", "+1")
  130. out, err := cmd.CombinedOutput()
  131. if err != nil {
  132. log.Println(string(out))
  133. sendErrorResponse(w, string(out))
  134. }
  135. log.Println(string(out))
  136. }
  137. sendOK(w)
  138. }