2021-04-01 10:22:51 +00:00
|
|
|
{ stdenv
|
|
|
|
, lib
|
|
|
|
, fetchFromGitHub
|
2022-10-08 00:53:23 +00:00
|
|
|
, fetchpatch
|
2021-04-01 10:22:51 +00:00
|
|
|
, rustPlatform
|
|
|
|
, pkg-config
|
2021-06-11 11:18:56 +00:00
|
|
|
, llvmPackages
|
|
|
|
, openssl
|
2021-04-01 10:22:51 +00:00
|
|
|
, protobuf
|
2021-06-11 11:18:56 +00:00
|
|
|
, rdkafka
|
|
|
|
, oniguruma
|
|
|
|
, zstd
|
2021-04-01 10:22:51 +00:00
|
|
|
, Security
|
|
|
|
, libiconv
|
|
|
|
, coreutils
|
|
|
|
, CoreServices
|
2021-06-11 11:18:56 +00:00
|
|
|
, tzdata
|
2021-12-30 12:51:28 +00:00
|
|
|
, cmake
|
2022-04-08 11:52:45 +00:00
|
|
|
, perl
|
2022-09-02 09:41:44 +00:00
|
|
|
# nix has a problem with the `?` in the feature list
|
|
|
|
# enabling kafka will produce a vector with no features at all
|
|
|
|
, enableKafka ? false
|
2022-10-14 16:04:35 +00:00
|
|
|
# TODO investigate adding "vrl-cli" and various "vendor-*"
|
2021-06-11 11:18:56 +00:00
|
|
|
# "disk-buffer" is using leveldb TODO: investigate how useful
|
|
|
|
# it would be, perhaps only for massive scale?
|
2022-12-03 14:44:31 +00:00
|
|
|
, features ? ([ "api" "api-client" "enrichment-tables" "sinks" "sources" "transforms" "vrl-cli" ]
|
2021-06-11 11:18:56 +00:00
|
|
|
# the second feature flag is passed to the rdkafka dependency
|
|
|
|
# building on linux fails without this feature flag (both x86_64 and AArch64)
|
2022-09-02 09:41:44 +00:00
|
|
|
++ lib.optionals enableKafka [ "rdkafka?/gssapi-vendored" ]
|
2021-11-16 00:19:01 +00:00
|
|
|
++ lib.optional stdenv.targetPlatform.isUnix "unix")
|
2023-01-19 22:41:40 +00:00
|
|
|
, nix-update-script
|
2019-10-28 05:35:02 +00:00
|
|
|
}:
|
|
|
|
|
2021-10-24 01:12:05 +00:00
|
|
|
let
|
2019-10-28 05:35:02 +00:00
|
|
|
pname = "vector";
|
2023-01-19 22:41:40 +00:00
|
|
|
version = "0.27.0";
|
2021-10-24 01:12:05 +00:00
|
|
|
in
|
|
|
|
rustPlatform.buildRustPackage {
|
|
|
|
inherit pname version;
|
2019-12-15 02:26:48 +00:00
|
|
|
|
2019-10-28 05:35:02 +00:00
|
|
|
src = fetchFromGitHub {
|
2022-06-20 04:22:29 +00:00
|
|
|
owner = "vectordotdev";
|
2021-04-01 10:22:51 +00:00
|
|
|
repo = pname;
|
|
|
|
rev = "v${version}";
|
2023-01-19 22:41:40 +00:00
|
|
|
sha256 = "sha256-+jap7cexevEky3H+Ct9LXXUwHR5tnbzdN+b13pv3f70=";
|
2019-10-28 05:35:02 +00:00
|
|
|
};
|
|
|
|
|
2023-01-19 22:41:40 +00:00
|
|
|
cargoSha256 = "sha256-KehBEwoz5N0zQLDk+9vwFSrn1TrVwljFj+asr7q7hmw=";
|
2022-04-08 11:52:45 +00:00
|
|
|
nativeBuildInputs = [ pkg-config cmake perl ];
|
2021-06-11 11:18:56 +00:00
|
|
|
buildInputs = [ oniguruma openssl protobuf rdkafka zstd ]
|
2021-08-07 10:07:36 +00:00
|
|
|
++ lib.optionals stdenv.isDarwin [ Security libiconv coreutils CoreServices ];
|
2019-10-28 05:35:02 +00:00
|
|
|
|
|
|
|
# needed for internal protobuf c wrapper library
|
2021-04-01 10:22:51 +00:00
|
|
|
PROTOC = "${protobuf}/bin/protoc";
|
|
|
|
PROTOC_INCLUDE = "${protobuf}/include";
|
2021-06-11 11:18:56 +00:00
|
|
|
RUSTONIG_SYSTEM_LIBONIG = true;
|
|
|
|
LIBCLANG_PATH = "${llvmPackages.libclang.lib}/lib";
|
2019-10-28 05:35:02 +00:00
|
|
|
|
2021-11-16 00:19:01 +00:00
|
|
|
TZDIR = "${tzdata}/share/zoneinfo";
|
|
|
|
|
2022-04-16 10:38:53 +00:00
|
|
|
# needed to dynamically link rdkafka
|
|
|
|
CARGO_FEATURE_DYNAMIC_LINKING=1;
|
|
|
|
|
2021-11-16 00:19:01 +00:00
|
|
|
buildNoDefaultFeatures = true;
|
|
|
|
buildFeatures = features;
|
|
|
|
|
2021-06-11 11:18:56 +00:00
|
|
|
# TODO investigate compilation failure for tests
|
2022-06-03 03:52:37 +00:00
|
|
|
# there are about 100 tests failing (out of 1100) for version 0.22.0
|
2022-04-23 16:00:18 +00:00
|
|
|
doCheck = false;
|
2021-11-16 00:19:01 +00:00
|
|
|
|
|
|
|
checkFlags = [
|
|
|
|
# tries to make a network access
|
|
|
|
"--skip=sinks::loki::tests::healthcheck_grafana_cloud"
|
|
|
|
|
|
|
|
# flaky on linux-aarch64
|
|
|
|
"--skip=kubernetes::api_watcher::tests::test_stream_errors"
|
|
|
|
|
|
|
|
# flaky on linux-x86_64
|
|
|
|
"--skip=sources::socket::test::tcp_with_tls_intermediate_ca"
|
|
|
|
"--skip=sources::host_metrics::cgroups::tests::generates_cgroups_metrics"
|
2022-01-26 12:53:10 +00:00
|
|
|
"--skip=sources::aws_kinesis_firehose::tests::aws_kinesis_firehose_forwards_events"
|
|
|
|
"--skip=sources::aws_kinesis_firehose::tests::aws_kinesis_firehose_forwards_events_gzip_request"
|
|
|
|
"--skip=sources::aws_kinesis_firehose::tests::handles_acknowledgement_failure"
|
2021-11-16 00:19:01 +00:00
|
|
|
];
|
2020-09-14 02:37:21 +00:00
|
|
|
|
|
|
|
# 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-10-23 12:09:39 +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-03-12 02:47:27 +00:00
|
|
|
postPatch = ''
|
2020-09-14 02:37:21 +00:00
|
|
|
substituteInPlace ./src/dns.rs \
|
2021-03-12 02:47:27 +00:00
|
|
|
--replace "#[tokio::test]" ""
|
2020-10-23 12:09:39 +00:00
|
|
|
|
|
|
|
${lib.optionalString (!builtins.elem "transforms-geoip" features) ''
|
|
|
|
substituteInPlace ./Cargo.toml --replace '"transforms-geoip",' ""
|
|
|
|
''}
|
2020-09-14 02:37:21 +00:00
|
|
|
'';
|
2019-10-28 05:35:02 +00:00
|
|
|
|
2022-12-17 18:16:34 +00:00
|
|
|
passthru = {
|
|
|
|
inherit features;
|
2023-01-19 22:41:40 +00:00
|
|
|
updateScript = nix-update-script { };
|
2022-12-17 18:16:34 +00:00
|
|
|
};
|
2021-03-12 02:47:27 +00:00
|
|
|
|
2021-01-11 07:54:33 +00:00
|
|
|
meta = with lib; {
|
2019-10-28 05:35:02 +00:00
|
|
|
description = "A high-performance logs, metrics, and events router";
|
2021-04-01 10:22:51 +00:00
|
|
|
homepage = "https://github.com/timberio/vector";
|
|
|
|
license = with licenses; [ asl20 ];
|
2020-11-30 07:34:53 +00:00
|
|
|
maintainers = with maintainers; [ thoughtpolice happysalada ];
|
2022-10-05 20:48:28 +00:00
|
|
|
platforms = with platforms; all;
|
2019-10-28 05:35:02 +00:00
|
|
|
};
|
|
|
|
}
|
2022-10-08 00:53:23 +00:00
|
|
|
|