Files
wwjcloud/.trae/rules/common-layer-standards.md

152 lines
5.4 KiB
Markdown
Raw Normal View History

# Common层模块化设计标准
## 📋 概述
本文档定义了 `wwjcloud/src/common/` 层的模块化设计标准,确保每个业务模块符合微服务导向的架构设计原则。
## 🏗️ 模块化设计原则
### 1. 模块完整性原则
每个业务模块必须包含完整的分层结构,为未来微服务拆分做准备。
### 2. 模块自治性原则
模块间通过明确的接口和事件进行通信,避免直接文件导入依赖。
### 3. 分层内聚原则
模块内部按照Spring Boot分层架构组织确保职责清晰。
## 📁 标准目录结构
### 🎯 命名规范策略
- **文件名对齐PHP**所有业务文件名与PHP项目保持一致`User.ts`, `SysUser.ts`, `UserService.ts`
- **目录结构参考Java**采用Java/Spring Boot分层架构组织方式
- **避免NestJS文件命名风格**:不使用 `user.controller.ts` 风格,使用 `User.ts` 风格
### 完整模块结构(必需)
```
src/common/{module-name}/
├── {module-name}.module.ts # 模块定义文件必需NestJS特有
├── controllers/ # 控制器层(必需)
│ ├── adminapi/ # 管理端控制器
│ │ └── {Name}.ts # 对齐PHP: User.php → User.ts
│ └── api/ # 前台控制器
│ └── {Name}.ts # 对齐PHP: User.php → User.ts
├── services/ # 服务层(必需)
│ ├── admin/ # 管理端服务
│ │ └── {Name}Service.ts # 对齐PHP: UserService.php → UserService.ts
│ ├── api/ # 前台服务
│ │ └── {Name}Service.ts # 对齐PHP: UserService.php → UserService.ts
│ └── core/ # 核心业务服务
│ └── {Name}Service.ts # 对齐PHP: UserService.php → UserService.ts
├── entity/ # 实体层(必需)
│ └── {Name}.ts # 对齐PHP: SysUser.php → SysUser.ts
├── dto/ # 数据传输对象(必需)
│ ├── admin/
│ │ └── {Name}Dto.ts # 对齐PHP验证器命名
│ └── api/
│ └── {Name}Dto.ts # 对齐PHP验证器命名
├── interfaces/ # 接口定义(可选)
│ └── {Name}Interface.ts # 对齐PHP接口命名
├── decorators/ # 装饰器(可选)
│ └── {Name}Decorator.ts # 对齐PHP特性命名
├── guards/ # 守卫(可选)
│ └── {Name}Guard.ts # 对齐PHP中间件命名
└── enums/ # 枚举(可选)
└── {Name}Enum.ts # 对齐PHP枚举命名
```
### 最小模块结构(基本要求)
```
src/common/{module-name}/
├── {module-name}.module.ts # 模块定义文件
├── controllers/ # 至少包含一个控制器
├── services/ # 至少包含一个服务
├── entity/ # 至少包含一个实体(如果有数据库操作)
└── dto/ # 至少包含一个DTO如果有API接口
```
## 🔍 当前模块分析结果
### ✅ 完整模块26个
符合标准的模块:
- addon, agreement, aliapp, applet, auth, diy, member, niucloud, pay, poster, site, sys, user, weapp
### ⚠️ 不完整模块11个
需要修复的模块:
#### 缺失DTO的模块8个
- channel: 缺失dto目录
- dict: 缺失dto目录
- generator: 缺失dto目录
- notice: 缺失dto目录
- schedule: 缺失dto目录
- stat: 缺失dto目录
- verify: 缺失dto目录
- wechat: 缺失dto目录
- wxoplatform: 缺失dto目录
#### 缺失Entity的模块3个
- home: 缺失entity目录
- login: 缺失entity目录
- upload: 缺失entity目录
#### 特殊模块1个
- lang: 缺失所有核心层级controllers, services, entity, dto
## 🛠️ 整治计划
### 阶段1修复不完整模块
1. **为缺失DTO的模块添加DTO层**
- 基于控制器方法分析所需的DTO
- 创建标准的admin和api DTO目录结构
2. **为缺失Entity的模块添加Entity层**
- 分析模块功能确定是否需要数据库实体
- 如不需要数据库操作,可创建接口或配置类
3. **处理特殊模块**
- lang模块评估是否需要完整的模块结构或作为配置模块处理
### 阶段2标准化目录结构
1. **统一命名规范**
- 确保所有文件命名符合NestJS规范
- 统一目录组织方式
2. **优化模块依赖**
- 检查模块间的导入关系
- 确保通过接口和事件通信
### 阶段3验证模块自治性
1. **依赖关系检查**
- 识别跨模块直接导入
- 重构为接口或事件通信
2. **边界清晰化**
- 明确模块职责边界
- 为微服务拆分做准备
## 📊 质量标准
### 模块完整性指标
- ✅ 必需文件存在率100%
- ✅ 目录结构规范率100%
- ✅ 命名规范符合率100%
### 模块自治性指标
- ✅ 跨模块直接导入0个
- ✅ 接口通信覆盖率100%
- ✅ 事件通信覆盖率100%
## 🔧 自动化检查
使用 `auto-mapping-checker.js` 进行自动化检查:
```bash
node auto-mapping-checker.js --check-common-structure
```
检查项目:
- [ ] 模块目录完整性
- [ ] 必需文件存在性
- [ ] 命名规范符合性
- [ ] 模块依赖关系
- [ ] 微服务边界清晰度