gonotes/cmd/server/main.go

66 lines
1.6 KiB
Go
Raw Normal View History

package main
import (
"flag"
"log"
"net"
"net/http"
2025-06-26 22:42:03 +01:00
"os"
"time"
2025-12-10 16:34:40 +00:00
"forgejo.gwairfelin.com/max/gonotes/internal/auth"
2025-06-01 21:27:08 +01:00
"forgejo.gwairfelin.com/max/gonotes/internal/conf"
"forgejo.gwairfelin.com/max/gonotes/internal/middleware"
"forgejo.gwairfelin.com/max/gonotes/internal/notes"
2025-06-01 21:27:08 +01:00
"forgejo.gwairfelin.com/max/gonotes/internal/notes/views"
)
func main() {
var confFile string
2025-07-30 13:41:03 +01:00
sessions := middleware.NewSessionStore()
2025-07-30 09:35:01 +01:00
2025-06-24 19:48:55 +01:00
flag.StringVar(&confFile, "c", "/etc/gonotes/conf.toml", "Specify path to config file.")
flag.Parse()
conf.LoadConfig(confFile)
err := notes.Init()
if err != nil {
log.Fatal(err)
}
2025-06-26 22:42:03 +01:00
log.SetOutput(os.Stdout)
router := http.NewServeMux()
notesRouter := views.GetRoutes("/notes")
2025-12-10 16:34:40 +00:00
authRouter := auth.GetRoutes("/auth", sessions.Login)
cacheExpiration, err := time.ParseDuration("24h")
if err != nil {
log.Fatal(err)
}
etag := middleware.NewETag("static", cacheExpiration)
2025-12-10 16:34:40 +00:00
router.Handle("/logout/", sessions.AsMiddleware(middleware.LoggingMiddleware(http.HandlerFunc(sessions.Logout))))
router.Handle("/", middleware.LoggingMiddleware(http.RedirectHandler("/notes/", http.StatusFound)))
2025-07-30 13:41:03 +01:00
router.Handle("/notes/", sessions.AsMiddleware(middleware.LoggingMiddleware(http.StripPrefix("/notes", notesRouter))))
2025-12-10 16:34:40 +00:00
router.Handle("/auth/", sessions.AsMiddleware(middleware.LoggingMiddleware(http.StripPrefix("/auth", authRouter))))
2025-01-28 22:08:01 +00:00
router.Handle(
2025-06-25 21:30:57 +01:00
"/static/",
middleware.LoggingMiddleware(
middleware.StaticEtagMiddleware(
*etag,
http.FileServer(http.FS(conf.Static)),
),
2025-01-28 22:08:01 +00:00
),
)
listener, err := net.Listen(conf.Conf.Protocol, conf.Conf.Address)
if err != nil {
log.Fatal(err)
}
log.Fatal(http.Serve(listener, router))
}