diff options
author | zimbatm <zimbatm@zimbatm.com> | 2019-08-12 17:19:43 +0200 |
---|---|---|
committer | zimbatm <zimbatm@zimbatm.com> | 2019-08-16 15:05:45 +0200 |
commit | b226b5cd976ca71abb3c0861b56d5e5940430924 (patch) | |
tree | f0c33d03dc692f5d2108b78f2bd898206bf4dfe7 /src | |
parent | 91b00b145f0c50e346d0250168cbcbcba7aa3b40 (diff) |
nix-store: fix out of sync protocol
If a NAR is already in the store, addToStore doesn't read the source
which makes the protocol go out of sync. This happens for example when
two client try to nix-copy-closure the same derivation at the same time.
Diffstat (limited to 'src')
-rw-r--r-- | src/nix-store/nix-store.cc | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/src/nix-store/nix-store.cc b/src/nix-store/nix-store.cc index f324056bb..0cbceb02f 100644 --- a/src/nix-store/nix-store.cc +++ b/src/nix-store/nix-store.cc @@ -950,8 +950,16 @@ static void opServe(Strings opFlags, Strings opArgs) info.sigs = readStrings<StringSet>(in); in >> info.ca; - // FIXME: race if addToStore doesn't read source? - store->addToStore(info, in, NoRepair, NoCheckSigs); + if (info.narSize == 0) { + throw Error("narInfo is too old and missing the narSize field"); + } + + SizedSource sizedSource(in, info.narSize); + + store->addToStore(info, sizedSource, NoRepair, NoCheckSigs); + + // consume all the data that has been sent before continuing. + sizedSource.drainAll(); out << 1; // indicate success |