summary refs log tree commit diff
path: root/pkgs/applications/networking/cluster/kanif/default.nix
blob: b4bb69dc1f6253258672231412292ed4a769659f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
{ lib, stdenv, fetchurl, perl , taktuk}:

stdenv.mkDerivation rec {
  version = "1.2.2";
  pname = "kanif";

  src = fetchurl {
    url = "https://gforge.inria.fr/frs/download.php/26773/${pname}-${version}.tar.gz";
    sha256 = "3f0c549428dfe88457c1db293cfac2a22b203f872904c3abf372651ac12e5879";
  };

  preBuild = ''
      substituteInPlace ./kanif --replace "/usr/bin/perl" "${perl}/bin/perl"
      substituteInPlace ./kanif --replace '$taktuk_command = "taktuk";' '$taktuk_command = "${taktuk}/bin/taktuk";'
  '';

  meta = {
    description = "Cluster management and administration swiss army knife";
    longDescription = ''
      Kanif is a tool for high performance computing clusters management and
      administration. It combines the main functionalities of well-known cluster
      management tools such as c3, pdsh and dsh, and mimics their syntax. It
      provides three tools to run the same command on several nodes ("parallel
      ssh", using the 'kash' command), to broadcast the copy of files or
      directories to several nodes ('kaput' command), and to gather several
      remote files or directories locally ('kaget' command). It relies on TakTuk
      for efficiency and scalability.'';
    homepage = "http://taktuk.gforge.inria.fr/kanif";
    license = lib.licenses.gpl2;
    maintainers = [ lib.maintainers.bzizou ];
    platforms = lib.platforms.linux;
  };

}