refactor(modules): 提取 BaseModule,将基础包和系统文件移入模块
This commit is contained in:
@@ -0,0 +1,46 @@
|
|||||||
|
from decman import File, Module
|
||||||
|
from decman.plugins.aur import packages as aur_packages
|
||||||
|
from decman.plugins.pacman import packages as pacman_packages
|
||||||
|
|
||||||
|
|
||||||
|
class BaseModule(Module):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__("base")
|
||||||
|
|
||||||
|
def files(self):
|
||||||
|
return {
|
||||||
|
"/etc/pacman.d/mirrorlist": File(
|
||||||
|
source_file="./system/etc/pacman.d/mirrorlist",
|
||||||
|
),
|
||||||
|
"/etc/sudoers.d/10-wheel": File(
|
||||||
|
source_file="./system/etc/sudoers.d/10-wheel",
|
||||||
|
permissions=0o440,
|
||||||
|
),
|
||||||
|
}
|
||||||
|
|
||||||
|
@pacman_packages
|
||||||
|
def pacman_packages(self) -> set[str]:
|
||||||
|
return {
|
||||||
|
"base-devel",
|
||||||
|
"bat",
|
||||||
|
"bun",
|
||||||
|
"curl",
|
||||||
|
"fd",
|
||||||
|
"git",
|
||||||
|
"mise",
|
||||||
|
"neovim",
|
||||||
|
"nodejs",
|
||||||
|
"ripgrep",
|
||||||
|
"sudo",
|
||||||
|
"trash-cli",
|
||||||
|
"vim",
|
||||||
|
"wget",
|
||||||
|
"zoxide",
|
||||||
|
}
|
||||||
|
|
||||||
|
@aur_packages
|
||||||
|
def aur_packages(self) -> set[str]:
|
||||||
|
return {
|
||||||
|
"decman",
|
||||||
|
"yay",
|
||||||
|
}
|
||||||
@@ -10,8 +10,8 @@ Arch Linux 声明式系统配置 — decman
|
|||||||
import os
|
import os
|
||||||
|
|
||||||
import decman
|
import decman
|
||||||
from decman import File
|
|
||||||
|
|
||||||
|
import modules.base
|
||||||
import modules.docker
|
import modules.docker
|
||||||
import modules.locale
|
import modules.locale
|
||||||
import modules.zsh
|
import modules.zsh
|
||||||
@@ -24,46 +24,11 @@ assert decman.systemd is not None
|
|||||||
USERNAME = os.environ.get("SUDO_USER")
|
USERNAME = os.environ.get("SUDO_USER")
|
||||||
if not USERNAME:
|
if not USERNAME:
|
||||||
raise decman.SourceError("请使用 sudo decman 运行")
|
raise decman.SourceError("请使用 sudo decman 运行")
|
||||||
HOME = f"/home/{USERNAME}"
|
|
||||||
|
|
||||||
# ── 系统文件(/etc/)──────────────────────────────────────────
|
|
||||||
decman.files["/etc/pacman.d/mirrorlist"] = File(
|
|
||||||
source_file="./system/etc/pacman.d/mirrorlist",
|
|
||||||
)
|
|
||||||
|
|
||||||
decman.files["/etc/sudoers.d/10-wheel"] = File(
|
|
||||||
source_file="./system/etc/sudoers.d/10-wheel",
|
|
||||||
permissions=0o440,
|
|
||||||
)
|
|
||||||
|
|
||||||
# ── Modules ──────────────────────────────────────────────────
|
# ── Modules ──────────────────────────────────────────────────
|
||||||
decman.modules += [
|
decman.modules += [
|
||||||
|
modules.base.BaseModule(),
|
||||||
modules.locale.LocaleModule(),
|
modules.locale.LocaleModule(),
|
||||||
modules.docker.DockerModule(),
|
modules.docker.DockerModule(),
|
||||||
modules.zsh.ZshModule(USERNAME),
|
modules.zsh.ZshModule(USERNAME),
|
||||||
]
|
]
|
||||||
|
|
||||||
# ── Pacman 包(官方仓库)──────────────────────────────────────
|
|
||||||
decman.pacman.packages |= {
|
|
||||||
"base-devel",
|
|
||||||
"bat",
|
|
||||||
"bun",
|
|
||||||
"curl",
|
|
||||||
"fd",
|
|
||||||
"git",
|
|
||||||
"mise",
|
|
||||||
"neovim",
|
|
||||||
"nodejs",
|
|
||||||
"ripgrep",
|
|
||||||
"sudo",
|
|
||||||
"trash-cli",
|
|
||||||
"vim",
|
|
||||||
"wget",
|
|
||||||
"zoxide",
|
|
||||||
}
|
|
||||||
|
|
||||||
# ── AUR 包 ────────────────────────────────────────────────────
|
|
||||||
decman.aur.packages |= {
|
|
||||||
"decman",
|
|
||||||
"yay",
|
|
||||||
}
|
|
||||||
|
|||||||
Reference in New Issue
Block a user