Skip to content

h4cc/guzzle-cache-middleware

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

guzzle-cache-middleware

Latest Stable Version Total Downloads License Build Status
Scrutinizer Code Quality SensioLabsInsight

A HTTP Cache for Guzzle 6. It's a simple Middleware to be added in the HandlerStack. This project is under development but it's already functional.

Installation

composer require kevinrob/guzzle-cache-middleware:~0.5

or add it the your composer.json and make a composer update kevinrob/guzzle-cache-middleware.

Why?

Performance. It's very common to do some HTTP calls to an API for rendering a page and it takes times to do it.

How?

With a simple Middleware added at the top of the HandlerStack of Guzzle6.

use GuzzleHttp\Client;
use GuzzleHttp\HandlerStack;
use Kevinrob\GuzzleCache;

// Create default HandlerStack
$stack = HandlerStack::create();

// Add this middleware to the top with `push`
$stack->push(new CacheMiddleware(), 'cache');

// Initialize the client with the handler option
$client = new Client(['handler' => $stack]);

You can use a custom Cache with:

[...]
use Doctrine\Common\Cache;

[...]
$stack->push(new CacheMiddleware(new PrivateCache(new FilesystemCache('/tmp/')), 'cache');

You can use ChainCache for using multiple CacheProvider. With that provider, you have to sort the different cache from the faster to the slower. Like that, you can have a very fast cache.

[...]
use Doctrine\Common\Cache;

[...]
$stack->push(new CacheMiddleware(
  new PrivateCache(
    new ChainCache([
      new ArrayCache(),
      new ApcCache(),
      new FileCache('/tmp/'),
    ])
  )
), 'cache');

About

A HTTP Cache for Guzzle 6. It's a simple Middleware to be added in the HandlerStack.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%