mirror of
https://github.com/moonD4rk/HackBrowserData.git
synced 2026-05-19 18:58:03 +02:00
92053b85b0
* chore: update golangci-lint config and fix lint issues
62 lines
1.6 KiB
Go
62 lines
1.6 KiB
Go
package output
|
|
|
|
import (
|
|
"encoding/json"
|
|
"io"
|
|
|
|
"github.com/moond4rk/hackbrowserdata/types"
|
|
)
|
|
|
|
// cookieEditorFormatter outputs cookies in the CookieEditor browser extension
|
|
// format. Non-cookie categories fall back to standard JSON output.
|
|
type cookieEditorFormatter struct {
|
|
fallback *jsonFormatter
|
|
}
|
|
|
|
func (f *cookieEditorFormatter) ext() string { return "json" }
|
|
|
|
func (f *cookieEditorFormatter) format(w io.Writer, rows []row) error {
|
|
if len(rows) == 0 {
|
|
return nil
|
|
}
|
|
// aggregate() guarantees all rows in a batch share the same type;
|
|
// check the first row to decide the format.
|
|
if _, ok := rows[0].entry.(types.CookieEntry); !ok {
|
|
return f.fallback.format(w, rows)
|
|
}
|
|
|
|
entries := make([]cookieEditorEntry, 0, len(rows))
|
|
for _, r := range rows {
|
|
c, _ := r.entry.(types.CookieEntry)
|
|
var expDate float64
|
|
if !c.ExpireAt.IsZero() {
|
|
expDate = float64(c.ExpireAt.Unix())
|
|
}
|
|
entries = append(entries, cookieEditorEntry{
|
|
Domain: c.Host,
|
|
ExpirationDate: expDate,
|
|
HTTPOnly: c.IsHTTPOnly,
|
|
Name: c.Name,
|
|
Path: c.Path,
|
|
Secure: c.IsSecure,
|
|
Value: c.Value,
|
|
})
|
|
}
|
|
|
|
enc := json.NewEncoder(w)
|
|
enc.SetIndent("", " ")
|
|
enc.SetEscapeHTML(false)
|
|
return enc.Encode(entries)
|
|
}
|
|
|
|
// cookieEditorEntry matches the CookieEditor browser extension's import format.
|
|
type cookieEditorEntry struct {
|
|
Domain string `json:"domain"`
|
|
ExpirationDate float64 `json:"expirationDate"`
|
|
HTTPOnly bool `json:"httpOnly"`
|
|
Name string `json:"name"`
|
|
Path string `json:"path"`
|
|
Secure bool `json:"secure"`
|
|
Value string `json:"value"`
|
|
}
|