X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=view%2Ftheme%2Fvier%2Fstyle.php;h=8cd0d7a32aae8921ab67db53ee12faf928a96bb9;hb=2ae8e5d34e69a180bc29b018e3bc5dd8fbe7336d;hp=407e080550e13d31a23b0e91f031c8aa6c6a0d32;hpb=4fb2547df87825c136d3ee080bc6960f5c957c65;p=friendica.git diff --git a/view/theme/vier/style.php b/view/theme/vier/style.php index 407e080550..8cd0d7a32a 100644 --- a/view/theme/vier/style.php +++ b/view/theme/vier/style.php @@ -1,49 +1,57 @@ . + * */ -use Friendica\Core\Config; -use Friendica\Core\PConfig; -use Friendica\Model\Profile; -$uid = Profile::getThemeUid(); +use Friendica\Core\Logger; +use Friendica\DI; -$style = PConfig::get($uid, 'vier', 'style'); +$uid = $_REQUEST['puid'] ?? 0; -if ($style == "") { - $style = Config::get('vier', 'style'); -} +$style = DI::pConfig()->get($uid, 'vier', 'style'); -if ($style == "") { - $style = "plus"; +if (empty($style)) { + $style = DI::config()->get('vier', 'style'); } -if ($style == "flat") { - $stylecssfile = 'view/theme/vier/flat.css'; -} else if ($style == "netcolour") { - $stylecssfile = 'view/theme/vier/netcolour.css'; -} else if ($style == "breathe") { - $stylecssfile = 'view/theme/vier/breathe.css'; -} else if ($style == "plus") { - $stylecssfile = 'view/theme/vier/plus.css'; -} else if ($style == "dark") { - $stylecssfile = 'view/theme/vier/dark.css'; -} else if ($style == "plusminus") { - $stylecssfile = 'view/theme/vier/plusminus.css'; +if (empty($style)) { + $style = "plus"; } -if (file_exists($THEMEPATH."//style.css")) { - $stylecss = file_get_contents($THEMEPATH."//style.css")."\n"; - $modified = filemtime($THEMEPATH."//style.css"); -} +$stylecss = ''; +$modified = ''; -$stylemodified = filemtime($stylecssfile); -$stylecss .= file_get_contents($stylecssfile); +$style = \Friendica\Util\Strings::sanitizeFilePathItem($style); -if ($stylemodified > $modified) { - $modified = $stylemodified; +foreach (['style', $style] as $file) { + $stylecssfile = $THEMEPATH . DIRECTORY_SEPARATOR . $file .'.css'; + if (file_exists($stylecssfile)) { + $stylecss .= file_get_contents($stylecssfile); + $stylemodified = filemtime($stylecssfile); + if ($stylemodified > $modified) { + $modified = $stylemodified; + } + } else { + //TODO: use Logger::ERROR? + Logger::log('Error: missing file: "' . $stylecssfile .'" (userid: '. $uid .')'); + } } - $modified = gmdate('r', $modified); $etag = md5($stylecss); @@ -53,10 +61,9 @@ header('Cache-Control: public'); header('ETag: "'.$etag.'"'); header('Last-Modified: '.$modified); -if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) || isset($_SERVER['HTTP_IF_NONE_MATCH'])) { - +if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && isset($_SERVER['HTTP_IF_NONE_MATCH'])) { $cached_modified = gmdate('r', strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE'])); - $cached_etag = str_replace(array('"', "-gzip"), array('', ''), + $cached_etag = str_replace(['"', "-gzip"], ['', ''], stripslashes($_SERVER['HTTP_IF_NONE_MATCH'])); if (($cached_modified == $modified) && ($cached_etag == $etag)) {