mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-14 07:02:34 +01:00
da49880733
* Bulk storing request & accesing policy service * Transform hardcoded action to self-property * Testing, support for multiple resources * Uncomment, response(200) * Change authorize to isAdmin() property
48 lines
997 B
PHP
48 lines
997 B
PHP
<?php
|
|
|
|
namespace App\Http\Requests\Client;
|
|
|
|
use App\Utils\Traits\BulkOptions;
|
|
use Illuminate\Foundation\Http\FormRequest;
|
|
use App\Models\Client;
|
|
|
|
class BulkClientRequest extends FormRequest
|
|
{
|
|
use BulkOptions;
|
|
|
|
/**
|
|
* Determine if the user is authorized to make this request.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function authorize()
|
|
{
|
|
if (!$this->has('action')) {
|
|
return false;
|
|
}
|
|
|
|
if (!in_array($this->action, $this->getBulkOptions(), true)) {
|
|
return false;
|
|
}
|
|
|
|
return auth()->user()->can(auth()->user()->isAdmin(), Client::class);
|
|
}
|
|
|
|
/**
|
|
* Get the validation rules that apply to the request.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function rules()
|
|
{
|
|
$rules = $this->getGlobalRules();
|
|
|
|
/** We don't require IDs on bulk storing. */
|
|
if ($this->action !== self::$STORE_METHOD) {
|
|
$rules['ids'] = ['required'];
|
|
}
|
|
|
|
return $rules;
|
|
}
|
|
}
|