diff options
author | Nikolay Amiantov <ab@fmap.me> | 2015-02-05 18:14:28 +0300 |
---|---|---|
committer | Nikolay Amiantov <ab@fmap.me> | 2015-02-05 19:46:25 +0300 |
commit | 4b3bb7b4489bffc35efdf8b972f8393beb2f870b (patch) | |
tree | 19fd86eddd22533ce2af2b03082f5a095d6e6b3a /pkgs/build-support/build-fhs-userenv/default.nix | |
parent | b3ee378f5038886d08b2a17eb4ab5130ba7f77b8 (diff) | |
download | nixpkgs-4b3bb7b4489bffc35efdf8b972f8393beb2f870b.tar nixpkgs-4b3bb7b4489bffc35efdf8b972f8393beb2f870b.tar.gz nixpkgs-4b3bb7b4489bffc35efdf8b972f8393beb2f870b.tar.bz2 nixpkgs-4b3bb7b4489bffc35efdf8b972f8393beb2f870b.tar.lz nixpkgs-4b3bb7b4489bffc35efdf8b972f8393beb2f870b.tar.xz nixpkgs-4b3bb7b4489bffc35efdf8b972f8393beb2f870b.tar.zst nixpkgs-4b3bb7b4489bffc35efdf8b972f8393beb2f870b.zip |
userFHSEnv: add build tool
Diffstat (limited to 'pkgs/build-support/build-fhs-userenv/default.nix')
-rw-r--r-- | pkgs/build-support/build-fhs-userenv/default.nix | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/pkgs/build-support/build-fhs-userenv/default.nix b/pkgs/build-support/build-fhs-userenv/default.nix new file mode 100644 index 00000000000..b3bbc19dda8 --- /dev/null +++ b/pkgs/build-support/build-fhs-userenv/default.nix @@ -0,0 +1,36 @@ +{ writeTextFile, stdenv, ruby } : { env, runScript } : + +let + name = env.pname; + + # Sandboxing script + chroot-user = writeTextFile { + name = "chroot-user"; + executable = true; + destination = "/bin/chroot-user"; + text = '' + #! ${ruby}/bin/ruby + ${builtins.readFile ./chroot-user.rb} + ''; + }; + +in stdenv.mkDerivation { + name = "${name}-userenv"; + buildInputs = [ ruby ]; + buildCommand = '' + mkdir -p $out/bin + cat > $out/bin/${name} <<EOF + #! ${stdenv.shell} + exec ${chroot-user}/bin/chroot-user ${env} $out/libexec/run + EOF + chmod +x $out/bin/${name} + + mkdir -p $out/libexec + cat > $out/libexec/run <<EOF + #! ${stdenv.shell} + source /etc/profile + ${runScript} + EOF + chmod +x $out/libexec/run + ''; +} |