{ lib, stdenv, fetchFromGitHub, libkrb5, openssl, pam, pkg-config, postgresql, readline, sqlite, testers, zlib, }: stdenv.mkDerivation (finalAttrs: { pname = "pgcopydb"; version = "0.15"; src = fetchFromGitHub { owner = "dimitri"; repo = "pgcopydb"; rev = "v${finalAttrs.version}"; hash = "sha256-m9iIF8h6V3wWLUQuPntXtRAh16RrmR3uqZZIljGCY08="; }; nativeBuildInputs = [ pkg-config ]; buildInputs = [ libkrb5 openssl postgresql readline sqlite zlib ] ++ lib.optionals stdenv.hostPlatform.isLinux [ pam ]; hardeningDisable = [ "format" ]; installPhase = '' runHook preInstall install -D -t $out/bin/ src/bin/pgcopydb/pgcopydb runHook postInstall ''; passthru.tests = { version = testers.testVersion { package = finalAttrs.finalPackage; }; }; meta = with lib; { description = "Copy a Postgres database to a target Postgres server (pg_dump | pg_restore on steroids"; homepage = "https://github.com/dimitri/pgcopydb"; changelog = "https://github.com/dimitri/pgcopydb/blob/${finalAttrs.src.rev}/CHANGELOG.md"; license = licenses.postgresql; maintainers = [ ]; mainProgram = "pgcopydb"; platforms = platforms.all; }; })