commit 78d6c27c8940da32a6de8e64327c86f74fdaa2eb Author: adminoo <git@kadath.corp> Date: Wed Feb 4 12:59:22 2026 +0100 feat: freebsd log rotation config thingie commit 55af4e6c70122e679272ed247c26e04b1247f694 Author: adminoo <git@kadath.corp> Date: Wed Feb 4 12:58:43 2026 +0100 feat: embed templates, static resolution commit 29c917f929a7378ec29c54315ee2e9f420747787 Author: adminoo <git@kadath.corp> Date: Wed Feb 4 10:44:34 2026 +0100 feat: set log file path commit 294fd3d1549979eab63587ceec6ff5d0978e9afc Author: adminoo <git@kadath.corp> Date: Wed Feb 4 10:23:53 2026 +0100 feat: logging HTTP request commit c9ae80b240d58e1abed7ae3b7b2c3b283a31f1a1 Author: adminoo <git@kadath.corp> Date: Wed Feb 4 09:54:05 2026 +0100 feat: freebsd-specific compile target and scripts commit 86ca154dedd19aa1fe5f571c445dcf17a8396bfa Author: adminoo <git@kadath.corp> Date: Wed Feb 4 09:25:16 2026 +0100 feat: mobile friendly CSS commit 199f4319e0b08a4b6d595d7eb3effb6db6c7beec Author: adminoo <git@kadath.corp> Date: Wed Feb 4 09:25:03 2026 +0100 feat: persisting rendered note commit 865e258237e45d7c542685a4653bcad3c5af259d Author: adminoo <git@kadath.corp> Date: Wed Feb 4 08:06:38 2026 +0100 fix: grouping notes by folder commit 242d1d074c92461f38212b033c7a9e383f9dc550 Author: adminoo <git@kadath.corp> Date: Tue Feb 3 16:52:50 2026 +0100 feat: storage layer logic - Prune notes from db not matching current folder structure at start - Detect file system deletion on start by comparing in-db notes - Prevent updating of in-db notes at start if modification time is not newer - Delete by path commit d75d46bc1ab22bd990d0fdc307e571fe52f0dd99 Author: adminoo <git@kadath.corp> Date: Tue Feb 3 15:27:07 2026 +0100 feat: group notes by root folders commit e1e25a938e717599332f7b40a449d9bb854b673a Author: adminoo <git@kadath.corp> Date: Tue Feb 3 14:24:37 2026 +0100 feat: size in kilobytes commit 61220272a2df2b66c2b8e356ba359ed01de3bd12 Author: adminoo <git@kadath.corp> Date: Tue Feb 3 14:19:40 2026 +0100 feat: styling inputs
96 lines
2.5 KiB
Go
96 lines
2.5 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
"path/filepath"
|
|
|
|
"donniemarko/internal/render"
|
|
"donniemarko/internal/scanner"
|
|
"donniemarko/internal/service"
|
|
"donniemarko/internal/storage"
|
|
"donniemarko/internal/web"
|
|
)
|
|
|
|
func main() {
|
|
// Define command line flags
|
|
var help bool
|
|
rootFolder := flag.String("root", ".", "Root folder to serve files from")
|
|
listenAddr := flag.String("addr", "localhost:5555", "Address to listen on")
|
|
dbPath := flag.String("db", "", "SQLite database path (empty uses ~/.local/share/donniemarko/notes.db)")
|
|
logPath := flag.String("log", "/var/log/donniemarko.log", "Log file path")
|
|
flag.BoolVar(&help, "help", false, "display this program usage")
|
|
flag.Parse()
|
|
|
|
if help {
|
|
flag.PrintDefaults()
|
|
return
|
|
}
|
|
|
|
// Initialize storage
|
|
var noteStorage storage.Storage
|
|
var sqliteStorage *storage.SQLiteStorage
|
|
resolvedDBPath := *dbPath
|
|
if resolvedDBPath == "" {
|
|
homeDir, err := os.UserHomeDir()
|
|
if err != nil {
|
|
log.Fatalf("failed to resolve home directory: %v", err)
|
|
}
|
|
resolvedDBPath = filepath.Join(homeDir, ".local", "share", "donniemarko", "notes.db")
|
|
}
|
|
|
|
if err := os.MkdirAll(filepath.Dir(resolvedDBPath), 0o700); err != nil {
|
|
log.Fatalf("failed to create database directory: %v", err)
|
|
}
|
|
|
|
var err error
|
|
sqliteStorage, err = storage.NewSQLiteStorage(resolvedDBPath)
|
|
if err != nil {
|
|
log.Fatalf("failed to open sqlite db: %v", err)
|
|
}
|
|
defer func() {
|
|
if err := sqliteStorage.Close(); err != nil {
|
|
log.Printf("failed to close sqlite db: %v", err)
|
|
}
|
|
}()
|
|
noteStorage = sqliteStorage
|
|
|
|
if f, err := os.OpenFile(*logPath, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0o644); err == nil {
|
|
log.SetOutput(f)
|
|
} else {
|
|
log.Printf("failed to open log file %s: %v", *logPath, err)
|
|
}
|
|
|
|
// Initialize scanner
|
|
monitor := scanner.NewScanner(*rootFolder)
|
|
monitor.SeedExisting(noteStorage.GetAll())
|
|
|
|
// Initialize notes handler for scanner
|
|
notesHandler := scanner.NewNotesHandler(noteStorage, *rootFolder)
|
|
monitor.SetHandler(notesHandler)
|
|
|
|
// Initialize service
|
|
noteService := service.NewNoteService()
|
|
noteService.SetStorage(noteStorage)
|
|
|
|
// Start scanner in background
|
|
ctx := context.Background()
|
|
go monitor.Monitor(ctx)
|
|
|
|
// log.Println("WE GET THERE", len(noteStorage.Index))
|
|
// Initialize template manager
|
|
tm := render.NewTemplateManagerFS(web.TemplatesFS(), "")
|
|
|
|
// Initialize web handler
|
|
handler := web.NewHandler(noteService, tm)
|
|
|
|
// Setup routes
|
|
handler.SetupRoutes()
|
|
|
|
log.Printf("Serving on http://%s", *listenAddr)
|
|
log.Fatal(http.ListenAndServe(*listenAddr, nil))
|
|
}
|