Clean up install script
Signed-off-by: Severin Kaderli <severin@kaderli.dev>
This commit is contained in:
parent
893d322bdf
commit
33c37eef02
6 changed files with 102 additions and 98 deletions
119
install
119
install
|
@ -34,6 +34,10 @@ DIRECTORIES=(
|
|||
"Videos"
|
||||
)
|
||||
|
||||
WORK_DIRECTORIES=(
|
||||
"Work"
|
||||
)
|
||||
|
||||
# Files which should be symlinked in the home folder
|
||||
LINKED_FILES_HOME=(
|
||||
".config/autokey"
|
||||
|
@ -68,7 +72,6 @@ LINKED_FILES_HOME=(
|
|||
".config/zathura"
|
||||
".config/zsh"
|
||||
".local/bin"
|
||||
".local/share/applications/vim.desktop"
|
||||
".local/share/gnupg/gpg-agent.conf"
|
||||
)
|
||||
|
||||
|
@ -87,7 +90,8 @@ PERMISSIONS=(
|
|||
|
||||
# Groups the user should be added to
|
||||
ADD_GROUPS=(
|
||||
"bumblebee"
|
||||
"log"
|
||||
"wheel"
|
||||
)
|
||||
|
||||
# Array of systemd services which should be enabled
|
||||
|
@ -102,7 +106,7 @@ SYSTEMD_SERVICES=(
|
|||
###############################################################################
|
||||
# Install package manager and packages #
|
||||
###############################################################################
|
||||
print_section "Installing requirements"
|
||||
print_section "Installing package requirements"
|
||||
sudo pacman -S git base-devel --noconfirm --needed
|
||||
|
||||
print_section "Installing yay"
|
||||
|
@ -128,77 +132,130 @@ yay -S --noconfirm --needed "$(cat "${PACKAGES_DIR}/packages.list")"
|
|||
|
||||
|
||||
###############################################################################
|
||||
# Create directories and symlinks #
|
||||
# Creating directories #
|
||||
###############################################################################
|
||||
print_section "Creating directories"
|
||||
for dir in "${DIRECTORIES[@]}"
|
||||
do
|
||||
create_directory "${dir}"
|
||||
print_log "Creating directory ${YELLOW}${HOME}/${dir}${RESET}"
|
||||
mkdir -p "${HOME}/${dir}"
|
||||
done
|
||||
|
||||
if [ "${IS_WORK}" = "1" ]; then
|
||||
print_section "Creating work directories"
|
||||
for dir in "${WORK_DIRECTORIES[@]}"
|
||||
do
|
||||
print_log "Creating directory ${YELLOW}${HOME}/${dir}${RESET}"
|
||||
mkdir -p "${HOME}/${dir}"
|
||||
done
|
||||
fi
|
||||
|
||||
|
||||
###############################################################################
|
||||
# Creating symlinks #
|
||||
###############################################################################
|
||||
print_section "Creating symlinks"
|
||||
for file in "${LINKED_FILES_HOME[@]}";
|
||||
do
|
||||
create_link "${file}"
|
||||
print_log "Linking ${YELLOW}${HOME}/${file}${RESET} to ${YELLOW}${SYSTEM_DIR}/${file}${RESET}"
|
||||
rm -rf "${HOME:?}/${file}"
|
||||
ln -fs "${SYSTEM_DIR}/${file}" "${HOME}/${file}"
|
||||
done
|
||||
|
||||
|
||||
for file in "${!LINKED_FILES[@]}"; do
|
||||
print_log "Linking ${YELLOW}${file}${RESET} -> ${YELLOW}${LINKED_FILES[${file}]}${RESET}"
|
||||
print_log "Linking ${YELLOW}${file}${RESET} to ${YELLOW}${LINKED_FILES[${file}]}${RESET}"
|
||||
rm -rf "${file}"
|
||||
ln -fs "${LINKED_FILES[${file}]}" "${file}"
|
||||
done
|
||||
|
||||
print_section "Give permissions"
|
||||
|
||||
###############################################################################
|
||||
# Giving permissions #
|
||||
###############################################################################
|
||||
print_section "Giving permissions"
|
||||
for permission in "${!PERMISSIONS[@]}"; do
|
||||
set_permission "${USER}" "${PERMISSIONS[${permission}]}" "${permission}"
|
||||
print_log "Changing owner of ${YELLOW}${permission}${RESET} to ${YELLOW}${USER}${RESET}"
|
||||
sudo chown -R "${USER}" ""${permission}""
|
||||
print_log "Changing permission of ${YELLOW}"${permission}"${RESET} to ${YELLOW}${PERMISSIONS[${permission}]}${RESET}"
|
||||
sudo chmod -R "${PERMISSIONS[${permission}]}" "${permission}"
|
||||
done
|
||||
|
||||
print_section "Add user to groups"
|
||||
|
||||
###############################################################################
|
||||
# Adding user to groups #
|
||||
###############################################################################
|
||||
print_section "Adding user to groups"
|
||||
for group in "${ADD_GROUPS[@]}"
|
||||
do
|
||||
add_to_group "${USER}" "${group}"
|
||||
print_log "Adding user ${YELLOW}${USER}${RESET} to group ${YELLOW}${group}${RESET}"
|
||||
sudo gpasswd -a "${USER}" "${group}" > /dev/null 2>&1
|
||||
done
|
||||
|
||||
|
||||
###############################################################################
|
||||
# Copying systemd services #
|
||||
###############################################################################
|
||||
print_section "Copying systemd services"
|
||||
for file in "${SYSTEM_DIR}/etc/systemd/system/"*
|
||||
do
|
||||
print_log "Copy ${YELLOW}$(basename "${file}")${RESET} to ${YELLOW}/etc/systemd/system${RESET}"
|
||||
print_log "Copying ${YELLOW}$(basename "${file}")${RESET} to ${YELLOW}/etc/systemd/system${RESET}"
|
||||
sudo install -m 644 "${file}" "/etc/systemd/system"
|
||||
done
|
||||
|
||||
|
||||
###############################################################################
|
||||
# Enabling systemd services #
|
||||
###############################################################################
|
||||
print_section "Enabling systemd services"
|
||||
for service in "${SYSTEMD_SERVICES[@]}"
|
||||
do
|
||||
enable_service "${service}"
|
||||
print_log "Enabling service ${YELLOW}${service}${RESET}"
|
||||
sudo systemctl enable "${service}"
|
||||
done
|
||||
|
||||
print_section "Copy custom udev rules"
|
||||
|
||||
###############################################################################
|
||||
# Enabling systemd services #
|
||||
###############################################################################
|
||||
print_section "Copying custom udev rules"
|
||||
for file in "${SYSTEM_DIR}/etc/udev/rules.d/"*.rules
|
||||
do
|
||||
copy_udev_rule "${file}"
|
||||
print_log "Copying ${YELLOW}$(basename "${file}")${RESET} to ${YELLOW}/etc/udev/rules.d/${RESET}"
|
||||
sudo cp "${file}" "/etc/udev/rules.d/"
|
||||
done
|
||||
sudo udevadm control --reload-rules
|
||||
|
||||
print_section "Copy sudoers content"
|
||||
for file in "${SYSTEM_DIR}/etc/sudoers.d/"*
|
||||
do
|
||||
copy_sudoers_content "${file}"
|
||||
done
|
||||
|
||||
print_section "Copy other files"
|
||||
print_log "Copy ${SYSTEM_DIR}/etc/docker/daemon.json"
|
||||
###############################################################################
|
||||
# Copying other files #
|
||||
###############################################################################
|
||||
print_section "Copying other files"
|
||||
|
||||
print_log "Copying custom sudoers file to ${YELLOW}/etc/sudoers.d${RESET}"
|
||||
sudo install -m 0440 "${SYSTEM_DIR}/etc/sudoers.d/severin" "/etc/sudoers.d"
|
||||
|
||||
print_log "Copying docker configuration to ${YELLOW}/etc/docker${RESET}"
|
||||
sudo install -m 644 "${SYSTEM_DIR}/etc/docker/daemon.json" "/etc/docker"
|
||||
|
||||
print_section "Set lockscreen image"
|
||||
echo "${DOTFILES}/assets/lockscreen.${HOST}.jpg"
|
||||
betterlockscreen -u "${DOTFILES}/assets/lockscreen.${HOST}.jpg"
|
||||
|
||||
print_section "Create issue file"
|
||||
###############################################################################
|
||||
# Setting lockscreen image #
|
||||
###############################################################################
|
||||
print_section "Setting lockscreen image"
|
||||
betterlockscreen -u "${DOTFILES}/assets/lockscreen.${HOST}.jpg" > /dev/null 2>&1
|
||||
print_log "Lockscreen generated"
|
||||
|
||||
|
||||
###############################################################################
|
||||
# Creating issue file #
|
||||
###############################################################################
|
||||
print_section "Creating issue file"
|
||||
{
|
||||
echo '\e{red}';
|
||||
< "/etc/hostname" tr '[:lower:]' '[:upper:]' | figlet -f big | sed "s/\\\\/\\\\\\\/g";
|
||||
echo -e "\\\r (\\\l)";
|
||||
echo '\e{reset}';
|
||||
echo '\e{red}';
|
||||
< "/etc/hostname" tr '[:lower:]' '[:upper:]' | figlet -f big | sed "s/\\\\/\\\\\\\/g";
|
||||
echo -e "\\\r (\\\l)";
|
||||
echo '\e{reset}';
|
||||
} >> "/tmp/issue"
|
||||
sudo mv "/tmp/issue" "/etc/issue"
|
||||
sudo install "/tmp/issue" "/etc/issue"
|
||||
print_log "Issue file created"
|
Loading…
Add table
Add a link
Reference in a new issue