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

相关推荐
一碗饭特稀6 小时前
NestJS入门(2)——数据库、用户、备忘录模块初始化
node.js·nestjs
麻辣小蜗牛7 小时前
以 NestJS 为原型看懂 Node.js 框架设计:Provider Scope
nestjs
你的电影很有趣10 小时前
lesson72:Node.js 安全实战:Crypto-Js 4.2.0 与 Express 加密体系构建指南
javascript·安全·node.js
玩代码10 小时前
使用 nvm(Node Version Manager) 高效管理Node.js
node.js·vue·nvm
api_1800790546012 小时前
异步数据采集实践:用 Python/Node.js 构建高并发淘宝商品 API 调用引擎
大数据·开发语言·数据库·数据挖掘·node.js
_孤傲_13 小时前
webpack实现常用plugin
前端·webpack·node.js
小菜摸鱼1 天前
Node.js + vue3 大文件-切片上传全流程(视频文件)
前端·node.js
PaytonD1 天前
LoopBack 2 如何设置静态资源缓存时间
前端·javascript·node.js
许久'2 天前
环境搭建node.js gnvm
node.js
细节控菜鸡2 天前
Webpack 核心知识点详解:proxy、热更新、Loader与Plugin全解析
前端·webpack·node.js