mirror of
https://github.com/passepartoutvpn/passepartout-apple.git
synced 2025-02-02 22:12:23 +00:00
45e33ae314
- Purge tunnel logs properly - Prepend sessions with system information (app/system version, device type)
65 lines
2.3 KiB
Swift
65 lines
2.3 KiB
Swift
//
|
|
// PassepartoutConfiguration+Logging.swift
|
|
// Passepartout
|
|
//
|
|
// Created by Davide De Rosa on 10/4/24.
|
|
// Copyright (c) 2025 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 PassepartoutKit
|
|
|
|
extension PassepartoutConfiguration {
|
|
public func configureLogging(to url: URL, parameters: Constants.Log, logsPrivateData: Bool) {
|
|
pp_log(.app, .debug, "Log to: \(url)")
|
|
|
|
setLocalLogger(
|
|
url: url,
|
|
options: parameters.options,
|
|
mapper: parameters.formatter.formattedLine
|
|
)
|
|
|
|
if logsPrivateData {
|
|
logsAddresses = true
|
|
logsModules = true
|
|
}
|
|
|
|
appendLog(parameters.options.maxLevel, message: "")
|
|
appendLog(parameters.options.maxLevel, message: "--- BEGIN ---")
|
|
appendLog(parameters.options.maxLevel, message: "")
|
|
|
|
let systemInfo = SystemInformation()
|
|
appendLog(parameters.options.maxLevel, message: "App: \(BundleConfiguration.mainVersionString)")
|
|
appendLog(parameters.options.maxLevel, message: "OS: \(systemInfo.osString)")
|
|
if let deviceString = systemInfo.deviceString {
|
|
appendLog(parameters.options.maxLevel, message: "Device: \(deviceString)")
|
|
}
|
|
appendLog(parameters.options.maxLevel, message: "")
|
|
}
|
|
|
|
public func currentLog(parameters: Constants.Log) -> [String] {
|
|
currentLogLines(
|
|
sinceLast: parameters.sinceLast,
|
|
maxLevel: parameters.options.maxLevel
|
|
)
|
|
.map(parameters.formatter.formattedLine)
|
|
}
|
|
}
|