core/pkgs/build-support/fetchs3/default.nix

33 lines
937 B
Nix
Raw Normal View History

2024-05-02 00:46:19 +00:00
{ lib, runCommand, awscli }:
2024-05-13 21:24:10 +00:00
{ s3url, name ? builtins.baseNameOf s3url, sha256, region ? "us-east-1"
2024-05-02 00:46:19 +00:00
, credentials ? null # Default to looking at local EC2 metadata service
2024-05-13 21:24:10 +00:00
, recursiveHash ? false, postFetch ? null }:
2024-05-02 00:46:19 +00:00
let
mkCredentials = { access_key_id, secret_access_key, session_token ? null }: {
AWS_ACCESS_KEY_ID = access_key_id;
AWS_SECRET_ACCESS_KEY = secret_access_key;
AWS_SESSION_TOKEN = session_token;
};
2024-05-13 21:24:10 +00:00
credentialAttrs =
lib.optionalAttrs (credentials != null) (mkCredentials credentials);
2024-05-02 00:46:19 +00:00
in runCommand name ({
nativeBuildInputs = [ awscli ];
outputHashAlgo = "sha256";
outputHash = sha256;
outputHashMode = if recursiveHash then "recursive" else "flat";
preferLocalBuild = true;
AWS_DEFAULT_REGION = region;
} // credentialAttrs) (if postFetch != null then ''
downloadedFile="$(mktemp)"
aws s3 cp ${s3url} $downloadedFile
${postFetch}
2024-05-13 21:24:10 +00:00
'' else ''
2024-05-02 00:46:19 +00:00
aws s3 cp ${s3url} $out
'')