mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-15 18:56:16 +02:00
470c0501eb
In particular `local://<path>` and `unix://` (without any path) now work, and mean the same things as `local` and `daemon`, respectively. We thus now have the opportunity to desguar `local` and `daemon` early. This will allow me to make a change to https://github.com/NixOS/nix/pull/9839 requested during review to desugar those earlier. Co-authored-by: Théophane Hufschmitt <7226587+thufschmitt@users.noreply.github.com>
68 lines
1.4 KiB
C++
68 lines
1.4 KiB
C++
#pragma once
|
|
///@file
|
|
|
|
#include "sync.hh"
|
|
#include "processes.hh"
|
|
#include "file-system.hh"
|
|
|
|
namespace nix {
|
|
|
|
class SSHMaster
|
|
{
|
|
private:
|
|
|
|
const std::string host;
|
|
bool fakeSSH;
|
|
const std::string keyFile;
|
|
const std::string sshPublicHostKey;
|
|
const bool useMaster;
|
|
const bool compress;
|
|
const int logFD;
|
|
|
|
struct State
|
|
{
|
|
#ifndef _WIN32 // TODO re-enable on Windows, once we can start processes.
|
|
Pid sshMaster;
|
|
#endif
|
|
std::unique_ptr<AutoDelete> tmpDir;
|
|
Path socketPath;
|
|
};
|
|
|
|
Sync<State> state_;
|
|
|
|
void addCommonSSHOpts(Strings & args);
|
|
bool isMasterRunning();
|
|
|
|
#ifndef _WIN32 // TODO re-enable on Windows, once we can start processes.
|
|
Path startMaster();
|
|
#endif
|
|
|
|
public:
|
|
|
|
SSHMaster(
|
|
std::string_view host,
|
|
std::string_view keyFile,
|
|
std::string_view sshPublicHostKey,
|
|
bool useMaster, bool compress, int logFD = -1);
|
|
|
|
struct Connection
|
|
{
|
|
#ifndef _WIN32 // TODO re-enable on Windows, once we can start processes.
|
|
Pid sshPid;
|
|
#endif
|
|
AutoCloseFD out, in;
|
|
};
|
|
|
|
/**
|
|
* @param command The command (arg vector) to execute.
|
|
*
|
|
* @param extraSShArgs Extra args to pass to SSH (not the command to
|
|
* execute). Will not be used when "fake SSHing" to the local
|
|
* machine.
|
|
*/
|
|
std::unique_ptr<Connection> startCommand(
|
|
Strings && command,
|
|
Strings && extraSshArgs = {});
|
|
};
|
|
|
|
}
|