Skip to main content

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


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)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xiaomi_xb-1.0.9-py3-none-any.whl (73.1 kB view details)

Uploaded Python 3

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

Hashes for xiaomi_xb-1.0.9.tar.gz
Algorithm Hash digest
SHA256 490619815bd84cd886ee94b6a5870ab0af0b409b74403ccd4fdd08d41c21884a
MD5 24a0f68c9247c4aea3573fe7a099ac44
BLAKE2b-256 42a6655b12fbfdb2282118ea0a6c1bb39e8b826c91a841621d67b50e1db14a34

See more details on using hashes here.

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

Hashes for xiaomi_xb-1.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 f6b48228b597e011e2e76a4cb5adeadf040c57dd90c62c7e509b8c05359b3821
MD5 1657eefd6b1c3b1678141031b48e3f89
BLAKE2b-256 a8c5913600535241037102d375a31e7261fcd9916a52a319304071e938af2696

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page