mirror of
https://github.com/passepartoutvpn/passepartout-apple.git
synced 2024-12-24 10:22:42 +00:00
da87ca698a
Initial integration of providers via API: - Generic views and modifiers for provider/server selection - Add in OpenVPNView - Prepare in WireGuardView Also: - Introduce ProfileProcessor, move IAP processing there - Move .asModuleView() to ModuleViewModifier for proper animation - Use .themeModal() rather than .sheet()
94 lines
2.6 KiB
Swift
94 lines
2.6 KiB
Swift
//
|
|
// Shared.swift
|
|
// Passepartout
|
|
//
|
|
// Created by Davide De Rosa on 8/11/24.
|
|
// Copyright (c) 2024 Davide De Rosa. All rights reserved.
|
|
//
|
|
// https://github.com/passepartoutvpn
|
|
//
|
|
// This file is part of Passepartout.
|
|
//
|
|
// Passepartout is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Passepartout is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Passepartout. If not, see <http://www.gnu.org/licenses/>.
|
|
//
|
|
|
|
import Foundation
|
|
import PassepartoutAPIBundle
|
|
import PassepartoutKit
|
|
import PassepartoutWireGuardGo
|
|
|
|
extension LoggerDestination {
|
|
public static let app = Self(category: "app")
|
|
}
|
|
|
|
extension WireGuard.Configuration.Builder {
|
|
public static var `default`: Self {
|
|
.init(keyGenerator: StandardWireGuardKeyGenerator())
|
|
}
|
|
}
|
|
|
|
// TODO: #716, move to Environment
|
|
extension Constants {
|
|
public static let shared = Bundle.module.unsafeDecode(Constants.self, filename: "Constants")
|
|
}
|
|
|
|
// TODO: #716, move to Environment?
|
|
// BundleConfiguration.shared
|
|
|
|
// TODO: #716, move to Environment
|
|
extension UserDefaults {
|
|
public static let appGroup: UserDefaults = {
|
|
let appGroup = BundleConfiguration.mainString(for: .groupId)
|
|
guard let defaults = UserDefaults(suiteName: appGroup) else {
|
|
fatalError("No access to App Group: \(appGroup)")
|
|
}
|
|
return defaults
|
|
}()
|
|
}
|
|
|
|
// TODO: #716, move to Environment
|
|
extension API {
|
|
public static var shared: [APIMapper] {
|
|
#if DEBUG
|
|
[API.bundled]
|
|
#else
|
|
[API.remoteThenBundled]
|
|
#endif
|
|
}
|
|
|
|
private static let remoteThenBundled: [APIMapper] = [
|
|
Self.remote,
|
|
Self.bundled
|
|
]
|
|
|
|
public static let bundled: APIMapper = {
|
|
guard let url = API.bundledURL else {
|
|
fatalError("Unable to find bundled API")
|
|
}
|
|
let ws = API.V5.DefaultWebServices(
|
|
url,
|
|
timeout: Constants.shared.api.timeoutInterval
|
|
)
|
|
return API.V5.Mapper(webServices: ws)
|
|
}()
|
|
|
|
public static let remote: APIMapper = {
|
|
let ws = API.V5.DefaultWebServices(
|
|
Constants.shared.websites.api,
|
|
timeout: Constants.shared.api.timeoutInterval
|
|
)
|
|
return API.V5.Mapper(webServices: ws)
|
|
}()
|
|
}
|