From 2d08c50fd78e8ae74f27a2418f7909b18ae2bf42 Mon Sep 17 00:00:00 2001 From: alecpl <alec@alec.pl> Date: Fri, 05 Mar 2010 04:47:32 -0500 Subject: [PATCH] - Support/Require tls:// prefix in 'smtp_server' option for TLS connections - "Split" config file into sections --- program/include/rcube_html_page.php | 57 ++++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 42 insertions(+), 15 deletions(-) diff --git a/program/include/rcube_html_page.php b/program/include/rcube_html_page.php index 78f6176..6281043 100644 --- a/program/include/rcube_html_page.php +++ b/program/include/rcube_html_page.php @@ -15,7 +15,7 @@ | Author: Thomas Bruederli <roundcube@gmail.com> | +-----------------------------------------------------------------------+ - $Id: $ + $Id$ */ @@ -29,16 +29,17 @@ protected $scripts_path = ''; protected $script_files = array(); protected $scripts = array(); - protected $charset = 'UTF-8'; + protected $charset = RCMAIL_CHARSET; - protected $script_tag_file = "<script type=\"text/javascript\" src=\"%s%s\"></script>\n"; - protected $script_tag = "<script type=\"text/javascript\">\n<!--\n%s\n\n//-->\n</script>\n"; + protected $script_tag_file = "<script type=\"text/javascript\" src=\"%s\"></script>\n"; + protected $script_tag = "<script type=\"text/javascript\">\n/* <![CDATA[ */\n%s\n/* ]]> */\n</script>"; protected $default_template = "<html>\n<head><title></title></head>\n<body></body>\n</html>"; protected $title = ''; protected $header = ''; protected $footer = ''; protected $body = ''; + protected $base_path = ''; /** Constructor */ @@ -53,6 +54,9 @@ public function include_script($file, $position='head') { static $sa_files = array(); + + if (!preg_match('|^https?://|i', $file) && $file[0] != '/') + $file = $this->scripts_path . $file . (($fs = @filemtime($this->scripts_path . $file)) ? '?s='.$fs : ''); if (in_array($file, $sa_files)) { return; @@ -165,7 +169,7 @@ // definition of the code to be placed in the document header and footer if (is_array($this->script_files['head'])) { foreach ($this->script_files['head'] as $file) { - $__page_header .= sprintf($this->script_tag_file, $this->scripts_path, $file); + $__page_header .= sprintf($this->script_tag_file, $file); } } @@ -180,7 +184,7 @@ if (is_array($this->script_files['foot'])) { foreach ($this->script_files['foot'] as $file) { - $__page_footer .= sprintf($this->script_tag_file, $this->scripts_path, $file); + $__page_footer .= sprintf($this->script_tag_file, $file); } } @@ -193,14 +197,14 @@ } // find page header - if ($hpos = strpos(strtolower($output), '</head>')) { + if ($hpos = stripos($output, '</head>')) { $__page_header .= "\n"; } else { if (!is_numeric($hpos)) { - $hpos = strpos(strtolower($output), '<body'); + $hpos = stripos($output, '<body'); } - if (!is_numeric($hpos) && ($hpos = strpos(strtolower($output), '<html'))) { + if (!is_numeric($hpos) && ($hpos = stripos($output, '<html'))) { while ($output[$hpos] != '>') { $hpos++; } @@ -218,14 +222,14 @@ } // find page body - if ($bpos = strpos(strtolower($output), '<body')) { + if ($bpos = stripos($output, '<body')) { while ($output[$bpos] != '>') { $bpos++; } $bpos++; } else { - $bpos = strpos(strtolower($output), '</head>')+7; + $bpos = stripos($output, '</head>')+7; } // add page body @@ -234,8 +238,7 @@ } // find and add page footer - $output_lc = strtolower($output); - if (($fpos = strrpos($output_lc, '</body>')) || ($fpos = strrpos($output_lc, '</html>'))) { + if (($fpos = strripos($output, '</body>')) || ($fpos = strripos($output, '</html>'))) { $output = substr($output, 0, $fpos) . "$__page_footer\n" . substr($output, $fpos); } else { @@ -245,11 +248,35 @@ // reset those global vars $__page_header = $__page_footer = ''; + $this->base_path = $base_path; // correct absolute paths in images and other tags - $output = preg_replace('/(src|href|background)=(["\']?)(\/[a-z0-9_\-]+)/Ui', "\\1=\\2$base_path\\3", $output); + // add timestamp to .js and .css filename + $output = preg_replace_callback('!(src|href|background)=(["\']?)([a-z0-9/_.-]+)(["\'\s>])!i', + array($this, 'file_callback'), $output); $output = str_replace('$__skin_path', $base_path, $output); - echo rcube_charset_convert($output, 'UTF-8', $this->charset); + if ($this->charset != RCMAIL_CHARSET) + echo rcube_charset_convert($output, RCMAIL_CHARSET, $this->charset); + else + echo $output; + } + + /** + * Callback function for preg_replace_callback in write() + */ + private function file_callback($matches) + { + $file = $matches[3]; + + // correct absolute paths + if ($file[0] == '/') + $file = $this->base_path . $file; + + // add file modification timestamp + if (preg_match('/\.(js|css)$/', $file)) + $file .= '?s=' . @filemtime($file); + + return sprintf("%s=%s%s%s", $matches[1], $matches[2], $file, $matches[4]); } } -- Gitblit v1.9.1