summaryrefslogtreecommitdiff
path: root/internal/storage/db.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-04-14 11:16:45 +0300
committerPaul Buetow <paul@buetow.org>2026-04-14 11:16:45 +0300
commit2bc4e64acf93f04c8871d964d75f041ada57f89d (patch)
treec156e09a6c65c47e35006a9c108f4a85e78ef1e2 /internal/storage/db.go
parenta58a6cf092338e0dac45608efa9f2c7b81cbe01f (diff)
refactor: share .records file discovery (ask u3)
Extract ListNonEmptyFiles and HostFromFileName into internal/recordsdir for aggregate and storage ImportFromDir. Behavior unchanged. Made-with: Cursor
Diffstat (limited to 'internal/storage/db.go')
-rw-r--r--internal/storage/db.go21
1 files changed, 4 insertions, 17 deletions
diff --git a/internal/storage/db.go b/internal/storage/db.go
index 7b577e7..fe789d6 100644
--- a/internal/storage/db.go
+++ b/internal/storage/db.go
@@ -6,10 +6,9 @@ import (
"database/sql"
"fmt"
"os"
- "path/filepath"
- "strings"
"codeberg.org/snonux/goprecords/internal/recordline"
+ "codeberg.org/snonux/goprecords/internal/recordsdir"
_ "modernc.org/sqlite"
)
@@ -67,7 +66,7 @@ func ImportFromDir(ctx context.Context, db *sql.DB, statsDir string) error {
if err := ResetRecords(ctx, db); err != nil {
return fmt.Errorf("reset records: %w", err)
}
- entries, err := os.ReadDir(statsDir)
+ files, err := recordsdir.ListNonEmptyFiles(statsDir)
if err != nil {
return fmt.Errorf("read dir: %w", err)
}
@@ -81,20 +80,8 @@ func ImportFromDir(ctx context.Context, db *sql.DB, statsDir string) error {
return fmt.Errorf("prepare insert: %w", err)
}
defer insert.Close()
- for _, e := range entries {
- if e.IsDir() || !strings.HasSuffix(e.Name(), ".records") {
- continue
- }
- path := filepath.Join(statsDir, e.Name())
- info, err := os.Stat(path)
- if err != nil || info.Size() == 0 {
- continue
- }
- host := strings.TrimSuffix(e.Name(), filepath.Ext(e.Name()))
- if idx := strings.Index(host, "."); idx > 0 {
- host = host[:idx]
- }
- if err := importFile(ctx, insert, path, host); err != nil {
+ for _, f := range files {
+ if err := importFile(ctx, insert, f.Path, f.Host); err != nil {
return err
}
}