3#include <xrpl/core/PerfLog.h>
4#include <xrpl/core/StartUpType.h>
5#include <xrpl/rdb/DBInit.h>
6#include <xrpl/rdb/SociDB.h>
8#include <boost/filesystem/path.hpp>
82 "xrpl::DatabaseCon::Setup::commonPragma : consistent global "
98 template <std::
size_t N, std::
size_t M>
110 : (setup.dataDir / dbName),
111 setup.commonPragma(),
119 template <std::
size_t N, std::
size_t M>
127 :
DatabaseCon(setup, dbName, pragma, initSQL, journal)
132 template <std::
size_t N, std::
size_t M>
134 boost::filesystem::path
const& dataDir,
139 :
DatabaseCon(dataDir / dbName, nullptr, pragma, initSQL, journal)
144 template <std::
size_t N, std::
size_t M>
146 boost::filesystem::path
const& dataDir,
152 :
DatabaseCon(dataDir, dbName, pragma, initSQL, journal)
168 using namespace std::chrono_literals;
179 template <std::
size_t N, std::
size_t M>
181 boost::filesystem::path
const& pPath,
190 for (
auto const& p : pragma)
192 soci::statement st =
session_->prepare << p;
198 for (
auto const& p : *commonPragma)
200 soci::statement st =
session_->prepare << p;
205 for (
auto const& sql : initSQL)
207 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)
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_
void setupCheckpointing(JobQueue *, Logs &)
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*()
Manages partitions for logging.
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::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