nix-super/src/nix/copy.cc

97 lines
2.7 KiB
C++
Raw Normal View History

#include "command.hh"
#include "shared.hh"
#include "store-api.hh"
#include "sync.hh"
2016-04-22 19:19:48 +03:00
#include "thread-pool.hh"
#include <atomic>
using namespace nix;
struct CmdCopy : StorePathsCommand
{
std::string srcUri, dstUri;
2017-08-14 16:24:04 +03:00
CheckSigsFlag checkSigs = CheckSigs;
2017-09-08 16:32:07 +03:00
SubstituteFlag substitute = NoSubstitute;
CmdCopy()
2017-09-27 19:28:54 +03:00
: StorePathsCommand(true)
{
mkFlag()
.longName("from")
.labels({"store-uri"})
.description("URI of the source Nix store")
.dest(&srcUri);
mkFlag()
.longName("to")
.labels({"store-uri"})
.description("URI of the destination Nix store")
.dest(&dstUri);
2017-08-14 16:24:04 +03:00
mkFlag()
.longName("no-check-sigs")
.description("do not require that paths are signed by trusted keys")
.set(&checkSigs, NoCheckSigs);
2017-09-08 16:32:07 +03:00
mkFlag()
.longName("substitute")
.shortName('s')
.description("whether to try substitutes on the destination store (only supported by SSH)")
.set(&substitute, Substitute);
}
std::string name() override
{
return "copy";
}
std::string description() override
{
return "copy paths between Nix stores";
}
Examples examples() override
{
return {
Example{
2017-09-08 12:33:46 +03:00
"To copy Firefox from the local store to a binary cache in file:///tmp/cache:",
"nix copy --to file:///tmp/cache $(type -p firefox)"
},
2017-09-08 12:33:46 +03:00
Example{
"To copy the entire current NixOS system closure to another machine via SSH:",
"nix copy --to ssh://server /run/current-system"
2017-09-08 12:33:46 +03:00
},
Example{
"To copy a closure from another machine via SSH:",
"nix copy --from ssh://server /nix/store/a6cnl93nk1wxnq84brbbwr6hxw9gp2w9-blender-2.79-rc2"
2017-09-08 12:33:46 +03:00
},
#ifdef ENABLE_S3
Example{
"To populate the current folder build output to a S3 binary cache:",
"nix copy --to s3://my-bucket?region=eu-west-1"
},
#endif
};
}
ref<Store> createStore() override
{
return srcUri.empty() ? StoreCommand::createStore() : openStore(srcUri);
}
void run(ref<Store> srcStore, Paths storePaths) override
{
if (srcUri.empty() && dstUri.empty())
throw UsageError("you must pass '--from' and/or '--to'");
ref<Store> dstStore = dstUri.empty() ? openStore() : openStore(dstUri);
2017-08-14 16:24:04 +03:00
copyPaths(srcStore, dstStore, PathSet(storePaths.begin(), storePaths.end()),
2017-09-08 16:32:07 +03:00
NoRepair, checkSigs, substitute);
}
};
static RegisterCommand r1(make_ref<CmdCopy>());