Configure Revalidate Route
Revalidate routes in Next.js
Implement on-demand revalidation using an API route at /revalidate.
Update Environment Variables
First, update .env.local to include the revalidate secret you specified.
.env.local
# Required for On-demand RevalidationDRUPAL_REVALIDATE_SECRET=secretCreate the Revalidate Route
Next, create the API route that will be used for on-demand revalidation.
If you're using the Basic Starter, the revalidate route is already created for you. You can skip this step.
/app/api/revalidate/route.ts
app/api/revalidate/route.ts
import { revalidatePath, revalidateTag } from "next/cache"import type { NextRequest } from "next/server"
async function handler(request: NextRequest) {  const searchParams = request.nextUrl.searchParams  const path = searchParams.get("path")  const tags = searchParams.get("tags")  const secret = searchParams.get("secret")
  // Validate secret.  if (secret !== process.env.DRUPAL_REVALIDATE_SECRET) {    return new Response("Invalid secret.", { status: 401 })  }
  // Either tags or path must be provided.  if (!path && !tags) {    return new Response("Missing path or tags.", { status: 400 })  }
  try {    path && revalidatePath(path)    tags?.split(",").forEach((tag) => revalidateTag(tag))
    return new Response("Revalidated.")  } catch (error) {    return new Response((error as Error).message, { status: 500 })  }}
export { handler as GET, handler as POST }