Kea 1.5.0
db_log.cc
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
8
9#include <config.h>
10
12#include <database/db_log.h>
13#include <database/db_messages.h>
14
15using namespace isc::log;
16
17namespace isc {
18namespace db {
19
22
25 { DB_INVALID_ACCESS, DATABASE_INVALID_ACCESS },
26
27 { PGSQL_DEALLOC_ERROR, DATABASE_PGSQL_DEALLOC_ERROR },
28 { PGSQL_FATAL_ERROR, DATABASE_PGSQL_FATAL_ERROR },
29 { PGSQL_START_TRANSACTION, DATABASE_PGSQL_START_TRANSACTION },
30 { PGSQL_COMMIT, DATABASE_PGSQL_COMMIT },
31 { PGSQL_ROLLBACK, DATABASE_PGSQL_ROLLBACK },
32
33 { MYSQL_FATAL_ERROR, DATABASE_MYSQL_FATAL_ERROR },
34 { MYSQL_START_TRANSACTION, DATABASE_MYSQL_START_TRANSACTION },
35 { MYSQL_COMMIT, DATABASE_MYSQL_COMMIT },
36 { MYSQL_ROLLBACK, DATABASE_MYSQL_ROLLBACK },
37
38 { CQL_DEALLOC_ERROR, DATABASE_CQL_DEALLOC_ERROR },
40 DATABASE_CQL_CONNECTION_BEGIN_TRANSACTION },
41 { CQL_CONNECTION_COMMIT, DATABASE_CQL_CONNECTION_COMMIT },
42 { CQL_CONNECTION_ROLLBACK, DATABASE_CQL_CONNECTION_ROLLBACK }
43};
44
45
47
49
51
52
53const MessageID&
55 try {
56 return (map_.at(id));
57 } catch (const std::out_of_range&) {
58 isc_throw(isc::Unexpected, "can't map message: " << id);
59 }
60}
61
63 if (db_logger_stack.empty()) {
64 isc_throw(isc::Unexpected, "database logger stack is empty");
65 }
66}
67
68} // namespace db
69} // namespace isc
A generic exception that is thrown when an unexpected error condition occurs.
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
Logger Class.
Definition: log/logger.h:143
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 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
const int DBGLVL_TRACE_DETAIL
Trace detailed operations.
Definition: log_dbglevels.h:71
Defines the logger used by the top-level component of kea-dhcp-ddns.