mirror of
https://github.com/snipe/snipe-it.git
synced 2024-11-12 16:44:08 -08:00
52 lines
1.3 KiB
PHP
52 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Requests;
|
|
|
|
use App\Models\Asset;
|
|
use App\Models\Company;
|
|
use Illuminate\Support\Facades\Gate;
|
|
|
|
class StoreAssetRequest extends ImageUploadRequest
|
|
{
|
|
/**
|
|
* Determine if the user is authorized to make this request.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function authorize(): bool
|
|
{
|
|
return Gate::allows('create', new Asset);
|
|
}
|
|
|
|
public function prepareForValidation(): void
|
|
{
|
|
// Guard against users passing in an array for company_id instead of an integer.
|
|
// If the company_id is not an integer then we simply use what was
|
|
// provided to be caught by model level validation later.
|
|
$idForCurrentUser = is_int($this->company_id)
|
|
? Company::getIdForCurrentUser($this->company_id)
|
|
: $this->company_id;
|
|
|
|
$this->merge([
|
|
'asset_tag' => $this->asset_tag ?? Asset::autoincrement_asset(),
|
|
'company_id' => $idForCurrentUser,
|
|
'assigned_to' => $assigned_to ?? null,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Get the validation rules that apply to the request.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function rules(): array
|
|
{
|
|
$rules = array_merge(
|
|
(new Asset)->getRules(),
|
|
parent::rules(),
|
|
);
|
|
|
|
return $rules;
|
|
}
|
|
}
|