2019-10-03 20:15:15 +03:00
|
|
|
//
|
2020-01-01 04:23:48 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2020
|
2019-10-03 20:15:15 +03: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/SqliteConnectionSafe.h"
|
|
|
|
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
#include "td/utils/format.h"
|
|
|
|
#include "td/utils/logging.h"
|
2019-10-03 20:38:47 +03:00
|
|
|
#include "td/utils/port/Stat.h"
|
2019-10-03 20:15:15 +03:00
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
2020-08-14 17:48:43 +03:00
|
|
|
SqliteConnectionSafe::SqliteConnectionSafe(string path, DbKey key, optional<int32> cipher_version)
|
|
|
|
: path_(std::move(path))
|
|
|
|
, lsls_connection_([path = path_, key = std::move(key), cipher_version = std::move(cipher_version)] {
|
|
|
|
auto r_db = SqliteDb::open_with_key(path, key, cipher_version.copy());
|
2019-10-03 20:15:15 +03:00
|
|
|
if (r_db.is_error()) {
|
2019-10-03 20:38:47 +03:00
|
|
|
auto r_stat = stat(path);
|
|
|
|
if (r_stat.is_error()) {
|
2020-02-19 04:34:55 +03:00
|
|
|
LOG(FATAL) << "Can't open database (" << r_stat.error() << "): " << r_db.error();
|
2019-10-03 20:38:47 +03:00
|
|
|
} else {
|
2020-02-19 04:34:55 +03:00
|
|
|
LOG(FATAL) << "Can't open database of size " << r_stat.ok().size_ << ": " << r_db.error();
|
2019-10-03 20:38:47 +03:00
|
|
|
}
|
2019-10-03 20:15:15 +03:00
|
|
|
}
|
|
|
|
auto db = r_db.move_as_ok();
|
|
|
|
db.exec("PRAGMA synchronous=NORMAL").ensure();
|
|
|
|
db.exec("PRAGMA temp_store=MEMORY").ensure();
|
|
|
|
db.exec("PRAGMA secure_delete=1").ensure();
|
|
|
|
db.exec("PRAGMA recursive_triggers=1").ensure();
|
|
|
|
return db;
|
|
|
|
}) {
|
|
|
|
}
|
|
|
|
|
2020-08-14 17:11:58 +03:00
|
|
|
void SqliteConnectionSafe::set(SqliteDb &&db) {
|
|
|
|
lsls_connection_.set(std::move(db));
|
|
|
|
}
|
|
|
|
|
2019-10-03 20:15:15 +03:00
|
|
|
SqliteDb &SqliteConnectionSafe::get() {
|
|
|
|
return lsls_connection_.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
void SqliteConnectionSafe::close() {
|
2019-10-03 20:38:47 +03:00
|
|
|
LOG(INFO) << "Close SQLite database " << tag("path", path_);
|
2019-10-03 20:15:15 +03:00
|
|
|
lsls_connection_.clear_values();
|
|
|
|
}
|
|
|
|
|
|
|
|
void SqliteConnectionSafe::close_and_destroy() {
|
|
|
|
close();
|
2019-10-03 20:38:47 +03:00
|
|
|
LOG(INFO) << "Destroy SQLite database " << tag("path", path_);
|
|
|
|
SqliteDb::destroy(path_).ignore();
|
2019-10-03 20:15:15 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|