1
0
mirror of https://github.com/typemill/typemill.git synced 2025-01-17 21:38:25 +01:00
php-typemill/system/Settings.php

194 lines
5.7 KiB
PHP
Raw Normal View History

2019-10-20 12:09:45 +02:00
<?php
namespace Typemill;
class Settings
{
public static function loadSettings()
{
$defaultSettings = self::getDefaultSettings();
$userSettings = self::getUserSettings();
$settings = $defaultSettings;
if($userSettings)
{
$settings = array_merge($defaultSettings, $userSettings);
}
2020-04-05 19:13:10 +02:00
# if there is no theme set
if(!isset($settings['theme']))
{
# scan theme folder and get the first theme
$themefolder = $settings['rootPath'] . $settings['themeFolder'] . DIRECTORY_SEPARATOR;
$themes = array_diff(scandir($themefolder), array('..', '.'));
$firsttheme = reset($themes);
# if there is a theme with valid theme settings-file
if($firsttheme && self::getObjectSettings('themes', $firsttheme))
{
$settings['theme'] = $firsttheme;
}
else
{
die('There is no theme in the theme-folder. Please add a theme from https://themes.typemill.net');
}
}
# i18n
2020-01-20 19:41:57 +01:00
# load the strings of the set language
$language = $settings['language'];
$settings['labels'] = self::getLanguageLabels($language);
$settings['vuejsLabels'] = self::getVuejsLabels($language);
2020-01-09 15:46:20 +01:00
# We know the used theme now so create the theme path
$settings['themePath'] = $settings['rootPath'] . $settings['themeFolder'] . DIRECTORY_SEPARATOR . $settings['theme'];
# if there are no theme settings yet (e.g. no setup yet) use default theme settings
if(!isset($settings['themes']))
{
$themeSettings = self::getObjectSettings('themes', $settings['theme']);
$settings['themes'][$settings['theme']] = isset($themeSettings['settings']) ? $themeSettings['settings'] : false;
2020-04-05 19:13:10 +02:00
}
2019-10-20 12:09:45 +02:00
return array('settings' => $settings);
}
public static function getDefaultSettings()
{
$rootPath = __DIR__ . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR;
return [
'determineRouteBeforeAppMiddleware' => true,
'displayErrorDetails' => false,
'title' => 'TYPEMILL',
'author' => 'Unknown',
'copyright' => 'Copyright',
'language' => 'en',
'startpage' => true,
'rootPath' => $rootPath,
'themeFolder' => 'themes',
2019-10-20 12:09:45 +02:00
'themeBasePath' => $rootPath,
'themePath' => '',
2019-10-20 12:09:45 +02:00
'settingsPath' => $rootPath . 'settings',
'userPath' => $rootPath . 'settings' . DIRECTORY_SEPARATOR . 'users',
'authorPath' => __DIR__ . DIRECTORY_SEPARATOR . 'author' . DIRECTORY_SEPARATOR,
'editor' => 'visual',
2020-04-05 19:13:10 +02:00
'formats' => ['markdown', 'headline', 'ulist', 'olist', 'table', 'quote', 'image', 'video', 'file', 'toc', 'hr', 'definition', 'code'],
2019-10-20 12:09:45 +02:00
'contentFolder' => 'content',
'cache' => true,
'cachePath' => $rootPath . 'cache',
2020-02-26 21:57:01 +01:00
'version' => '1.3.3',
2019-10-20 12:09:45 +02:00
'setup' => true,
'welcome' => true,
2020-04-05 19:13:10 +02:00
'images' => ['live' => ['width' => 820], 'thumbs' => ['width' => 250, 'height' => 150]],
2019-10-20 12:09:45 +02:00
];
}
public static function getUserSettings()
{
$yaml = new Models\WriteYaml();
$userSettings = $yaml->getYaml('settings', 'settings.yaml');
return $userSettings;
}
2020-01-09 15:46:20 +01:00
# i18n
public static function getLanguageLabels($language)
2020-01-09 15:46:20 +01:00
{
# if not present, set the English language
if( empty($language) )
{
$language = 'en';
}
2020-01-09 15:46:20 +01:00
# load the strings of the set language
2020-01-09 15:46:20 +01:00
$yaml = new Models\WriteYaml();
$labels = $yaml->getYaml('settings/languages', $language.'.yaml');
return $labels;
}
2020-01-13 15:50:20 +01:00
public static function getVuejsLabels($language)
{
2020-01-13 16:09:53 +01:00
if( empty($language) ){
$language = 'en';
}
2020-01-13 15:50:20 +01:00
// load the strings of the set language
$yaml = new Models\WriteYaml();
2020-01-13 16:09:53 +01:00
$labels = $yaml->getYaml('settings/languages', 'vuejs-'.$language.'.yaml');
2020-01-13 15:50:20 +01:00
return $labels;
}
2020-01-09 15:46:20 +01:00
2019-10-20 12:09:45 +02:00
public static function getObjectSettings($objectType, $objectName)
{
$yaml = new Models\WriteYaml();
$objectFolder = $objectType . DIRECTORY_SEPARATOR . $objectName;
$objectFile = $objectName . '.yaml';
$objectSettings = $yaml->getYaml($objectFolder, $objectFile);
return $objectSettings;
}
2019-12-31 15:57:45 +01:00
2019-10-20 12:09:45 +02:00
public static function createSettings()
{
$yaml = new Models\WriteYaml();
# create initial settings file with only setup false
if($yaml->updateYaml('settings', 'settings.yaml', array('setup' => false)))
{
return true;
}
return false;
}
public static function updateSettings($settings)
{
# only allow if usersettings already exists (setup has been done)
$userSettings = self::getUserSettings();
if($userSettings)
{
2020-04-05 19:13:10 +02:00
# whitelist settings that can be stored in usersettings (values are not relevant here, only keys)
$allowedUserSettings = ['displayErrorDetails' => true,
2020-04-05 19:13:10 +02:00
'title' => true,
'copyright' => true,
'language' => true,
'startpage' => true,
'author' => true,
'year' => true,
'theme' => true,
'editor' => true,
'formats' => true,
'setup' => true,
'welcome' => true,
'images' => true,
'plugins' => true,
'themes' => true,
'latestVersion' => true,
'logo' => true,
'favicon' => true,
2019-10-20 12:09:45 +02:00
];
# cleanup the existing usersettings
$userSettings = array_intersect_key($userSettings, $allowedUserSettings);
# cleanup the new settings passed as an argument
$settings = array_intersect_key($settings, $allowedUserSettings);
# merge usersettings with new settings
$settings = array_merge($userSettings, $settings);
# write settings to yaml
2019-10-20 12:09:45 +02:00
$yaml = new Models\WriteYaml();
$yaml->updateYaml('settings', 'settings.yaml', $settings);
}
}
2020-01-13 16:09:06 +01:00
}