做了一个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呢(自己玩一玩还是不错滴

相关推荐
李白的天不白15 小时前
webpack 与 webpack-cli 版本匹配问题
前端·webpack·node.js
李白的天不白21 小时前
webpack 与axios 版本冲突问题
前端·webpack·node.js
donecoding1 天前
pnpm 全局包与 nvm 的真相:命令永在,运行时随缘
node.js·claude
老蒋每日coding1 天前
Node.js 安装指南(Mac 版本)
macos·node.js
吴声子夜歌2 天前
Node.js——JSON-Server轻量级RESTful API
node.js·json·restful·json-server
tERS ERTS2 天前
node.js下载、安装、设置国内镜像源(永久)(Windows11)
node.js
donecoding2 天前
Corepack 完全解析:从懵到懂,包管理器自由了
前端·node.js·前端工程化
donecoding3 天前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
donecoding3 天前
别再让 pnpm 跟着 nvm 跑了!独立安装终极指南
前端·node.js·前端工程化