Kea  1.9.9-git
db_log.h
Go to the documentation of this file.
1 // Copyright (C) 2018-2021 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 
27 namespace isc {
28 namespace db {
29 
36 
41 extern const int DB_DBG_TRACE_DETAIL;
42 
44 
47 
53 
59 
64 
69 };
71 
74 class DbLogger {
75 public:
77  typedef std::map<DbMessageID, isc::log::MessageID> MessageMap;
78 
83  DbLogger(isc::log::Logger& logger, const MessageMap& map)
84  : logger_(logger), map_(map) {
85  }
86 
92  const isc::log::MessageID& translateMessage(const DbMessageID& id) const;
93 
96 
98  const MessageMap& map_;
99 };
100 
102 typedef std::list<DbLogger> DbLoggerStack;
103 
105 extern DbLoggerStack db_logger_stack;
106 
108 extern std::mutex db_logger_mutex;
109 
113 void checkDbLoggerStack();
114 
122 };
123 
125 template <log_type_t log_type>
126 struct DB_LOG {
129  DB_LOG(DbMessageID const message_id, int const debug_level = 0) {
130  std::lock_guard<std::mutex> lock(isc::db::db_logger_mutex);
132  if (isEnabled()) {
133  formatter_ = formatter(message_id, debug_level);
134  }
135  }
136 
143  template <typename T, typename... Args>
144  DB_LOG& arg(T first, Args... args) {
145  formatter_.arg(first);
146  return arg(args...);
147  }
148 
154  DB_LOG& arg() {
155  return *this;
156  }
157 
158 private:
166  formatter(DbMessageID const message_id, int const debug_level = 0);
167 
173  bool isEnabled(int const debug_level = 0) const;
174 
176  isc::log::Logger::Formatter formatter_;
177 };
178 
181 struct DB_LOG_FATAL : DB_LOG<fatal> {
182  DB_LOG_FATAL(DbMessageID const message_id) : DB_LOG(message_id) {
183  }
184 };
185 
186 struct DB_LOG_ERROR : DB_LOG<error> {
187  DB_LOG_ERROR(DbMessageID const message_id) : DB_LOG(message_id) {
188  }
189 };
190 
191 struct DB_LOG_WARN : DB_LOG<warn> {
192  DB_LOG_WARN(DbMessageID const message_id) : DB_LOG(message_id) {
193  }
194 };
195 
196 struct DB_LOG_INFO : DB_LOG<info> {
197  DB_LOG_INFO(DbMessageID const message_id) : DB_LOG(message_id) {
198  }
199 };
200 
201 struct DB_LOG_DEBUG : DB_LOG<debug> {
202  DB_LOG_DEBUG(int const debug_level, DbMessageID const message_id)
203  : DB_LOG(message_id, debug_level) {
204  }
205 };
207 
210 
213 
214 } // namespace db
215 } // namespace isc
216 
217 #endif // DB_LOG_H
DB_LOG_DEBUG(int const debug_level, DbMessageID const message_id)
Definition: db_log.h:202
Logger Class.
Definition: log/logger.h:141
Database logger class.
Definition: db_log.h:74
DB_LOG & arg(T first, Args...args)
Pass parameters to replace logger placeholders.
Definition: db_log.h:144
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:129
DbMessageID
Database messages.
Definition: db_log.h:51
DB_LOG & arg()
The last invocation of the arg() which is without parameters.
Definition: db_log.h:154
isc::log::Logger & logger_
The logger.
Definition: db_log.h:95
const DbLogger::MessageMap db_message_map
Map of translated messages.
Definition: db_log.cc:24
DB_LOG_FATAL(DbMessageID const message_id)
Definition: db_log.h:182
std::map< DbMessageID, isc::log::MessageID > MessageMap
Translation map type.
Definition: db_log.h:77
std::mutex db_logger_mutex
Global mutex to protect logger stack.
Definition: db_log.cc:51
DbLogger(isc::log::Logger &logger, const MessageMap &map)
Constructor.
Definition: db_log.h:83
DB_LOG_WARN(DbMessageID const message_id)
Definition: db_log.h:192
log_type_t
log type enumerations for use in DB_LOG specializations
Definition: db_log.h:116
std::list< DbLogger > DbLoggerStack
Database logger stack.
Definition: db_log.h:102
DbLoggerStack db_logger_stack
Global database logger stack (initialized to database logger)
Definition: db_log.cc:49
DB_LOG_* logic.
Definition: db_log.h:126
Formatter & arg(const Arg &value)
Replaces another placeholder.
DB_LOG_ERROR(DbMessageID const message_id)
Definition: db_log.h:187
const int DB_DBG_TRACE_DETAIL
Database logging levels.
Definition: db_log.cc:21
Defines the logger used by the top-level component of kea-dhcp-ddns.
const isc::log::MessageID & translateMessage(const DbMessageID &id) const
Translate message.
Definition: db_log.cc:54
isc::log::Logger logger("asiodns")
Use the ASIO logger.
The log message formatter.
DB_LOG_INFO(DbMessageID const message_id)
Definition: db_log.h:197
all DB_LOG specializations
Definition: db_log.h:181
void checkDbLoggerStack()
Check database logger stack.
Definition: db_log.cc:62
DbLogger db_logger_translator(database_logger, db_message_map)
Database logger translator.
Definition: db_log.h:212
isc::log::Logger database_logger("database")
Common database library logger.
Definition: db_log.h:46
const MessageMap & map_
The translation map.
Definition: db_log.h:98
const char * MessageID
Definition: message_types.h:15