Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Subscription refactoring #2764

Merged
merged 65 commits into from
May 22, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
ee75110
BSK local
federicocappelli May 1, 2024
8405288
Merge branch 'main' into fcappelli/subscription_refactoring
federicocappelli May 1, 2024
d0fd095
AccountManager injected
federicocappelli May 2, 2024
1b41a14
unit tests fixed
federicocappelli May 2, 2024
8fa8789
AccountManaging protocol
federicocappelli May 2, 2024
fea4789
Merge branch 'main' into fcappelli/subscription_refactoring
federicocappelli May 2, 2024
ab8fe34
Merge branch 'main' into fcappelli/subscription_refactoring
federicocappelli May 3, 2024
9ecc6f2
alerts temporary restored
federicocappelli May 3, 2024
4fd5f93
swiftlint
federicocappelli May 3, 2024
269f1af
BSK from PR branch
federicocappelli May 3, 2024
73f0fd6
another accountManager DI
federicocappelli May 3, 2024
dc8d9e6
another AccountManager DI
federicocappelli May 3, 2024
430c046
more DI
federicocappelli May 3, 2024
32c74f4
user script merged
federicocappelli May 3, 2024
107d010
Merge branch 'main' into fcappelli/subscription_refactoring
federicocappelli May 3, 2024
a859720
subscription service DI
federicocappelli May 6, 2024
8fff64e
Merge branch 'main' into fcappelli/subscription_refactoring
federicocappelli May 6, 2024
2ef70f6
Merge branch 'fcappelli/subscription_refactoring' into fcappelli/subs…
federicocappelli May 6, 2024
6cb20e1
refactoring WIP
federicocappelli May 6, 2024
159bf6c
more dismantling and rebuilding
federicocappelli May 7, 2024
a9efc50
it builds!
federicocappelli May 7, 2024
2e13dd1
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 8, 2024
41b1ad3
unit tests improved using AccountManagerMock
federicocappelli May 8, 2024
7a76e2f
SubscriptionManaging
federicocappelli May 8, 2024
932f0cc
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 9, 2024
e7851bd
subscriptionenvironment saved and loaded from userdefaults
federicocappelli May 9, 2024
9633942
subscription environment propagated across app and extensions
federicocappelli May 9, 2024
60baabc
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 9, 2024
d385fa0
BSK points now to the right branch
federicocappelli May 9, 2024
c78d47e
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 10, 2024
3b1d3d4
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 13, 2024
e81c2d3
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 13, 2024
84df605
lint and BSK update, VPN env aligned with subscription env
federicocappelli May 14, 2024
cca282b
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 14, 2024
a9a9265
VPN env now follows the Subscription env changes
federicocappelli May 14, 2024
828f1e1
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 15, 2024
c5a1b69
lint
federicocappelli May 15, 2024
0943e0b
SubscriptionEnvironment Default moved to main app
federicocappelli May 15, 2024
5b45f8f
Platform renamed PurchasePlatform
federicocappelli May 15, 2024
740a266
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 15, 2024
b6faadc
VPNSettings environment is now aligned with subscription environment
federicocappelli May 15, 2024
d5e6f54
BSK updated
federicocappelli May 15, 2024
9ab1c26
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 16, 2024
e02eb69
lint and unit tests fixed
federicocappelli May 16, 2024
5d7e14f
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 16, 2024
15ce1f6
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 16, 2024
605bfcf
BSK update and renaming
federicocappelli May 16, 2024
ea24db9
various improvements suggested in the PR
federicocappelli May 16, 2024
39e91bd
lint
federicocappelli May 16, 2024
baa806b
BSK updated
federicocappelli May 16, 2024
c7d46ac
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 17, 2024
b7fdb06
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 17, 2024
e33bdb3
BSK update
federicocappelli May 17, 2024
f91ffc4
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 20, 2024
0104011
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 20, 2024
8e5719f
lint
federicocappelli May 20, 2024
71577f9
DBP and VPN environments aligned with Subscription, related debug men…
federicocappelli May 20, 2024
393db02
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 21, 2024
d468952
align removed from debug menu
federicocappelli May 21, 2024
c2784b2
lint and DI
federicocappelli May 21, 2024
ead89b6
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 21, 2024
9d33fed
net ext crash fixed and vpn+subscription environments aligned
federicocappelli May 21, 2024
ca1eb39
lint
federicocappelli May 21, 2024
5d6842c
merge from main
federicocappelli May 22, 2024
438c2cd
Merge branch 'main' into fcappelli/subscription_refactoring_2
federicocappelli May 22, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
194 changes: 167 additions & 27 deletions DuckDuckGo.xcodeproj/project.pbxproj

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,8 @@
"kind" : "remoteSourceControl",
"location" : "https://github.com/duckduckgo/BrowserServicesKit",
"state" : {
"revision" : "a49bbac8aa58033981a5a946d220886366dd471b",
"version" : "145.3.3"
"branch" : "fcappelli/subscription_refactoring_2",
"revision" : "874ae4269db821797742655e134e72199c2813c8"
}
},
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -154,6 +154,9 @@
<Test
Identifier = "CoreDataEncryptionTests/testSavingIncorrectValueTypes()">
</Test>
<Test
Identifier = "DownloadsIntegrationTests/testWhenDownloadIsStartedInNewTab_tabIsClosed()">
</Test>
<Test
Identifier = "EncryptionKeyStoreTests">
</Test>
Expand Down
138 changes: 66 additions & 72 deletions DuckDuckGo/Application/AppDelegate.swift
Original file line number Diff line number Diff line change
Expand Up @@ -34,12 +34,12 @@ import ServiceManagement
import SyncDataProviders
import UserNotifications
import Lottie

