plugin-icon

Jinx Fast-Cache

Blazing fast full-page caching for WordPress. Jinx Fast-Cache serves static HTML files, bypassing PHP and database overhead entirely.
Version
0.9.8
Last updated
Jan 16, 2026
Jinx Fast-Cache

Jinx Fast-Cache provides a simple but highly efficient way to implement full-page caching. It generates static HTML files of your pages, which are then served directly by your web server (Apache or Nginx).

By bypassing the entire PHP process and database queries, your server load is significantly reduced and your website response time becomes near-instant. Unlike many other plugins, Jinx Fast-Cache is built with a developer-first approach, working primarily with URLs and offering deep integration via filters and actions.

Usage

Server Configuration

To serve the cached files directly, you must add rewrite rules to your server configuration.

For Apache (.htaccess): The plugin will attempt to modify your .htaccess automatically. If it fails, add this manually:

# BEGIN Jinx Fast-Cache RewriteEngine On RewriteBase / RewriteCond %{DOCUMENT_ROOT}/wp-content/jinx-fast-cache/%{HTTP_HOST}/%{REQUEST_URI}/%{QUERY_STRING}/index.html -s RewriteCond %{REQUEST_METHOD} GET RewriteRule .* /wp-content/jinx-fast-cache/%{HTTP_HOST}/%{REQUEST_URI}/%{QUERY_STRING}/index.html [L] # END Jinx Fast-Cache

For Nginx: Add the following logic to your server block:

set $cache_path false; if ($request_method = GET) { set $cache_path /wp-content/jinx-fast-cache/$host/$uri/$args/index.html; } location / { try_files $cache_path $uri $uri/ /index.php?$query_string; }

Cache Management

  • Admin Bar: You can flush (clear), warm (generate), or refresh (flush & warm) single or multiple URLs directly from the admin bar.
  • Automatic Updates: Posts are automatically “warmed” after saving and “flushed” when deleted or set to draft.
  • Background Processing: The warming process uses a background queue handled via WordPress Cron to ensure server stability. Single post warming skips the queue for immediate results.
  • Plugin Updates: The cache is automatically refreshed after the plugin is updated.

Developer API

Jinx Fast-Cache is highly extensible. While a settings panel is available, developers can fine-tune every detail via filters and actions.

1. Filters

  • jinx_fast_cache_active: Toggle caching for specific conditions (default: false).
  • jinx_fast_cache_post_types: Define which post types should be cached (default: ‘page’ and ‘publicly_queryable’ types).
  • jinx_fast_cache_posts: Filter the specific list of post objects to be cached.
  • jinx_fast_cache_taxonomies: Define which taxonomies are cacheable.
  • jinx_fast_cache_terms: Filter the specific list of terms to be cached.
  • jinx_fast_cache_output: Modify the raw HTML content before it is saved to the cache file.
  • jinx_fast_cache_minify: Enable/disable HTML minification (default: false).
  • jinx_fast_cache_flush: Define additional related URLs that should be cleared when a specific page is flushed.
  • jinx_fast_cache_warm: Define additional related URLs that should be preloaded when a specific page is warmed.
  • jinx_fast_cache_queue_interval: Adjust the cron task frequency for the warming queue (default: 60s).
  • jinx_fast_cache_queue_size: Adjust the batch size per cron task (default: 10). Set to <= 0 to process everything at once (Caution: High server load).
  • jinx_fast_cache_gc_interval: Adjust the Garbage Collector frequency to remove invalid files (default: 60s).
  • jinx_fast_cache_ignore_logged_in_users: Toggle caching for logged-in users (default: true).
  • jinx_fast_cache_ignore_404: Toggle if 404 error pages should be cached (default: false).
  • jinx_fast_cache_query_params: Define allowed query parameters. Return __return_empty_array to ignore all parameters.
  • jinx_fast_cache_refresh_on_upgrade: Toggle the full cache refresh after plugin updates (default: true).
  • jinx_fast_cache_ttl: Define the cache lifetime (TTL). Supports seconds (e.g., 3600) or strings (e.g., ’12 hours’, ‘1 week’).

2. Dynamic Injections (AJAX)

Since static HTML files cannot execute PHP, Jinx allows you to “inject” dynamic content (like a user’s name or a shopping cart) via AJAX.

Injecting a Template Part:

do_action('jinx_fast_cache_inject_template', 'template-slug', 'Placeholder text...');

Injecting via Function Call:

You can call any public function or class method:

do_action('jinx_fast_cache_inject', 'date', ['Y']); do_action('jinx_fast_cache_inject', ['MyClass', 'myMethod'], [$arg1, $arg2]);

Using Shortcodes:

[jinx_fast_cache_inject placeholder="Loading..."] Your dynamic content here [/jinx_fast_cache_inject]

JS Callbacks:

Trigger custom JavaScript after the content has been injected:

$('.element').on('jinx-fast-cache-inject', (e) => { /* Handle injection */ }); element.addEventListener('jinx-fast-cache-inject', (e) => { /* Handle injection */ }, false);

3. URL Tags & Relations

Tags are a powerful way to link multiple URLs together. If one URL is flushed, all other URLs sharing the same tag will also be purged. This is perfect for linking a “Latest Posts” widget on your homepage to your single post entries.

Via Shortcode:

[jinx_fast_cache tags="news,homepage"]

Via Action:

do_action('jinx_fast_cache', ['tags' => 'tag1,tag2']); do_action('jinx_fast_cache', ['tags' => ['tag1', 'tag2']]);

4. Per-Page Cache Duration (TTL)

Override the global TTL for specific high-traffic or highly dynamic pages.

Via Shortcode:

[jinx_fast_cache ttl="3600"] or `[jinx_fast_cache ttl="12 hours"]`

Via Action:

do_action('jinx_fast_cache', ['ttl' => 3600]);

Combined Call (Tags + TTL):

do_action('jinx_fast_cache', ['ttl' => 3600, 'tags' => ['foo', 'bar']]);<h3>Roadmap</h3>

– [x] Release the plugin – [x] Add HTML minification for output – [x] Allow injection of dynamic rendered templates using ajax requests – [x] Add taxonomies – [x] Provide scheduled tasks – [x] Add admin columns for cache status – [x] Provide exclude option for posts and terms in backend – [x] Add multisite support – [x] Flush and warm after update complete – [x] Add possibility to ignore 404 – [x] Allow query params to be excluded or totally ignored – [x] Provide cache duration – [x] Provide admin panel to change options – [x] Add tags to flush related pages – [x] Add shortcode for injects – [x] Add JS events for injects – [x] Gutenberg inject block

Freeon Business plan
Tested up to
WordPress 6.9.0
This plugin is available for download for your site.