2025-08-25 17:26:20 +09:00
|
|
|
<?php
|
2025-11-06 17:24:42 +09:00
|
|
|
|
2025-08-25 17:26:20 +09:00
|
|
|
/**
|
|
|
|
|
* 성공/안내/일반 메시지 (비에러)
|
|
|
|
|
* - API 정상 응답의 message 필드용
|
|
|
|
|
* - 도메인 공통 키와 리소스별 하위 그룹을 혼합 사용
|
|
|
|
|
* - 예: return ApiResponse::success($data, __('message.created'));
|
|
|
|
|
*/
|
|
|
|
|
return [
|
|
|
|
|
|
|
|
|
|
// 공통 (CRUD/편의)
|
2025-11-06 17:24:42 +09:00
|
|
|
'fetched' => '조회 성공',
|
|
|
|
|
'created' => '등록 성공',
|
|
|
|
|
'updated' => '수정 성공',
|
|
|
|
|
'deleted' => '삭제 성공',
|
|
|
|
|
'restored' => '복구 성공',
|
|
|
|
|
'toggled' => '상태 변경 성공',
|
2025-08-25 17:26:20 +09:00
|
|
|
'bulk_upsert' => '대량 저장 성공',
|
2025-11-06 17:24:42 +09:00
|
|
|
'reordered' => '정렬 변경 성공',
|
|
|
|
|
'no_changes' => '변경 사항이 없습니다.',
|
2025-08-25 17:26:20 +09:00
|
|
|
|
|
|
|
|
// 인증/세션
|
2025-11-06 17:24:42 +09:00
|
|
|
'login_success' => '로그인 성공',
|
2025-08-25 17:26:20 +09:00
|
|
|
'logout_success' => '로그아웃 되었습니다.',
|
|
|
|
|
'signup_success' => '회원가입이 완료되었습니다.',
|
2025-11-10 09:11:41 +09:00
|
|
|
'registered' => '회원가입 처리',
|
2025-11-10 11:17:32 +09:00
|
|
|
'token_refreshed' => '토큰이 갱신되었습니다',
|
2025-08-25 17:26:20 +09:00
|
|
|
|
|
|
|
|
// 테넌트/컨텍스트
|
|
|
|
|
'tenant_switched' => '활성 테넌트가 전환되었습니다.',
|
|
|
|
|
|
|
|
|
|
// 리소스별 세부 (필요 시)
|
|
|
|
|
'product' => [
|
2025-11-07 02:29:51 +09:00
|
|
|
'fetched' => '제품을 조회했습니다.',
|
|
|
|
|
'category_fetched' => '제품 카테고리를 조회했습니다.',
|
2025-11-06 17:24:42 +09:00
|
|
|
'created' => '제품이 등록되었습니다.',
|
|
|
|
|
'updated' => '제품이 수정되었습니다.',
|
|
|
|
|
'deleted' => '제품이 삭제되었습니다.',
|
|
|
|
|
'toggled' => '제품 상태가 변경되었습니다.',
|
2025-11-07 02:29:51 +09:00
|
|
|
'searched' => '제품을 검색했습니다.',
|
2025-08-25 17:26:20 +09:00
|
|
|
],
|
|
|
|
|
|
|
|
|
|
'bom' => [
|
2025-11-06 17:24:42 +09:00
|
|
|
'fetched' => 'BOM 항목을 조회했습니다.',
|
2025-08-25 17:26:20 +09:00
|
|
|
'bulk_upsert' => 'BOM 항목이 저장되었습니다.',
|
2025-11-06 17:24:42 +09:00
|
|
|
'reordered' => 'BOM 정렬이 변경되었습니다.',
|
|
|
|
|
'fetch' => 'BOM 항목 조회',
|
|
|
|
|
'create' => 'BOM 항목 등록',
|
|
|
|
|
'update' => 'BOM 항목 수정',
|
|
|
|
|
'delete' => 'BOM 항목 삭제',
|
|
|
|
|
'restore' => 'BOM 항목 복구',
|
2025-08-25 17:26:20 +09:00
|
|
|
],
|
|
|
|
|
|
|
|
|
|
'category' => [
|
2025-11-07 02:47:30 +09:00
|
|
|
'fetched' => '카테고리를 조회했습니다.',
|
|
|
|
|
'created' => '카테고리가 등록되었습니다.',
|
|
|
|
|
'updated' => '카테고리가 수정되었습니다.',
|
|
|
|
|
'deleted' => '카테고리가 삭제되었습니다.',
|
|
|
|
|
'toggled' => '카테고리 상태가 변경되었습니다.',
|
|
|
|
|
'moved' => '카테고리가 이동되었습니다.',
|
|
|
|
|
'reordered' => '카테고리 정렬순서가 변경되었습니다.',
|
|
|
|
|
'tree_fetched' => '카테고리 트리를 조회했습니다.',
|
2025-11-06 17:24:42 +09:00
|
|
|
'fields_saved' => '카테고리 필드가 저장되었습니다.',
|
2025-08-25 17:26:20 +09:00
|
|
|
'template_saved' => '카테고리 템플릿이 저장되었습니다.',
|
|
|
|
|
'template_applied' => '카테고리 템플릿이 적용되었습니다.',
|
|
|
|
|
],
|
2025-09-11 13:34:20 +09:00
|
|
|
|
2025-11-14 13:45:54 +09:00
|
|
|
'category_field' => [
|
|
|
|
|
'fetched' => '카테고리 필드를 조회했습니다.',
|
|
|
|
|
'created' => '카테고리 필드가 생성되었습니다.',
|
|
|
|
|
'updated' => '카테고리 필드가 수정되었습니다.',
|
|
|
|
|
'deleted' => '카테고리 필드가 삭제되었습니다.',
|
|
|
|
|
'reordered' => '카테고리 필드 정렬이 변경되었습니다.',
|
|
|
|
|
'bulk_upsert' => '카테고리 필드가 일괄 저장되었습니다.',
|
|
|
|
|
],
|
|
|
|
|
|
2025-09-11 13:34:20 +09:00
|
|
|
'design' => [
|
|
|
|
|
'template_cloned' => 'BOM 템플릿이 복제되었습니다.',
|
2025-11-06 17:24:42 +09:00
|
|
|
'template_diff' => 'BOM 템플릿 차이를 계산했습니다.',
|
2025-09-11 13:34:20 +09:00
|
|
|
],
|
2025-09-24 17:41:26 +09:00
|
|
|
|
|
|
|
|
'model_set' => [
|
2025-11-06 17:24:42 +09:00
|
|
|
'cloned' => '모델셋이 복제되었습니다.',
|
|
|
|
|
'calculated' => 'BOM 계산이 완료되었습니다.',
|
2025-09-24 17:41:26 +09:00
|
|
|
],
|
|
|
|
|
|
|
|
|
|
'estimate' => [
|
2025-11-06 17:24:42 +09:00
|
|
|
'cloned' => '견적이 복제되었습니다.',
|
2025-09-24 17:41:26 +09:00
|
|
|
'status_changed' => '견적 상태가 변경되었습니다.',
|
|
|
|
|
],
|
|
|
|
|
|
|
|
|
|
// 계산 관련
|
|
|
|
|
'calculated' => '계산 완료',
|
2025-09-24 20:35:17 +09:00
|
|
|
|
|
|
|
|
// 설정 관리 (Settings & Configuration 통합)
|
|
|
|
|
'settings' => [
|
2025-11-06 17:24:42 +09:00
|
|
|
'fields_updated' => '필드 설정이 업데이트되었습니다.',
|
|
|
|
|
'fields_bulk_saved' => '필드 설정 일괄 저장이 완료되었습니다.',
|
|
|
|
|
'options_saved' => '옵션 그룹이 저장되었습니다.',
|
|
|
|
|
'options_reordered' => '옵션 값 정렬이 변경되었습니다.',
|
|
|
|
|
'common_code_saved' => '공통 코드가 저장되었습니다.',
|
2025-09-24 20:35:17 +09:00
|
|
|
],
|
|
|
|
|
|
|
|
|
|
// 자재 관리 (Products & Materials 통합)
|
2025-11-07 02:37:18 +09:00
|
|
|
'material' => [
|
|
|
|
|
'fetched' => '자재를 조회했습니다.',
|
2025-11-06 17:24:42 +09:00
|
|
|
'created' => '자재가 등록되었습니다.',
|
|
|
|
|
'updated' => '자재가 수정되었습니다.',
|
|
|
|
|
'deleted' => '자재가 삭제되었습니다.',
|
2025-09-24 20:35:17 +09:00
|
|
|
],
|
|
|
|
|
|
2025-11-07 02:40:18 +09:00
|
|
|
// 거래처 관리
|
|
|
|
|
'client' => [
|
|
|
|
|
'fetched' => '거래처를 조회했습니다.',
|
|
|
|
|
'created' => '거래처가 등록되었습니다.',
|
|
|
|
|
'updated' => '거래처가 수정되었습니다.',
|
|
|
|
|
'deleted' => '거래처가 삭제되었습니다.',
|
|
|
|
|
'toggled' => '거래처 상태가 변경되었습니다.',
|
|
|
|
|
],
|
|
|
|
|
|
2025-11-07 02:44:11 +09:00
|
|
|
// 사용자 관리
|
|
|
|
|
'user' => [
|
|
|
|
|
'fetched' => '사용자를 조회했습니다.',
|
|
|
|
|
'me_fetched' => '나의 정보를 조회했습니다.',
|
|
|
|
|
'me_updated' => '나의 정보가 수정되었습니다.',
|
|
|
|
|
'password_changed' => '비밀번호가 변경되었습니다.',
|
|
|
|
|
'tenants_fetched' => '나의 테넌트 목록을 조회했습니다.',
|
|
|
|
|
'tenant_switched' => '활성 테넌트가 전환되었습니다.',
|
|
|
|
|
],
|
|
|
|
|
|
2025-11-07 02:47:30 +09:00
|
|
|
// 테넌트 관리
|
|
|
|
|
'tenant' => [
|
|
|
|
|
'fetched' => '테넌트를 조회했습니다.',
|
|
|
|
|
'created' => '테넌트가 등록되었습니다.',
|
|
|
|
|
'updated' => '테넌트가 수정되었습니다.',
|
|
|
|
|
'deleted' => '테넌트가 삭제되었습니다.',
|
|
|
|
|
'restored' => '테넌트가 복구되었습니다.',
|
|
|
|
|
],
|
|
|
|
|
|
2025-11-14 14:09:53 +09:00
|
|
|
'tenant_stat_field' => [
|
|
|
|
|
'fetched' => '통계 필드를 조회했습니다.',
|
|
|
|
|
'created' => '통계 필드가 생성되었습니다.',
|
|
|
|
|
'updated' => '통계 필드가 수정되었습니다.',
|
|
|
|
|
'deleted' => '통계 필드가 삭제되었습니다.',
|
|
|
|
|
'reordered' => '통계 필드 정렬이 변경되었습니다.',
|
|
|
|
|
'bulk_upsert' => '통계 필드가 일괄 저장되었습니다.',
|
|
|
|
|
],
|
|
|
|
|
|
2025-09-24 20:35:17 +09:00
|
|
|
// 파일 관리
|
|
|
|
|
'file' => [
|
|
|
|
|
'uploaded' => '파일이 업로드되었습니다.',
|
2025-11-06 17:24:42 +09:00
|
|
|
'deleted' => '파일이 삭제되었습니다.',
|
|
|
|
|
'fetched' => '파일 목록을 조회했습니다.',
|
2025-09-24 20:35:17 +09:00
|
|
|
],
|
feat: 파일 저장 시스템 DB 마이그레이션
- enhance_files_table: 이중 파일명 시스템 (display_name/stored_name), 폴더 관리, 문서 연결 지원
- create_folders_table: 동적 폴더 관리 시스템 (tenant별 커스터마이징 가능)
- 5개 stub 마이그레이션 생성 (file_share_links, file_deletion_logs, storage_usage_history, add_storage_columns_to_tenants)
- FolderSeeder stub 생성
- CURRENT_WORKS.md에 Phase 1 진행상황 문서화
fix: 파일 공유 및 삭제 기능 버그 수정
- ShareLinkRequest: PATH 파라미터 {id}를 file_id로 자동 병합
- routes/api.php: 공유 링크 다운로드를 auth.apikey 그룹 밖으로 이동 (인증 불필요)
- FileShareLink: File, Tenant 클래스 import 추가
- File 모델: softDeleteFile()에서 SoftDeletes의 delete() 메서드 사용
- FileStorageService: getTrash(), restoreFile(), permanentDelete()에서 onlyTrashed() 사용
- File 모델: Tenant 네임스페이스 수정 (App\Models\Tenants\Tenant)
refactor: Swagger 문서 정리 - File 태그를 Files로 통합
- FileApi.php의 모든 태그를 Files로 변경
- 구 파일 시스템 라우트 삭제 (prefix 'file')
- 구 FileController.php 삭제
- 신규 파일 저장소 시스템으로 완전 통합
fix: 모든 legacy 파일 컬럼 nullable 일괄 처리
- 5개 legacy 컬럼을 한 번에 nullable로 변경
* original_name, file_name, file_name_old (string)
* fileable_id, fileable_type (polymorphic)
- foreach 루프로 반복 작업 자동화
- 신규/기존 시스템 간 완전한 하위 호환성 확보
fix: legacy 파일 컬럼 nullable 처리 완료
- file_name, file_name_old 컬럼도 nullable로 변경
- 기존 시스템과 신규 시스템 간 완전한 하위 호환성 확보
- Legacy: original_name, file_name, file_name_old (nullable)
- New: display_name, stored_name (required)
fix: original_name 컬럼 nullable 처리
- original_name을 nullable로 변경하여 하위 호환성 유지
- 새 시스템에서는 display_name 사용, 기존 시스템은 original_name 사용 가능
fix: 파일 업로드 DB 컬럼 누락 및 메시지 구조 개선
- files 테이블에 감사 컬럼 추가 (created_by, updated_by, uploaded_by)
- ApiResponse::handle() 메시지 로직 개선 (접미사 제거)
- 다국어 지원을 위한 완성된 문장 구조 유지
- FileUploadRequest 파일 검증 규칙 수정
fix: 파일 저장소 버그 수정 및 신규 테넌트 폴더 자동 생성
- FolderSeeder 네임스페이스 수정 (App\Models\Tenant → App\Models\Tenants\Tenant)
- FileStorageController use 문 구문 오류 수정 (/ → \)
- TenantObserver에 신규 테넌트 기본 폴더 자동 생성 로직 추가
- 5개 기본 폴더 (생산관리, 품질관리, 회계, 인사, 일반)
- 에러 처리 및 로깅
- 회원가입 시 자동 실행
2025-11-10 19:08:56 +09:00
|
|
|
|
|
|
|
|
// 파일 저장소
|
|
|
|
|
'file_uploaded' => '파일이 업로드되었습니다.',
|
|
|
|
|
'files_moved' => '파일이 이동되었습니다.',
|
|
|
|
|
'file_deleted' => '파일이 삭제되었습니다.',
|
|
|
|
|
'file_restored' => '파일이 복구되었습니다.',
|
|
|
|
|
'file_permanently_deleted' => '파일이 영구 삭제되었습니다.',
|
|
|
|
|
'share_link_created' => '공유 링크가 생성되었습니다.',
|
|
|
|
|
'storage_exceeded_grace_period' => '저장소 용량이 초과되었습니다. 유예 기간이 적용됩니다.',
|
|
|
|
|
|
|
|
|
|
// 폴더 관리
|
|
|
|
|
'folder_created' => '폴더가 생성되었습니다.',
|
|
|
|
|
'folder_updated' => '폴더가 수정되었습니다.',
|
|
|
|
|
'folder_deleted' => '폴더가 비활성화되었습니다.',
|
|
|
|
|
'folders_reordered' => '폴더 순서가 변경되었습니다.',
|
2025-08-25 17:26:20 +09:00
|
|
|
];
|