diff options
-rw-r--r-- | ChangeLog | 1 | ||||
-rw-r--r-- | app/Controller/Currency.php | 2 | ||||
-rw-r--r-- | app/Core/Session/SessionStorage.php | 1 | ||||
-rw-r--r-- | app/Model/Config.php | 112 | ||||
-rw-r--r-- | app/Model/Currency.php | 26 | ||||
-rw-r--r-- | app/Model/Setting.php | 6 | ||||
-rw-r--r-- | tests/units/Model/ConfigTest.php | 143 | ||||
-rw-r--r-- | tests/units/Model/CurrencyTest.php | 7 |
8 files changed, 188 insertions, 110 deletions
@@ -10,6 +10,7 @@ Improvements: * Add dropdown menu for subtasks, categories, swimlanes, columns, custom filters, task links and groups * Add new template hooks +* Application settings are not cached anymore in the session Bug fixes: diff --git a/app/Controller/Currency.php b/app/Controller/Currency.php index 3d0deeac..42e404f8 100644 --- a/app/Controller/Currency.php +++ b/app/Controller/Currency.php @@ -38,7 +38,7 @@ class Currency extends Base 'values' => $values, 'errors' => $errors, 'rates' => $this->currency->getAll(), - 'currencies' => $this->config->getCurrencies(), + 'currencies' => $this->currency->getCurrencies(), 'title' => t('Settings').' > '.t('Currency rates'), ))); } diff --git a/app/Core/Session/SessionStorage.php b/app/Core/Session/SessionStorage.php index 5ee1d811..667d9253 100644 --- a/app/Core/Session/SessionStorage.php +++ b/app/Core/Session/SessionStorage.php @@ -8,7 +8,6 @@ namespace Kanboard\Core\Session; * @package session * @author Frederic Guillot * - * @property array $config * @property array $user * @property array $flash * @property array $csrf diff --git a/app/Model/Config.php b/app/Model/Config.php index 839a2fd4..d815246f 100644 --- a/app/Model/Config.php +++ b/app/Model/Config.php @@ -15,32 +15,6 @@ use Kanboard\Core\Session\SessionManager; class Config extends Setting { /** - * Get available currencies - * - * @access public - * @return array - */ - public function getCurrencies() - { - return array( - 'USD' => t('USD - US Dollar'), - 'EUR' => t('EUR - Euro'), - 'GBP' => t('GBP - British Pound'), - 'CHF' => t('CHF - Swiss Francs'), - 'CAD' => t('CAD - Canadian Dollar'), - 'AUD' => t('AUD - Australian Dollar'), - 'NZD' => t('NZD - New Zealand Dollar'), - 'INR' => t('INR - Indian Rupee'), - 'JPY' => t('JPY - Japanese Yen'), - 'RSD' => t('RSD - Serbian dinar'), - 'SEK' => t('SEK - Swedish Krona'), - 'NOK' => t('NOK - Norwegian Krone'), - 'BAM' => t('BAM - Konvertible Mark'), - 'RUB' => t('RUB - Russian Ruble'), - ); - } - - /** * Get available timezones * * @access public @@ -60,6 +34,31 @@ class Config extends Setting } /** + * Get current timezone + * + * @access public + * @return string + */ + public function getCurrentTimezone() + { + if ($this->userSession->isLogged() && ! empty($this->sessionStorage->user['timezone'])) { + return $this->sessionStorage->user['timezone']; + } + + return $this->get('application_timezone', 'UTC'); + } + + /** + * Set timezone + * + * @access public + */ + public function setupTimezone() + { + date_default_timezone_set($this->getCurrentTimezone()); + } + + /** * Get available languages * * @access public @@ -157,43 +156,6 @@ class Config extends Setting } /** - * Get a config variable from the session or the database - * - * @access public - * @param string $name Parameter name - * @param string $default_value Default value of the parameter - * @return string - */ - public function get($name, $default_value = '') - { - if (! SessionManager::isOpen()) { - return $this->getOption($name, $default_value); - } - - // Cache config in session - if (! isset($this->sessionStorage->config[$name])) { - $this->sessionStorage->config = $this->getAll(); - } - - if (! empty($this->sessionStorage->config[$name])) { - return $this->sessionStorage->config[$name]; - } - - return $default_value; - } - - /** - * Reload settings in the session and the translations - * - * @access public - */ - public function reload() - { - $this->sessionStorage->config = $this->getAll(); - $this->setupTranslations(); - } - - /** * Load translations * * @access public @@ -204,28 +166,27 @@ class Config extends Setting } /** - * Get current timezone + * Get a config variable from the session or the database * * @access public + * @param string $name Parameter name + * @param string $default_value Default value of the parameter * @return string */ - public function getCurrentTimezone() + public function get($name, $default_value = '') { - if ($this->userSession->isLogged() && ! empty($this->sessionStorage->user['timezone'])) { - return $this->sessionStorage->user['timezone']; - } - - return $this->get('application_timezone', 'UTC'); + $options = $this->memoryCache->proxy($this, 'getAll'); + return isset($options[$name]) && $options[$name] !== '' ? $options[$name] : $default_value; } /** - * Set timezone + * Reload settings in the session and the translations * * @access public */ - public function setupTimezone() + public function reload() { - date_default_timezone_set($this->getCurrentTimezone()); + $this->setupTranslations(); } /** @@ -236,7 +197,7 @@ class Config extends Setting */ public function optimizeDatabase() { - return $this->db->getconnection()->exec("VACUUM"); + return $this->db->getconnection()->exec('VACUUM'); } /** @@ -266,10 +227,11 @@ class Config extends Setting * * @access public * @param string $option Parameter name + * @return boolean */ public function regenerateToken($option) { - $this->save(array($option => Token::getToken())); + return $this->save(array($option => Token::getToken())); } /** diff --git a/app/Model/Currency.php b/app/Model/Currency.php index 4351d2aa..abcce2f0 100644 --- a/app/Model/Currency.php +++ b/app/Model/Currency.php @@ -18,6 +18,32 @@ class Currency extends Base const TABLE = 'currencies'; /** + * Get available application currencies + * + * @access public + * @return array + */ + public function getCurrencies() + { + return array( + 'USD' => t('USD - US Dollar'), + 'EUR' => t('EUR - Euro'), + 'GBP' => t('GBP - British Pound'), + 'CHF' => t('CHF - Swiss Francs'), + 'CAD' => t('CAD - Canadian Dollar'), + 'AUD' => t('AUD - Australian Dollar'), + 'NZD' => t('NZD - New Zealand Dollar'), + 'INR' => t('INR - Indian Rupee'), + 'JPY' => t('JPY - Japanese Yen'), + 'RSD' => t('RSD - Serbian dinar'), + 'SEK' => t('SEK - Swedish Krona'), + 'NOK' => t('NOK - Norwegian Krone'), + 'BAM' => t('BAM - Konvertible Mark'), + 'RUB' => t('RUB - Russian Ruble'), + ); + } + + /** * Get all currency rates * * @access public diff --git a/app/Model/Setting.php b/app/Model/Setting.php index 3507d424..44e6c065 100644 --- a/app/Model/Setting.php +++ b/app/Model/Setting.php @@ -47,10 +47,12 @@ abstract class Setting extends Base */ public function getOption($name, $default = '') { - return $this->db + $value = $this->db ->table(self::TABLE) ->eq('option', $name) - ->findOneColumn('value') ?: $default; + ->findOneColumn('value'); + + return $value === null || $value === false || $value === '' ? $default : $value; } /** diff --git a/tests/units/Model/ConfigTest.php b/tests/units/Model/ConfigTest.php index 0c108fd1..447c9238 100644 --- a/tests/units/Model/ConfigTest.php +++ b/tests/units/Model/ConfigTest.php @@ -7,6 +7,74 @@ use Kanboard\Core\Session\SessionManager; class ConfigTest extends Base { + public function testGetTimezones() + { + $configModel = new Config($this->container); + $this->assertNotEmpty($configModel->getTimezones()); + $this->assertArrayHasKey('Europe/Paris', $configModel->getTimezones()); + $this->assertContains('Europe/Paris', $configModel->getTimezones()); + $this->assertArrayNotHasKey('', $configModel->getTimezones()); + + $this->assertArrayHasKey('', $configModel->getTimezones(true)); + $this->assertContains('Application default', $configModel->getTimezones(true)); + } + + public function testGetLanguages() + { + $configModel = new Config($this->container); + $this->assertNotEmpty($configModel->getLanguages()); + $this->assertArrayHasKey('fr_FR', $configModel->getLanguages()); + $this->assertContains('Français', $configModel->getLanguages()); + $this->assertArrayNotHasKey('', $configModel->getLanguages()); + + $this->assertArrayHasKey('', $configModel->getLanguages(true)); + $this->assertContains('Application default', $configModel->getLanguages(true)); + } + + public function testGetJsLanguage() + { + $configModel = new Config($this->container); + $this->assertEquals('en', $configModel->getJsLanguageCode()); + + $this->container['sessionStorage']->user = array('language' => 'fr_FR'); + $this->assertEquals('fr', $configModel->getJsLanguageCode()); + + $this->container['sessionStorage']->user = array('language' => 'xx_XX'); + $this->assertEquals('en', $configModel->getJsLanguageCode()); + } + + public function testGetCurrentLanguage() + { + $configModel = new Config($this->container); + $this->assertEquals('en_US', $configModel->getCurrentLanguage()); + + $this->container['sessionStorage']->user = array('language' => 'fr_FR'); + $this->assertEquals('fr_FR', $configModel->getCurrentLanguage()); + + $this->container['sessionStorage']->user = array('language' => 'xx_XX'); + $this->assertEquals('xx_XX', $configModel->getCurrentLanguage()); + } + + public function testGetCurrentTimezone() + { + $configModel = new Config($this->container); + $this->assertEquals('UTC', $configModel->getCurrentTimezone()); + + $this->container['sessionStorage']->user = array('timezone' => 'Europe/Paris'); + $this->assertEquals('Europe/Paris', $configModel->getCurrentTimezone()); + + $this->container['sessionStorage']->user = array('timezone' => 'Something'); + $this->assertEquals('Something', $configModel->getCurrentTimezone()); + } + + public function testRegenerateToken() + { + $configModel = new Config($this->container); + $token = $configModel->getOption('api_token'); + $this->assertTrue($configModel->regenerateToken('api_token')); + $this->assertNotEquals($token, $configModel->getOption('api_token')); + } + public function testCRUDOperations() { $c = new Config($this->container); @@ -37,60 +105,73 @@ class ConfigTest extends Base $c = new Config($this->container); $this->assertTrue($c->save(array('application_url' => 'http://localhost/'))); - $this->assertEquals('http://localhost/', $c->get('application_url')); + $this->assertEquals('http://localhost/', $c->getOption('application_url')); $this->assertTrue($c->save(array('application_url' => 'http://localhost'))); - $this->assertEquals('http://localhost/', $c->get('application_url')); + $this->assertEquals('http://localhost/', $c->getOption('application_url')); $this->assertTrue($c->save(array('application_url' => ''))); - $this->assertEquals('', $c->get('application_url')); + $this->assertEquals('', $c->getOption('application_url')); } public function testDefaultValues() { $c = new Config($this->container); - $this->assertEquals('en_US', $c->get('application_language')); - $this->assertEquals('UTC', $c->get('application_timezone')); - - $this->assertEmpty($c->get('webhook_url_task_modification')); - $this->assertEmpty($c->get('webhook_url_task_creation')); - $this->assertEmpty($c->get('board_columns')); - $this->assertEmpty($c->get('application_url')); - - $this->assertNotEmpty($c->get('webhook_token')); - $this->assertNotEmpty($c->get('api_token')); + $this->assertEquals(172800, $c->getOption('board_highlight_period')); + $this->assertEquals(60, $c->getOption('board_public_refresh_interval')); + $this->assertEquals(10, $c->getOption('board_private_refresh_interval')); + $this->assertEmpty($c->getOption('board_columns')); + + $this->assertEquals('yellow', $c->getOption('default_color')); + $this->assertEquals('en_US', $c->getOption('application_language')); + $this->assertEquals('UTC', $c->getOption('application_timezone')); + $this->assertEquals('m/d/Y', $c->getOption('application_date_format')); + $this->assertEmpty($c->getOption('application_url')); + $this->assertEmpty($c->getOption('application_stylesheet')); + $this->assertEquals('USD', $c->getOption('application_currency')); + + $this->assertEquals(0, $c->getOption('calendar_user_subtasks_time_tracking')); + $this->assertEquals('date_started', $c->getOption('calendar_user_tasks')); + $this->assertEquals('date_started', $c->getOption('calendar_user_tasks')); + + $this->assertEquals(0, $c->getOption('integration_gravatar')); + $this->assertEquals(1, $c->getOption('cfd_include_closed_tasks')); + $this->assertEquals(1, $c->getOption('password_reset')); + + $this->assertEquals(1, $c->getOption('subtask_time_tracking')); + $this->assertEquals(0, $c->getOption('subtask_restriction')); + $this->assertEmpty($c->getOption('project_categories')); + + $this->assertEmpty($c->getOption('webhook_url_task_modification')); + $this->assertEmpty($c->getOption('webhook_url_task_creation')); + $this->assertNotEmpty($c->getOption('webhook_token')); + $this->assertEmpty($c->getOption('webhook_url')); + + $this->assertNotEmpty($c->getOption('api_token')); } - public function testGet() + public function testGetOption() { $c = new Config($this->container); - $this->assertEquals('', $c->get('board_columns')); - $this->assertEquals('test', $c->get('board_columns', 'test')); - $this->assertEquals(0, $c->get('board_columns', 0)); + $this->assertEquals('', $c->getOption('board_columns')); + $this->assertEquals('test', $c->getOption('board_columns', 'test')); + $this->assertEquals(0, $c->getOption('board_columns', 0)); } - public function testGetWithSession() + public function testGetWithCaching() { $c = new Config($this->container); - session_id('test'); - $this->assertTrue(SessionManager::isOpen()); + $this->assertEquals('UTC', $c->get('application_timezone')); + $this->assertTrue($c->save(array('application_timezone' => 'Europe/Paris'))); + + $this->assertEquals('UTC', $c->get('application_timezone')); // cached value + $this->assertEquals('Europe/Paris', $c->getOption('application_timezone')); $this->assertEquals('', $c->get('board_columns')); $this->assertEquals('test', $c->get('board_columns', 'test')); - - $this->container['sessionStorage']->config = array( - 'board_columns' => 'foo', - 'empty_value' => 0 - ); - - $this->assertEquals('foo', $c->get('board_columns')); - $this->assertEquals('foo', $c->get('board_columns', 'test')); $this->assertEquals('test', $c->get('empty_value', 'test')); - - session_id(''); - $this->assertFalse(SessionManager::isOpen()); } } diff --git a/tests/units/Model/CurrencyTest.php b/tests/units/Model/CurrencyTest.php index ee11c0fb..0bc71da6 100644 --- a/tests/units/Model/CurrencyTest.php +++ b/tests/units/Model/CurrencyTest.php @@ -6,6 +6,13 @@ use Kanboard\Model\Currency; class CurrencyTest extends Base { + public function testGetCurrencies() + { + $currencyModel = new Currency($this->container); + $currencies = $currencyModel->getCurrencies(); + $this->assertArrayHasKey('EUR', $currencies); + } + public function testGetAll() { $currencyModel = new Currency($this->container); |