89 lines
2.7 KiB
Bash
Executable File
89 lines
2.7 KiB
Bash
Executable File
#!/bin/bash
|
|
set -e
|
|
|
|
# Colors
|
|
GREEN='\033[1;32m'
|
|
YELLOW='\033[1;33m'
|
|
RED='\033[1;31m'
|
|
NC='\033[0m'
|
|
|
|
# Root Check
|
|
if [ "$EUID" -ne 0 ]; then
|
|
echo -e "${RED}Please run this script as root.${NC}"
|
|
exit 1
|
|
fi
|
|
|
|
# OS Detection
|
|
echo -e "${YELLOW}LOG: Detecting OS...${NC}"
|
|
if [ -f /etc/os-release ]; then
|
|
. /etc/os-release
|
|
OS=$ID
|
|
fi
|
|
|
|
# Install Prerequisites (Git, Make, Zsh, Sudo)
|
|
echo -e "${YELLOW}LOG: Updating system and installing base tools...${NC}"
|
|
|
|
if [ "$OS" == "arch" ] || [ "$OS" == "manjaro" ]; then
|
|
pacman -Sy --noconfirm git make curl zsh sudo
|
|
SUDO_GROUP="wheel"
|
|
elif [ "$OS" == "ubuntu" ] || [ "$OS" == "debian" ]; then
|
|
apt-get update
|
|
apt-get install -y git make curl sudo
|
|
SUDO_GROUP="sudo"
|
|
else
|
|
echo -e "${RED}Unsupported OS: $OS${NC}"
|
|
exit 1
|
|
fi
|
|
|
|
# Interactive Prompts
|
|
echo -e "${GREEN}---------------------------------------${NC}"
|
|
echo -e "${GREEN} USER PROVISIONING WIZARD ${NC}"
|
|
echo -e "${GREEN}---------------------------------------${NC}"
|
|
|
|
read -p "Enter Username (default: mangopig): " USERNAME
|
|
USERNAME=${USERNAME:-mangopig}
|
|
|
|
read -p "Enter UID (default: 1000): " USER_UID
|
|
USER_UID=${USER_UID:-1000}
|
|
|
|
read -p "Enter GID (default: 1000): " USER_GID
|
|
USER_GID=${USER_GID:-1000}
|
|
|
|
# Group Creation
|
|
if getent group "$USER_GID" >/dev/null; then
|
|
echo -e "${YELLOW}LOG: Group with GID $USER_GID already exists. Using it.${NC}"
|
|
else
|
|
echo -e "${YELLOW}LOG: Creating group $USERNAME with GID $USER_GID...${NC}"
|
|
groupadd -g "$USER_GID" "$USERNAME"
|
|
fi
|
|
|
|
# User Creation
|
|
if id "$USERNAME" &>/dev/null; then
|
|
echo -e "${YELLOW}LOG: User $USERNAME already exists. Skipping creation.${NC}"
|
|
else
|
|
echo -e "${YELLOW}LOG: Creating user $USERNAME...${NC}"
|
|
|
|
# Create user with specific UID, GID, Groups, and Shell
|
|
useradd -m -u "$USER_UID" -g "$USER_GID" -G "$SUDO_GROUP" -s "$ZSH_PATH" "$USERNAME"
|
|
|
|
echo -e "${GREEN}LOG: Setting password for $USERNAME...${NC}"
|
|
passwd "$USERNAME"
|
|
fi
|
|
|
|
# Sudo Configuration (Passwordless)
|
|
echo -e "${YELLOW}LOG: Configuring passwordless sudo...${NC}"
|
|
echo "$USERNAME ALL=(ALL) NOPASSWD:ALL" > "/etc/sudoers.d/90-$USERNAME"
|
|
chmod 0440 "/etc/sudoers.d/90-$USERNAME"
|
|
|
|
# Arch Specific: Uncomment wheel in sudoers if not already active
|
|
if [ "$OS" == "arch" ]; then
|
|
# Ensure the 'wheel' group is actually enabled in the main config if drop-in fails
|
|
sed -i 's/^# %wheel ALL=(ALL:ALL) ALL/%wheel ALL=(ALL:ALL) ALL/' /etc/sudoers
|
|
fi
|
|
|
|
# Cloning Dotfiles
|
|
echo -e "${YELLOW}LOG: Cloning dotfiles for $USERNAME...${NC}"
|
|
sudo -u "$USERNAME" git clone https://git.mangopig.tech/MangoPig/Dot-Zsh.git "/home/$USERNAME/Config/Dot-Zsh"
|
|
|
|
|
|
echo -e "${GREEN}✅ Server Provisioned! Log out and SSH as $USERNAME.${NC}" |