Я использую graphql-yoga с Prisma и Prisma-Bindings
Я пытаюсь добавить фрагмент в свой преобразователь, чтобы определенное поле (id в этой ситуации) всегда выбиралось, когда пользователь запрашивает настраиваемое поле costToDate.
Это сделано для того, чтобы я мог сделать несколько дополнительных запросов, необходимых для построения результата для этого поля, и для этого мне нужен идентификатор объекта.
К сожалению, я не могу заставить его работать, и в документации, похоже, немного не хватает специфики с graphql-yoga и Prisma.
Вот определение типа:
type Job {
id: ID!
projectNumber: String!
client: Client!
name: String!
description: String
quoteNumber: String
workshopDaysQuoted: String!
quoted: String!
targetSpend: String!
costs: [JobCost!]!
estimatedCompletion: DateTime
completed: Boolean!
costTotal: String
workshopDaysUsed: String
costsToDate: String
}
И вот решатель для запроса:
const jobs = {
fragment: `fragment description on Jobs { id }`,
resolve: jobsResolver
}
async function jobsResolver(root, args, context, info) {
await validatePermission(args,context,info,['admin','user','appAuth'])
const {showCompleted} = args
const completedFilter = (typeof showCompleted === 'boolean') ? { completed: showCompleted } : {}
const jobIDS = await context.db.query.jobs({ where: completedFilter }, `{ id }`)
//console.log(jobIDS);
let jobs = await context.db.query.jobs({
where: completedFilter
}, info)
return await getAllJobCostsToDateList(jobs)
}
Я применяю замену фрагмента, как показано ниже.
const fragmentReplacements = extractFragmentReplacements(resolvers)
console.log(fragmentReplacements)
const port = process.env.PORT || 3010
const graphQLServer = new GraphQLServer({
typeDefs: './src/schema.graphql',
resolvers,
resolverValidationOptions: {
requireResolversForResolveType: false
},
context: req => ({
...req,
db: new Prisma({
typeDefs: `src/generated/prisma.graphql`,
fragmentReplacements,
endpoint: PRISMA_ENDPOINT,
secret: PRISMA_KEY,
debug: false
})
})
})
Если я console.log объект fragmentReplacements, я получаю следующее, так что, похоже, он собирает фрагменты.
[ { field: 'job', fragment: 'fragment costsToDate on Job { id }' },
{ field: 'jobs',
fragment: 'fragment costsToDate on Jobs { id }' } ]
Итак, я ожидаю, что если я сделаю запрос к заданиям или заданию, которое запрашивает поле costToDate, оно также получит идентификатор задания / каждого задания.
Однако, если я сделаю следующий запрос.
query{
jobs{
description
costsToDate
}
}
Но я не вижу полученного идентификатора и ничего в корневом параметре функции преобразователя.
Приносим извинения, так как я, вероятно, лаю здесь совершенно не на то дерево, это кажется довольно простым требованием, но я не могу с этим справиться. Конечно, мне не хватает чего-то фундаментального.
Спасибо!
Гарет