api.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. package main
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "net/http/pprof"
  6. "imuslab.com/zoraxy/mod/acme/acmewizard"
  7. "imuslab.com/zoraxy/mod/auth"
  8. "imuslab.com/zoraxy/mod/netstat"
  9. "imuslab.com/zoraxy/mod/netutils"
  10. "imuslab.com/zoraxy/mod/utils"
  11. )
  12. /*
  13. API.go
  14. This file contains all the API called by the web management interface
  15. */
  16. var requireAuth = true
  17. func initAPIs() {
  18. authRouter := auth.NewManagedHTTPRouter(auth.RouterOption{
  19. AuthAgent: authAgent,
  20. RequireAuth: requireAuth,
  21. DeniedHandler: func(w http.ResponseWriter, r *http.Request) {
  22. http.Error(w, "401 - Unauthorized", http.StatusUnauthorized)
  23. },
  24. })
  25. //Register the standard web services urls
  26. fs := http.FileServer(http.FS(webres))
  27. if development {
  28. fs = http.FileServer(http.Dir("web/"))
  29. }
  30. //Add a layer of middleware for advance control
  31. advHandler := FSHandler(fs)
  32. http.Handle("/", advHandler)
  33. //Authentication APIs
  34. registerAuthAPIs(requireAuth)
  35. //Reverse proxy
  36. authRouter.HandleFunc("/api/proxy/enable", ReverseProxyHandleOnOff)
  37. authRouter.HandleFunc("/api/proxy/add", ReverseProxyHandleAddEndpoint)
  38. authRouter.HandleFunc("/api/proxy/status", ReverseProxyStatus)
  39. authRouter.HandleFunc("/api/proxy/list", ReverseProxyList)
  40. authRouter.HandleFunc("/api/proxy/edit", ReverseProxyHandleEditEndpoint)
  41. authRouter.HandleFunc("/api/proxy/del", DeleteProxyEndpoint)
  42. authRouter.HandleFunc("/api/proxy/updateCredentials", UpdateProxyBasicAuthCredentials)
  43. authRouter.HandleFunc("/api/proxy/tlscheck", HandleCheckSiteSupportTLS)
  44. authRouter.HandleFunc("/api/proxy/setIncoming", HandleIncomingPortSet)
  45. authRouter.HandleFunc("/api/proxy/useHttpsRedirect", HandleUpdateHttpsRedirect)
  46. authRouter.HandleFunc("/api/proxy/requestIsProxied", HandleManagementProxyCheck)
  47. //Reverse proxy auth related APIs
  48. authRouter.HandleFunc("/api/proxy/auth/exceptions/list", ListProxyBasicAuthExceptionPaths)
  49. authRouter.HandleFunc("/api/proxy/auth/exceptions/add", AddProxyBasicAuthExceptionPaths)
  50. authRouter.HandleFunc("/api/proxy/auth/exceptions/delete", RemoveProxyBasicAuthExceptionPaths)
  51. //TLS / SSL config
  52. authRouter.HandleFunc("/api/cert/tls", handleToggleTLSProxy)
  53. authRouter.HandleFunc("/api/cert/tlsRequireLatest", handleSetTlsRequireLatest)
  54. authRouter.HandleFunc("/api/cert/upload", handleCertUpload)
  55. authRouter.HandleFunc("/api/cert/list", handleListCertificate)
  56. authRouter.HandleFunc("/api/cert/listdomains", handleListDomains)
  57. authRouter.HandleFunc("/api/cert/checkDefault", handleDefaultCertCheck)
  58. authRouter.HandleFunc("/api/cert/delete", handleCertRemove)
  59. //Redirection config
  60. authRouter.HandleFunc("/api/redirect/list", handleListRedirectionRules)
  61. authRouter.HandleFunc("/api/redirect/add", handleAddRedirectionRule)
  62. authRouter.HandleFunc("/api/redirect/delete", handleDeleteRedirectionRule)
  63. //Blacklist APIs
  64. authRouter.HandleFunc("/api/blacklist/list", handleListBlacklisted)
  65. authRouter.HandleFunc("/api/blacklist/country/add", handleCountryBlacklistAdd)
  66. authRouter.HandleFunc("/api/blacklist/country/remove", handleCountryBlacklistRemove)
  67. authRouter.HandleFunc("/api/blacklist/ip/add", handleIpBlacklistAdd)
  68. authRouter.HandleFunc("/api/blacklist/ip/remove", handleIpBlacklistRemove)
  69. authRouter.HandleFunc("/api/blacklist/enable", handleBlacklistEnable)
  70. //Whitelist APIs
  71. authRouter.HandleFunc("/api/whitelist/list", handleListWhitelisted)
  72. authRouter.HandleFunc("/api/whitelist/country/add", handleCountryWhitelistAdd)
  73. authRouter.HandleFunc("/api/whitelist/country/remove", handleCountryWhitelistRemove)
  74. authRouter.HandleFunc("/api/whitelist/ip/add", handleIpWhitelistAdd)
  75. authRouter.HandleFunc("/api/whitelist/ip/remove", handleIpWhitelistRemove)
  76. authRouter.HandleFunc("/api/whitelist/enable", handleWhitelistEnable)
  77. //Path Blocker APIs
  78. authRouter.HandleFunc("/api/pathrule/add", pathRuleHandler.HandleAddBlockingPath)
  79. authRouter.HandleFunc("/api/pathrule/list", pathRuleHandler.HandleListBlockingPath)
  80. authRouter.HandleFunc("/api/pathrule/remove", pathRuleHandler.HandleRemoveBlockingPath)
  81. //Statistic & uptime monitoring API
  82. authRouter.HandleFunc("/api/stats/summary", statisticCollector.HandleTodayStatLoad)
  83. authRouter.HandleFunc("/api/stats/countries", HandleCountryDistrSummary)
  84. authRouter.HandleFunc("/api/stats/netstat", netstat.HandleGetNetworkInterfaceStats)
  85. authRouter.HandleFunc("/api/stats/netstatgraph", netstatBuffers.HandleGetBufferedNetworkInterfaceStats)
  86. authRouter.HandleFunc("/api/stats/listnic", netstat.HandleListNetworkInterfaces)
  87. authRouter.HandleFunc("/api/utm/list", HandleUptimeMonitorListing)
  88. //Global Area Network APIs
  89. authRouter.HandleFunc("/api/gan/network/info", ganManager.HandleGetNodeID)
  90. authRouter.HandleFunc("/api/gan/network/add", ganManager.HandleAddNetwork)
  91. authRouter.HandleFunc("/api/gan/network/remove", ganManager.HandleRemoveNetwork)
  92. authRouter.HandleFunc("/api/gan/network/list", ganManager.HandleListNetwork)
  93. authRouter.HandleFunc("/api/gan/network/name", ganManager.HandleNetworkNaming)
  94. //authRouter.HandleFunc("/api/gan/network/detail", ganManager.HandleNetworkDetails)
  95. authRouter.HandleFunc("/api/gan/network/setRange", ganManager.HandleSetRanges)
  96. authRouter.HandleFunc("/api/gan/members/list", ganManager.HandleMemberList)
  97. authRouter.HandleFunc("/api/gan/members/ip", ganManager.HandleMemberIP)
  98. authRouter.HandleFunc("/api/gan/members/name", ganManager.HandleMemberNaming)
  99. authRouter.HandleFunc("/api/gan/members/authorize", ganManager.HandleMemberAuthorization)
  100. authRouter.HandleFunc("/api/gan/members/delete", ganManager.HandleMemberDelete)
  101. //TCP Proxy
  102. authRouter.HandleFunc("/api/tcpprox/config/add", tcpProxyManager.HandleAddProxyConfig)
  103. authRouter.HandleFunc("/api/tcpprox/config/edit", tcpProxyManager.HandleEditProxyConfigs)
  104. authRouter.HandleFunc("/api/tcpprox/config/list", tcpProxyManager.HandleListConfigs)
  105. authRouter.HandleFunc("/api/tcpprox/config/start", tcpProxyManager.HandleStartProxy)
  106. authRouter.HandleFunc("/api/tcpprox/config/stop", tcpProxyManager.HandleStopProxy)
  107. authRouter.HandleFunc("/api/tcpprox/config/delete", tcpProxyManager.HandleRemoveProxy)
  108. authRouter.HandleFunc("/api/tcpprox/config/status", tcpProxyManager.HandleGetProxyStatus)
  109. authRouter.HandleFunc("/api/tcpprox/config/validate", tcpProxyManager.HandleConfigValidate)
  110. //mDNS APIs
  111. authRouter.HandleFunc("/api/mdns/list", HandleMdnsListing)
  112. authRouter.HandleFunc("/api/mdns/discover", HandleMdnsScanning)
  113. //Zoraxy Analytic
  114. authRouter.HandleFunc("/api/analytic/list", AnalyticLoader.HandleSummaryList)
  115. authRouter.HandleFunc("/api/analytic/load", AnalyticLoader.HandleLoadTargetDaySummary)
  116. authRouter.HandleFunc("/api/analytic/loadRange", AnalyticLoader.HandleLoadTargetRangeSummary)
  117. authRouter.HandleFunc("/api/analytic/exportRange", AnalyticLoader.HandleRangeExport)
  118. authRouter.HandleFunc("/api/analytic/resetRange", AnalyticLoader.HandleRangeReset)
  119. //Network utilities
  120. authRouter.HandleFunc("/api/tools/ipscan", HandleIpScan)
  121. authRouter.HandleFunc("/api/tools/traceroute", netutils.HandleTraceRoute)
  122. authRouter.HandleFunc("/api/tools/ping", netutils.HandlePing)
  123. authRouter.HandleFunc("/api/tools/whois", netutils.HandleWhois)
  124. authRouter.HandleFunc("/api/tools/webssh", HandleCreateProxySession)
  125. authRouter.HandleFunc("/api/tools/websshSupported", HandleWebSshSupportCheck)
  126. authRouter.HandleFunc("/api/tools/wol", HandleWakeOnLan)
  127. authRouter.HandleFunc("/api/tools/smtp/get", HandleSMTPGet)
  128. authRouter.HandleFunc("/api/tools/smtp/set", HandleSMTPSet)
  129. authRouter.HandleFunc("/api/tools/smtp/admin", HandleAdminEmailGet)
  130. authRouter.HandleFunc("/api/tools/smtp/test", HandleTestEmailSend)
  131. //Account Reset
  132. http.HandleFunc("/api/account/reset", HandleAdminAccountResetEmail)
  133. http.HandleFunc("/api/account/new", HandleNewPasswordSetup)
  134. //ACME & Auto Renewer
  135. authRouter.HandleFunc("/api/acme/listExpiredDomains", acmeHandler.HandleGetExpiredDomains)
  136. authRouter.HandleFunc("/api/acme/obtainCert", AcmeCheckAndHandleRenewCertificate)
  137. authRouter.HandleFunc("/api/acme/autoRenew/enable", acmeAutoRenewer.HandleAutoRenewEnable)
  138. authRouter.HandleFunc("/api/acme/autoRenew/email", acmeAutoRenewer.HandleACMEEmail)
  139. authRouter.HandleFunc("/api/acme/autoRenew/setDomains", acmeAutoRenewer.HandleSetAutoRenewDomains)
  140. authRouter.HandleFunc("/api/acme/autoRenew/listDomains", acmeAutoRenewer.HandleLoadAutoRenewDomains)
  141. authRouter.HandleFunc("/api/acme/autoRenew/renewPolicy", acmeAutoRenewer.HandleRenewPolicy)
  142. authRouter.HandleFunc("/api/acme/autoRenew/renewNow", acmeAutoRenewer.HandleRenewNow)
  143. authRouter.HandleFunc("/api/acme/wizard", acmewizard.HandleGuidedStepCheck) //ACME Wizard
  144. //Others
  145. http.HandleFunc("/api/info/x", HandleZoraxyInfo)
  146. http.HandleFunc("/api/conf/export", ExportConfigAsZip)
  147. http.HandleFunc("/api/conf/import", ImportConfigFromZip)
  148. //Debug
  149. authRouter.HandleFunc("/api/info/pprof", pprof.Index)
  150. //If you got APIs to add, append them here
  151. }
  152. // Function to renders Auth related APIs
  153. func registerAuthAPIs(requireAuth bool) {
  154. //Auth APIs
  155. http.HandleFunc("/api/auth/login", authAgent.HandleLogin)
  156. http.HandleFunc("/api/auth/logout", authAgent.HandleLogout)
  157. http.HandleFunc("/api/auth/checkLogin", func(w http.ResponseWriter, r *http.Request) {
  158. if requireAuth {
  159. authAgent.CheckLogin(w, r)
  160. } else {
  161. utils.SendJSONResponse(w, "true")
  162. }
  163. })
  164. http.HandleFunc("/api/auth/username", func(w http.ResponseWriter, r *http.Request) {
  165. username, err := authAgent.GetUserName(w, r)
  166. if err != nil {
  167. http.Error(w, http.StatusText(http.StatusUnauthorized), http.StatusUnauthorized)
  168. return
  169. }
  170. js, _ := json.Marshal(username)
  171. utils.SendJSONResponse(w, string(js))
  172. })
  173. http.HandleFunc("/api/auth/userCount", func(w http.ResponseWriter, r *http.Request) {
  174. uc := authAgent.GetUserCounts()
  175. js, _ := json.Marshal(uc)
  176. utils.SendJSONResponse(w, string(js))
  177. })
  178. http.HandleFunc("/api/auth/register", func(w http.ResponseWriter, r *http.Request) {
  179. if authAgent.GetUserCounts() == 0 {
  180. //Allow register root admin
  181. authAgent.HandleRegisterWithoutEmail(w, r, func(username, reserved string) {
  182. })
  183. } else {
  184. //This function is disabled
  185. utils.SendErrorResponse(w, "Root management account already exists")
  186. }
  187. })
  188. http.HandleFunc("/api/auth/changePassword", func(w http.ResponseWriter, r *http.Request) {
  189. username, err := authAgent.GetUserName(w, r)
  190. if err != nil {
  191. http.Error(w, "401 - Unauthorized", http.StatusUnauthorized)
  192. return
  193. }
  194. oldPassword, err := utils.PostPara(r, "oldPassword")
  195. if err != nil {
  196. utils.SendErrorResponse(w, "empty current password")
  197. return
  198. }
  199. newPassword, err := utils.PostPara(r, "newPassword")
  200. if err != nil {
  201. utils.SendErrorResponse(w, "empty new password")
  202. return
  203. }
  204. confirmPassword, _ := utils.PostPara(r, "confirmPassword")
  205. if newPassword != confirmPassword {
  206. utils.SendErrorResponse(w, "confirm password not match")
  207. return
  208. }
  209. //Check if the old password correct
  210. oldPasswordCorrect, _ := authAgent.ValidateUsernameAndPasswordWithReason(username, oldPassword)
  211. if !oldPasswordCorrect {
  212. utils.SendErrorResponse(w, "Invalid current password given")
  213. return
  214. }
  215. //Change the password of the root user
  216. authAgent.UnregisterUser(username)
  217. authAgent.CreateUserAccount(username, newPassword, "")
  218. })
  219. }