nixpkgs/pkgs/tools/networking/pdsh/default.nix
2013-12-10 23:20:23 +01:00

54 lines
1.7 KiB
Nix

{stdenv, fetchurl, perl, readline, rsh, ssh, pam}:
let
name = "pdsh-2.26";
in
stdenv.mkDerivation {
inherit name;
src = fetchurl {
url = "http://pdsh.googlecode.com/files/${name}.tar.bz2";
sha256 = "ada2f35509064bf9cd0fd5ca39a351108cdd6f5155b05f39f1711a271298469a";
};
buildInputs = [perl readline ssh pam];
/* pdsh uses pthread_cancel(), which requires libgcc_s.so.1 to be
loadable at run-time. Adding the flag below ensures that the
library can be found. Obviously, though, this is a hack. */
NIX_LDFLAGS="-lgcc_s";
preConfigure = ''
configureFlagsArray=(
"--infodir=$out/share/info"
"--mandir=$out/share/man"
"--with-machines=/etc/pdsh/machines"
${if readline == null then "--without-readline" else "--with-readline"}
${if ssh == null then "--without-ssh" else "--with-ssh"}
${if pam == null then "--without-pam" else "--with-pam"}
${if rsh == false then "--without-rsh" else "--with-rsh"}
"--with-dshgroups"
"--with-xcpu"
"--disable-debug"
)
'';
meta = {
homepage = "http://code.google.com/p/pdsh/";
description = "High-performance, parallel remote shell utility";
license = "GPLv2";
longDescription = ''
Pdsh is a high-performance, parallel remote shell utility. It has
built-in, thread-safe clients for Berkeley and Kerberos V4 rsh and
can call SSH externally (though with reduced performance). Pdsh
uses a "sliding window" parallel algorithm to conserve socket
resources on the initiating node and to allow progress to continue
while timeouts occur on some connections.
'';
hydraPlatforms = stdenv.lib.platforms.unix;
maintainers = [ stdenv.lib.maintainers.simons ];
};
}