Вход Регистрация
Файл: app/Http/Controllers/Admin/UserController.php
Строк: 212
<?php

declare(strict_types=1);

namespace 
AppHttpControllersAdmin;

use 
AppClassesValidator;
use 
AppModelsBanhist;
use 
AppModelsBlackList;
use 
AppModelsComment;
use 
AppModelsFile;
use 
AppModelsPost;
use 
AppModelsTopic;
use 
AppModelsUser;
use 
AppModelsUserField;
use 
IlluminateDatabaseQueryJoinClause;
use 
IlluminateHttpRedirectResponse;
use 
IlluminateHttpRequest;
use 
IlluminateViewView;

class 
UserController extends AdminController
{
    
/**
     * Главная страница
     */
    
public function index(): View
    
{
        
$users User::query()
            ->
orderByDesc('created_at')
            ->
paginate(setting('userlist'));

        return 
view('admin/users/index'compact('users'));
    }

    
/**
     * Поиск пользователей
     */
    
public function search(Request $request): View
    
{
        
$q check($request->input('q'));

        
$search $q === '1' "RLIKE '^[-0-9]'" "LIKE '$q%'";

        
$users User::query()
            ->
whereRaw('login ' $search)
            ->
orderByDesc('point')
            ->
paginate(setting('usersearch'))
            ->
appends(['q' => $q]);

        return 
view('admin/users/search'compact('users'));
    }

    
/**
     * Редактирование пользователя
     */
    
public function edit(Request $requestValidator $validator): View|RedirectResponse
    
{
        
$user getUserByLogin($request->input('user'));

        if (! 
$user) {
            
abort(404__('validator.user'));
        }

        
$allThemes array_map('basename'glob(public_path('themes/*'), GLOB_ONLYDIR));
        
$adminGroups User::ADMIN_GROUPS;

        
$allGroups = [];
        foreach (
User::ALL_GROUPS as $level) {
            
$allGroups[$level] = User::getLevelByKey($level);
        }

        
$fields UserField::query()
            ->
select('uf.*''ud.value')
            ->
from('user_fields as uf')
            ->
leftJoin('user_data as ud', static function (JoinClause $join) use ($user) {
                
$join->on('uf.id''ud.field_id')
                    ->
where('ud.user_id'$user->id);
            })
            ->
orderBy('uf.sort')
            ->
get();

        if (
$request->isMethod('post')) {
            
$level $request->input('level');
            
$password $request->input('password');
            
$email $request->input('email');
            
$name $request->input('name');
            
$country $request->input('country');
            
$city $request->input('city');
            
$phone preg_replace('/D/'''$request->input('phone') ?? '');
            
$site $request->input('site');
            
$birthday $request->input('birthday');
            
$point int($request->input('point'));
            
$money int($request->input('money'));
            
$status $request->input('status');
            
$posrating int($request->input('posrating'));
            
$negrating int($request->input('negrating'));
            
$themes $request->input('themes');
            
$gender $request->input('gender') === User::MALE User::MALE User::FEMALE;
            
$info $request->input('info');
            
$created $request->input('created');

            
$validator->equal($request->input('_token'), csrf_token(), __('validator.token'))
                ->
in($levelUser::ALL_GROUPS, ['level' => __('users.user_level_invalid')])
                ->
length($password620__('users.password_length_requirements'), false)
                ->
email($email, ['email' => __('validator.email')])
                ->
phone($phone, ['phone' => __('validator.phone')], false)
                ->
url($site, ['site' => __('validator.url')], false)
                ->
regex($birthday'#^[0-9]{2}+.[0-9]{2}+.[0-9]{4}$#', ['birthday' => __('validator.date')], false)
                ->
regex($created'#^[0-9]{2}+.[0-9]{2}+.[0-9]{4}$#', ['created' => __('validator.date')], false)
                ->
length($status325, ['status' => __('users.status_short_or_long')], false)
                ->
true(in_array($themes$allThemestrue) || empty($themes), ['themes' => __('users.theme_not_installed')])
                ->
length($info01000, ['info' => __('users.info_yourself_long')]);

            foreach (
$fields as $field) {
                
$validator->length(
                    
$request->input('field' $field->id),
                    
$field->min,
                    
$field->max,
                    [
'field' $field->id => __('validator.text')],
                    
false // Для админа поля не обязательны
                
);
            }

            if (
$validator->isValid()) {
                if (
$password) {
                    
$text __('users.user_new_password', ['password' => $password]);
                    
$password password_hash($passwordPASSWORD_BCRYPT);
                } else {
                    
$text null;
                    
$password $user->password;
                }

                
$name utfSubstr($name020);
                
$country utfSubstr($country030);
                
$city utfSubstr($city050);
                
$rating $posrating $negrating;

                
$user->update([
                    
'password'   => $password,
                    
'level'      => $level,
                    
'email'      => $email,
                    
'name'       => $name,
                    
'country'    => $country,
                    
'city'       => $city,
                    
'phone'      => $phone,
                    
'site'       => $site,
                    
'birthday'   => $birthday,
                    
'point'      => $point,
                    
'money'      => $money,
                    
'status'     => $status,
                    
'rating'     => $rating,
                    
'posrating'  => $posrating,
                    
'negrating'  => $negrating,
                    
'themes'     => $themes,
                    
'gender'     => $gender,
                    
'info'       => $info,
                    
'created_at' => strtotime($created),
                ]);

                foreach (
$fields as $field) {
                    
$user->data()
                        ->
updateOrCreate([
                            
'field_id' => $field->id,
                        ], [
                            
'value' => $request->input('field' $field->id),
                        ]);
                }

                
clearCache('status');
                
setFlash('success', [__('users.user_success_changed'), $text]);

                return 
redirect('admin/users/edit?user=' $user->login);
            }

            
setInput($request->all());
            
setFlash('danger'$validator->getErrors());
        }

        
$banhist Banhist::query()
            ->
where('user_id'$user->id)
            ->
whereIn('type', ['ban''change'])
            ->
orderByDesc('created_at')
            ->
first();

        return 
view('admin/users/edit'compact('user''banhist''allThemes''allGroups''adminGroups''fields'));
    }

    
/**
     * Удаление пользователя
     */
    
public function delete(Request $requestValidator $validator): View|RedirectResponse
    
{
        
$user getUserByLogin($request->input('user'));

        if (! 
$user) {
            
abort(404__('validator.user'));
        }

        if (
$request->isMethod('post')) {
            
$loginblack = empty($request->input('loginblack')) ? 1;
            
$mailblack = empty($request->input('mailblack')) ? 1;
            
$deltopics = empty($request->input('deltopics')) ? 1;
            
$delposts = empty($request->input('delposts')) ? 1;
            
$delcomments = empty($request->input('delcomments')) ? 1;
            
$delimages = empty($request->input('delimages')) ? 1;

            
$validator->equal($request->input('_token'), csrf_token(), __('validator.token'))
                ->
notIn($user->levelUser::ADMIN_GROUPS__('users.admins_remove_forbidden'));

            if (
$validator->isValid()) {
                if (
$loginblack) {
                    
$duplicate BlackList::query()->where('type''login')->where('value'$user->login)->first();
                    if (! 
$duplicate) {
                        
BlackList::query()->create([
                            
'type'       => 'login',
                            
'value'      => $user->login,
                            
'user_id'    => getUser('id'),
                            
'created_at' => SITETIME,
                        ]);
                    }
                }

                if (
$mailblack) {
                    
$duplicate BlackList::query()->where('type''email')->where('value'$user->email)->first();
                    if (! 
$duplicate) {
                        
BlackList::query()->create([
                            
'type'       => 'email',
                            
'value'      => $user->email,
                            
'user_id'    => getUser('id'),
                            
'created_at' => SITETIME,
                        ]);
                    }
                }

                
// Удаление тем форума
                
if ($deltopics) {
                    
$topics Topic::query()->where('user_id'$user->id)->pluck('id')->all();
                    
$posts Post::query()->whereIn('topic_id'$topics)->pluck('id')->all();

                    
// Удаление загруженных файлов
                    
if ($posts) {
                        
$files File::query()
                            ->
where('relate_type'Post::$morphName)
                            ->
whereIn('relate_id'$posts)
                            ->
get();

                        if (
$files->isNotEmpty()) {
                            foreach (
$files as $file) {
                                
$file->delete();
                            }
                        }
                    }

                    
Post::query()->whereIn('topic_id'$topics)->delete();
                    
Topic::query()->where('user_id'$user->id)->delete();
                    
restatement('forums');
                }

                
// Удаление постов форума
                
if ($delposts) {
                    
$posts Post::query()->where('user_id'$user->id)->pluck('id')->all();

                    
// Удаление загруженных файлов
                    
if ($posts) {
                        
$files File::query()
                            ->
where('relate_type'Post::$morphName)
                            ->
whereIn('relate_id'$posts)
                            ->
get();

                        if (
$files->isNotEmpty()) {
                            foreach (
$files as $file) {
                                
$file->delete();
                            }
                        }
                    }

                    
Post::query()->where('user_id'$user->id)->delete();
                    
restatement('forums');
                }

                
// Удаление комментариев
                
if ($delcomments) {
                    
$deletes Comment::query()
                        ->
where('user_id'$user->id)
                        ->
delete();

                    if (
$deletes) {
                        
restatement('blogs');
                        
restatement('loads');
                        
restatement('news');
                        
restatement('photos');
                        
restatement('offers');
                    }
                }

                
// Удаление фотографий в галерее
                
if ($delimages) {
                    
$user->deleteAlbum();
                }

                
$user->delete();

                
setFlash('success'__('users.user_success_deleted'));

                return 
redirect('admin/users');
            }

            
setInput($request->all());
            
setFlash('danger'$validator->getErrors());
        }

        return 
view('admin/users/delete'compact('user'));
    }
}
Онлайн: 6
Реклама