Skip to content

Commit

Permalink
feat: Allow users to customize fetch behavior
Browse files Browse the repository at this point in the history
NextJS SSR v15.1+ will not cache `fetch` requests by default, but some users might want that, specially in development mode.
We're now allowing them to customize our `fetch` requests by setting the new `fetch_options` setting when calling `posthog.init`

This needs to be used carefully, but it should be extremely powerful and useful for NextJS users. We'll add documentation about it on `posthog.com` soon.
  • Loading branch information
rafaeelaudibert committed Dec 11, 2024
1 parent 4b28ae7 commit 9df3836
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 0 deletions.
4 changes: 4 additions & 0 deletions src/posthog-core.ts
Original file line number Diff line number Diff line change
Expand Up @@ -663,6 +663,10 @@ export class PostHog {
}
options.compression = options.compression === 'best-available' ? this.compression : options.compression

// Specially useful if you're doing SSR with NextJS
// Users must be careful when tweaking `cache` because they might get out-of-date feature flags
options.fetchOptions = options.fetchOptions || this.config.fetch_options

request({
...options,
callback: (response) => {
Expand Down
1 change: 1 addition & 0 deletions src/request.ts
Original file line number Diff line number Diff line change
Expand Up @@ -165,6 +165,7 @@ const _fetch = (options: RequestOptions) => {
keepalive: options.method === 'POST' && (estimatedSize || 0) < KEEP_ALIVE_THRESHOLD,
body,
signal: aborter?.signal,
...options.fetchOptions,
})
.then((response) => {
return response.text().then((responseText) => {
Expand Down
16 changes: 16 additions & 0 deletions src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -333,6 +333,15 @@ export interface PostHogConfig {
events_burst_limit?: number
}

/** Used when sending data via `fetch`, use with care, this is intentionally meant to be used with NextJS `fetch`
* Incorrect usage may cause out-of-date data for feature flags, actions tracking, etc.
* See https://nextjs.org/docs/app/api-reference/functions/fetch#fetchurl-options
*/
fetch_options?: {
cache?: RequestInit['cache']
next_options?: NextOptions
}

/**
* PREVIEW - MAY CHANGE WITHOUT WARNING - DO NOT USE IN PRODUCTION
* whether to wrap fetch and add tracing headers to the request
Expand Down Expand Up @@ -440,6 +449,9 @@ export interface RequestResponse {

export type RequestCallback = (response: RequestResponse) => void

// See https://nextjs.org/docs/app/api-reference/functions/fetch#fetchurl-options
type NextOptions = { revalidate: false | 0 | number; tags: string[] }

export interface RequestOptions {
url: string
// Data can be a single object or an array of objects when batched
Expand All @@ -452,6 +464,10 @@ export interface RequestOptions {
timeout?: number
noRetries?: boolean
compression?: Compression | 'best-available'
fetchOptions?: {
cache?: RequestInit['cache']
next?: NextOptions
}
}

// Queued request types - the same as a request but with additional queueing information
Expand Down

0 comments on commit 9df3836

Please sign in to comment.