forked from halfgaar/FlashMQ
-
Notifications
You must be signed in to change notification settings - Fork 0
/
logger.h
107 lines (87 loc) · 2.36 KB
/
logger.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/*
This file is part of FlashMQ (https://www.flashmq.org)
Copyright (C) 2021-2023 Wiebe Cazemier
FlashMQ is free software: you can redistribute it and/or modify
it under the terms of The Open Software License 3.0 (OSL-3.0).
See LICENSE for license details.
*/
#ifndef LOGGER_H
#define LOGGER_H
#include <stdio.h>
#include <stdarg.h>
#include <mutex>
#include <queue>
#include <thread>
#include <sstream>
#include <optional>
#include "semaphore.h"
#include "flashmq_plugin.h"
enum class LogLevel
{
Debug,
Info,
Notice,
Warning,
Error,
None
};
int logSslError(const char *str, size_t len, void *u);
/**
* @brief Use as a temporary, so don't give a name. This makes the stream gets logged immediately.
*/
class StreamToLog : public std::ostringstream
{
int level = LOG_NOTICE;
public:
StreamToLog(int level);
~StreamToLog();
};
class LogLine
{
std::string line;
bool alsoToStdOut;
public:
LogLine(std::string &&line, bool alsoToStdOut);
LogLine(const char *s, size_t len, bool alsoToStdOut);
LogLine();
LogLine(const LogLine &other) = delete;
LogLine(LogLine &&other) = default;
LogLine &operator=(LogLine &&other) = default;
const char *c_str() const;
bool alsoLogToStdOut() const;
};
class Logger
{
static Logger *instance;
static std::mutex instanceMutex;
std::string logPath;
int curLogLevel = LOG_ERR | LOG_WARNING | LOG_NOTICE | LOG_INFO | LOG_SUBSCRIBE | LOG_UNSUBSCRIBE ;
std::mutex logMutex;
std::queue<LogLine> lines;
sem_t linesPending;
std::thread writerThread;
bool running = true;
FILE *file = nullptr;
bool alsoLogToStd = true;
bool reload = false;
Logger();
~Logger();
static std::string_view getLogLevelString(int level);
void reOpen();
void writeLog();
static std::string getPrefix(int level);
public:
static void stopAndReset();
static Logger *getInstance();
void logstring(int level, const std::string &str);
void logf(int level, const char *str, va_list args);
void logf(int level, const char *str, ...);
StreamToLog log(int level);
void queueReOpen();
void noLongerLogToStd();
void setLogPath(const std::string &path);
void setFlags(LogLevel level, bool logSubscriptions);
void setFlags(std::optional<bool> logDebug, std::optional<bool> quiet);
void quit();
};
#endif // LOGGER_H