发布查询时,我只想检索分配给当前用户(id)的数据。
userId
我用包含的中间件函数检索和设置;
const userId = tokenPayload['claims']['uid'];
ctx.userId = userId;
基于userId
我需要从这样的模型中过滤数据;
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/or relations
where user.id === ctx.userId
。
我希望很清楚我想要实现什么,它不必像这样,唯一需要相同的是以最高效的方式响应。
我希望有人能提供帮助,在过去的几周里,我一直在努力解决当前的问题。