handlers.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. package samba
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "path/filepath"
  6. "strings"
  7. "imuslab.com/arozos/mod/utils"
  8. )
  9. // Get current samba service status
  10. func (s *ShareManager) SmbdStates(w http.ResponseWriter, r *http.Request) {
  11. set, err := utils.PostPara(r, "set")
  12. if err != nil {
  13. //return the current smbd states
  14. smbdRunning, err := IsSmbdRunning()
  15. if err != nil {
  16. utils.SendErrorResponse(w, err.Error())
  17. return
  18. }
  19. js, _ := json.Marshal(smbdRunning)
  20. utils.SendJSONResponse(w, string(js))
  21. return
  22. } else if set == "enable" {
  23. //Set smbd to enable
  24. err = SetSmbdEnableState(true)
  25. if err != nil {
  26. utils.SendErrorResponse(w, err.Error())
  27. return
  28. }
  29. utils.SendOK(w)
  30. return
  31. } else if set == "disable" {
  32. //Set smbd to disable
  33. err = SetSmbdEnableState(false)
  34. if err != nil {
  35. utils.SendErrorResponse(w, err.Error())
  36. return
  37. }
  38. utils.SendOK(w)
  39. return
  40. }
  41. utils.SendErrorResponse(w, "not support set state: "+set+". Only support enable /disable")
  42. }
  43. // List all the samba shares
  44. func (s *ShareManager) ListSambaShares(w http.ResponseWriter, r *http.Request) {
  45. shares, err := s.ReadSambaShares()
  46. if err != nil {
  47. utils.SendErrorResponse(w, err.Error())
  48. return
  49. }
  50. //Remove those shares that is reserved by systems
  51. shares = s.FilterSystemCreatedShares(shares)
  52. js, _ := json.Marshal(shares)
  53. utils.SendJSONResponse(w, string(js))
  54. }
  55. // Add a samba share
  56. func (s *ShareManager) AddSambaShare(w http.ResponseWriter, r *http.Request) {
  57. shareName, err := utils.PostPara(r, "name")
  58. if err != nil {
  59. utils.SendErrorResponse(w, "share name not given")
  60. return
  61. }
  62. shareName = strings.TrimSpace(shareName)
  63. //Check if this share name already been used
  64. shareNameExists, err := s.ShareNameExists(shareName)
  65. if err != nil {
  66. utils.SendErrorResponse(w, err.Error())
  67. return
  68. }
  69. if shareNameExists {
  70. utils.SendErrorResponse(w, "share with identical name already exists")
  71. return
  72. }
  73. sharePath, err := utils.PostPara(r, "path")
  74. if err != nil {
  75. utils.SendErrorResponse(w, "share path not given")
  76. return
  77. }
  78. //Parse the path to absolute path
  79. absoluteSharePath, err := filepath.Abs(sharePath)
  80. if err != nil {
  81. utils.SendErrorResponse(w, err.Error())
  82. return
  83. }
  84. //Check if path exists
  85. if !utils.FileExists(absoluteSharePath) {
  86. utils.SendErrorResponse(w, "target path not exists")
  87. return
  88. }
  89. //Check if target path is a folder
  90. if !utils.IsDir(absoluteSharePath) {
  91. utils.SendErrorResponse(w, "target path is not a directory")
  92. return
  93. }
  94. validUsersJSON, err := utils.PostPara(r, "users")
  95. if err != nil {
  96. utils.SendErrorResponse(w, "no valid user givens")
  97. return
  98. }
  99. //Parse valid users into string slice
  100. validUsers := []string{}
  101. err = json.Unmarshal([]byte(validUsersJSON), &validUsers)
  102. if err != nil {
  103. utils.SendErrorResponse(w, "unable to parse JSON for valid users")
  104. return
  105. }
  106. //Check if all the users exists in the host OS
  107. readOnly, err := utils.PostBool(r, "readonly")
  108. if err != nil {
  109. readOnly = false
  110. }
  111. browseable, err := utils.PostBool(r, "browseable")
  112. if err != nil {
  113. browseable = true
  114. }
  115. allowGuest, err := utils.PostBool(r, "guestok")
  116. if err != nil {
  117. allowGuest = false
  118. }
  119. shareToCreate := ShareConfig{
  120. Name: shareName,
  121. Path: absoluteSharePath,
  122. ValidUsers: validUsers,
  123. ReadOnly: readOnly,
  124. Browseable: browseable,
  125. GuestOk: allowGuest,
  126. }
  127. //Add the new share to smb.conf
  128. err = s.CreateNewSambaShare(&shareToCreate)
  129. if err != nil {
  130. utils.SendErrorResponse(w, err.Error())
  131. return
  132. }
  133. //Restart smbd
  134. err = restartSmbd()
  135. if err != nil {
  136. utils.SendErrorResponse(w, err.Error())
  137. return
  138. }
  139. utils.SendOK(w)
  140. }
  141. // Remove a samba share by name
  142. func (s *ShareManager) DelSambaShare(w http.ResponseWriter, r *http.Request) {
  143. shareName, err := utils.PostPara(r, "name")
  144. if err != nil {
  145. utils.SendErrorResponse(w, "share name not given")
  146. return
  147. }
  148. //Check if share exists
  149. shareExists, err := s.ShareExists(shareName)
  150. if err != nil {
  151. utils.SendErrorResponse(w, err.Error())
  152. return
  153. }
  154. if !shareExists {
  155. utils.SendErrorResponse(w, "share to be remove not exists")
  156. return
  157. }
  158. //Remove the share from config file
  159. err = s.RemoveSambaShareConfig(shareName)
  160. if err != nil {
  161. utils.SendErrorResponse(w, err.Error())
  162. return
  163. }
  164. //Restart smbd
  165. err = restartSmbd()
  166. if err != nil {
  167. utils.SendErrorResponse(w, err.Error())
  168. return
  169. }
  170. utils.SendOK(w)
  171. }
  172. // Add a new samba user
  173. func (s *ShareManager) NewSambaUser(w http.ResponseWriter, r *http.Request) {
  174. //TODO: Replace the GetPara to Post
  175. username, err := utils.GetPara(r, "username")
  176. if err != nil {
  177. utils.SendErrorResponse(w, "username not given")
  178. return
  179. }
  180. password, err := utils.GetPara(r, "password")
  181. if err != nil {
  182. utils.SendErrorResponse(w, "password not set")
  183. return
  184. }
  185. err = s.AddSambaUser(username, password)
  186. if err != nil {
  187. utils.SendErrorResponse(w, err.Error())
  188. return
  189. }
  190. utils.SendOK(w)
  191. }
  192. // Remove a samba user
  193. func (s *ShareManager) DelSambaUser(w http.ResponseWriter, r *http.Request) {
  194. username, err := utils.GetPara(r, "username")
  195. if err != nil {
  196. utils.SendErrorResponse(w, "username not given")
  197. return
  198. }
  199. //Remove the samba user
  200. err = s.RemoveSmbUser(username)
  201. if err != nil {
  202. utils.SendErrorResponse(w, err.Error())
  203. return
  204. }
  205. utils.SendOK(w)
  206. }
  207. // List all samba users info
  208. func (s *ShareManager) ListSambaUsers(w http.ResponseWriter, r *http.Request) {
  209. userInfo, err := s.ListSambaUsersInfo()
  210. if err != nil {
  211. utils.SendErrorResponse(w, err.Error())
  212. return
  213. }
  214. js, _ := json.Marshal(userInfo)
  215. utils.SendJSONResponse(w, string(js))
  216. }