GraphQL - 突变响应后的自定义错误消息

GraphQL - custom error message after mutation response

我正在学习 Graphql,但我遇到了一个无法进一步解决的问题。

在后端 (nodeJS) 中,您可以进入时事通讯列表,它可以正常工作。 如果电子邮件地址已经存在,Mailchimp 将 return "Member exists"。目前一切正常。

如果我没理解错的话,答案必须是相应类型的格式。 如果注册不起作用,我现在想发出自定义消息。

那么,我究竟应该如何继续调整正确的响应并发送自定义消息?

突变:

createNewsletterSubscription(
    data: CreateNewsletterSubscriptionInput
): NewsletterSubscription!

以及类型:

type NewsletterSubscription {
email: String!
name: String!

}

给我的回复 "Member exists":

JSON.parse(error.response.text).title

变异方法:

async createNewsletterSubscription(parent, args, { db }, info) {
    const { name, email } = args.data;
    const newEmailSubscription = {
        email,
        name,
    };

    const FNAME = name;

    try {
        const result = await request
            .post(  `https://${mailchimpInstance}.api.mailchimp.com/3.0/lists/${MAILCHIMP_LIST_ID}/members`
            )
            .set(
                'Authorization',
                // eslint-disable-next-line no-buffer-constructor
                `Basic ${new Buffer(`any:${MAILCHIMP_APIKEY}`).toString(
                    'base64'
                )}`
            )
            .send({
                email_address: email,
                status: 'subscribed',
                merge_fields: {
                    FNAME,
                },
            });

        if (result.status === 200 && result.body.status === 'subscribed') {
            return newEmailSubscription;
        }
    } catch (error) {
        // If member exists throw new error
        return JSON.parse(error.response.text).title;
    }
},

这是我的 GraphQL Playgrund 中的输出:

{
  "data": null,
  "errors": [
    {
      "message": "Cannot return null for non-nullable field NewsletterSubscription.email.",
      "locations": [
        {
          "line": 3,
          "column": 5
        }
      ],
      "path": [
        "createNewsletterSubscription",
        "email"
      ]
    }
  ]
}
} catch (error) {
    // If member exists throw new error
    return JSON.parse(error.response.text).title;
}

您不能只是 return 简单的响应 - 看起来像正常的响应,不是错误。

处理错误在apollo服务器上有详细解释docs