lazy/init_sudo.sh

174 lines
4.9 KiB
Bash
Executable File

#!/bin/bash
scriptdir=$(dirname $(realpath $0))
tempdir="/tmp"
# ============================================================
git_clone() {
local repo=$1
local dir=$2
if [ ! -d "$dir" ]; then
if [ "$3" = "--norecursive" ]; then
git clone --single-branch "$github/$repo" $dir
else
git clone --single-branch --recursive "$github/$repo" $dir
fi
fi
}
# ============================================================
check_google_access() {
abroad=0
local response=$(curl -s -o /dev/null -w "%{http_code}" -m 5 "http://www.google.com")
if [ "$response" -eq 200 ]; then
abroad=1
echo "Internet: abroad"
github="https://github.com"
else
abroad=0
echo "Internet: internal"
github="https://g.nano.ac/https://github.com"
fi
}
configure_ssh() {
[ -f ~/.ssh/authorized_keys ] && return
read -p "要配置 .ssh 吗?[Y/n]: " response
if [[ -z "$response" ]] || [[ $response =~ ^[Yy]$ ]]; then
mkdir -p ~/.ssh
cp $scriptdir/files/authorized_keys ~/.ssh/authorized_keys
fi
}
configure_ssh_keygen() {
[ -f ~/.ssh/id_ed25519.pub ] && return
read -p "要生成 sshkey 吗?[y/N]: " response
if [[ $response =~ ^[Yy]$ ]]; then
mkdir -p ~/.ssh
read -p "sshkey 的名字: " sshkeyname
ssh-keygen -t ed25519 -C $sshkeyname
fi
}
configure_nano() {
[ -f ~/.nanorc ] && return
read -p "要配置 nano 吗?[Y/n]: " response
if [[ -z "$response" ]] || [[ $response =~ ^[Yy]$ ]]; then
sudo apt install nano -y
cp $scriptdir/files/.nanorc ~/.nanorc
fi
}
configure_vim() {
read -p "要配置 vim 吗?[Y/n]: " response
if [[ -z "$response" ]] || [[ $response =~ ^[Yy]$ ]]; then
sudo apt install vim -y
cp $scriptdir/files/.vimrc ~/.vimrc
fi
}
configure_apt_upgrade() {
read -p "要运行 apt upgrade 吗?[y/N]: " response
if [[ $response =~ ^[Yy]$ ]]; then
sudo apt update
sudo apt upgrade -y
sudo apt autoremove -y
fi
}
configure_apt_install() {
read -p "要运行 apt install 吗?[Y/n]: " response
if [[ -z "$response" ]] || [[ $response =~ ^[Yy]$ ]]; then
sudo apt update
sudo apt install tmux git curl htop net-tools tcptraceroute tar unzip -y
sudo apt install hexyl bat neofetch fd-find fzf -y
sudo apt install exa -y
if [ $? -ne 0 ]; then
unzip $scriptdir/files/exa-linux-x86_64-v0.10.1.zip -d $tempdir/exa
sudo cp $tempdir/exa/bin/* /usr/local/bin/
sudo cp $tempdir/exa/man/* /usr/share/man/man1/
sudo cp $tempdir/exa/completions/exa.zsh /usr/local/share/zsh/site-functions
rm $tempdir/exa -r
fi
fi
}
configure_zsh() {
[ -f ~/.zshrc ] && return
read -p "要配置 zsh 吗?[Y/n]: " response
if [[ -z "$response" ]] || [[ $response =~ ^[Yy]$ ]]; then
sudo apt install zsh -y
git_clone ohmyzsh/ohmyzsh ~/.oh-my-zsh
RUNZSH=no ZSH=~/.oh-my-zsh $scriptdir/files/install-ohmyzsh.sh
git_clone zsh-users/zsh-autosuggestions ~/.oh-my-zsh/plugins/zsh-autosuggestions
git_clone zsh-users/zsh-syntax-highlighting ~/.oh-my-zsh/plugins/zsh-syntax-highlighting
git_clone paulirish/git-open ~/.oh-my-zsh/plugins/git-open
sudo apt install autojump -y
cp $scriptdir/files/.zshrc ~/.zshrc
cp $scriptdir/files/ys-simple.zsh-theme ~/.oh-my-zsh/themes/ys-simple.zsh-theme
fi
}
configure_tmux() {
[ -f ~/.tmux.conf ] && return
read -p "要配置 tmux 吗?[Y/n]: " response
if [[ -z "$response" ]] || [[ $response =~ ^[Yy]$ ]]; then
sudo apt install tmux -y
git_clone tmux-plugins/tpm ~/.tmux/plugins/tpm --norecursive
git_clone tmux-plugins/tmux-sensible ~/.tmux/plugins/tmux-sensible
git_clone tmux-plugins/tmux-yank ~/.tmux/plugins/tmux-yank
git_clone tmux-plugins/tmux-prefix-highlight ~/.tmux/plugins/tmux-prefix-highlight
git_clone seebi/tmux-colors-solarized ~/.tmux/plugins/tmux-colors-solarized
cp $scriptdir/files/.tmux.conf ~/.tmux.conf
sudo apt install xsel -y # 能够让 tmux 剪切板与 terminal 同步
fi
}
configure_iptables() {
[ -f /etc/network/if-pre-up.d/iptables-load ] && return
read -p "要配置 iptables 吗?[n/Y]: " response
if [[ $response =~ ^[Yy]$ ]]; then
sudo cp $scriptdir/files/iptables-load /etc/network/if-pre-up.d/iptables-load
sudo chmod +x /etc/network/if-pre-up.d/iptables-load
sudo sh /etc/network/if-pre-up.d/iptables-load
fi
}
if [[ $EUID -eq 0 ]]; then
echo "This script should not be run as root."
exit 1
fi
check_google_access
configure_ssh
configure_ssh_keygen
configure_nano
configure_vim
configure_apt_upgrade
configure_apt_install
configure_zsh
configure_tmux
configure_iptables