mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-11 00:36:20 +02:00
5db358d4d7
This makes it consistent with the Nixpkgs fetchurl and makes it work in chroots. We don't need verification because the hash of the result is checked anyway.
30 lines
947 B
C++
30 lines
947 B
C++
#include "builtins.hh"
|
||
#include "download.hh"
|
||
|
||
namespace nix {
|
||
|
||
void builtinFetchurl(const BasicDerivation & drv)
|
||
{
|
||
auto url = drv.env.find("url");
|
||
if (url == drv.env.end()) throw Error("attribute ‘url’ missing");
|
||
printMsg(lvlInfo, format("downloading ‘%1%’...") % url->second);
|
||
|
||
/* No need to do TLS verification, because we check the hash of
|
||
the result anyway. */
|
||
DownloadOptions options;
|
||
options.verifyTLS = false;
|
||
|
||
auto data = downloadFile(url->second, options); // FIXME: show progress
|
||
|
||
auto out = drv.env.find("out");
|
||
if (out == drv.env.end()) throw Error("attribute ‘url’ missing");
|
||
writeFile(out->second, data.data);
|
||
|
||
auto executable = drv.env.find("executable");
|
||
if (executable != drv.env.end() && executable->second == "1") {
|
||
if (chmod(out->second.c_str(), 0755) == -1)
|
||
throw SysError(format("making ‘%1%’ executable") % out->second);
|
||
}
|
||
}
|
||
|
||
}
|