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

declare(strict_types=1);

namespace 
AppHttpControllers;

use 
AppClassesValidator;
use 
AppModelsComment;
use 
AppModelsFlood;
use 
AppModelsOffer;
use 
IlluminateDatabaseQueryJoinClause;
use 
IlluminateHttpRedirectResponse;
use 
IlluminateHttpRequest;
use 
IlluminateViewView;

class 
OfferController extends Controller
{
    
/**
     * Главная страница
     */
    
public function index(Request $requeststring $type 'offer'): View
    
{
        
$offerCount Offer::query()->where('type'Offer::OFFER)->count();
        
$issueCount Offer::query()->where('type'Offer::ISSUE)->count();

        
$sort check($request->input('sort''rating'));
        
$order match ($sort) {
            
'time'     => 'created_at',
            
'status'   => 'status',
            
'comments' => 'count_comments',
            default    => 
'rating',
        };

        
$offers Offer::query()
            ->
where('type'$type)
            ->
orderByDesc($order)
            ->
with('user')
            ->
paginate(setting('postoffers'))
            ->
appends(compact('type''sort'));

        return 
view('offers/index'compact('offers''order''type''sort''offerCount''issueCount'));
    }

    
/**
     * Просмотр записи
     */
    
public function view(int $id): View
    
{
        
$offer Offer::query()
            ->
select('offers.*''pollings.vote')
            ->
where('offers.id'$id)
            ->
leftJoin('pollings', static function (JoinClause $join) {
                
$join->on('offers.id''pollings.relate_id')
                    ->
where('pollings.relate_type'Offer::$morphName)
                    ->
where('pollings.user_id'getUser('id'));
            })
            ->
first();

        if (! 
$offer) {
            
abort(404__('main.record_not_found'));
        }

        return 
view('offers/view'compact('offer'));
    }

    
/**
     * Создание записи
     *
     *
     * @return View|RedirectResponse
     */
    
public function create(Request $requestValidator $validatorFlood $flood)
    {
        if (! 
$user getUser()) {
            
abort(403__('main.not_authorized'));
        }

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

        if (
$request->isMethod('post')) {
            
$title $request->input('title');
            
$text $request->input('text');

            
$validator->equal($request->input('_token'), csrf_token(), __('validator.token'))
                ->
length($title350, ['title' => __('validator.text')])
                ->
length($text51000, ['text' => __('validator.text')])
                ->
false($flood->isFlood(), ['msg' => __('validator.flood', ['sec' => $flood->getPeriod()])])
                ->
in($typeOffer::TYPES, ['type' => __('offers.type_invalid')])
                ->
gte(getUser('point'), setting('addofferspoint'), __('offers.condition_add', ['point' => plural(setting('addofferspoint'), setting('scorename'))]));

            if (
$validator->isValid()) {
                
$title antimat($title);
                
$text antimat($text);

                
/** @var Offer $offer */
                
$offer Offer::query()->create([
                    
'type'       => $type,
                    
'title'      => $title,
                    
'text'       => $text,
                    
'user_id'    => $user->id,
                    
'rating'     => 1,
                    
'status'     => 'wait',
                    
'created_at' => SITETIME,
                ]);

                
$flood->saveState();

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

                return 
redirect('offers/' $offer->id);
            }

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

        return 
view('offers/create'compact('type'));
    }

    
/**
     * Редактирование записи
     *
     *
     * @return View|RedirectResponse
     */
    
public function edit(int $idRequest $requestValidator $validator)
    {
        if (! 
$user getUser()) {
            
abort(403__('main.not_authorized'));
        }

        
$offer Offer::query()
            ->
where('id'$id)
            ->
where('user_id'$user->id)
            ->
first();

        if (! 
$offer) {
            
abort(404__('main.record_not_found'));
        }

        if (! 
in_array($offer->status, ['wait''process'])) {
            
abort(200__('offers.already_resolved'));
        }

        if (
$request->isMethod('post')) {
            
$title $request->input('title');
            
$text $request->input('text');
            
$type $request->input('type');

            
$validator->equal($request->input('_token'), csrf_token(), __('validator.token'))
                ->
length($title350, ['title' => __('validator.text')])
                ->
length($text51000, ['text' => __('validator.text')])
                ->
in($typeOffer::TYPES, ['type' => __('offers.type_invalid')]);

            if (
$validator->isValid()) {
                
$title antimat($title);
                
$text antimat($text);

                
$offer->update([
                    
'type'       => $type,
                    
'title'      => $title,
                    
'text'       => $text,
                    
'updated_at' => SITETIME,
                ]);

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

                return 
redirect('offers/' $offer->id);
            }

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

        return 
view('offers/edit'compact('offer'));
    }

    
/**
     * Комментарии
     *
     *
     * @return View|RedirectResponse
     */
    
public function comments(int $idRequest $requestValidator $validatorFlood $flood)
    {
        
/** @var Offer $offer */
        
$offer Offer::query()->find($id);

        if (! 
$offer) {
            
abort(404__('main.record_not_found'));
        }

        if (
$request->isMethod('post')) {
            
$msg $request->input('msg');

            
$validator
                
->true(getUser(), __('main.not_authorized'))
                ->
equal($request->input('_token'), csrf_token(), __('validator.token'))
                ->
length($msg5setting('comment_length'), ['msg' => __('validator.text')])
                ->
false($flood->isFlood(), ['msg' => __('validator.flood', ['sec' => $flood->getPeriod()])])
                ->
empty($offer->closed, ['msg' => __('offers.offer_closed')]);

            if (
$validator->isValid()) {
                
$msg antimat($msg);

                
/** @var Comment $comment */
                
$comment $offer->comments()->create([
                    
'text'       => $msg,
                    
'user_id'    => getUser('id'),
                    
'created_at' => SITETIME,
                    
'ip'         => getIp(),
                    
'brow'       => getBrowser(),
                ]);

                
$user getUser();
                
$user->increment('allcomments');
                
$user->increment('point');
                
$user->increment('money'5);

                
$offer->increment('count_comments');

                
$flood->saveState();
                
sendNotify($msg'/offers/comment/' $offer->id '/' $comment->id$offer->title);

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

                return 
redirect('offers/end/' $offer->id);
            }

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

        
$comments $offer->comments()
            ->
orderBy('created_at')
            ->
paginate(setting('comments_per_page'));

        return 
view('offers/comments'compact('offer''comments'));
    }

    
/**
     * Подготовка к редактированию комментария
     *
     *
     * @return View|RedirectResponse
     */
    
public function editComment(int $idint $cidRequest $requestValidator $validator)
    {
        
$page int($request->input('page'1));

        
/** @var Offer $offer */
        
$offer Offer::query()->find($id);

        if (! 
$offer) {
            
abort(404__('main.record_not_found'));
        }

        if (! 
getUser()) {
            
abort(403__('main.not_authorized'));
        }

        
$comment $offer->comments()
            ->
where('id'$cid)
            ->
where('user_id'getUser('id'))
            ->
first();

        if (! 
$comment) {
            
abort(200__('main.comment_deleted'));
        }

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

        if (
$request->isMethod('post')) {
            
$msg $request->input('msg');
            
$page int($request->input('page'1));

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

            if (
$validator->isValid()) {
                
$msg antimat($msg);

                
$comment->update([
                    
'text' => $msg,
                ]);

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

                return 
redirect('offers/comments/' $offer->id '?page=' $page);
            }

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

        return 
view('offers/editcomment'compact('offer''comment''page'));
    }

    
/**
     * Переадресация на последнюю страницу
     */
    
public function end(int $id): RedirectResponse
    
{
        
/** @var Offer $offer */
        
$offer Offer::query()->find($id);

        if (! 
$offer) {
            
abort(404__('main.record_not_found'));
        }

        
$total $offer->comments()->count();

        
$end ceil($total setting('comments_per_page'));

        return 
redirect('offers/comments/' $offer->id '?page=' $end);
    }

    
/**
     * Переход к сообщению
     */
    
public function viewComment(int $idint $cid): RedirectResponse
    
{
        
/** @var Offer $offer */
        
$offer Offer::query()->find($id);

        if (! 
$offer) {
            
abort(404__('main.record_not_found'));
        }

        
$total $offer->comments()
            ->
where('id''<='$cid)
            ->
orderBy('created_at')
            ->
count();

        
$end ceil($total setting('comments_per_page'));

        return 
redirect('offers/comments/' $offer->id '?page=' $end '#comment_' $cid);
    }
}
Онлайн: 1
Реклама