2021-04-05 15:23:46 +00:00
|
|
|
{ stdenv
|
|
|
|
, lib
|
|
|
|
, fetchFromGitHub
|
|
|
|
, rustPlatform
|
|
|
|
, pkg-config
|
2021-06-28 23:13:55 +00:00
|
|
|
, llvmPackages
|
|
|
|
, openssl
|
2021-04-05 15:23:46 +00:00
|
|
|
, protobuf
|
2021-06-28 23:13:55 +00:00
|
|
|
, rdkafka
|
|
|
|
, oniguruma
|
|
|
|
, zstd
|
2021-04-05 15:23:46 +00:00
|
|
|
, Security
|
|
|
|
, libiconv
|
2020-10-11 12:50:04 +00:00
|
|
|
, coreutils
|
|
|
|
, CoreServices
|
2021-06-28 23:13:55 +00:00
|
|
|
, tzdata
|
|
|
|
# kafka is optional but one of the most used features
|
|
|
|
, enableKafka ? true
|
|
|
|
# TODO investigate adding "api" "api-client" "vrl-cli" and various "vendor-*"
|
|
|
|
# "disk-buffer" is using leveldb TODO: investigate how useful
|
|
|
|
# it would be, perhaps only for massive scale?
|
|
|
|
, features ? ([ "sinks" "sources" "transforms" ]
|
|
|
|
# the second feature flag is passed to the rdkafka dependency
|
|
|
|
# building on linux fails without this feature flag (both x86_64 and AArch64)
|
|
|
|
++ (lib.optionals enableKafka [ "rdkafka-plain" "rdkafka/dynamic_linking" ])
|
|
|
|
++ (lib.optional stdenv.targetPlatform.isUnix "unix"))
|
2020-04-24 23:36:52 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
rustPlatform.buildRustPackage rec {
|
|
|
|
pname = "vector";
|
2021-08-05 21:33:18 +00:00
|
|
|
version = "0.15.1";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
2021-04-05 15:23:46 +00:00
|
|
|
owner = "timberio";
|
|
|
|
repo = pname;
|
|
|
|
rev = "v${version}";
|
2021-08-05 21:33:18 +00:00
|
|
|
sha256 = "sha256-9Q0jRh8nlgiWslmlFAth8eff+hir5gIT8YL898FMSqk=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
2021-08-05 21:33:18 +00:00
|
|
|
cargoSha256 = "sha256-DFFA6t+ZgpGieq5kT80PW5ZSByIp54ia2UvcBYY2+Lg=";
|
2020-04-24 23:36:52 +00:00
|
|
|
nativeBuildInputs = [ pkg-config ];
|
2021-06-28 23:13:55 +00:00
|
|
|
buildInputs = [ oniguruma openssl protobuf rdkafka zstd ]
|
2021-04-05 15:23:46 +00:00
|
|
|
++ lib.optional stdenv.isDarwin [ Security libiconv coreutils CoreServices ];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# needed for internal protobuf c wrapper library
|
2021-04-05 15:23:46 +00:00
|
|
|
PROTOC = "${protobuf}/bin/protoc";
|
|
|
|
PROTOC_INCLUDE = "${protobuf}/include";
|
2021-06-28 23:13:55 +00:00
|
|
|
RUSTONIG_SYSTEM_LIBONIG = true;
|
|
|
|
LIBCLANG_PATH = "${llvmPackages.libclang.lib}/lib";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2021-04-05 15:23:46 +00:00
|
|
|
cargoBuildFlags = [ "--no-default-features" "--features" (lib.concatStringsSep "," features) ];
|
2021-06-28 23:13:55 +00:00
|
|
|
# TODO investigate compilation failure for tests
|
|
|
|
# dev dependency includes httpmock which depends on iashc which depends on curl-sys with http2 feature enabled
|
|
|
|
# compilation fails because of a missing http2 include
|
|
|
|
doCheck = !stdenv.isDarwin;
|
2020-10-11 12:50:04 +00:00
|
|
|
checkPhase = "TZDIR=${tzdata}/share/zoneinfo cargo test --no-default-features --features ${lib.concatStringsSep "," features} -- --test-threads 1";
|
|
|
|
|
|
|
|
# recent overhauls of DNS support in 0.9 mean that we try to resolve
|
|
|
|
# vector.dev during the checkPhase, which obviously isn't going to work.
|
|
|
|
# these tests in the DNS module are trivial though, so stubbing them out is
|
|
|
|
# fine IMO.
|
2020-11-12 09:05:59 +00:00
|
|
|
#
|
|
|
|
# the geoip transform yields maxmindb.so which contains references to rustc.
|
|
|
|
# neither figured out why the shared object is included in the output
|
|
|
|
# (it doesn't seem to be a runtime dependencies of the geoip transform),
|
|
|
|
# nor do I know why it depends on rustc.
|
|
|
|
# However, in order for the closure size to stay at a reasonable level,
|
|
|
|
# transforms-geoip is patched out of Cargo.toml for now - unless explicitly asked for.
|
2021-04-05 15:23:46 +00:00
|
|
|
postPatch = ''
|
2020-10-11 12:50:04 +00:00
|
|
|
substituteInPlace ./src/dns.rs \
|
2021-04-05 15:23:46 +00:00
|
|
|
--replace "#[tokio::test]" ""
|
2020-11-12 09:05:59 +00:00
|
|
|
|
|
|
|
${lib.optionalString (!builtins.elem "transforms-geoip" features) ''
|
|
|
|
substituteInPlace ./Cargo.toml --replace '"transforms-geoip",' ""
|
|
|
|
''}
|
2020-10-11 12:50:04 +00:00
|
|
|
'';
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2021-04-05 15:23:46 +00:00
|
|
|
passthru = { inherit features; };
|
|
|
|
|
2021-01-15 22:18:51 +00:00
|
|
|
meta = with lib; {
|
2020-04-24 23:36:52 +00:00
|
|
|
description = "A high-performance logs, metrics, and events router";
|
2021-04-05 15:23:46 +00:00
|
|
|
homepage = "https://github.com/timberio/vector";
|
|
|
|
license = with licenses; [ asl20 ];
|
2020-12-03 08:41:04 +00:00
|
|
|
maintainers = with maintainers; [ thoughtpolice happysalada ];
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
}
|