Shortcode Caching

Understand and customize how Asana data is cached and used within WordPress.

Table of Contents

  1. What is Caching?
  2. Changing the Cache TTL
    1. Overriding in PHP
  3. Clearing the Cache
    1. Advanced Usage For Developers

What is Caching?

Completionist uses caching to reduce the number of unnecessary requests made to Asana. This drastically improves the performance of your website where Asana data is displayed via Completionist’s shortcodes.

Basically, Completionist requests data from Asana once every 15 minutes. By remembering the data (caching it), Completionist then doesn’t need to request new data from Asana. After 15 minutes, Completionist then considers the cached data to be expired and requests the latest data from Asana. This cycle of fetching, storing, and expiring data repeats endlessly, which saves countless requests every 15 minutes.

But what if you want your Asana changes to be reflected more often than just every 15 minutes? Or what if you only need Asana changes updated every hour? How can you force an important update even if the cache hasn’t expired yet? These are common scenarios which the following settings help solve!

Changing the Cache TTL

In Completionist’s Settings screen, you can manage the Asana data cache records. Frontend requests are cached by default for 15 minutes (900 seconds). This immensely improves website performance by reducing how often data is requested from Asana.

If you find that Asana data is not updated often enough, you can decrease the Cache Duration (TTL) setting in Completionist’s settings. For example, to reflect new changes from Asana on your WordPress website every 5 minutes, set the Cache Duration (TTL) setting to 300 seconds. Note that you must be an administrator (have the manage_options capability) in WordPress to update this setting.

Settings section to manage the Asana data cache records

Overriding in PHP

For a custom or dynamic solution, the following filter hook is also available in PHP.

This reduces the cache duration to 5 minutes:

add_filter( 'ptc_completionist_request_tokens_ttl', 'ptc_get_request_tokens_ttl', 10, 1 );
function ptc_get_request_tokens_ttl( $ttl ) {
  return 5 * MINUTE_IN_SECONDS;
}

You may also increase the cache duration, such as using 1 hour:

add_filter( 'ptc_completionist_request_tokens_ttl', 'ptc_get_request_tokens_ttl', 10, 1 );
function ptc_get_request_tokens_ttl( $ttl ) {
  return HOUR_IN_SECONDS;
}

Refer to WordPress’s PHP time constants for other duration expressions.

Clearing the Cache

In Completionist’s Settings screen, there is a Clear Cache button available in the Asana Data Cache settings section. You can click that button anytime you need changes from Asana immediately reflected on your WordPress website.

Advanced Usage For Developers

Frontend caching and security is managed by the Request_Token PHP class within Completionist. You can think of request tokens as WordPress nonces. All related data is stored within the {$wpdb->prefix}ptc_completionist_request_tokens database table.

Request tokens are created in secure contexts as they are needed, including their associated cache records. Feel free to truncate the table at any time, but note that any frontend HTML caching of your WordPress website might become out-of-sync. For example, shortcodes may reference old request tokens which no longer exist and result in HTTP 400 errors. For this reason, you should also clear the PHP/HTML cache for each page that contains a Completionist shortcode.

You can clear the request tokens database table by using PHP:

// Load the Request_Token class file.
include_once PTC_Completionist\PLUGIN_PATH . 'src/public/class-request-token.php';

if (
    class_exists( 'PTC_Completionist\Request_Token' ) &&
    method_exists( 'PTC_Completionist\Request_Token', 'delete_all' )
) {
    // Attempt to delete all request token data, including cache records.
    if ( PTC_Completionist\Request_Token::delete_all() ) {
        // Successfully deleted all request tokens.
        // @TODO - Clear HTML page cache records.
    }
}

To keep all generated request tokens and simply clear their associated caches, use this method in PHP instead:

$rows_affected = Request_Token::clear_cache_data();