0

发布查询时,我只想检索分配给当前用户(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语句中设置的要求。所以有了这个集合,它应该只返回adressesand/or relationswhere user.id === ctx.userId

我希望很清楚我想要实现什么,它不必像这样,唯一需要相同的是以最高效的方式响应。

我希望有人能提供帮助,在过去的几周里,我一直在努力解决当前的问题。

4

1 回答 1

0

我通过编辑生成的解析器解决了这个问题;

通过更换

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
            }
          }
        })
      }
    });
于 2020-02-25T15:41:31.403 回答