mirror of
https://github.com/grocy/grocy.git
synced 2025-04-29 09:39:57 +00:00
166 lines
4.3 KiB
PHP
166 lines
4.3 KiB
PHP
<?php
|
|
|
|
namespace Grocy\Services;
|
|
|
|
use LessQL\Result;
|
|
|
|
class UsersService extends BaseService
|
|
{
|
|
public function CreateUser(string $username, ?string $firstName, ?string $lastName, string $password, string $pictureFileName = null)
|
|
{
|
|
$newUserRow = $this->getDatabase()->users()->createRow([
|
|
'username' => $username,
|
|
'first_name' => $firstName,
|
|
'last_name' => $lastName,
|
|
'password' => password_hash($password, PASSWORD_DEFAULT),
|
|
'picture_file_name' => $pictureFileName
|
|
]);
|
|
$newUserRow = $newUserRow->save();
|
|
$permList = [];
|
|
|
|
foreach ($this->getDatabase()->permission_hierarchy()->where('name', GROCY_DEFAULT_PERMISSIONS)->fetchAll() as $perm)
|
|
{
|
|
$permList[] = [
|
|
'user_id' => $newUserRow->id,
|
|
'permission_id' => $perm->id
|
|
];
|
|
}
|
|
|
|
$this->getDatabase()->user_permissions()->insert($permList);
|
|
|
|
return $newUserRow;
|
|
}
|
|
|
|
public function DeleteUser($userId)
|
|
{
|
|
$row = $this->getDatabase()->users($userId);
|
|
$row->delete();
|
|
}
|
|
|
|
public function EditUser(int $userId, string $username, string $firstName, string $lastName, ?string $password, string $pictureFileName = null)
|
|
{
|
|
if (!$this->UserExists($userId))
|
|
{
|
|
throw new \Exception('User does not exist');
|
|
}
|
|
|
|
$user = $this->getDatabase()->users($userId);
|
|
|
|
if ($password == null || empty($password))
|
|
{
|
|
$user->update([
|
|
'username' => $username,
|
|
'first_name' => $firstName,
|
|
'last_name' => $lastName,
|
|
'picture_file_name' => $pictureFileName
|
|
]);
|
|
}
|
|
else
|
|
{
|
|
$user->update([
|
|
'username' => $username,
|
|
'first_name' => $firstName,
|
|
'last_name' => $lastName,
|
|
'password' => password_hash($password, PASSWORD_DEFAULT),
|
|
'picture_file_name' => $pictureFileName
|
|
]);
|
|
}
|
|
}
|
|
|
|
private static $UserSettingsCache = [];
|
|
public function GetUserSetting($userId, $settingKey)
|
|
{
|
|
if (!array_key_exists($userId, self::$UserSettingsCache))
|
|
{
|
|
self::$UserSettingsCache[$userId] = [];
|
|
}
|
|
|
|
if (array_key_exists($settingKey, self::$UserSettingsCache[$userId]))
|
|
{
|
|
return self::$UserSettingsCache[$userId][$settingKey];
|
|
}
|
|
|
|
$value = null;
|
|
$settingRow = $this->getDatabase()->user_settings()->where('user_id = :1 AND key = :2', $userId, $settingKey)->fetch();
|
|
if ($settingRow !== null)
|
|
{
|
|
$value = $settingRow->value;
|
|
}
|
|
else
|
|
{
|
|
// Use the configured default values for a missing setting, otherwise return NULL
|
|
global $GROCY_DEFAULT_USER_SETTINGS;
|
|
if (array_key_exists($settingKey, $GROCY_DEFAULT_USER_SETTINGS))
|
|
{
|
|
$value = $GROCY_DEFAULT_USER_SETTINGS[$settingKey];
|
|
}
|
|
}
|
|
|
|
self::$UserSettingsCache[$userId][$settingKey] = $value;
|
|
return $value;
|
|
}
|
|
|
|
public function GetUserSettings($userId)
|
|
{
|
|
$settings = [];
|
|
$settingRows = $this->getDatabase()->user_settings()->where('user_id = :1', $userId)->fetchAll();
|
|
foreach ($settingRows as $settingRow)
|
|
{
|
|
$settings[$settingRow->key] = $settingRow->value;
|
|
}
|
|
|
|
// Use the configured default values for all missing settings
|
|
global $GROCY_DEFAULT_USER_SETTINGS;
|
|
return array_merge($GROCY_DEFAULT_USER_SETTINGS, $settings);
|
|
}
|
|
|
|
public function GetUsersAsDto(): Result
|
|
{
|
|
return $this->getDatabase()->users_dto();
|
|
}
|
|
|
|
public function SetUserSetting($userId, $settingKey, $settingValue)
|
|
{
|
|
if (!array_key_exists($userId, self::$UserSettingsCache))
|
|
{
|
|
self::$UserSettingsCache[$userId] = [];
|
|
}
|
|
self::$UserSettingsCache[$userId][$settingKey] = $settingValue;
|
|
|
|
$settingRow = $this->getDatabase()->user_settings()->where('user_id = :1 AND key = :2', $userId, $settingKey)->fetch();
|
|
if ($settingRow !== null)
|
|
{
|
|
$settingRow->update([
|
|
'value' => $settingValue,
|
|
'row_updated_timestamp' => date('Y-m-d H:i:s')
|
|
]);
|
|
}
|
|
else
|
|
{
|
|
$settingRow = $this->getDatabase()->user_settings()->createRow([
|
|
'user_id' => $userId,
|
|
'key' => $settingKey,
|
|
'value' => $settingValue
|
|
]);
|
|
$settingRow->save();
|
|
}
|
|
}
|
|
|
|
public function DeleteUserSetting($userId, $settingKey)
|
|
{
|
|
if (!array_key_exists($userId, self::$UserSettingsCache))
|
|
{
|
|
self::$UserSettingsCache[$userId] = [];
|
|
}
|
|
unset(self::$UserSettingsCache[$userId][$settingKey]);
|
|
|
|
$this->getDatabase()->user_settings()->where('user_id = :1 AND key = :2', $userId, $settingKey)->delete();
|
|
}
|
|
|
|
private function UserExists($userId)
|
|
{
|
|
$userRow = $this->getDatabase()->users()->where('id = :1', $userId)->fetch();
|
|
return $userRow !== null;
|
|
}
|
|
}
|