import NetworkProtection
import Subscription
import NetworkProtectionIPC
import DataBrokerProtection

@MainActor
// @MainActor
final class AppDelegate: NSObject, NSApplicationDelegate {

#if DEBUG
Expand Down Expand Up @@ -86,20 +86,15 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
let bookmarksManager = LocalBookmarkManager.shared
var privacyDashboardWindow: NSWindow?

// Needs to be lazy as indirectly depends on AppDelegate
private lazy var networkProtectionSubscriptionEventHandler: NetworkProtectionSubscriptionEventHandler = {

let ipcClient = TunnelControllerIPCClient()
let tunnelController = NetworkProtectionIPCTunnelController(ipcClient: ipcClient)
let vpnUninstaller = VPNUninstaller(ipcClient: ipcClient)

return NetworkProtectionSubscriptionEventHandler(
tunnelController: tunnelController,
vpnUninstaller: vpnUninstaller)
}()
private var accountManager: AccountManaging {
subscriptionManager.accountManager
}
public let subscriptionManager: SubscriptionManaging
public let vpnSettings = VPNSettings(defaults: .netP)

private var networkProtectionSubscriptionEventHandler: NetworkProtectionSubscriptionEventHandler?
#if DBP
private let dataBrokerProtectionSubscriptionEventHandler = DataBrokerProtectionSubscriptionEventHandler()
private var dataBrokerProtectionSubscriptionEventHandler: DataBrokerProtectionSubscriptionEventHandler?
#endif

private var didFinishLaunching = false
Expand Down Expand Up @@ -188,19 +183,14 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
privacyConfigManager: AppPrivacyFeatures.shared.contentBlocking.privacyConfigurationManager
)

#if APPSTORE || !STRIPE
SubscriptionPurchaseEnvironment.current = .appStore
#else
SubscriptionPurchaseEnvironment.current = .stripe
#endif
}
// Configure Subscription
subscriptionManager = SubscriptionManager()

static func configurePixelKit() {
#if DEBUG
Self.setUpPixelKit(dryRun: true)
#else
Self.setUpPixelKit(dryRun: false)
#endif
// Update VPN environment and match the Subscription environment
vpnSettings.alignTo(subscriptionEnvironment: subscriptionManager.currentEnvironment)

// Update DBP environment and match the Subscription environment
DataBrokerProtectionSettings().alignTo(subscriptionEnvironment: subscriptionManager.currentEnvironment)
}

