- GET /items/{id}/files 엔드포인트 추가 (파일 목록 조회)
- document_type을 group_id('1')로 변경 (테이블명 대신 코드 기반)
- field_key 제한 해제 (자유롭게 지정 가능)
- 품목 상세 조회 시 files 필드 포함 (field_key별 그룹핑)
- ItemFileUploadRequest FormRequest 추가
- DELETE 라우트 파라미터를 {fileId}로 변경
54 lines
1.4 KiB
PHP
54 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Requests\Item;
|
|
|
|
use Illuminate\Foundation\Http\FormRequest;
|
|
|
|
/**
|
|
* 품목 파일 업로드 요청 검증
|
|
*
|
|
* field_key 동적 지원, 다중 파일 가능
|
|
*/
|
|
class ItemFileUploadRequest extends FormRequest
|
|
{
|
|
public function authorize(): bool
|
|
{
|
|
return true;
|
|
}
|
|
|
|
public function rules(): array
|
|
{
|
|
return [
|
|
'field_key' => ['required', 'string', 'max:100'],
|
|
'file' => [
|
|
'required',
|
|
'file',
|
|
'mimes:jpg,jpeg,png,gif,bmp,svg,webp,pdf,doc,docx,xls,xlsx,hwp,dwg,dxf,zip,rar',
|
|
'max:20480', // 20MB
|
|
],
|
|
'file_id' => ['sometimes', 'nullable', 'integer'],
|
|
'item_type' => ['sometimes', 'nullable', 'string', 'in:FG,PT,SM,RM,CS,fg,pt,sm,rm,cs'],
|
|
];
|
|
}
|
|
|
|
public function attributes(): array
|
|
{
|
|
return [
|
|
'field_key' => '필드 키',
|
|
'file' => '파일',
|
|
'file_id' => '파일 ID',
|
|
'item_type' => '품목 유형',
|
|
];
|
|
}
|
|
|
|
public function messages(): array
|
|
{
|
|
return [
|
|
'field_key.required' => '필드 키는 필수입니다.',
|
|
'file.required' => '파일을 선택해주세요.',
|
|
'file.mimes' => '허용되지 않는 파일 형식입니다.',
|
|
'file.max' => '파일 크기는 20MB를 초과할 수 없습니다.',
|
|
];
|
|
}
|
|
}
|