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
26namespace isc {
27namespace db {
28
35
40extern const int DB_DBG_TRACE_DETAIL;
41
43
46
47
53
59
64
69};
71
74class DbLogger {
75public:
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
99};
100
102typedef std::list<DbLogger> DbLoggerStack;
103
106
110void 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
Database logger class.
Definition: db_log.h:74
DbLogger(isc::log::Logger &logger, const MessageMap &map)
Constructor.
Definition: db_log.h:83
const MessageMap & map_
The translation map.
Definition: db_log.h:98
const isc::log::MessageID & translateMessage(const DbMessageID &id) const
Translate message.
Definition: db_log.cc:54
std::map< DbMessageID, isc::log::MessageID > MessageMap
Translation map type.
Definition: db_log.h:77
isc::log::Logger & logger_
The logger.
Definition: db_log.h:95
Logger Class.
Definition: log/logger.h:143
const int DB_DBG_TRACE_DETAIL
Database logging levels.
Definition: db_log.h:40
isc::log::Logger database_logger("database")
Common database library logger.
Definition: db_log.h:45
std::list< DbLogger > DbLoggerStack
Database logger stack.
Definition: db_log.h:102
DbMessageID
Database messages.
Definition: db_log.h:51
@ DB_INVALID_ACCESS
Definition: db_log.h:52
@ CQL_CONNECTION_COMMIT
Definition: db_log.h:67
@ CQL_CONNECTION_BEGIN_TRANSACTION
Definition: db_log.h:66
@ MYSQL_START_TRANSACTION
Definition: db_log.h:61
@ PGSQL_ROLLBACK
Definition: db_log.h:58
@ CQL_DEALLOC_ERROR
Definition: db_log.h:65
@ PGSQL_COMMIT
Definition: db_log.h:57
@ PGSQL_START_TRANSACTION
Definition: db_log.h:56
@ CQL_CONNECTION_ROLLBACK
Definition: db_log.h:68
@ PGSQL_FATAL_ERROR
Definition: db_log.h:55
@ MYSQL_ROLLBACK
Definition: db_log.h:63
@ PGSQL_DEALLOC_ERROR
Definition: db_log.h:54
@ MYSQL_FATAL_ERROR
Definition: db_log.h:60
@ MYSQL_COMMIT
Definition: db_log.h:62
DbLoggerStack db_logger_stack
Global database logger stack (initialized to dhcpsrv logger)
Definition: db_log.cc:50
void checkDbLoggerStack()
Check database logger stack.
Definition: db_log.cc:62
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:157
const char * MessageID
Definition: message_types.h:15
Defines the logger used by the top-level component of kea-dhcp-ddns.