summary refs log blame commit diff
path: root/pkgs/os-specific/linux/syscall_limiter/default.nix
blob: a5c69e1d876e0fa8f81ff778986646409b679a28 (plain) (tree)
1
2
3
4
5
6
7
8
9
10







                         

                                         

                         



                                                                    


















                                                                             

                                                        
                                              
                                  

    
{ stdenv
, fetchFromGitHub
, libseccomp
, perl
, which
}:

stdenv.mkDerivation rec {
  name    = "syscall_limiter-${version}";
  version = "20170123";

  src = fetchFromGitHub {
    owner  = "vi";
    repo   = "syscall_limiter";
    rev    = "481c8c883f2e1260ebc83b352b63bf61a930a341";
    sha256 = "0z5arj1kq1xczgrbw1b8m9kicbv3vs9bd32wvgfr4r6ndingsp5m";
  };

  configurePhase = "";

  buildPhase = ''
    make CC="gcc -I${libseccomp}/include -L${libseccomp}/lib"
  '';

  installPhase = ''
    mkdir -p $out/bin
    cp -v limit_syscalls $out/bin
    cp -v monitor.sh $out/bin/limit_syscalls_monitor.sh
    substituteInPlace $out/bin/limit_syscalls_monitor.sh \
      --replace perl ${perl}/bin/perl \
      --replace which ${which}/bin/which
  '';

  meta = with stdenv.lib; {
    description = "Start Linux programs with only selected syscalls enabled";
    homepage    = https://github.com/vi/syscall_limiter;
    license     = licenses.mit;
    maintainers = with maintainers; [ obadz ];
    platforms   = platforms.linux;
  };
}