发布查询时,我只想检索分配给当前用户(id)的数据。
我检索并设置了userId
一个包含以下内容的中间件函数:
const userId = tokenPayload['claims']['uid'];
ctx.userId = userId;
基于userId
i,我需要从这样的模型中过滤数据;
model Address {
id String @id @default(uuid())
name string
...
user User
}
所以我想返回等价于 Addresses.filter(address => address.user.id === ctx.userId)
(Addresses
其中user.id
等于中间件中的那个)
例如这样的东西(这是编成的代码,因此可以正常工作)
plugins: [nexusPrismaPlugin(
{
computedInputs: {
...
},
computedFilters: {
addresses: ({ ctx }) => ({ where: { user: { id: ctx.userId } } }),
relations: ({ ctx }) => ({ where: { user: { id: ctx.userId } } }),
...
}
}
)],
在其中computedFilters
筛选传入查询以匹配where
语句中设置的要求的位置。因此,使用此设置,它应该仅返回adresses
and和/或relations
where user.id === ctx.userId
。
我希望我想实现的目标很明确,不必一定是这样,唯一需要保持一致的就是以最高效的方式做出响应。
我希望有人能提供帮助,最近两周我一直在努力解决当前问题。
我通过编辑生成的解析器解决了该问题;
通过替换
t.crud.addresses({filtering: true, ordering: true});
与
t.list.field('addresses', {
type: 'Address',
resolve: (_parent, _args, ctx) => {
return ctx.prisma.address.findMany({
where: {
user: {
id: ctx.userId
}
}
})
}
});