thomascube
2009-06-19 2f14293716edb59882eb6f16e1ad4b7fb79ce3da
Use filemtime for cache busting + better etag for static files

2 files modified
10 ■■■■ changed files
.htaccess 2 ●●● patch | view | raw | blame | history
program/include/rcube_html_page.php 8 ●●●● patch | view | raw | blame | history
.htaccess
@@ -43,7 +43,7 @@
ExpiresDefault "access plus 1 month"
</IfModule>
FileETag MTime
FileETag MTime Size
Order deny,allow
Allow from all
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]);
    }
}