diff --git a/deps/Sentry/Sentry.cmake b/deps/Sentry/Sentry.cmake index 138580b24f..07fb569c56 100644 --- a/deps/Sentry/Sentry.cmake +++ b/deps/Sentry/Sentry.cmake @@ -81,7 +81,7 @@ endif() Snapmaker_Orca_add_cmake_project(Sentry GIT_REPOSITORY https://github.com/getsentry/sentry-native.git - GIT_TAG 0.12.1 + GIT_TAG 0.12.2 GIT_SHALLOW ON PATCH_COMMAND ${SENTRY_PATCH_COMMAND} CMAKE_ARGS diff --git a/src/common_func/common_func.cpp b/src/common_func/common_func.cpp index cdde23d3c6..4b31cfd860 100644 --- a/src/common_func/common_func.cpp +++ b/src/common_func/common_func.cpp @@ -100,8 +100,8 @@ namespace common } nlohmann::json json_data; json_file >> json_data; - std::string str_version = json_data["version"]; - std::string str_build_number = json_data["build_number"]; + std::string str_version = json_data.value("version", ""); + std::string str_build_number = json_data.value("build_number", ""); std::string flutter_version = std::string("flutter_version: ") + str_version + std::string(" ") + std::string("build_number: ") + str_build_number; @@ -109,4 +109,73 @@ namespace common return flutter_version; } + + std::string getLocalArea() + { + std::string localArea = ""; + std::string cfgfile = ""; +#ifdef _WIN32 + wchar_t appDataPath[MAX_PATH] = {0}; + auto hr = SHGetFolderPathW(NULL, CSIDL_APPDATA, NULL, SHGFP_TYPE_CURRENT, appDataPath); + char* path = new char[MAX_PATH]; + size_t pathLength; + wcstombs_s(&pathLength, path, MAX_PATH, appDataPath, MAX_PATH); + std::string filePath = path; + cfgfile = filePath + "\\" + std::string("Snapmaker_Orca\\Snapmaker_Orca.conf"); +#elif __APPLE__ + const char* home_env = getenv("HOME"); + cfgfile = home_env; + cfgfile = versionFilePath + "/Library/Application Support/Snapmaker_Orca/Snapmaker_Orca.conf"; +#else + +#endif + std::ifstream json_file(cfgfile); + if (!json_file.is_open()) { + std::ifstream json_file(cfgfile); + return ""; + } + + nlohmann::json json_data; + json_file >> json_data; + + auto dataObj = json_data.value("app", nlohmann::json::object()); + localArea = dataObj.value("region", ""); + + return localArea; + } + + std::string getLanguage() + { + std::string localLanguage = ""; + + std::string cfgfile = ""; +#ifdef _WIN32 + wchar_t appDataPath[MAX_PATH] = {0}; + auto hr = SHGetFolderPathW(NULL, CSIDL_APPDATA, NULL, SHGFP_TYPE_CURRENT, appDataPath); + char* path = new char[MAX_PATH]; + size_t pathLength; + wcstombs_s(&pathLength, path, MAX_PATH, appDataPath, MAX_PATH); + std::string filePath = path; + cfgfile = filePath + "\\" + std::string("Snapmaker_Orca\\Snapmaker_Orca.conf"); +#elif __APPLE__ + const char* home_env = getenv("HOME"); + cfgfile = home_env; + cfgfile = versionFilePath + "/Library/Application Support/Snapmaker_Orca/Snapmaker_Orca.conf"; +#else + +#endif + std::ifstream json_file(cfgfile); + if (!json_file.is_open()) { + std::ifstream json_file(cfgfile); + return ""; + } + + nlohmann::json json_data; + json_file >> json_data; + + auto dataObj = json_data.value("app", nlohmann::json::object()); + localLanguage = dataObj.value("language", ""); + + return localLanguage; + } } \ No newline at end of file diff --git a/src/common_func/common_func.hpp b/src/common_func/common_func.hpp index 9303b4196f..8ad5eec3f7 100644 --- a/src/common_func/common_func.hpp +++ b/src/common_func/common_func.hpp @@ -25,6 +25,10 @@ namespace common std::string getMachineId(); + std::string getLocalArea(); + + std::string getLanguage(); + } // namespace common #endif \ No newline at end of file diff --git a/src/sentry_wrapper/SentryWrapper.cpp b/src/sentry_wrapper/SentryWrapper.cpp index de4dd86c6a..4657754836 100644 --- a/src/sentry_wrapper/SentryWrapper.cpp +++ b/src/sentry_wrapper/SentryWrapper.cpp @@ -55,10 +55,13 @@ static sentry_value_t on_crash_callback(const sentry_ucontext_t* uctx, sentry_va return event; } + static sentry_value_t before_send_log(sentry_value_t log, void* user_dataa) +{ + return log; + } + static sentry_value_t before_send(sentry_value_t event, void* hint, void* data) { - - sentry_value_t level_val = sentry_value_get_by_key(event, SENTRY_KEY_LEVEL); std::string levelName = sentry_value_as_string(level_val); @@ -198,8 +201,8 @@ void initSentryEx() sentry_options_set_debug(options, 0); #endif - // sentry_options_set_environment(options, "develop"); - sentry_options_set_environment(options, "Release"); + sentry_options_set_environment(options, "develop"); + //sentry_options_set_environment(options, "Release"); sentry_options_set_auto_session_tracking(options, 0); sentry_options_set_symbolize_stacktraces(options, 1); @@ -209,6 +212,10 @@ void initSentryEx() sentry_options_set_sample_rate(options, 1.0); sentry_options_set_traces_sample_rate(options, 1.0); + sentry_options_set_enable_logs(options, 1); + sentry_options_set_before_send_log(options, before_send_log, NULL); + sentry_options_set_logs_with_attributes(options, true); + sentry_init(options); sentry_start_session(); @@ -240,48 +247,67 @@ void sentryReportLogEx(SENTRY_LOG_LEVEL logLevel, const std::string& logTraceId) { sentry_level_t sentry_msg_level; - switch (logLevel) - { - case SENTRY_LOG_TRACE: - sentry_msg_level = SENTRY_LEVEL_TRACE; - break; - case SENTRY_LOG_DEBUG: - sentry_msg_level = SENTRY_LEVEL_DEBUG; - break; - case SENTRY_LOG_INFO: - sentry_msg_level = SENTRY_LEVEL_INFO; - break; - case SENTRY_LOG_WARNING: - sentry_msg_level = SENTRY_LEVEL_WARNING; - break; - case SENTRY_LOG_ERROR: - sentry_msg_level = SENTRY_LEVEL_ERROR; - break; - case SENTRY_LOG_FATAL: - sentry_msg_level = SENTRY_LEVEL_FATAL; - break; - default: - return; - } + sentry_value_t tags = sentry_value_new_object(); - sentry_value_t event = sentry_value_new_message_event(sentry_msg_level, - funcModule.c_str(), - logContent.c_str() - ); + if (!funcModule.empty()) + sentry_value_set_by_key(tags, "function_module", sentry_value_new_string(funcModule.c_str())); - sentry_value_t tags = sentry_value_new_object(); + if (!logTraceId.empty()) + sentry_value_set_by_key(tags, "snapmaker_trace_id", sentry_value_new_string(logTraceId.c_str())); - if (!logTraceId.empty()) - sentry_value_set_by_key(tags, "snapmaker_trace_id", sentry_value_new_string(logTraceId.c_str())); - - if (SENTRY_LEVEL_TRACE == sentry_msg_level) - sentry_value_set_by_key(tags, BURY_POINT, sentry_value_new_string("snapmaker_bury_point")); - if (!logTagKey.empty()) sentry_value_set_by_key(tags, logTagKey.c_str(), sentry_value_new_string(logTagValue.c_str())); - sentry_value_set_by_key(event, "snapmaker_tags", tags); - sentry_capture_event(event); + sentry_value_set_by_key(tags, "snapmaker_version", sentry_value_new_string(Snapmaker_VERSION)); + + std::string flutterVersion = common::get_flutter_version(); + if (!flutterVersion.empty()) + sentry_value_set_by_key(tags, "flutter_version", sentry_value_new_string(flutterVersion.c_str())); + + std::string pcName = common::get_pc_name(); + if (!pcName.empty()) + sentry_value_set_by_key(tags, "pc_name", sentry_value_new_string(pcName.c_str())); + + std::string machineID = common::getMachineId(); + if (!machineID.empty()) + sentry_value_set_by_key(tags, "machine_id", sentry_value_new_string(machineID.c_str())); + + std::string currentLanguage = common::getLanguage(); + if (!currentLanguage.empty()) + sentry_value_set_by_key(tags, "current_language", sentry_value_new_string(currentLanguage.c_str())); + + std::string localArea = common::getLocalArea(); + if (!localArea.empty()) + sentry_value_set_by_key(tags, "local_area", sentry_value_new_string(localArea.c_str())); + + switch (logLevel) { + case SENTRY_LOG_TRACE: + sentry_msg_level = SENTRY_LEVEL_TRACE; + sentry_value_set_by_key(tags, BURY_POINT, sentry_value_new_string("snapmaker_bury_point")); + sentry_log_trace(logContent.c_str(), tags, 3); + break; + case SENTRY_LOG_DEBUG: + sentry_msg_level = SENTRY_LEVEL_DEBUG; + sentry_log_debug(logContent.c_str(), tags, 3); + break; + case SENTRY_LOG_INFO: + sentry_msg_level = SENTRY_LEVEL_INFO; + sentry_log_info(logContent.c_str(), tags, 3); + break; + case SENTRY_LOG_WARNING: + sentry_msg_level = SENTRY_LEVEL_WARNING; + sentry_log_warn(logContent.c_str(), tags, 3); + break; + case SENTRY_LOG_ERROR: + sentry_msg_level = SENTRY_LEVEL_ERROR; + sentry_log_error(logContent.c_str(), tags, 3); + break; + case SENTRY_LOG_FATAL: + sentry_msg_level = SENTRY_LEVEL_FATAL; + sentry_log_fatal(logContent.c_str(), tags, 3); + break; + default: return; + } }