]> source.dussan.org Git - nextcloud-server.git/commitdiff
Make SCCCacher injectable
authorRoeland Jago Douma <roeland@famdouma.nl>
Wed, 30 Nov 2016 20:51:09 +0000 (21:51 +0100)
committerRoeland Jago Douma <roeland@famdouma.nl>
Fri, 6 Jan 2017 08:42:14 +0000 (09:42 +0100)
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
lib/private/Template/CSSResourceLocator.php
lib/private/Template/SCSSCacher.php

index 59b49c7337674b4e132434fc0a3ccd64c0460a76..757c0232ca75c6a4a5f7ca71586d839fe4cc41e4 100755 (executable)
@@ -91,24 +91,22 @@ class CSSResourceLocator extends ResourceLocator {
         *
         * @param string $root path to check
         * @param string $file the filename
-        * @param \OCP\Files\IAppData $appData
-        * @param \OCP\IURLGenerator $urlGenerator
-        * @param \OC\SystemConfig $systemConfig
+        * @param IAppData $appData
+        * @param IURLGenerator $urlGenerator
+        * @param SystemConfig $systemConfig
         * @param string|null $webRoot base for path, default map $root to $webRoot
         * @return bool True if the resource was found and cached, false otherwise
         */
-       protected function cacheAndAppendScssIfExist($root, $file, $appData, $urlGenerator, $systemConfig, $webRoot = null) {
+       protected function cacheAndAppendScssIfExist($root, $file, IAppData $appData, IURLGenerator $urlGenerator, SystemConfig $systemConfig, $webRoot = null) {
                if (is_file($root.'/'.$file)) {
                        $scssCache = new SCSSCacher(
                                $this->logger,
-                               $root,
-                               $file,
                                $appData,
                                $urlGenerator,
                                $systemConfig);
 
-                       if($scssCache->process()) {
-                               $this->append($root, $scssCache->getCachedSCSS('core'), $webRoot, false);
+                       if($scssCache->process($root, $file)) {
+                               $this->append($root, $scssCache->getCachedSCSS('core', $file), $webRoot, false);
                                return true;
                        } else {
                                $this->logger->error('Failed to compile and/or save '.$root.'/'.$file, ['app' => 'core']);
index 8e42c623d7ea321eae60fe66dd82fbab59c9ad53..1e3ee4115956f798be29ae06f54f49f91fcab45e 100755 (executable)
@@ -25,36 +25,15 @@ use Leafo\ScssPhp\Compiler;
 use Leafo\ScssPhp\Exception\ParserException;
 use Leafo\ScssPhp\Formatter\Crunched;
 use Leafo\ScssPhp\Formatter\Expanded;
-use OC\Files\SimpleFS\SimpleFolder;
 use OC\SystemConfig;
 use OCP\Files\IAppData;
 use OCP\Files\NotFoundException;
+use OCP\Files\SimpleFS\ISimpleFolder;
 use OCP\ILogger;
 use OCP\IURLGenerator;
 
 class SCSSCacher {
 
-       /** @var string The root path to the nextcloud installation */
-       protected $root;
-
-       /** @var array The exploded absolute path to the file */
-       protected $file;
-
-       /** @var string The scss filename with extension */
-       protected $fileNameSCSS;
-
-       /** @var string The css filename with extension */
-       protected $fileNameCSS;
-
-       /** @var string Absolute path to scss file location folder */
-       protected $fileLoc;
-
-       /** @var string Path to scss file from the root installation */
-       protected $rootCssLoc;
-
-       /** @var SimpleFolder The folder we're putting our compiled css files */
-       protected $folder;
-
        /** @var ILogger */
        protected $logger;
 
@@ -69,62 +48,62 @@ class SCSSCacher {
 
        /**
         * @param ILogger $logger
-        * @param string $root Root path to the nextcloud installation
-        * @param string $file 
         * @param IAppData $appData
         * @param IURLGenerator $urlGenerator
         * @param SystemConfig $systemConfig
         */
-       public function __construct(ILogger $logger, $root, $file, IAppData $appData, IURLGenerator $urlGenerator, SystemConfig $systemConfig) {
+       public function __construct(ILogger $logger, IAppData $appData, IURLGenerator $urlGenerator, SystemConfig $systemConfig) {
                $this->logger = $logger;
                $this->appData = $appData;
                $this->urlGenerator = $urlGenerator;
                $this->systemConfig = $systemConfig;
+       }
 
-               $this->root = $root;
-               $this->file = explode('/', $root.'/'.$file);
+       /**
+        * Process the caching process if needed
+        * @param string $root Root path to the nextcloud installation
+        * @param string $file
+        * @return boolean
+        */
+       public function process($root, $file) {
+               $path = explode('/', $root . '/' . $file);
 
-               /* filenames */
-               $this->fileNameSCSS = array_pop($this->file);
-               $this->fileNameCSS = str_replace('.scss', '.css', $this->fileNameSCSS);
+               $fileNameSCSS = array_pop($path);
+               $fileNameCSS = str_replace('.scss', '.css', $fileNameSCSS);
 
-               $this->fileLoc = implode('/', $this->file);
+               $path = implode('/', $path);
 
-               // base uri to css file
-               $this->rootCssLoc = explode('/', $file);
-               array_pop($this->rootCssLoc);
-               $this->rootCssLoc = implode('/', $this->rootCssLoc);
+               $webDir = explode('/', $file);
+               array_pop($webDir);
+               $webDir = implode('/', $webDir);
 
                try {
-                       $this->folder = $this->appData->getFolder('core');
+                       $folder = $this->appData->getFolder('core');
                } catch(NotFoundException $e) {
                        // creating css appdata folder
-                       $this->folder = $this->appData->newFolder('core');
+                       $folder = $this->appData->newFolder('core');
                }
-       }
-
-       /**
-        * Process the caching process if needed
-        * @return boolean
-        */
-       public function process() {
 
-               if($this->is_cached()) {
+               if($this->is_cached($fileNameCSS, $fileNameSCSS, $folder, $path)) {
                        return true;
                } else {
-                       return $this->cache();
+                       return $this->cache($path, $fileNameCSS, $fileNameSCSS, $folder, $webDir);
                }
        }
 
        /**
         * Check if the file is cached or not
+        * @param string $fileNameCSS
+        * @param string $fileNameSCSS
+        * @param ISimpleFolder $folder
+        * @param string $path
         * @return boolean
         */
-       private function is_cached() {
+       private function is_cached($fileNameCSS, $fileNameSCSS, ISimpleFolder $folder, $path) {
                try{
-                       $cachedfile = $this->folder->getFile($this->fileNameCSS);
-                       if( $cachedfile->getMTime() > filemtime($this->fileLoc.'/'.$this->fileNameSCSS)
-                               && $cachedfile->getSize() > 0 ) {
+                       $cachedFile = $folder->getFile($fileNameCSS);
+                       if( $cachedFile->getMTime() > filemtime($this->fileLoc.'/'.$fileNameSCSS)
+                               && $cachedFile->getSize() > 0 ) {
                                return true;
                        }
                } catch(NotFoundException $e) {
@@ -135,11 +114,16 @@ class SCSSCacher {
 
        /**
         * Cache the file with AppData
+        * @param string $path
+        * @param string $fileNameCSS
+        * @param string $fileNameSCSS
+        * @param ISimpleFolder $folder
+        * @param string $webDir
         * @return boolean
         */
-       private function cache() {
+       private function cache($path, $fileNameCSS, $fileNameSCSS, ISimpleFolder $folder, $webDir) {
                $scss = new Compiler();
-               $scss->setImportPaths($this->fileLoc);
+               $scss->setImportPaths($path);
                if($this->systemConfig->getValue('debug')) {
                        // Debug mode
                        $scss->setFormatter(Expanded::class);
@@ -150,22 +134,22 @@ class SCSSCacher {
                }
 
                try {
-                       $cachedfile = $this->folder->getFile($this->fileNameCSS);
+                       $cachedfile = $folder->getFile($fileNameCSS);
                } catch(NotFoundException $e) {
-                       $cachedfile = $this->folder->newFile($this->fileNameCSS);
+                       $cachedfile = $folder->newFile($fileNameCSS);
                }
 
                // Compile
                try {
-                       $compiledScss = $scss->compile('@import "'.$this->fileNameSCSS.'";');
+                       $compiledScss = $scss->compile('@import "'.$fileNameSCSS.'";');
                } catch(ParserException $e) {
                        $this->logger->error($e, ['app' => 'core']);
                        return false;
                }
 
                try {
-                       $cachedfile->putContent($this->rebaseUrls($compiledScss));
-                       $this->logger->debug($this->rootCssLoc.'/'.$this->fileNameSCSS.' compiled and successfully cached', ['app' => 'core']);
+                       $cachedfile->putContent($this->rebaseUrls($compiledScss, $webDir));
+                       $this->logger->debug($webDir.'/'.$fileNameSCSS.' compiled and successfully cached', ['app' => 'core']);
                        return true;
                } catch(NotFoundException $e) {
                        return false;
@@ -175,20 +159,25 @@ class SCSSCacher {
        /**
         * Add the correct uri prefix to make uri valid again
         * @param string $css
+        * @param string $webDir
         * @return string
         */
-       private function rebaseUrls($css) {
+       private function rebaseUrls($css, $webDir) {
                $re = '/url\([\'"]([\.\w?=\/-]*)[\'"]\)/x';
-               $subst = 'url(\'../../../'.$this->rootCssLoc.'/$1\')';
+               $subst = 'url(\'../../../'.$webDir.'/$1\')';
                return preg_replace($re, $subst, $css);
        }
 
        /**
         * Return the cached css file uri
         * @param string $appName the app name
+        * @param string $fileName
         * @return string
         */
-       public function getCachedSCSS($appName) {
-               return substr($this->urlGenerator->linkToRoute('core.Css.getCss', array('fileName' => $this->fileNameCSS, 'appName' => $appName)), 1);
+       public function getCachedSCSS($appName, $fileName) {
+               $fileName = array_pop(explode('/', $fileName));
+               $fileName = str_replace('.scss', '.css', $fileName);
+
+               return substr($this->urlGenerator->linkToRoute('core.Css.getCss', array('fileName' => $fileName, 'appName' => $appName)), 1);
        }
 }