Skip to content

Navigate and debug the Next.js data cache

License

Notifications You must be signed in to change notification settings

47ng/next-cache-explorer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

next-cache-explorer

NPM MIT License CI/CD Coverage Status

Navigate & debug the Next.js data cache

Installation

  1. Install the dependency:

Note: requires Next.js 13.4+ with the app router.

pnpm add next-cache-explorer
yarn add next-cache-explorer
npm i next-cache-explorer
  1. Add the following file to your Next.js app:
// src/app/cache-explorer/[[...slug]]/page.tsx

import { mountCacheExplorer } from 'next-cache-explorer'

export const dynamic = 'force-dynamic'

export default mountCacheExplorer()
  1. Start your app and navigate to the /cache-explorer page.

Usage

Index page

Shows a list of all cache entries and tags. Click an entry to see its details, or a tag to only show entries with that tag.

Tags page

Shows a list of all entries for a given tag.

Entry page

Shows the details of a given cache entry, including:

  • Size in bytes
  • Associated URL
  • Revalidation time / TTL
  • Tags to invalidate this entry
  • Response headers
  • Response body

Options

Mount path

You can choose to place the cache explorer at a different path. The main page will still need to be under [[...slug]]/page.tsx, but if you place it in another base path, you'll need to configure it:

// src/app/admin/cache-explorer/[[...slug]]/page.tsx

export default mountCacheExplorer({
  mountPath: '/admin/cache-explorer',
})

Running in production

By default, the cache explorer will only be available in development mode. To enable it in production, you can set the CACHE_EXPLORER environment variable to true.

You can also enable it programmatically:

export default mountCacheExplorer({
  enabled: true,
})

When disabled, the page (and sub-pages) will render a "Cache explorer is disabled" message.

To redirect to the default NotFound page, use the notFoundWhenDisabled option:

export default mountCacheExplorer({
  notFoundWhenDisabled: true,
})

License

MIT - Made with ❤️ by François Best

Using this package at work ? Sponsor me to help with support and maintenance.

This package is signed with sceau, under the following associated public key:

sceau verify --publicKey 380db0ad0ccf92c3bcffc065b614515dd260cf291ed301a9f6ae550f6419f3c7