2015-07-28 12:37:27 -07:00
|
|
|
let
|
|
|
|
|
2019-01-26 09:46:57 -08:00
|
|
|
generic =
|
|
|
|
# dependencies
|
|
|
|
{ stdenv, lib, fetchurl, makeWrapper
|
2017-02-01 19:28:17 -08:00
|
|
|
, glibc, zlib, readline, openssl, openssl_1_0_2, icu, systemd, libossp_uuid
|
2019-01-26 09:46:57 -08:00
|
|
|
, pkgconfig, libxml2, tzdata
|
|
|
|
|
2019-07-21 12:13:06 -07:00
|
|
|
# This is important to obtain a version of `libpq` that does not depend on systemd.
|
2019-07-22 20:08:28 -07:00
|
|
|
, enableSystemd ? (lib.versionAtLeast version "9.6" && !stdenv.isDarwin)
|
2019-07-21 12:13:06 -07:00
|
|
|
|
2019-01-26 09:46:57 -08:00
|
|
|
# for postgreql.pkgs
|
|
|
|
, this, self, newScope, buildEnv
|
|
|
|
|
|
|
|
# source specification
|
|
|
|
, version, sha256, psqlSchema
|
|
|
|
}:
|
2018-12-07 21:32:26 -08:00
|
|
|
let
|
|
|
|
atLeast = lib.versionAtLeast version;
|
|
|
|
icuEnabled = atLeast "10";
|
2019-01-26 09:46:57 -08:00
|
|
|
|
|
|
|
in stdenv.mkDerivation rec {
|
2019-08-15 05:41:18 -07:00
|
|
|
pname = "postgresql";
|
2018-11-27 11:16:21 -08:00
|
|
|
inherit version;
|
2015-07-28 12:37:27 -07:00
|
|
|
|
|
|
|
src = fetchurl {
|
2019-08-15 05:41:18 -07:00
|
|
|
url = "mirror://postgresql/source/v${version}/${pname}-${version}.tar.bz2";
|
2015-07-28 12:37:27 -07:00
|
|
|
inherit sha256;
|
|
|
|
};
|
|
|
|
|
2017-09-27 12:48:39 -07:00
|
|
|
outputs = [ "out" "lib" "doc" "man" ];
|
2015-10-13 20:47:54 -07:00
|
|
|
setOutputFlags = false; # $out retains configureFlags :-/
|
2015-07-28 12:37:27 -07:00
|
|
|
|
|
|
|
buildInputs =
|
2017-02-01 19:28:17 -08:00
|
|
|
[ zlib readline libxml2 makeWrapper ]
|
2018-12-07 21:32:26 -08:00
|
|
|
++ lib.optionals icuEnabled [ icu ]
|
2019-07-21 12:13:06 -07:00
|
|
|
++ lib.optionals enableSystemd [ systemd ]
|
2017-02-01 19:28:17 -08:00
|
|
|
++ [ (if atLeast "9.5" then openssl else openssl_1_0_2) ]
|
2015-07-28 12:37:27 -07:00
|
|
|
++ lib.optionals (!stdenv.isDarwin) [ libossp_uuid ];
|
|
|
|
|
2018-12-07 21:32:26 -08:00
|
|
|
nativeBuildInputs = lib.optionals icuEnabled [ pkgconfig ];
|
|
|
|
|
2018-11-27 12:13:23 -08:00
|
|
|
enableParallelBuilding = !stdenv.isDarwin;
|
2015-07-28 12:37:27 -07:00
|
|
|
|
2019-05-30 19:30:15 -07:00
|
|
|
buildFlags = [ "world" ];
|
2015-07-28 12:37:27 -07:00
|
|
|
|
2018-07-30 20:23:17 -07:00
|
|
|
NIX_CFLAGS_COMPILE = [ "-I${libxml2.dev}/include/libxml2" ];
|
|
|
|
|
2018-08-19 00:07:00 -07:00
|
|
|
# Otherwise it retains a reference to compiler and fails; see #44767. TODO: better.
|
2018-08-20 01:07:27 -07:00
|
|
|
preConfigure = "CC=${stdenv.cc.targetPrefix}cc";
|
2018-08-19 00:07:00 -07:00
|
|
|
|
2015-10-13 20:47:54 -07:00
|
|
|
configureFlags = [
|
|
|
|
"--with-openssl"
|
2017-07-15 06:58:17 -07:00
|
|
|
"--with-libxml"
|
2015-10-13 20:47:54 -07:00
|
|
|
"--sysconfdir=/etc"
|
|
|
|
"--libdir=$(lib)/lib"
|
2018-08-11 11:06:13 -07:00
|
|
|
"--with-system-tzdata=${tzdata}/share/zoneinfo"
|
2019-07-21 12:13:06 -07:00
|
|
|
(lib.optionalString enableSystemd "--with-systemd")
|
2018-08-02 13:22:42 -07:00
|
|
|
(if stdenv.isDarwin then "--with-uuid=e2fs" else "--with-ossp-uuid")
|
2018-12-07 21:32:26 -08:00
|
|
|
] ++ lib.optionals icuEnabled [ "--with-icu" ];
|
2015-07-28 12:37:27 -07:00
|
|
|
|
|
|
|
patches =
|
2018-08-06 08:17:49 -07:00
|
|
|
[ (if atLeast "9.4" then ./patches/disable-resolve_symlinks-94.patch else ./patches/disable-resolve_symlinks.patch)
|
|
|
|
(if atLeast "9.6" then ./patches/less-is-more-96.patch else ./patches/less-is-more.patch)
|
|
|
|
(if atLeast "9.6" then ./patches/hardcode-pgxs-path-96.patch else ./patches/hardcode-pgxs-path.patch)
|
|
|
|
./patches/specify_pkglibdir_at_runtime.patch
|
2019-05-30 19:30:15 -07:00
|
|
|
./patches/findstring.patch
|
2019-03-16 04:28:20 -07:00
|
|
|
] ++ lib.optional stdenv.isLinux ./patches/socketdir-in-run.patch;
|
2015-07-28 12:37:27 -07:00
|
|
|
|
|
|
|
installTargets = [ "install-world" ];
|
|
|
|
|
|
|
|
LC_ALL = "C";
|
|
|
|
|
2016-05-14 17:37:10 -07:00
|
|
|
postConfigure =
|
2016-11-22 13:48:18 -08:00
|
|
|
let path = if atLeast "9.6" then "src/common/config_info.c" else "src/bin/pg_config/pg_config.c"; in
|
|
|
|
''
|
|
|
|
# Hardcode the path to pgxs so pg_config returns the path in $out
|
2017-09-27 12:48:39 -07:00
|
|
|
substituteInPlace "${path}" --replace HARDCODED_PGXS_PATH $out/lib
|
2016-11-22 13:48:18 -08:00
|
|
|
'';
|
2016-05-14 17:37:10 -07:00
|
|
|
|
2015-07-28 12:37:27 -07:00
|
|
|
postInstall =
|
|
|
|
''
|
2017-09-27 12:48:39 -07:00
|
|
|
moveToOutput "lib/pgxs" "$out" # looks strange, but not deleting it
|
2019-10-03 16:00:00 -07:00
|
|
|
moveToOutput "lib/libpgcommon*.a" "$out"
|
|
|
|
moveToOutput "lib/libpgport*.a" "$out"
|
2015-12-02 01:03:23 -08:00
|
|
|
moveToOutput "lib/libecpg*" "$out"
|
2015-10-13 20:47:54 -07:00
|
|
|
|
2017-09-27 12:48:39 -07:00
|
|
|
# Prevent a retained dependency on gcc-wrapper.
|
|
|
|
substituteInPlace "$out/lib/pgxs/src/Makefile.global" --replace ${stdenv.cc}/bin/ld ld
|
|
|
|
|
2018-01-11 06:19:46 -08:00
|
|
|
if [ -z "''${dontDisableStatic:-}" ]; then
|
|
|
|
# Remove static libraries in case dynamic are available.
|
2019-02-18 17:31:09 -08:00
|
|
|
for i in $out/lib/*.a $lib/lib/*.a; do
|
2018-01-11 06:19:46 -08:00
|
|
|
name="$(basename "$i")"
|
2018-11-27 17:33:57 -08:00
|
|
|
ext="${stdenv.hostPlatform.extensions.sharedLibrary}"
|
|
|
|
if [ -e "$lib/lib/''${name%.a}$ext" ] || [ -e "''${i%.a}$ext" ]; then
|
2018-01-11 06:19:46 -08:00
|
|
|
rm "$i"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
2015-07-28 12:37:27 -07:00
|
|
|
'';
|
|
|
|
|
2018-01-11 20:27:55 -08:00
|
|
|
postFixup = lib.optionalString (!stdenv.isDarwin && stdenv.hostPlatform.libc == "glibc")
|
2016-11-22 13:48:18 -08:00
|
|
|
''
|
|
|
|
# initdb needs access to "locale" command from glibc.
|
|
|
|
wrapProgram $out/bin/initdb --prefix PATH ":" ${glibc.bin}/bin
|
|
|
|
'';
|
|
|
|
|
2019-06-05 21:18:38 -07:00
|
|
|
doCheck = !stdenv.isDarwin;
|
2019-05-12 12:40:22 -07:00
|
|
|
# autodetection doesn't seem to able to find this, but it's there.
|
|
|
|
checkTarget = "check";
|
|
|
|
|
2018-04-24 20:20:18 -07:00
|
|
|
doInstallCheck = false; # needs a running daemon?
|
|
|
|
|
2015-07-28 12:37:27 -07:00
|
|
|
disallowedReferences = [ stdenv.cc ];
|
|
|
|
|
|
|
|
passthru = {
|
2019-01-26 09:46:57 -08:00
|
|
|
inherit readline psqlSchema version;
|
|
|
|
|
|
|
|
pkgs = let
|
|
|
|
scope = { postgresql = this; };
|
|
|
|
newSelf = self // scope;
|
|
|
|
newSuper = { callPackage = newScope (scope // this.pkgs); };
|
|
|
|
in import ./packages.nix newSelf newSuper;
|
|
|
|
|
|
|
|
withPackages = postgresqlWithPackages {
|
|
|
|
inherit makeWrapper buildEnv;
|
|
|
|
postgresql = this;
|
|
|
|
}
|
|
|
|
this.pkgs;
|
2015-07-28 12:37:27 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
meta = with lib; {
|
2018-11-02 11:31:20 -07:00
|
|
|
homepage = https://www.postgresql.org;
|
2015-07-28 12:37:27 -07:00
|
|
|
description = "A powerful, open source object-relational database system";
|
2018-11-02 11:31:20 -07:00
|
|
|
license = licenses.postgresql;
|
2019-08-20 10:36:05 -07:00
|
|
|
maintainers = with maintainers; [ ocharles thoughtpolice danbst globin ];
|
2018-11-02 11:31:20 -07:00
|
|
|
platforms = platforms.unix;
|
2018-12-17 07:33:18 -08:00
|
|
|
knownVulnerabilities = optional (!atLeast "9.4")
|
|
|
|
"PostgreSQL versions older than 9.4 are not maintained anymore!";
|
2015-07-28 12:37:27 -07:00
|
|
|
};
|
2019-01-26 09:46:57 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
postgresqlWithPackages = { postgresql, makeWrapper, buildEnv }: pkgs: f: buildEnv {
|
|
|
|
name = "postgresql-and-plugins-${postgresql.version}";
|
|
|
|
paths = f pkgs ++ [
|
|
|
|
postgresql
|
|
|
|
postgresql.lib
|
|
|
|
postgresql.man # in case user installs this into environment
|
|
|
|
];
|
|
|
|
buildInputs = [ makeWrapper ];
|
|
|
|
|
|
|
|
# We include /bin to ensure the $out/bin directory is created, which is
|
|
|
|
# needed because we'll be removing the files from that directory in postBuild
|
|
|
|
# below. See #22653
|
|
|
|
pathsToLink = ["/" "/bin"];
|
|
|
|
|
2019-07-21 12:05:41 -07:00
|
|
|
# Note: the duplication of executables is about 4MB size.
|
|
|
|
# So a nicer solution was patching postgresql to allow setting the
|
|
|
|
# libdir explicitely.
|
2019-01-26 09:46:57 -08:00
|
|
|
postBuild = ''
|
|
|
|
mkdir -p $out/bin
|
|
|
|
rm $out/bin/{pg_config,postgres,pg_ctl}
|
|
|
|
cp --target-directory=$out/bin ${postgresql}/bin/{postgres,pg_config,pg_ctl}
|
|
|
|
wrapProgram $out/bin/postgres --set NIX_PGLIBDIR $out/lib
|
|
|
|
'';
|
|
|
|
};
|
2015-07-28 12:37:27 -07:00
|
|
|
|
2019-02-02 12:56:52 -08:00
|
|
|
in self: {
|
2015-07-28 12:37:27 -07:00
|
|
|
|
2019-02-02 12:56:52 -08:00
|
|
|
postgresql_9_5 = self.callPackage generic {
|
2019-08-09 04:30:33 -07:00
|
|
|
version = "9.5.19";
|
2016-01-08 07:47:03 -08:00
|
|
|
psqlSchema = "9.5";
|
2019-08-09 04:30:33 -07:00
|
|
|
sha256 = "1cqvbsyfs9048wbvdv0vhhaksjyjqv2vvh6ij4vqmjibc4kal34n";
|
2019-01-26 09:46:57 -08:00
|
|
|
this = self.postgresql_9_5;
|
|
|
|
inherit self;
|
2016-01-08 07:47:03 -08:00
|
|
|
};
|
|
|
|
|
2019-02-02 12:56:52 -08:00
|
|
|
postgresql_9_6 = self.callPackage generic {
|
2019-08-09 04:30:33 -07:00
|
|
|
version = "9.6.15";
|
2016-11-22 13:48:18 -08:00
|
|
|
psqlSchema = "9.6";
|
2019-08-09 04:30:33 -07:00
|
|
|
sha256 = "02hp69h2p02asfblkaahblzdz2zmawd2r11h6237y5j7yadgxn9w";
|
2019-01-26 09:46:57 -08:00
|
|
|
this = self.postgresql_9_6;
|
|
|
|
inherit self;
|
2016-11-22 13:48:18 -08:00
|
|
|
};
|
2016-01-08 07:47:03 -08:00
|
|
|
|
2019-02-02 12:56:52 -08:00
|
|
|
postgresql_10 = self.callPackage generic {
|
2019-08-09 04:30:33 -07:00
|
|
|
version = "10.10";
|
2019-02-21 09:21:08 -08:00
|
|
|
psqlSchema = "10.0"; # should be 10, but changing it is invasive
|
2019-08-09 04:30:33 -07:00
|
|
|
sha256 = "0lzj46dwd9cw94gnqm36bxd7jlhfdyqjrfzr3c4xd3prfn2rnkxd";
|
2019-01-26 09:46:57 -08:00
|
|
|
this = self.postgresql_10;
|
|
|
|
inherit self;
|
2017-10-06 15:50:44 -07:00
|
|
|
};
|
|
|
|
|
2019-02-02 12:56:52 -08:00
|
|
|
postgresql_11 = self.callPackage generic {
|
2019-08-09 04:30:33 -07:00
|
|
|
version = "11.5";
|
2019-02-21 09:21:08 -08:00
|
|
|
psqlSchema = "11.1"; # should be 11, but changing it is invasive
|
2019-08-09 04:30:33 -07:00
|
|
|
sha256 = "106ikalvrilihlvhq7xj7snq98hgbgq6qsgjrd252wgw1c327pvz";
|
2019-01-26 09:46:57 -08:00
|
|
|
this = self.postgresql_11;
|
|
|
|
inherit self;
|
2018-10-18 06:52:29 -07:00
|
|
|
};
|
|
|
|
|
2019-10-03 16:00:00 -07:00
|
|
|
postgresql_12 = self.callPackage generic {
|
|
|
|
version = "12.0";
|
|
|
|
psqlSchema = "12";
|
|
|
|
sha256 = "1ijm13gx1d9ai09n26nbdc77n9b8akh6pj21yy9vfn7p2mr3k8nd";
|
|
|
|
this = self.postgresql_12;
|
|
|
|
inherit self;
|
|
|
|
};
|
|
|
|
|
2019-02-02 12:56:52 -08:00
|
|
|
}
|