summaryrefslogtreecommitdiffstats
path: root/src/Daemon
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2010-01-27 13:28:46 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2010-01-27 13:28:46 +0100
commitf964da092f6191bd02754ee0dc786107d85d5a3e (patch)
tree0400560cc93f3d46e1d0f96a916c564f1762bde6 /src/Daemon
parent7ecc9f64d70cd5d6a9ebe5cc835c4950cc81c1ea (diff)
downloadabrt-f964da092f6191bd02754ee0dc786107d85d5a3e.tar.gz
abrt-f964da092f6191bd02754ee0dc786107d85d5a3e.tar.xz
abrt-f964da092f6191bd02754ee0dc786107d85d5a3e.zip
abrtd: set "Reported" status only if at least one reporter succeeded
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'src/Daemon')
-rw-r--r--src/Daemon/MiddleWare.cpp17
1 files changed, 11 insertions, 6 deletions
diff --git a/src/Daemon/MiddleWare.cpp b/src/Daemon/MiddleWare.cpp
index c56b7b1c..01c3850b 100644
--- a/src/Daemon/MiddleWare.cpp
+++ b/src/Daemon/MiddleWare.cpp
@@ -437,6 +437,7 @@ report_status_t Report(const map_crash_data_t& client_report,
key = analyzer;
}
+ bool at_least_one_reporter_succeeded = false;
report_status_t ret;
std::string message;
if (keyPtr != end)
@@ -485,6 +486,7 @@ report_status_t Report(const map_crash_data_t& client_report,
if (message != "")
message += "; ";
message += res;
+ at_least_one_reporter_succeeded = true;
}
}
catch (CABRTException& e)
@@ -493,13 +495,16 @@ report_status_t Report(const map_crash_data_t& client_report,
ret[plugin_name].push_back(e.what()); // REPORT_STATUS_IDX_MSG
update_client("Reporting via '%s' was not successful: %s", plugin_name, e.what());
}
- }
- }
+ } // for
+ } // if
- CDatabase* database = g_pPluginManager->GetDatabase(g_settings_sDatabase.c_str());
- database->Connect();
- database->SetReported(UUID, UID, message.c_str());
- database->DisConnect();
+ if (at_least_one_reporter_succeeded)
+ {
+ CDatabase* database = g_pPluginManager->GetDatabase(g_settings_sDatabase.c_str());
+ database->Connect();
+ database->SetReported(UUID, UID, message.c_str());
+ database->DisConnect();
+ }
return ret;
#undef client_report