snipe-it/app/Actions/CheckoutRequests/CreateCheckoutRequest.php

81 lines
2.3 KiB
PHP
Raw Normal View History

2024-10-16 15:23:22 -07:00
<?php
namespace App\Actions\CheckoutRequests;
2024-10-21 15:31:26 -07:00
use App\Exceptions\AssetNotRequestable;
2024-10-22 13:09:35 -07:00
use App\Exceptions\ThereIsNoUser;
2024-10-16 15:23:22 -07:00
use App\Models\Actionlog;
use App\Models\Asset;
use App\Models\Company;
use App\Models\Setting;
use App\Models\User;
use App\Notifications\RequestAssetCancelation;
use App\Notifications\RequestAssetNotification;
2024-10-21 15:31:26 -07:00
use Illuminate\Auth\Access\AuthorizationException;
2024-10-16 15:23:22 -07:00
class CreateCheckoutRequest
{
2024-10-21 15:31:26 -07:00
/**
* @throws AssetNotRequestable
* @throws AuthorizationException
*/
public static function run(Asset $asset, User $user): string
2024-10-16 15:23:22 -07:00
{
2024-10-22 13:09:35 -07:00
//throw new \Exception();
2024-10-21 15:31:26 -07:00
if (is_null(Asset::RequestableAssets()->find($asset->id))) {
throw new AssetNotRequestable($asset);
2024-10-16 15:23:22 -07:00
}
if (!Company::isCurrentUserHasAccess($asset)) {
2024-10-21 15:31:26 -07:00
throw new AuthorizationException();
2024-10-16 15:23:22 -07:00
}
$data['item'] = $asset;
2024-10-21 15:31:26 -07:00
$data['target'] = $user;
2024-10-16 15:23:22 -07:00
$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.
2024-10-22 13:09:35 -07:00
// this is going into another action class
2024-10-16 15:23:22 -07:00
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) {
2024-10-16 22:02:15 -07:00
\Log::warning($e);
2024-10-16 15:23:22 -07:00
}
2024-10-21 15:31:26 -07:00
return $status = 'cancelled';
2024-10-16 15:23:22 -07:00
}
$logaction->logaction('requested');
$asset->request();
$asset->increment('requests_counter', 1);
try {
$settings->notify(new RequestAssetNotification($data));
} catch (\Exception $e) {
2024-10-16 16:48:15 -07:00
\Log::warning($e);
2024-10-16 15:23:22 -07:00
}
2024-10-17 10:45:49 -07:00
2024-10-22 13:09:35 -07:00
return true; // or $asset, or whatever
}
public function doSomethingElse()
{
2024-10-16 16:48:15 -07:00
}
2024-10-21 15:31:26 -07:00
}