File size: 2.36Kb
<?php
namespace App\Controllers\User;
use App\Classes\Request;
use App\Classes\Validator;
use App\Controllers\BaseController;
use App\Models\Banhist;
use App\Models\User;
class BanController extends BaseController
{
/*
* Бан пользователя
*/
function ban()
{
if (! $user = getUser()) {
abort(403, 'Вы не авторизованы!');
}
if ($user->level != User::BANNED) {
abort('default', 'Вы не забанены или срок бана истек!');
}
if ($user->timeban <= SITETIME) {
$user->update([
'level' => User::USER,
'timeban' => 0,
]);
setFlash('success', 'Поздравляем! Время вашего бана истекло!');
redirect('/');
}
$banhist = Banhist::query()
->where('user_id', $user->id)
->whereIn('type', ['ban', 'change'])
->orderBy('created_at', 'desc')
->first();
if ($banhist && Request::isMethod('post')) {
$msg = check(Request::input('msg'));
$sendUser = getUserById($banhist->send_user_id);
$validator = new Validator();
$validator
->true(setting('addbansend'), 'Писать объяснительные запрещено администрацией!')
->true($banhist->explain, 'Ошибка! Вы уже писали объяснение!')
->true($sendUser->id, 'Пользователь который вас забанил не найден!')
->length($msg, 5, 1000, ['text' => 'Слишком длинное или короткое объяснение!']);
if ($validator->isValid()) {
$message = 'Объяснение нарушения: '.antimat($msg);
sendMessage($sendUser, $user, $message);
$banhist->update([
'explain' => 0
]);
setFlash('success', 'Объяснение успешно отправлено!');
redirect('/ban');
} else {
setInput(Request::all());
setFlash('danger', $validator->getErrors());
}
}
return view('users/bans', compact('user', 'banhist'));
}
}