Kea 3.2.0
db_log.h
Go to the documentation of this file.
1// Copyright (C) 2018-2026 Internet Systems Consortium, Inc. ("ISC")
2//
3// This Source Code Form is subject to the terms of the Mozilla Public
4// License, v. 2.0. If a copy of the MPL was not distributed with this
5// file, You can obtain one at http://mozilla.org/MPL/2.0/.
6
7#ifndef DB_LOG_H
8#define DB_LOG_H
9
10#include <log/macros.h>
11
12#include <map>
13#include <mutex>
14#include <list>
15
26
27namespace isc {
28namespace db {
29
36
41extern const int DB_DBG_TRACE_DETAIL;
42
44
47
76
77
80class DbLogger {
81public:
83 typedef std::map<DbMessageID, isc::log::MessageID> MessageMap;
84
90 : logger_(logger), map_(map) {
91 }
92
98 const isc::log::MessageID& translateMessage(const DbMessageID& id) const;
99
102
105};
106
108typedef std::list<DbLogger> DbLoggerStack;
109
112
114extern std::mutex db_logger_mutex;
115
119void checkDbLoggerStack();
120
129
131template <log_type_t log_type>
132struct DB_LOG {
135 DB_LOG(DbMessageID const message_id, int const debug_level = 0) {
136 std::lock_guard<std::mutex> lock(isc::db::db_logger_mutex);
138 if (isEnabled()) {
139 formatter_ = formatter(message_id, debug_level);
140 }
141 }
142
149 template <typename T, typename... Args>
150 DB_LOG& arg(T first, Args... args) {
151 formatter_.arg(first);
152 return arg(args...);
153 }
154
161 return *this;
162 }
163
164private:
172 formatter(DbMessageID const message_id, int const debug_level = 0);
173
179 bool isEnabled(int const debug_level = 0) const;
180
183};
184
187struct DB_LOG_FATAL : DB_LOG<fatal> {
188 DB_LOG_FATAL(DbMessageID const message_id) : DB_LOG(message_id) {
189 }
190};
191
192struct DB_LOG_ERROR : DB_LOG<error> {
193 DB_LOG_ERROR(DbMessageID const message_id) : DB_LOG(message_id) {
194 }
195};
196
197struct DB_LOG_WARN : DB_LOG<warn> {
198 DB_LOG_WARN(DbMessageID const message_id) : DB_LOG(message_id) {
199 }
200};
201
202struct DB_LOG_INFO : DB_LOG<info> {
203 DB_LOG_INFO(DbMessageID const message_id) : DB_LOG(message_id) {
204 }
205};
206
207struct DB_LOG_DEBUG : DB_LOG<debug> {
208 DB_LOG_DEBUG(int const debug_level, DbMessageID const message_id)
209 : DB_LOG(message_id, debug_level) {
210 }
211};
212
213
216
219
220} // namespace db
221} // namespace isc
222
223#endif // DB_LOG_H
Database logger class.
Definition db_log.h:80
DbLogger(isc::log::Logger &logger, const MessageMap &map)
Constructor.
Definition db_log.h:89
const MessageMap & map_
The translation map.
Definition db_log.h:104
const isc::log::MessageID & translateMessage(const DbMessageID &id) const
Translate message.
Definition db_log.cc:59
std::map< DbMessageID, isc::log::MessageID > MessageMap
Translation map type.
Definition db_log.h:83
isc::log::Logger & logger_
The logger.
Definition db_log.h:101
Logger Class.
Definition log/logger.h:142
isc::log::Formatter< Logger > Formatter
The formatter used to replace placeholders.
Definition log/logger.h:194
const int DB_DBG_TRACE_DETAIL
Database logging levels.
Definition db_log.cc:21
isc::log::Logger database_logger("database")
Common database library logger.
Definition db_log.h:46
std::list< DbLogger > DbLoggerStack
Database logger stack.
Definition db_log.h:108
DbMessageID
Database messages.
Definition db_log.h:51
@ DB_INVALID_ACCESS
Definition db_log.h:52
@ MYSQL_START_TRANSACTION
Definition db_log.h:72
@ MYSQL_NO_INIT_NO_ADMIN
Definition db_log.h:69
@ PGSQL_ROLLBACK_SAVEPOINT
Definition db_log.h:64
@ PGSQL_CREATE_SAVEPOINT
Definition db_log.h:63
@ PGSQL_ROLLBACK
Definition db_log.h:62
@ MYSQL_INITIALIZE_SCHEMA
Definition db_log.h:68
@ PGSQL_TCP_USER_TIMEOUT_UNSUPPORTED
Definition db_log.h:65
@ PGSQL_COMMIT
Definition db_log.h:61
@ PGSQL_NO_INIT_NO_ADMIN
Definition db_log.h:56
@ PGSQL_START_TRANSACTION
Definition db_log.h:60
@ MYSQL_INITIAL_CONNECTION_FAIL
Definition db_log.h:67
@ PGSQL_FATAL_ERROR
Definition db_log.h:59
@ MYSQL_ROLLBACK
Definition db_log.h:74
@ PGSQL_NO_INIT_READONLY
Definition db_log.h:57
@ PGSQL_INITIALIZE_SCHEMA
Definition db_log.h:55
@ MYSQL_NO_INIT_READONLY
Definition db_log.h:70
@ PGSQL_DEALLOC_ERROR
Definition db_log.h:58
@ MYSQL_FATAL_ERROR
Definition db_log.h:71
@ PGSQL_INITIAL_CONNECTION_FAIL
Definition db_log.h:54
@ MYSQL_COMMIT
Definition db_log.h:73
DbLoggerStack db_logger_stack
Global database logger stack (initialized to database logger).
Definition db_log.cc:54
log_type_t
log type enumerations for use in DB_LOG specializations
Definition db_log.h:122
@ fatal
Definition db_log.h:123
@ info
Definition db_log.h:126
@ debug
Definition db_log.h:127
@ error
Definition db_log.h:124
@ warn
Definition db_log.h:125
std::mutex db_logger_mutex
Global mutex to protect logger stack.
Definition db_log.cc:56
void checkDbLoggerStack()
Check database logger stack.
Definition db_log.cc:67
const DbLogger::MessageMap db_message_map
Map of translated messages.
Definition db_log.cc:24
DbLogger db_logger_translator(database_logger, db_message_map)
Database logger translator.
Definition db_log.h:218
const char * MessageID
Defines the logger used by the top-level component of kea-lfc.
DB_LOG_DEBUG(int const debug_level, DbMessageID const message_id)
Definition db_log.h:208
DB_LOG_ERROR(DbMessageID const message_id)
Definition db_log.h:193
DB_LOG_FATAL(DbMessageID const message_id)
Definition db_log.h:188
DB_LOG_INFO(DbMessageID const message_id)
Definition db_log.h:203
DB_LOG_WARN(DbMessageID const message_id)
Definition db_log.h:198
DB_LOG & arg(T first, Args... args)
Pass parameters to replace logger placeholders.
Definition db_log.h:150
DB_LOG & arg()
The last invocation of the arg() which is without parameters.
Definition db_log.h:160
DB_LOG(DbMessageID const message_id, int const debug_level=0)
To preserve the old way of logging, this constructor facilitates initiating the DB_LOG_* chain call.
Definition db_log.h:135