From 150a7a4fe8767532a9c4652161db7c1a6569bf7f Mon Sep 17 00:00:00 2001 From: Jacob Sikorski Date: Wed, 11 Oct 2023 10:46:57 -0600 Subject: [PATCH] Fix unwanted removal of content blockers upon launch (#8222) * Fix unwanted removal of content blockers upon launch * Use mutable reduce * Change reduce to a map --- .../Browser/Helpers/LaunchHelper.swift | 31 +++++++++++++++---- 1 file changed, 25 insertions(+), 6 deletions(-) diff --git a/Sources/Brave/Frontend/Browser/Helpers/LaunchHelper.swift b/Sources/Brave/Frontend/Browser/Helpers/LaunchHelper.swift index 22b92af0c19..d1deaa96a21 100644 --- a/Sources/Brave/Frontend/Browser/Helpers/LaunchHelper.swift +++ b/Sources/Brave/Frontend/Browser/Helpers/LaunchHelper.swift @@ -109,13 +109,9 @@ public actor LaunchHelper { /// Get all possible types of blocklist types available in this app, this includes actual and potential types /// This is used to delete old filter lists so that we clean up old stuff @MainActor private func getAllValidBlocklistTypes() -> Set { - return FilterListStorage.shared.filterLists + return FilterListStorage.shared // All filter lists blocklist types - .reduce(Set()) { partialResult, filterList in - return partialResult.union([ - .filterList(componentId: filterList.entry.componentId, isAlwaysAggressive: filterList.isAlwaysAggressive) - ]) - } + .validBlocklistTypes // All generic types .union( ContentBlockerManager.GenericBlocklistType.allCases.map { .generic($0) } @@ -127,6 +123,29 @@ public actor LaunchHelper { } } +private extension FilterListStorage { + /// Return all the blocklist types that are valid for filter lists. + var validBlocklistTypes: Set { + if filterLists.isEmpty { + // If we don't have filter lists yet loaded, use the settings + return Set(allFilterListSettings.compactMap { setting in + guard let componentId = setting.componentId else { return nil } + return .filterList( + componentId: componentId, + isAlwaysAggressive: setting.isAlwaysAggressive + ) + }) + } else { + // If we do have filter lists yet loaded, use them as they are always the most up to date and accurate + return Set(filterLists.map { filterList in + return .filterList( + componentId: filterList.entry.componentId, + isAlwaysAggressive: filterList.isAlwaysAggressive + ) + }) + } + } +} private extension ShieldLevel { /// Return a list of first launch content blocker modes that MUST be precompiled during launch var firstLaunchBlockingModes: Set {