mirror of
https://github.com/moonD4rk/HackBrowserData
synced 2025-03-04 18:37:38 +00:00
* refactor: Refactor logging to use structured slog package. - Remove `gookit` dependencies from `go.sum` - Improve error logging in multiple packages by replacing `log` with `log/slog` - Update dependencies in `go.mod` - Add new `logger` package with test cases - Refactor logging statements in multiple packages to use `slog` instead of `log` - Change logging format and level in multiple packages for better structured logging * refactor: Refactor logger package and add handler interface - Refactor logger package - Rename `defaultHandler` to `DefaultLogger` - Move `ReplaceAttr` function to `Logger` struct - Implement `LogHandler` struct with `slog.Handler` interface - Add new `Logger` methods for configuration - Add `SetMaxLevel`, `SetJSONHandler`, `SetTextHandler`, `SetOutput`, `SetVerbose`, `SetReplaceAttrFunc` - Add verbose flag to `cmd/hack-browser-data/main.go` to increase logging * refactor: Refactor logger package to use simplified handler initialization. - Refactor logger package to use Default instead of DefaultLogger - Update `NewHandler` method to correctly reference `Default` logger and simplify handler initialization - Update tests for logger to reflect changes in Default usage - Rename `DefaultLogger` to `Default` and update comments to better reflect its purpose - Update function calls in hack-browser-data main.go to reflect logger package updates * refactor: Refactor logging in Chromium implementation Refactor logging and simplify decryption in chromium files - Replace logger package import with shared slog package - Change logging messages to use slog instead of logger - Simplify decryption process by removing first 5 characters of encrypted key - Refactor error logging in linux file to use shared slog package - Replace string concatenation with formatted string in linux error message
138 lines
3.2 KiB
Go
138 lines
3.2 KiB
Go
package creditcard
|
|
|
|
import (
|
|
"database/sql"
|
|
"log/slog"
|
|
"os"
|
|
|
|
// import sqlite3 driver
|
|
_ "github.com/mattn/go-sqlite3"
|
|
|
|
"github.com/moond4rk/hackbrowserdata/crypto"
|
|
"github.com/moond4rk/hackbrowserdata/item"
|
|
)
|
|
|
|
type ChromiumCreditCard []card
|
|
|
|
type card struct {
|
|
GUID string
|
|
Name string
|
|
ExpirationYear string
|
|
ExpirationMonth string
|
|
CardNumber string
|
|
Address string
|
|
NickName string
|
|
}
|
|
|
|
const (
|
|
queryChromiumCredit = `SELECT guid, name_on_card, expiration_month, expiration_year, card_number_encrypted, billing_address_id, nickname FROM credit_cards`
|
|
)
|
|
|
|
func (c *ChromiumCreditCard) Parse(masterKey []byte) error {
|
|
db, err := sql.Open("sqlite3", item.ChromiumCreditCard.TempFilename())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer os.Remove(item.ChromiumCreditCard.TempFilename())
|
|
defer db.Close()
|
|
|
|
rows, err := db.Query(queryChromiumCredit)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer rows.Close()
|
|
for rows.Next() {
|
|
var (
|
|
name, month, year, guid, address, nickname string
|
|
value, encryptValue []byte
|
|
)
|
|
if err := rows.Scan(&guid, &name, &month, &year, &encryptValue, &address, &nickname); err != nil {
|
|
slog.Error("scan chromium credit card error", "err", err)
|
|
}
|
|
ccInfo := card{
|
|
GUID: guid,
|
|
Name: name,
|
|
ExpirationMonth: month,
|
|
ExpirationYear: year,
|
|
Address: address,
|
|
NickName: nickname,
|
|
}
|
|
if len(encryptValue) > 0 {
|
|
if len(masterKey) == 0 {
|
|
value, err = crypto.DPAPI(encryptValue)
|
|
} else {
|
|
value, err = crypto.DecryptPass(masterKey, encryptValue)
|
|
}
|
|
if err != nil {
|
|
slog.Error("decrypt chromium credit card error", "err", err)
|
|
}
|
|
}
|
|
|
|
ccInfo.CardNumber = string(value)
|
|
*c = append(*c, ccInfo)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (c *ChromiumCreditCard) Name() string {
|
|
return "creditcard"
|
|
}
|
|
|
|
func (c *ChromiumCreditCard) Len() int {
|
|
return len(*c)
|
|
}
|
|
|
|
type YandexCreditCard []card
|
|
|
|
func (c *YandexCreditCard) Parse(masterKey []byte) error {
|
|
db, err := sql.Open("sqlite3", item.YandexCreditCard.TempFilename())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer os.Remove(item.YandexCreditCard.TempFilename())
|
|
defer db.Close()
|
|
rows, err := db.Query(queryChromiumCredit)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer rows.Close()
|
|
for rows.Next() {
|
|
var (
|
|
name, month, year, guid, address, nickname string
|
|
value, encryptValue []byte
|
|
)
|
|
if err := rows.Scan(&guid, &name, &month, &year, &encryptValue, &address, &nickname); err != nil {
|
|
slog.Error("scan chromium credit card error", "err", err)
|
|
}
|
|
ccInfo := card{
|
|
GUID: guid,
|
|
Name: name,
|
|
ExpirationMonth: month,
|
|
ExpirationYear: year,
|
|
Address: address,
|
|
NickName: nickname,
|
|
}
|
|
if len(encryptValue) > 0 {
|
|
if len(masterKey) == 0 {
|
|
value, err = crypto.DPAPI(encryptValue)
|
|
} else {
|
|
value, err = crypto.DecryptPass(masterKey, encryptValue)
|
|
}
|
|
if err != nil {
|
|
slog.Error("decrypt chromium credit card error", "err", err)
|
|
}
|
|
}
|
|
ccInfo.CardNumber = string(value)
|
|
*c = append(*c, ccInfo)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (c *YandexCreditCard) Name() string {
|
|
return "creditcard"
|
|
}
|
|
|
|
func (c *YandexCreditCard) Len() int {
|
|
return len(*c)
|
|
}
|