Apollo federation support for PostGraphile (or any Graphile Engine schema).
NOTE:
This repository is forked from https://github.com/graphile/federation which is currently unmaintained. While this repository will not be in active development with new features, all contributions and pull requests are welcome and will be reviewed in a timely manner.
Maintaining this fork was a preference from the original owners of the federation repository See Issue 39.
npm install postgraphile @graphile/federation
postgraphile --append-plugins @graphile/federation
const express = require("express");
const { postgraphile } = require("postgraphile");
const { default: FederationPlugin } = require("@graphile/federation");
const app = express();
app.use(
postgraphile(process.env.DATABASE_URL, "public", {
appendPlugins: [FederationPlugin],
})
);
app.listen(process.env.PORT || 3000);
This plugin exposes the Global Object Identification
Specification
(i.e. Node
interface) in a way that's compatible with Apollo Federation.
Requires PostGraphile v4.4.2-rc.0+ and a maintained LTS version of Node.
Docker can be used to spin up a test instance for running Jest tests. The instance will be exposed at port 5432
. See .env.example
for the exported Postgre connection.
docker compose up -d
./scripts/test
Only use this if you're planning to have your API consumed by Apollo Federation; exposing these redundant interfaces to regular users may be confusing.
Proof of concept. No tests, use at your own risk! Pull requests very welcome.