logger.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. #ifndef LOGGER_H
  2. #define LOGGER_H
  3. #include <string>
  4. #include <fstream>
  5. #include <mutex>
  6. #include <memory>
  7. #include <sstream>
  8. #include <chrono>
  9. #include <iomanip>
  10. /**
  11. * @brief Log level enumeration
  12. */
  13. enum class LogLevel {
  14. DEBUG,
  15. INFO,
  16. WARNING,
  17. ERROR
  18. };
  19. /**
  20. * @brief Simple logger with file and console output support
  21. *
  22. * Designed to be systemd-friendly with structured logging format
  23. */
  24. class Logger {
  25. public:
  26. /**
  27. * @brief Get the singleton logger instance
  28. */
  29. static Logger& getInstance();
  30. /**
  31. * @brief Initialize the logger
  32. *
  33. * @param enableFileLogging Enable logging to file
  34. * @param logFilePath Path to log file (if file logging enabled)
  35. * @param minLevel Minimum log level to output
  36. */
  37. void initialize(bool enableFileLogging = false,
  38. const std::string& logFilePath = "",
  39. LogLevel minLevel = LogLevel::INFO);
  40. /**
  41. * @brief Log a message
  42. *
  43. * @param level Log level
  44. * @param message Message to log
  45. */
  46. void log(LogLevel level, const std::string& message);
  47. /**
  48. * @brief Log debug message
  49. */
  50. void debug(const std::string& message) { log(LogLevel::DEBUG, message); }
  51. /**
  52. * @brief Log info message
  53. */
  54. void info(const std::string& message) { log(LogLevel::INFO, message); }
  55. /**
  56. * @brief Log warning message
  57. */
  58. void warning(const std::string& message) { log(LogLevel::WARNING, message); }
  59. /**
  60. * @brief Log error message
  61. */
  62. void error(const std::string& message) { log(LogLevel::ERROR, message); }
  63. /**
  64. * @brief Check if file logging is enabled
  65. */
  66. bool isFileLoggingEnabled() const { return m_fileLoggingEnabled; }
  67. /**
  68. * @brief Get current log file path
  69. */
  70. std::string getLogFilePath() const { return m_logFilePath; }
  71. /**
  72. * @brief Close log file
  73. */
  74. void close();
  75. private:
  76. Logger() = default;
  77. ~Logger();
  78. // Prevent copying
  79. Logger(const Logger&) = delete;
  80. Logger& operator=(const Logger&) = delete;
  81. std::string getCurrentTimestamp();
  82. std::string levelToString(LogLevel level);
  83. std::string levelToSystemdPriority(LogLevel level);
  84. bool m_fileLoggingEnabled = false;
  85. std::string m_logFilePath;
  86. LogLevel m_minLevel = LogLevel::INFO;
  87. std::ofstream m_logFile;
  88. mutable std::mutex m_mutex;
  89. };
  90. // Convenience macros for logging
  91. #define LOG_DEBUG(msg) Logger::getInstance().debug(msg)
  92. #define LOG_INFO(msg) Logger::getInstance().info(msg)
  93. #define LOG_WARNING(msg) Logger::getInstance().warning(msg)
  94. #define LOG_ERROR(msg) Logger::getInstance().error(msg)
  95. #endif // LOGGER_H