Fetcher

Using a custom fetcher with DrupalClient.


⚠️

The `DrupalClient` is available in `next-drupal ^1.3.0` as experimental.

The `DrupalClient` uses Next.js polyfilled `fetch` as the default fetcher.

You can provide your own using the `fetcher` option.

Example

Here's how you can replace the default fetcher with cross-fetch.

⚠️

We're using cross-fetch instead of node-fetch because it is compatible with the built-in fetch and uses the same signature.

lib/drupal.ts

import { Experiment_DrupalClient as DrupalClient } from "next-drupal"
import crossFetch from "cross-fetch"
const fetcher = (url, options) => {
const { withAuth, ...opts } = options
if (withAuth) {
// Make additional requests to fetch a bearer token
// Or any other Authorization headers.
}
return crossFetch(url, {
...opts,
// Pass in additional options. Example: agent.
})
}
export const drupal = new DrupalClient(
process.env.NEXT_PUBLIC_DRUPAL_BASE_URL,
{
fetcher,
}
)