2017-04-19 21:41:28 +02:00
|
|
|
# snippets that can be shared by multiple fetchers (pkgs/build-support)
|
2017-07-29 02:05:35 +02:00
|
|
|
{ lib }:
|
2024-09-15 15:33:50 +02:00
|
|
|
rec {
|
2016-09-17 21:50:01 +02:00
|
|
|
|
|
|
|
proxyImpureEnvVars = [
|
|
|
|
# We borrow these environment variables from the caller to allow
|
|
|
|
# easy proxy configuration. This is impure, but a fixed-output
|
|
|
|
# derivation like fetchurl is allowed to do so since its result is
|
|
|
|
# by definition pure.
|
|
|
|
"http_proxy" "https_proxy" "ftp_proxy" "all_proxy" "no_proxy"
|
2024-04-26 09:03:18 +02:00
|
|
|
"HTTP_PROXY" "HTTPS_PROXY" "FTP_PROXY" "ALL_PROXY" "NO_PROXY"
|
2023-11-28 12:15:40 +01:00
|
|
|
|
|
|
|
# https proxies typically need to inject custom root CAs too
|
|
|
|
"NIX_SSL_CERT_FILE"
|
2016-09-17 21:50:01 +02:00
|
|
|
];
|
|
|
|
|
2024-09-15 15:33:50 +02:00
|
|
|
/**
|
|
|
|
Converts an attrset containing one of `hash`, `sha256` or `sha512`,
|
|
|
|
into one containing `outputHash{,Algo}` as accepted by `mkDerivation`.
|
|
|
|
|
|
|
|
All other attributes in the set remain as-is.
|
|
|
|
|
|
|
|
# Example
|
|
|
|
|
|
|
|
```nix
|
|
|
|
normalizeHash { } { hash = lib.fakeHash; foo = "bar"; }
|
|
|
|
=>
|
|
|
|
{
|
|
|
|
outputHash = lib.fakeHash;
|
|
|
|
outputHashAlgo = null;
|
|
|
|
foo = "bar";
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
```nix
|
|
|
|
normalizeHash { } { sha256 = lib.fakeSha256; }
|
|
|
|
=>
|
|
|
|
{
|
|
|
|
outputHash = lib.fakeSha256;
|
|
|
|
outputHashAlgo = "sha256";
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
```nix
|
|
|
|
normalizeHash { } { sha512 = lib.fakeSha512; }
|
|
|
|
=>
|
|
|
|
{
|
|
|
|
outputHash = lib.fakeSha512;
|
|
|
|
outputHashAlgo = "sha512";
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
# Type
|
|
|
|
```
|
|
|
|
normalizeHash :: { hashTypes :: List String, required :: Bool } -> AttrSet -> AttrSet
|
|
|
|
```
|
|
|
|
|
|
|
|
# Arguments
|
|
|
|
|
|
|
|
hashTypes
|
|
|
|
: the set of attribute names accepted as hash inputs, in addition to `hash`
|
|
|
|
|
|
|
|
required
|
|
|
|
: whether to throw if no hash was present in the input; otherwise returns the original input, unmodified
|
|
|
|
*/
|
|
|
|
normalizeHash = {
|
|
|
|
hashTypes ? [ "sha256" ],
|
|
|
|
required ? true,
|
2024-09-16 11:05:29 +02:00
|
|
|
}:
|
2024-09-15 15:33:50 +02:00
|
|
|
let
|
2024-09-16 11:12:12 +02:00
|
|
|
inherit (lib) concatMapStringsSep const head tail throwIf;
|
|
|
|
inherit (lib.attrsets) attrsToList genAttrs intersectAttrs removeAttrs optionalAttrs;
|
|
|
|
|
2024-09-15 15:33:50 +02:00
|
|
|
hNames = [ "hash" ] ++ hashTypes;
|
2024-09-16 11:05:29 +02:00
|
|
|
hAttrs = genAttrs hNames (const {});
|
2024-09-15 15:33:50 +02:00
|
|
|
in
|
2024-09-16 11:05:29 +02:00
|
|
|
args:
|
|
|
|
if args ? "outputHash" then
|
|
|
|
args
|
|
|
|
else
|
|
|
|
let
|
|
|
|
# The argument hash, as a {name, value} pair
|
|
|
|
h =
|
|
|
|
let _h = attrsToList (intersectAttrs hAttrs args); in
|
|
|
|
if _h == [] then
|
|
|
|
throwIf required "fetcher called without `hash`" null
|
|
|
|
else if tail _h != [] then
|
|
|
|
throw "fetcher called with mutually-incompatible arguments: ${concatMapStringsSep ", " (a: a.name) _h}"
|
|
|
|
else
|
|
|
|
head _h
|
|
|
|
;
|
|
|
|
in
|
|
|
|
removeAttrs args hNames // (optionalAttrs (h != null) {
|
|
|
|
outputHash = h.value;
|
|
|
|
outputHashAlgo = if h.name == "hash" then null else h.name;
|
|
|
|
})
|
2024-09-15 15:33:50 +02:00
|
|
|
;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Wraps a function which accepts `outputHash{,Algo}` into one which accepts `hash` or `sha{256,512}`
|
|
|
|
|
|
|
|
# Example
|
|
|
|
```nix
|
|
|
|
withNormalizedHash { hashTypes = [ "sha256" "sha512" ]; } (
|
|
|
|
{ outputHash, outputHashAlgo, ... }:
|
|
|
|
...
|
|
|
|
)
|
|
|
|
```
|
|
|
|
is a function which accepts one of `hash`, `sha256`, or `sha512` (or the original's `outputHash` and `outputHashAlgo`).
|
|
|
|
|
|
|
|
Its `functionArgs` metadata only lists `hash` as a parameter, optional iff. `outputHash` was an optional parameter of
|
|
|
|
the original function. `sha256`, `sha512`, `outputHash`, or `outputHashAlgo` are not mentioned in the `functionArgs`
|
|
|
|
metadata.
|
|
|
|
|
|
|
|
# Type
|
|
|
|
```
|
|
|
|
withNormalizedHash :: { hashTypes :: List String } -> (AttrSet -> T) -> (AttrSet -> T)
|
|
|
|
```
|
|
|
|
|
|
|
|
# Arguments
|
|
|
|
|
|
|
|
hashTypes
|
|
|
|
: the set of attribute names accepted as hash inputs, in addition to `hash`
|
|
|
|
: they must correspond to a valid value for `outputHashAlgo`, currently one of: `md5`, `sha1`, `sha256`, or `sha512`.
|
|
|
|
|
|
|
|
f
|
|
|
|
: the function to be wrapped
|
|
|
|
|
|
|
|
::: {.note}
|
|
|
|
In nixpkgs, `mkDerivation` rejects MD5 `outputHash`es, and SHA-1 is being deprecated.
|
|
|
|
|
|
|
|
As such, there is no reason to add `md5` to `hashTypes`, and
|
|
|
|
`sha1` should only ever be included for backwards compatibility.
|
|
|
|
:::
|
|
|
|
|
|
|
|
# Output
|
|
|
|
|
|
|
|
`withNormalizedHash { inherit hashTypes; } f` is functionally equivalent to
|
|
|
|
```nix
|
|
|
|
args: f (normalizeHash {
|
|
|
|
inherit hashTypes;
|
|
|
|
required = !(lib.functionArgs f).outputHash;
|
|
|
|
} args)
|
|
|
|
```
|
|
|
|
|
|
|
|
However, `withNormalizedHash` preserves `functionArgs` metadata insofar as possible,
|
|
|
|
and is implemented somewhat more efficiently.
|
|
|
|
*/
|
|
|
|
withNormalizedHash = {
|
|
|
|
hashTypes ? [ "sha256" ]
|
|
|
|
}: fetcher:
|
|
|
|
let
|
2024-09-16 11:12:12 +02:00
|
|
|
inherit (lib.attrsets) genAttrs intersectAttrs removeAttrs;
|
|
|
|
inherit (lib.trivial) const functionArgs setFunctionArgs;
|
|
|
|
|
2024-09-15 15:33:50 +02:00
|
|
|
hAttrs = genAttrs ([ "hash" ] ++ hashTypes) (const {});
|
|
|
|
fArgs = functionArgs fetcher;
|
2024-09-16 11:05:29 +02:00
|
|
|
|
|
|
|
normalize = normalizeHash {
|
|
|
|
inherit hashTypes;
|
|
|
|
required = !fArgs.outputHash;
|
|
|
|
};
|
2024-09-15 15:33:50 +02:00
|
|
|
in
|
|
|
|
# The o.g. fetcher must *only* accept outputHash and outputHashAlgo
|
2024-09-15 23:07:57 +02:00
|
|
|
assert fArgs ? outputHash && fArgs ? outputHashAlgo;
|
2024-09-15 15:33:50 +02:00
|
|
|
assert intersectAttrs fArgs hAttrs == {};
|
|
|
|
|
|
|
|
setFunctionArgs
|
2024-09-16 11:05:29 +02:00
|
|
|
(args: fetcher (normalize args))
|
|
|
|
(removeAttrs fArgs [ "outputHash" "outputHashAlgo" ] // { hash = fArgs.outputHash; });
|
2016-09-17 21:50:01 +02:00
|
|
|
}
|