wfc-server/sake/main.go
2024-09-07 11:13:02 -04:00

58 lines
1.3 KiB
Go

package sake
import (
"context"
"fmt"
"net/http"
"strings"
"wwfc/common"
"wwfc/logging"
"github.com/jackc/pgx/v4/pgxpool"
"github.com/logrusorgru/aurora/v3"
)
var (
ctx = context.Background()
pool *pgxpool.Pool
)
func StartServer(reload bool) {
// Get config
config := common.GetConfig()
common.ReadGameList()
// Start SQL
dbString := fmt.Sprintf("postgres://%s:%s@%s/%s", config.Username, config.Password, config.DatabaseAddress, config.DatabaseName)
dbConf, err := pgxpool.ParseConfig(dbString)
if err != nil {
panic(err)
}
pool, err = pgxpool.ConnectConfig(ctx, dbConf)
if err != nil {
panic(err)
}
}
func Shutdown() {
}
func HandleRequest(w http.ResponseWriter, r *http.Request) {
logging.Info("SAKE", aurora.Yellow(r.Method), aurora.Cyan(r.URL), "via", aurora.Cyan(r.Host), "from", aurora.BrightCyan(r.RemoteAddr))
urlPath := r.URL.Path
switch {
case urlPath == "/SakeStorageServer/StorageServer.asmx":
moduleName := "SAKE:Storage:" + r.RemoteAddr
handleStorageRequest(moduleName, w, r)
case strings.HasSuffix(urlPath, "download.aspx"):
moduleName := "SAKE:File:" + r.RemoteAddr
handleFileRequest(moduleName, w, r, FileRequestDownload)
case strings.HasSuffix(urlPath, "upload.aspx"):
moduleName := "SAKE:File:" + r.RemoteAddr
handleFileRequest(moduleName, w, r, FileRequestUpload)
}
}