3#include <xrpld/app/main/DBInit.h>
4#include <xrpld/core/Config.h>
5#include <xrpld/core/SociDB.h>
7#include <xrpl/core/PerfLog.h>
9#include <boost/filesystem/path.hpp>
83 "xrpl::DatabaseCon::Setup::commonPragma : consistent global "
99 template <std::
size_t N, std::
size_t M>
108 setup.standAlone && setup.startUp !=
Config::LOAD && setup.startUp !=
Config::LOAD_FILE &&
109 setup.startUp !=
Config::REPLAY
111 : (setup.dataDir / dbName),
112 setup.commonPragma(),
120 template <std::
size_t N, std::
size_t M>
128 :
DatabaseCon(setup, dbName, pragma, initSQL, journal)
133 template <std::
size_t N, std::
size_t M>
135 boost::filesystem::path
const& dataDir,
140 :
DatabaseCon(dataDir / dbName, nullptr, pragma, initSQL, journal)
145 template <std::
size_t N, std::
size_t M>
147 boost::filesystem::path
const& dataDir,
153 :
DatabaseCon(dataDir, dbName, pragma, initSQL, journal)
169 using namespace std::chrono_literals;
180 template <std::
size_t N, std::
size_t M>
182 boost::filesystem::path
const& pPath,
191 for (
auto const& p : pragma)
193 soci::statement st =
session_->prepare << p;
199 for (
auto const& p : *commonPragma)
201 soci::statement st =
session_->prepare << p;
206 for (
auto const& sql : initSQL)
208 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.
DatabaseCon::Setup setup_DatabaseCon(Config const &c, std::optional< beast::Journal > j=std::nullopt)
@ 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
Config::StartUpType startUp
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