|
1 | 1 | {
|
| 2 | + pkgs, |
2 | 3 | lib,
|
3 | 4 | stdenv,
|
4 | 5 | fetchFromGitHub,
|
5 | 6 | postgresql,
|
6 | 7 | }:
|
7 | 8 |
|
8 |
| -stdenv.mkDerivation rec { |
| 9 | +let |
9 | 10 | pname = "pg_cron";
|
10 |
| - version = "1.6.4"; |
| 11 | + allVersions = (builtins.fromJSON (builtins.readFile ./versions.json)).${pname}; |
| 12 | + supportedVersions = lib.filterAttrs ( |
| 13 | + _: value: builtins.elem (lib.versions.major postgresql.version) value.postgresql |
| 14 | + ) allVersions; |
| 15 | + versions = lib.naturalSort (lib.attrNames supportedVersions); |
| 16 | + latestVersion = lib.last versions; |
| 17 | + numberOfVersions = builtins.length versions; |
| 18 | + build = |
| 19 | + version: versionData: |
| 20 | + stdenv.mkDerivation rec { |
| 21 | + inherit pname version; |
11 | 22 |
|
12 |
| - buildInputs = [ postgresql ]; |
| 23 | + buildInputs = [ postgresql ]; |
13 | 24 |
|
14 |
| - src = fetchFromGitHub { |
15 |
| - owner = "citusdata"; |
16 |
| - repo = pname; |
17 |
| - rev = "v${version}"; |
18 |
| - hash = "sha256-t1DpFkPiSfdoGG2NgNT7g1lkvSooZoRoUrix6cBID40="; |
19 |
| - }; |
| 25 | + src = fetchFromGitHub { |
| 26 | + owner = "citusdata"; |
| 27 | + repo = pname; |
| 28 | + rev = versionData.rev or "v${version}"; |
| 29 | + hash = versionData.hash; |
| 30 | + }; |
| 31 | + |
| 32 | + patches = map (p: ./. + "/${p}") (versionData.patches or [ ]); |
| 33 | + |
| 34 | + installPhase = '' |
| 35 | + mkdir -p $out/{lib,share/postgresql/extension} |
| 36 | +
|
| 37 | + # Install shared library with version suffix |
| 38 | + mv ${pname}${postgresql.dlSuffix} $out/lib/${pname}-${version}${postgresql.dlSuffix} |
| 39 | +
|
| 40 | + # Create version-specific control file |
| 41 | + sed -e "/^default_version =/d" \ |
| 42 | + -e "s|^module_pathname = .*|module_pathname = '\$libdir/${pname}-${version}'|" \ |
| 43 | + ${pname}.control > $out/share/postgresql/extension/${pname}--${version}.control |
20 | 44 |
|
21 |
| - installPhase = '' |
22 |
| - mkdir -p $out/{lib,share/postgresql/extension} |
| 45 | + # For the latest version, create default control file and symlink and copy SQL upgrade scripts |
| 46 | + if [[ "${version}" == "${latestVersion}" ]]; then |
| 47 | + { |
| 48 | + echo "default_version = '${version}'" |
| 49 | + cat $out/share/postgresql/extension/${pname}--${version}.control |
| 50 | + } > $out/share/postgresql/extension/${pname}.control |
| 51 | + ln -sfn ${pname}-${latestVersion}${postgresql.dlSuffix} $out/lib/${pname}${postgresql.dlSuffix} |
| 52 | + cp *.sql $out/share/postgresql/extension |
| 53 | + fi |
| 54 | + ''; |
23 | 55 |
|
24 |
| - cp *${postgresql.dlSuffix} $out/lib |
25 |
| - cp *.sql $out/share/postgresql/extension |
26 |
| - cp *.control $out/share/postgresql/extension |
27 |
| - ''; |
| 56 | + meta = with lib; { |
| 57 | + description = "Run Cron jobs through PostgreSQL"; |
| 58 | + homepage = "https://github.com/citusdata/pg_cron"; |
| 59 | + changelog = "https://github.com/citusdata/pg_cron/raw/v${version}/CHANGELOG.md"; |
| 60 | + platforms = postgresql.meta.platforms; |
| 61 | + license = licenses.postgresql; |
| 62 | + }; |
| 63 | + }; |
| 64 | + packages = builtins.attrValues (lib.mapAttrs (name: value: build name value) supportedVersions); |
| 65 | +in |
| 66 | +pkgs.buildEnv { |
| 67 | + name = pname; |
| 68 | + paths = packages; |
| 69 | + pathsToLink = [ |
| 70 | + "/lib" |
| 71 | + "/share/postgresql/extension" |
| 72 | + ]; |
28 | 73 |
|
29 |
| - meta = with lib; { |
30 |
| - description = "Run Cron jobs through PostgreSQL"; |
31 |
| - homepage = "https://github.com/citusdata/pg_cron"; |
32 |
| - changelog = "https://github.com/citusdata/pg_cron/raw/v${version}/CHANGELOG.md"; |
33 |
| - platforms = postgresql.meta.platforms; |
34 |
| - license = licenses.postgresql; |
| 74 | + passthru = { |
| 75 | + inherit versions numberOfVersions; |
| 76 | + pname = "${pname}-all"; |
| 77 | + version = |
| 78 | + "multi-" + lib.concatStringsSep "-" (map (v: lib.replaceStrings [ "." ] [ "-" ] v) versions); |
35 | 79 | };
|
36 | 80 | }
|
0 commit comments