nixpkgs/pkgs/development/libraries/aws-sdk-cpp/default.nix

155 lines
4.9 KiB
Nix
Raw Normal View History

2022-04-19 05:52:02 +00:00
{ lib
, stdenv
, fetchFromGitHub
, cmake
, curl
, openssl
, zlib
2021-09-25 19:14:17 +00:00
, aws-crt-cpp
2022-04-19 05:52:02 +00:00
, CoreAudio
, AudioToolbox
, nix
, arrow-cpp
, aws-sdk-cpp
, # Allow building a limited set of APIs, e.g. ["s3" "ec2"].
apis ? ["*"]
, # Whether to enable AWS' custom memory management.
customMemoryManagement ? true
}:
2016-02-16 12:41:19 +00:00
let
host_os = if stdenv.hostPlatform.isDarwin then "APPLE"
else if stdenv.hostPlatform.isAndroid then "ANDROID"
else if stdenv.hostPlatform.isWindows then "WINDOWS"
else if stdenv.hostPlatform.isLinux then "LINUX"
else throw "Unknown host OS";
in
stdenv.mkDerivation rec {
pname = "aws-sdk-cpp";
2024-06-04 09:43:21 +00:00
version = "1.11.336";
2016-02-16 12:41:19 +00:00
src = fetchFromGitHub {
2022-01-07 12:03:43 +00:00
owner = "aws";
2016-02-16 12:41:19 +00:00
repo = "aws-sdk-cpp";
rev = version;
2024-06-04 09:43:21 +00:00
hash = "sha256-hetXtXM8HG6V3rAuyf+w+DtlxEcpsyaroZsw0nIJoAw=";
2016-02-16 12:41:19 +00:00
};
2021-09-25 19:14:17 +00:00
postPatch = ''
# Append the dev output to path hints in finding Aws.h to avoid
# having to pass `AWS_CORE_HEADER_FILE` explicitly to cmake configure
# when using find_package(AWSSDK CONFIG)
substituteInPlace cmake/AWSSDKConfig.cmake \
--replace 'C:/AWSSDK/''${AWSSDK_INSTALL_INCLUDEDIR}/aws/core' \
'C:/AWSSDK/''${AWSSDK_INSTALL_INCLUDEDIR}/aws/core"
"${placeholder "dev"}/include/aws/core'
# Avoid blanket -Werror to evade build failures on less
# tested compilers.
substituteInPlace cmake/compiler_settings.cmake \
--replace '"-Werror"' ' '
# Flaky on Hydra
rm tests/aws-cpp-sdk-core-tests/aws/auth/AWSCredentialsProviderTest.cpp
2023-05-24 22:59:04 +00:00
rm tests/aws-cpp-sdk-core-tests/aws/client/AWSClientTest.cpp
rm tests/aws-cpp-sdk-core-tests/aws/client/AwsConfigTest.cpp
2021-09-25 19:14:17 +00:00
# Includes aws-c-auth private headers, so only works with submodule build
rm tests/aws-cpp-sdk-core-tests/aws/auth/AWSAuthSignerTest.cpp
2021-09-25 19:14:17 +00:00
# TestRandomURLMultiThreaded fails
rm tests/aws-cpp-sdk-core-tests/http/HttpClientTest.cpp
'' + lib.optionalString stdenv.hostPlatform.isi686 ''
# EPSILON is exceeded
rm tests/aws-cpp-sdk-core-tests/aws/client/AdaptiveRetryStrategyTest.cpp
2021-09-25 19:14:17 +00:00
'';
2016-12-08 13:19:19 +00:00
# FIXME: might be nice to put different APIs in different outputs
# (e.g. libaws-cpp-sdk-s3.so in output "s3").
outputs = [ "out" "dev" ];
2017-12-10 15:14:24 +00:00
nativeBuildInputs = [ cmake curl ];
buildInputs = [
2021-06-04 09:41:19 +00:00
curl openssl zlib
] ++ lib.optionals (stdenv.hostPlatform.isDarwin &&
2017-11-13 06:34:59 +00:00
((builtins.elem "text-to-speech" apis) ||
(builtins.elem "*" apis)))
[ CoreAudio AudioToolbox ];
2016-02-16 12:41:19 +00:00
# propagation is needed for Security.framework to be available when linking
2021-10-20 06:59:07 +00:00
propagatedBuildInputs = [ aws-crt-cpp ];
cmakeFlags = [
"-DBUILD_DEPS=OFF"
] ++ lib.optional (!customMemoryManagement) "-DCUSTOM_MEMORY_MANAGEMENT=0"
++ lib.optionals (stdenv.buildPlatform != stdenv.hostPlatform) [
"-DENABLE_TESTING=OFF"
"-DCURL_HAS_H2=1"
"-DCURL_HAS_TLS_PROXY=1"
"-DTARGET_ARCH=${host_os}"
] ++ lib.optional (apis != ["*"])
"-DBUILD_ONLY=${lib.concatStringsSep ";" apis}";
env.NIX_CFLAGS_COMPILE = toString [
# openssl 3 generates several deprecation warnings
"-Wno-error=deprecated-declarations"
];
postFixupHooks = [
# This bodge is necessary so that the file that the generated -config.cmake file
# points to an existing directory.
"mkdir -p $out/include"
];
__darwinAllowLocalNetworking = true;
# Builds in 2+h with 2 cores, and ~10m with a big-parallel builder.
requiredSystemFeatures = [ "big-parallel" ];
passthru = {
tests = {
inherit nix arrow-cpp;
cmake-find-package = stdenv.mkDerivation {
pname = "aws-sdk-cpp-cmake-find-package-test";
version = "0";
dontUnpack = true;
nativeBuildInputs = [ cmake ];
buildInputs = [ aws-sdk-cpp ];
buildCommand = ''
cat > CMakeLists.txt <<'EOF'
find_package(AWSSDK)
EOF
# Intentionally not using 'cmakeConfigurePhase' to test that find_package works without it.
mkdir build && cd build
if output=$(cmake -Wno-dev .. 2>&1); then
if grep -Fw -- "Found AWS" - <<< "$output"; then
touch "$out"
else
echo "'Found AWS' not found in the cmake output!" >&2
echo "The output was:" >&2
echo "$output" >&2
exit 1
fi
else
echo -n "'cmake -Wno-dev ..'" >&2
echo " returned a non-zero exit code." >&2
echo "$output" >&2
exit 1
fi
'';
};
};
};
meta = with lib; {
description = "C++ interface for Amazon Web Services";
2022-01-07 12:03:43 +00:00
homepage = "https://github.com/aws/aws-sdk-cpp";
license = licenses.asl20;
platforms = platforms.unix;
tree-wide: remove eelco as maintainer from things he no longer maintains While preparing this change, I read the git blame on all of the files I touched. I saw a working lifetime of building this system which we use every day and love dearly and keep maintained ourselves. I saw commits from a 14 year range between 2003 to 2017!! I could not be more thankful for Eelco's work on building large parts of the foundation of nixpkgs that all of us rely on now. However, the end date of that range of the files I looked at the blame on was 2017. I did not see surviving code from any newer date than that. Looking at the Git logs, Eelco has been working on other things, and that's totally fine. However, it means that our maintenance metadata is out of date on a lot of packages, and *that*'s the reason I am submitting this change. There are a lot of packages that don't have anyone with their name on them to be pinged if they need attention, even if they have had recent activity (although it is never clear if recent activity was just someone fixing it because ZHF or because the package actually matters to them). There are a lot of packages with storied history that maybe don't need to be in the set anymore at all since they have not been touched in years; or maybe they are simply finished. Empty maintainer lists should be a sign that we need to figure out who maintains it or potentially remove it if it has rotted, and allowing the maintainer list to be empty if it is already not maintained is part of a healthy repository ecology. Either way, I would like to have the maintenance metadata not mislead anyone into sending Eelco emails about packages he doesn't, in practice, work on anymore. I have not removed his name from everything; there are some things that he is the upstream for or has worked on more recently, for instance, like Nix, which I have left alone.
2024-08-21 08:07:42 +00:00
maintainers = with maintainers; [ orivej ];
# building ec2 runs out of memory: cc1plus: out of memory allocating 33554372 bytes after a total of 74424320 bytes
broken = stdenv.buildPlatform.is32bit && ((builtins.elem "ec2" apis) || (builtins.elem "*" apis));
2016-02-16 12:41:19 +00:00
};
}