mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-09-11 07:15:54 +03:00
apache_datasketches: init at 1.6.0
PostgreSQL extension providing approximate algorithms for distinct item counts, quantile estimation and frequent items detection.
This commit is contained in:
parent
32630256f2
commit
aafe0f4314
@ -10674,6 +10674,12 @@
|
|||||||
githubId = 708570;
|
githubId = 708570;
|
||||||
name = "Manuel Mendez";
|
name = "Manuel Mendez";
|
||||||
};
|
};
|
||||||
|
mmusnjak = {
|
||||||
|
email = "marko.musnjak@gmail.com";
|
||||||
|
github = "mmusnjak";
|
||||||
|
githubId = 668956;
|
||||||
|
name = "Marko Mušnjak";
|
||||||
|
};
|
||||||
mnacamura = {
|
mnacamura = {
|
||||||
email = "m.nacamura@gmail.com";
|
email = "m.nacamura@gmail.com";
|
||||||
github = "mnacamura";
|
github = "mnacamura";
|
||||||
|
@ -614,6 +614,7 @@ in {
|
|||||||
postfix-raise-smtpd-tls-security-level = handleTest ./postfix-raise-smtpd-tls-security-level.nix {};
|
postfix-raise-smtpd-tls-security-level = handleTest ./postfix-raise-smtpd-tls-security-level.nix {};
|
||||||
postfixadmin = handleTest ./postfixadmin.nix {};
|
postfixadmin = handleTest ./postfixadmin.nix {};
|
||||||
postgis = handleTest ./postgis.nix {};
|
postgis = handleTest ./postgis.nix {};
|
||||||
|
apache_datasketches = handleTest ./apache_datasketches.nix {};
|
||||||
postgresql = handleTest ./postgresql.nix {};
|
postgresql = handleTest ./postgresql.nix {};
|
||||||
postgresql-jit = handleTest ./postgresql-jit.nix {};
|
postgresql-jit = handleTest ./postgresql-jit.nix {};
|
||||||
postgresql-wal-receiver = handleTest ./postgresql-wal-receiver.nix {};
|
postgresql-wal-receiver = handleTest ./postgresql-wal-receiver.nix {};
|
||||||
|
29
nixos/tests/apache_datasketches.nix
Normal file
29
nixos/tests/apache_datasketches.nix
Normal file
@ -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));'")
|
||||||
|
'';
|
||||||
|
})
|
71
pkgs/servers/sql/postgresql/ext/apache_datasketches.nix
Normal file
71
pkgs/servers/sql/postgresql/ext/apache_datasketches.nix
Normal file
@ -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 ];
|
||||||
|
};
|
||||||
|
})
|
@ -2,6 +2,8 @@ self: super: {
|
|||||||
|
|
||||||
age = super.callPackage ./ext/age.nix { };
|
age = super.callPackage ./ext/age.nix { };
|
||||||
|
|
||||||
|
apache_datasketches = super.callPackage ./ext/apache_datasketches.nix { };
|
||||||
|
|
||||||
jsonb_deep_sum = super.callPackage ./ext/jsonb_deep_sum.nix { };
|
jsonb_deep_sum = super.callPackage ./ext/jsonb_deep_sum.nix { };
|
||||||
|
|
||||||
periods = super.callPackage ./ext/periods.nix { };
|
periods = super.callPackage ./ext/periods.nix { };
|
||||||
|
Loading…
Reference in New Issue
Block a user