3#include <xrpl/core/PerfLog.h>
4#include <xrpl/core/ServiceRegistry.h>
5#include <xrpl/core/StartUpType.h>
6#include <xrpl/rdb/DBInit.h>
7#include <xrpl/rdb/SociDB.h>
9#include <boost/filesystem/path.hpp>
36 :
session_(std::move(rhs.session_)),
lock_(std::move(rhs.lock_))
85 "xrpl::DatabaseCon::Setup::commonPragma : consistent global "
101 template <std::
size_t N, std::
size_t M>
113 : (setup.dataDir / dbName),
114 setup.commonPragma(),
122 template <std::
size_t N, std::
size_t M>
130 :
DatabaseCon(setup, dbName, pragma, initSQL, journal)
135 template <std::
size_t N, std::
size_t M>
137 boost::filesystem::path
const& dataDir,
142 :
DatabaseCon(dataDir / dbName, nullptr, pragma, initSQL, journal)
147 template <std::
size_t N, std::
size_t M>
149 boost::filesystem::path
const& dataDir,
155 :
DatabaseCon(dataDir, dbName, pragma, initSQL, journal)
171 using namespace std::chrono_literals;
182 template <std::
size_t N, std::
size_t M>
184 boost::filesystem::path
const& pPath,
193 for (
auto const& p : pragma)
195 soci::statement st =
session_->prepare << p;
201 for (
auto const& p : *commonPragma)
203 soci::statement st =
session_->prepare << p;
208 for (
auto const& sql : initSQL)
210 soci::statement st =
session_->prepare << sql;
A generic endpoint for log messages.
DatabaseCon(boost::filesystem::path const &dataDir, std::string const &dbName, std::array< std::string, N > const &pragma, std::array< char const *, M > const &initSQL, beast::Journal journal)
void setupCheckpointing(JobQueue *, ServiceRegistry &)
DatabaseCon(boost::filesystem::path const &dataDir, std::string const &dbName, std::array< std::string, N > const &pragma, std::array< char const *, M > const &initSQL, CheckpointerSetup const &checkpointerSetup, beast::Journal journal)
std::shared_ptr< soci::session > const session_
std::shared_ptr< Checkpointer > checkpointer_
soci::session & getSession()
DatabaseCon(Setup const &setup, std::string const &dbName, std::array< std::string, N > const &pragma, std::array< char const *, M > const &initSQL, CheckpointerSetup const &checkpointerSetup, beast::Journal journal)
LockedSociSession checkoutDb()
DatabaseCon(Setup const &setup, std::string const &dbName, std::array< std::string, N > const &pragma, std::array< char const *, M > const &initSQL, beast::Journal journal)
DatabaseCon(boost::filesystem::path const &pPath, std::vector< std::string > const *commonPragma, std::array< std::string, N > const &pragma, std::array< char const *, M > const &initSQL, beast::Journal journal)
LockedSociSession::mutex lock_
A pool of threads to perform work.
std::shared_ptr< soci::session > session_
LockedSociSession(std::shared_ptr< soci::session > it, mutex &m)
soci::session * operator->()
LockedSociSession(LockedSociSession const &rhs)=delete
std::unique_lock< mutex > lock_
LockedSociSession & operator=(LockedSociSession const &rhs)=delete
LockedSociSession(LockedSociSession &&rhs) noexcept
LockedSociSession()=delete
soci::session & operator*()
Service registry for dependency injection.
auto measureDurationAndLog(Func &&func, std::string const &actionDescription, std::chrono::duration< Rep, Period > maxDelay, beast::Journal const &journal)
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
@ open
We haven't closed our ledger yet, but others might have.
std::shared_ptr< Checkpointer > checkpointerFromId(std::uintptr_t id)
std::reference_wrapper< ServiceRegistry > registry
std::array< std::string, 4 > txPragma
static std::unique_ptr< std::vector< std::string > const > globalPragma
boost::filesystem::path dataDir
std::array< std::string, 1 > lgrPragma
std::vector< std::string > const * commonPragma() const