Remove CleanDeclinedAccessoryCheckouts command
This commit is contained in:
@@ -1,65 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Console\Commands;
|
||||
|
||||
use App\Models\Accessory;
|
||||
use App\Models\AccessoryCheckout;
|
||||
use App\Models\CheckoutAcceptance;
|
||||
use App\Models\User;
|
||||
use Illuminate\Console\Command;
|
||||
|
||||
class CleanDeclinedAccessoryCheckouts extends Command
|
||||
{
|
||||
/**
|
||||
* The name and signature of the console command.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $signature = 'snipeit:clean-declined-accessory-checkouts';
|
||||
|
||||
/**
|
||||
* The console command description.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $description = 'Command description';
|
||||
// @todo
|
||||
|
||||
/**
|
||||
* Execute the console command.
|
||||
*/
|
||||
public function handle()
|
||||
{
|
||||
$accessoryCheckouts = AccessoryCheckout::where('assigned_type', User::class)->get();
|
||||
|
||||
$declinedCheckoutAcceptances = CheckoutAcceptance::query()
|
||||
->where([
|
||||
'checkoutable_type' => Accessory::class,
|
||||
])
|
||||
// if it was declined and the qty is null that means it potentially left
|
||||
// some entries in the `accessories_checkout` table behind.
|
||||
->whereNull('qty')
|
||||
->declined()
|
||||
->get();
|
||||
|
||||
$declinedCheckoutAcceptances->map(function (CheckoutAcceptance $acceptance) use ($accessoryCheckouts) {
|
||||
$matchedCheckouts = $accessoryCheckouts->filter(function ($checkout) use ($acceptance) {
|
||||
return $checkout->accessory_id == $acceptance->checkoutable_id
|
||||
&& $checkout->assigned_to == $acceptance->assigned_to_id
|
||||
&& $checkout->created_at == $acceptance->created_at;
|
||||
});
|
||||
|
||||
$acceptance->setRelation('accessoryCheckouts', $matchedCheckouts);
|
||||
|
||||
return $acceptance;
|
||||
});
|
||||
|
||||
$checkoutsToDelete = $declinedCheckoutAcceptances->pluck('accessoryCheckouts')->flatten();
|
||||
|
||||
if ($this->confirm("Delete {$checkoutsToDelete->count()} entries from the accessory_checkout table?")) {
|
||||
$checkoutsToDelete->each(fn($checkout) => $checkout->delete());
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user