func applicationWillFinishLaunching(_ notification: Notification) {
Expand All @@ -217,6 +207,18 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
#endif

appIconChanger = AppIconChanger(internalUserDecider: internalUserDecider)

// Configure Event handlers
let ipcClient = TunnelControllerIPCClient()
let tunnelController = NetworkProtectionIPCTunnelController(ipcClient: ipcClient)
let vpnUninstaller = VPNUninstaller(ipcClient: ipcClient)

networkProtectionSubscriptionEventHandler = NetworkProtectionSubscriptionEventHandler(subscriptionManager: subscriptionManager,
tunnelController: tunnelController,
vpnUninstaller: vpnUninstaller)
#if DBP
dataBrokerProtectionSubscriptionEventHandler = DataBrokerProtectionSubscriptionEventHandler(subscriptionManager: subscriptionManager)
#endif
}

// swiftlint:disable:next function_body_length
Expand Down Expand Up @@ -264,19 +266,7 @@ final class AppDelegate: NSObject, NSApplicationDelegate {

startupSync()

let defaultEnvironment = SubscriptionPurchaseEnvironment.ServiceEnvironment.default

let currentEnvironment = UserDefaultsWrapper(key: .subscriptionEnvironment,
defaultValue: defaultEnvironment).wrappedValue
SubscriptionPurchaseEnvironment.currentServiceEnvironment = currentEnvironment

Task {
let accountManager = AccountManager(subscriptionAppGroup: Bundle.main.appGroup(bundle: .subs))
if let token = accountManager.accessToken {
_ = await SubscriptionService.getSubscription(accessToken: token, cachePolicy: .reloadIgnoringLocalCacheData)
_ = await accountManager.fetchEntitlements(cachePolicy: .reloadIgnoringLocalCacheData)
}
}
subscriptionManager.loadInitialData()

if [.normal, .uiTests].contains(NSApp.runType) {
stateRestorationManager.applicationDidFinishLaunching()
Expand Down Expand Up @@ -314,13 +304,13 @@ final class AppDelegate: NSObject, NSApplicationDelegate {

UserDefaultsWrapper<Any>.clearRemovedKeys()

networkProtectionSubscriptionEventHandler.registerForSubscriptionAccountManagerEvents()
networkProtectionSubscriptionEventHandler?.registerForSubscriptionAccountManagerEvents()

NetworkProtectionAppEvents().applicationDidFinishLaunching()
NetworkProtectionAppEvents(featureVisibility: DefaultNetworkProtectionVisibility(subscriptionManager: subscriptionManager)).applicationDidFinishLaunching()
UNUserNotificationCenter.current().delegate = self

#if DBP
dataBrokerProtectionSubscriptionEventHandler.registerForSubscriptionAccountManagerEvents()
dataBrokerProtectionSubscriptionEventHandler?.registerForSubscriptionAccountManagerEvents()
#endif

#if DBP
Expand All @@ -336,15 +326,18 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
syncService?.initializeIfNeeded()
syncService?.scheduler.notifyAppLifecycleEvent()

NetworkProtectionAppEvents().applicationDidBecomeActive()

NetworkProtectionAppEvents(featureVisibility: DefaultNetworkProtectionVisibility(subscriptionManager: subscriptionManager)).applicationDidBecomeActive()
#if DBP
DataBrokerProtectionAppEvents().applicationDidBecomeActive()
#endif

AppPrivacyFeatures.shared.contentBlocking.privacyConfigurationManager.toggleProtectionsCounter.sendEventsIfNeeded()

updateSubscriptionStatus()
subscriptionManager.updateSubscriptionStatus { isActive in
if isActive {
PixelKit.fire(PrivacyProPixel.privacyProSubscriptionActive, frequency: .daily)
}
}
}

func applicationShouldTerminate(_ sender: NSApplication) -> NSApplication.TerminateReply {
Expand Down Expand Up @@ -386,9 +379,14 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
urlEventHandler.handleFiles(files)
}

private func applyPreferredTheme() {
let appearancePreferences = AppearancePreferences()
appearancePreferences.updateUserInterfaceStyle()
// MARK: - PixelKit

static func configurePixelKit() {
#if DEBUG
Self.setUpPixelKit(dryRun: true)
#else
Self.setUpPixelKit(dryRun: false)
#endif
}

private static func setUpPixelKit(dryRun: Bool) {
Expand All @@ -415,6 +413,13 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
}
}

// MARK: - Theme

private func applyPreferredTheme() {
let appearancePreferences = AppearancePreferences()
appearancePreferences.updateUserInterfaceStyle()
}

// MARK: - Sync

private func startupSync() {
Expand Down Expand Up @@ -490,7 +495,9 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
switch response {
case .alertSecondButtonReturn:
alert.window.sheetParent?.endSheet(alert.window)
WindowControllersManager.shared.showPreferencesTab(withSelectedPane: .sync)
DispatchQueue.main.async {
WindowControllersManager.shared.showPreferencesTab(withSelectedPane: .sync)
}
default:
break
}
Expand Down Expand Up @@ -567,30 +574,15 @@ final class AppDelegate: NSObject, NSApplicationDelegate {
}

private func setUpAutoClearHandler() {
autoClearHandler = AutoClearHandler(preferences: .shared,
fireViewModel: FireCoordinator.fireViewModel,
stateRestorationManager: stateRestorationManager)
autoClearHandler.handleAppLaunch()
autoClearHandler.onAutoClearCompleted = {
NSApplication.shared.reply(toApplicationShouldTerminate: true)
}
}

}

func updateSubscriptionStatus() {
Task {
let accountManager = AccountManager(subscriptionAppGroup: Bundle.main.appGroup(bundle: .subs))

guard let token = accountManager.accessToken else { return }

if case .success(let subscription) = await SubscriptionService.getSubscription(accessToken: token, cachePolicy: .reloadIgnoringLocalCacheData) {
if subscription.isActive {
PixelKit.fire(PrivacyProPixel.privacyProSubscriptionActive, frequency: .daily)
DispatchQueue.main.async {
self.autoClearHandler = AutoClearHandler(preferences: .shared,
fireViewModel: FireCoordinator.fireViewModel,
stateRestorationManager: self.stateRestorationManager)
self.autoClearHandler.handleAppLaunch()
self.autoClearHandler.onAutoClearCompleted = {
NSApplication.shared.reply(toApplicationShouldTerminate: true)
}
}

_ = await accountManager.fetchEntitlements(cachePolicy: .reloadIgnoringLocalCacheData)
}
}

Expand All @@ -609,7 +601,9 @@ extension AppDelegate: UNUserNotificationCenterDelegate {

#if DBP
if response.notification.request.identifier == DataBrokerProtectionWaitlist.notificationIdentifier {
DataBrokerProtectionAppEvents().handleWaitlistInvitedNotification(source: .localPush)
DispatchQueue.main.async {
DataBrokerProtectionAppEvents().handleWaitlistInvitedNotification(source: .localPush)
}
}
#endif
}
Expand Down
12 changes: 7 additions & 5 deletions DuckDuckGo/Application/Application.swift
Original file line number Diff line number Diff line change
Expand Up @@ -23,16 +23,18 @@ import Foundation
final class Application: NSApplication {

private let copyHandler = CopyHandler()
private var _delegate: AppDelegate!
// private var _delegate: AppDelegate!
public static var appDelegate: AppDelegate!

override init() {
super.init()

_delegate = AppDelegate()
self.delegate = _delegate
let delegate = AppDelegate()
self.delegate = delegate
Application.appDelegate = delegate

let mainMenu = MainMenu(featureFlagger: _delegate.featureFlagger,
bookmarkManager: _delegate.bookmarksManager,
let mainMenu = MainMenu(featureFlagger: delegate.featureFlagger,
bookmarkManager: delegate.bookmarksManager,
faviconManager: FaviconManager.shared,
copyHandler: copyHandler)
self.mainMenu = mainMenu
Expand Down
Loading
Loading