igfs/kernel/modules/user/service/UserService.php

121 lines
2.9 KiB
PHP
Raw Normal View History

2024-07-24 14:07:45 +03:00
<?php
2024-09-06 16:53:20 +03:00
namespace kernel\modules\user\service;
2024-07-24 14:07:45 +03:00
use kernel\FormModel;
2024-12-16 14:26:13 +03:00
use kernel\helpers\Debug;
2024-09-11 17:38:46 +03:00
use kernel\modules\user\models\User;
2024-07-24 14:07:45 +03:00
class UserService
{
2024-07-24 17:22:59 +03:00
public function create(FormModel $form_model): false|User
2024-07-24 14:07:45 +03:00
{
$model = new User();
$model->username = $form_model->getItem('username');
$model->email = $form_model->getItem('email');
$model->password_hash = password_hash($form_model->getItem('password'), PASSWORD_DEFAULT);
2025-01-19 20:50:25 +03:00
$model->user_photo = $form_model->getItem('user_photo');
2024-07-24 17:22:59 +03:00
if ($model->save()){
return $model;
}
return false;
2024-07-24 14:07:45 +03:00
}
2024-07-25 13:23:50 +03:00
public function update(FormModel $form_model, User $user): false|User
{
$user->username = $form_model->getItem('username');
$user->email = $form_model->getItem('email');
2024-12-16 14:26:13 +03:00
if ($form_model->getItem('password')) {
$user->password_hash = password_hash($form_model->getItem('password'), PASSWORD_DEFAULT);
}
2025-01-19 20:50:25 +03:00
$user->user_photo = $form_model->getItem('user_photo');
2024-07-25 13:23:50 +03:00
if ($user->save()){
return $user;
}
return false;
}
2024-10-23 16:16:47 +03:00
/**
* @param string $field
* @param string $value
* @return mixed
*/
2024-12-16 14:26:13 +03:00
public static function getByField(string $field, string $value): mixed
2024-09-24 17:22:09 +03:00
{
return User::where($field, $value)->first();
}
2024-07-26 16:09:06 +03:00
public static function createUsernameArr(): array
{
foreach (User::all()->toArray() as $user) {
2024-07-26 16:26:01 +03:00
$userArr[$user['id']] = $user['username'];
2024-07-26 16:09:06 +03:00
}
if (!empty($userArr)) {
return $userArr;
}
return [];
}
2024-09-24 17:22:09 +03:00
public static function getAuthUser()
{
if (isset($_COOKIE['user_id'])){
$user = User::where("id", $_COOKIE['user_id'])->first();
if ($user){
return $user;
}
}
return false;
}
public static function getAuthUsername(): string
{
$user = self::getAuthUser();
if ($user){
return $user->username;
}
return '';
}
2025-01-19 20:50:25 +03:00
public static function getAuthUserId(): string
{
$user = self::getAuthUser();
if ($user){
return $user->id;
}
return '';
}
public static function getAuthUserPhoto(): string|null
{
$user = self::getAuthUser();
if ($user){
if ($user->user_photo) {
return $user->user_photo;
}
}
return null;
}
2024-10-23 16:16:47 +03:00
public function getByAccessToken(string $token)
{
return $this->getByField("access_token", $token);
}
2024-12-16 14:26:13 +03:00
public static function createUserByEmailAndPassword(string $email, string $password): void
{
$user = new User();
$user->email = $email;
$user->username = $email;
$user->password_hash = password_hash($password, PASSWORD_DEFAULT);
$user->save();
}
2024-07-24 14:07:45 +03:00
}