Giter VIP home page Giter VIP logo

kirby-clear-cloudflare-cache's Introduction

Clear Cloudflare Cache Kirby Plugin

This Kirby plugin can automatically purge Cloudflare cached URLs.

Installation

Download

Download and copy this repository to /site/plugins/clear-cloudflare-cache.

Git submodule

git submodule add https://github.com/thathoff/kirby-clear-cloudflare-cache.git site/plugins/clear-cloudflare-cache

Composer

composer require thathoff/kirby-clear-cloudflare-cache

Setup

At a minimum, you must set the following options in your config.php file:

'thathoff.clearcloudflarecache.cloudflareZoneID' => 'YOUR_CF_ZONE_ID',
'thathoff.clearcloudflarecache.cloudflareEmail'  => 'YOUR_CF_EMAIL',
'thathoff.clearcloudflarecache.cloudflareAPIKey' => 'YOUR_CF_API_KEY',

Options

thathoff.clearcloudflarecache.cloudflareZoneID

This must be set to your Cloudflare Zone ID (available in the Overview dashboard).

thathoff.clearcloudflarecache.cloudflareEmail

This must be set to the email address of your Cloudflare account.

thathoff.clearcloudflarecache.cloudflareAPIKey

This must be set to your Cloudflare API Key (available in the Profile page).

thathoff.clearcloudflarecache.dependantUrlsForPage

This must be a function that returns what URL(s) should be cleared after a page modification.

By default, simply returns the URL of the page itself and potentially the previous URL (in the case of a slug change).

function ($hook, $page, $oldPage = null) {
    return $oldPage ? [$page->url(), $oldPage->url()] : $page->url();
}

If you know that a change to one page affects other pages, you could include them as well. For example, the following would clear the Cloudflare cache for a modified page siblings (including the affected page) and parent pages.

'thathoff.clearcloudflarecache.dependantUrlsForPage'=> function ($hook, $page, $oldPage = null) {
    return $page->parents()->add($page->siblings(true));
},

Or, a more elaborate example could include a sitemap and content representations:

'thathoff.clearcloudflarecache.dependantUrlsForPage'=> function ($hook, $page, $oldPage = null) {
    $urls = [];
    $urls[] = $page->url();
    $urls[] = $page->url() . '.json';
    if ($oldPage) {
        $urls[] = $oldPage->url();
        $urls[] = $oldPage->url() . '.json';
    }
    $urls[] = page('sitemap')->url();
    $urls[] = page('sitemap')->url() . '.xml';
    return $urls;
},

The function may return:

  • a single Page object
  • a single URL string
  • a Pages collection of Page objects
  • an array of URL strings and/or Page objects
  • null, empty array, or empty Pages collection (this will cause no cache to be cleared)

Duplicate URLs will automatically be filtered out.

All URL strings must be absolute URLs (https://www.example.com/blog), not relative (/blog);

License

MIT

Credits

Maintained by Markus Denhoff, originally developed by Neil Daniels of The Streamable

kirby-clear-cloudflare-cache's People

Contributors

neildaniels avatar thathoff avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar

Forkers

selim13

kirby-clear-cloudflare-cache's Issues

Thumbnails K3

How do you deal with thumbnails and cloudflare?
When the thumbnail has not been created yet, cloudflare returns kirby error page in his cache most of the time.

Support using restricted API keys for cache clearing

The regular Cloudflare API key can be used to update everything in the Cloudflare account. It should be possible to use a limited API Token (with Zone.Cache Purge rights) for this plugin.

API Tokens use the standard Authorization: Bearer header for authentication instead of x-auth-email and x-auth-key that API Keys use.

I would propose to provide another config option cloudflareAPIToken to provide the token and authenticate the request to Cloudflare like written above.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.