diff options
| author | tv <tv@krebsco.de> | 2016-02-19 19:37:00 +0100 | 
|---|---|---|
| committer | tv <tv@krebsco.de> | 2016-02-20 02:02:08 +0100 | 
| commit | d8d39f5c4a9925f2098e58dc80e36920ece6ac71 (patch) | |
| tree | 6a138e3e064d8cda836564ab225f3888318a7d43 | |
| parent | 1226a20038fa61e8a98b31f223a59b244dd6cd03 (diff) | |
prepare_common: simplify nixos-install installation
| -rw-r--r-- | krebs/4lib/infest/prepare.sh | 33 | 
1 files changed, 14 insertions, 19 deletions
| diff --git a/krebs/4lib/infest/prepare.sh b/krebs/4lib/infest/prepare.sh index b3824c7d4..a217e7bed 100644 --- a/krebs/4lib/infest/prepare.sh +++ b/krebs/4lib/infest/prepare.sh @@ -184,26 +184,21 @@ prepare_common() {(    . /root/.nix-profile/etc/profile.d/nix.sh -  for i in \ -    bash \ -    coreutils \ -    # This line intentionally left blank. -  do -    if ! nix-env -q $i | grep -q .; then -      nix-env -iA nixpkgs.pkgs.$i -    fi -  done +  mkdir -p /mnt/"$target_path" +  mkdir -p "$target_path" + +  if ! mountpoint "$target_path"; then +    mount --rbind /mnt/"$target_path" "$target_path" +  fi + +  mkdir -p bin +  rm -f bin/nixos-install +  cp "$(type -p nixos-install)" bin/nixos-install +  sed -i "s@^NIX_PATH=\"[^\"]*\"@NIX_PATH=$target_path@" bin/nixos-install -  # install nixos-install -  if ! type nixos-install 2>/dev/null; then -    nixpkgs_expr='import <nixpkgs> { system = builtins.currentSystem; }' -    nixpkgs_path=$(find /nix/store -mindepth 1 -maxdepth 1 -name *-nixpkgs-* -type d) -    nix-env \ -      --arg config "{ nix.package = ($nixpkgs_expr).nix; }" \ -      --arg pkgs "$nixpkgs_expr" \ -      --arg modulesPath 'throw "no modulesPath"' \ -      -f $nixpkgs_path/nixpkgs/nixos/modules/installer/tools/tools.nix \ -      -iA config.system.build.nixos-install +  if ! grep -q '^PATH.*#krebs' .bashrc; then +    echo '. /root/.nix-profile/etc/profile.d/nix.sh' >> .bashrc +    echo 'PATH=$HOME/bin:$PATH #krebs' >> .bashrc    fi  )} | 
