<?php
/**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2023, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
*/
use Friendica\DI;
+use Friendica\Network\HTTPException\NotModifiedException;
use Friendica\Util\Strings;
require_once 'view/theme/frio/theme.php';
$schemecssfile = false;
$scheme_modified = 0;
-DI::config()->load('frio');
-
-// Default to hard-coded values for empty settings
-$scheme = DI::config()->get('frio', 'scheme', DI::config()->get('frio', 'schema'));
-$nav_bg = DI::config()->get('frio', 'nav_bg') ?: '#708fa0';
-$nav_icon_color = DI::config()->get('frio', 'nav_icon_color') ?: '#ffffff';
-$link_color = DI::config()->get('frio', 'link_color') ?: '#6fdbe8';
-$background_color = DI::config()->get('frio', 'background_color') ?: '#ededed';
-$contentbg_transp = DI::config()->get('frio', 'contentbg_transp') ?? 100;
-$background_image = DI::config()->get('frio', 'background_image') ?: 'img/none.png';
-$bg_image_option = DI::config()->get('frio', 'bg_image_option') ?: '';
-$login_bg_image = DI::config()->get('frio', 'login_bg_image') ?: '';
-$login_bg_color = DI::config()->get('frio', 'login_bg_color') ?: '';
-$modified = DI::config()->get('frio', 'css_modified') ?: time();
+/*
+ * This script can be included when the maintenance mode is on, which requires us to avoid any config call and
+ * use the following hardcoded defaults
+ */
+$scheme = null;
+$scheme_accent = FRIO_SCHEME_ACCENT_BLUE;
+$nav_bg = '#708fa0';
+$nav_icon_color = '#ffffff';
+$link_color = '#6fdbe8';
+$background_color = '#ededed';
+$contentbg_transp = 100;
+$background_image = 'img/none.png';
+$bg_image_option = '';
+$login_bg_image = '';
+$login_bg_color = '';
+$modified = time();
+
+if (DI::mode()->has(\Friendica\App\Mode::MAINTENANCEDISABLED)) {
+ DI::config()->reload();
+
+ // Default to hard-coded values for empty settings
+ $scheme = DI::config()->get('frio', 'scheme', DI::config()->get('frio', 'schema'));
+ $scheme_accent = DI::config()->get('frio', 'scheme_accent') ?: $scheme_accent;
+ $nav_bg = DI::config()->get('frio', 'nav_bg') ?: $nav_bg;
+ $nav_icon_color = DI::config()->get('frio', 'nav_icon_color') ?: $nav_icon_color;
+ $link_color = DI::config()->get('frio', 'link_color') ?: $link_color;
+ $background_color = DI::config()->get('frio', 'background_color') ?: $background_color;
+ $contentbg_transp = DI::config()->get('frio', 'contentbg_transp') ?? $contentbg_transp;
+ $background_image = DI::config()->get('frio', 'background_image') ?: $background_image;
+ $bg_image_option = DI::config()->get('frio', 'bg_image_option') ?: $bg_image_option;
+ $login_bg_image = DI::config()->get('frio', 'login_bg_image') ?: $login_bg_image;
+ $login_bg_color = DI::config()->get('frio', 'login_bg_color') ?: $login_bg_color;
+ $modified = DI::config()->get('frio', 'css_modified') ?: $modified;
+
+ // Get the UID of the profile owner.
+ $uid = $_REQUEST['puid'] ?? 0;
+ if ($uid) {
+ DI::pConfig()->load($uid, 'frio');
+
+ // Only override display settings that have actually been set
+ $scheme = DI::pConfig()->get($uid, 'frio', 'scheme', DI::pConfig()->get($uid, 'frio', 'schema')) ?: $scheme;
+ $scheme_accent = DI::pConfig()->get($uid, 'frio', 'scheme_accent') ?: $scheme_accent;
+ $nav_bg = DI::pConfig()->get($uid, 'frio', 'nav_bg') ?: $nav_bg;
+ $nav_icon_color = DI::pConfig()->get($uid, 'frio', 'nav_icon_color') ?: $nav_icon_color;
+ $link_color = DI::pConfig()->get($uid, 'frio', 'link_color') ?: $link_color;
+ $background_color = DI::pConfig()->get($uid, 'frio', 'background_color') ?: $background_color;
+ $contentbg_transp = DI::pConfig()->get($uid, 'frio', 'contentbg_transp') ?? $contentbg_transp;
+ $background_image = DI::pConfig()->get($uid, 'frio', 'background_image') ?: $background_image;
+ $bg_image_option = DI::pConfig()->get($uid, 'frio', 'bg_image_option') ?: $bg_image_option;
+ $modified = DI::pConfig()->get($uid, 'frio', 'css_modified') ?: $modified;
+ }
+}
if (!$login_bg_image && !$login_bg_color) {
$login_bg_image = 'img/login_bg.jpg';
}
$login_bg_color = $login_bg_color ?: '#ededed';
-// Get the UID of the profile owner.
-$uid = $_REQUEST['puid'] ?? 0;
-if ($uid) {
- DI::pConfig()->load($uid, 'frio');
-
- // Only override display settings that have actually been set
- $scheme = DI::pConfig()->get($uid, 'frio', 'scheme', DI::pConfig()->get($uid, 'frio', 'schema')) ?: $scheme;
- $nav_bg = DI::pConfig()->get($uid, 'frio', 'nav_bg') ?: $nav_bg;
- $nav_icon_color = DI::pConfig()->get($uid, 'frio', 'nav_icon_color') ?: $nav_icon_color;
- $link_color = DI::pConfig()->get($uid, 'frio', 'link_color') ?: $link_color;
- $background_color = DI::pConfig()->get($uid, 'frio', 'background_color') ?: $background_color;
- $contentbg_transp = DI::pConfig()->get($uid, 'frio', 'contentbg_transp') ?? $contentbg_transp;
- $background_image = DI::pConfig()->get($uid, 'frio', 'background_image') ?: $background_image;
- $bg_image_option = DI::pConfig()->get($uid, 'frio', 'bg_image_option') ?: $bg_image_option;
- $modified = DI::pConfig()->get($uid, 'frio', 'css_modified') ?: $modified;
-}
-
// Now load the scheme. If a value is changed above, we'll keep the settings
// If not, we'll keep those defined by the scheme
// Setting $scheme to '' wasn't working for some reason, so we'll check it's
$scheme = $_REQUEST['scheme'];
}
-$scheme = Strings::sanitizeFilePathItem($scheme);
+$scheme = Strings::sanitizeFilePathItem($scheme ?? '');
-if (($scheme) && ($scheme != '---')) {
+if ($scheme && ($scheme != '---')) {
if (file_exists('view/theme/frio/scheme/' . $scheme . '.php')) {
$schemefile = 'view/theme/frio/scheme/' . $scheme . '.php';
require_once $schemefile;
}
}
-$contentbg_transp = ((isset($contentbg_transp) && $contentbg_transp != '') ? $contentbg_transp : 100);
+$contentbg_transp = $contentbg_transp != '' ? $contentbg_transp : 100;
// Calculate some colors in dependance of existing colors.
// Some colors are calculated to don't have too many selection
'$background_repeat' => $background_repeat,
'$login_bg_image' => $login_bg_image,
'$login_bg_color' => $login_bg_color,
- '$font_color_darker' => $font_color_darker ?? '#555',
- '$font_color' => $font_color ?? '#777',
+ '$font_color_darker' => $font_color_darker ?? '#222',
+ '$font_color_lighter' => $font_color_lighter ?? '#aaa',
+ '$font_color' => $font_color ?? '#444',
];
$css_tpl = file_get_contents('view/theme/frio/css/style.css');
+$css_tpl .= file_get_contents('view/theme/frio/css/dropzone.min.frio.css');
// Get the content of the scheme css file and the time of the last file change.
if ($schemecssfile) {
stripslashes($_SERVER['HTTP_IF_NONE_MATCH']));
if (($cached_modified == $modified) && ($cached_etag == $etag)) {
- header('HTTP/1.1 304 Not Modified');
- exit();
+ throw new NotModifiedException();
}
}