From cdb75d3fcbc9339b897f8c6ff4d69a577f017393 Mon Sep 17 00:00:00 2001 From: Leonardo Bishop Date: Tue, 8 Jul 2025 23:26:05 +0100 Subject: Rewrite in Go --- main.go | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 main.go (limited to 'main.go') diff --git a/main.go b/main.go new file mode 100644 index 0000000..7a38d82 --- /dev/null +++ b/main.go @@ -0,0 +1,52 @@ +package main + +import ( + "fmt" + "log/slog" + "net/http" + "path" + "path/filepath" + + "github.com/LMBishop/scrapbook/api" + "github.com/LMBishop/scrapbook/pkg/config" + "github.com/LMBishop/scrapbook/pkg/constants" + "github.com/LMBishop/scrapbook/pkg/index" + "github.com/LMBishop/scrapbook/pkg/server" + "github.com/LMBishop/scrapbook/web" +) + +func main() { + slog.Info("welcome to scrapbook") + + var cfg config.MainConfig + err := config.ReadMainConfig(filepath.Join(constants.SysConfDir, "config.toml"), &cfg) + if err != nil { + panic(fmt.Errorf("main config read failed: %w", err)) + } + err = config.ValidateMainConfig(&cfg) + if err != nil { + panic(fmt.Errorf("main config validation failed: %w", err)) + } + + siteIndex := index.NewSiteIndex() + + err = index.ScanDirectory(path.Join(constants.SysDataDir, "sites"), siteIndex) + if err != nil { + panic(fmt.Errorf("could not scan data directory: %w", err)) + } + + slog.Info("initial data directory scan complete", "sites", len(siteIndex.GetSites())) + + if cfg.Command.Host == "" { + slog.Warn("command interface host is empty - neither api or web interface will be accessible") + } + + mux := http.NewServeMux() + + mux.Handle(fmt.Sprintf("%s/api/", cfg.Command.Host), http.StripPrefix("/api/", api.NewMux(&cfg, siteIndex))) + mux.Handle(fmt.Sprintf("%s/", cfg.Command.Host), web.NewMux(&cfg, siteIndex)) + mux.HandleFunc("/", server.ServeSite(siteIndex)) + + err = http.ListenAndServe(fmt.Sprintf("%s:%d", cfg.Listen.Address, cfg.Listen.Port), mux) + slog.Error("http server closing", "reason", err.Error()) +} -- cgit v1.2.3-70-g09d2