forked from lino/radar-wp
33 lines
908 B
PHP
33 lines
908 B
PHP
|
<?php
|
||
|
|
||
|
namespace Guzzle\Plugin\Cache;
|
||
|
|
||
|
use Guzzle\Http\Message\RequestInterface;
|
||
|
use Guzzle\Http\Message\Response;
|
||
|
|
||
|
/**
|
||
|
* Default strategy used to determine of an HTTP request can be cached
|
||
|
*/
|
||
|
class DefaultCanCacheStrategy implements CanCacheStrategyInterface
|
||
|
{
|
||
|
public function canCacheRequest(RequestInterface $request)
|
||
|
{
|
||
|
// Only GET and HEAD requests can be cached
|
||
|
if ($request->getMethod() != RequestInterface::GET && $request->getMethod() != RequestInterface::HEAD) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
// Never cache requests when using no-store
|
||
|
if ($request->hasHeader('Cache-Control') && $request->getHeader('Cache-Control')->hasDirective('no-store')) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
public function canCacheResponse(Response $response)
|
||
|
{
|
||
|
return $response->isSuccessful() && $response->canCache();
|
||
|
}
|
||
|
}
|