Project management tool for UV + FastAPI + Vue3 + Electron desktop applications
Project description
xb - Project Management Tool
xb 是一个基于 uv 又类似 uv 的项目管理工具,用于快速初始化 UV + FastAPI + Vue3 + Electron 桌面应用。
特性
- 一键初始化完整项目结构
- UV + FastAPI + Vue3 + Electron 开箱即用
- 可选 sudo 免密配置
- 内置开发、构建、版本管理脚本
- 自动初始化 git 仓库并提交首个 commit
安装
# 安装 uv
curl -LsSf https://astral.sh/uv/install.sh | sh
# 安装 xb
cd xb
uv sync
uv tool install .
xb --help
快速开始
# 在当前目录创建 myapp/ 子目录,自动 git init + 首次 commit
xb init myapp
# 带 sudo 免密配置
xb init myapp --sudoers
cd myapp
# 启动开发环境
xb dev
# 查看状态
xb dev --status
# 停止
xb dev --stop
xb init自动行为:在目标目录执行git init并以chore: xb init 初始化 <package> 项目提交首个 commit。 若系统未安装 git 或未配置user.name/user.email,会打印警告但不阻塞项目创建,可稍后手动补提交。
构建
# 构建所有
xb build
# 单独构建
xb build -f # 前端
xb build -b # 后端
xb build -e # Electron DEB
项目结构
myapp/
├── pyproject.toml # Python 依赖 (uv)
├── backend/ # FastAPI 后端
│ ├── main.py
│ ├── api/
│ └── managers/
├── frontend/ # Vue 3 前端
│ └── src/
├── electron/ # Electron 主进程
├── version/ # 版本管理
│ ├── hooks/
│ └── scripts/
├── configs/ # 配置文件
├── scripts/ # 可执行脚本
├── dev.sh # 开发脚本
├── build.sh # 打包脚本
└── .venv # Python 虚拟环境
版本管理
# 查看当前版本
xb version
配置
Sudo 免密
# 启用 sudo 免密配置
xb init myapp --sudoers
# 密码存储在 configs/global_config.yaml
# 建议设置文件权限: chmod 600 configs/global_config.yaml
技术栈
| 组件 | 技术 |
|---|---|
| 后端 | FastAPI + Uvicorn |
| 前端 | Vue 3 + Vite |
| 桌面 | Electron |
| 构建 | PyInstaller + electron-builder |
| 依赖 | uv |
环境要求
- Python: 3.10+
- Node.js: 16+
- npm: 8+
- OS: Linux
许可证
MIT
故障排查
# 后端启动失败
cat datas/logs/backend.log
lsof -i :8000
# 手动启动测试
cd myapp
.venv/bin/python backend/main.py
# 前端启动失败
cat datas/logs/frontend.log
cd frontend && rm -rf node_modules && npm install
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
xiaomi_xb-1.0.9.tar.gz
(55.9 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
xiaomi_xb-1.0.9-py3-none-any.whl
(73.1 kB
view details)
File details
Details for the file xiaomi_xb-1.0.9.tar.gz.
File metadata
- Download URL: xiaomi_xb-1.0.9.tar.gz
- Upload date:
- Size: 55.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
490619815bd84cd886ee94b6a5870ab0af0b409b74403ccd4fdd08d41c21884a
|
|
| MD5 |
24a0f68c9247c4aea3573fe7a099ac44
|
|
| BLAKE2b-256 |
42a6655b12fbfdb2282118ea0a6c1bb39e8b826c91a841621d67b50e1db14a34
|
File details
Details for the file xiaomi_xb-1.0.9-py3-none-any.whl.
File metadata
- Download URL: xiaomi_xb-1.0.9-py3-none-any.whl
- Upload date:
- Size: 73.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f6b48228b597e011e2e76a4cb5adeadf040c57dd90c62c7e509b8c05359b3821
|
|
| MD5 |
1657eefd6b1c3b1678141031b48e3f89
|
|
| BLAKE2b-256 |
a8c5913600535241037102d375a31e7261fcd9916a52a319304071e938af2696
|