From 2f14293716edb59882eb6f16e1ad4b7fb79ce3da Mon Sep 17 00:00:00 2001
From: thomascube <thomas@roundcube.net>
Date: Fri, 19 Jun 2009 10:42:09 -0400
Subject: [PATCH] Use filemtime for cache busting + better etag for static files

---
 .htaccess                           |    2 +-
 program/include/rcube_html_page.php |    8 ++++----
 2 files changed, 5 insertions(+), 5 deletions(-)

diff --git a/.htaccess b/.htaccess
index a30369d..9b8063d 100644
--- a/.htaccess
+++ b/.htaccess
@@ -43,7 +43,7 @@
 ExpiresDefault "access plus 1 month"
 </IfModule>
 
-FileETag MTime
+FileETag MTime Size
 
 Order deny,allow
 Allow from all
diff --git a/program/include/rcube_html_page.php b/program/include/rcube_html_page.php
index d56b5ce..446efa5 100644
--- a/program/include/rcube_html_page.php
+++ b/program/include/rcube_html_page.php
@@ -55,7 +55,7 @@
         static $sa_files = array();
         
         if (!preg_match('|^https?://|i', $file) && $file[0] != '/')
-          $file = $this->scripts_path . $file . (($fs = @filesize($this->scripts_path . $file)) ? '?s='.$fs : '');
+          $file = $this->scripts_path . $file . (($fs = @filemtime($this->scripts_path . $file)) ? '?s='.$fs : '');
 
         if (in_array($file, $sa_files)) {
             return;
@@ -250,7 +250,7 @@
 
         // correct absolute paths in images and other tags
         $output = preg_replace('!(src|href|background)=(["\']?)(/[a-z0-9_-]+)!i', "\\1=\\2$base_path\\3", $output);
-        $output = preg_replace_callback('!(src|href)=(["\']?)([a-z0-9/_.-]+.(css|js))(["\'\s>])!i', array($this, 'add_filesize'), $output);
+        $output = preg_replace_callback('!(src|href)=(["\']?)([a-z0-9/_.-]+.(css|js))(["\'\s>])!i', array($this, 'add_filemtime'), $output);
         $output = str_replace('$__skin_path', $base_path, $output);
 
         echo rcube_charset_convert($output, 'UTF-8', $this->charset);
@@ -259,9 +259,9 @@
     /**
      * Callback function for preg_replace_callback in write()
      */
-    public function add_filesize($matches)
+    public function add_filemtime($matches)
     {
-        return sprintf("%s=%s%s?s=%d%s", $matches[1], $matches[2], $matches[3], @filesize($matches[3]), $matches[5]);
+        return sprintf("%s=%s%s?s=%d%s", $matches[1], $matches[2], $matches[3], @filemtime($matches[3]), $matches[5]);
     }
 }
 

--
Gitblit v1.9.1