mirror of
https://github.com/passepartoutvpn/passepartout-apple.git
synced 2025-01-18 22:49:10 +00:00
Merge branch 'profile-trusted-networks'
This commit is contained in:
commit
b1aa5c0e5b
@ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||
|
||||
### Changed
|
||||
|
||||
- "Trusted networks" settings are now saved per profile. [#114](https://github.com/passepartoutvpn/passepartout-ios/issues/114)
|
||||
- Require explicit `--ca` and `--cipher` in .ovpn configuration file.
|
||||
|
||||
### Fixed
|
||||
|
@ -191,17 +191,26 @@ class ProductManager: NSObject {
|
||||
func reviewPurchases() {
|
||||
let service = TransientStore.shared.service
|
||||
reloadReceipt(andNotify: false)
|
||||
var shouldReinstall = false
|
||||
var anyRefund = false
|
||||
|
||||
// review features and potentially revert them if they were used (Siri is handled in AppDelegate)
|
||||
|
||||
log.debug("Checking 'Trusted networks'")
|
||||
if !isEligible(forFeature: .trustedNetworks) {
|
||||
if service.preferences.trustsMobileNetwork || !service.preferences.trustedWifis.isEmpty {
|
||||
service.preferences.trustsMobileNetwork = false
|
||||
service.preferences.trustedWifis.removeAll()
|
||||
|
||||
// reset trusted networks for ALL profiles (must load first)
|
||||
for key in service.allProfileKeys() {
|
||||
guard let profile = service.profile(withKey: key) else {
|
||||
continue
|
||||
}
|
||||
if profile.trustedNetworks.includesMobile || !profile.trustedNetworks.includedWiFis.isEmpty {
|
||||
profile.trustedNetworks.includesMobile = false
|
||||
profile.trustedNetworks.includedWiFis.removeAll()
|
||||
anyRefund = true
|
||||
}
|
||||
}
|
||||
if anyRefund {
|
||||
log.debug("\tRefunded")
|
||||
shouldReinstall = true
|
||||
}
|
||||
}
|
||||
|
||||
@ -213,7 +222,7 @@ class ProductManager: NSObject {
|
||||
service.removeProfile(ProfileKey(.host, id))
|
||||
}
|
||||
log.debug("\tRefunded")
|
||||
shouldReinstall = true
|
||||
anyRefund = true
|
||||
}
|
||||
}
|
||||
|
||||
@ -222,12 +231,11 @@ class ProductManager: NSObject {
|
||||
if !isEligible(forProvider: name) {
|
||||
service.removeProfile(ProfileKey(name))
|
||||
log.debug("\tRefunded provider: \(name)")
|
||||
shouldReinstall = true
|
||||
anyRefund = true
|
||||
}
|
||||
}
|
||||
|
||||
// no refunds
|
||||
guard shouldReinstall else {
|
||||
guard anyRefund else {
|
||||
return
|
||||
}
|
||||
|
||||
|
@ -67,7 +67,7 @@ class ServiceViewController: UIViewController, StrongTableHost {
|
||||
|
||||
var model: StrongTableModel<SectionType, RowType> = StrongTableModel()
|
||||
|
||||
private let trustedNetworks = TrustedNetworksModel()
|
||||
private let trustedNetworks = TrustedNetworksUI()
|
||||
|
||||
// MARK: UIViewController
|
||||
|
||||
@ -429,7 +429,7 @@ class ServiceViewController: UIViewController, StrongTableHost {
|
||||
|
||||
private func toggleTrustedConnectionPolicy(_ isOn: Bool, sender: ToggleTableViewCell) {
|
||||
let completionHandler: () -> Void = {
|
||||
self.service.preferences.trustPolicy = isOn ? .disconnect : .ignore
|
||||
self.uncheckedProfile.trustedNetworks.policy = isOn ? .disconnect : .ignore
|
||||
if self.vpn.isEnabled {
|
||||
self.vpn.reinstall(completionHandler: nil)
|
||||
}
|
||||
@ -782,7 +782,7 @@ extension ServiceViewController: UITableViewDataSource, UITableViewDelegate, Tog
|
||||
return ip
|
||||
}
|
||||
|
||||
private func mappedTrustedNetworksRow(_ from: TrustedNetworksModel.RowType) -> RowType {
|
||||
private func mappedTrustedNetworksRow(_ from: TrustedNetworksUI.RowType) -> RowType {
|
||||
switch from {
|
||||
case .trustsMobile:
|
||||
return .trustedMobile
|
||||
@ -933,7 +933,7 @@ extension ServiceViewController: UITableViewDataSource, UITableViewDelegate, Tog
|
||||
case .trustedMobile:
|
||||
let cell = Cells.toggle.dequeue(from: tableView, for: indexPath, tag: row.rawValue, delegate: self)
|
||||
cell.caption = L10n.Core.Service.Cells.TrustedMobile.caption
|
||||
cell.isOn = service.preferences.trustsMobileNetwork
|
||||
cell.isOn = uncheckedProfile.trustedNetworks.includesMobile
|
||||
return cell
|
||||
|
||||
case .trustedWiFi:
|
||||
@ -952,7 +952,7 @@ extension ServiceViewController: UITableViewDataSource, UITableViewDelegate, Tog
|
||||
case .trustedPolicy:
|
||||
let cell = Cells.toggle.dequeue(from: tableView, for: indexPath, tag: row.rawValue, delegate: self)
|
||||
cell.caption = L10n.Core.Service.Cells.TrustedPolicy.caption
|
||||
cell.isOn = (service.preferences.trustPolicy == .disconnect)
|
||||
cell.isOn = (uncheckedProfile.trustedNetworks.policy == .disconnect)
|
||||
return cell
|
||||
|
||||
// diagnostics
|
||||
@ -1241,7 +1241,7 @@ extension ServiceViewController: UITableViewDataSource, UITableViewDelegate, Tog
|
||||
}
|
||||
|
||||
trustedNetworks.delegate = self
|
||||
trustedNetworks.load(from: service.preferences)
|
||||
trustedNetworks.load(from: uncheckedProfile.trustedNetworks)
|
||||
model.set(trustedNetworks.rows.map { mappedTrustedNetworksRow($0) }, forSection: .trusted)
|
||||
}
|
||||
|
||||
@ -1313,21 +1313,21 @@ extension ServiceViewController: UITextFieldDelegate {
|
||||
|
||||
// MARK: -
|
||||
|
||||
extension ServiceViewController: TrustedNetworksModelDelegate {
|
||||
func trustedNetworksCouldDisconnect(_: TrustedNetworksModel) -> Bool {
|
||||
return (service.preferences.trustPolicy == .disconnect) && (vpn.status != .disconnected)
|
||||
extension ServiceViewController: TrustedNetworksUIDelegate {
|
||||
func trustedNetworksCouldDisconnect(_: TrustedNetworksUI) -> Bool {
|
||||
return (uncheckedProfile.trustedNetworks.policy == .disconnect) && (vpn.status != .disconnected)
|
||||
}
|
||||
|
||||
func trustedNetworksShouldConfirmDisconnection(_: TrustedNetworksModel, triggeredAt rowIndex: Int, completionHandler: @escaping () -> Void) {
|
||||
func trustedNetworksShouldConfirmDisconnection(_: TrustedNetworksUI, triggeredAt rowIndex: Int, completionHandler: @escaping () -> Void) {
|
||||
confirmPotentialTrustedDisconnection(at: rowIndex, completionHandler: completionHandler)
|
||||
}
|
||||
|
||||
func trustedNetworks(_: TrustedNetworksModel, shouldInsertWifiAt rowIndex: Int) {
|
||||
func trustedNetworks(_: TrustedNetworksUI, shouldInsertWifiAt rowIndex: Int) {
|
||||
model.set(trustedNetworks.rows.map { mappedTrustedNetworksRow($0) }, forSection: .trusted)
|
||||
tableView.insertRows(at: [IndexPath(row: rowIndex, section: trustedSectionIndex)], with: .bottom)
|
||||
}
|
||||
|
||||
func trustedNetworks(_: TrustedNetworksModel, shouldReloadWifiAt rowIndex: Int, isTrusted: Bool) {
|
||||
func trustedNetworks(_: TrustedNetworksUI, shouldReloadWifiAt rowIndex: Int, isTrusted: Bool) {
|
||||
let genericCell = tableView.cellForRow(at: IndexPath(row: rowIndex, section: trustedSectionIndex))
|
||||
guard let cell = genericCell as? ToggleTableViewCell else {
|
||||
fatalError("Not a trusted Wi-Fi cell (\(type(of: genericCell)) != ToggleTableViewCell)")
|
||||
@ -1338,14 +1338,14 @@ extension ServiceViewController: TrustedNetworksModelDelegate {
|
||||
cell.setOn(isTrusted, animated: true)
|
||||
}
|
||||
|
||||
func trustedNetworks(_: TrustedNetworksModel, shouldDeleteWifiAt rowIndex: Int) {
|
||||
func trustedNetworks(_: TrustedNetworksUI, shouldDeleteWifiAt rowIndex: Int) {
|
||||
model.set(trustedNetworks.rows.map { mappedTrustedNetworksRow($0) }, forSection: .trusted)
|
||||
tableView.deleteRows(at: [IndexPath(row: rowIndex, section: trustedSectionIndex)], with: .top)
|
||||
}
|
||||
|
||||
func trustedNetworksShouldReinstall(_: TrustedNetworksModel) {
|
||||
service.preferences.trustsMobileNetwork = trustedNetworks.trustsMobileNetwork
|
||||
service.preferences.trustedWifis = trustedNetworks.trustedWifis
|
||||
func trustedNetworksShouldReinstall(_: TrustedNetworksUI) {
|
||||
uncheckedProfile.trustedNetworks.includesMobile = trustedNetworks.trustsMobileNetwork
|
||||
uncheckedProfile.trustedNetworks.includedWiFis = trustedNetworks.trustedWifis
|
||||
if vpn.isEnabled {
|
||||
vpn.reinstall(completionHandler: nil)
|
||||
}
|
||||
|
@ -92,6 +92,7 @@
|
||||
0EAAD71920E6669A0088754A /* GroupConstants.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0EDE8DED20C93E4C004C739C /* GroupConstants.swift */; };
|
||||
0EB60FDA2111136E00AD27F3 /* UITextView+Search.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0EB60FD92111136E00AD27F3 /* UITextView+Search.swift */; };
|
||||
0EB67D6B2184581E00BA6200 /* ImportedHostsViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0EB67D6A2184581E00BA6200 /* ImportedHostsViewController.swift */; };
|
||||
0EB9EB7323867E7F009C0A1C /* TrustedNetworksUI.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0EB9EB7223867E7F009C0A1C /* TrustedNetworksUI.swift */; };
|
||||
0EBE3A79213C4E5500BFA2F5 /* OrganizerViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0EBE3A78213C4E5400BFA2F5 /* OrganizerViewController.swift */; };
|
||||
0ECC60DE2256B68A0020BEAC /* SwiftGen+Assets.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0ECC60DD2256B6890020BEAC /* SwiftGen+Assets.swift */; };
|
||||
0ECEB10A224FECEA00E9E551 /* DataUnit.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0ECEB109224FECEA00E9E551 /* DataUnit.swift */; };
|
||||
@ -259,6 +260,7 @@
|
||||
0E9CDB6623604AD5006733B4 /* ServerNetworkViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ServerNetworkViewController.swift; sourceTree = "<group>"; };
|
||||
0EB60FD92111136E00AD27F3 /* UITextView+Search.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UITextView+Search.swift"; sourceTree = "<group>"; };
|
||||
0EB67D6A2184581E00BA6200 /* ImportedHostsViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ImportedHostsViewController.swift; sourceTree = "<group>"; };
|
||||
0EB9EB7223867E7F009C0A1C /* TrustedNetworksUI.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TrustedNetworksUI.swift; sourceTree = "<group>"; };
|
||||
0EBBE8F42182361700106008 /* ConnectionService+Migration.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "ConnectionService+Migration.swift"; sourceTree = "<group>"; };
|
||||
0EBE2FD02360F88C00F0D5AB /* zh-Hans */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = "zh-Hans"; path = "zh-Hans.lproj/InfoPlist.strings"; sourceTree = "<group>"; };
|
||||
0EBE2FD12360F88E00F0D5AB /* fr */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = fr; path = fr.lproj/InfoPlist.strings; sourceTree = "<group>"; };
|
||||
@ -496,6 +498,15 @@
|
||||
path = Organizer;
|
||||
sourceTree = "<group>";
|
||||
};
|
||||
0EB9EB7123867E7F009C0A1C /* UI */ = {
|
||||
isa = PBXGroup;
|
||||
children = (
|
||||
0EB9EB7223867E7F009C0A1C /* TrustedNetworksUI.swift */,
|
||||
);
|
||||
name = UI;
|
||||
path = Submodules/Core/Passepartout/Sources/UI;
|
||||
sourceTree = SOURCE_ROOT;
|
||||
};
|
||||
0EBE3AA2213DC1B000BFA2F5 /* Profiles */ = {
|
||||
isa = PBXGroup;
|
||||
children = (
|
||||
@ -588,10 +599,11 @@
|
||||
0EDE8DF020C93EBB004C739C /* Sources */ = {
|
||||
isa = PBXGroup;
|
||||
children = (
|
||||
0E50E7C422330E5100D5F76C /* Intents */,
|
||||
0ED31C0E20CF09890027975F /* Model */,
|
||||
0ED31C1B20CF0ACE0027975F /* Services */,
|
||||
0EB9EB7123867E7F009C0A1C /* UI */,
|
||||
0E4FD7D920D3E43F002221FF /* VPN */,
|
||||
0E50E7C422330E5100D5F76C /* Intents */,
|
||||
0E39BCF2214DA9310035E9DE /* AppConstants.swift */,
|
||||
0E6BE13920CFB76800A6DD36 /* ApplicationError.swift */,
|
||||
0EDE8DED20C93E4C004C739C /* GroupConstants.swift */,
|
||||
@ -984,6 +996,7 @@
|
||||
0EFB901822764689006405E4 /* ProfileNetworkSettings.swift in Sources */,
|
||||
0E3152C0223FA03D00F61841 /* Utils.swift in Sources */,
|
||||
0E3152CB223FA04D00F61841 /* Pool.swift in Sources */,
|
||||
0EB9EB7323867E7F009C0A1C /* TrustedNetworksUI.swift in Sources */,
|
||||
0E3CAFC0229AAE770008E5C8 /* Intents.intentdefinition in Sources */,
|
||||
0E3152C7223FA04800F61841 /* VPNStatus.swift in Sources */,
|
||||
);
|
||||
|
@ -1 +1 @@
|
||||
Subproject commit 637f4002f5fa1e6bc29df34ff6225facc6711c63
|
||||
Subproject commit 2b6edafb0cd34c331aa0a7040571ef82a552ad97
|
Loading…
Reference in New Issue
Block a user