mirror of
https://github.com/ItsDrike/dotfiles.git
synced 2024-12-25 20:54:34 +00:00
121 lines
4.7 KiB
Bash
Executable file
121 lines
4.7 KiB
Bash
Executable file
#!/bin/bash
|
|
set -euo pipefail
|
|
|
|
# Arch installation script to be ran during OS installation, after user account creation.
|
|
# (Check install_root.sh first)
|
|
# $ arch-chroot /mnt zsh
|
|
# $ useradd itsdrike
|
|
# $ usermod -aG wheel itsdrike
|
|
# $ install -o itsdrike -g itsdrike -d /home/itsdrike
|
|
# $ passwd itsdrike
|
|
# $ chsh -s /usr/bin/zsh itsdrike
|
|
# $ su -l itsdrike
|
|
# $ git clone --recursive https://github.com/ItsDrike/dotfiles ~/dots
|
|
# $ cd ~/dots
|
|
# $ ./install_user.sh
|
|
# ---------------------------------------------------------------------------------------
|
|
|
|
if [ "$UID" = 0 ]; then
|
|
echo >&2 "This script must be ran as an unpriviledged user (non-root)"
|
|
exit 1
|
|
fi
|
|
|
|
# cd into the dotfiles dir, no matter where the script was called from
|
|
pushd "$(dirname "$0")"
|
|
|
|
# Install AUR helper (yay)
|
|
git clone https://aur.archlinux.org/yay.git ~/yay
|
|
pushd ~/yay
|
|
makepkg -si
|
|
popd
|
|
rm -rf ~/yay
|
|
|
|
# Sync mirrors and update before other installations
|
|
yay -Syu --noconfirm
|
|
|
|
# Install some useful packages
|
|
yay -S --noconfirm --needed \
|
|
openssh cronie exa bat dust mlocate lshw trash-cli ncdu btop \
|
|
dnsutils net-tools wget jq fzf polkit rebuild-detector hyperfine mediainfo git-delta \
|
|
python-pip ripgrep zip unzip usbutils hexyl strace python-poetry pyenv yt-dlp \
|
|
luarocks rustup cargo cmake meson npm downgrade lf glow xdg-ninja-git
|
|
|
|
# Make yay automatically track development dependencies
|
|
yay -Y --gendb
|
|
yay -Y --devel --save
|
|
|
|
# Copy over zsh configuration
|
|
# Note that this assumes you've ran install_root.sh, whcih created /etc/zsh/zshenv
|
|
# with $ZOOTDIR exported. If you haven't done that, you'll want to symlink the
|
|
# ~/.config/zsh/.zshenv to your home directory.
|
|
mkdir -p ~/.config
|
|
cp -ra home/.config/shell ~/.config
|
|
rm -rf ~/.config/zsh/ || true # in case there is already some zsh config
|
|
cp -ra home/.config/zsh ~/.config
|
|
rm -rf ~/.config/zsh/.zgenom
|
|
git clone https://github.com/jandamm/zgenom ~/.config/zsh/.zgenom
|
|
mkdir -p ~/.cache/zsh
|
|
touch ~/.cache/zsh/history
|
|
|
|
# Copy other user configurations
|
|
mkdir -p ~/.local
|
|
cp -ra home/.local/bin ~/.local
|
|
cp -ra home/.config/python ~/.config
|
|
install -m 700 -d ~/.local/share/gnupg
|
|
mkdir -p ~/.local/share/npm/lib
|
|
mkdir -p ~/.local/state
|
|
cp -ra home/.config/btop ~/.config
|
|
mkdir -p ~/.config/gtk-2.0
|
|
mkdir -p ~/.config/gtk-3.0
|
|
mkdir -p ~/.config/java
|
|
|
|
# More opinionated settings, you may not need some of these
|
|
cp home/.config/black ~/.config
|
|
cp -ra home/.config/git ~/.config/git
|
|
cp -ra home/.config/gtk-2.0 ~/.config
|
|
cp -ra home/.config/gtk-3.0 ~/.config
|
|
cp -ra home/.config/lf ~/.config
|
|
cp -ra home/.local/share/gnupg/gpg.conf ~/.local/share/gnupg
|
|
chmod 600 ~/.local/share/gnupg/gpg.conf
|
|
mkdir ~/.config/wakatime
|
|
|
|
# Source the environment file to make sure the commands below
|
|
# install to the correct (XDG) location.
|
|
# shellcheck source=home/.config/shell/environment
|
|
source ~/.config/shell/environment
|
|
|
|
# Install stable channel default rust toolchain
|
|
rustup default stable
|
|
|
|
# Install various python versions with pyenv
|
|
# This might take a while
|
|
# (note: if you don't need pyenv, remove ~/.config/shell/py-alias, and commment these lines)
|
|
pyenv install -l | cut -d' ' -f3 | grep -E '^3\.12\.[0-9]+$' | tail -n 1 | xargs -I {} pyenv install {}
|
|
pyenv install -l | cut -d' ' -f3 | grep -E '^3\.11\.[0-9]+$' | tail -n 1 | xargs -I {} pyenv install {}
|
|
pyenv install -l | cut -d' ' -f3 | grep -E '^3\.10\.[0-9]+$' | tail -n 1 | xargs -I {} pyenv install {}
|
|
pyenv install -l | cut -d' ' -f3 | grep -E '^3\.9\.[0-9]+$' | tail -n 1 | xargs -I {} pyenv install {}
|
|
pyenv install -l | cut -d' ' -f3 | grep -E '^3\.8\.[0-9]+$' | tail -n 1 | xargs -I {} pyenv install {}
|
|
pyenv install -l | cut -d' ' -f3 | grep -E '^3\.7\.[0-9]+$' | tail -n 1 | xargs -I {} pyenv install {}
|
|
pyenv install -l | cut -d' ' -f3 | grep -E '^3\.6\.[0-9]+$' | tail -n 1 | xargs -I {} pyenv install {}
|
|
|
|
# Install IPython and upgrade pip on all pyenv python versions
|
|
PYENV_VERSION="3.12" pip install --upgrade pip ipython
|
|
PYENV_VERSION="3.11" pip install --upgrade pip ipython
|
|
PYENV_VERSION="3.10" pip install --upgrade pip ipython
|
|
PYENV_VERSION="3.9" pip install --upgrade pip ipython
|
|
PYENV_VERSION="3.8" pip install --upgrade pip ipython
|
|
PYENV_VERSION="3.7" pip install --upgrade pip ipython
|
|
PYENV_VERSION="3.6" pip install --upgrade pip ipython
|
|
|
|
# Pull my public key and give it ultimate trust
|
|
# (Obviously, you might not want to do this in your case,
|
|
# you can give it a lower trust level, or not import it at all)
|
|
gpg --keyserver keys.openpgp.org --recv-keys FA2745890B7048C0
|
|
echo "136F5E08AFF7F6DD3E9227A0FA2745890B7048C0:6:" | gpg --import-ownertrust
|
|
|
|
echo "You should now exit (logout) the user and relogin with: su -l itsdrike"
|
|
echo "This will put you into a configured ZSH shell, you can continue" \
|
|
"configuring the rest of of the system manually from there"
|
|
|
|
popd
|