diff --git a/services/backup/src/BackupServiceImpl.cpp b/services/backup/src/BackupServiceImpl.cpp --- a/services/backup/src/BackupServiceImpl.cpp +++ b/services/backup/src/BackupServiceImpl.cpp @@ -3,6 +3,7 @@ #include "CreateNewBackupReactor.h" #include "DatabaseManager.h" #include "PullBackupReactor.h" +#include "ReactorStatusHolder.h" #include "RecoverBackupKeyReactor.h" #include "SendLogReactor.h" @@ -80,6 +81,41 @@ std::shared_ptr logItem = database::DatabaseManager::getInstance().findLogItem(backupID, logID); logItem->addAttachmentHolders(holders); + if (!logItem->getPersistedInBlob() && + database::LogItem::getItemSize(logItem.get()) > + LOG_DATA_SIZE_DATABASE_LIMIT) { + std::string holder = tools::generateHolder( + logItem->getDataHash(), + logItem->getBackupID(), + logItem->getLogID()); + std::string data = std::move(logItem->getValue()); + logItem = std::make_shared( + logItem->getBackupID(), + logItem->getLogID(), + true, + holder, + logItem->getAttachmentHolders(), + logItem->getDataHash()); + // put into S3 + std::condition_variable blobPutDoneCV; + std::mutex blobPutDoneCVMutex; + std::shared_ptr putReactor = + std::make_shared( + holder, logItem->getDataHash(), &blobPutDoneCV); + ServiceBlobClient().put(putReactor); + std::unique_lock lockPut(blobPutDoneCVMutex); + putReactor->scheduleSendingDataChunk( + std::make_unique(std::move(data))); + putReactor->scheduleSendingDataChunk(std::make_unique("")); + if (putReactor->getStatusHolder()->state != + reactor::ReactorState::DONE) { + blobPutDoneCV.wait(lockPut); + } + if (!putReactor->getStatusHolder()->getStatus().ok()) { + throw std::runtime_error( + putReactor->getStatusHolder()->getStatus().error_message()); + } + } database::DatabaseManager::getInstance().putLogItem(*logItem); } } catch (std::runtime_error &e) {