refactor: cleanup of the fresh.sh script
This commit is contained in:
parent
a0952d0c32
commit
0126146f36
98
fresh.sh
98
fresh.sh
@ -1,17 +1,28 @@
|
||||
#!/bin/bash
|
||||
# Author: Philip Gaber <phga@posteo.de>
|
||||
|
||||
me=$(basename "$0")
|
||||
scriptdir=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
|
||||
|
||||
help_msg="\nUsage: $me [OPTIONS]\n\n
|
||||
Examples:\n\n $ $me -l -u\n\n
|
||||
Options:\n
|
||||
-d GIT_DOTFILES_REPO_URL (e.g. https://user@gitmebabyonemoretime.com/user/dotfiles)\n
|
||||
-p PACKAGE_CSV_FILE (e.g. ./pack.csv)\n
|
||||
-a AURHELPER (e.g. yay)\n
|
||||
-l LOGFILE (default: $HOME/install.log)\n
|
||||
-u Update the current system\n
|
||||
-s Enable necessary services on the current system\n
|
||||
|
||||
"
|
||||
# Get params
|
||||
while getopts "r:p:d:vush" opt;
|
||||
do case $opt in
|
||||
h) echo -e "-r: https://link-to-repo\n-p: /link/to/prog/file\n-d: devicename for special dotfiles\n-v: verbose, please supply logfile path (default is $HOME/install.log)" && exit ;;
|
||||
d) device=${OPTARG} ;;
|
||||
r) repo=${OPTARG} && git ls-remote "$repo" || exit ;;
|
||||
p) prog=${OPTARG} ;;
|
||||
h) echo -e $help_msg && exit ;;
|
||||
d) dotfiles=${OPTARG} && git ls-remote "$repo" || exit ;;
|
||||
p) pack_csv=${OPTARG} ;;
|
||||
a) aurhelper=${OPTARG} ;;
|
||||
v) logfile="$scriptdir/install.log" ;;
|
||||
l) logfile="$scriptdir/install.log" ;;
|
||||
u) todo="update" ;;
|
||||
s) todo="services" ;;
|
||||
\?) echo "-$OPTARG is not valid" >&2 && exit ;;
|
||||
@ -19,9 +30,8 @@ do case $opt in
|
||||
done
|
||||
|
||||
# Default settings
|
||||
device=${device:="480"}
|
||||
repo=${repo:="https://phga@g.phga.de/phga/dotfiles"}
|
||||
prog=${prog:="$scriptdir/pack.csv"}
|
||||
dotfiles=${dotfiles:="https://phga@g.phga.de/phga/dotfiles"}
|
||||
pack_csv=${pack_csv:="$scriptdir/pack.csv"}
|
||||
aurhelper=${aurhelper:="yay"}
|
||||
logfile=${logfile:="/dev/null"}
|
||||
todo=${todo:="install"}
|
||||
@ -29,12 +39,15 @@ todo=${todo:="install"}
|
||||
|
||||
startup_msg() {
|
||||
curr_platform=$(dialog --clear --title "Welcome to the Freshcript <3" --menu "Choose your current platform:" 0 0 3 "L" "Laptop" "D" "Desktop" "S" "Server" 2>&1>/dev/tty)
|
||||
[ -z "$curr_platform" ] && { clear; exit; }
|
||||
echo "Script started - Platform is: $curr_platform\n\n" >> $logfile
|
||||
}
|
||||
|
||||
wait_for_network() {
|
||||
dialog --infobox "Waiting for internet connection...\n\nDumdidum dum dumdiii dum" 0 0
|
||||
dhcpcd >> $logfile
|
||||
|
||||
ping -c 1 -q "one.one.one.one" >> $logfile && return || dhcpcd >> $logfile
|
||||
|
||||
while [ ! $OK = 0 ]; do
|
||||
ping -c 1 -q "one.one.one.one" >> $logfile && OK=$?
|
||||
done
|
||||
@ -42,7 +55,8 @@ wait_for_network() {
|
||||
|
||||
init() {
|
||||
wait_for_network
|
||||
pacman -S --noconfirm --needed dialog git make || { echo "Run as root user"; clear; exit; }
|
||||
pacman -S --noconfirm --needed dialog git make > /dev/null 2>&1 ||
|
||||
{ echo "Run as root user"; clear; exit; }
|
||||
refresh_keyring
|
||||
}
|
||||
|
||||
@ -109,45 +123,50 @@ install_manual() {
|
||||
cd "/home/$uname" || exit
|
||||
}
|
||||
|
||||
# TODO: test with makepkg -si
|
||||
install_aur_helper() {
|
||||
dialog --title "Installing the AUR Helper" --infobox "Installing dependencies..." 0 0
|
||||
pacman --noconfirm --needed -S go &>> $logfile
|
||||
dialog --title "Installing the AUR Helper" --infobox "Cloning repository..." 0 0
|
||||
cd $(sudo -u $uname mktemp -d)
|
||||
git clone https://aur.archlinux.org/yay.git . &>> $logfile
|
||||
sudo -u $uname makepkg --noconfirm -si &>> $logfile
|
||||
# pacman -U --noconfirm *.zst
|
||||
git clone "https://aur.archlinux.org/$aurhelper.git" . &>> $logfile
|
||||
sudo -u $uname makepkg --noconfirm -s &>> $logfile
|
||||
pacman -U --noconfirm *.zst
|
||||
# Check if aurhelper installation was successful
|
||||
if ! hash $aurhelper > /dev/null 2>&1; then
|
||||
dialog --title "Installing the AUR Helper" --infobox \
|
||||
"Installation of $aurhelper failed" 0 0
|
||||
sleep 10
|
||||
clear
|
||||
exit
|
||||
fi
|
||||
}
|
||||
|
||||
installation_loop() {
|
||||
echo "Entered installationloop\n\n" >> $logfile
|
||||
([ -f "$prog" ] && cp "$prog" /tmp/pack.csv) || curl -Ls "$prog" > /tmp/pack.csv
|
||||
csv="/tmp/pack.csv"
|
||||
([ -f "$pack_csv" ] && cp "$pack_csv" "$csv") || curl -Ls "$pack_csv" > "$csv"
|
||||
# count packages and sum results for all and curr platform
|
||||
ps=$(($(grep -e "A,P," /tmp/pack.csv | wc -l) + $(grep -e "$curr_platform,P," /tmp/pack.csv | wc -l)))
|
||||
as=$(($(grep -e "A,A," /tmp/pack.csv | wc -l) + $(grep -e "$curr_platform,A," /tmp/pack.csv | wc -l)))
|
||||
ms=$(($(grep -e "A,M," /tmp/pack.csv | wc -l) + $(grep -e "$curr_platform,M," /tmp/pack.csv | wc -l)))
|
||||
ps=$(($(grep -e "A,P," "$csv" | wc -l) + $(grep -e "$curr_platform,P," "$csv" | wc -l)))
|
||||
as=$(($(grep -e "A,A," "$csv" | wc -l) + $(grep -e "$curr_platform,A," "$csv" | wc -l)))
|
||||
ms=$(($(grep -e "A,M," "$csv" | wc -l) + $(grep -e "$curr_platform,M," "$csv" | wc -l)))
|
||||
aur_already_installed=$(pacman -Qqm)
|
||||
#IFS separator
|
||||
# For all lines in pack.csv do
|
||||
while IFS=, read -r platform prefix program info; do
|
||||
|
||||
if [[ ${platform} != "A" ]] && [[ ${platform} != ${curr_platform} ]]; then
|
||||
continue
|
||||
fi
|
||||
[[ ${platform} != "A" ]] && [[ ${platform} != ${curr_platform} ]] && continue
|
||||
|
||||
case $prefix in
|
||||
P) install_pacman "$program" "$info" ;;
|
||||
A) install_aur "$program" "$info" ;;
|
||||
M) install_manual "$program" "$info" ;;
|
||||
esac
|
||||
done < /tmp/pack.csv
|
||||
done < "$csv"
|
||||
}
|
||||
|
||||
enable_service() {
|
||||
for service in "$@"; do
|
||||
dialog --infobox "Enabling: $service" 0 0
|
||||
if [[ $@ =~ "--user.*" ]]
|
||||
then
|
||||
if [[ $@ =~ "--user.*" ]]; then
|
||||
sudo -u $uname systemctl enable "$service"
|
||||
sudo -u $uname systemctl start "$service"
|
||||
else
|
||||
@ -167,7 +186,7 @@ set_permissions() {
|
||||
download_dotfiles() {
|
||||
cd /home/$uname
|
||||
sudo -u $uname mkdir -p .dotfiles && cd .dotfiles
|
||||
sudo -u $uname git clone $repo .
|
||||
sudo -u $uname git clone $dotfiles .
|
||||
sudo -u $uname ./scripts/link.sh
|
||||
echo "Dotfiles downloaded and installed\n\n" >> $logfile
|
||||
}
|
||||
@ -179,22 +198,8 @@ no_beep() {
|
||||
}
|
||||
|
||||
ready_steady_go() {
|
||||
dialog --title "WE ARE DONE" --msgbox "The installation is complete\n\n#fingerscrossed everything worked :D\n\nTODOs\n\n- Move syncthing keys into .config\n" 0 0 ;
|
||||
}
|
||||
|
||||
uncom() {
|
||||
sed -i '/'"$1"'/s/^#//g' $2
|
||||
}
|
||||
|
||||
com() {
|
||||
sed -i '/'"$1"'/s/^/#/g' $2
|
||||
}
|
||||
|
||||
add_after() {
|
||||
# Example:
|
||||
# add_after "Color" "ILoveCandy" "$HOME/test/pacman.conf"
|
||||
sed -i '/'"$2"'/d'
|
||||
sed -i '/'"$1"'/a '"$2"'' $3
|
||||
dialog --title "WE ARE DONE" --msgbox "The installation is complete\n\n#fingerscrossed
|
||||
everything worked :D\n\nTODOs\n\n- Move syncthing keys into .config\n" 0 0 ;
|
||||
}
|
||||
|
||||
add_xorg_conf() {
|
||||
@ -213,9 +218,9 @@ add_pacman_hooks() {
|
||||
cp $scriptdir/etc/pacman.d/hooks/* /etc/pacman.d/hooks/ &>> $logfile
|
||||
}
|
||||
|
||||
add_xorg_conf() {
|
||||
add_systemd_conf() {
|
||||
echo "Adding systemd configs\n\n" >> $logfile
|
||||
cp $scriptdir/etc/systemd/network/00-wired.network /etc/systemd/network/00-wired.network &>> $logfile
|
||||
cp -r $scriptdir/etc/systemd/* /etc/systemd/ &>> $logfile
|
||||
}
|
||||
|
||||
set_pacman_config() {
|
||||
@ -244,6 +249,7 @@ set_system_stuff() {
|
||||
set_pacman_config
|
||||
add_pacman_hooks
|
||||
add_xorg_conf
|
||||
add_systemd_conf
|
||||
set_git_config
|
||||
#link syncthing config and move certs
|
||||
# sudo -u $uname /home/$uname/.dotfiles/syncthing/link-confs.sh &>> $logfile
|
||||
@ -300,7 +306,7 @@ case $todo in
|
||||
set_permissions "Defaults timestamp_timeout=45\n%wheel ALL=(ALL) ALL\n%wheel ALL=(ALL) NOPASSWD: /usr/bin/shutdown,/usr/bin/reboot,/usr/bin/systemctl suspend"
|
||||
no_beep
|
||||
set_system_stuff
|
||||
enable_service "--user syncthing"
|
||||
enable_service "--user syncthing" "--user pipewire-pulse"
|
||||
if [[ ${curr_platform} == "L" ]]; then
|
||||
enable_service "netctl-auto@wlp3s0"
|
||||
else
|
||||
@ -331,7 +337,7 @@ case $todo in
|
||||
else
|
||||
enable_service "systemd-networkd"
|
||||
fi
|
||||
enable_service "systemd-timesyncd" "atd"
|
||||
enable_service "systemd-timesyncd" "atd" "--user syncthing" "--user pipewire-pulse"
|
||||
ready_steady_go
|
||||
clear
|
||||
;;
|
||||
|
38
pack.csv
38
pack.csv
@ -91,21 +91,31 @@ A,P,redshift,No more burning eyes at night <3
|
||||
A,P,alsa-plugins,Extra alsa plugins
|
||||
A,P,alsa-utils,An alternative implementation of Linux sound support
|
||||
|
||||
# A,A,apulse,Compatibility layer for applications that rely on pulseaudio
|
||||
A,P,pulseaudio,Sound server
|
||||
A,P,pulseaudio-alsa,ALSA Configuration for PulseAudio
|
||||
A,P,pavucontrol-qt,GUI to manage PulseAudio
|
||||
|
||||
D,P,pulseaudio-jack,Jack support for PulseAudio
|
||||
D,P,jack2,C++ version of the JACK low-latency audio server for multi-processor machines
|
||||
D,P,jack2-dbus,The JACK low-latency audio server (dbus integration)
|
||||
D,P,a2jmidid,Dbus midi jack thingy
|
||||
D,P,qjackctl,A Qt front-end for the JACK low-latency audio server
|
||||
D,P,python-dbus,Python bindings for DBUS
|
||||
D,P,realtime-privileges,Required for realtime applications
|
||||
|
||||
A,P,blueman,Bluetooth manager
|
||||
A,P,pulseaudio-bluetooth,Bluetooth support for PulseAudio
|
||||
|
||||
### PULSEAUDIO / JACK2
|
||||
# A,A,apulse,Compatibility layer for applications that rely on pulseaudio
|
||||
# A,P,pulseaudio,Sound server
|
||||
# A,P,pulseaudio-alsa,ALSA Configuration for PulseAudio
|
||||
# A,P,pavucontrol-qt,GUI to manage PulseAudio
|
||||
|
||||
# D,P,pulseaudio-jack,Jack support for PulseAudio
|
||||
# D,P,jack2,C++ version of the JACK low-latency audio server for multi-processor machines
|
||||
# D,P,jack2-dbus,The JACK low-latency audio server (dbus integration)
|
||||
# D,P,a2jmidid,Dbus midi jack thingy
|
||||
# D,P,qjackctl,A Qt front-end for the JACK low-latency audio server
|
||||
# D,P,python-dbus,Python bindings for DBUS
|
||||
# D,P,realtime-privileges,Required for realtime applications
|
||||
|
||||
# A,P,pulseaudio-bluetooth,Bluetooth support for PulseAudio
|
||||
|
||||
### PIPEWIRE
|
||||
A,P,pipewire,Low-latency audio/video router and processor
|
||||
A,P,pipewire-pulse,PulseAudio replacement
|
||||
A,P,pipewire-alsa,ALSA configuration
|
||||
A,P,pipewire-jack,JACK support
|
||||
A,P,wireplumber,Session and policy manager implementation for PipeWire
|
||||
A,P,qpwgraph,PipeWire Graph Qt GUI Interface
|
||||
|
||||
# Text editing
|
||||
A,P,emacs,The extensible customizable self-documenting real-time display editor
|
||||
|
|
Loading…
x
Reference in New Issue
Block a user