2021-03-04 13:54:50 +01:00
|
|
|
{ lib, runCommand, awscli }:
|
2017-04-26 04:01:18 +02:00
|
|
|
|
|
|
|
{ s3url
|
2018-05-03 12:08:25 +02:00
|
|
|
, name ? builtins.baseNameOf s3url
|
2017-04-26 04:01:18 +02:00
|
|
|
, sha256
|
|
|
|
, region ? "us-east-1"
|
|
|
|
, credentials ? null # Default to looking at local EC2 metadata service
|
|
|
|
, recursiveHash ? false
|
|
|
|
, postFetch ? null
|
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
2018-05-03 12:08:25 +02:00
|
|
|
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;
|
2017-04-26 04:01:18 +02:00
|
|
|
};
|
2018-05-03 12:08:25 +02:00
|
|
|
|
2021-01-27 06:50:30 +01:00
|
|
|
credentialAttrs = lib.optionalAttrs (credentials != null) (mkCredentials credentials);
|
2018-05-03 12:08:25 +02:00
|
|
|
in runCommand name ({
|
2018-01-09 21:36:14 +01:00
|
|
|
nativeBuildInputs = [ awscli ];
|
2018-05-03 12:08:25 +02:00
|
|
|
|
2017-04-26 04:01:18 +02:00
|
|
|
outputHashAlgo = "sha256";
|
|
|
|
outputHash = sha256;
|
|
|
|
outputHashMode = if recursiveHash then "recursive" else "flat";
|
2018-05-03 12:08:25 +02:00
|
|
|
|
|
|
|
preferLocalBuild = true;
|
|
|
|
|
|
|
|
AWS_DEFAULT_REGION = region;
|
2017-04-26 04:01:18 +02:00
|
|
|
} // credentialAttrs) (if postFetch != null then ''
|
|
|
|
downloadedFile="$(mktemp)"
|
|
|
|
aws s3 cp ${s3url} $downloadedFile
|
|
|
|
${postFetch}
|
|
|
|
'' else ''
|
|
|
|
aws s3 cp ${s3url} $out
|
|
|
|
'')
|