feat: Items Files API 개선 - group_id 기반, 동적 field_key 지원

- GET /items/{id}/files 엔드포인트 추가 (파일 목록 조회)
- document_type을 group_id('1')로 변경 (테이블명 대신 코드 기반)
- field_key 제한 해제 (자유롭게 지정 가능)
- 품목 상세 조회 시 files 필드 포함 (field_key별 그룹핑)
- ItemFileUploadRequest FormRequest 추가
- DELETE 라우트 파라미터를 {fileId}로 변경
This commit is contained in:
2025-12-12 17:38:22 +09:00
parent b6bea99cd9
commit 2e4d4d3be3
6 changed files with 397 additions and 235 deletions

View File

@@ -0,0 +1,53 @@
<?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를 초과할 수 없습니다.',
];
}
}