168 lines
5.3 KiB
C++
168 lines
5.3 KiB
C++
/**
|
|
* @file Logger.hpp
|
|
* @brief Logging system for the DPM utility
|
|
*
|
|
* Defines the Logger class which provides a centralized logging facility
|
|
* for the DPM utility. Supports multiple log levels, console output, and
|
|
* optional file logging with timestamps.
|
|
*
|
|
* @copyright Copyright (c) 2025 SILO GROUP LLC
|
|
* @author Chris Punches <chris.punches@silogroup.org>
|
|
*
|
|
* Part of the Dark Horse Linux Package Manager (DPM)
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*
|
|
* For bug reports or contributions, please contact the dhlp-contributors
|
|
* mailing list at: https://lists.darkhorselinux.org/mailman/listinfo/dhlp-contributors
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <fstream>
|
|
#include <iostream>
|
|
#include <ctime>
|
|
#include <string>
|
|
#include <filesystem>
|
|
#include <stdexcept>
|
|
#include <cstdlib>
|
|
|
|
#include "LoggingLevels.hpp"
|
|
#include "DPMDefaults.hpp"
|
|
|
|
/**
|
|
* @class Logger
|
|
* @brief Provides logging capabilities for the DPM system
|
|
*
|
|
* Implements a configurable logging system that can write messages to
|
|
* both console and file outputs. Supports different log levels to
|
|
* control verbosity and includes automatic timestamp generation for
|
|
* log file entries.
|
|
*/
|
|
class Logger {
|
|
public:
|
|
/**
|
|
* @brief Constructor
|
|
*
|
|
* Initializes a new Logger instance with default settings from DPMDefaults.
|
|
*/
|
|
Logger();
|
|
|
|
/**
|
|
* @brief Destructor
|
|
*/
|
|
~Logger();
|
|
|
|
/**
|
|
* @brief Logs a message with the specified log level
|
|
*
|
|
* Writes a log message to the console and optionally to a log file
|
|
* if the message level is less than or equal to the configured log level.
|
|
* Messages with levels FATAL, ERROR, or WARN are written to stderr,
|
|
* while others go to stdout. File logging includes timestamps.
|
|
*
|
|
* @param log_level The severity level of the message
|
|
* @param message The message to log
|
|
*/
|
|
void log(LoggingLevels log_level, const std::string& message);
|
|
|
|
/**
|
|
* @brief Logs a message to console only
|
|
*
|
|
* Writes a log message only to the console, skipping any file logging.
|
|
* Messages with levels FATAL, ERROR, or WARN are written to stderr,
|
|
* while others go to stdout.
|
|
*
|
|
* @param level The severity level of the message
|
|
* @param message The message to log
|
|
*/
|
|
void log_console(LoggingLevels level, const std::string& message);
|
|
|
|
/**
|
|
* @brief Sets the log file path
|
|
*
|
|
* Changes the file path where log messages are written when file
|
|
* logging is enabled. Ensures the log directory exists and is writable.
|
|
*
|
|
* @param log_file The path to the log file
|
|
*/
|
|
void setLogFile(const std::string& log_file);
|
|
|
|
/**
|
|
* @brief Enables or disables file logging
|
|
*
|
|
* Controls whether log messages are written to a file in addition
|
|
* to console output. If enabled, validates that the log file is writable.
|
|
*
|
|
* @param write_to_log true to enable file logging, false to disable
|
|
*/
|
|
void setWriteToLog(bool write_to_log);
|
|
|
|
/**
|
|
* @brief Sets the log level threshold
|
|
*
|
|
* Sets the maximum log level that will be processed. Messages with
|
|
* a level higher than this threshold will be ignored.
|
|
*
|
|
* @param log_level The new log level threshold
|
|
*/
|
|
void setLogLevel(LoggingLevels log_level);
|
|
|
|
/**
|
|
* @brief Converts a log level string to the corresponding enum value
|
|
*
|
|
* Parses a string representation of a log level (e.g., "INFO", "DEBUG")
|
|
* and returns the corresponding LoggingLevels enum value.
|
|
*
|
|
* @param level_str The string representation of the log level
|
|
* @param default_level The default level to return if parsing fails
|
|
* @return The corresponding LoggingLevels enum value
|
|
*/
|
|
static LoggingLevels stringToLogLevel(const std::string& level_str, LoggingLevels default_level = LoggingLevels::INFO);
|
|
|
|
/**
|
|
* @brief Converts a LoggingLevels enum value to its string representation
|
|
*
|
|
* Returns the string representation of a log level (e.g., "INFO", "DEBUG")
|
|
* for the given LoggingLevels enum value.
|
|
*
|
|
* @param level The LoggingLevels enum value
|
|
* @return The string representation of the log level
|
|
*/
|
|
static std::string LogLevelToString(LoggingLevels level);
|
|
|
|
private:
|
|
/**
|
|
* @brief The current log level threshold
|
|
*/
|
|
LoggingLevels log_level;
|
|
|
|
/**
|
|
* @brief Whether to write log messages to a file
|
|
*/
|
|
bool log_to_file;
|
|
|
|
/**
|
|
* @brief The path to the log file
|
|
*/
|
|
std::string log_file;
|
|
};
|
|
|
|
/**
|
|
* @brief Global logger instance
|
|
*
|
|
* Provides a single instance of the Logger that can be accessed
|
|
* from anywhere in the application.
|
|
*/
|
|
extern Logger g_logger; |