#include "cynara_checker.hh"
#include "request_handler_factory.hh"
#include "server/database/db_handle_provider.hh"
+#include "server/database/remove_cache_db_handler.hh"
#include "utils/logging.hh"
#include "pkgmgrinfo_debug.h"
auto type = req->GetRequestType();
LOG(WARNING) << "Request type: " << pkgmgr_common::ReqTypeToString(type)
- << " pid: " << req->GetSenderPID();
+ << " pid: " << req->GetSenderPID() << " tid: " << req->GetSenderTID();
auto handler = factory.GetRequestHandler(type);
if (handler == nullptr)
continue;
handler->PreExec();
handler->SetUID(ConvertUID(req->GetSenderUID()));
handler->SetPID(req->GetSenderPID());
- if (!handler->HandleRequest(req->GetData(), req->GetSize(),
+ if (!handler->HandleRequest(req->DetachData(), req->GetSize(),
locale_.GetObject()))
LOG(ERROR) << "Failed to handle request";
- std::vector<uint8_t> result_data = handler->ExtractResult();
- if (req->SendData(result_data.data(), result_data.size()) == false)
+ if (req->SendData(handler->ExtractResult()) == false)
LOG(ERROR) << "Failed to send response pid: " << req->GetSenderPID();
else
- LOG(WARNING) << "Success response pid: " << req->GetSenderPID();
+ LOG(WARNING) << "Success response pid: " << req->GetSenderPID()
+ << " tid: " << req->GetSenderTID();
} catch (const std::exception& err) {
LOG(ERROR) << "Exception occurred: " << err.what()
<< ", pid: " << req->GetSenderPID();
h->timer_ = 0;
}
- if (database::DBHandleProvider::IsCrashedWriteRequest())
- database::DBHandleProvider::GetInst(getuid()).UnsetMemoryMode(getpid());
+ auto crashed_writer_pids =
+ database::DBHandleProvider::CrashedWriteRequestPIDs();
+ if (!crashed_writer_pids.empty()) {
+ database::RemoveCacheDBHandler db(getuid(), std::move(crashed_writer_pids));
+ db.SetLocale(h->locale_.GetObject());
+ db.Execute();
+ }
sqlite3_release_memory(-1);
malloc_trim(0);
0, pkgmgr_common::parcel::ParcelableType::Unknown, PMINFO_R_ERROR);
tizen_base::Parcel p;
p.WriteParcelable(parcelable);
- std::vector<uint8_t> raw = p.GetRaw();
- req->SendData(&raw[0], raw.size());
+ req->SendData(p);
}
} // namespace pkgmgr_server