feat: NixOS 声明式配置(从 Arch + decman 迁移)

- flake.nix: NixOS + home-manager + nixos-wsl 三输入
- hosts/wsl + hosts/bare: WSL 与裸机共享模块,分主机配置
- modules/: base(CLI 工具) + dev(工具链+LSP) + docker + locale + shell
- home/: zsh(oh-my-zsh+插件+别名) + git(delta) + starship + 工具集成
- scripts/install.sh: 一键安装脚本(WSL/裸机通用)
- 原 bun/go 全局包 hack 改为 nixpkgs 声明式管理
This commit is contained in:
2026-04-03 19:05:06 +08:00
parent 5c851ea250
commit d58c650d59
33 changed files with 574 additions and 1058 deletions
+13 -30
View File
@@ -1,42 +1,25 @@
#!/bin/bash
# NixOS 配置安装脚本
# 在 NixOS-WSL 或裸机 NixOS 中运行
set -euo pipefail
REPO_URL="https://git.furtherverse.com/imbytecat/archlinux-config.git"
CONFIG_DIR="$HOME/.config/archlinux-config"
CONFIG_DIR="$HOME/.config/nixos-config"
FLAKE_TARGET="${1:-wsl}" # 默认 wsl,裸机传入 bare
echo "🔑 验证 sudo 权限..."
sudo -v < /dev/tty || { echo "❌ 需要 sudo 权限,请确认当前用户已配置 sudo"; exit 1; }
echo "🔄 更新系统..."
sudo pacman -Syu --noconfirm
echo "📦 安装基础依赖..."
sudo pacman -S --needed --noconfirm git base-devel
echo "📥 克隆配置仓库..."
mkdir -p "$(dirname "$CONFIG_DIR")"
echo "📥 获取配置仓库..."
if [[ -d "$CONFIG_DIR/.git" ]]; then
echo "⏩ 配置仓库已存在,跳过克隆"
elif [[ -e "$CONFIG_DIR" ]]; then
echo "❌ 目标路径已存在且不是 git 仓库:$CONFIG_DIR"
exit 1
echo "⏩ 仓库已存在,拉取最新..."
git -C "$CONFIG_DIR" pull
else
git clone "$REPO_URL" "$CONFIG_DIR"
git clone -b nixos "$REPO_URL" "$CONFIG_DIR"
fi
echo "📦 安装 decman..."
if ! command -v decman &> /dev/null; then
_tmpdir=$(mktemp -d)
trap 'rm -rf "$_tmpdir"' EXIT
git clone https://aur.archlinux.org/decman.git "$_tmpdir"
(cd "$_tmpdir" && makepkg -si --noconfirm)
fi
echo "⚙️ 应用系统配置..."
sudo decman --source "$CONFIG_DIR/source.py" < /dev/tty
echo "⚙️ 应用系统配置(目标: $FLAKE_TARGET..."
sudo nixos-rebuild switch --flake "$CONFIG_DIR#$FLAKE_TARGET"
echo ""
echo "🎉 安装完成!重新登录以使用 zsh。"
echo "🎉 安装完成!重新登录以使用 zsh。"
echo ""
echo "后续更新配置"
echo " cd $CONFIG_DIR && git pull && sudo decman"
echo "后续更新:"
echo " cd $CONFIG_DIR && git pull && sudo nixos-rebuild switch --flake .#$FLAKE_TARGET"
-54
View File
@@ -1,54 +0,0 @@
#!/bin/bash
set -euo pipefail
if [ "$(id -u)" -ne 0 ]; then
echo "❌ 请以 root 身份运行此脚本"
exit 1
fi
if [[ ! -f /proc/sys/fs/binfmt_misc/WSLInterop ]]; then
echo "❌ 此脚本仅用于 Arch Linux on WSL 的首次初始化"
exit 1
fi
USERNAME="${1:-}"
if [ -z "$USERNAME" ]; then
echo "用法: wsl-init.sh <用户名>"
echo "示例: wsl-init.sh imbytecat"
exit 1
fi
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'
%wheel ALL=(ALL) NOPASSWD: ALL
EOF
chmod 440 /etc/sudoers.d/10-wheel
echo "👤 创建用户 $USERNAME..."
if id "$USERNAME" &> /dev/null; then
echo "⏩ 用户 $USERNAME 已存在,确保 wheel 组成员"
usermod -aG wheel "$USERNAME"
else
useradd -m -G wheel -s /bin/bash "$USERNAME"
echo "请设置 $USERNAME 的密码:"
passwd "$USERNAME" < /dev/tty
fi
echo ""
echo "🎉 WSL 初始化完成!"
echo ""
echo "下一步:"
echo " 1. 在 PowerShell 中设置默认用户:"
echo " wsl --manage archlinux --set-default-user $USERNAME"
echo " 2. 重启 WSL"
echo " wsl --terminate archlinux"
echo " 3. 重新打开 Arch WSL 后运行:"
echo " curl -fsSL https://git.furtherverse.com/imbytecat/archlinux-config/raw/branch/main/scripts/install.sh | bash"