Title: Jinx Fast-Cache
Author: Lukas Rydygel
Published: <strong>Chwefror 10, 2022</strong>
Last modified: Ionawr 16, 2026

---

Search plugins

![](https://ps.w.org/jinx-fast-cache/assets/banner-772x250.jpg?rev=2676361)

![](https://ps.w.org/jinx-fast-cache/assets/icon-256x256.png?rev=2676361)

# Jinx Fast-Cache

 Gan [Lukas Rydygel](https://profiles.wordpress.org/lugat/)

[Llwytho i lawr](https://downloads.wordpress.org/plugin/jinx-fast-cache.zip)

 * [Details](https://cy.wordpress.org/plugins/jinx-fast-cache/#description)
 * [Reviews](https://cy.wordpress.org/plugins/jinx-fast-cache/#reviews)
 *  [Installation](https://cy.wordpress.org/plugins/jinx-fast-cache/#installation)
 * [Development](https://cy.wordpress.org/plugins/jinx-fast-cache/#developers)

 [Cefnogaeth](https://wordpress.org/support/plugin/jinx-fast-cache/)

## Disgrifiad

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

## Blocks

This plugin provides 1 block.

 *   ⚡ Jinx Fast-Cache Inject

## Gosod

 1. Unzip the downloaded package.
 2. Upload the `jinx-fast-cache` folder to the `/wp-content/plugins/` directory.
 3. Activate the plugin through the ‘Plugins’ menu in WordPress.
 4. **Important:** Configure your server rewrite rules (see “Usage”) to serve the static
    files.

## Adolygiadau

There are no reviews for this plugin.

## Contributors & Developers

“Jinx Fast-Cache” is open source software. The following people have contributed
to this plugin.

Cyfranwyr

 *   [ Lukas Rydygel ](https://profiles.wordpress.org/lugat/)

[Translate “Jinx Fast-Cache” into your language.](https://translate.wordpress.org/projects/wp-plugins/jinx-fast-cache)

### Interested in development?

[Browse the code](https://plugins.trac.wordpress.org/browser/jinx-fast-cache/), 
check out the [SVN repository](https://plugins.svn.wordpress.org/jinx-fast-cache/),
or subscribe to the [development log](https://plugins.trac.wordpress.org/log/jinx-fast-cache/)
by [RSS](https://plugins.trac.wordpress.org/log/jinx-fast-cache/?limit=100&mode=stop_on_copy&format=rss).

## Meta

 *  Version **0.9.8**
 *  Last updated **3 mis yn ôl**
 *  Active installations **Fewer than 10**
 *  WordPress version ** 5.0 neu uwch **
 *  Tested up to **6.9.0**
 *  PHP version ** 8.0 neu uwch **
 *  Language
 * [English (US)](https://wordpress.org/plugins/jinx-fast-cache/)
 * Tags
 * [cache](https://cy.wordpress.org/plugins/tags/cache/)[fullpage](https://cy.wordpress.org/plugins/tags/fullpage/)
   [html](https://cy.wordpress.org/plugins/tags/html/)[performance](https://cy.wordpress.org/plugins/tags/performance/)
   [static cache](https://cy.wordpress.org/plugins/tags/static-cache/)
 *  [Advanced View](https://cy.wordpress.org/plugins/jinx-fast-cache/advanced/)

## Graddau

No reviews have been submitted yet.

[Your review](https://wordpress.org/support/plugin/jinx-fast-cache/reviews/#new-post)

[See all reviews](https://wordpress.org/support/plugin/jinx-fast-cache/reviews/)

## Cyfranwyr

 *   [ Lukas Rydygel ](https://profiles.wordpress.org/lugat/)

## Cefnogaeth

Rhywbeth i’w ddweud? Angen help?

 [Gweld y fforwm cefnogi](https://wordpress.org/support/plugin/jinx-fast-cache/)