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

declare(strict_types=1);

namespace 
AppHttpControllers;

use 
AppClassesValidator;
use 
AppModelsFlood;
use 
AppModelsGuestbook;
use 
IlluminateHttpRedirectResponse;
use 
IlluminateHttpRequest;
use 
IlluminateViewView;

class 
GuestbookController extends Controller
{
    
/**
     * Главная страница
     */
    
public function index(): View
    
{
        
$posts Guestbook::query()
            ->
where('active'true)
            ->
orderByDesc('created_at')
            ->
with('user''editUser')
            ->
paginate(10);

        
$unpublished Guestbook::query()->where('active'false)->count();

        return 
view('guestbook/index'compact('posts''unpublished'));
    }

    
/**
     * Добавление сообщения
     */
    
public function add(Request $requestValidator $validatorFlood $flood): RedirectResponse
    
{
        
$msg $request->input('msg');
        
$user getUser();

        
$validator->equal($request->input('_token'), csrf_token(), ['msg' => __('validator.token')])
            ->
length($msg5setting('guesttextlength'), ['msg' => __('validator.text')])
            ->
false($flood->isFlood(), ['msg' => __('validator.flood', ['sec' => $flood->getPeriod()])]);

        
/* Проверка для гостей */
        
if (! $user && setting('bookadds')) {
            
$validator->true(captchaVerify(), ['protect' => __('validator.captcha')]);
            
$validator->true(! str_contains($msg ?? '''//'), ['msg' => __('guestbook.without_links')]);
            
$validator->length($request->input('guest_name'), 320, ['guest_name' => __('users.name_short_or_long')], false);
        } else {
            
$validator->true($user, ['msg' => __('main.not_authorized')]);
        }

        if (
$validator->isValid()) {
            
$msg antimat($msg);
            
$active = ! setting('guest_moderation');
            
$guestName $request->input('guest_name');

            if (
$user) {
                
$active true;
                
$guestName null;
                
$bookscores setting('bookscores') ? 0;

                
$user->increment('allguest');
                
$user->increment('point'$bookscores);
                
$user->increment('money'5);
            }

            
Guestbook::query()->create([
                
'user_id'    => $user->id ?? null,
                
'text'       => $msg,
                
'ip'         => getIp(),
                
'brow'       => getBrowser(),
                
'guest_name' => $guestName,
                
'active'     => $active,
                
'created_at' => SITETIME,
            ]);

            
clearCache('statGuestbook');
            
$flood->saveState();

            
sendNotify($msg'/guestbook'__('index.guestbook'));
            
setFlash('success'$active __('main.message_added_success') : __('main.message_publish_moderation'));
        } else {
            
setInput($request->all());
            
setFlash('danger'$validator->getErrors());
        }

        return 
redirect('/guestbook');
    }

    
/**
     * Редактирование сообщения
     *
     *
     * @return View|RedirectResponse
     */
    
public function edit(int $idRequest $requestValidator $validator)
    {
        if (! 
$user getUser()) {
            
abort(403);
        }

        
$msg $request->input('msg');

        
/** @var Guestbook $post */
        
$post Guestbook::query()->where('user_id'$user->id)->find($id);

        if (! 
$post) {
            
abort(404__('main.message_not_found'));
        }

        if (
$post->created_at 600 SITETIME) {
            
abort(200__('main.editing_impossible'));
        }

        if (
$request->isMethod('post')) {
            
$validator->equal($request->input('_token'), csrf_token(), ['msg' => __('validator.token')])
                ->
length($msg5setting('guesttextlength'), ['msg' => __('validator.text')]);

            if (
$validator->isValid()) {
                
$post->update([
                    
'text'         => antimat($msg),
                    
'edit_user_id' => $user->id,
                    
'updated_at'   => SITETIME,
                ]);

                
setFlash('success'__('main.message_edited_success'));

                return 
redirect('guestbook');
            }

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

        return 
view('guestbook/edit'compact('post'));
    }
}
Онлайн: 3
Реклама