From 3cf28580be76d7fbdf028655717ef2a450724917 Mon Sep 17 00:00:00 2001 From: Adam Fisk Date: Wed, 20 Nov 2024 13:10:43 -0700 Subject: [PATCH] Avoid ever modifying the set masquerades slice --- fronted.go | 23 ++++++++++++----------- fronted_test.go | 8 ++++---- 2 files changed, 16 insertions(+), 15 deletions(-) diff --git a/fronted.go b/fronted.go index 16d0f73..71ed6b9 100644 --- a/fronted.go +++ b/fronted.go @@ -62,25 +62,25 @@ func newFronted(pool *x509.CertPool, providers map[string]*Provider, return nil, fmt.Errorf("no masquerades found in providers") } + // copy providers + providersCopy := make(map[string]*Provider, len(providers)) + for k, p := range providers { + providersCopy[k] = NewProvider(p.HostAliases, p.TestURL, p.Masquerades, p.Validator, p.PassthroughPatterns, p.SNIConfig, p.VerifyHostname) + } + f := &fronted{ certPool: pool, - masquerades: make(sortedMasquerades, 0, size), + masquerades: loadMasquerades(providersCopy, size), maxAllowedCachedAge: defaultMaxAllowedCachedAge, maxCacheSize: defaultMaxCacheSize, cacheSaveInterval: defaultCacheSaveInterval, cacheDirty: make(chan interface{}, 1), cacheClosed: make(chan interface{}), defaultProviderID: defaultProviderID, - providers: make(map[string]*Provider), + providers: providersCopy, clientHelloID: clientHelloID, } - // copy providers - for k, p := range providers { - f.providers[k] = NewProvider(p.HostAliases, p.TestURL, p.Masquerades, p.Validator, p.PassthroughPatterns, p.SNIConfig, p.VerifyHostname) - } - - f.loadCandidates(f.providers) if cacheFile != "" { f.initCaching(cacheFile) } @@ -89,14 +89,14 @@ func newFronted(pool *x509.CertPool, providers map[string]*Provider, return f, nil } -func (f *fronted) loadCandidates(initial map[string]*Provider) { +func loadMasquerades(initial map[string]*Provider, size int) sortedMasquerades { log.Debugf("Loading candidates for %d providers", len(initial)) defer log.Debug("Finished loading candidates") + masquerades := make(sortedMasquerades, 0, size) for key, p := range initial { arr := p.Masquerades size := len(arr) - log.Debugf("Adding %d candidates for %v", size, key) // make a shuffled copy of arr // ('inside-out' Fisher-Yates) @@ -108,9 +108,10 @@ func (f *fronted) loadCandidates(initial map[string]*Provider) { } for _, c := range sh { - f.masquerades = append(f.masquerades, &masquerade{Masquerade: *c, ProviderID: key}) + masquerades = append(masquerades, &masquerade{Masquerade: *c, ProviderID: key}) } } + return masquerades } func (f *fronted) providerFor(m MasqueradeInterface) *Provider { diff --git a/fronted_test.go b/fronted_test.go index c2dc8e3..575af02 100644 --- a/fronted_test.go +++ b/fronted_test.go @@ -132,7 +132,7 @@ func TestVet(t *testing.T) { t.Fatal("None of the default masquerades vetted successfully") } -func TestLoadCandidates(t *testing.T) { +func TestLoadMasquerades(t *testing.T) { providers := testProviders() expected := make(map[Masquerade]bool) @@ -142,12 +142,12 @@ func TestLoadCandidates(t *testing.T) { } } + newMasquerades := loadMasquerades(providers, len(expected)) + d := &fronted{ - masquerades: make(sortedMasquerades, 0, len(expected)), + masquerades: newMasquerades, } - d.loadCandidates(providers) - actual := make(map[Masquerade]bool) count := 0 for _, m := range d.masquerades {