Kea  1.5.0
db_log.h
Go to the documentation of this file.
1 // Copyright (C) 2018 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 <list>
14 
25 
26 namespace isc {
27 namespace db {
28 
35 
40 extern const int DB_DBG_TRACE_DETAIL;
41 
43 
46 
47 
53 
59 
64 
69 };
71 
74 class DbLogger {
75 public:
77  typedef std::map<DbMessageID, isc::log::MessageID> MessageMap;
78 
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 
106 
110 void checkDbLoggerStack();
111 
114 
115 #define DB_LOG_DEBUG(LEVEL, MESSAGE) \
116  isc::db::checkDbLoggerStack(); \
117  if (!db_logger_stack.back().logger_.isDebugEnabled((LEVEL))) { \
118  } else \
119  isc::db::db_logger_stack.back().logger_.debug((LEVEL), \
120  isc::db::db_logger_stack.back().translateMessage((MESSAGE)))
121 
122 
123 #define DB_LOG_INFO(MESSAGE) \
124  isc::db::checkDbLoggerStack(); \
125  if (!isc::db::db_logger_stack.back().logger_.isInfoEnabled()) { \
126  } else \
127  isc::db::db_logger_stack.back().logger_.info( \
128  isc::db::db_logger_stack.back().translateMessage((MESSAGE)))
129 
130 #define DB_LOG_WARN(MESSAGE) \
131  isc::db::checkDbLoggerStack(); \
132  if (!isc::db::db_logger_stack.back().logger_.isWarnEnabled()) { \
133  } else \
134  isc::db::db_logger_stack.back().logger_.warn( \
135  isc::db::db_logger_stack.back().translateMessage((MESSAGE)))
136 
137 #define DB_LOG_ERROR(MESSAGE) \
138  isc::db::checkDbLoggerStack(); \
139  if (!isc::db::db_logger_stack.back().logger_.isErrorEnabled()) { \
140  } else \
141  isc::db::db_logger_stack.back().logger_.error( \
142  isc::db::db_logger_stack.back().translateMessage((MESSAGE)))
143 
144 #define DB_LOG_FATAL(MESSAGE) \
145  isc::db::checkDbLoggerStack(); \
146  if (!isc::db::db_logger_stack.back().logger_.isFatalEnabled()) { \
147  } else \
148  isc::db::db_logger_stack.back().logger_.fatal( \
149  isc::db::db_logger_stack.back().translateMessage((MESSAGE)))
150 
152 
155 
158 
159 } // namespace db
160 } // namespace isc
161 
162 #endif // DB_LOG_H
isc::db::CQL_CONNECTION_ROLLBACK
@ CQL_CONNECTION_ROLLBACK
Definition: db_log.h:68
isc::log::Logger
Logger Class.
Definition: log/logger.h:143
isc::db::db_message_map
const DbLogger::MessageMap db_message_map
Map of translated messages.
Definition: db_log.cc:24
isc::db::DbLogger::MessageMap
std::map< DbMessageID, isc::log::MessageID > MessageMap
Translation map type.
Definition: db_log.h:77
isc::db::DB_INVALID_ACCESS
@ DB_INVALID_ACCESS
Definition: db_log.h:52
isc::db::PGSQL_ROLLBACK
@ PGSQL_ROLLBACK
Definition: db_log.h:58
isc::db::PGSQL_DEALLOC_ERROR
@ PGSQL_DEALLOC_ERROR
Definition: db_log.h:54
isc::db::CQL_DEALLOC_ERROR
@ CQL_DEALLOC_ERROR
Definition: db_log.h:65
isc::db::DbMessageID
DbMessageID
Database messages.
Definition: db_log.h:51
isc::db::db_logger_stack
DbLoggerStack db_logger_stack
Global database logger stack (initialized to dhcpsrv logger)
Definition: db_log.cc:50
isc::db::DbLogger::translateMessage
const isc::log::MessageID & translateMessage(const DbMessageID &id) const
Translate message.
Definition: db_log.cc:54
isc::db::DB_DBG_TRACE_DETAIL
const int DB_DBG_TRACE_DETAIL
Database logging levels.
Definition: db_log.h:40
isc::db::PGSQL_START_TRANSACTION
@ PGSQL_START_TRANSACTION
Definition: db_log.h:56
macros.h
isc::db::PGSQL_FATAL_ERROR
@ PGSQL_FATAL_ERROR
Definition: db_log.h:55
isc::db::DbLogger::logger_
isc::log::Logger & logger_
The logger.
Definition: db_log.h:95
isc::db::CQL_CONNECTION_COMMIT
@ CQL_CONNECTION_COMMIT
Definition: db_log.h:67
isc
Defines the logger used by the top-level component of kea-dhcp-ddns.
Definition: agent_parser.cc:144
isc::db::MYSQL_ROLLBACK
@ MYSQL_ROLLBACK
Definition: db_log.h:63
isc::db::db_logger_translator
DbLogger db_logger_translator(database_logger, db_message_map)
Database logger translator.
Definition: db_log.h:157
isc::db::DbLogger::map_
const MessageMap & map_
The translation map.
Definition: db_log.h:98
isc::asiodns::logger
isc::log::Logger logger("asiodns")
Use the ASIO logger.
Definition: asiodns/logger.h:15
isc::db::checkDbLoggerStack
void checkDbLoggerStack()
Check database logger stack.
Definition: db_log.cc:62
isc::db::PGSQL_COMMIT
@ PGSQL_COMMIT
Definition: db_log.h:57
isc::db::database_logger
isc::log::Logger database_logger("database")
Common database library logger.
Definition: db_log.h:45
isc::db::MYSQL_START_TRANSACTION
@ MYSQL_START_TRANSACTION
Definition: db_log.h:61
isc::log::MessageID
const char * MessageID
Definition: message_types.h:15
isc::db::DbLogger
Database logger class.
Definition: db_log.h:74
isc::db::DbLogger::DbLogger
DbLogger(isc::log::Logger &logger, const MessageMap &map)
Constructor.
Definition: db_log.h:83
isc::db::CQL_CONNECTION_BEGIN_TRANSACTION
@ CQL_CONNECTION_BEGIN_TRANSACTION
Definition: db_log.h:66
isc::db::MYSQL_COMMIT
@ MYSQL_COMMIT
Definition: db_log.h:62
isc::db::DbLoggerStack
std::list< DbLogger > DbLoggerStack
Database logger stack.
Definition: db_log.h:102
isc::db::MYSQL_FATAL_ERROR
@ MYSQL_FATAL_ERROR
Definition: db_log.h:60