mirror of
https://github.com/donl/gPanel.git
synced 2026-05-26 22:06:36 -06:00
fixed bottleneck in web servers, tidy'ed code up in web servers by quite a bit
This commit is contained in:
parent
1e4c3849dd
commit
73fa8a9ea9
3 changed files with 93 additions and 65 deletions
|
|
@ -2,7 +2,7 @@
|
|||
package public
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"io"
|
||||
"net/http"
|
||||
"os"
|
||||
|
||||
|
|
@ -33,23 +33,26 @@ func (pub *PublicWeb) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
|||
|
||||
f, err := os.Open(path)
|
||||
|
||||
if err == nil {
|
||||
bufferedReader := bufio.NewReader(f)
|
||||
contentType, err := routing.GetContentType(path)
|
||||
|
||||
if err == nil {
|
||||
w.Header().Add("Content Type", contentType)
|
||||
bufferedReader.WriteTo(w)
|
||||
|
||||
logging.Console(logging.PUBLIC_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 200 success.")
|
||||
} else {
|
||||
routing.HttpThrowStatus(http.StatusUnsupportedMediaType, w)
|
||||
logging.Console(logging.PUBLIC_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" content type could not be determined, 404 error.")
|
||||
}
|
||||
|
||||
} else {
|
||||
if err != nil {
|
||||
routing.HttpThrowStatus(http.StatusNotFound, w)
|
||||
logging.Console(logging.PUBLIC_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 404 error.")
|
||||
return
|
||||
}
|
||||
|
||||
contentType, err := routing.GetContentType(path)
|
||||
|
||||
if err != nil {
|
||||
routing.HttpThrowStatus(http.StatusUnsupportedMediaType, w)
|
||||
logging.Console(logging.PUBLIC_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" content type could not be determined, 404 error.")
|
||||
return
|
||||
}
|
||||
|
||||
w.Header().Add("Content-Type", contentType)
|
||||
_, err = io.Copy(w, f)
|
||||
|
||||
if err != nil {
|
||||
routing.HttpThrowStatus(http.StatusInternalServerError, w)
|
||||
logging.Console(logging.PUBLIC_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 500 error.")
|
||||
return
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,15 +0,0 @@
|
|||
// Package webhost handles the logic of the webhosting panel
|
||||
package webhost
|
||||
|
||||
import "strings"
|
||||
|
||||
var allowedUnauthorizedPathSuffixes = [...]string{"api_testing.html", "user_auth", "user_register"}
|
||||
|
||||
func CheckAuth(path string) bool {
|
||||
for _, suffix := range allowedUnauthorizedPathSuffixes {
|
||||
if strings.HasSuffix(path, suffix) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
|
@ -2,9 +2,10 @@
|
|||
package webhost
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"io"
|
||||
"net/http"
|
||||
"os"
|
||||
"strings"
|
||||
|
||||
"github.com/Ennovar/gPanel/pkg/api"
|
||||
"github.com/Ennovar/gPanel/pkg/logging"
|
||||
|
|
@ -23,6 +24,30 @@ func NewPrivateHost() PrivateHost {
|
|||
}
|
||||
}
|
||||
|
||||
// reqAuth function checks to see if the given path requires authentication.
|
||||
func reqAuth(path string) bool {
|
||||
path = strings.ToLower(path)
|
||||
|
||||
dismissibleTypes := []string{".css", ".js"}
|
||||
for _, t := range dismissibleTypes {
|
||||
if strings.HasSuffix(path, t) {
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
dismissibleFiles := []string{
|
||||
"api_testing.html",
|
||||
"index.html",
|
||||
}
|
||||
for _, f := range dismissibleFiles {
|
||||
if strings.HasSuffix(path, f) {
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
return true
|
||||
}
|
||||
|
||||
// ServeHTTP function routes all requests for the private webhost server. It is used in the main
|
||||
// function inside of the http.ListenAndServe() function for the private webhost host.
|
||||
func (priv *PrivateHost) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
||||
|
|
@ -33,43 +58,58 @@ func (priv *PrivateHost) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
|||
path = (priv.Directory + path)
|
||||
}
|
||||
|
||||
store := networking.GetStore(networking.COOKIES_USER_AUTH)
|
||||
val, err := store.Read(w, req, "auth")
|
||||
if err != nil {
|
||||
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||
var auth interface{} = true
|
||||
if reqAuth(path) {
|
||||
store := networking.GetStore(networking.COOKIES_USER_AUTH)
|
||||
|
||||
auth, err := store.Read(w, req, "auth")
|
||||
if err != nil {
|
||||
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
|
||||
auth, ok := auth.(bool)
|
||||
if !ok {
|
||||
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
if !auth.(bool) {
|
||||
routing.HttpThrowStatus(http.StatusUnauthorized, w)
|
||||
logging.Console(logging.PRIVATE_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 401 error.")
|
||||
return
|
||||
}
|
||||
|
||||
if val != true && !CheckAuth(path) {
|
||||
routing.HttpThrowStatus(http.StatusUnauthorized, w)
|
||||
logging.Console(logging.PRIVATE_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 401 error.")
|
||||
} else {
|
||||
isApi, _ := api.HandleAPI(path, w, req)
|
||||
|
||||
if isApi != true {
|
||||
f, err := os.Open(path)
|
||||
|
||||
if err == nil {
|
||||
bufferedReader := bufio.NewReader(f)
|
||||
contentType, err := routing.GetContentType(path)
|
||||
|
||||
if err == nil {
|
||||
w.Header().Add("Content Type", contentType)
|
||||
bufferedReader.WriteTo(w)
|
||||
|
||||
logging.Console(logging.PRIVATE_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 200 success.")
|
||||
} else {
|
||||
routing.HttpThrowStatus(http.StatusUnsupportedMediaType, w)
|
||||
logging.Console(logging.PRIVATE_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" content type could not be determined, 404 error.")
|
||||
}
|
||||
|
||||
} else {
|
||||
routing.HttpThrowStatus(http.StatusNotFound, w)
|
||||
logging.Console(logging.PRIVATE_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 404 error.")
|
||||
}
|
||||
|
||||
}
|
||||
isApi, _ := api.HandleAPI(path, w, req)
|
||||
|
||||
if isApi {
|
||||
// API methods handle HTTP logic from here
|
||||
return
|
||||
}
|
||||
|
||||
f, err := os.Open(path)
|
||||
|
||||
if err != nil {
|
||||
routing.HttpThrowStatus(http.StatusNotFound, w)
|
||||
logging.Console(logging.PRIVATE_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 404 error.")
|
||||
return
|
||||
}
|
||||
|
||||
contentType, err := routing.GetContentType(path)
|
||||
|
||||
if err != nil {
|
||||
routing.HttpThrowStatus(http.StatusUnsupportedMediaType, w)
|
||||
logging.Console(logging.PUBLIC_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" content type could not be determined, 404 error.")
|
||||
return
|
||||
}
|
||||
|
||||
w.Header().Add("Content-Type", contentType)
|
||||
_, err = io.Copy(w, f)
|
||||
|
||||
if err != nil {
|
||||
routing.HttpThrowStatus(http.StatusInternalServerError, w)
|
||||
logging.Console(logging.PUBLIC_PREFIX, logging.NORMAL_LOG, "Path \""+path+"\" rendered a 500 error.")
|
||||
return
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue