api.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. package main
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "net/http/pprof"
  6. "imuslab.com/zoraxy/mod/acme/acmedns"
  7. "imuslab.com/zoraxy/mod/acme/acmewizard"
  8. "imuslab.com/zoraxy/mod/auth"
  9. "imuslab.com/zoraxy/mod/ipscan"
  10. "imuslab.com/zoraxy/mod/netstat"
  11. "imuslab.com/zoraxy/mod/netutils"
  12. "imuslab.com/zoraxy/mod/utils"
  13. )
  14. /*
  15. API.go
  16. This file contains all the API called by the web management interface
  17. */
  18. var requireAuth = true
  19. func initAPIs(targetMux *http.ServeMux) {
  20. authRouter := auth.NewManagedHTTPRouter(auth.RouterOption{
  21. AuthAgent: authAgent,
  22. RequireAuth: requireAuth,
  23. TargetMux: targetMux,
  24. DeniedHandler: func(w http.ResponseWriter, r *http.Request) {
  25. http.Error(w, "401 - Unauthorized", http.StatusUnauthorized)
  26. },
  27. })
  28. //Register the standard web services urls
  29. fs := http.FileServer(http.FS(webres))
  30. if development {
  31. fs = http.FileServer(http.Dir("web/"))
  32. }
  33. //Add a layer of middleware for advance control
  34. advHandler := FSHandler(fs)
  35. targetMux.Handle("/", advHandler)
  36. //Authentication APIs
  37. registerAuthAPIs(requireAuth, targetMux)
  38. //Reverse proxy
  39. authRouter.HandleFunc("/api/proxy/enable", ReverseProxyHandleOnOff)
  40. authRouter.HandleFunc("/api/proxy/add", ReverseProxyHandleAddEndpoint)
  41. authRouter.HandleFunc("/api/proxy/status", ReverseProxyStatus)
  42. authRouter.HandleFunc("/api/proxy/toggle", ReverseProxyToggleRuleSet)
  43. authRouter.HandleFunc("/api/proxy/list", ReverseProxyList)
  44. authRouter.HandleFunc("/api/proxy/detail", ReverseProxyListDetail)
  45. authRouter.HandleFunc("/api/proxy/edit", ReverseProxyHandleEditEndpoint)
  46. authRouter.HandleFunc("/api/proxy/setAlias", ReverseProxyHandleAlias)
  47. authRouter.HandleFunc("/api/proxy/del", DeleteProxyEndpoint)
  48. authRouter.HandleFunc("/api/proxy/updateCredentials", UpdateProxyBasicAuthCredentials)
  49. authRouter.HandleFunc("/api/proxy/tlscheck", HandleCheckSiteSupportTLS)
  50. authRouter.HandleFunc("/api/proxy/setIncoming", HandleIncomingPortSet)
  51. authRouter.HandleFunc("/api/proxy/useHttpsRedirect", HandleUpdateHttpsRedirect)
  52. authRouter.HandleFunc("/api/proxy/listenPort80", HandleUpdatePort80Listener)
  53. authRouter.HandleFunc("/api/proxy/requestIsProxied", HandleManagementProxyCheck)
  54. authRouter.HandleFunc("/api/proxy/developmentMode", HandleDevelopmentModeChange)
  55. //Reverse proxy upstream (load balance) APIs
  56. authRouter.HandleFunc("/api/proxy/upstream/list", ReverseProxyUpstreamList)
  57. authRouter.HandleFunc("/api/proxy/upstream/add", ReverseProxyUpstreamAdd)
  58. authRouter.HandleFunc("/api/proxy/upstream/setPriority", ReverseProxyUpstreamSetPriority)
  59. authRouter.HandleFunc("/api/proxy/upstream/update", ReverseProxyUpstreamUpdate)
  60. authRouter.HandleFunc("/api/proxy/upstream/remove", ReverseProxyUpstreamDelete)
  61. //Reverse proxy virtual directory APIs
  62. authRouter.HandleFunc("/api/proxy/vdir/list", ReverseProxyListVdir)
  63. authRouter.HandleFunc("/api/proxy/vdir/add", ReverseProxyAddVdir)
  64. authRouter.HandleFunc("/api/proxy/vdir/del", ReverseProxyDeleteVdir)
  65. authRouter.HandleFunc("/api/proxy/vdir/edit", ReverseProxyEditVdir)
  66. //Reverse proxy user define header apis
  67. authRouter.HandleFunc("/api/proxy/header/list", HandleCustomHeaderList)
  68. authRouter.HandleFunc("/api/proxy/header/add", HandleCustomHeaderAdd)
  69. authRouter.HandleFunc("/api/proxy/header/remove", HandleCustomHeaderRemove)
  70. authRouter.HandleFunc("/api/proxy/header/handleHSTS", HandleHSTSState)
  71. authRouter.HandleFunc("/api/proxy/header/handleHopByHop", HandleHopByHop)
  72. authRouter.HandleFunc("/api/proxy/header/handleHostOverwrite", HandleHostOverwrite)
  73. authRouter.HandleFunc("/api/proxy/header/handlePermissionPolicy", HandlePermissionPolicy)
  74. //Reverse proxy auth related APIs
  75. authRouter.HandleFunc("/api/proxy/auth/exceptions/list", ListProxyBasicAuthExceptionPaths)
  76. authRouter.HandleFunc("/api/proxy/auth/exceptions/add", AddProxyBasicAuthExceptionPaths)
  77. authRouter.HandleFunc("/api/proxy/auth/exceptions/delete", RemoveProxyBasicAuthExceptionPaths)
  78. //TLS / SSL config
  79. authRouter.HandleFunc("/api/cert/tls", handleToggleTLSProxy)
  80. authRouter.HandleFunc("/api/cert/tlsRequireLatest", handleSetTlsRequireLatest)
  81. authRouter.HandleFunc("/api/cert/upload", handleCertUpload)
  82. authRouter.HandleFunc("/api/cert/download", handleCertDownload)
  83. authRouter.HandleFunc("/api/cert/list", handleListCertificate)
  84. authRouter.HandleFunc("/api/cert/listdomains", handleListDomains)
  85. authRouter.HandleFunc("/api/cert/checkDefault", handleDefaultCertCheck)
  86. authRouter.HandleFunc("/api/cert/delete", handleCertRemove)
  87. //SSO and Oauth
  88. authRouter.HandleFunc("/api/sso/status", ssoHandler.HandleSSOStatus)
  89. authRouter.HandleFunc("/api/sso/enable", ssoHandler.HandleSSOEnable)
  90. authRouter.HandleFunc("/api/sso/setPort", ssoHandler.HandlePortChange)
  91. authRouter.HandleFunc("/api/sso/setAuthURL", ssoHandler.HandleSetAuthURL)
  92. authRouter.HandleFunc("/api/sso/app/register", ssoHandler.HandleRegisterApp)
  93. //authRouter.HandleFunc("/api/sso/app/list", ssoHandler.HandleListApp)
  94. //authRouter.HandleFunc("/api/sso/app/remove", ssoHandler.HandleRemoveApp)
  95. authRouter.HandleFunc("/api/sso/user/list", ssoHandler.HandleListUser)
  96. authRouter.HandleFunc("/api/sso/user/add", ssoHandler.HandleAddUser)
  97. authRouter.HandleFunc("/api/sso/user/edit", ssoHandler.HandleEditUser)
  98. authRouter.HandleFunc("/api/sso/user/remove", ssoHandler.HandleRemoveUser)
  99. //Redirection config
  100. authRouter.HandleFunc("/api/redirect/list", handleListRedirectionRules)
  101. authRouter.HandleFunc("/api/redirect/add", handleAddRedirectionRule)
  102. authRouter.HandleFunc("/api/redirect/delete", handleDeleteRedirectionRule)
  103. authRouter.HandleFunc("/api/redirect/regex", handleToggleRedirectRegexpSupport)
  104. //Access Rules API
  105. authRouter.HandleFunc("/api/access/list", handleListAccessRules)
  106. authRouter.HandleFunc("/api/access/attach", handleAttachRuleToHost)
  107. authRouter.HandleFunc("/api/access/create", handleCreateAccessRule)
  108. authRouter.HandleFunc("/api/access/remove", handleRemoveAccessRule)
  109. authRouter.HandleFunc("/api/access/update", handleUpadateAccessRule)
  110. //Blacklist APIs
  111. authRouter.HandleFunc("/api/blacklist/list", handleListBlacklisted)
  112. authRouter.HandleFunc("/api/blacklist/country/add", handleCountryBlacklistAdd)
  113. authRouter.HandleFunc("/api/blacklist/country/remove", handleCountryBlacklistRemove)
  114. authRouter.HandleFunc("/api/blacklist/ip/add", handleIpBlacklistAdd)
  115. authRouter.HandleFunc("/api/blacklist/ip/remove", handleIpBlacklistRemove)
  116. authRouter.HandleFunc("/api/blacklist/enable", handleBlacklistEnable)
  117. //Whitelist APIs
  118. authRouter.HandleFunc("/api/whitelist/list", handleListWhitelisted)
  119. authRouter.HandleFunc("/api/whitelist/country/add", handleCountryWhitelistAdd)
  120. authRouter.HandleFunc("/api/whitelist/country/remove", handleCountryWhitelistRemove)
  121. authRouter.HandleFunc("/api/whitelist/ip/add", handleIpWhitelistAdd)
  122. authRouter.HandleFunc("/api/whitelist/ip/remove", handleIpWhitelistRemove)
  123. authRouter.HandleFunc("/api/whitelist/enable", handleWhitelistEnable)
  124. //Path Blocker APIs
  125. authRouter.HandleFunc("/api/pathrule/add", pathRuleHandler.HandleAddBlockingPath)
  126. authRouter.HandleFunc("/api/pathrule/list", pathRuleHandler.HandleListBlockingPath)
  127. authRouter.HandleFunc("/api/pathrule/remove", pathRuleHandler.HandleRemoveBlockingPath)
  128. //Statistic & uptime monitoring API
  129. authRouter.HandleFunc("/api/stats/summary", statisticCollector.HandleTodayStatLoad)
  130. authRouter.HandleFunc("/api/stats/countries", HandleCountryDistrSummary)
  131. authRouter.HandleFunc("/api/stats/netstat", netstatBuffers.HandleGetNetworkInterfaceStats)
  132. authRouter.HandleFunc("/api/stats/netstatgraph", netstatBuffers.HandleGetBufferedNetworkInterfaceStats)
  133. authRouter.HandleFunc("/api/stats/listnic", netstat.HandleListNetworkInterfaces)
  134. authRouter.HandleFunc("/api/utm/list", HandleUptimeMonitorListing)
  135. //Global Area Network APIs
  136. authRouter.HandleFunc("/api/gan/network/info", ganManager.HandleGetNodeID)
  137. authRouter.HandleFunc("/api/gan/network/add", ganManager.HandleAddNetwork)
  138. authRouter.HandleFunc("/api/gan/network/remove", ganManager.HandleRemoveNetwork)
  139. authRouter.HandleFunc("/api/gan/network/list", ganManager.HandleListNetwork)
  140. authRouter.HandleFunc("/api/gan/network/name", ganManager.HandleNetworkNaming)
  141. //authRouter.HandleFunc("/api/gan/network/detail", ganManager.HandleNetworkDetails)
  142. authRouter.HandleFunc("/api/gan/network/setRange", ganManager.HandleSetRanges)
  143. authRouter.HandleFunc("/api/gan/network/join", ganManager.HandleServerJoinNetwork)
  144. authRouter.HandleFunc("/api/gan/network/leave", ganManager.HandleServerLeaveNetwork)
  145. authRouter.HandleFunc("/api/gan/members/list", ganManager.HandleMemberList)
  146. authRouter.HandleFunc("/api/gan/members/ip", ganManager.HandleMemberIP)
  147. authRouter.HandleFunc("/api/gan/members/name", ganManager.HandleMemberNaming)
  148. authRouter.HandleFunc("/api/gan/members/authorize", ganManager.HandleMemberAuthorization)
  149. authRouter.HandleFunc("/api/gan/members/delete", ganManager.HandleMemberDelete)
  150. //Stream (TCP / UDP) Proxy
  151. authRouter.HandleFunc("/api/streamprox/config/add", streamProxyManager.HandleAddProxyConfig)
  152. authRouter.HandleFunc("/api/streamprox/config/edit", streamProxyManager.HandleEditProxyConfigs)
  153. authRouter.HandleFunc("/api/streamprox/config/list", streamProxyManager.HandleListConfigs)
  154. authRouter.HandleFunc("/api/streamprox/config/start", streamProxyManager.HandleStartProxy)
  155. authRouter.HandleFunc("/api/streamprox/config/stop", streamProxyManager.HandleStopProxy)
  156. authRouter.HandleFunc("/api/streamprox/config/delete", streamProxyManager.HandleRemoveProxy)
  157. authRouter.HandleFunc("/api/streamprox/config/status", streamProxyManager.HandleGetProxyStatus)
  158. //mDNS APIs
  159. authRouter.HandleFunc("/api/mdns/list", HandleMdnsListing)
  160. authRouter.HandleFunc("/api/mdns/discover", HandleMdnsScanning)
  161. //Zoraxy Analytic
  162. authRouter.HandleFunc("/api/analytic/list", AnalyticLoader.HandleSummaryList)
  163. authRouter.HandleFunc("/api/analytic/load", AnalyticLoader.HandleLoadTargetDaySummary)
  164. authRouter.HandleFunc("/api/analytic/loadRange", AnalyticLoader.HandleLoadTargetRangeSummary)
  165. authRouter.HandleFunc("/api/analytic/exportRange", AnalyticLoader.HandleRangeExport)
  166. authRouter.HandleFunc("/api/analytic/resetRange", AnalyticLoader.HandleRangeReset)
  167. //Network utilities
  168. authRouter.HandleFunc("/api/tools/ipscan", ipscan.HandleIpScan)
  169. authRouter.HandleFunc("/api/tools/portscan", ipscan.HandleScanPort)
  170. authRouter.HandleFunc("/api/tools/traceroute", netutils.HandleTraceRoute)
  171. authRouter.HandleFunc("/api/tools/ping", netutils.HandlePing)
  172. authRouter.HandleFunc("/api/tools/whois", netutils.HandleWhois)
  173. authRouter.HandleFunc("/api/tools/webssh", HandleCreateProxySession)
  174. authRouter.HandleFunc("/api/tools/websshSupported", HandleWebSshSupportCheck)
  175. authRouter.HandleFunc("/api/tools/wol", HandleWakeOnLan)
  176. authRouter.HandleFunc("/api/tools/smtp/get", HandleSMTPGet)
  177. authRouter.HandleFunc("/api/tools/smtp/set", HandleSMTPSet)
  178. authRouter.HandleFunc("/api/tools/smtp/admin", HandleAdminEmailGet)
  179. authRouter.HandleFunc("/api/tools/smtp/test", HandleTestEmailSend)
  180. authRouter.HandleFunc("/api/tools/fwdproxy/enable", forwardProxy.HandleToogle)
  181. authRouter.HandleFunc("/api/tools/fwdproxy/port", forwardProxy.HandlePort)
  182. //Account Reset
  183. targetMux.HandleFunc("/api/account/reset", HandleAdminAccountResetEmail)
  184. targetMux.HandleFunc("/api/account/new", HandleNewPasswordSetup)
  185. //ACME & Auto Renewer
  186. authRouter.HandleFunc("/api/acme/listExpiredDomains", acmeHandler.HandleGetExpiredDomains)
  187. authRouter.HandleFunc("/api/acme/obtainCert", AcmeCheckAndHandleRenewCertificate)
  188. authRouter.HandleFunc("/api/acme/autoRenew/enable", acmeAutoRenewer.HandleAutoRenewEnable)
  189. authRouter.HandleFunc("/api/acme/autoRenew/ca", HandleACMEPreferredCA)
  190. authRouter.HandleFunc("/api/acme/autoRenew/email", acmeAutoRenewer.HandleACMEEmail)
  191. authRouter.HandleFunc("/api/acme/autoRenew/setDomains", acmeAutoRenewer.HandleSetAutoRenewDomains)
  192. authRouter.HandleFunc("/api/acme/autoRenew/setEAB", acmeAutoRenewer.HanldeSetEAB)
  193. authRouter.HandleFunc("/api/acme/autoRenew/setDNS", acmeAutoRenewer.HanldeSetDNS)
  194. authRouter.HandleFunc("/api/acme/autoRenew/listDomains", acmeAutoRenewer.HandleLoadAutoRenewDomains)
  195. authRouter.HandleFunc("/api/acme/autoRenew/renewPolicy", acmeAutoRenewer.HandleRenewPolicy)
  196. authRouter.HandleFunc("/api/acme/autoRenew/renewNow", acmeAutoRenewer.HandleRenewNow)
  197. authRouter.HandleFunc("/api/acme/dns/providers", acmedns.HandleServeProvidersJson)
  198. authRouter.HandleFunc("/api/acme/wizard", acmewizard.HandleGuidedStepCheck) //ACME Wizard
  199. //Static Web Server
  200. authRouter.HandleFunc("/api/webserv/status", staticWebServer.HandleGetStatus)
  201. authRouter.HandleFunc("/api/webserv/start", staticWebServer.HandleStartServer)
  202. authRouter.HandleFunc("/api/webserv/stop", staticWebServer.HandleStopServer)
  203. authRouter.HandleFunc("/api/webserv/setPort", HandleStaticWebServerPortChange)
  204. authRouter.HandleFunc("/api/webserv/setDirList", staticWebServer.SetEnableDirectoryListing)
  205. if *allowWebFileManager {
  206. //Web Directory Manager file operation functions
  207. authRouter.HandleFunc("/api/fs/list", staticWebServer.FileManager.HandleList)
  208. authRouter.HandleFunc("/api/fs/upload", staticWebServer.FileManager.HandleUpload)
  209. authRouter.HandleFunc("/api/fs/download", staticWebServer.FileManager.HandleDownload)
  210. authRouter.HandleFunc("/api/fs/newFolder", staticWebServer.FileManager.HandleNewFolder)
  211. authRouter.HandleFunc("/api/fs/copy", staticWebServer.FileManager.HandleFileCopy)
  212. authRouter.HandleFunc("/api/fs/move", staticWebServer.FileManager.HandleFileMove)
  213. authRouter.HandleFunc("/api/fs/properties", staticWebServer.FileManager.HandleFileProperties)
  214. authRouter.HandleFunc("/api/fs/del", staticWebServer.FileManager.HandleFileDelete)
  215. }
  216. //Docker UX Optimizations
  217. authRouter.HandleFunc("/api/docker/available", DockerUXOptimizer.HandleDockerAvailable)
  218. authRouter.HandleFunc("/api/docker/containers", DockerUXOptimizer.HandleDockerContainersList)
  219. //Others
  220. targetMux.HandleFunc("/api/info/x", HandleZoraxyInfo)
  221. authRouter.HandleFunc("/api/info/geoip", HandleGeoIpLookup)
  222. authRouter.HandleFunc("/api/conf/export", ExportConfigAsZip)
  223. authRouter.HandleFunc("/api/conf/import", ImportConfigFromZip)
  224. authRouter.HandleFunc("/api/log/list", LogViewer.HandleListLog)
  225. authRouter.HandleFunc("/api/log/read", LogViewer.HandleReadLog)
  226. //Debug
  227. authRouter.HandleFunc("/api/info/pprof", pprof.Index)
  228. //If you got APIs to add, append them here
  229. }
  230. // Function to renders Auth related APIs
  231. func registerAuthAPIs(requireAuth bool, targetMux *http.ServeMux) {
  232. //Auth APIs
  233. targetMux.HandleFunc("/api/auth/login", authAgent.HandleLogin)
  234. targetMux.HandleFunc("/api/auth/logout", authAgent.HandleLogout)
  235. targetMux.HandleFunc("/api/auth/checkLogin", func(w http.ResponseWriter, r *http.Request) {
  236. if requireAuth {
  237. authAgent.CheckLogin(w, r)
  238. } else {
  239. utils.SendJSONResponse(w, "true")
  240. }
  241. })
  242. targetMux.HandleFunc("/api/auth/username", func(w http.ResponseWriter, r *http.Request) {
  243. username, err := authAgent.GetUserName(w, r)
  244. if err != nil {
  245. http.Error(w, http.StatusText(http.StatusUnauthorized), http.StatusUnauthorized)
  246. return
  247. }
  248. js, _ := json.Marshal(username)
  249. utils.SendJSONResponse(w, string(js))
  250. })
  251. targetMux.HandleFunc("/api/auth/userCount", func(w http.ResponseWriter, r *http.Request) {
  252. uc := authAgent.GetUserCounts()
  253. js, _ := json.Marshal(uc)
  254. utils.SendJSONResponse(w, string(js))
  255. })
  256. targetMux.HandleFunc("/api/auth/register", func(w http.ResponseWriter, r *http.Request) {
  257. if authAgent.GetUserCounts() == 0 {
  258. //Allow register root admin
  259. authAgent.HandleRegisterWithoutEmail(w, r, func(username, reserved string) {
  260. })
  261. } else {
  262. //This function is disabled
  263. utils.SendErrorResponse(w, "Root management account already exists")
  264. }
  265. })
  266. targetMux.HandleFunc("/api/auth/changePassword", func(w http.ResponseWriter, r *http.Request) {
  267. username, err := authAgent.GetUserName(w, r)
  268. if err != nil {
  269. http.Error(w, "401 - Unauthorized", http.StatusUnauthorized)
  270. return
  271. }
  272. oldPassword, err := utils.PostPara(r, "oldPassword")
  273. if err != nil {
  274. utils.SendErrorResponse(w, "empty current password")
  275. return
  276. }
  277. newPassword, err := utils.PostPara(r, "newPassword")
  278. if err != nil {
  279. utils.SendErrorResponse(w, "empty new password")
  280. return
  281. }
  282. confirmPassword, _ := utils.PostPara(r, "confirmPassword")
  283. if newPassword != confirmPassword {
  284. utils.SendErrorResponse(w, "confirm password not match")
  285. return
  286. }
  287. //Check if the old password correct
  288. oldPasswordCorrect, _ := authAgent.ValidateUsernameAndPasswordWithReason(username, oldPassword)
  289. if !oldPasswordCorrect {
  290. utils.SendErrorResponse(w, "Invalid current password given")
  291. return
  292. }
  293. //Change the password of the root user
  294. authAgent.UnregisterUser(username)
  295. authAgent.CreateUserAccount(username, newPassword, "")
  296. })
  297. }