做了一个nest.js prisma模块,让prisma支持切面编程的精髓:监听器

开头先上正菜。安装方法:

bash 复制代码
pnpm i @nailyjs.nest.modules/prisma

没装Prisma的请先装:

bash 复制代码
pnpm i prisma @prisma/client

这俩是必须滴。

使用

和其他三方nest模块一样,参照README.md先从@nailyjs.nest.modules/prisma中导入PrismaModule到你的根模块中。

typescript 复制代码
import { Module } from '@nestjs/common';
import { PrismaModule } from '@nailyjs.nest.modules/prisma';

@Module({
  imports: [
    // 导入Prisma模块。如果不注册任何监听器,可以这么导入。
    PrismaModule.forRoot(),
  ],
})
export class AppModule {}

然后在任何地方都可以注入PrismaServicePrismaClient两个类了。

PrismaClient@prisma/client包导入,监听器不会监听到PrismaClient发出的事件;PrismaService的基类就是PrismaClient,在PrismaClient的基础上实现了监听器的功能。

一般情况下,请使用PrismaService; 除非有特殊的需求,不想让监听器监听到,那就可以使用PrismaClient

PrismaClient本来是不能被nest.js注入的,但是由于PrismaModule.forRoot()了,此时PrismaClient就是可以被注入的类了。可以很轻松地使用这俩类😜

撰写Service

typescript 复制代码
import { Injectable } from '@nestjs/common';
import { PrismaService } from '@nailyjs.nest.modules/prisma';

@Injectable()
export class AppService {
  constructor(
      // 这是能被监听器监听到的
      private readonly prismaService: PrismaService,
      // 这是不能的
      private readonly prismaClient: PrismaClient
  ) {}

  async findMany() {
    return this.prismaService.user.findMany();
  }
}

一个示例Subscriber

import语句我就不写了,懒得弄。看得懂就行。

typescript 复制代码
@Injectable()
export class PrismaListener {
  /**
   * 假设您有一个名为`user`的prisma模型,可以在这里注册一个监听器,监听`findMany`事件。
   * BeforeListen顾名思义,就是在`findMany`方法执行之前执行的方法。
   */
  @BeforeListen('user', 'findMany')
  public async beforeFindMany() {
    console.log('before findMany');
  }

  /**
   * AfterListen顾名思义,就是在`findMany`方法执行之后执行的方法。
   */
  @AfterListen('user', 'findMany')
  public async afterFindMany() {
    console.log('after findMany');
  }
}

BeforeListenAfterListen@nailyjs.nest.modules/prisma包导入。

写好了之后,还要注册到forRoot

typescript 复制代码
@Module({
  imports: [
    PrismaModule.forRoot({
        subscribers: [PrismaListener]
    }),
  ],
})
export class AppModule {}

然后每次调用user表里的findMany方法时,都会先依次触发PrismaListener里的beforeFindMany方法,然后结束后再触发afterFindMany方法。

这样,就实现了切面的逻辑分离了。

这个包于2024年2月5日新鲜出炉,想上生产的都先等会()说不定有bug呢(自己玩一玩还是不错滴

相关推荐
糖拌西瓜皮16 小时前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js
智通1 天前
Node.js事件循环核心机制
node.js
初圣魔门首席弟子2 天前
Node.js 详细介绍(知识库版)
windows·qt·node.js·知识库
糖拌西瓜皮2 天前
Java 开发者如何快速上手 Node.js:一份从入门到进阶的学习路线
node.js
yspwf2 天前
NestJS 配置管理完整方案
后端·架构·node.js
网络点点滴2 天前
Node.js事件驱动架构
架构·node.js
weixin_471383032 天前
Node.js + Express 入门实战笔记-01-基础
node.js·lua·express
Rain5093 天前
2.2 数据基础:数据库集成与 ORM(TypeORM / Prisma)
数据库·人工智能·ai·数据分析·node.js·自动化·ai编程
大家的林语冰3 天前
npm 不忍了,正式上线“阶段式发布“的新功能,进一步对抗频繁的供应链攻击!
前端·javascript·node.js
天蓝色的鱼鱼3 天前
Node.js 现在能直接跑 TypeScript 了,tsx 和 ts-node 还需要吗?
前端·typescript·node.js