From e56d1647cf2a2e5dbb16c77a9e602778b0359065 Mon Sep 17 00:00:00 2001 From: Pierrick Charron Date: Wed, 27 Feb 2019 23:14:07 -0500 Subject: [PATCH] Fix pre-condition precedence According to RFC7232 (https://tools.ietf.org/html/rfc7232#section-6), If-None-Match Must be checked before If-Modidied-Since --- src/Cache.php | 31 ++++++++++++++++--------------- 1 file changed, 16 insertions(+), 15 deletions(-) diff --git a/src/Cache.php b/src/Cache.php index c488549..6fe9e2f 100644 --- a/src/Cache.php +++ b/src/Cache.php @@ -72,21 +72,6 @@ public function __invoke(RequestInterface $request, ResponseInterface $response, } } - // Last-Modified header and conditional GET check - $lastModified = $response->getHeaderLine('Last-Modified'); - - if ($lastModified) { - if (!is_integer($lastModified)) { - $lastModified = strtotime($lastModified); - } - - $ifModifiedSince = $request->getHeaderLine('If-Modified-Since'); - - if ($ifModifiedSince && $lastModified <= strtotime($ifModifiedSince)) { - return $response->withStatus(304); - } - } - // ETag header and conditional GET check $etag = $response->getHeader('ETag'); $etag = reset($etag); @@ -102,6 +87,22 @@ public function __invoke(RequestInterface $request, ResponseInterface $response, } } + + // Last-Modified header and conditional GET check + $lastModified = $response->getHeaderLine('Last-Modified'); + + if ($lastModified) { + if (!is_integer($lastModified)) { + $lastModified = strtotime($lastModified); + } + + $ifModifiedSince = $request->getHeaderLine('If-Modified-Since'); + + if ($ifModifiedSince && $lastModified <= strtotime($ifModifiedSince)) { + return $response->withStatus(304); + } + } + return $response; } }