Files
sam-manage/app/Http/Requests/UpdateRoleRequest.php
hskwon 5f50716d7f feat: Phase 4-2 역할 관리 시스템 구현 (HTMX + API 패턴)
- RoleService, RoleController (Blade/API) 생성
- 역할 CRUD 기능 완성 (목록/생성/수정/삭제)
- FormRequest 검증 (StoreRoleRequest, UpdateRoleRequest)
- HTMX 패턴 적용 (index, create, edit)
- 권한 선택 UI (체크박스, 전체 선택/해제)
- Tenant Selector 통합
- 레이아웃 패턴 문서화 (LAYOUT_PATTERN.md)
- Sidebar 메뉴에 역할 관리 추가
- Pagination partial 컴포넌트 추가
- Tenants 레이아웃 100% 폭으로 통일

주요 수정:
- UpdateRoleRequest 라우트 파라미터 수정 (role → id)
- RoleController permissions 조회 시 description 제거
- Conditional tenant filtering 적용
2025-11-24 16:36:02 +09:00

67 lines
1.9 KiB
PHP

<?php
namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Validation\Rule;
class UpdateRoleRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*/
public function authorize(): bool
{
return true; // 권한 체크는 middleware에서 처리
}
/**
* Get the validation rules that apply to the request.
*/
public function rules(): array
{
$tenantId = session('selected_tenant_id');
$roleId = $this->route('id'); // URL 파라미터에서 role ID 가져오기
return [
'name' => [
'required',
'string',
'max:100',
Rule::unique('roles', 'name')
->where('tenant_id', $tenantId)
->where('guard_name', 'web')
->ignore($roleId),
],
'description' => 'nullable|string|max:500',
'permissions' => 'nullable|array',
'permissions.*' => 'exists:permissions,id',
];
}
/**
* Get custom attributes for validator errors.
*/
public function attributes(): array
{
return [
'name' => '역할 이름',
'description' => '설명',
'permissions' => '권한',
];
}
/**
* Get the error messages for the defined validation rules.
*/
public function messages(): array
{
return [
'name.required' => '역할 이름은 필수입니다.',
'name.unique' => '이미 존재하는 역할 이름입니다.',
'name.max' => '역할 이름은 최대 100자까지 입력 가능합니다.',
'description.max' => '설명은 최대 500자까지 입력 가능합니다.',
'permissions.*.exists' => '유효하지 않은 권한이 포함되어 있습니다.',
];
}
}