2019-10-29 14:57:13 +01:00
|
|
|
<?php
|
2019-10-30 00:30:39 +01:00
|
|
|
|
|
|
|
/*
|
2019-11-10 17:48:54 +01:00
|
|
|
* This file is part of RaspiSMS.
|
2019-10-30 00:30:39 +01:00
|
|
|
*
|
2019-11-10 17:48:54 +01:00
|
|
|
* (c) Pierre-Lin Bonnemaison <plebwebsas@gmail.com>
|
2019-10-30 00:30:39 +01:00
|
|
|
*
|
2019-11-10 17:48:54 +01:00
|
|
|
* This source file is subject to the GPL-3.0 license that is bundled
|
2019-10-30 00:30:39 +01:00
|
|
|
* with this source code in the file LICENSE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace controllers\internals;
|
2019-10-29 14:57:13 +01:00
|
|
|
|
2019-11-14 02:02:50 +01:00
|
|
|
class Setting extends StandardController
|
2019-10-29 14:57:13 +01:00
|
|
|
{
|
2020-01-17 18:19:25 +01:00
|
|
|
protected $model;
|
2019-10-29 14:57:13 +01:00
|
|
|
|
2019-10-29 18:36:25 +01:00
|
|
|
/**
|
2019-11-11 04:05:26 +01:00
|
|
|
* Return all settings of a user.
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2019-11-11 04:05:26 +01:00
|
|
|
* @param int $id_user : user id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2019-11-11 04:05:26 +01:00
|
|
|
* @return array
|
2019-10-29 18:36:25 +01:00
|
|
|
*/
|
2020-01-17 18:19:25 +01:00
|
|
|
public function gets_for_user(int $id_user)
|
2019-10-29 18:36:25 +01:00
|
|
|
{
|
2019-11-14 02:02:50 +01:00
|
|
|
$settings = $this->get_model()->gets_for_user($id_user);
|
2019-11-11 04:05:26 +01:00
|
|
|
$settings_array = [];
|
|
|
|
|
|
|
|
foreach ($settings as $setting)
|
|
|
|
{
|
|
|
|
$settings_array[$setting['name']] = $setting['value'];
|
|
|
|
}
|
|
|
|
|
|
|
|
return $settings_array;
|
2019-10-29 18:36:25 +01:00
|
|
|
}
|
2019-10-29 14:57:13 +01:00
|
|
|
|
2023-09-17 16:12:31 +02:00
|
|
|
/**
|
|
|
|
* Get a user setting by his name for a user.
|
|
|
|
*
|
|
|
|
* @param int $id_user : user id
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function get_by_name_for_user(int $id_user, string $name)
|
|
|
|
{
|
|
|
|
return $this->get_model()->get_by_name_for_user($id_user, $name);
|
|
|
|
}
|
|
|
|
|
2019-10-29 18:36:25 +01:00
|
|
|
/**
|
2019-11-11 04:05:26 +01:00
|
|
|
* Update a setting by his name and user id.
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
|
|
|
* @param int $id_user : user id
|
|
|
|
* @param string $name : setting name
|
|
|
|
* @param mixed $value
|
|
|
|
*
|
2019-11-11 04:05:26 +01:00
|
|
|
* @return int : number of modified lines
|
|
|
|
*/
|
2020-01-17 18:19:25 +01:00
|
|
|
public function update_for_user(int $id_user, string $name, $value): bool
|
2019-11-11 04:05:26 +01:00
|
|
|
{
|
2019-11-14 23:09:56 +01:00
|
|
|
return (bool) $this->get_model()->update_by_name_for_user($id_user, $name, $value);
|
2019-11-11 04:05:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2020-01-17 18:19:25 +01:00
|
|
|
* Create a new setting.
|
|
|
|
*
|
|
|
|
* @param int $id_user : user id
|
|
|
|
* @param string $name : setting name
|
|
|
|
* @param mixed $value : value of the setting
|
2019-10-29 18:36:25 +01:00
|
|
|
*/
|
2020-01-17 18:19:25 +01:00
|
|
|
public function create(int $id_user, string $name, $value): bool
|
2019-10-29 14:57:13 +01:00
|
|
|
{
|
2019-11-11 04:05:26 +01:00
|
|
|
$setting = [
|
|
|
|
'id_user' => $id_user,
|
|
|
|
'name' => $name,
|
|
|
|
'value' => $value,
|
|
|
|
];
|
|
|
|
|
2019-11-14 02:02:50 +01:00
|
|
|
return (bool) $this->get_model()->insert($setting);
|
2019-10-29 14:57:13 +01:00
|
|
|
}
|
2020-01-06 23:33:27 +01:00
|
|
|
|
|
|
|
/**
|
2020-01-17 18:19:25 +01:00
|
|
|
* Generate and insert default settings for a user.
|
|
|
|
*
|
2020-01-06 23:33:27 +01:00
|
|
|
* @param int $id_user : user id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2020-01-06 23:33:27 +01:00
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function create_defaults_for_user(int $id_user)
|
|
|
|
{
|
|
|
|
$all_success = true;
|
|
|
|
foreach (USER_DEFAULT_SETTINGS as $name => $value)
|
|
|
|
{
|
2024-10-22 22:28:24 +02:00
|
|
|
// Ignore if already existing settings
|
|
|
|
if (count($this->get_by_name_for_user($id_user, $name)))
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2020-01-06 23:33:27 +01:00
|
|
|
$success = $this->create($id_user, $name, $value);
|
|
|
|
$all_success = ($all_success && $success);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $all_success;
|
|
|
|
}
|
2020-01-17 18:19:25 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the model for the Controller.
|
|
|
|
*/
|
2021-07-19 17:32:23 +02:00
|
|
|
protected function get_model(): \models\Setting
|
2020-01-17 18:19:25 +01:00
|
|
|
{
|
|
|
|
$this->model = $this->model ?? new \models\Setting($this->bdd);
|
|
|
|
|
|
|
|
return $this->model;
|
|
|
|
}
|
2019-10-29 18:36:25 +01:00
|
|
|
}
|