Open jasonbahl opened 2 months ago
Hi there, Since I finished these tasks for my project previously, I'm willing to assist. I have emailed you through the Google form because I am interested in helping you resolve this issue. I look forward to working with you on it.
As a developer building a Faust website, I would like to be able to get data from multiple WordPress installs and render the data in the same Faust front-end.
Problem
Currently Faust.js is centered around a singular WPGraphQL endpoint, enabling the Faust front-end to get data from 1 WordPress install.
Organizations that use multiple WordPress installs to split up content creation responsibilities have reported wanting to use Faust to pull in data from multiple different WordPress and render the data in a single front-end.
Proposal
My proposal is to create a "Client Registry" within Faust that allows multiple clients to be configured. Then different dynamic templates could be created and the
<WordPressTemplate />
andgetWordPressProps
functions could pass an argument to specify which client to interact with.Client Registry
Users would configure multiple clients in their
faust.config.js
, like so (pseudo):Template Usage
Multiple NextJS Dynamic Routes could be created, each specifying which client should be used:
Default Client
In this example, any url that did not match another dynamic route would fall back to this template and communicate to the "default" client (i.e.
site-a.com
)/pages/[...WordPressNode].js
Additional Clients
In this example, any url visited under the
/news/**
directory would attempt to resolve by communicating with "site-b"/pages/news/[...WordPressNode].js
Helper functions, etc
We'd likely need to introduce various helper functions and utilities for fetching from a specific client directly.
getApolloClient()
would need to be updated to accept aclientId
argument.i.e.
generatePossibleTypes
would need to be updated to store the results in a per-client manner as each endpoint could (and most likely would) have a different schema.