{ stdenv, fetchurl, zlib, openssl, perl , pamSupport ? false, pam ? null , etcDir ? null , hpnSupport ? false }: assert pamSupport -> pam != null; let hpnSrc = fetchurl { url = http://www.psc.edu/networking/projects/hpn-ssh/openssh-5.3p1-hpn13v7.diff.gz; sha256 = "1kqir6v14z77l0wn9j4jzdqsip5s1ky34w749psvbshbp9dzizn8"; }; in stdenv.mkDerivation rec { name = "openssh-5.4p1"; src = fetchurl { url = "ftp://ftp.nluug.nl/pub/security/OpenSSH/${name}.tar.gz"; sha256 = "0kj0qp43dn2pnkcgrbbhm2r9db448ppsmmzh22mj8j0h0h6yg5mf"; }; patchPhase = stdenv.lib.optionalString hpnSupport '' gunzip -c ${hpnSrc} | patch -p1 ''; buildInputs = [ zlib openssl perl ] ++ stdenv.lib.optional pamSupport pam; configureFlags = '' --with-mantype=man ${if pamSupport then "--with-pam" else "--without-pam"} ${if etcDir != null then "--sysconfdir=${etcDir}" else ""} ''; preConfigure = '' configureFlags="$configureFlags --with-privsep-path=$out/empty" ensureDir $out/empty ''; postInstall = '' # Install ssh-copy-id, it's very useful. cp contrib/ssh-copy-id $out/bin/ chmod +x $out/bin/ssh-copy-id cp contrib/ssh-copy-id.1 $out/share/man/man1/ ensureDir $out/etc/ssh cp moduli $out/etc/ssh/ ''; installTargets = "install-nosysconf"; meta = { homepage = http://www.openssh.org/; description = "An implementation of the SSH protocol"; license = "bsd"; }; }