logger.h 4.1 KB

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