Purge Cloudflare Cache on Model Update
This package offers easy ways to purge Cloudflare Cache on Model update.
Install the package via Composer :
$ composer require Leknoppix/laravel-cloudflare
Laravel version | Laravel Cloudflare version |
---|---|
8.x | 1.x |
Add the package service provider in your config/app.php
'providers' => [
// ...
Leknoppix\Cloudflare\ServiceProvider::class,
];
Add the package's alias in your config/app.php
'aliases' => [
// ...
'CloudflareCache' => Leknoppix\Cloudflare\Facade::class,
];
Publish the package asset files using this php artisan
command
$ php artisan vendor:publish --provider="Leknoppix\Cloudflare\ServiceProvider"
The command above would create new laravel-cloudflare.php
file in your application's config directory.
return [
/*
|--------------------------------------------------------------------------
| Cloudflare Site
|--------------------------------------------------------------------------
|
| Specify the sitename of the Cloudflare.
|
*/
'sitename' => env('CLOUDFLARE_SITE', 'test.com'),
/*
|--------------------------------------------------------------------------
| Cloudflare Authentication Email
|--------------------------------------------------------------------------
|
| Specify the authentication email to access Cloudflare.
|
*/
'auth_email' => env('CLOUDFLARE_AUTH_EMAIL', 'example@domain.com'),
/*
|--------------------------------------------------------------------------
| Cloudflare Authentication Key
|--------------------------------------------------------------------------
|
| Specify the authentication key to access Cloudflare.
|
*/
'auth_key' => env('CLOUDFLARE_AUTH_KEY', 'test_auth_key'),
];
This package assumes that the Page Rules has configured in your Cloudflare Dashboard. To configure the Page Rules, please refer to the Page Rules Tutorial.
Depends on the way the Page Rules configured, Cloudflare will cache each page in our website for some time. The Cloudflare will then serve the page from its cache, and will not send the request to the application server. This become a problem when there are data updates from the server. Because Cloudflare does not know when the data is updated, so it still serve the outdated data to the user. We need to purge the cache stored in Cloudflare.
Cloudflare provide API endpoints to purge its cache programmatically. This package utilize those API endpoints to purge the cache on model updates.
To start using this package, you need to add these credentials to the .env
file:
CLOUDFLARE_SITE=registered-cloudflare-sitename.com
CLOUDFLARE_AUTH_EMAIL=cloudflare-account@email.com
CLOUDFLARE_AUTH_KEY=cloudflare-auth-key
You can find the Cloudflare Auth Key in the API Tokens section on the profile page in your Cloudflare account. Copy the value of the Global API Key to your .env file.
Add the Leknoppix\Cloudflare\Model\Concerns\Cloudflare
to your model:
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Leknoppix\Cloudflare\Model\Concerns\Cloudflare;
class Post extends Model
{
use Cloudflare;
}
Create a listener to the Leknoppix\Cloudflare\Events\ModelHasUpdated
event:
<?php
namespace App\Listeners;
use Illuminate\Contracts\Queue\ShouldQueue;
use Leknoppix\Cloudflare\Events\ModelHasUpdated;
class PurgeCloudflareCache implements ShouldQueue
{
/**
* Create the event listener.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Handle the event.
*
* @param ModelHasUpdated $event
* @return void
*/
public function handle(ModelHasUpdated $event): void
{
//handle the Cloudflare purging
}
}
Register the listener to the EventServiceProvider
:
protected $listen = [
'Leknoppix\Cloudflare\Events\ModelHasUpdated' => [
'App\Listeners\PurgeCloudflareCache',
]
];
There are several method that can be used to purge the Cloudflare cache:
-
Purge all files: purge all resources in Cloudflare's cache.
-
Purge by urls: remove one or more files from Cloudflare's cache either by specifying URLs.
-
Purge by cache tags, hosts, or prefixes: emove one or more files from Cloudflare's cache either by specifying the host, the associated Cache-Tag, or a Prefix. Please note that theses methods only available for Enterprise User.
// purge all files \CloudflareCache::purgeAll(); // purge by urls $urls = [ 'http://example.com/posts/post-1', 'http://example.com/posts/post-2', ]; \CloudflareCache::purgeByUrls($urls); // purge by Cache-Tag (only available for Enterprise user) $tags = [ 'news-tag', 'posts-tag', ]; \CloudflareCache::purgeByTags($tags); // purge by hosts (only available for Enterprise user) $hosts = [ 'https://example.com', 'https://domain.com', ]; \CloudflareCache::purgeByHosts($hosts); // purge by prefixes (only available for Enterprise user) $prefixes = [ '/news', '/products/product-1', ]; \CloudflareCache::purgeByPrefixes($prefixes);
- [suitmedia/laravel-cloudflare]https://github.com/[suitmedia/laravel-cloudflare](https://github.com/suitmedia/laravel-cloudflare) - The original version
- richan-fongdasen/laravel-varnishable - The purging cache flow was inspired by this package.
The MIT License (MIT). Please see License File for more information.