refactor(browser): publicize key-injection capability api (#597)

Promote keyRetrieversSetter to public KeyManager and lift
keychainPasswordSetter from browser_darwin.go into browser.go as
KeychainPasswordReceiver. Engines already implement these methods;
only type-assertion sites switch to the public interface names.
This commit is contained in:
Roger
2026-05-16 12:26:57 +08:00
committed by GitHub
parent f8bd391923
commit 00be145044
4 changed files with 16 additions and 25 deletions
+7 -4
View File
@@ -111,13 +111,16 @@ func pickFromConfigs(configs []types.BrowserConfig, opts PickOptions) ([]Browser
return browsers, nil
}
// keyRetrieversSetter is an optional capability interface. Chromium variants implement it to
// receive the per-tier master-key retrievers (V10 / V11 / V20) as a single Retrievers struct;
// Firefox and Safari do not.
type keyRetrieversSetter interface {
// KeyManager is implemented by engines that accept externally-provided master-key retrievers (Chromium family only).
type KeyManager interface {
SetKeyRetrievers(keyretriever.Retrievers)
}
// KeychainPasswordReceiver is implemented by engines that need the macOS login password (Safari only).
type KeychainPasswordReceiver interface {
SetKeychainPassword(string)
}
// resolveGlobs expands glob patterns in browser configs' UserDataDir.
// This supports MSIX/UWP browsers on Windows whose package directories
// contain a dynamic publisher hash suffix (e.g., "TheBrowserCompany.Arc_*").
+5 -17
View File
@@ -155,20 +155,8 @@ func resolveKeychainPassword(flagPassword string) string {
return password
}
// keychainPasswordSetter is an optional capability interface satisfied by
// Safari, which reads InternetPassword records directly from the login keychain.
type keychainPasswordSetter interface {
SetKeychainPassword(string)
}
// newPlatformInjector returns a closure that injects the Chromium master-key
// retriever and the Safari Keychain password into each Browser.
//
// Resolution is lazy: the keychain password prompt and retriever construction
// are deferred until the first Browser that actually needs them passes through
// the closure. Browsers that satisfy neither setter interface (e.g. Firefox)
// short-circuit without ever touching the keychain, so `-b firefox` on macOS
// no longer triggers a password prompt.
// newPlatformInjector lazily wires retrievers (and the macOS keychain password) into each Browser;
// `-b firefox` never triggers a keychain prompt because lazy resolution skips browsers that need neither.
func newPlatformInjector(opts PickOptions) func(Browser) {
var (
password string
@@ -176,8 +164,8 @@ func newPlatformInjector(opts PickOptions) func(Browser) {
resolved bool
)
return func(b Browser) {
rs, needsRetrievers := b.(keyRetrieversSetter)
kps, needsKeychainPassword := b.(keychainPasswordSetter)
km, needsRetrievers := b.(KeyManager)
kps, needsKeychainPassword := b.(KeychainPasswordReceiver)
if !needsRetrievers && !needsKeychainPassword {
return
}
@@ -187,7 +175,7 @@ func newPlatformInjector(opts PickOptions) func(Browser) {
resolved = true
}
if needsRetrievers {
rs.SetKeyRetrievers(retrievers)
km.SetKeyRetrievers(retrievers)
}
if needsKeychainPassword {
kps.SetKeychainPassword(password)
+2 -2
View File
@@ -75,8 +75,8 @@ func platformBrowsers() []types.BrowserConfig {
func newPlatformInjector(_ PickOptions) func(Browser) {
retrievers := keyretriever.DefaultRetrievers()
return func(b Browser) {
if s, ok := b.(keyRetrieversSetter); ok {
s.SetKeyRetrievers(retrievers)
if km, ok := b.(KeyManager); ok {
km.SetKeyRetrievers(retrievers)
}
}
}
+2 -2
View File
@@ -132,8 +132,8 @@ func platformBrowsers() []types.BrowserConfig {
func newPlatformInjector(_ PickOptions) func(Browser) {
retrievers := keyretriever.DefaultRetrievers()
return func(b Browser) {
if s, ok := b.(keyRetrieversSetter); ok {
s.SetKeyRetrievers(retrievers)
if km, ok := b.(KeyManager); ok {
km.SetKeyRetrievers(retrievers)
}
}
}