2019-10-29 14:57:13 +01:00
< ? php
2019-10-30 00:30:39 +01:00
/*
* 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
/**
2019-10-30 00:30:39 +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
{
2019-10-30 00:17:10 +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 );
2019-10-30 00:17:10 +01:00
\controllers\internals\Tool :: verifyconnect ();
2019-10-29 14:57:13 +01:00
}
/**
2019-10-30 00:30:39 +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-30 00:30:39 +01:00
2019-10-29 14:57:13 +01:00
/**
2019-10-30 00:30:39 +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-30 00:30:39 +01:00
*
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
{
2019-10-30 00:30:39 +01:00
if ( ! $this -> verify_csrf ( $csrf ))
{
2019-10-30 00:17:10 +01:00
\modules\DescartesSessionMessages\internals\DescartesSessionMessages :: push ( 'danger' , 'Jeton CSRF invalid !' );
2019-10-30 00:30:39 +01:00
2019-10-30 00:17:10 +01:00
return $this -> redirect ( \descartes\Router :: url ( 'Setting' , 'show' ));
2019-10-29 14:57:13 +01:00
}
2019-10-30 00:30:39 +01:00
if ( ! \controllers\internals\Tool :: is_admin ())
{
2019-10-30 00:17:10 +01:00
\modules\DescartesSessionMessages\internals\DescartesSessionMessages :: push ( 'danger' , 'Vous devez être administrateur pour pouvoir modifier un réglage.' );
2019-10-30 00:30:39 +01:00
2019-10-30 00:17:10 +01:00
return $this -> redirect ( \descartes\Router :: url ( 'Setting' , 'show' ));
2019-10-29 14:57:13 +01:00
}
$setting_value = $_POST [ 'setting_value' ] ? ? false ;
2019-10-30 00:30:39 +01:00
if ( false === $setting_value )
{
2019-10-30 00:17:10 +01:00
\modules\DescartesSessionMessages\internals\DescartesSessionMessages :: push ( 'danger' , 'Vous devez renseigner une valeure pour le réglage.' );
2019-10-30 00:30:39 +01:00
2019-10-30 00:17:10 +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 );
2019-10-30 00:30:39 +01:00
if ( false === $update_setting_result )
{
2019-10-30 00:17:10 +01:00
\modules\DescartesSessionMessages\internals\DescartesSessionMessages :: push ( 'danger' , 'Impossible de mettre à jour ce réglage.' );
2019-10-30 00:30:39 +01:00
2019-10-30 00:17:10 +01:00
return $this -> redirect ( \descartes\Router :: url ( 'Setting' , 'show' ));
2019-10-29 14:57:13 +01:00
}
2019-10-30 00:17:10 +01:00
\modules\DescartesSessionMessages\internals\DescartesSessionMessages :: push ( 'success' , 'Le réglage a bien été mis à jour.' );
2019-10-30 00:30:39 +01:00
2019-10-30 00:17:10 +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
}