Files
HackBrowserData/.gitignore
T
Roger 9fb5165fcb feat: add crypto/keyretriever with keychainbreaker integration (#518)
* feat: add crypto/keyretriever package for Chromium master key retrieval

* feat: complete keyretriever with gcoredump, chainbreaker, and tests

* refactor: replace internal chainbreaker with keychainbreaker v0.1.0

Replace the incomplete internal chainbreaker implementation (~1400 lines
of duplicated code) with the external keychainbreaker package, which
provides a complete, well-tested keychain parsing library.

Changes:
- Add github.com/moond4rk/keychainbreaker v0.1.0 dependency
- Update gcoredump_darwin.go to use keychainbreaker API (Open/Unlock/GenericPasswords)
- Add KeychainPasswordRetriever for password-based keychain unlocking
  with sync.Once caching across multiple browser queries
- Unify DefaultRetriever(keychainPassword string) signature across all platforms
- Delete utils/chainbreaker/ (696 lines + test + testdata)
- Delete crypto/keyretriever/chainbreaker_darwin.go (696 lines duplicate)
- Delete browser/exploit/gcoredump/ (duplicate of keyretriever version)
- Update chromium_darwin.go to use keyretriever.DecryptKeychain
- Clean up .golangci.yml lint exceptions and .gitignore entries
- Use errors.Is() instead of == for context.DeadlineExceeded check

* refactor: improve gcoredump exploit code quality and add comments
* fix: address Copilot review feedback on keyretriever
2026-04-04 01:41:01 +08:00

47 lines
764 B
Plaintext

# Ignore everything by default (whitelist approach).
# This is critical for a security research tool — prevents
# accidental commit of browser data files (Cookies, Login Data, etc.)
*
# Allow git to traverse directories
!*/
# === Source code ===
!*.go
!go.mod
!go.sum
# === Project root config ===
!.gitignore
!.golangci.yml
!.goreleaser.yml
!.typos.toml
!CLAUDE.md
!LICENSE
# === Documentation ===
!README.md
!CONTRIBUTING.md
!CODE_OF_CONDUCT.md
!LOGO.png
!CONTRIBUTORS.svg
# === GitHub ===
!.github/workflows/*.yml
!.github/ISSUE_TEMPLATE/*.md
!.github/PULL_REQUEST_TEMPLATE.md
!.github/dependabot.yml
!.github/release-drafter.yml
# === RFCs ===
!rfcs/*.md
# === Always ignore (override !*/) ===
.git/
.idea/
.vscode/
vendor/
result/
results/
.DS_Store