1-1:搭建项目框架

初始化prisma

server文件夹下,执行命令npx prisma init。于是在server文件夹下,就创建了prisma目录

在server目录下创建新模块

不需要来回切换目录。执行命令:nest g res user --project server。这个命令是在根目录下执行的(server),但是它会自动找到server/server/src,然后将user模块写入,并自动和app.module进行绑定

在ai中创建chat模块

同理:nest g res chat --project ai

shared中创建

在server/libs/shared/src创建prisma nest g mo prisma --project shared
nest g s prisma --project shared 显然prisma是ai和server都需要使用的,因此需要将prisma注册为全局模块

  1. 在shared/src/index.ts中,将prisma的service+module导出
js 复制代码
export * from './prisma/prisma.service'
export * from './prisma/prisma.module'
  1. 在prisma.module中导出prisma的service
js 复制代码
@Module({
    providers:[PrismaService],
    exports:[PrismaService]
})
  1. 在shared.module中导出prismaModule
js 复制代码
@Module({
    providers:[SharedService],
    exports:[SharedService,PrimsaService],
    imports:[PrimsaModule]
})
  1. 将shared.module扩充为全局模块(@Global
js 复制代码
@Global()
@Module({
    imports:[PrimsaModule],
    providers:[SharedService],
    exports:[SharedService,PrimsaModule],
})
  1. 在app.module中注册一下
js 复制代码
@Module({
    imports:[UserModule,SharedModule],
    controllers:[AppController],
    providers:[AppService],
})

Tips:如果Prisma是一个独立的基础设施模块,可以直接让PrismaModule自己@Glabal()

js 复制代码
@Global()
@Module({
  providers: [PrismaService],
  exports: [PrismaService],
})
export class PrismaModule {}

但是,这里我们希望把所有的共享基础设施(比如有PrismaModule,RedisModule,LoggerModule)都通过SharedModule做统一出口暴露,就要采用上面的方式,将SharedModule做全局模块聚合 此外关于@Globalexport * from './prisma/prisma.service':
@Global解决的是运行时的依赖注入问题,通过它可以实现其它模块这样注入:

js 复制代码
constructor(private readonly prisma: PrismaService) {}

@Global() 不会让 TypeScript 自动知道 PrismaService 从哪里import。因此此时导入需要写很长的路径:import { PrismaService } from 'libs/shared/src/prisma/prisma.service' 但是,通过

js 复制代码
export * from './prisma/prisma.module'
export * from './prisma/prisma.service'

我们可以写import { PrismaService } from '@app/shared'

简单测试一下,记得将nest-cli.json中的webpack配置项删除(我们并不希望通过webpack进行编译)

相关推荐
禅思院2 小时前
Vite vs Webpack 深度对比:从启动原理到生产构建,一篇就够了
前端·架构·前端框架
Cerrda21 小时前
开发体验升级:UnoCSS 自定义 SVG 图标热更新方案
架构·前端框架
Kstheme1 天前
把任何 GitHub 仓库变成系统设计课:这个开源项目做到了
架构
禅思院1 天前
路由性能高可用架构实战方案
前端·架构·前端框架
贵慜_Derek2 天前
《从零实现 Agent 系统》连载 32|闭集 IE 与小模型:分类、意图与字段抽取
人工智能·架构·agent
江米小枣tonylua3 天前
译:设计生产级 RAG 架构
架构
怕浪猫3 天前
领域特定语言(Domain-Specific Language, DSL)
设计模式·程序员·架构
怕浪猫3 天前
哪些软件对 Chrome DevTools Protocol 频繁使用
人工智能·架构·前端框架
Jack203 天前
HarmonyOS APP事件驱动大揭秘
架构
Colin草率地做慢慢地改3 天前
关于QuickStore这个项目的重构(2)- 数据库建表文件
后端·面试·架构