fix: 修复模块收敛性、异常处理和引导脚本健壮性

- dev: 异常捕获改为 except Exception 适配 decman 自定义异常
- docker/zsh/wsl: on_enable 改为 after_update + 状态检查确保收敛
- docker/zsh: subprocess 失败时 early return 避免误触发
- wsl: systemctl 调用加 try/except 防止 systemd 不可用时崩溃
- zsh: shell 路径改为精确解析 passwd 字段
- docker: decorator 别名统一为 pacman_packages
- install.sh: 开头验证 sudo 权限、mkdir -p 确保父目录、[ 改 [[
- wsl-init.sh: pacman -Sy 改 -Syu 避免 partial upgrade、已有用户补 wheel 组
This commit is contained in:
2026-03-26 20:41:54 +08:00
parent 769ca0a44b
commit 7d0ceb4e1c
6 changed files with 65 additions and 16 deletions
+8 -2
View File
@@ -42,6 +42,12 @@ class DevModule(Module):
def after_update(self, store):
for pkg in BUN_GLOBAL_PACKAGES:
decman.prg(["su", "-", self.user, "-c", f"bun add -g {pkg}"])
try:
decman.prg(["su", "-", self.user, "-c", f"bun add -g {pkg}"])
except Exception:
print(f"警告:安装 {pkg} 失败,跳过")
for pkg in GO_INSTALL_PACKAGES:
decman.prg(["su", "-", self.user, "-c", f"go install {pkg}"])
try:
decman.prg(["su", "-", self.user, "-c", f"go install {pkg}"])
except Exception:
print(f"警告:安装 {pkg} 失败,跳过")
+13 -5
View File
@@ -1,6 +1,8 @@
import subprocess
import decman
from decman import Module
from decman.plugins.pacman import packages
from decman.plugins.pacman import packages as pacman_packages
from decman.plugins.systemd import units
@@ -9,13 +11,19 @@ class DockerModule(Module):
super().__init__("docker")
self.user = user
@packages
def packages(self) -> set[str]:
@pacman_packages
def pacman_packages(self) -> set[str]:
return {"docker", "docker-compose"}
@units
def units(self) -> set[str]:
return {"docker.socket"}
def on_enable(self, store):
decman.prg(["gpasswd", "-a", self.user, "docker"])
def after_update(self, store):
result = subprocess.run(
["id", "-nG", self.user], capture_output=True, text=True
)
if result.returncode != 0:
return
if "docker" not in result.stdout.split():
decman.prg(["gpasswd", "-a", self.user, "docker"])
+17 -2
View File
@@ -1,3 +1,5 @@
import subprocess
import decman
from decman import Module
@@ -6,5 +8,18 @@ class WslModule(Module):
def __init__(self):
super().__init__("wsl")
def on_enable(self, store):
decman.prg(["systemctl", "mask", "systemd-networkd-wait-online.service"])
def after_update(self, store):
try:
result = subprocess.run(
["systemctl", "is-enabled", "systemd-networkd-wait-online.service"],
capture_output=True,
text=True,
)
if result.stdout.strip() != "masked":
decman.prg(
["systemctl", "mask", "systemd-networkd-wait-online.service"]
)
except Exception:
print(
"警告:systemd 不可用,跳过 mask systemd-networkd-wait-online.service"
)
+12 -2
View File
@@ -1,3 +1,5 @@
import subprocess
import decman
from decman import File, Module
from decman.plugins.aur import packages as aur_packages
@@ -38,5 +40,13 @@ class ZshModule(Module):
"oh-my-zsh-git",
}
def on_enable(self, store):
decman.prg(["chsh", "-s", "/usr/bin/zsh", self.user])
def after_update(self, store):
result = subprocess.run(
["getent", "passwd", self.user], capture_output=True, text=True
)
if result.returncode != 0:
return
# passwd 格式: name:x:uid:gid:gecos:home:shell
shell = result.stdout.strip().split(":")[-1]
if shell != "/usr/bin/zsh":
decman.prg(["chsh", "-s", "/usr/bin/zsh", self.user])
+6 -2
View File
@@ -4,13 +4,17 @@ set -euo pipefail
REPO_URL="https://git.furtherverse.com/imbytecat/archlinux-config.git"
CONFIG_DIR="$HOME/.config/archlinux-config"
echo "==> 验证 sudo 权限..."
sudo -v < /dev/tty || { echo "错误:需要 sudo 权限,请确认当前用户已配置 sudo"; exit 1; }
echo "==> 安装 git..."
sudo pacman -S --needed --noconfirm git
echo "==> 克隆配置仓库..."
if [ -d "$CONFIG_DIR/.git" ]; then
mkdir -p "$(dirname "$CONFIG_DIR")"
if [[ -d "$CONFIG_DIR/.git" ]]; then
echo "配置仓库已存在:$CONFIG_DIR,跳过克隆"
elif [ -e "$CONFIG_DIR" ]; then
elif [[ -e "$CONFIG_DIR" ]]; then
echo "目标路径已存在且不是 git 仓库:$CONFIG_DIR"
exit 1
else
+9 -3
View File
@@ -18,8 +18,13 @@ if [ -z "$USERNAME" ]; then
exit 1
fi
echo "==> 同步数据库并安装 sudo..."
pacman -Sy --needed --noconfirm sudo
echo "==> 更新系统..."
pacman -Syu --noconfirm
if ! command -v sudo &> /dev/null; then
echo "==> 安装 sudo..."
pacman -S --needed --noconfirm sudo
fi
echo "==> 配置 sudo 权限..."
cat > /etc/sudoers.d/10-wheel << 'EOF'
@@ -29,7 +34,8 @@ chmod 440 /etc/sudoers.d/10-wheel
echo "==> 创建用户 $USERNAME..."
if id "$USERNAME" &> /dev/null; then
echo "用户 $USERNAME 已存在,跳过创建"
echo "用户 $USERNAME 已存在,确保 wheel 组成员"
usermod -aG wheel "$USERNAME"
else
useradd -m -G wheel -s /bin/bash "$USERNAME"
echo "请设置 $USERNAME 的密码:"