VTJ.PRO 在线应用开发平台的后端模块系统

后端模块系统

VTJ.PRO 后端是一个基于 NestJS 的应用,其设计采用了模块化架构,将平台级服务与特定领域的业务逻辑分离开来。它为低代码引擎提供了坚实的基础,具有自动验证、标准化响应封装和全面的安全模型等特性。

AppModule 组合

AppModule 作为后端应用的根模块。它协调了核心基础设施、业务模块和全局配置的集成。

  • 基础设施 :通过 ConfigModule 加载环境变量,通过 TypeOrmModule 管理数据库连接,并通过 MulterModule 处理文件上传。
  • 模块分离 :系统区分了 CoreModules(身份认证、访问控制、系统设置)和 BusinessModules(低代码应用、DSL管理、AI智能体)。

后端系统架构

下图说明了主入口点、共享基础设施和模块层之间的关系。

flowchart TD Main["main.ts"] AppMod["AppModule"] ValPipe["ValidationPipe"] LogInt["LoggingInterceptor"] ResInt["ResponseInterceptor"] ExcFil["AllExceptionsFilter"] Core["Core Modules (Auth, RBAC, Cache)"] Biz["Business Modules (DSL, Apps, AI)"] Main --> AppMod AppMod --> Core AppMod --> Biz AppMod -.-> ValPipe AppMod -.-> LogInt AppMod -.-> ResInt

全局中间件与请求生命周期

后端使用 NestJS 的原生组件实现标准化的请求/响应生命周期,以确保所有端点的一致性。

组件 类名 用途
验证 ValidationPipe 强制使用 DTO 模式并转换输入类型
日志记录 LoggingInterceptor 记录请求持续时间和元数据,用于监控
响应封装 ResponseInterceptor 将所有成功响应封装为标准 { code, data, msg } 格式
异常处理 AllExceptionsFilter 捕获所有错误并返回标准化的 JSON 错误响应

Swagger 文档

该平台使用 Swagger 自动生成 API 文档。在开发环境中,可通过 /docs 端点访问。该设置包括 JWT Bearer 认证配置,允许直接从 UI 测试受保护的路由。

核心模块与业务模块

代码库在 backend/src/ 中分为两个主要目录,以保持关注点的清晰分离。

核心模块

这些模块提供了任何企业应用所需的"平台"能力。

  • 身份与访问AuthModuleUserModule 处理认证(包括 OAuth)和用户资料。
  • RBACRoleModulePermissionModule 管理细粒度的访问控制列表。
  • 系统服务 :包括 CacheModule(Redis/内存)、SettingModule(全局配置)和 OssModule(对象存储)。

有关详细信息,请参阅 核心模块(用户、认证、RBAC、缓存、设置)

业务模块

这些模块包含特定于 VTJ 低代码平台的领域逻辑。

  • 低代码引擎LowcodeAppModuleDSLModule 管理应用及其 JSON 模式的生命周期。
  • AI 与智能AgentModuleSkillModule 与大语言模型(LLMs)集成,提供 AI 辅助开发功能。
  • 商业与运营OrderModuleProductModule 处理平台的商业化功能。

有关详细信息,请参阅 业务模块(应用、DSL、模板、订单、智能体、技能)

代码实体映射

下图展示了逻辑模块组与其在代码中具体服务实现之间的映射关系。

flowchart TD AuthS["AuthService"] UserS["UserService"] RoleS["RoleService"] CacheS["CacheService"] AppS["LowcodeAppService"] DslS["DslService"] AgentS["AgentService"] SkillS["SkillService"] BCS["BaseCrudService"] BCC["BaseCrudController"] AuthS -.-> UserS AppS -.-> BCS RoleS -.-> BCS DslS -.-> AppS

参考资料

相关推荐
踩着两条虫2 小时前
VTJ.PRO 在线应用开发平台的业务模块(应用、DSL、模板、订单、智能体、技能)
后端·agent·nestjs
踩着两条虫2 小时前
VTJ.PRO 在线应用开发平台的核心模块(用户、认证、RBAC、缓存、设置)
后端·低代码·nestjs
王码码20352 小时前
Flutter for OpenHarmony:使用 pluto_grid 打造高性能数据网格
flutter·http·华为·架构·harmonyos
无籽西瓜a2 小时前
【西瓜带你学设计模式 | 第二期-观察者模式】观察者模式——推模型与拉模型实现、优缺点与适用场景
java·后端·观察者模式·设计模式
GISer_Jing2 小时前
Claude Code架构深度解析:从核心文件到Harness的确定性控制体系
ai·架构·aigc
倾颜2 小时前
我是怎么把单 Tool Calling 升级成多 Tool Runtime 的
前端·后端·langchain
Counter-Strike大牛2 小时前
SpringBoot项目调用数据库函数报错Result consisted of more than one row
数据库·spring boot·后端
清汤饺子2 小时前
Superpowers:给 AI 编程 Agent 装上"工程化超能力"
前端·javascript·后端
踩着两条虫2 小时前
AI驱动的Vue3应用开发平台 深入探究(十三):物料系统之区块与页面模板
前端·vue.js·人工智能·架构·系统架构