Kea 3.2.0-git
db_log.cc
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
8
9#include <config.h>
10
12#include <database/db_log.h>
14
15using namespace isc::log;
16
17namespace isc {
18namespace db {
19
22
49
51
53
55
56std::mutex db_logger_mutex;
57
58const MessageID&
60 try {
61 return (map_.at(id));
62 } catch (const std::out_of_range&) {
63 isc_throw(isc::Unexpected, "can't map message: " << id);
64 }
65}
66
68 if (db_logger_stack.empty()) {
69 isc_throw(isc::Unexpected, "database logger stack is empty");
70 }
71}
72
73template <>
75DB_LOG<fatal>::formatter(DbMessageID const message_id,
76 int const /* debug_level = 0 */) {
77 return isc::db::db_logger_stack.back().logger_.fatal(
78 isc::db::db_logger_stack.back().translateMessage(message_id));
79}
80
81template <>
83DB_LOG<error>::formatter(DbMessageID const message_id,
84 int const /* debug_level = 0 */) {
85 return isc::db::db_logger_stack.back().logger_.error(
86 isc::db::db_logger_stack.back().translateMessage(message_id));
87}
88
89template <>
91DB_LOG<warn>::formatter(DbMessageID const message_id,
92 int const /* debug_level = 0 */) {
93 return isc::db::db_logger_stack.back().logger_.warn(
94 isc::db::db_logger_stack.back().translateMessage(message_id));
95}
96
97template <>
99DB_LOG<info>::formatter(DbMessageID const message_id,
100 int const /* debug_level = 0 */) {
101 return isc::db::db_logger_stack.back().logger_.info(
102 isc::db::db_logger_stack.back().translateMessage(message_id));
103}
104
105template <>
107DB_LOG<debug>::formatter(DbMessageID const message_id,
108 int const debug_level /* = 0 */) {
109 return isc::db::db_logger_stack.back().logger_.debug(
110 debug_level,
111 isc::db::db_logger_stack.back().translateMessage(message_id));
112}
113
114template <>
115bool
116DB_LOG<fatal>::isEnabled(int const /* debug_level = 0 */) const {
117 return db_logger_stack.back().logger_.isFatalEnabled();
118}
119
120template <>
121bool
122DB_LOG<error>::isEnabled(int const /* debug_level = 0 */) const {
123 return db_logger_stack.back().logger_.isErrorEnabled();
124}
125
126template <>
127bool
128DB_LOG<warn>::isEnabled(int const /* debug_level = 0 */) const {
129 return db_logger_stack.back().logger_.isWarnEnabled();
130}
131
132template <>
133bool
134DB_LOG<info>::isEnabled(int const /* debug_level = 0 */) const {
135 return db_logger_stack.back().logger_.isInfoEnabled();
136}
137
138template <>
139bool
140DB_LOG<debug>::isEnabled(int const debug_level /* = 0 */) const {
141 return db_logger_stack.back().logger_.isDebugEnabled(debug_level);
142}
143
144} // namespace db
145} // namespace isc
A generic exception that is thrown when an unexpected error condition occurs.
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
Logger Class.
Definition log/logger.h:142
isc::log::Formatter< Logger > Formatter
The formatter used to replace placeholders.
Definition log/logger.h:194
We want to reuse the database backend connection and exchange code for other uses,...
#define isc_throw(type, stream)
A shortcut macro to insert known values into exception arguments.
const isc::log::MessageID DATABASE_MYSQL_INITIAL_CONNECTION_FAIL
Definition db_messages.h:16
const int DB_DBG_TRACE_DETAIL
Database logging levels.
Definition db_log.cc:21
const isc::log::MessageID DATABASE_PGSQL_FATAL_ERROR
Definition db_messages.h:24
isc::log::Logger database_logger("database")
Common database library logger.
Definition db_log.h:46
const isc::log::MessageID DATABASE_MYSQL_COMMIT
Definition db_messages.h:13
std::list< DbLogger > DbLoggerStack
Database logger stack.
Definition db_log.h:108
const isc::log::MessageID DATABASE_MYSQL_INITIALIZE_SCHEMA
Definition db_messages.h:15
const isc::log::MessageID DATABASE_PGSQL_INITIAL_CONNECTION_FAIL
Definition db_messages.h:26
const isc::log::MessageID DATABASE_PGSQL_INITIALIZE_SCHEMA
Definition db_messages.h:25
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
const isc::log::MessageID DATABASE_PGSQL_COMMIT
Definition db_messages.h:21
DbLoggerStack db_logger_stack
Global database logger stack (initialized to database logger).
Definition db_log.cc:54
const isc::log::MessageID DATABASE_MYSQL_NO_INIT_READONLY
Definition db_messages.h:18
const isc::log::MessageID DATABASE_PGSQL_CREATE_SAVEPOINT
Definition db_messages.h:22
const isc::log::MessageID DATABASE_INVALID_ACCESS
Definition db_messages.h:12
const isc::log::MessageID DATABASE_PGSQL_ROLLBACK_SAVEPOINT
Definition db_messages.h:30
const isc::log::MessageID DATABASE_MYSQL_NO_INIT_NO_ADMIN
Definition db_messages.h:17
const isc::log::MessageID DATABASE_MYSQL_ROLLBACK
Definition db_messages.h:19
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 isc::log::MessageID DATABASE_PGSQL_DEALLOC_ERROR
Definition db_messages.h:23
const DbLogger::MessageMap db_message_map
Map of translated messages.
Definition db_log.cc:24
const isc::log::MessageID DATABASE_PGSQL_NO_INIT_READONLY
Definition db_messages.h:28
DbLogger db_logger_translator(database_logger, db_message_map)
Database logger translator.
Definition db_log.h:218
const isc::log::MessageID DATABASE_PGSQL_START_TRANSACTION
Definition db_messages.h:31
const isc::log::MessageID DATABASE_PGSQL_NO_INIT_NO_ADMIN
Definition db_messages.h:27
const isc::log::MessageID DATABASE_PGSQL_TCP_USER_TIMEOUT_UNSUPPORTED
Definition db_messages.h:32
const isc::log::MessageID DATABASE_PGSQL_ROLLBACK
Definition db_messages.h:29
const isc::log::MessageID DATABASE_MYSQL_FATAL_ERROR
Definition db_messages.h:14
const isc::log::MessageID DATABASE_MYSQL_START_TRANSACTION
Definition db_messages.h:20
const char * MessageID
const int DBGLVL_TRACE_DETAIL
Trace detailed operations.
Defines the logger used by the top-level component of kea-lfc.