2023-04-01 06:18:41 +03:00
|
|
|
#pragma once
|
|
|
|
///@file
|
|
|
|
|
2023-03-22 15:23:36 +02:00
|
|
|
#include "store-api.hh"
|
|
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
|
|
|
struct CommonSSHStoreConfig : virtual StoreConfig
|
|
|
|
{
|
|
|
|
using StoreConfig::StoreConfig;
|
|
|
|
|
2023-10-31 00:12:37 +02:00
|
|
|
const Setting<Path> sshKey{this, "", "ssh-key",
|
2023-03-22 15:23:36 +02:00
|
|
|
"Path to the SSH private key used to authenticate to the remote machine."};
|
|
|
|
|
2023-10-31 00:12:37 +02:00
|
|
|
const Setting<std::string> sshPublicHostKey{this, "", "base64-ssh-public-host-key",
|
2023-03-22 15:23:36 +02:00
|
|
|
"The public host key of the remote machine."};
|
|
|
|
|
2023-10-31 00:12:37 +02:00
|
|
|
const Setting<bool> compress{this, false, "compress",
|
2023-03-22 15:23:36 +02:00
|
|
|
"Whether to enable SSH compression."};
|
|
|
|
|
2023-10-31 00:12:37 +02:00
|
|
|
const Setting<std::string> remoteStore{this, "", "remote-store",
|
2023-03-22 15:23:36 +02:00
|
|
|
R"(
|
2023-12-01 00:07:09 +02:00
|
|
|
[Store URL](@docroot@/store/types/index.md#store-url-format)
|
2023-03-22 15:23:36 +02:00
|
|
|
to be used on the remote machine. The default is `auto`
|
|
|
|
(i.e. use the Nix daemon or `/nix/store` directly).
|
|
|
|
)"};
|
2024-01-25 17:31:52 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The `parseURL` function supports both IPv6 URIs as defined in
|
|
|
|
* RFC2732, but also pure addresses. The latter one is needed here to
|
|
|
|
* connect to a remote store via SSH (it's possible to do e.g. `ssh root@::1`).
|
|
|
|
*
|
|
|
|
* This function now ensures that a usable connection string is available:
|
|
|
|
*
|
|
|
|
* - If the store to be opened is not an SSH store, nothing will be done.
|
|
|
|
*
|
|
|
|
* - If the URL looks like `root@[::1]` (which is allowed by the URL parser and probably
|
|
|
|
* needed to pass further flags), it
|
|
|
|
* will be transformed into `root@::1` for SSH (same for `[::1]` -> `::1`).
|
|
|
|
*
|
|
|
|
* - If the URL looks like `root@::1` it will be left as-is.
|
|
|
|
*
|
|
|
|
* - In any other case, the string will be left as-is.
|
|
|
|
*
|
|
|
|
* Will throw an error if `connStr` is empty too.
|
|
|
|
*/
|
|
|
|
static std::string extractConnStr(
|
|
|
|
std::string_view scheme,
|
|
|
|
std::string_view connStr);
|
2023-03-22 15:23:36 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|