/* This file is part of TON Blockchain Library. TON Blockchain Library is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. TON Blockchain Library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with TON Blockchain Library. If not, see . */ #pragma once #include "td/db/KeyValueAsync.h" #include "tl-utils/common-utils.hpp" namespace db { using DbType = td::KeyValueAsync; template inline void db_get(DbType& db, td::Bits256 key, bool allow_not_found, td::Promise> promise) { db.get(key, [allow_not_found, promise = std::move(promise)](td::Result R) mutable { TRY_RESULT_PROMISE(promise, r, std::move(R)); if (r.status == td::KeyValueReader::GetStatus::NotFound) { if (allow_not_found) { promise.set_value(nullptr); } else { promise.set_error(td::Status::Error("Key not found")); } return; } promise.set_result(ton::fetch_tl_object(r.value, true)); }); } template inline td::Result> db_get(td::KeyValue& db, td::Bits256 key, bool allow_not_found) { std::string value; TRY_RESULT(r, db.get(key.as_slice(), value)); if (r == td::KeyValue::GetStatus::NotFound) { if (allow_not_found) { return nullptr; } else { return td::Status::Error("Key not found"); } } return ton::fetch_tl_object(td::Slice(value), true); } } // namespace db