bunch of cleanup, split cancel out

This commit is contained in:
spencerrlongg 2024-10-22 20:48:27 -05:00
parent 8a99cc1391
commit 48c812d345
5 changed files with 62 additions and 45 deletions

View file

@ -0,0 +1,43 @@
<?php
namespace App\Actions\CheckoutRequests;
use App\Models\Actionlog;
use App\Models\Asset;
use App\Models\Setting;
use App\Models\User;
use App\Notifications\RequestAssetCancelation;
class CancelCheckoutRequest
{
public static function run(Asset $asset, User $user)
{
$asset->cancelRequest();
$asset->decrement('requests_counter', 1);
$data['item'] = $asset;
$data['target'] = $user;
$data['item_quantity'] = 1;
$settings = Setting::getSettings();
$logaction = Actionlog::create([
'item_id' => $data['asset_id'] = $asset->id,
'item_type' => $data['item_type'] = Asset::class,
'created_at' => $data['requested_date'] = date('Y-m-d H:i:s'),
'target_id' => $data['user_id'] = auth()->id(),
'target_type' => User::class,
'location_id' => $user->location_id ?? null,
]);
$logaction->logaction('request canceled');
try {
$settings->notify(new RequestAssetCancelation($data));
} catch (\Exception $e) {
\Log::warning($e);
}
return true;
}
}

View file

@ -21,7 +21,6 @@ class CreateCheckoutRequest
*/
public static function run(Asset $asset, User $user): string
{
//throw new \Exception();
if (is_null(Asset::RequestableAssets()->find($asset->id))) {
throw new AssetNotRequestable($asset);
}
@ -34,33 +33,16 @@ class CreateCheckoutRequest
$data['item_quantity'] = 1;
$settings = Setting::getSettings();
$logaction = new Actionlog();
$logaction->item_id = $data['asset_id'] = $asset->id;
$logaction->item_type = $data['item_type'] = Asset::class;
$logaction->created_at = $data['requested_date'] = date('Y-m-d H:i:s');
if ($user->location_id) {
$logaction->location_id = $user->location_id;
}
$logaction->target_id = $data['user_id'] = auth()->id();
$logaction->target_type = User::class;
// If it's already requested, cancel the request.
// this is going into another action class
if ($asset->isRequestedBy(auth()->user())) {
$asset->cancelRequest();
$asset->decrement('requests_counter', 1);
$logaction->logaction('request canceled');
try {
$settings->notify(new RequestAssetCancelation($data));
} catch (\Exception $e) {
\Log::warning($e);
}
return $status = 'cancelled';
}
$logaction = Actionlog::create([
'target_id' => $data['asset_id'] = $asset->id,
'item_type' => $data['item_type'] = Asset::class,
'created_at' => $data['requested_date'] = date('Y-m-d H:i:s'),
'user_id' => $data['user_id'] = auth()->id(),
'target_type' => User::class,
'location_id' => $user->location_id ?? null,
]);
$logaction->logaction('requested');
$asset->request();
$asset->increment('requests_counter', 1);
try {

View file

@ -352,8 +352,7 @@ class AssetFactory extends Factory
'deployable' => true,
'pending' => true,
])->id;
//return $this->state(['requestable' => true]);
return $this->state(['status_id' => $id]);
return $this->state(['status_id' => $id, 'requestable' => true]);
}
public function nonrequestable()
@ -363,8 +362,7 @@ class AssetFactory extends Factory
'deployable' => false,
'pending' => false,
])->id;
//return $this->state(['requestable' => false]);
return $this->state(['status_id' => $id]);
return $this->state(['status_id' => $id, 'requestable' => false]);
}
public function noPurchaseOrEolDate()

View file

@ -294,24 +294,18 @@ Route::group(['prefix' => 'account', 'middleware' => ['auth']], function () {
Route::get('api', [ProfileController::class, 'api'])->name('user.api');
// View Assets
Route::get('view-assets', [ViewAssetsController::class, 'getIndex'])->name('view-assets');
Route::get('view-assets', [ViewAssetsController::class, 'index'])->name('view-assets');
Route::get('requested', [ViewAssetsController::class, 'getRequestedAssets'])->name('account.requested');
// Profile
Route::get(
'requestable-assets',
[ViewAssetsController::class, 'getRequestableIndex']
)->name('requestable-assets');
Route::post(
'request-asset/{asset}',
[ViewAssetsController::class, 'store']
)->name('account/request-asset');
Route::get('requestable-assets', [ViewAssetsController::class, 'getRequestableIndex'])->name('requestable-assets');
Route::post(
'request/{itemType}/{itemId}/{cancel_by_admin?}/{requestingUser?}',
[ViewAssetsController::class, 'getRequestItem']
)->name('account/request-item');
Route::post('request-asset/{asset}', [ViewAssetsController::class, 'store'])
->name('account/request-asset');
Route::post('request/{itemType}/{itemId}/{cancel_by_admin?}/{requestingUser?}', [ViewAssetsController::class, 'getRequestItem'])
->name('account/request-item');
// Account Dashboard
Route::get('/', [ViewAssetsController::class, 'getIndex'])->name('account');