nixpkgs/pkgs/tools/admin/elasticsearch-curator/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

86 lines
2.1 KiB
Nix
Raw Normal View History

2022-05-05 04:20:19 +00:00
{ lib, fetchFromGitHub, python3 }:
let
2022-05-05 04:20:19 +00:00
python = python3.override {
packageOverrides = self: super: {
click = super.click.overridePythonAttrs (old: rec {
version = "7.1.2";
src = old.src.override {
inherit version;
hash = "sha256-0rUlXHxjSbwb0eWeCM0SrLvWPOZJ8liHVXg6qU37axo=";
2022-05-05 04:20:19 +00:00
};
});
requests-aws4auth = super.requests-aws4auth.overridePythonAttrs (old: {
doCheck = false; # requires click>=8.0
});
};
};
2022-05-05 04:20:19 +00:00
in python.pkgs.buildPythonApplication rec {
pname = "elasticsearch-curator";
2022-05-05 04:20:19 +00:00
version = "5.8.4";
format = "setuptools";
src = fetchFromGitHub {
owner = "elastic";
repo = "curator";
rev = "v${version}";
2022-05-05 04:20:19 +00:00
hash = "sha256-wSfd52jebUkgF5xhjcoUjI7j46eJF33pVb4Wrybq44g=";
};
2022-05-05 04:20:19 +00:00
postPatch = ''
substituteInPlace setup.cfg \
--replace "urllib3==1.26.4" "urllib3"
substituteInPlace setup.py \
--replace "urllib3==1.26.4" "urllib3" \
--replace "pyyaml==5.4.1" "pyyaml"
'';
2022-05-05 04:20:19 +00:00
propagatedBuildInputs = with python.pkgs; [
elasticsearch
2022-05-05 04:20:19 +00:00
urllib3
requests
boto3
2022-05-05 04:20:19 +00:00
requests-aws4auth
click
pyyaml
voluptuous
certifi
six
];
nativeCheckInputs = with python.pkgs; [
mock
2022-05-05 04:20:19 +00:00
pytestCheckHook
];
2022-05-05 04:20:19 +00:00
disabledTestPaths = [
"test/integration" # requires running elasticsearch
];
disabledTests = [
# access network
"test_api_key_not_set"
"test_api_key_set"
];
2019-09-06 14:10:39 +00:00
meta = with lib; {
homepage = "https://github.com/elastic/curator";
description = "Curate, or manage, your Elasticsearch indices and snapshots";
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.
'';
maintainers = with maintainers; [ basvandijk ];
};
}