summary refs log tree commit diff
path: root/pkgs/build-support/build-fhs-userenv/default.nix
diff options
context:
space:
mode:
authorNikolay Amiantov <ab@fmap.me>2015-02-05 18:14:28 +0300
committerNikolay Amiantov <ab@fmap.me>2015-02-05 19:46:25 +0300
commit4b3bb7b4489bffc35efdf8b972f8393beb2f870b (patch)
tree19fd86eddd22533ce2af2b03082f5a095d6e6b3a /pkgs/build-support/build-fhs-userenv/default.nix
parentb3ee378f5038886d08b2a17eb4ab5130ba7f77b8 (diff)
downloadnixpkgs-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.nix36
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
+  '';
+}