Files
HackBrowserData/browser/firefox/extract_history.go
T
Roger b3bbc0dadf feat: add CountEntries to skip decryption for list --detail (#562)
* feat: add CountEntries to skip decryption for list --detail (#549)
* test: add CountEntries and countCategory tests at browser level
* fix: address review feedback on CountRows and countLocalStorage
* test: add CountRows unit tests
2026-04-07 22:28:39 +08:00

46 lines
1.2 KiB
Go

package firefox
import (
"database/sql"
"sort"
"github.com/moond4rk/hackbrowserdata/types"
"github.com/moond4rk/hackbrowserdata/utils/sqliteutil"
)
const (
firefoxHistoryQuery = `SELECT url, COALESCE(last_visit_date, 0),
COALESCE(title, ''), visit_count FROM moz_places`
firefoxCountHistoryQuery = `SELECT COUNT(*) FROM moz_places`
)
func extractHistories(path string) ([]types.HistoryEntry, error) {
histories, err := sqliteutil.QueryRows(path, true, firefoxHistoryQuery,
func(rows *sql.Rows) (types.HistoryEntry, error) {
var url, title string
var visitCount int
var lastVisit int64
if err := rows.Scan(&url, &lastVisit, &title, &visitCount); err != nil {
return types.HistoryEntry{}, err
}
return types.HistoryEntry{
URL: url,
Title: title,
VisitCount: visitCount,
LastVisit: timestamp(lastVisit / 1000000),
}, nil
})
if err != nil {
return nil, err
}
sort.Slice(histories, func(i, j int) bool {
return histories[i].VisitCount < histories[j].VisitCount
})
return histories, nil
}
func countHistories(path string) (int, error) {
return sqliteutil.CountRows(path, true, firefoxCountHistoryQuery)
}