Nix/src/libstore/remote-store.hh

162 lines
4.4 KiB
C++
Raw Normal View History

#pragma once
2006-11-30 19:35:50 +01:00
2016-02-23 16:40:16 +01:00
#include <limits>
2006-11-30 19:35:50 +01:00
#include <string>
#include "store-api.hh"
namespace nix {
class Pipe;
class Pid;
struct FdSink;
struct FdSource;
template<typename T> class Pool;
struct ConnectionHandle;
/* FIXME: RemoteStore is a misnomer - should be something like
DaemonStore. */
class RemoteStore : public virtual Store
2006-11-30 19:35:50 +01:00
{
public:
const Setting<int> maxConnections{(Store*) this, 1,
"max-connections", "maximum number of concurrent connections to the Nix daemon"};
const Setting<unsigned int> maxConnectionAge{(Store*) this, std::numeric_limits<unsigned int>::max(),
"max-connection-age", "number of seconds to reuse a connection"};
virtual bool sameMachine() = 0;
RemoteStore(const Params & params);
2006-11-30 19:35:50 +01:00
/* Implementations of abstract store API methods. */
bool isValidPathUncached(const StorePath & path) override;
2006-11-30 19:35:50 +01:00
StorePathSet queryValidPaths(const StorePathSet & paths,
SubstituteFlag maybeSubstitute = NoSubstitute) override;
StorePathSet queryAllValidPaths() override;
void queryPathInfoUncached(const StorePath & path,
Callback<std::shared_ptr<const ValidPathInfo>> callback) noexcept override;
2006-11-30 19:35:50 +01:00
void queryReferrers(const StorePath & path, StorePathSet & referrers) override;
StorePathSet queryValidDerivers(const StorePath & path) override;
StorePathSet queryDerivationOutputs(const StorePath & path) override;
StringSet queryDerivationOutputNames(const StorePath & path) override;
std::optional<StorePath> queryPathFromHashPart(const std::string & hashPart) override;
StorePathSet querySubstitutablePaths(const StorePathSet & paths) override;
void querySubstitutablePathInfos(const StorePathSet & paths,
2015-09-18 01:22:06 +02:00
SubstitutablePathInfos & infos) override;
void addToStore(const ValidPathInfo & info, Source & nar,
RepairFlag repair, CheckSigsFlag checkSigs,
2016-10-21 18:09:30 +02:00
std::shared_ptr<FSAccessor> accessor) override;
StorePath addToStore(const string & name, const Path & srcPath,
bool recursive = true, HashType hashAlgo = htSHA256,
PathFilter & filter = defaultPathFilter, RepairFlag repair = NoRepair) override;
2006-11-30 19:35:50 +01:00
StorePath addTextToStore(const string & name, const string & s,
const StorePathSet & references, RepairFlag repair) override;
2006-11-30 19:35:50 +01:00
void buildPaths(const std::vector<StorePathWithOutputs> & paths, BuildMode buildMode) override;
2006-11-30 19:35:50 +01:00
BuildResult buildDerivation(const StorePath & drvPath, const BasicDerivation & drv,
BuildMode buildMode) override;
void ensurePath(const StorePath & path) override;
2006-11-30 19:35:50 +01:00
void addTempRoot(const StorePath & path) override;
2015-09-18 01:22:06 +02:00
void addIndirectRoot(const Path & path) override;
2015-09-18 01:22:06 +02:00
void syncWithGC() override;
Roots findRoots(bool censor) override;
2015-09-18 01:22:06 +02:00
void collectGarbage(const GCOptions & options, GCResults & results) override;
2015-09-18 01:22:06 +02:00
void optimiseStore() override;
bool verifyStore(bool checkContents, RepairFlag repair) override;
void addSignatures(const StorePath & storePath, const StringSet & sigs) override;
void queryMissing(const std::vector<StorePathWithOutputs> & targets,
StorePathSet & willBuild, StorePathSet & willSubstitute, StorePathSet & unknown,
unsigned long long & downloadSize, unsigned long long & narSize) override;
void connect() override;
unsigned int getProtocol() override;
void flushBadConnections();
protected:
struct Connection
{
AutoCloseFD fd;
FdSink to;
FdSource from;
unsigned int daemonVersion;
std::chrono::time_point<std::chrono::steady_clock> startTime;
2016-09-02 20:31:38 +02:00
virtual ~Connection();
2016-02-23 16:40:16 +01:00
std::exception_ptr processStderr(Sink * sink = 0, Source * source = 0);
};
2006-12-04 14:28:14 +01:00
2017-03-03 19:35:34 +01:00
ref<Connection> openConnectionWrapper();
virtual ref<Connection> openConnection() = 0;
void initConnection(Connection & conn);
ref<Pool<Connection>> connections;
virtual void setOptions(Connection & conn);
ConnectionHandle getConnection();
friend struct ConnectionHandle;
private:
2017-03-03 19:35:34 +01:00
std::atomic_bool failed{false};
};
class UDSRemoteStore : public LocalFSStore, public RemoteStore
{
public:
UDSRemoteStore(const Params & params);
UDSRemoteStore(std::string path, const Params & params);
std::string getUri() override;
2019-11-26 21:07:44 +01:00
bool sameMachine() override
{ return true; }
private:
ref<RemoteStore::Connection> openConnection() override;
2019-02-12 13:43:32 +01:00
std::optional<std::string> path;
2006-11-30 19:35:50 +01:00
};
}