2018-12-31 20:04:05 +01:00
|
|
|
//
|
2021-01-01 13:57:46 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2021
|
2018-12-31 20:04:05 +01:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#include "td/db/detail/RawSqliteDb.h"
|
|
|
|
|
|
|
|
#include "sqlite/sqlite3.h"
|
|
|
|
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
#include "td/utils/logging.h"
|
|
|
|
#include "td/utils/port/path.h"
|
2018-06-07 21:56:03 +02:00
|
|
|
#include "td/utils/port/Stat.h"
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
namespace td {
|
|
|
|
namespace detail {
|
2018-06-26 01:43:11 +02:00
|
|
|
|
2020-02-19 02:34:55 +01:00
|
|
|
Status RawSqliteDb::last_error(sqlite3 *db, CSlice path) {
|
|
|
|
return Status::Error(PSLICE() << Slice(sqlite3_errmsg(db)) << " for database \"" << path << '"');
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
2018-06-26 01:43:11 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
Status RawSqliteDb::destroy(Slice path) {
|
2018-06-07 21:56:03 +02:00
|
|
|
Status error;
|
|
|
|
with_db_path(path, [&](auto path) {
|
|
|
|
unlink(path).ignore();
|
|
|
|
if (!stat(path).is_error()) {
|
2020-02-19 02:34:55 +01:00
|
|
|
error = Status::Error(PSLICE() << "Failed to delete file \"" << path << '"');
|
2018-06-07 21:56:03 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
return error;
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
2018-06-26 01:43:11 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
Status RawSqliteDb::last_error() {
|
|
|
|
//If database was corrupted, try to delete it.
|
|
|
|
auto code = sqlite3_errcode(db_);
|
|
|
|
if (code == SQLITE_CORRUPT) {
|
|
|
|
destroy(path_).ignore();
|
|
|
|
}
|
|
|
|
|
2020-02-19 02:34:55 +01:00
|
|
|
return last_error(db_, path());
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
2018-06-26 01:43:11 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
RawSqliteDb::~RawSqliteDb() {
|
|
|
|
auto rc = sqlite3_close(db_);
|
2020-02-19 02:34:55 +01:00
|
|
|
LOG_IF(FATAL, rc != SQLITE_OK) << last_error(db_, path());
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace detail
|
|
|
|
} // namespace td
|