diff --git a/maintainers/maintainer-list.nix b/maintainers/maintainer-list.nix index 1ec14715c782..83366767406b 100644 --- a/maintainers/maintainer-list.nix +++ b/maintainers/maintainer-list.nix @@ -10674,6 +10674,12 @@ githubId = 708570; name = "Manuel Mendez"; }; + mmusnjak = { + email = "marko.musnjak@gmail.com"; + github = "mmusnjak"; + githubId = 668956; + name = "Marko MuĆĄnjak"; + }; mnacamura = { email = "m.nacamura@gmail.com"; github = "mnacamura"; diff --git a/nixos/tests/all-tests.nix b/nixos/tests/all-tests.nix index beee97566606..e597a26f31bb 100644 --- a/nixos/tests/all-tests.nix +++ b/nixos/tests/all-tests.nix @@ -614,6 +614,7 @@ in { postfix-raise-smtpd-tls-security-level = handleTest ./postfix-raise-smtpd-tls-security-level.nix {}; postfixadmin = handleTest ./postfixadmin.nix {}; postgis = handleTest ./postgis.nix {}; + apache_datasketches = handleTest ./apache_datasketches.nix {}; postgresql = handleTest ./postgresql.nix {}; postgresql-jit = handleTest ./postgresql-jit.nix {}; postgresql-wal-receiver = handleTest ./postgresql-wal-receiver.nix {}; diff --git a/nixos/tests/apache_datasketches.nix b/nixos/tests/apache_datasketches.nix new file mode 100644 index 000000000000..2bf099ac7991 --- /dev/null +++ b/nixos/tests/apache_datasketches.nix @@ -0,0 +1,29 @@ +import ./make-test-python.nix ({ pkgs, ...} : { + name = "postgis"; + meta = with pkgs.lib.maintainers; { + maintainers = [ lsix ]; # TODO: Who's the maintener now? + }; + + nodes = { + master = + { pkgs, ... }: + + { + services.postgresql = let mypg = pkgs.postgresql_15; in { + enable = true; + package = mypg; + extraPlugins = with mypg.pkgs; [ + apache_datasketches + ]; + }; + }; + }; + + testScript = '' + start_all() + master.wait_for_unit("postgresql") + master.sleep(10) # Hopefully this is long enough!! + master.succeed("sudo -u postgres psql -c 'CREATE EXTENSION datasketches;'") + master.succeed("sudo -u postgres psql -c 'SELECT hll_sketch_to_string(hll_sketch_build(1));'") + ''; +}) diff --git a/pkgs/servers/sql/postgresql/ext/apache_datasketches.nix b/pkgs/servers/sql/postgresql/ext/apache_datasketches.nix new file mode 100644 index 000000000000..47873e725c4b --- /dev/null +++ b/pkgs/servers/sql/postgresql/ext/apache_datasketches.nix @@ -0,0 +1,71 @@ +{ stdenv, lib, fetchFromGitHub, postgresql, boost182, nixosTests }: + +stdenv.mkDerivation (finalAttrs: { + pname = "apache_datasketches"; + version = "1.6.0"; + + srcs = [ + ( fetchFromGitHub { + name = "datasketches-postgresql"; + owner = "apache"; + repo = "datasketches-postgresql"; + rev = "refs/tags/${finalAttrs.version}"; + hash = "sha256-sz94fIe7nyWhjiw8FAm6ZzVpB0sAK5YxUrtbaZt/guA="; + }) + ( fetchFromGitHub { + name = "datasketches-cpp"; + owner = "apache"; + repo = "datasketches-cpp"; + rev = "refs/tags/4.1.0"; + hash = "sha256-vPoFzRxOXlEAiiHH9M5S6255ahzaKsGNYS0cdHwrRYw="; + }) + ]; + sourceRoot = "datasketches-postgresql"; + + buildInputs = [ postgresql boost182 ]; + + patchPhase = '' + runHook prePatch + cp -r ../datasketches-cpp . + runHook postPatch + ''; + + installPhase = '' + runHook preInstall + install -D -m 644 ./datasketches.so -t $out/lib/ + cat \ + sql/datasketches_cpc_sketch.sql \ + sql/datasketches_kll_float_sketch.sql \ + sql/datasketches_kll_double_sketch.sql \ + sql/datasketches_theta_sketch.sql \ + sql/datasketches_frequent_strings_sketch.sql \ + sql/datasketches_hll_sketch.sql \ + sql/datasketches_aod_sketch.sql \ + sql/datasketches_req_float_sketch.sql \ + sql/datasketches_quantiles_double_sketch.sql \ + > sql/datasketches--${finalAttrs.version}.sql + install -D -m 644 ./datasketches.control -t $out/share/postgresql/extension + install -D -m 644 \ + ./sql/datasketches--${finalAttrs.version}.sql \ + ./sql/datasketches--1.3.0--1.4.0.sql \ + ./sql/datasketches--1.4.0--1.5.0.sql \ + ./sql/datasketches--1.5.0--1.6.0.sql \ + -t $out/share/postgresql/extension + runHook postInstall + ''; + + passthru.tests.apache_datasketches = nixosTests.apache_datasketches; + + meta = { + description = "PostgreSQL extension providing approximate algorithms for distinct item counts, quantile estimation and frequent items detection"; + longDescription = '' + apache_datasketches is an extension to support approximate algorithms on PostgreSQL. The implementation + is based on the Apache Datasketches CPP library, and provides support for HyperLogLog, + Compressed Probabilistic Counting, KLL, Frequent strings, and Theta sketches. + ''; + homepage = "https://datasketches.apache.org/"; + platforms = postgresql.meta.platforms; + license = lib.licenses.asl20; + maintainers = with lib.maintainers; [ mmusnjak ]; + }; +}) diff --git a/pkgs/servers/sql/postgresql/packages.nix b/pkgs/servers/sql/postgresql/packages.nix index c94b91f02e2b..8a8fd8cca563 100644 --- a/pkgs/servers/sql/postgresql/packages.nix +++ b/pkgs/servers/sql/postgresql/packages.nix @@ -2,6 +2,8 @@ self: super: { age = super.callPackage ./ext/age.nix { }; + apache_datasketches = super.callPackage ./ext/apache_datasketches.nix { }; + jsonb_deep_sum = super.callPackage ./ext/jsonb_deep_sum.nix { }; periods = super.callPackage ./ext/periods.nix { };