Same-Origin Requests
Overview
If your client and server are on the same origin (e.g. making an API call to foo.com/api
from JavaScript running on foo.com
), the session token is automatically passed to the backend in a cookie. This means all requests to same-origin endpoints are authenticated by default.
Using Fetch
You can use the native browser Fetch API as you normally would and the request will be authenticated.
fetch('/api/foo').then(res => res.json());
useSWR hook
If you are using React or Next.js and would like to use the useSWR
hook, it’s as simple as supplying the API route with whichever fetcher function you are using. Because of the automatic revalidation feature of SWR, you need to retrieve and set the session token in the Authorization header. Call the asynchronous getToken()
method from the useAuth()
hook and add it as a Bearer token.
1import useSWR from 'swr';2import { useAuth } from '@clerk/nextjs';34export default function useClerkSWR(url) {5const { getToken } = useAuth();6const fetcher = async (...args) => {7return fetch(...args, {8headers: { Authorization: `Bearer ${await getToken()}` }9}).then(res => res.json());10};11return useSWR(url, fetcher);12}
1import useSWR from 'swr';2import { useAuth } from '@clerk/nextjs';34export default function useClerkSWR(url: string) {5const { getToken } = useAuth();6const fetcher = async (...args: [RequestInfo]) => {7return fetch(...args, {8headers: { Authorization: `Bearer ${await getToken()}` }9}).then(res => res.json());10};11return useSWR(url, fetcher);12}
When you re-focus a page or switch between tabs, SWR automatically revalidates data. This can be useful to immediately synchronize to the latest state in scenarios like stale mobile tabs, or laptops that went to sleep.
react-query
If you are using React Query in your application, you need to use a query function that throws errors. Since the native Fetch API does not, you can add it in. Also make sure that you have your application wrapped in <QueryClientProvider />
with a QueryClient
set.
import { useQuery } from 'react-query';const { data, error } = useQuery('foo', async () => {const res = await fetch('/api/foo');if (!res.ok) {throw new Error('Network response error')}return res.json()});
Background Fetching
For applications that are fetching content in the background, when a tab is no longer focused you will need to include an Authorization Header along with your request.
1import { useAuth } from '@clerk/nextjs';23export default function useFetch() {4const { getToken } = useAuth();5const authenticatedFetch = async (...args) => {6return fetch(...args, {7headers: { Authorization: `Bearer ${await getToken()}` }8}).then(res => res.json());9};10return authenticatedFetch;11}