logger.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  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 Logger type enumeration
  21. */
  22. enum class LoggerType {
  23. HTTP, // HTTP access logs
  24. INTERNAL // Internal operation logs
  25. };
  26. /**
  27. * @brief Simple logger with file and console output support
  28. *
  29. * Designed to be systemd-friendly with structured logging format
  30. */
  31. class Logger {
  32. public:
  33. /**
  34. * @brief Get the singleton logger instance
  35. */
  36. static Logger& getInstance();
  37. /**
  38. * @brief Initialize the logger
  39. *
  40. * @param enableFileLogging Enable logging to file
  41. * @param logFilePath Path to log file (if file logging enabled)
  42. * @param minLevel Minimum log level to output
  43. */
  44. void initialize(bool enableFileLogging = false,
  45. const std::string& logFilePath = "",
  46. LogLevel minLevel = LogLevel::INFO);
  47. /**
  48. * @brief Log a message
  49. *
  50. * @param level Log level
  51. * @param message Message to log
  52. * @param type Logger type (HTTP or INTERNAL)
  53. */
  54. void log(LogLevel level, const std::string& message, LoggerType type = LoggerType::INTERNAL);
  55. /**
  56. * @brief Log debug message
  57. */
  58. void debug(const std::string& message, LoggerType type = LoggerType::INTERNAL) { log(LogLevel::DEBUG, message, type); }
  59. /**
  60. * @brief Log info message
  61. */
  62. void info(const std::string& message, LoggerType type = LoggerType::INTERNAL) { log(LogLevel::INFO, message, type); }
  63. /**
  64. * @brief Log warning message
  65. */
  66. void warning(const std::string& message, LoggerType type = LoggerType::INTERNAL) { log(LogLevel::WARNING, message, type); }
  67. /**
  68. * @brief Log error message
  69. */
  70. void error(const std::string& message, LoggerType type = LoggerType::INTERNAL) { log(LogLevel::ERROR, message, type); }
  71. /**
  72. * @brief Set minimum log level for specific logger type
  73. */
  74. void setLogLevel(LoggerType type, LogLevel level);
  75. /**
  76. * @brief Get minimum log level for specific logger type
  77. */
  78. LogLevel getLogLevel(LoggerType type) const;
  79. /**
  80. * @brief Check if file logging is enabled
  81. */
  82. bool isFileLoggingEnabled() const { return m_fileLoggingEnabled; }
  83. /**
  84. * @brief Get current log file path
  85. */
  86. std::string getLogFilePath() const { return m_logFilePath; }
  87. /**
  88. * @brief Close log file
  89. */
  90. void close();
  91. private:
  92. Logger() = default;
  93. ~Logger();
  94. // Prevent copying
  95. Logger(const Logger&) = delete;
  96. Logger& operator=(const Logger&) = delete;
  97. std::string getCurrentTimestamp();
  98. std::string levelToString(LogLevel level);
  99. std::string levelToSystemdPriority(LogLevel level);
  100. std::string typeToString(LoggerType type);
  101. bool m_fileLoggingEnabled = false;
  102. std::string m_logFilePath;
  103. LogLevel m_httpMinLevel = LogLevel::INFO;
  104. LogLevel m_internalMinLevel = LogLevel::INFO;
  105. std::ofstream m_logFile;
  106. mutable std::mutex m_mutex;
  107. };
  108. // Convenience macros for logging
  109. #define LOG_DEBUG(msg) Logger::getInstance().debug(msg, LoggerType::INTERNAL)
  110. #define LOG_INFO(msg) Logger::getInstance().info(msg, LoggerType::INTERNAL)
  111. #define LOG_WARNING(msg) Logger::getInstance().warning(msg, LoggerType::INTERNAL)
  112. #define LOG_ERROR(msg) Logger::getInstance().error(msg, LoggerType::INTERNAL)
  113. // HTTP-specific logging macros
  114. #define HTTP_DEBUG(msg) Logger::getInstance().debug(msg, LoggerType::HTTP)
  115. #define HTTP_INFO(msg) Logger::getInstance().info(msg, LoggerType::HTTP)
  116. #define HTTP_WARNING(msg) Logger::getInstance().warning(msg, LoggerType::HTTP)
  117. #define HTTP_ERROR(msg) Logger::getInstance().error(msg, LoggerType::HTTP)
  118. #endif // LOGGER_H