summaryrefslogtreecommitdiffstats
path: root/lib/private/minimizer.php
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2013-09-25 13:36:30 +0200
committerThomas Müller <thomas.mueller@tmit.eu>2013-09-30 16:36:59 +0200
commit9c9dc276b7a1d2592c4fb0a887888632dc1f1e29 (patch)
treebbe3aed3e09c31c68806bdb8acffef70ba08f51c /lib/private/minimizer.php
parenta711399e62d5a9f14d4b748efe4354ee37e61f13 (diff)
downloadnextcloud-server-9c9dc276b7a1d2592c4fb0a887888632dc1f1e29.tar.gz
nextcloud-server-9c9dc276b7a1d2592c4fb0a887888632dc1f1e29.zip
move the private namespace OC into lib/private - OCP will stay in lib/public
Conflicts: lib/private/vcategories.php
Diffstat (limited to 'lib/private/minimizer.php')
-rw-r--r--lib/private/minimizer.php64
1 files changed, 64 insertions, 0 deletions
diff --git a/lib/private/minimizer.php b/lib/private/minimizer.php
new file mode 100644
index 00000000000..db522de74dc
--- /dev/null
+++ b/lib/private/minimizer.php
@@ -0,0 +1,64 @@
+<?php
+
+abstract class OC_Minimizer {
+ public function generateETag($files) {
+ $fullpath_files = array();
+ foreach($files as $file_info) {
+ $fullpath_files[] = $file_info[0] . '/' . $file_info[2];
+ }
+ return OC_Cache::generateCacheKeyFromFiles($fullpath_files);
+ }
+
+ abstract public function minimizeFiles($files);
+
+ public function output($files, $cache_key) {
+ header('Content-Type: '.$this->contentType);
+ OC_Response::enableCaching();
+ $etag = $this->generateETag($files);
+ $cache_key .= '-'.$etag;
+
+ $gzout = false;
+ $cache = OC_Cache::getGlobalCache();
+ if (!OC_Request::isNoCache() && (!defined('DEBUG') || !DEBUG)) {
+ OC_Response::setETagHeader($etag);
+ $gzout = $cache->get($cache_key.'.gz');
+ }
+
+ if (!$gzout) {
+ $out = $this->minimizeFiles($files);
+ $gzout = gzencode($out);
+ $cache->set($cache_key.'.gz', $gzout);
+ OC_Response::setETagHeader($etag);
+ }
+ // on some systems (e.g. SLES 11, but not Ubuntu) mod_deflate and zlib compression will compress the output twice.
+ // This results in broken core.css and core.js. To avoid it, we switch off zlib compression.
+ // Since mod_deflate is still active, Apache will compress what needs to be compressed, i.e. no disadvantage.
+ if(function_exists('apache_get_modules') && ini_get('zlib.output_compression') && in_array('mod_deflate', apache_get_modules())) {
+ ini_set('zlib.output_compression', 'Off');
+ }
+ if ($encoding = OC_Request::acceptGZip()) {
+ header('Content-Encoding: '.$encoding);
+ $out = $gzout;
+ } else {
+ $out = gzdecode($gzout);
+ }
+ header('Content-Length: '.strlen($out));
+ echo $out;
+ }
+
+ public function clearCache() {
+ $cache = OC_Cache::getGlobalCache();
+ $cache->clear('core.css');
+ $cache->clear('core.js');
+ }
+}
+
+if (!function_exists('gzdecode')) {
+ function gzdecode($data, $maxlength=null, &$filename='', &$error='')
+ {
+ if (strcmp(substr($data, 0, 9),"\x1f\x8b\x8\0\0\0\0\0\0")) {
+ return null; // Not the GZIP format we expect (See RFC 1952)
+ }
+ return gzinflate(substr($data, 10, -8));
+ }
+}