diff options
| author | davidovski <david@davidovski.xyz> | 2022-03-31 00:12:31 +0100 | 
|---|---|---|
| committer | davidovski <david@davidovski.xyz> | 2022-03-31 00:12:31 +0100 | 
| commit | dc7e66b46601c34d70945701f929135736ec1392 (patch) | |
| tree | c03d3586741d702cda22b5431d43b7ace9f865af /scripts | |
| parent | f6f10ace48e249b0f1d6da28ad0a03b65b92e306 (diff) | |
added install system script
Diffstat (limited to 'scripts')
| -rwxr-xr-x | scripts/install.sh | 122 | 
1 files changed, 122 insertions, 0 deletions
| diff --git a/scripts/install.sh b/scripts/install.sh new file mode 100755 index 0000000..f13495a --- /dev/null +++ b/scripts/install.sh @@ -0,0 +1,122 @@ +#!/bin/sh + +default_packages="base linux xipkg dracut grub" +additional_packages="sudo neofetch vim networkmanager" +default_key="davidovski https://xi.davidovski.xyz/keychain/xi.pub" + +XIPKG="/usr/bin/xi" +XIFLAGS="-yl" +TMPDIR=/tmp +SYSROOT=$1 + +[ ! -e $XIPKG ] && { +    git clone https://xi.davidovski.xyz/git/xiutils.git $TMPDIR/xiutils +    make && make install + +    git clone https://xi.davidovski.xyz/git/xipkg.git $TMPDIR/xipkg +    make && make install +} + +echo "Please make sure that you have correctly formatted any partitions and mounted them as desired under $SYSROOT" + +[ $# -eq 0 ] && echo "Please specify where you would like to instal the system" && exit 1 + +[ -e $SYSROOT ] && { +    printf "Remove existing system at $SYSROOT? [Y/n] " +    read response +    [ "$response" != "n" ] && rm -rf $SYSROOT && echo "removed $SYSROOT" +} + +$XIPKG $XIFLAGS sync +$XIPKG $XIFLAGS -r $SYSROOT bootstrap $default_packages +$XIPKG $XIFLAGS -r $SYSROOT keyimport $default_key + +configuring_users () { +    echo "Setting root password: " +    xichroot $SYSROOT passwd  + +    echo +    echo "Creating user" +    read -p "Enter username: " username +    xichroot $SYSROOT useradd -m $username +    xichroot $SYSROOT passwd $username +} + +configuring_system () { +    read -p "Enter system hostname: " hostname + +    echo $hostname > $SYSROOT/etc/hostname + +    cat > $SYSROOT/etc/hosts << EOF +127.0.0.1   localhost +::1         localhost +127.0.1.1   $hostname.local $hostname +EOF +} + +configuring_nameservers () { +    echo "Configuring nameservers..." + +    cat > $SYSROOT/etc/resolv.conf << EOF +nameserver 80.80.80.80 +EOF +} + +generating_fstab () { +    echo "Generating fstab..." +    xichroot $SYSCONFIG genfstab -U / > $SYSROOT/etc/fstab +} + +building_initramfs () { +    echo "Building initramfs..." +    kernel_version=$(ls $SYSROOT/usr/lib/modules | tail -1) +    xichroot $SYSROOT dracut --kver $kernel_version  2>/dev/null > $TMPDIR/dracut.log +} + +installing_bootloader () { +    read -p "Install Grub? [y]" r +    [ "$r" != "n" ] && { +        opts="--target=x86_64-efi" +     +        read -p "Enter efi partition: " efi_part +        opts="$opts --efi-partition=$efi_part" + +        read -p "Removable system? [y]" r +        [ "$r" != "n" ] && { +            opts="$opts --removable" +        } + +        xichroot $SYSROOT grub-install $opts +        xichroot $SYSROOT grub-mkconfig -o /boot/grub/grub.cfg +    } +} + +downloading_additional_packages () { +    echo "Syncing repos..." +    xichroot $SYSROOT xi sync +    echo "Downloading additional packages..." +    xichroot $SYSROOT xi $XIFLAGS install $additional_packages +} + +steps=" +generating_fstab +building_initramfs +configuring_system +installing_bootloader +configuring_users +configuring_nameservers +downloading_additional_packages +" + +len=$(echo "$steps" | wc -l) +i=0 + + +for step in $steps; do +    i=$((i+1)) +    clear +    hbar -t -T "$(echo $step | sed "s/_/ /g")" $i $len +    $step +done + +echo "Installation finished!" | 
