raspisms/controllers/publics/Setting.php

85 lines
2.7 KiB
PHP
Raw Normal View History

2019-10-29 14:57:13 +01:00
<?php
/*
* This file is part of PHP CS Fixer.
*
* (c) Fabien Potencier <fabien@symfony.com>
* Dariusz Rumiński <dariusz.ruminski@gmail.com>
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
2019-10-29 14:57:13 +01:00
namespace controllers\publics;
2019-10-29 18:36:25 +01:00
/**
* Page des settings.
2019-10-29 18:36:25 +01:00
*/
class Setting extends \descartes\Controller
2019-10-29 14:57:13 +01:00
{
private $internal_setting;
2019-10-29 18:36:25 +01:00
public function __construct()
2019-10-29 14:57:13 +01:00
{
$bdd = \descartes\Model::_connect(DATABASE_HOST, DATABASE_NAME, DATABASE_USER, DATABASE_PASSWORD);
2019-10-29 14:57:13 +01:00
$this->internal_setting = new \controllers\internals\Setting($bdd);
\controllers\internals\Tool::verifyconnect();
2019-10-29 14:57:13 +01:00
}
/**
* Return all settings to administrate them.
2019-10-29 18:36:25 +01:00
*/
public function show()
2019-10-29 14:57:13 +01:00
{
return $this->render('setting/show');
2019-10-29 18:36:25 +01:00
}
2019-10-29 14:57:13 +01:00
/**
* Update a setting value identified by his name.
*
2019-10-29 14:57:13 +01:00
* @param string $setting_name : Name of the setting to modify
* @param $csrf : CSRF token
* @param string $_POST['setting_value'] : Setting's new value
*
2019-10-29 14:57:13 +01:00
* @return boolean;
*/
2019-10-29 18:36:25 +01:00
public function update(string $setting_name, string $csrf)
2019-10-29 14:57:13 +01:00
{
if (!$this->verify_csrf($csrf))
{
2019-11-09 03:35:12 +01:00
\FlashMessage\FlashMessage::push('danger', 'Jeton CSRF invalid !');
2019-11-10 17:36:42 +01:00
return $this->redirect(\descartes\Router::url('Setting', 'show'));
2019-10-29 14:57:13 +01:00
}
if (!\controllers\internals\Tool::is_admin())
{
2019-11-09 03:35:12 +01:00
\FlashMessage\FlashMessage::push('danger', 'Vous devez être administrateur pour pouvoir modifier un réglage.');
2019-11-10 17:36:42 +01:00
return $this->redirect(\descartes\Router::url('Setting', 'show'));
2019-10-29 14:57:13 +01:00
}
$setting_value = $_POST['setting_value'] ?? false;
if (false === $setting_value)
{
2019-11-09 03:35:12 +01:00
\FlashMessage\FlashMessage::push('danger', 'Vous devez renseigner une valeure pour le réglage.');
2019-11-10 17:36:42 +01:00
return $this->redirect(\descartes\Router::url('Setting', 'show'));
2019-10-29 14:57:13 +01:00
}
$update_setting_result = $this->internal_setting->update($setting_name, $setting_value);
if (false === $update_setting_result)
{
2019-11-09 03:35:12 +01:00
\FlashMessage\FlashMessage::push('danger', 'Impossible de mettre à jour ce réglage.');
2019-11-10 17:36:42 +01:00
return $this->redirect(\descartes\Router::url('Setting', 'show'));
2019-10-29 14:57:13 +01:00
}
2019-11-09 03:35:12 +01:00
\FlashMessage\FlashMessage::push('success', 'Le réglage a bien été mis à jour.');
2019-11-10 17:36:42 +01:00
return $this->redirect(\descartes\Router::url('Setting', 'show'));
2019-10-29 14:57:13 +01:00
}
2019-10-29 18:36:25 +01:00
}