Build Status codecov Total Downloads Latest Stable Version License: MIT

Laravel Cloudflare

Purge Cloudflare Cache on Model Update

Synopsis

This package offers easy ways to purge Cloudflare Cache on Model update.

Table of contents

Setup

Install the package via Composer :

$ composer require Leknoppix/laravel-cloudflare

Laravel version compatibility

Laravel version Laravel Cloudflare version
8.x 1.x

Service Provider

Add the package service provider in your config/app.php

'providers' => [
    // ...
    Leknoppix\Cloudflare\ServiceProvider::class,
];

Alias

Add the package's alias in your config/app.php

'aliases' => [
    // ...
    'CloudflareCache' => Leknoppix\Cloudflare\Facade::class,
];

Publish package assets

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.

Configuration

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'),
];

Usage

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);

Credits

License

The MIT License (MIT). Please see License File for more information.