30 lines
1.0 KiB
PHP
30 lines
1.0 KiB
PHP
<?php
|
|
|
|
namespace Krzysiej\RyobiCrawler\Controller;
|
|
|
|
use Krzysiej\RyobiCrawler\Models\Product;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
use Symfony\Component\Routing\Attribute\Route;
|
|
use function Symfony\Component\Clock\now;
|
|
|
|
final class LowestPriceController extends BaseController
|
|
{
|
|
#[Route('/lowest-price', name: 'app_lowest_price', methods: ['GET'])]
|
|
public function __invoke(): Response
|
|
{
|
|
$listType = 'lowest_price';
|
|
if($this->cache->getItem('lowest_price')->isHit()) {
|
|
return $this->render('productList.html.twig', ['listType' => $listType]);
|
|
}
|
|
|
|
$products = Product::whereRaw('priceCurrent = priceLowest')
|
|
->whereRaw('lastSeen = "'.now()->format('Y-m-d').'"')
|
|
->whereRaw('priceCurrent < productStandardPrice')
|
|
->orderByDesc('starred')
|
|
->orderByDesc('created_by')
|
|
->with(['currentPrice', 'lowestPrice'])
|
|
->get();
|
|
return $this->render('productList.html.twig', ['products' => $products, 'listType' => $listType]);
|
|
}
|
|
}
|