DeviceLogger.swift 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. // Copyright 2021 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. import Foundation
  15. import os
  16. /// Enum of debug messages.
  17. // TODO: Create list of all possible messages with code - according to format.
  18. enum LoggerMessageCode {
  19. case modelDownloaded
  20. case downloadedModelMovedToURL
  21. case analyticsEventEncodeError
  22. case telemetryInitError
  23. }
  24. /// On-device logger.
  25. class DeviceLogger {
  26. /// Log event on device.
  27. static func logEvent(level: OSLogType, category: OSLog, message: StaticString,
  28. messageCode: LoggerMessageCode) {
  29. // TODO: Replace with GULLogBasic.
  30. os_log(message, log: category, type: level)
  31. }
  32. }
  33. /// Extension to categorize on-device logging.
  34. extension OSLog {
  35. private static let subsystem: String = {
  36. let bundleID = Bundle.main.bundleIdentifier ?? ""
  37. return "com.google.firebaseml.\(bundleID)"
  38. }()
  39. /// List of logging categories.
  40. static let modelDownload = OSLog(subsystem: subsystem, category: "model-download")
  41. static let analytics = OSLog(subsystem: subsystem, category: "analytics")
  42. }