|
1 | 1 | {
|
| 2 | + pkgs, |
2 | 3 | lib,
|
3 | 4 | stdenv,
|
4 | 5 | fetchFromGitHub,
|
5 | 6 | postgresql,
|
6 | 7 | }:
|
| 8 | +let |
| 9 | + pname = "vector"; |
7 | 10 |
|
8 |
| -stdenv.mkDerivation rec { |
9 |
| - pname = "pgvector"; |
10 |
| - version = "0.8.0"; |
| 11 | + # Load version configuration from external file |
| 12 | + allVersions = (builtins.fromJSON (builtins.readFile ./versions.json)).${pname}; |
11 | 13 |
|
12 |
| - buildInputs = [ postgresql ]; |
| 14 | + # Filter versions compatible with current PostgreSQL version |
| 15 | + supportedVersions = lib.filterAttrs ( |
| 16 | + _: value: builtins.elem (lib.versions.major postgresql.version) value.postgresql |
| 17 | + ) allVersions; |
13 | 18 |
|
14 |
| - src = fetchFromGitHub { |
15 |
| - owner = "pgvector"; |
16 |
| - repo = pname; |
17 |
| - rev = "refs/tags/v${version}"; |
18 |
| - hash = "sha256-JsZV+I4eRMypXTjGmjCtMBXDVpqTIPHQa28ogXncE/Q="; |
19 |
| - }; |
| 19 | + # Derived version information |
| 20 | + versions = lib.naturalSort (lib.attrNames supportedVersions); |
| 21 | + latestVersion = lib.last versions; |
| 22 | + numberOfVersions = builtins.length versions; |
| 23 | + packages = builtins.attrValues ( |
| 24 | + lib.mapAttrs (name: value: build name value.hash) supportedVersions |
| 25 | + ); |
| 26 | + |
| 27 | + # Build function for individual versions |
| 28 | + build = |
| 29 | + version: hash: |
| 30 | + stdenv.mkDerivation rec { |
| 31 | + inherit pname version; |
| 32 | + |
| 33 | + buildInputs = [ postgresql ]; |
| 34 | + |
| 35 | + src = fetchFromGitHub { |
| 36 | + owner = "pgvector"; |
| 37 | + repo = "pgvector"; |
| 38 | + rev = "refs/tags/v${version}"; |
| 39 | + inherit hash; |
| 40 | + }; |
| 41 | + |
| 42 | + installPhase = '' |
| 43 | + mkdir -p $out/{lib,share/postgresql/extension} |
| 44 | +
|
| 45 | + # Install shared library with version suffix |
| 46 | + mv ${pname}${postgresql.dlSuffix} $out/lib/${pname}-${version}${postgresql.dlSuffix} |
| 47 | +
|
| 48 | + # Create version-specific control file |
| 49 | + sed -e "/^default_version =/d" \ |
| 50 | + -e "s|^module_pathname = .*|module_pathname = '\$libdir/${pname}'|" \ |
| 51 | + ${pname}.control > $out/share/postgresql/extension/${pname}--${version}.control |
| 52 | +
|
| 53 | + # Copy SQL file to install the specific version |
| 54 | + cp sql/${pname}.sql $out/share/postgresql/extension/${pname}--${version}.sql |
| 55 | +
|
| 56 | + # For the latest version, copy sql upgrade script, default control file and symlink |
| 57 | + if [[ "${version}" == "${latestVersion}" ]]; then |
| 58 | + cp sql/*.sql $out/share/postgresql/extension |
| 59 | + { |
| 60 | + echo "default_version = '${latestVersion}'" |
| 61 | + cat $out/share/postgresql/extension/${pname}--${latestVersion}.control |
| 62 | + } > $out/share/postgresql/extension/${pname}.control |
| 63 | + ln -sfn ${pname}-${latestVersion}${postgresql.dlSuffix} $out/lib/${pname}${postgresql.dlSuffix} |
| 64 | + fi |
20 | 65 |
|
21 |
| - installPhase = '' |
22 |
| - mkdir -p $out/{lib,share/postgresql/extension} |
| 66 | + runHook postInstall |
| 67 | + ''; |
23 | 68 |
|
24 |
| - cp *${postgresql.dlSuffix} $out/lib |
25 |
| - cp sql/*.sql $out/share/postgresql/extension |
26 |
| - cp *.control $out/share/postgresql/extension |
27 |
| - ''; |
| 69 | + meta = with lib; { |
| 70 | + description = "Open-source vector similarity search for Postgres"; |
| 71 | + homepage = "https://github.com/${src.owner}/${src.repo}"; |
| 72 | + maintainers = with maintainers; [ olirice ]; |
| 73 | + platforms = postgresql.meta.platforms; |
| 74 | + license = licenses.postgresql; |
| 75 | + }; |
| 76 | + }; |
| 77 | +in |
| 78 | +pkgs.buildEnv { |
| 79 | + name = pname; |
| 80 | + paths = packages; |
| 81 | + pathsToLink = [ |
| 82 | + "/lib" |
| 83 | + "/share/postgresql/extension" |
| 84 | + ]; |
28 | 85 |
|
29 |
| - meta = with lib; { |
30 |
| - description = "Open-source vector similarity search for Postgres"; |
31 |
| - homepage = "https://github.com/${src.owner}/${src.repo}"; |
32 |
| - maintainers = with maintainers; [ olirice ]; |
33 |
| - platforms = postgresql.meta.platforms; |
34 |
| - license = licenses.postgresql; |
| 86 | + passthru = { |
| 87 | + inherit versions numberOfVersions; |
| 88 | + pname = "${pname}-all"; |
| 89 | + version = |
| 90 | + "multi-" + lib.concatStringsSep "-" (map (v: lib.replaceStrings [ "." ] [ "-" ] v) versions); |
35 | 91 | };
|
36 | 92 | }
|
0 commit comments