//go:build linux package chromium import ( "crypto/sha1" "fmt" "os" "github.com/godbus/dbus/v5" keyring "github.com/ppacher/go-dbus-keyring" "golang.org/x/crypto/pbkdf2" "github.com/moond4rk/HackBrowserData/item" "github.com/moond4rk/HackBrowserData/log" ) func (c *Chromium) GetMasterKey() ([]byte, error) { // what is d-bus @https://dbus.freedesktop.org/ // don't need chromium key file for Linux defer os.Remove(item.TempChromiumKey) conn, err := dbus.SessionBus() if err != nil { return nil, err } svc, err := keyring.GetSecretService(conn) if err != nil { return nil, err } session, err := svc.OpenSession() if err != nil { return nil, err } defer func() { if err := session.Close(); err != nil { log.Errorf("close session failed: %v", err) } }() collections, err := svc.GetAllCollections() if err != nil { return nil, err } var secret []byte for _, col := range collections { items, err := col.GetAllItems() if err != nil { return nil, err } for _, i := range items { label, err := i.GetLabel() if err != nil { log.Error(err) continue } if label == c.storage { se, err := i.GetSecret(session.Path()) if err != nil { return nil, fmt.Errorf("get storage from dbus error: %v" + err.Error()) } secret = se.Value } } } if len(secret) == 0 { // set default secret @https://source.chromium.org/chromium/chromium/src/+/main:components/os_crypt/os_crypt_linux.cc;l=100 secret = []byte("peanuts") } salt := []byte("saltysalt") // @https://source.chromium.org/chromium/chromium/src/+/master:components/os_crypt/os_crypt_linux.cc key := pbkdf2.Key(secret, salt, 1, 16, sha1.New) c.masterKey = key log.Infof("%s initialized master key success", c.name) return key, nil }