Enable debug logs
This commit is contained in:
parent
8f89ad15f7
commit
4b1b062388
@ -122,6 +122,12 @@ else(NOT (CMAKE_BUILD_TYPE OR CMAKE_CONFIGURATION_TYPES))
|
|||||||
message("Build type set to '${CMAKE_BUILD_TYPE}'")
|
message("Build type set to '${CMAKE_BUILD_TYPE}'")
|
||||||
endif(NOT (CMAKE_BUILD_TYPE OR CMAKE_CONFIGURATION_TYPES))
|
endif(NOT (CMAKE_BUILD_TYPE OR CMAKE_CONFIGURATION_TYPES))
|
||||||
|
|
||||||
|
if(${CMAKE_BUILD_TYPE} STREQUAL "Debug")
|
||||||
|
set(SPDLOG_DEBUG_ON true)
|
||||||
|
else()
|
||||||
|
set(SPDLOG_DEBUG_ON false)
|
||||||
|
endif()
|
||||||
|
|
||||||
find_program(GIT git)
|
find_program(GIT git)
|
||||||
if(GIT)
|
if(GIT)
|
||||||
execute_process(
|
execute_process(
|
||||||
@ -143,7 +149,7 @@ message(STATUS "Version: ${PROJECT_VERSION}")
|
|||||||
|
|
||||||
cmake_host_system_information(RESULT BUILD_HOST QUERY HOSTNAME)
|
cmake_host_system_information(RESULT BUILD_HOST QUERY HOSTNAME)
|
||||||
set(BUILD_USER $ENV{USER})
|
set(BUILD_USER $ENV{USER})
|
||||||
configure_file(cmake/version.h config/version.h)
|
configure_file(cmake/nheko.h config/nheko.h)
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -274,7 +280,6 @@ endif()
|
|||||||
include_directories(SYSTEM ${TWEENY_INCLUDE_DIR})
|
include_directories(SYSTEM ${TWEENY_INCLUDE_DIR})
|
||||||
|
|
||||||
include_directories(${CMAKE_SOURCE_DIR}/src)
|
include_directories(${CMAKE_SOURCE_DIR}/src)
|
||||||
include_directories(${CMAKE_CURRENT_BINARY_DIR}/config)
|
|
||||||
include_directories(${Boost_INCLUDE_DIRS})
|
include_directories(${Boost_INCLUDE_DIRS})
|
||||||
|
|
||||||
qt5_wrap_cpp(MOC_HEADERS
|
qt5_wrap_cpp(MOC_HEADERS
|
||||||
|
6
cmake/nheko.h
Normal file
6
cmake/nheko.h
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
namespace nheko {
|
||||||
|
constexpr auto version = "${PROJECT_VERSION}";
|
||||||
|
constexpr auto build_user = "${BUILD_USER}@${BUILD_HOST}";
|
||||||
|
constexpr auto build_os = "${CMAKE_HOST_SYSTEM_NAME}";
|
||||||
|
constexpr auto enable_debug_log = ${SPDLOG_DEBUG_ON};
|
||||||
|
}
|
@ -1,5 +0,0 @@
|
|||||||
namespace nheko {
|
|
||||||
static constexpr const char *version = "${PROJECT_VERSION}";
|
|
||||||
static constexpr const char *build_user = "${BUILD_USER}@${BUILD_HOST}";
|
|
||||||
static constexpr const char *build_os = "${CMAKE_HOST_SYSTEM_NAME}";
|
|
||||||
}
|
|
@ -1,4 +1,5 @@
|
|||||||
#include "Logging.h"
|
#include "Logging.h"
|
||||||
|
#include "config/nheko.h"
|
||||||
|
|
||||||
#include "spdlog/sinks/rotating_file_sink.h"
|
#include "spdlog/sinks/rotating_file_sink.h"
|
||||||
#include "spdlog/sinks/stdout_color_sinks.h"
|
#include "spdlog/sinks/stdout_color_sinks.h"
|
||||||
@ -32,6 +33,12 @@ init(const std::string &file_path)
|
|||||||
db_logger = std::make_shared<spdlog::logger>("db", std::begin(sinks), std::end(sinks));
|
db_logger = std::make_shared<spdlog::logger>("db", std::begin(sinks), std::end(sinks));
|
||||||
crypto_logger =
|
crypto_logger =
|
||||||
std::make_shared<spdlog::logger>("crypto", std::begin(sinks), std::end(sinks));
|
std::make_shared<spdlog::logger>("crypto", std::begin(sinks), std::end(sinks));
|
||||||
|
|
||||||
|
if (nheko::enable_debug_log) {
|
||||||
|
db_logger->set_level(spdlog::level::trace);
|
||||||
|
ui_logger->set_level(spdlog::level::trace);
|
||||||
|
crypto_logger->set_level(spdlog::level::trace);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::shared_ptr<spdlog::logger>
|
std::shared_ptr<spdlog::logger>
|
||||||
|
36
src/Olm.cpp
36
src/Olm.cpp
@ -92,7 +92,7 @@ handle_olm_message(const OlmMessage &msg)
|
|||||||
auto payload = try_olm_decryption(msg.sender_key, cipher.second);
|
auto payload = try_olm_decryption(msg.sender_key, cipher.second);
|
||||||
|
|
||||||
if (!payload.is_null()) {
|
if (!payload.is_null()) {
|
||||||
nhlog::crypto()->info("decrypted olm payload: {}", payload.dump(2));
|
nhlog::crypto()->debug("decrypted olm payload: {}", payload.dump(2));
|
||||||
create_inbound_megolm_session(msg.sender, msg.sender_key, payload);
|
create_inbound_megolm_session(msg.sender, msg.sender_key, payload);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -146,7 +146,7 @@ handle_pre_key_olm_message(const std::string &sender,
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto plaintext = json::parse(std::string((char *)output.data(), output.size()));
|
auto plaintext = json::parse(std::string((char *)output.data(), output.size()));
|
||||||
nhlog::crypto()->info("decrypted message: \n {}", plaintext.dump(2));
|
nhlog::crypto()->debug("decrypted message: \n {}", plaintext.dump(2));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
cache::client()->saveOlmSession(sender_key, std::move(inbound_session));
|
cache::client()->saveOlmSession(sender_key, std::move(inbound_session));
|
||||||
@ -206,11 +206,11 @@ try_olm_decryption(const std::string &sender_key, const mtx::events::msg::OlmCip
|
|||||||
text = olm::client()->decrypt_message(session->get(), msg.type, msg.body);
|
text = olm::client()->decrypt_message(session->get(), msg.type, msg.body);
|
||||||
cache::client()->saveOlmSession(id, std::move(session.value()));
|
cache::client()->saveOlmSession(id, std::move(session.value()));
|
||||||
} catch (const mtx::crypto::olm_exception &e) {
|
} catch (const mtx::crypto::olm_exception &e) {
|
||||||
nhlog::crypto()->info("failed to decrypt olm message ({}, {}) with {}: {}",
|
nhlog::crypto()->debug("failed to decrypt olm message ({}, {}) with {}: {}",
|
||||||
msg.type,
|
msg.type,
|
||||||
sender_key,
|
sender_key,
|
||||||
id,
|
id,
|
||||||
e.what());
|
e.what());
|
||||||
continue;
|
continue;
|
||||||
} catch (const lmdb::error &e) {
|
} catch (const lmdb::error &e) {
|
||||||
nhlog::crypto()->critical("failed to save session: {}", e.what());
|
nhlog::crypto()->critical("failed to save session: {}", e.what());
|
||||||
@ -339,19 +339,19 @@ void
|
|||||||
handle_key_request_message(const mtx::events::msg::KeyRequest &req)
|
handle_key_request_message(const mtx::events::msg::KeyRequest &req)
|
||||||
{
|
{
|
||||||
if (req.algorithm != MEGOLM_ALGO) {
|
if (req.algorithm != MEGOLM_ALGO) {
|
||||||
nhlog::crypto()->info("ignoring key request {} with invalid algorithm: {}",
|
nhlog::crypto()->debug("ignoring key request {} with invalid algorithm: {}",
|
||||||
req.request_id,
|
req.request_id,
|
||||||
req.algorithm);
|
req.algorithm);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if we were the sender of the session being requested.
|
// Check if we were the sender of the session being requested.
|
||||||
if (req.sender_key != olm::client()->identity_keys().curve25519) {
|
if (req.sender_key != olm::client()->identity_keys().curve25519) {
|
||||||
nhlog::crypto()->info("ignoring key request {} because we were not the sender: "
|
nhlog::crypto()->debug("ignoring key request {} because we were not the sender: "
|
||||||
"\nrequested({}) ours({})",
|
"\nrequested({}) ours({})",
|
||||||
req.request_id,
|
req.request_id,
|
||||||
req.sender_key,
|
req.sender_key,
|
||||||
olm::client()->identity_keys().curve25519);
|
olm::client()->identity_keys().curve25519);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -380,7 +380,7 @@ handle_key_request_message(const mtx::events::msg::KeyRequest &req)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!utils::respondsToKeyRequests(req.room_id)) {
|
if (!utils::respondsToKeyRequests(req.room_id)) {
|
||||||
nhlog::crypto()->info("ignoring all key requests for room {}", req.room_id);
|
nhlog::crypto()->debug("ignoring all key requests for room {}", req.room_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -433,7 +433,7 @@ send_megolm_key_to_device(const std::string &user_id,
|
|||||||
|
|
||||||
if ((device_keys.find(curveKey) == device_keys.end()) ||
|
if ((device_keys.find(curveKey) == device_keys.end()) ||
|
||||||
(device_keys.find(edKey) == device_keys.end())) {
|
(device_keys.find(edKey) == device_keys.end())) {
|
||||||
nhlog::net()->info("ignoring malformed keys for device {}", device_id);
|
nhlog::net()->debug("ignoring malformed keys for device {}", device_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -499,7 +499,7 @@ send_megolm_key_to_device(const std::string &user_id,
|
|||||||
body["messages"][user_id] = json::object();
|
body["messages"][user_id] = json::object();
|
||||||
|
|
||||||
auto device = retrieved_devices.begin()->second;
|
auto device = retrieved_devices.begin()->second;
|
||||||
nhlog::net()->info("{} : \n {}", device_id, device.dump(2));
|
nhlog::net()->debug("{} : \n {}", device_id, device.dump(2));
|
||||||
|
|
||||||
json device_msg;
|
json device_msg;
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
#include "ui/FlatButton.h"
|
#include "ui/FlatButton.h"
|
||||||
#include "ui/ToggleButton.h"
|
#include "ui/ToggleButton.h"
|
||||||
|
|
||||||
#include "version.h"
|
#include "config/nheko.h"
|
||||||
|
|
||||||
UserSettings::UserSettings() { load(); }
|
UserSettings::UserSettings() { load(); }
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
#include "MatrixClient.h"
|
#include "MatrixClient.h"
|
||||||
#include "RunGuard.h"
|
#include "RunGuard.h"
|
||||||
#include "Utils.h"
|
#include "Utils.h"
|
||||||
#include "version.h"
|
#include "config/nheko.h"
|
||||||
|
|
||||||
#if defined(Q_OS_MAC)
|
#if defined(Q_OS_MAC)
|
||||||
#include "emoji/MacHelper.h"
|
#include "emoji/MacHelper.h"
|
||||||
|
@ -354,8 +354,7 @@ TimelineView::parseEncryptedEvent(const mtx::events::EncryptedEvent<mtx::events:
|
|||||||
body["origin_server_ts"] = e.origin_server_ts;
|
body["origin_server_ts"] = e.origin_server_ts;
|
||||||
body["unsigned"] = e.unsigned_data;
|
body["unsigned"] = e.unsigned_data;
|
||||||
|
|
||||||
nhlog::crypto()->info("decrypted event: {}", e.event_id);
|
nhlog::crypto()->debug("decrypted event: {}", e.event_id);
|
||||||
nhlog::crypto()->debug("decrypted data: \n {}", body.dump(2));
|
|
||||||
|
|
||||||
json event_array = json::array();
|
json event_array = json::array();
|
||||||
event_array.push_back(body);
|
event_array.push_back(body);
|
||||||
@ -746,7 +745,7 @@ TimelineView::sendNextPendingMessage()
|
|||||||
m.widget->markSent();
|
m.widget->markSent();
|
||||||
|
|
||||||
if (m.is_encrypted) {
|
if (m.is_encrypted) {
|
||||||
nhlog::ui()->info("[{}] sending encrypted event", m.txn_id);
|
nhlog::ui()->debug("[{}] sending encrypted event", m.txn_id);
|
||||||
prepareEncryptedMessage(std::move(m));
|
prepareEncryptedMessage(std::move(m));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1330,7 +1329,7 @@ TimelineView::prepareEncryptedMessage(const PendingMessage &msg)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
nhlog::ui()->info("creating new outbound megolm session");
|
nhlog::ui()->debug("creating new outbound megolm session");
|
||||||
|
|
||||||
// Create a new outbound megolm session.
|
// Create a new outbound megolm session.
|
||||||
auto outbound_session = olm::client()->init_outbound_group_session();
|
auto outbound_session = olm::client()->init_outbound_group_session();
|
||||||
@ -1413,7 +1412,7 @@ TimelineView::prepareEncryptedMessage(const PendingMessage &msg)
|
|||||||
|
|
||||||
if ((device_keys.find(curveKey) == device_keys.end()) ||
|
if ((device_keys.find(curveKey) == device_keys.end()) ||
|
||||||
(device_keys.find(edKey) == device_keys.end())) {
|
(device_keys.find(edKey) == device_keys.end())) {
|
||||||
nhlog::net()->info(
|
nhlog::net()->debug(
|
||||||
"ignoring malformed keys for device {}",
|
"ignoring malformed keys for device {}",
|
||||||
device_id.get());
|
device_id.get());
|
||||||
continue;
|
continue;
|
||||||
@ -1512,15 +1511,15 @@ TimelineView::handleClaimedKeys(std::shared_ptr<StateKeeper> keeper,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
nhlog::net()->info("claimed keys for {}", user_id);
|
nhlog::net()->debug("claimed keys for {}", user_id);
|
||||||
|
|
||||||
if (res.one_time_keys.size() == 0) {
|
if (res.one_time_keys.size() == 0) {
|
||||||
nhlog::net()->info("no one-time keys found for user_id: {}", user_id);
|
nhlog::net()->debug("no one-time keys found for user_id: {}", user_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (res.one_time_keys.find(user_id) == res.one_time_keys.end()) {
|
if (res.one_time_keys.find(user_id) == res.one_time_keys.end()) {
|
||||||
nhlog::net()->info("no one-time keys found for user_id: {}", user_id);
|
nhlog::net()->debug("no one-time keys found for user_id: {}", user_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1532,7 +1531,7 @@ TimelineView::handleClaimedKeys(std::shared_ptr<StateKeeper> keeper,
|
|||||||
|
|
||||||
for (const auto &rd : retrieved_devices) {
|
for (const auto &rd : retrieved_devices) {
|
||||||
const auto device_id = rd.first;
|
const auto device_id = rd.first;
|
||||||
nhlog::net()->info("{} : \n {}", device_id, rd.second.dump(2));
|
nhlog::net()->debug("{} : \n {}", device_id, rd.second.dump(2));
|
||||||
|
|
||||||
// TODO: Verify signatures
|
// TODO: Verify signatures
|
||||||
auto otk = rd.second.begin()->at("key");
|
auto otk = rd.second.begin()->at("key");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#include "Config.h"
|
|
||||||
#include "InfoMessage.h"
|
#include "InfoMessage.h"
|
||||||
|
#include "Config.h"
|
||||||
|
|
||||||
#include <QDateTime>
|
#include <QDateTime>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
|
Loading…
Reference in New Issue
Block a user