Remove asset pipelin
Fixes #215 The asset pipeline has shown to do more harm than good. Some apps fail hard with it. Also it makes sure that you download a huge file on each unvisited page.
This commit is contained in:
parent
e577ef8728
commit
72464f1ce4
|
@ -1168,22 +1168,6 @@ $CONFIG = array(
|
||||||
*/
|
*/
|
||||||
'part_file_in_storage' => true,
|
'part_file_in_storage' => true,
|
||||||
|
|
||||||
/**
|
|
||||||
* All css and js files will be served by the Web server statically in one js
|
|
||||||
* file and one css file if this is set to ``true``. This improves performance.
|
|
||||||
*/
|
|
||||||
'asset-pipeline.enabled' => false,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The parent of the directory where css and js assets will be stored if
|
|
||||||
* pipelining is enabled; this defaults to the Nextcloud directory. The assets
|
|
||||||
* will be stored in a subdirectory of this directory named 'assets'. The
|
|
||||||
* server *must* be configured to serve that directory as $WEBROOT/assets.
|
|
||||||
* You will only likely need to change this if the main Nextcloud directory
|
|
||||||
* is not writeable by the Web server in your configuration.
|
|
||||||
*/
|
|
||||||
'assetdirectory' => '/var/www/nextcloud',
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Where ``mount.json`` file should be stored, defaults to ``data/mount.json``
|
* Where ``mount.json`` file should be stored, defaults to ``data/mount.json``
|
||||||
* in the Nextcloud directory.
|
* in the Nextcloud directory.
|
||||||
|
|
|
@ -29,14 +29,10 @@ use OCP\Migration\IRepairStep;
|
||||||
class AssetCache implements IRepairStep {
|
class AssetCache implements IRepairStep {
|
||||||
|
|
||||||
public function getName() {
|
public function getName() {
|
||||||
return 'Clear asset cache after upgrade';
|
return 'Remove asset cache';
|
||||||
}
|
}
|
||||||
|
|
||||||
public function run(IOutput $output) {
|
public function run(IOutput $output) {
|
||||||
if (!\OC_Template::isAssetPipelineEnabled()) {
|
|
||||||
$output->info('Asset pipeline disabled -> nothing to do');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$assetDir = \OC::$server->getConfig()->getSystemValue('assetdirectory', \OC::$SERVERROOT) . '/assets';
|
$assetDir = \OC::$server->getConfig()->getSystemValue('assetdirectory', \OC::$SERVERROOT) . '/assets';
|
||||||
\OC_Helper::rmdirr($assetDir, false);
|
\OC_Helper::rmdirr($assetDir, false);
|
||||||
$output->info('Asset cache cleared.');
|
$output->info('Asset cache cleared.');
|
||||||
|
|
|
@ -137,11 +137,6 @@ class TemplateLayout extends \OC_Template {
|
||||||
self::$versionHash = md5('not installed');
|
self::$versionHash = md5('not installed');
|
||||||
}
|
}
|
||||||
|
|
||||||
$useAssetPipeline = self::isAssetPipelineEnabled();
|
|
||||||
if ($useAssetPipeline) {
|
|
||||||
$this->append( 'jsfiles', \OC::$server->getURLGenerator()->linkToRoute('js_config', ['v' => self::$versionHash]));
|
|
||||||
$this->generateAssets();
|
|
||||||
} else {
|
|
||||||
// Add the js files
|
// Add the js files
|
||||||
$jsFiles = self::findJavascriptFiles(\OC_Util::$scripts);
|
$jsFiles = self::findJavascriptFiles(\OC_Util::$scripts);
|
||||||
$this->assign('jsfiles', array());
|
$this->assign('jsfiles', array());
|
||||||
|
@ -169,7 +164,6 @@ class TemplateLayout extends \OC_Template {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array $styles
|
* @param array $styles
|
||||||
|
@ -205,91 +199,6 @@ class TemplateLayout extends \OC_Template {
|
||||||
return $locator->getResources();
|
return $locator->getResources();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function generateAssets() {
|
|
||||||
$assetDir = \OC::$server->getConfig()->getSystemValue('assetdirectory', \OC::$SERVERROOT);
|
|
||||||
$jsFiles = self::findJavascriptFiles(\OC_Util::$scripts);
|
|
||||||
$jsHash = self::hashFileNames($jsFiles);
|
|
||||||
|
|
||||||
if (!file_exists("$assetDir/assets/$jsHash.js")) {
|
|
||||||
$jsFiles = array_map(function ($item) {
|
|
||||||
$root = $item[0];
|
|
||||||
$file = $item[2];
|
|
||||||
// no need to minifiy minified files
|
|
||||||
if (substr($file, -strlen('.min.js')) === '.min.js') {
|
|
||||||
return new FileAsset($root . '/' . $file, array(
|
|
||||||
new SeparatorFilter(';')
|
|
||||||
), $root, $file);
|
|
||||||
}
|
|
||||||
return new FileAsset($root . '/' . $file, array(
|
|
||||||
new JSqueezeFilter(),
|
|
||||||
new SeparatorFilter(';')
|
|
||||||
), $root, $file);
|
|
||||||
}, $jsFiles);
|
|
||||||
$jsCollection = new AssetCollection($jsFiles);
|
|
||||||
$jsCollection->setTargetPath("assets/$jsHash.js");
|
|
||||||
|
|
||||||
$writer = new AssetWriter($assetDir);
|
|
||||||
$writer->writeAsset($jsCollection);
|
|
||||||
}
|
|
||||||
|
|
||||||
$cssFiles = self::findStylesheetFiles(\OC_Util::$styles);
|
|
||||||
|
|
||||||
// differentiate between screen stylesheets and printer stylesheets
|
|
||||||
$screenCssFiles = array_filter($cssFiles, function($cssFile) {
|
|
||||||
return substr_compare($cssFile[2], 'print.css', -strlen('print.css')) !== 0;
|
|
||||||
});
|
|
||||||
$screenCssAsset = $this->generateCssAsset($screenCssFiles);
|
|
||||||
|
|
||||||
$printCssFiles = array_filter($cssFiles, function($cssFile) {
|
|
||||||
return substr_compare($cssFile[2], 'print.css', -strlen('print.css')) === 0;
|
|
||||||
});
|
|
||||||
$printCssAsset = $this->generateCssAsset($printCssFiles);
|
|
||||||
|
|
||||||
$this->append('jsfiles', \OC::$server->getURLGenerator()->linkTo('assets', "$jsHash.js"));
|
|
||||||
$this->append('cssfiles', $screenCssAsset);
|
|
||||||
$this->append('printcssfiles', $printCssAsset);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* generates a single css asset file from an array of css files if at least one of them has changed
|
|
||||||
* otherwise it just returns the path to the old asset file
|
|
||||||
* @param $files
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
private function generateCssAsset($files) {
|
|
||||||
$assetDir = \OC::$server->getConfig()->getSystemValue('assetdirectory', \OC::$SERVERROOT);
|
|
||||||
$hash = self::hashFileNames($files);
|
|
||||||
|
|
||||||
if (!file_exists("$assetDir/assets/$hash.css")) {
|
|
||||||
$files = array_map(function ($item) {
|
|
||||||
$root = $item[0];
|
|
||||||
$file = $item[2];
|
|
||||||
$assetPath = $root . '/' . $file;
|
|
||||||
$sourceRoot = \OC::$SERVERROOT;
|
|
||||||
$sourcePath = substr($assetPath, strlen(\OC::$SERVERROOT));
|
|
||||||
return new FileAsset(
|
|
||||||
$assetPath,
|
|
||||||
array(
|
|
||||||
new CssRewriteFilter(),
|
|
||||||
new CssMinFilter(),
|
|
||||||
new CssImportFilter()
|
|
||||||
),
|
|
||||||
$sourceRoot,
|
|
||||||
$sourcePath
|
|
||||||
);
|
|
||||||
}, $files);
|
|
||||||
|
|
||||||
$cssCollection = new AssetCollection($files);
|
|
||||||
$cssCollection->setTargetPath("assets/$hash.css");
|
|
||||||
|
|
||||||
$writer = new AssetWriter($assetDir);
|
|
||||||
$writer->writeAsset($cssCollection);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return \OC::$server->getURLGenerator()->linkTo('assets', "$hash.css");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts the absolute file path to a relative path from \OC::$SERVERROOT
|
* Converts the absolute file path to a relative path from \OC::$SERVERROOT
|
||||||
* @param string $filePath Absolute path
|
* @param string $filePath Absolute path
|
||||||
|
@ -304,24 +213,4 @@ class TemplateLayout extends \OC_Template {
|
||||||
|
|
||||||
return $relativePath[1];
|
return $relativePath[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $files
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
|
|
||||||
private static function hashFileNames($files) {
|
|
||||||
foreach($files as $i => $file) {
|
|
||||||
try {
|
|
||||||
$files[$i] = self::convertToRelativePath($file[0]).'/'.$file[2];
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
$files[$i] = $file[0].'/'.$file[2];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sort($files);
|
|
||||||
// include the apps' versions hash to invalidate the cached assets
|
|
||||||
$files[] = self::$versionHash;
|
|
||||||
return hash('md5', implode('', $files));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -395,46 +395,4 @@ class OC_Template extends \OC\Template\Base {
|
||||||
}
|
}
|
||||||
return 'HTTP/1.1';
|
return 'HTTP/1.1';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
public static function isAssetPipelineEnabled() {
|
|
||||||
try {
|
|
||||||
if (\OCP\Util::needUpgrade()) {
|
|
||||||
// Don't use the compiled asset when we need to do an update
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
} catch (\Exception $e) {
|
|
||||||
// Catch any exception, because this code is also called when displaying
|
|
||||||
// an exception error page.
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// asset management enabled?
|
|
||||||
$config = \OC::$server->getConfig();
|
|
||||||
$useAssetPipeline = $config->getSystemValue('asset-pipeline.enabled', false);
|
|
||||||
if (!$useAssetPipeline) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// assets folder exists?
|
|
||||||
$assetDir = $config->getSystemValue('assetdirectory', \OC::$SERVERROOT) . '/assets';
|
|
||||||
if (!is_dir($assetDir)) {
|
|
||||||
if (!mkdir($assetDir)) {
|
|
||||||
\OCP\Util::writeLog('assets',
|
|
||||||
"Folder <$assetDir> does not exist and/or could not be generated.", \OCP\Util::ERROR);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// assets folder can be accessed?
|
|
||||||
if (!touch($assetDir."/.oc")) {
|
|
||||||
\OCP\Util::writeLog('assets',
|
|
||||||
"Folder <$assetDir> could not be accessed.", \OCP\Util::ERROR);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return $useAssetPipeline;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue