network.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612
  1. package main
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "strconv"
  6. "strings"
  7. "imuslab.com/arozos/mod/fileservers"
  8. "imuslab.com/arozos/mod/fileservers/servers/dirserv"
  9. "imuslab.com/arozos/mod/fileservers/servers/ftpserv"
  10. "imuslab.com/arozos/mod/fileservers/servers/samba"
  11. "imuslab.com/arozos/mod/fileservers/servers/sftpserv"
  12. "imuslab.com/arozos/mod/fileservers/servers/tftpserv"
  13. "imuslab.com/arozos/mod/fileservers/servers/webdavserv"
  14. network "imuslab.com/arozos/mod/network"
  15. mdns "imuslab.com/arozos/mod/network/mdns"
  16. "imuslab.com/arozos/mod/network/netstat"
  17. ssdp "imuslab.com/arozos/mod/network/ssdp"
  18. upnp "imuslab.com/arozos/mod/network/upnp"
  19. "imuslab.com/arozos/mod/network/websocket"
  20. prout "imuslab.com/arozos/mod/prouter"
  21. "imuslab.com/arozos/mod/utils"
  22. "imuslab.com/arozos/mod/www"
  23. )
  24. var (
  25. //Network Services Managers
  26. MDNS *mdns.MDNSHost
  27. UPNP *upnp.UPnPClient
  28. SSDP *ssdp.SSDPHost
  29. WebSocketRouter *websocket.Router
  30. //File Server Managers
  31. FTPManager *ftpserv.Manager
  32. TFTPManager *tftpserv.Manager
  33. WebDAVManager *webdavserv.Manager
  34. SFTPManager *sftpserv.Manager
  35. SambaShareManager *samba.ShareManager
  36. DirListManager *dirserv.Manager
  37. )
  38. func NetworkServiceInit() {
  39. systemWideLogger.PrintAndLog("Network", "Starting ArOZ Network Services", nil)
  40. //Create a router that allow users with System Setting access to access these api endpoints
  41. router := prout.NewModuleRouter(prout.RouterOption{
  42. ModuleName: "System Setting",
  43. AdminOnly: false,
  44. UserHandler: userHandler,
  45. DeniedHandler: func(w http.ResponseWriter, r *http.Request) {
  46. utils.SendErrorResponse(w, "Permission Denied")
  47. },
  48. })
  49. /*
  50. Standard Network Utilties
  51. */
  52. //Register handler endpoints
  53. if *allow_hardware_management {
  54. router.HandleFunc("/system/network/getNICinfo", network.GetNICInfo)
  55. router.HandleFunc("/system/network/getPing", network.GetPing)
  56. //Register as a system setting
  57. registerSetting(settingModule{
  58. Name: "Network Info",
  59. Desc: "Network Information",
  60. IconPath: "SystemAO/network/img/ethernet.png",
  61. Group: "Network",
  62. StartDir: "SystemAO/network/hardware.html",
  63. })
  64. }
  65. router.HandleFunc("/system/network/getNICUsage", netstat.HandleGetNetworkInterfaceStats)
  66. //Start the services that depends on network interface
  67. StartNetworkServices()
  68. //Start the port forward configuration interface
  69. portForwardInit()
  70. //Start userhomepage if enabled
  71. //Handle user webroot routings if homepage is enabled
  72. if *allow_homepage {
  73. userWwwHandler = www.NewWebRootHandler(www.Options{
  74. UserHandler: userHandler,
  75. Database: sysdb,
  76. AgiGateway: AGIGateway,
  77. })
  78. router.HandleFunc("/system/network/www/toggle", userWwwHandler.HandleToggleHomepage)
  79. router.HandleFunc("/system/network/www/webRoot", userWwwHandler.HandleSetWebRoot)
  80. //Register as a system setting
  81. registerSetting(settingModule{
  82. Name: "Personal Page",
  83. Desc: "Personal Web Page",
  84. IconPath: "SystemAO/www/img/homepage.png",
  85. Group: "Network",
  86. StartDir: "SystemAO/www/config.html",
  87. })
  88. }
  89. userRouter := prout.NewModuleRouter(prout.RouterOption{
  90. AdminOnly: false,
  91. UserHandler: userHandler,
  92. DeniedHandler: func(w http.ResponseWriter, r *http.Request) {
  93. utils.SendErrorResponse(w, "Permission Denied")
  94. },
  95. })
  96. WebSocketRouter = websocket.NewRouter()
  97. userRouter.HandleFunc("/system/ws", WebSocketRouter.HandleWebSocketRouting)
  98. }
  99. func StartNetworkServices() {
  100. /*
  101. MDNS Services
  102. */
  103. if *allow_mdns {
  104. m, err := mdns.NewMDNS(mdns.NetworkHost{
  105. HostName: *host_name + "_" + deviceUUID, //To handle more than one identical model within the same network, this must be unique
  106. Port: *listen_port,
  107. Domain: "arozos.com",
  108. Model: deviceModel,
  109. UUID: deviceUUID,
  110. Vendor: deviceVendor,
  111. BuildVersion: build_version,
  112. MinorVersion: internal_version,
  113. }, *force_mac)
  114. if err != nil {
  115. systemWideLogger.PrintAndLog("Network", "MDNS Startup Failed. Running in Offline Mode.", err)
  116. } else {
  117. MDNS = m
  118. }
  119. }
  120. /*
  121. SSDP Discovery Services
  122. */
  123. if *allow_ssdp {
  124. //Get outbound ip
  125. obip, err := network.GetOutboundIP()
  126. if err != nil {
  127. systemWideLogger.PrintAndLog("Network", "SSDP Startup Failed. Running in Offline Mode.", err)
  128. } else {
  129. thisIp := obip.String()
  130. adv, err := ssdp.NewSSDPHost(thisIp, *listen_port, "system/ssdp.xml", ssdp.SSDPOption{
  131. URLBase: "http://" + thisIp + ":" + strconv.Itoa(*listen_port), //This must be http if used as local hosting devices
  132. Hostname: *host_name,
  133. Vendor: deviceVendor,
  134. VendorURL: deviceVendorURL,
  135. ModelName: deviceModel,
  136. ModelDesc: deviceModelDesc,
  137. UUID: deviceUUID,
  138. Serial: "generic",
  139. })
  140. if err != nil {
  141. systemWideLogger.PrintAndLog("Network", "SSDP Startup Failed. Running in Offline Mode.", err)
  142. } else {
  143. //OK! Start SSDP Service
  144. SSDP = adv
  145. SSDP.Start()
  146. }
  147. }
  148. }
  149. /*
  150. UPNP / Setup automatic port forwarding
  151. */
  152. if *allow_upnp {
  153. var u *upnp.UPnPClient
  154. var err error = nil
  155. if *use_tls {
  156. u, err = upnp.NewUPNPClient(*tls_listen_port, *host_name+"-https")
  157. } else {
  158. u, err = upnp.NewUPNPClient(*listen_port, *host_name+"-http")
  159. }
  160. if err != nil {
  161. systemWideLogger.PrintAndLog("Network", "UPnP Startup Failed: "+err.Error(), err)
  162. } else {
  163. //Bind the http port if running in https and http server is not disabled
  164. if *use_tls && !*disable_http {
  165. u.ForwardPort(*listen_port, *host_name+"-http")
  166. }
  167. UPNP = u
  168. //Register nightly listener for upnp renew
  169. nightlyManager.RegisterNightlyTask(func() {
  170. UPNP.RenewForwardRules()
  171. })
  172. //Show a tip for success port forward
  173. connectionEndpoint := UPNP.ExternalIP + ":" + strconv.Itoa(*listen_port)
  174. obip, err := network.GetOutboundIP()
  175. obipstring := "[Outbound IP]"
  176. if err != nil {
  177. } else {
  178. obipstring = obip.String()
  179. }
  180. localEndpoint := obipstring + ":" + strconv.Itoa(*listen_port)
  181. systemWideLogger.PrintAndLog("Network", "Automatic Port Forwarding Completed. Forwarding all request from "+connectionEndpoint+" to "+localEndpoint, nil)
  182. }
  183. }
  184. }
  185. func StopNetworkServices() {
  186. //systemWideLogger.PrintAndLog("Shutting Down Network Services...",nil)
  187. //Shutdown uPNP service if enabled
  188. if *allow_upnp {
  189. systemWideLogger.PrintAndLog("System", "<!> Shutting down uPNP service", nil)
  190. UPNP.Close()
  191. }
  192. //Shutdown SSDP service if enabled
  193. if *allow_ssdp {
  194. systemWideLogger.PrintAndLog("System", "<!> Shutting down SSDP service", nil)
  195. SSDP.Close()
  196. }
  197. //Shutdown MDNS if enabled
  198. if *allow_mdns {
  199. systemWideLogger.PrintAndLog("System", "<!> Shutting down MDNS service", nil)
  200. MDNS.Close()
  201. }
  202. }
  203. /*
  204. File Server Services
  205. */
  206. var networkFileServerDaemon []*fileservers.Server = []*fileservers.Server{}
  207. // Initiate all File Server services
  208. func FileServerInit() {
  209. //Register System Setting
  210. registerSetting(settingModule{
  211. Name: "File Servers",
  212. Desc: "Network File Transfer Servers",
  213. IconPath: "SystemAO/disk/smart/img/small_icon.png",
  214. Group: "Network",
  215. StartDir: "SystemAO/disk/services.html",
  216. RequireAdmin: false,
  217. })
  218. //Create request routers
  219. adminRouter := prout.NewModuleRouter(prout.RouterOption{
  220. ModuleName: "System Setting",
  221. AdminOnly: true,
  222. UserHandler: userHandler,
  223. DeniedHandler: func(w http.ResponseWriter, r *http.Request) {
  224. errorHandlePermissionDenied(w, r)
  225. },
  226. })
  227. router := prout.NewModuleRouter(prout.RouterOption{
  228. ModuleName: "System Setting",
  229. AdminOnly: false,
  230. UserHandler: userHandler,
  231. DeniedHandler: func(w http.ResponseWriter, r *http.Request) {
  232. utils.SendErrorResponse(w, "Permission Denied")
  233. },
  234. })
  235. /* Create File Server Managers */
  236. //WebDAV
  237. webdavPort := *listen_port
  238. if *use_tls {
  239. webdavPort = *tls_listen_port
  240. }
  241. WebDAVManager = webdavserv.NewWebDAVManager(&webdavserv.ManagerOption{
  242. Sysdb: sysdb,
  243. Hostname: *host_name,
  244. TmpDir: *tmp_directory,
  245. Port: webdavPort,
  246. UseTls: *use_tls,
  247. UserHandler: userHandler,
  248. })
  249. //FTP
  250. FTPManager = ftpserv.NewFTPManager(&ftpserv.ManagerOption{
  251. Hostname: *host_name,
  252. TmpFolder: *tmp_directory,
  253. Logger: systemWideLogger,
  254. UserManager: userHandler,
  255. FtpServer: nil,
  256. Sysdb: sysdb,
  257. Upnp: UPNP,
  258. AllowUpnp: *allow_upnp,
  259. })
  260. //TFTP
  261. TFTPManager = tftpserv.NewTFTPManager(&tftpserv.ManagerOption{
  262. Hostname: *host_name,
  263. TmpFolder: *tmp_directory,
  264. Logger: systemWideLogger,
  265. UserManager: userHandler,
  266. TftpServer: nil,
  267. Sysdb: sysdb,
  268. })
  269. //SFTP
  270. SFTPManager = sftpserv.NewSFTPServer(&sftpserv.ManagerOption{
  271. Hostname: *host_name,
  272. Upnp: UPNP,
  273. UserManager: userHandler,
  274. KeyFile: "system/auth/id_rsa.key",
  275. Logger: systemWideLogger,
  276. Sysdb: sysdb,
  277. })
  278. listeningPort := *listen_port
  279. if *use_tls {
  280. listeningPort = *tls_listen_port
  281. }
  282. DirListManager = dirserv.NewDirectoryServer(&dirserv.Option{
  283. Sysdb: sysdb,
  284. ServerPort: listeningPort,
  285. UserManager: userHandler,
  286. ServerUUID: deviceUUID,
  287. })
  288. //Samba
  289. var err error
  290. SambaShareManager, err = samba.NewSambaShareManager(userHandler)
  291. if err != nil {
  292. //Disable samba if not installed or platform not supported
  293. systemWideLogger.PrintAndLog("System", "[INFO] Samba Share Manager Disabled: "+err.Error(), nil)
  294. }
  295. //Register Endpoints
  296. //WebDAV
  297. http.HandleFunc("/system/network/webdav/list", WebDAVManager.HandleConnectionList)
  298. router.HandleFunc("/system/network/webdav/edit", WebDAVManager.HandlePermissionEdit)
  299. router.HandleFunc("/system/network/webdav/clear", WebDAVManager.HandleClearAllPending)
  300. router.HandleFunc("/system/network/webdav/status", WebDAVManager.HandleStatusChange)
  301. //SFTP
  302. adminRouter.HandleFunc("/system/storage/sftp/port", SFTPManager.HandleListeningPort)
  303. adminRouter.HandleFunc("/system/storage/sftp/upnp", SFTPManager.HandleToogleUPnP)
  304. adminRouter.HandleFunc("/system/storage/sftp/users", SFTPManager.HandleGetConnectedClients)
  305. //FTP
  306. //adminRouter.HandleFunc("/system/storage/ftp/start", FTPManager.HandleFTPServerStart)
  307. //adminRouter.HandleFunc("/system/storage/ftp/stop", FTPManager.HandleFTPServerStop)
  308. adminRouter.HandleFunc("/system/storage/ftp/upnp", FTPManager.HandleFTPUPnP)
  309. adminRouter.HandleFunc("/system/storage/ftp/status", FTPManager.HandleFTPServerStatus)
  310. adminRouter.HandleFunc("/system/storage/ftp/updateGroups", FTPManager.HandleFTPAccessUpdate)
  311. adminRouter.HandleFunc("/system/storage/ftp/setPort", FTPManager.HandleFTPSetPort)
  312. adminRouter.HandleFunc("/system/storage/ftp/passivemode", FTPManager.HandleFTPPassiveModeSettings)
  313. //TFTP
  314. adminRouter.HandleFunc("/system/storage/tftp/status", TFTPManager.HandleTFTPServerStatus)
  315. adminRouter.HandleFunc("/system/storage/tftp/setPort", TFTPManager.HandleTFTPPort)
  316. adminRouter.HandleFunc("/system/storage/tftp/defaultUser", TFTPManager.HandleTFTPDefaultUser)
  317. //Samba Shares (Optional)
  318. if SambaShareManager != nil {
  319. //Activate and Deactivate are functions all users can use if admin enabled smbd service
  320. router.HandleFunc("/system/storage/samba/activate", func(w http.ResponseWriter, r *http.Request) {
  321. if !AuthValidateSecureRequest(w, r, false) {
  322. return
  323. }
  324. if !SambaShareManager.IsEnabled() {
  325. utils.SendErrorResponse(w, "smbd is not enabled on this server")
  326. return
  327. }
  328. password, _ := utils.PostPara(r, "password")
  329. SambaShareManager.ActivateUserAccount(w, r, password)
  330. })
  331. adminRouter.HandleFunc("/system/storage/samba/deactivate", SambaShareManager.DeactiveUserAccount)
  332. adminRouter.HandleFunc("/system/storage/samba/myshare", SambaShareManager.HandleUserSmbStatusList)
  333. //adminRouter.HandleFunc("/system/storage/samba/myshare/delete", SambaShareManager.DelUserSambaShare)
  334. adminRouter.HandleFunc("/system/storage/samba/status", SambaShareManager.SmbdStates)
  335. adminRouter.HandleFunc("/system/storage/samba/list", SambaShareManager.ListSambaShares)
  336. adminRouter.HandleFunc("/system/storage/samba/add", SambaShareManager.AddSambaShare)
  337. adminRouter.HandleFunc("/system/storage/samba/editPath", SambaShareManager.HandleSharePathChange)
  338. adminRouter.HandleFunc("/system/storage/samba/remove", SambaShareManager.DelSambaShare)
  339. adminRouter.HandleFunc("/system/storage/samba/addUser", SambaShareManager.NewSambaUser)
  340. adminRouter.HandleFunc("/system/storage/samba/delUser", SambaShareManager.DelSambaUser)
  341. adminRouter.HandleFunc("/system/storage/samba/listUsers", SambaShareManager.ListSambaUsers)
  342. adminRouter.HandleFunc("/system/storage/samba/updateShareUsers", SambaShareManager.HandleAccessUserUpdate)
  343. }
  344. networkFileServerDaemon = append(networkFileServerDaemon, &fileservers.Server{
  345. ID: "webdav",
  346. Name: "WebDAV",
  347. Desc: "WebDAV Server",
  348. IconPath: "img/system/network-folder-blue.svg",
  349. DefaultPorts: []int{},
  350. Ports: []int{},
  351. ForwardPortIfUpnp: false,
  352. ConnInstrPage: "SystemAO/disk/instr/webdav.html",
  353. ConfigPage: "SystemAO/disk/webdav.html",
  354. EnableCheck: WebDAVManager.GetWebDavEnabled,
  355. ToggleFunc: WebDAVManager.WebDavToogle,
  356. GetEndpoints: WebDAVManager.WebDavGetEndpoints,
  357. })
  358. networkFileServerDaemon = append(networkFileServerDaemon, &fileservers.Server{
  359. ID: "sftp",
  360. Name: "SFTP",
  361. Desc: "SSH File Transfer Protocol Server",
  362. IconPath: "img/system/network-folder-sftp.svg",
  363. DefaultPorts: []int{2022},
  364. Ports: []int{},
  365. ForwardPortIfUpnp: true,
  366. ConnInstrPage: "SystemAO/disk/instr/sftp.html",
  367. ConfigPage: "SystemAO/disk/sftp.html",
  368. EnableCheck: SFTPManager.IsEnabled,
  369. ToggleFunc: SFTPManager.ServerToggle,
  370. GetEndpoints: SFTPManager.GetEndpoints,
  371. })
  372. networkFileServerDaemon = append(networkFileServerDaemon, &fileservers.Server{
  373. ID: "ftp",
  374. Name: "FTP",
  375. Desc: "File Transfer Protocol Server",
  376. IconPath: "img/system/network-folder.svg",
  377. DefaultPorts: []int{21, 22, 23},
  378. Ports: []int{},
  379. ForwardPortIfUpnp: true,
  380. ConnInstrPage: "SystemAO/disk/instr/ftp.html",
  381. ConfigPage: "SystemAO/disk/ftp.html",
  382. EnableCheck: FTPManager.IsFtpServerEnabled,
  383. ToggleFunc: FTPManager.FTPServerToggle,
  384. GetEndpoints: FTPManager.FTPGetEndpoints,
  385. })
  386. networkFileServerDaemon = append(networkFileServerDaemon, &fileservers.Server{
  387. ID: "tftp",
  388. Name: "TFTP",
  389. Desc: "Trivial File Transfer Protocol Server",
  390. IconPath: "img/system/network-folder-black.svg",
  391. DefaultPorts: []int{69},
  392. Ports: []int{},
  393. ForwardPortIfUpnp: false,
  394. ConnInstrPage: "SystemAO/disk/instr/tftp.html",
  395. ConfigPage: "SystemAO/disk/tftp.html",
  396. EnableCheck: TFTPManager.IsTftpServerEnabled,
  397. ToggleFunc: TFTPManager.TFTPServerToggle,
  398. GetEndpoints: TFTPManager.TFTPGetEndpoints,
  399. })
  400. networkFileServerDaemon = append(networkFileServerDaemon, &fileservers.Server{
  401. ID: "dirserv",
  402. Name: "Directory Server",
  403. Desc: "Web file viewer for legacy devices",
  404. IconPath: "img/system/network-dirserv.svg",
  405. DefaultPorts: []int{},
  406. Ports: []int{},
  407. ForwardPortIfUpnp: false,
  408. ConnInstrPage: "SystemAO/disk/instr/dirserv.html",
  409. ConfigPage: "SystemAO/disk/dirserv.html",
  410. EnableCheck: DirListManager.DirServerEnabled,
  411. ToggleFunc: DirListManager.Toggle,
  412. GetEndpoints: DirListManager.ListEndpoints,
  413. })
  414. if SambaShareManager != nil {
  415. //Samba is external and might not exists on this host
  416. networkFileServerDaemon = append(networkFileServerDaemon, &fileservers.Server{
  417. ID: "smbd",
  418. Name: "Samba Shares",
  419. Desc: "Share local files via SMB using Samba",
  420. IconPath: "img/system/network-samba.svg",
  421. DefaultPorts: []int{},
  422. Ports: []int{},
  423. ForwardPortIfUpnp: false,
  424. ConnInstrPage: "SystemAO/disk/instr/samba.html",
  425. ConfigPage: "SystemAO/disk/samba.html",
  426. EnableCheck: SambaShareManager.IsEnabled,
  427. ToggleFunc: SambaShareManager.ServerToggle,
  428. GetEndpoints: SambaShareManager.GetEndpoints,
  429. })
  430. }
  431. router.HandleFunc("/system/network/server/list", NetworkHandleGetFileServerServiceList)
  432. router.HandleFunc("/system/network/server/endpoints", NetworkHandleGetFileServerEndpoints)
  433. router.HandleFunc("/system/network/server/status", NetworkHandleGetFileServerStatus)
  434. adminRouter.HandleFunc("/system/network/server/toggle", NetworkHandleFileServerToggle)
  435. }
  436. // Toggle the target File Server Services
  437. func NetworkHandleFileServerToggle(w http.ResponseWriter, r *http.Request) {
  438. servid, err := utils.PostPara(r, "id")
  439. if err != nil {
  440. utils.SendErrorResponse(w, "invalid service id given")
  441. return
  442. }
  443. newState, err := utils.PostPara(r, "enable")
  444. if err != nil {
  445. utils.SendErrorResponse(w, "undefined enable state")
  446. return
  447. }
  448. targetfserv := fileservers.GetFileServerById(networkFileServerDaemon, servid)
  449. if targetfserv == nil {
  450. utils.SendErrorResponse(w, "target service not exists")
  451. return
  452. }
  453. if newState == "true" {
  454. //Start up the target service
  455. err = targetfserv.ToggleFunc(true)
  456. if err != nil {
  457. utils.SendErrorResponse(w, "startup failed: "+err.Error())
  458. return
  459. }
  460. } else if newState == "false" {
  461. err = targetfserv.ToggleFunc(false)
  462. if err != nil {
  463. utils.SendErrorResponse(w, "shutdown failed: "+err.Error())
  464. return
  465. }
  466. } else {
  467. utils.SendErrorResponse(w, "unknown state keyword")
  468. return
  469. }
  470. }
  471. // Return a list of supported File Server Services
  472. func NetworkHandleGetFileServerServiceList(w http.ResponseWriter, r *http.Request) {
  473. js, _ := json.Marshal(networkFileServerDaemon)
  474. utils.SendJSONResponse(w, string(js))
  475. }
  476. // Get the status of a file server type.
  477. func NetworkHandleGetFileServerStatus(w http.ResponseWriter, r *http.Request) {
  478. servid, _ := utils.GetPara(r, "id")
  479. if servid == "" {
  480. //List all state in map
  481. result := map[string]bool{}
  482. for _, fserv := range networkFileServerDaemon {
  483. result[fserv.ID] = fserv.EnableCheck()
  484. }
  485. js, _ := json.Marshal(result)
  486. utils.SendJSONResponse(w, string(js))
  487. } else {
  488. //ID is defined. Get the target server and return its status
  489. targetfserv := fileservers.GetFileServerById(networkFileServerDaemon, servid)
  490. if targetfserv == nil {
  491. utils.SendErrorResponse(w, "target file server type not found")
  492. return
  493. }
  494. js, _ := json.Marshal(targetfserv.EnableCheck())
  495. utils.SendJSONResponse(w, string(js))
  496. }
  497. }
  498. // Get a list of endpoint usable by this service
  499. func NetworkHandleGetFileServerEndpoints(w http.ResponseWriter, r *http.Request) {
  500. userinfo, err := userHandler.GetUserInfoFromRequest(w, r)
  501. if err != nil {
  502. utils.SendErrorResponse(w, "user not logged in")
  503. return
  504. }
  505. targetServerTypeID, _ := utils.GetPara(r, "fserv")
  506. targetServerTypeID = strings.TrimSpace(targetServerTypeID)
  507. if targetServerTypeID == "" {
  508. //List all the endpoints
  509. results := map[string][]*fileservers.Endpoint{}
  510. for _, fser := range networkFileServerDaemon {
  511. if fser.GetEndpoints == nil {
  512. results[fser.ID] = []*fileservers.Endpoint{}
  513. continue
  514. }
  515. thisEndpoints := fser.GetEndpoints(userinfo)
  516. results[fser.ID] = thisEndpoints
  517. }
  518. js, _ := json.Marshal(results)
  519. utils.SendJSONResponse(w, string(js))
  520. } else {
  521. //List the target endpoint
  522. for _, fser := range networkFileServerDaemon {
  523. if targetServerTypeID == fser.ID {
  524. thisEndpoints := fser.GetEndpoints(userinfo)
  525. js, _ := json.Marshal(thisEndpoints)
  526. utils.SendJSONResponse(w, string(js))
  527. return
  528. }
  529. }
  530. utils.SendErrorResponse(w, "target service not found")
  531. }
  532. }