summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBen Coburn <btcoburn@silicodon.net>2006-04-21 04:54:24 +0200
committerBen Coburn <btcoburn@silicodon.net>2006-04-21 04:54:24 +0200
commit83730152bf4050753830c82cd64c94eaa4c3507c (patch)
treef12e214efeda6fa5fa94a6a786a026146e9198c4
parent4f3c4962cebeec6b73456cbacbf7f219ccb90c85 (diff)
downloadrpg-83730152bf4050753830c82cd64c94eaa4c3507c.tar.gz
rpg-83730152bf4050753830c82cd64c94eaa4c3507c.tar.bz2
smart cache-control headers for media fetch
The HTTP Cache-Control header output now respects the Dokuwiki media parameters 'cache', 'recache', and 'nocache'. - cache: cachetime or one hour (which ever is larger) - recache: remaining cachetime + 10 seconds so the newly recached media is used - nocache: no caching Notes: - 'proxy-revalidate' should ensure that public caches always revalidate, this will keep caches from (accidentally) ignoring Dokuwiki's ACL rules. - 'no-transform' should keep media from being modified in transit by caches. Impact: Speeds up page layout/display by browsers when they already have the media in their [memory] cache. For example the 2nd time a page is viewed. This also reduces server load by eliminating most of the overhead needed to return '304 Not Modified' responses each time an image is viewed. darcs-hash:20060421025424-05dcb-23ff26c5cb410bcd166299a840f4c500fa0d112e.gz
-rw-r--r--lib/exe/fetch.php29
1 files changed, 24 insertions, 5 deletions
diff --git a/lib/exe/fetch.php b/lib/exe/fetch.php
index 9157baeb8..4df204f50 100644
--- a/lib/exe/fetch.php
+++ b/lib/exe/fetch.php
@@ -70,7 +70,7 @@
}
// finally send the file to the client
- sendFile($FILE,$MIME);
+ sendFile($FILE,$MIME,$CACHE);
/* ------------------------------------------------------------------------ */
@@ -78,15 +78,34 @@
* Set headers and send the file to the client
*
* @author Andreas Gohr <andi@splitbrain.org>
+ * @author Ben Coburn <btcoburn@silicodon.net>
*/
-function sendFile($file,$mime){
+function sendFile($file,$mime,$cache){
+ global $conf;
+ $fmtime = filemtime($file);
// send headers
header("Content-Type: $mime");
- header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
- header('Pragma: public');
+ // smart http caching headers
+ if ($cache==-1) {
+ // cache
+ // cachetime or one hour
+ header('Expires: '.gmdate("D, d M Y H:i:s", time()+max($conf['cachetime'], 3600)).' GMT');
+ header('Cache-Control: public, proxy-revalidate, no-transform, max-age='.max($conf['cachetime'], 3600));
+ header('Pragma: public');
+ } else if ($cache>0) {
+ // recache
+ // remaining cachetime + 10 seconds so the newly recached media is used
+ header('Expires: '.gmdate("D, d M Y H:i:s", $fmtime+$conf['cachetime']+10).' GMT');
+ header('Cache-Control: public, proxy-revalidate, no-transform, max-age='.max($fmtime-time()+$conf['cachetime']+10, 0));
+ header('Pragma: public');
+ } else if ($cache==0) {
+ // nocache
+ header('Cache-Control: must-revalidate, no-transform, post-check=0, pre-check=0');
+ header('Pragma: public');
+ }
header('Accept-Ranges: bytes');
//send important headers first, script stops here if '304 Not Modified' response
- http_conditionalRequest(filemtime($file));
+ http_conditionalRequest($fmtime);
list($start,$len) = http_rangeRequest(filesize($file));
//application mime type is downloadable