refactor: modularize main function
This commit is contained in:
parent
00d2f3e510
commit
8afc49bd04
46
abyss.go
46
abyss.go
@ -13,6 +13,28 @@ import (
|
|||||||
func main() {
|
func main() {
|
||||||
app := new(Application)
|
app := new(Application)
|
||||||
|
|
||||||
|
parseEnv(app)
|
||||||
|
|
||||||
|
mux := http.NewServeMux()
|
||||||
|
|
||||||
|
setupHandlers(mux, app)
|
||||||
|
|
||||||
|
srv := &http.Server{
|
||||||
|
Addr: app.port,
|
||||||
|
Handler: mux,
|
||||||
|
IdleTimeout: 10 * time.Second,
|
||||||
|
ReadTimeout: 10 * time.Second,
|
||||||
|
WriteTimeout: 60 * time.Second,
|
||||||
|
}
|
||||||
|
|
||||||
|
log.Printf("starting server on %s", srv.Addr)
|
||||||
|
|
||||||
|
if err := srv.ListenAndServe(); err != nil {
|
||||||
|
log.Fatalf("Failed to start server: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func parseEnv(app *Application) {
|
||||||
err := godotenv.Load()
|
err := godotenv.Load()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Warn("no .env file detected, getting env from running process")
|
slog.Warn("no .env file detected, getting env from running process")
|
||||||
@ -25,7 +47,7 @@ func main() {
|
|||||||
app.filesDir = os.Getenv("ABYSS_FILEDIR")
|
app.filesDir = os.Getenv("ABYSS_FILEDIR")
|
||||||
app.port = os.Getenv("ABYSS_PORT")
|
app.port = os.Getenv("ABYSS_PORT")
|
||||||
|
|
||||||
auth := os.Getenv("SHOULD_AUTH")
|
app.authText = os.Getenv("SHOULD_AUTH")
|
||||||
|
|
||||||
if app.auth.username == "" {
|
if app.auth.username == "" {
|
||||||
log.Fatal("basic auth username must be provided")
|
log.Fatal("basic auth username must be provided")
|
||||||
@ -56,9 +78,11 @@ func main() {
|
|||||||
slog.Warn("no root url detected, defaulting to localhost.")
|
slog.Warn("no root url detected, defaulting to localhost.")
|
||||||
app.url = "localhost" + app.port
|
app.url = "localhost" + app.port
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
mux := http.NewServeMux()
|
func setupHandlers(mux *http.ServeMux, app *Application) {
|
||||||
mux.HandleFunc("/", app.indexHandler)
|
mux.HandleFunc("/", app.indexHandler)
|
||||||
|
|
||||||
mux.Handle(
|
mux.Handle(
|
||||||
"/tree/",
|
"/tree/",
|
||||||
http.StripPrefix(
|
http.StripPrefix(
|
||||||
@ -66,26 +90,14 @@ func main() {
|
|||||||
app.basicAuth(app.fileListingHandler),
|
app.basicAuth(app.fileListingHandler),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
mux.HandleFunc("/last", app.lastUploadedHandler)
|
mux.HandleFunc("/last", app.lastUploadedHandler)
|
||||||
if auth == "yes" {
|
|
||||||
|
if app.authText == "yes" {
|
||||||
mux.HandleFunc("/upload", app.basicAuth(app.uploadHandler))
|
mux.HandleFunc("/upload", app.basicAuth(app.uploadHandler))
|
||||||
slog.Warn("text uploading through the browser will be restricted")
|
slog.Warn("text uploading through the browser will be restricted")
|
||||||
} else {
|
} else {
|
||||||
mux.HandleFunc("/upload", app.uploadHandler)
|
mux.HandleFunc("/upload", app.uploadHandler)
|
||||||
slog.Warn("text uploading through the browser will NOT be restricted")
|
slog.Warn("text uploading through the browser will NOT be restricted")
|
||||||
}
|
}
|
||||||
|
|
||||||
srv := &http.Server{
|
|
||||||
Addr: app.port,
|
|
||||||
Handler: mux,
|
|
||||||
IdleTimeout: time.Minute,
|
|
||||||
ReadTimeout: 10 * time.Second,
|
|
||||||
WriteTimeout: 60 * time.Second,
|
|
||||||
}
|
|
||||||
|
|
||||||
log.Printf("starting server on %s", srv.Addr)
|
|
||||||
|
|
||||||
if err := srv.ListenAndServe(); err != nil {
|
|
||||||
log.Fatalf("Failed to start server: %v", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ type Application struct {
|
|||||||
key string
|
key string
|
||||||
filesDir string
|
filesDir string
|
||||||
port string
|
port string
|
||||||
|
authText string
|
||||||
lastUploadedFile string
|
lastUploadedFile string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user