File: /var/www/vhost/disk-apps/teamdemo.sports-crowd.com/app/Console/Commands/BlockSeats.php
<?php
namespace App\Console\Commands;
use App\Core\Ticket\TicketTypesEnum;
use Carbon\Carbon;
use App\Parameter;
use App\PreSubscriber;
use App\TicketUserBlock;
use App\TicketUserBlockBackup;
use Illuminate\Console\Command;
class BlockSeats extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'sportscrowd:blockSeats';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Command description';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return int
*/
public function handle()
{
$blocks = TicketUserBlock::where('end_block', '<=', Carbon::now())->whereNotNull('end_block')->get();
$parameters = Parameter::select('presuscription', 'web_presuscription')->first();
if ($parameters->presuscription || $parameters->web_presuscription) {
$seats = $blocks->where('ticket_type_id', TicketTypesEnum::SUBSCRIBER)->pluck('seat_id');
if (count($seats) > 0) {
PreSubscriber::where('payment', true)->whereIn('seat_id', $seats)->update(['payment' => false]);
}
}
foreach ($blocks as $ticket) {
$data = $ticket->toArray();
unset($data['id']);
TicketUserBlockBackup::create($data);
$ticket->delete();
}
}
}