gpt4 book ai didi

postgresql - Postgraphile -- makeExtendSchemaPlugin 将查看器类型添加到模式 -- Relay/Postgres

转载 作者:行者123 更新时间:2023-12-04 08:26:20 24 4
gpt4 key购买 nike

我是 Relay、GraphQL 和 Postgres 的新手,我正在尝试扩展 PostGraphile 创建的自动生成模式,以包含作为 Relay 主要内容的查看器类型。
他们文档中的示例可能足以让大多数人使用,但我无法充实它。我基本上希望它添加一个字段 viewer: Viewer!到每个类型。
任何帮助都是极好的。

const { makeExtendSchemaPlugin, gql } = require('graphile-utils');

const AddViewerPlugin = makeExtendSchemaPlugin(build => {
// Get any helpers we need from `build`
const { pgSql: sql, inflection } = build;

return {
typeDefs: gql`...`,
resolvers: {
/*...*/
},
};
});

module.exports = AddViewerPlugin;
我的数据库有一个 public.person 表和一个 private.person_account 表,但我犹豫重命名其中一个查看器。

最佳答案

您使用“postgraphile”对象进行自动模式检测。
并使用“makeExtendSchemaPlugin”为其添加额外的解析器。
makeExtendSchemaPlugin 创建一个插件对象,您可以在 postgrahile 对象构造中传递该对象。
这是 makeExtendSchemaPlugin page 的摘录在 postgraphile 文档中:

const { postgraphile } = require("postgraphile");
const { makeExtendSchemaPlugin, gql } = require("graphile-utils");const express = require("express");
const { convertUsdToAud } = require("ficticious-npm-library");
const MyForeignExchangePlugin = makeExtendSchemaPlugin(build => { return { typeDefs: gql` extend type Product { priceInAuCents: Int! @requires(columns: ["price_in_us_cents"]) } `, resolvers: { Product: { priceInAuCents: async product => { // Note that the columns are converted to fields, so the case changes // from `price_in_us_cents` to `priceInUsCents` const { priceInUsCents } = product; return await convertUsdToAud(priceInUsCents); }, }, }, };});

const app = express();
app.use(
postgraphile(process.env.DATABASE_URL, ["app_public"], {
graphiql: true,
appendPlugins: [MyForeignExchangePlugin], })
);
app.listen(3030);

关于postgresql - Postgraphile -- makeExtendSchemaPlugin 将查看器类型添加到模式 -- Relay/Postgres,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65246561/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com