diff options
author | ene <ene@sils.li> | 2023-02-19 23:45:08 +0100 |
---|---|---|
committer | ene <ene@sils.li> | 2023-02-19 23:45:08 +0100 |
commit | 508f70b7f66d5da17c8381545f5b67894fcbd576 (patch) | |
tree | e623806384d9f996080c569a98decf756bfec0c6 | |
parent | Fix(bootstrap): Allow to run the installer multiple times (diff) | |
download | nixos-config-508f70b7f66d5da17c8381545f5b67894fcbd576.zip |
Fix(bootstrap): Fix nasty grep bug
Diffstat (limited to '')
-rw-r--r-- | bootstrap/default.nix | 2 | ||||
-rwxr-xr-x | bootstrap/install.old | 65 | ||||
-rwxr-xr-x | bootstrap/install.sh (renamed from bootstrap/install) | 11 |
3 files changed, 6 insertions, 72 deletions
diff --git a/bootstrap/default.nix b/bootstrap/default.nix index 8cd7b394..6fab9a2d 100644 --- a/bootstrap/default.nix +++ b/bootstrap/default.nix @@ -6,7 +6,7 @@ }: let dependencies = with pkgs; [jq dash]; name = "install"; - script = ./install; + script = ./install.sh; lib = import ../lib {inherit pkgs shell-library;}; in lib.makeShellScriptWithLibrary {inherit dependencies name script;} diff --git a/bootstrap/install.old b/bootstrap/install.old deleted file mode 100755 index 013a1287..00000000 --- a/bootstrap/install.old +++ /dev/null @@ -1,65 +0,0 @@ -#!/bin/sh -# shellcheck disable=SC2086 -# shellcheck source=/dev/null -. ~/.local/lib/shell/lib - -#After partitioning /dev/vda1 as efi and /dev/vda2 as btrfs, installation is as simple as: - -available_disks="$(mktmp)"; -lsblk -J | jq '.[] | map(.name) | [foreach .[] as $item ({item: null, index: -1}; {$item, index: (.index + 1)})]' > $available_disks; -#"$(lsblk -J | jq '.[]| .[]| {name: .name, children: (.children | map(.name))} | .name')" - - -[ "$(jq '.[]' "$available_disks" | wc -l)" -eq 0 ] && die "No disks found" -msg "Select a disk to format:\n" - -i=9999; # nobody will have so many disks attached - -while ! jq -e --argjson i "$i" '.[$i]' "$available_disks" > /dev/null ; do - for disk in $(jq -c '.[]' "$available_disks" ); do - printf "%4s) %s \n" "$(echo "$disk" | jq '.index')" "$(echo "$disk" | jq '.item' | tr -d "\"")"; - done - printf "%4s) Exit\n" "q" - readp "Enter a option: " disk - - if [ $disk = "q" ];then - exit 1 - else - i="$disk" - fi - jq -e --argjson i "$i" '.[$i]' "$available_disks" || warning "\nNo disk selected. Select a disk to continue.\n" -done - -exit 0; -#disk=$((disk-1)) -#read -p "Do you want to delete all in ${Disk_Array[$disk]}? [N/y]" -n 1 -r result -#[[ $result =~ ^[Yy]$ ]] && echo || exit 1 -#sgdisk -Z "${Disk_Array[$disk]}" > /dev/null || dien "Zapping" -#sgdisk -n 1:0:+300M -n 2:0:"$ENDSECTOR" -t 1:ef00 -t 2:8300 "${Disk_Array[$disk]}" > /dev/null || dien "Partitioning" -# -#if [[ ${Disk_Array[$disk]} == *"nvme"* ]];then -# export DISK_EFI=${Disk_Array[$disk]}p1 && echo "${Disk_Array[$disk]}p1" > /root/efi-disk -# export DISK_ROOT=${Disk_Array[$disk]}p2 && echo "${Disk_Array[$disk]}p2" > /root/root-disk -#else -# export DISK_EFI=${Disk_Array[$disk]}1 && echo "${Disk_Array[$disk]}1" > /root/efi-disk -# export DISK_ROOT=${Disk_Array[$disk]}2 && echo "${Disk_Array[$disk]}2" > /root/root-disk -#fi -# -# -#mount -t btrfs /dev/vda2 /mnt -#btrfs subvolume create /mnt/{nix,storage} -#btrfs subvolume create /mnt/storage/{networkmanager,nixos-server} -#umount /mnt -#mount -t tmpfs none /mnt -#mkdir -p /mnt/{nix,etc/nixos,etc/NetworkManager,srv,boot} -#mount /dev/vda1 /mnt/boot -#mount -t btrfs -o subvol=nix /dev/vda2 /mnt/nix -#mount -t btrfs -o subvol=storage /dev/vda2 /mnt/srv -#mount -o bind /mnt/srv/nixos-server /mnt/etc/nixos -#mount -o bind /mnt/srv/networkmanager /mnt/etc/NetworkManager -#nixos-generate-config --root /mnt -#nixos-install --no-root-passwd -#reboot -# -# -#if [ -d /tmp/LIB_FILE_TEMP_DIR/ ];then rm -r /tmp/LIB_FILE_TEMP_DIR/; fi diff --git a/bootstrap/install b/bootstrap/install.sh index 81829019..37a5e758 100755 --- a/bootstrap/install +++ b/bootstrap/install.sh @@ -99,9 +99,9 @@ case $result in msg "Great, select a host-config:" hosts=$(mktmp); host=""; - awk -F "." '/nixosConfiguration/{print $2}' "$(tmp 'curl https://git.sils.li/ene/nixos-config/raw/branch/prime/flake.nix')" | awk '{print $1}' > $hosts; + awk -F "." '/nixosConfiguration/{print $2}' "$(tmp 'curl https://git.sils.li/ene/nixos-config/raw/branch/prime/flake.nix 2> /dev/null')" | awk '{print $1}' > $hosts; - while ! grep "$host" "$hosts" > /dev/null && [ "$host" == "" ]; do + while ! grep "$host" "$hosts" > /dev/null || [ "$(printf "%s" "$host" | wc -c)" -eq 0 ]; do i=1; while read -r ho ; do printf "%4s) %s \n" "$i" "$ho"; @@ -110,10 +110,9 @@ case $result in printf "%4s) Exit\n" "q" readp "Enter a option: " host - [ $host = "q" ] && exit 1 - if grep "$host" "$hosts" > /dev/null && [ "$host" != "" ]; then - host=$(awk -v i="$host" '{if (NR==i) {print $0}}' "$hosts"); - else + [ "$host" = "q" ] && exit 1 + host=$(awk -v i="$host" '{if (NR==i) {print $0}}' "$hosts"); + if ! grep "$host" "$hosts" > /dev/null || [ "$(printf "%s" "$host" | wc -c)" -eq 0 ]; then warning "No host selected. Select a host to continue.\n" fi done |