<?php
declare(strict_types=1);
namespace App\Controllers;
use App\Classes\Validator;
use App\Models\Advert;
use Illuminate\Http\Request;
class AdvertController extends BaseController
{
/**
* Конструктор
*/
public function __construct()
{
parent::__construct();
if (! setting('rekusershow')) {
abort('default', __('adverts.advert_closed'));
}
}
/**
* Главная страница
*
* @return string
*/
public function index(): string
{
$adverts = Advert::query()
->where('deleted_at', '>', SITETIME)
->orderByDesc('deleted_at')
->with('user')
->paginate(setting('rekuserpost'));
return view('adverts/index', compact('adverts'));
}
/**
* Покупка рекламы
*
* @param Request $request
* @param Validator $validator
*
* @return string
*/
public function create(Request $request, Validator $validator): string
{
if (! $user = getUser()) {
abort(403, __('main.not_authorized'));
}
if ($user->point < setting('rekuserpoint')) {
abort('default', __('adverts.advert_point', ['point' => plural(50, setting('scorename'))]));
}
$total = Advert::query()->where('deleted_at', '>', SITETIME)->count();
if ($total >= setting('rekusertotal')) {
abort('default', __('adverts.advert_not_seats'));
}
$advert = Advert::query()
->where('user_id', $user->id)
->where('deleted_at', '>', SITETIME)
->first();
if ($advert) {
abort('default', __('adverts.advert_already_posted'));
}
if ($request->isMethod('post')) {
$site = $request->input('site');
$name = $request->input('name');
$color = $request->input('color');
$bold = empty($request->input('bold')) ? 0 : 1;
$price = setting('rekuserprice');
if ($color) {
$price += setting('rekuseroptprice');
}
if ($bold) {
$price += setting('rekuseroptprice');
}
$validator->equal($request->input('token'), $_SESSION['token'], __('validator.token'))
->gte($user->point, setting('rekuserpoint'), __('adverts.advert_point', ['point' => plural(50, setting('scorename'))]))
->true(captchaVerify(), ['protect' => __('validator.captcha')])
->regex($site, '|^https?://([а-яa-z0-9_\-\.])+(\.([а-яa-z0-9\/\-?_=#])+)+$|iu', ['site' => __('validator.url')])
->length($site, 5, 100, ['site' => __('validator.url_text')])
->length($name, 5, 35, ['name' => __('validator.text')])
->regex($color, '|^#+[A-f0-9]{6}$|', ['color' => __('validator.color')], false)
->gte($user->money, $price, __('adverts.advert_not_money'));
if ($validator->isValid()) {
Advert::query()->where('deleted_at', '<', SITETIME)->delete();
Advert::query()->create([
'site' => $site,
'name' => $name,
'color' => $color,
'bold' => $bold,
'user_id' => $user->id,
'created_at' => SITETIME,
'deleted_at' => strtotime('+' . setting('rekusertime') . ' hours', SITETIME),
]);
$user->decrement('money', $price);
clearCache('adverts');
setFlash('success', __('adverts.advert_success_posted'));
redirect('/adverts');
} else {
setInput($request->all());
setFlash('danger', $validator->getErrors());
}
}
return view('adverts/create');
}
}