Add cross-organisation admin API endpoints behind role:super_admin middleware: - AdminOrganisationController: CRUD with search, filter, billing_status management - AdminUserController: user management with role assignment across orgs - AdminStatsController: platform-wide aggregate statistics - AdminActivityLogController: filterable activity log viewer - AdminImpersonationController + ImpersonationService: user impersonation with token-based session management and activity logging - BillingStatus enum, form requests, API resources, 23 feature tests Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
34 lines
959 B
PHP
34 lines
959 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Http\Requests\Admin;
|
|
|
|
use Illuminate\Foundation\Http\FormRequest;
|
|
use Illuminate\Validation\Rule;
|
|
|
|
final class AdminUpdateUserRequest extends FormRequest
|
|
{
|
|
public function authorize(): bool
|
|
{
|
|
return true;
|
|
}
|
|
|
|
/** @return array<string, mixed> */
|
|
public function rules(): array
|
|
{
|
|
return [
|
|
'first_name' => ['sometimes', 'string', 'max:255'],
|
|
'last_name' => ['sometimes', 'string', 'max:255'],
|
|
'email' => [
|
|
'sometimes', 'string', 'email', 'max:255',
|
|
Rule::unique('users', 'email')->ignore($this->route('user')),
|
|
],
|
|
'timezone' => ['sometimes', 'string', 'timezone'],
|
|
'locale' => ['sometimes', 'string', Rule::in(['nl', 'en'])],
|
|
'roles' => ['nullable', 'array'],
|
|
'roles.*' => ['string', Rule::in(['super_admin', 'support_agent'])],
|
|
];
|
|
}
|
|
}
|