159e378cbb
GitOrigin-RevId: c04d5652cfa9742b1d519688f65d1bbccea9eb7e
101 lines
2.8 KiB
Nix
101 lines
2.8 KiB
Nix
{
|
|
lib,
|
|
elasticsearch-curator,
|
|
fetchFromGitHub,
|
|
nix-update-script,
|
|
python3,
|
|
testers,
|
|
}:
|
|
|
|
python3.pkgs.buildPythonApplication rec {
|
|
pname = "elasticsearch-curator";
|
|
version = "8.0.16";
|
|
pyproject = true;
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "elastic";
|
|
repo = "curator";
|
|
rev = "refs/tags/v${version}";
|
|
hash = "sha256-nSBsLzem+eZBM0ebhW1Omh+pYYPYdly/VraM89iJe3E=";
|
|
};
|
|
|
|
pythonRelaxDeps = [ "es-client" ];
|
|
|
|
build-system = with python3.pkgs; [ hatchling ];
|
|
|
|
dependencies = with python3.pkgs; [
|
|
certifi
|
|
click
|
|
ecs-logging
|
|
elasticsearch8
|
|
es-client
|
|
pyyaml
|
|
six
|
|
voluptuous
|
|
];
|
|
|
|
nativeCheckInputs = with python3.pkgs; [
|
|
requests
|
|
pytestCheckHook
|
|
];
|
|
|
|
disabledTestPaths = [
|
|
# Test requires running elasticsearch
|
|
"tests/integration/test_alias.py"
|
|
"tests/integration/test_allocation.py"
|
|
"tests/integration/test_cli.py"
|
|
"tests/integration/test_close.py"
|
|
"tests/integration/test_clusterrouting.py"
|
|
"tests/integration/test_count_pattern.py"
|
|
"tests/integration/test_create_index.py"
|
|
"tests/integration/test_datemath.py"
|
|
"tests/integration/test_delete_indices.py"
|
|
"tests/integration/test_delete_snapshots.py"
|
|
"tests/integration/test_delete_snapshots.py"
|
|
"tests/integration/test_es_repo_mgr.py"
|
|
"tests/integration/test_forcemerge.py"
|
|
"tests/integration/test_integrations.py"
|
|
"tests/integration/test_open.py"
|
|
"tests/integration/test_reindex.py"
|
|
"tests/integration/test_replicas.py"
|
|
"tests/integration/test_restore.py"
|
|
"tests/integration/test_rollover.py"
|
|
"tests/integration/test_shrink.py"
|
|
"tests/integration/test_snapshot.py"
|
|
];
|
|
|
|
disabledTests = [
|
|
# Test require access network
|
|
"test_api_key_not_set"
|
|
"test_api_key_set"
|
|
];
|
|
|
|
passthru = {
|
|
tests.version = testers.testVersion {
|
|
package = elasticsearch-curator;
|
|
command = "${lib.getExe elasticsearch-curator} --version";
|
|
};
|
|
updateScript = nix-update-script { };
|
|
};
|
|
|
|
meta = with lib; {
|
|
description = "Curate, or manage, your Elasticsearch indices and snapshots";
|
|
homepage = "https://github.com/elastic/curator";
|
|
changelog = "https://github.com/elastic/curator/releases/tag/v${version}";
|
|
license = licenses.asl20;
|
|
longDescription = ''
|
|
Elasticsearch Curator helps you curate, or manage, your Elasticsearch
|
|
indices and snapshots by:
|
|
|
|
* Obtaining the full list of indices (or snapshots) from the cluster, as the
|
|
actionable list
|
|
|
|
* Iterate through a list of user-defined filters to progressively remove
|
|
indices (or snapshots) from this actionable list as needed.
|
|
|
|
* Perform various actions on the items which remain in the actionable list.
|
|
'';
|
|
mainProgram = "curator";
|
|
maintainers = with maintainers; [ basvandijk ];
|
|
};
|
|
}
|