- 后端:Bun + Hono + Drizzle ORM + SQLite - 前端:Vue 3 + Naive UI + ECharts - 项目管理:创建项目 + 绑定 Git 仓库 - OKR 系统:目标/关键结果 CRUD + 进度追踪 - Git 同步:Gitea API 自动同步 commit/PR + 作者关联 - 数据看板:项目 OKR 进度 + KR 状态分布 + 代码活动 - 权限体系:admin/manager/developer/viewer 四级 - Docker 部署:docker-compose + nginx Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
18 lines
518 B
TypeScript
18 lines
518 B
TypeScript
import { MiddlewareHandler } from 'hono';
|
|
import { AppError } from './error-handler';
|
|
|
|
type UserRole = 'admin' | 'manager' | 'developer' | 'viewer';
|
|
|
|
export function requireRole(...roles: UserRole[]): MiddlewareHandler {
|
|
return async (c, next) => {
|
|
const user = c.get('user');
|
|
if (!user) {
|
|
throw new AppError(40101, 'Authentication required', 401);
|
|
}
|
|
if (!roles.includes(user.role as UserRole)) {
|
|
throw new AppError(40103, 'Insufficient permissions', 403);
|
|
}
|
|
await next();
|
|
};
|
|
}
|