mirror of
https://github.com/passepartoutvpn/wireguard-apple.git
synced 2025-01-18 22:39:08 +00:00
154774ada2
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
62 lines
2.1 KiB
Swift
62 lines
2.1 KiB
Swift
// SPDX-License-Identifier: MIT
|
|
// Copyright © 2018 WireGuard LLC. All Rights Reserved.
|
|
|
|
import Foundation
|
|
import os.log
|
|
|
|
public class Logger {
|
|
static var global: Logger?
|
|
|
|
var log: OpaquePointer?
|
|
var tag: String
|
|
|
|
init(withFilePath filePath: String, withTag tag: String) {
|
|
self.tag = tag
|
|
self.log = open_log(filePath)
|
|
if self.log == nil {
|
|
os_log("Cannot open log file for writing. Log will not be saved to file.", log: OSLog.default, type: .error)
|
|
}
|
|
}
|
|
|
|
func log(message: String) {
|
|
guard let log = log else { return }
|
|
write_msg_to_log(log, String(format: "[%@] %@", tag, message.trimmingCharacters(in: .newlines)))
|
|
}
|
|
|
|
func writeLog(mergedWith otherLogFile: String, to targetFile: String) -> Bool {
|
|
guard let log = log else { return false }
|
|
guard let other = open_log(otherLogFile) else { return false }
|
|
let ret = write_logs_to_file(targetFile, log, other)
|
|
close_log(other)
|
|
return ret == 0
|
|
}
|
|
|
|
static func configureGlobal(withFilePath filePath: String?, withTag tag: String) {
|
|
if Logger.global != nil {
|
|
return
|
|
}
|
|
guard let filePath = filePath else {
|
|
os_log("Unable to determine log destination path. Log will not be saved to file.", log: OSLog.default, type: .error)
|
|
return
|
|
}
|
|
Logger.global = Logger(withFilePath: filePath, withTag: tag)
|
|
var appVersion = Bundle.main.infoDictionary?["CFBundleShortVersionString"] as? String ?? "Unknown version"
|
|
if let appBuild = Bundle.main.infoDictionary?["CFBundleVersion"] as? String {
|
|
appVersion += " (\(appBuild))"
|
|
}
|
|
let goBackendVersion = WIREGUARD_GO_VERSION
|
|
Logger.global?.log(message: "App version: \(appVersion); Go backend version: \(goBackendVersion)")
|
|
|
|
}
|
|
}
|
|
|
|
func wg_log(_ type: OSLogType, staticMessage msg: StaticString) {
|
|
os_log(msg, log: OSLog.default, type: type)
|
|
Logger.global?.log(message: "\(msg)")
|
|
}
|
|
|
|
func wg_log(_ type: OSLogType, message msg: String) {
|
|
os_log("%{public}s", log: OSLog.default, type: type, msg)
|
|
Logger.global?.log(message: msg)
|
|
}
|