2023-07-15 17:15:38 +00:00
|
|
|
{ stdenv
|
|
|
|
, lib
|
|
|
|
, fetchFromGitHub
|
|
|
|
, rustPlatform
|
|
|
|
, nix-update-script
|
|
|
|
, protobuf
|
2023-11-16 04:20:00 +00:00
|
|
|
, rust-jemalloc-sys
|
2023-07-15 17:15:38 +00:00
|
|
|
, Security
|
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
|
|
|
pname = "quickwit";
|
2024-04-21 15:54:59 +00:00
|
|
|
version = "0.8.0";
|
2023-07-15 17:15:38 +00:00
|
|
|
in
|
2023-08-04 22:07:22 +00:00
|
|
|
rustPlatform.buildRustPackage rec {
|
2023-07-15 17:15:38 +00:00
|
|
|
inherit pname version;
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "quickwit-oss";
|
|
|
|
repo = pname;
|
|
|
|
rev = "v${version}";
|
2024-04-21 15:54:59 +00:00
|
|
|
hash = "sha256-FZVGQfDuQYIdRnCsBZvXeLbJBdcLugZeHNm+kf6L9SY=";
|
2023-07-15 17:15:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
postPatch = ''
|
|
|
|
substituteInPlace ./quickwit-ingest/build.rs \
|
2024-04-21 15:54:59 +00:00
|
|
|
--replace-fail '.with_protos' '.with_includes(&["."]).with_protos'
|
2023-07-15 17:15:38 +00:00
|
|
|
substituteInPlace ./quickwit-codegen/example/build.rs \
|
2024-04-21 15:54:59 +00:00
|
|
|
--replace-fail '.with_protos' '.with_includes(&["."]).with_protos'
|
2023-10-09 19:29:22 +00:00
|
|
|
substituteInPlace ./quickwit-proto/build.rs \
|
2024-04-21 15:54:59 +00:00
|
|
|
--replace-fail '.with_protos' '.with_includes(&["."]).with_protos'
|
2023-07-15 17:15:38 +00:00
|
|
|
'';
|
|
|
|
|
2023-08-04 22:07:22 +00:00
|
|
|
sourceRoot = "${src.name}/quickwit";
|
2023-07-15 17:15:38 +00:00
|
|
|
|
2023-11-16 04:20:00 +00:00
|
|
|
buildInputs = [
|
|
|
|
rust-jemalloc-sys
|
|
|
|
] ++ lib.optionals stdenv.isDarwin [ Security ];
|
2023-07-15 17:15:38 +00:00
|
|
|
|
|
|
|
cargoLock = {
|
|
|
|
lockFile = ./Cargo.lock;
|
|
|
|
outputHashes = {
|
2024-04-21 15:54:59 +00:00
|
|
|
"chitchat-0.8.0" = "sha256-cjwKaBXoztYUXgnJvtFH+OSQU6tl2U3zKFWX324+9wo=";
|
|
|
|
"mrecordlog-0.4.0" = "sha256-9LIVs+BqK9FLSfHL3vm9LL+/FXIXJ6v617QLv4luQik=";
|
|
|
|
"ownedbytes-0.6.0" = "sha256-in18/NYYIgUiZ9sm8NgJlebWidRp34DR7AhOD1Nh0aw=";
|
2023-07-15 17:15:38 +00:00
|
|
|
"pulsar-5.0.2" = "sha256-j7wpsAro6x4fk3pvSL4fxLkddJFq8duZ7jDj0Edf3YQ=";
|
|
|
|
"sasl2-sys-0.1.20+2.1.28" = "sha256-u4BsfmTDFxuY3i1amLCsr7MDv356YPThMHclura0Sxs=";
|
2023-10-09 19:29:22 +00:00
|
|
|
"whichlang-0.1.0" = "sha256-7AvLGjtWHjG0TnZdg9p5D+O0H19uo2sqPxJMn6mOU0k=";
|
2023-07-15 17:15:38 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# needed for internal protobuf c wrapper library
|
|
|
|
PROTOC = "${protobuf}/bin/protoc";
|
|
|
|
PROTOC_INCLUDE = "${protobuf}/include";
|
|
|
|
|
|
|
|
passthru.updateScript = nix-update-script { };
|
|
|
|
|
|
|
|
checkFlags = [
|
|
|
|
# tries to make a network access
|
|
|
|
"--skip=test_all_local_index"
|
|
|
|
"--skip=test_cmd_create"
|
|
|
|
"--skip=test_cmd_create_no_index_uri"
|
|
|
|
"--skip=test_cmd_search_aggregation"
|
|
|
|
"--skip=test_cmd_search_with_snippets"
|
|
|
|
"--skip=test_delete_index_cli"
|
|
|
|
"--skip=test_delete_index_cli_dry_run"
|
|
|
|
"--skip=test_ingest_docs_cli"
|
|
|
|
"--skip=test_ingest_docs_cli_keep_cache"
|
|
|
|
"--skip=test_search_index_cli"
|
|
|
|
"--skip=test_garbage_collect_cli_no_grace"
|
|
|
|
"--skip=actors::indexing_service::tests::test_indexing_service_spawn_observe_detach"
|
|
|
|
"--skip=object_storage::s3_compatible_storage::tests::test_s3_compatible_storage_relative_path"
|
|
|
|
# flaky test
|
|
|
|
"--skip=actors::indexer::tests::test_indexer_triggers_commit_on_drained_mailbox"
|
|
|
|
"--skip=actors::indexer::tests::test_indexer_partitioning"
|
|
|
|
"--skip=actors::indexing_pipeline::tests::test_merge_pipeline_does_not_stop_on_indexing_pipeline_failure"
|
2023-08-04 22:07:22 +00:00
|
|
|
"--skip=actors::indexer::tests::test_indexer_triggers_commit_on_target_num_docs"
|
2023-10-09 19:29:22 +00:00
|
|
|
"--skip=actors::packager::tests::test_packager_simple"
|
2023-07-15 17:15:38 +00:00
|
|
|
# fail on darwin for some reason
|
|
|
|
"--skip=io::tests::test_controlled_writer_limited_async"
|
|
|
|
"--skip=io::tests::test_controlled_writer_limited_sync"
|
|
|
|
];
|
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
description = "Sub-second search & analytics engine on cloud storage";
|
|
|
|
homepage = "https://quickwit.io/";
|
|
|
|
license = licenses.agpl3Only;
|
|
|
|
maintainers = with maintainers; [ happysalada ];
|
|
|
|
platforms = platforms.all;
|
|
|
|
};
|
|
|
|
}
|