feat: 다수 기능 개선 - 순찰, 출근, 작업분석, 모바일 UI 등
- 순찰/점검 기능 개선 (zone-detail 페이지 추가) - 출근/근태 시스템 개선 (연차 조회, 근무현황) - 작업분석 대분류 그룹화 및 마이그레이션 스크립트 - 모바일 네비게이션 UI 추가 - NAS 배포 도구 및 문서 추가 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
96
deploy/tkfb-package/api.hyungi.net/services/uploadService.js
Normal file
96
deploy/tkfb-package/api.hyungi.net/services/uploadService.js
Normal file
@@ -0,0 +1,96 @@
|
||||
/**
|
||||
* 문서 업로드 관리 서비스
|
||||
*
|
||||
* 파일 업로드 및 문서 메타데이터 관리 관련 비즈니스 로직 처리
|
||||
*
|
||||
* @author TK-FB-Project
|
||||
* @since 2025-12-11
|
||||
*/
|
||||
|
||||
const uploadModel = require('../models/uploadModel');
|
||||
const { ValidationError, DatabaseError } = require('../utils/errors');
|
||||
const logger = require('../utils/logger');
|
||||
|
||||
/**
|
||||
* 문서 업로드 생성
|
||||
*/
|
||||
const createUploadService = async (uploadData) => {
|
||||
const {
|
||||
title,
|
||||
tags,
|
||||
description,
|
||||
original_name,
|
||||
stored_name,
|
||||
file_path,
|
||||
file_type,
|
||||
file_size,
|
||||
submitted_by
|
||||
} = uploadData;
|
||||
|
||||
// 필수 필드 검증
|
||||
if (!original_name || !stored_name || !file_path) {
|
||||
throw new ValidationError('필수 필드가 누락되었습니다', {
|
||||
required: ['original_name', 'stored_name', 'file_path'],
|
||||
received: { original_name, stored_name, file_path }
|
||||
});
|
||||
}
|
||||
|
||||
logger.info('문서 업로드 생성 요청', {
|
||||
title,
|
||||
original_name,
|
||||
file_type,
|
||||
file_size,
|
||||
submitted_by
|
||||
});
|
||||
|
||||
try {
|
||||
const insertId = await new Promise((resolve, reject) => {
|
||||
uploadModel.create(uploadData, (err, id) => {
|
||||
if (err) reject(err);
|
||||
else resolve(id);
|
||||
});
|
||||
});
|
||||
|
||||
logger.info('문서 업로드 생성 성공', {
|
||||
upload_id: insertId,
|
||||
original_name,
|
||||
file_size
|
||||
});
|
||||
|
||||
return { upload_id: insertId };
|
||||
} catch (error) {
|
||||
logger.error('문서 업로드 생성 실패', {
|
||||
original_name,
|
||||
error: error.message
|
||||
});
|
||||
throw new DatabaseError('문서 업로드 생성 중 오류가 발생했습니다');
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* 전체 업로드 문서 조회
|
||||
*/
|
||||
const getAllUploadsService = async () => {
|
||||
logger.info('업로드 문서 목록 조회 요청');
|
||||
|
||||
try {
|
||||
const rows = await new Promise((resolve, reject) => {
|
||||
uploadModel.getAll((err, data) => {
|
||||
if (err) reject(err);
|
||||
else resolve(data);
|
||||
});
|
||||
});
|
||||
|
||||
logger.info('업로드 문서 목록 조회 성공', { count: rows.length });
|
||||
|
||||
return rows;
|
||||
} catch (error) {
|
||||
logger.error('업로드 문서 목록 조회 실패', { error: error.message });
|
||||
throw new DatabaseError('업로드 문서 목록 조회 중 오류가 발생했습니다');
|
||||
}
|
||||
};
|
||||
|
||||
module.exports = {
|
||||
createUploadService,
|
||||
getAllUploadsService
|
||||
};
|
||||
Reference in New Issue
Block a user