Hyungi Ahn 3cf485f3f2 feat: 수신함 워크플로우 백엔드 완전 구현
🔧 Models & Schemas:
- 새로운 ENUM 클래스 추가:
  * ReviewStatus: pending_review, in_progress, completed, disposed
  * DisposalReasonType: duplicate, invalid_report, not_applicable, spam, custom

- Issue 모델 확장 (8개 새 필드):
  * review_status: 수신함 워크플로우 상태 (기본값: pending_review)
  * disposal_reason: 폐기 사유 ENUM
  * custom_disposal_reason: 사용자 정의 폐기 사유
  * disposed_at: 폐기 처리 시간
  * reviewed_by_id: 검토자 FK (users.id)
  * reviewed_at: 검토 완료 시간
  * original_data: 원본 데이터 보존 (JSONB)
  * modification_log: 수정 이력 추적 (JSONB)

- User 모델 관계 수정:
  * issues: 신고한 부적합 (foreign_keys 명시)
  * reviewed_issues: 검토한 부적합 (새로 추가)

🎯 Pydantic Schemas:
- 기존 Issue 스키마에 워크플로우 필드 추가
- 수신함 전용 스키마들:
  * IssueDisposalRequest: 폐기 요청
  * IssueReviewRequest: 검토/수정 요청
  * IssueStatusUpdateRequest: 상태 변경 요청
  * InboxIssue: 수신함용 간소화 모델
  * ModificationLogEntry: 수정 이력 항목

🚀 API Endpoints (/api/inbox):
- GET /: 수신함 부적합 목록 (프로젝트 필터링, 페이징)
- POST /{id}/dispose: 부적합 폐기 처리 (관리자 전용)
- POST /{id}/review: 부적합 검토/수정 (관리자 전용)
- POST /{id}/status: 최종 상태 결정 (관리자 전용)
- GET /{id}/history: 수정 이력 조회
- GET /statistics: 수신함 통계

🔒 Security & Validation:
- 관리자 전용 액션 (폐기, 검토, 상태변경)
- 사용자 정의 폐기 사유 검증
- 프로젝트 존재 여부 확인
- 상태 변경 로직 검증

📊 Data Preservation:
- 원본 데이터 자동 보존 (최초 1회)
- 모든 수정사항 이력 추적
- 검토자 및 시간 기록
- 폐기 사유 및 시간 기록

🎯 Workflow Logic:
업로드(pending_review) → 수신함 검토 → [폐기→폐기함] or [승인→관리함]
- 폐기: disposed 상태, 폐기함으로
- 승인: in_progress/completed 상태, 관리함으로
- 모든 변경사항 추적 및 보존

Result:
 수신함 워크플로우 백엔드 100% 완성
 DB 스키마와 완벽 동기화
 데이터 무결성 및 추적성 보장
 RESTful API 설계 준수
 관리자 권한 기반 보안 적용
2025-10-25 12:08:14 +09:00

M-Project - 작업보고서 시스템

간단하고 효율적인 부적합 사항 관리 및 공수 계산 시스템

🚀 빠른 시작

Docker를 사용한 실행 (권장)

  1. Docker 컨테이너 실행:
cd M-Project
docker-compose up -d
  1. 브라우저에서 접속:
http://localhost:16080
  1. 로그인:
  • 관리자: hyungi / djg3-jj34-X3Q3
  • 검사자1: inspector1 / pass123
  • 검사자2: inspector2 / pass456

간단한 웹 서버 실행 (개발용)

cd M-Project
python3 -m http.server 16080

📱 주요 기능

1. 프로젝트 관리 (신규 추가 )

  • Job No. 기반 프로젝트 생성
  • 관리자 전용 프로젝트 생성 배너
  • 프로젝트 목록 조회 및 관리

2. 부적합 등록 (모바일 최적화)

  • 사진 촬영 또는 업로드 (최대 2장)
  • 카테고리별 분류 (자재누락, 설계미스, 입고자재 불량, 검사미스)
  • 상세 설명 입력

3. 목록 관리

  • 등록된 부적합 사항 조회
  • 작업 시간 입력
  • 상태 변경 (신규→진행중→완료)
  • 추가 메모 작성

4. 일일 공수 관리

  • 작업자 수 및 정규/야근 시간 입력
  • 날짜별 공수 추적
  • 자동 계산 기능

5. 보고서

  • 작업 기간 및 총 공수 자동 계산
  • 카테고리별 통계
  • 부적합 사항 상세 내역
  • 인쇄 가능한 형식

📁 파일 구조

M-Project/
├── index.html      # 메인 애플리케이션
├── Rules.md        # 시스템 규칙 및 요구사항
└── README.md       # 이 파일

🛠️ 기술 스택

  • Backend: FastAPI (Python), SQLAlchemy, PostgreSQL
  • Frontend: HTML5, Tailwind CSS, JavaScript (Vanilla)
  • Database: PostgreSQL 15
  • Container: Docker & Docker Compose
  • Web Server: Nginx
  • Authentication: JWT (JSON Web Token)
  • Icons: Font Awesome

📋 데이터 구조

부적합 사항은 다음과 같은 형식으로 저장됩니다:

{
  id: 1234567890,                    // 타임스탬프
  photo: "data:image/jpeg;base64...", // Base64 이미지
  location: "2층 회의실",              // 위치
  category: "safety",                 // 카테고리
  description: "안전 장비 미착용",      // 설명
  urgency: "high",                    // 긴급도
  status: "new",                      // 상태
  reporter: "inspector1",             // 보고자 ID
  reporterName: "검사자1",            // 보고자 이름
  reportDate: "2025-09-17T10:30:00", // 보고 일시
  workHours: 2.5,                    // 작업 시간
  detailNotes: "추가 메모..."         // 상세 메모
}

특징

  • 모바일 우선: 현장에서 스마트폰으로 쉽게 입력
  • 실시간 데이터: PostgreSQL 데이터베이스로 실시간 동기화
  • 권한 관리: 관리자/일반 사용자 역할 기반 접근 제어
  • Docker 기반: 간편한 배포 및 확장성
  • RESTful API: 표준 API 설계로 확장 가능

🔒 보안 기능

  • JWT 인증: 토큰 기반 보안 인증 시스템
  • 비밀번호 암호화: bcrypt 해시를 사용한 안전한 비밀번호 저장
  • 권한 기반 접근: 역할별 API 접근 제어
  • SQL 인젝션 방지: SQLAlchemy ORM 사용

📚 문서

📝 라이선스

내부 사용 목적으로 제작됨


최종 업데이트: 2024-10-24
버전: 1.0.0 (프로젝트 관리 기능 추가)

Description
No description provided
Readme 1.9 MiB
Languages
HTML 66.2%
Python 13.6%
JavaScript 13.4%
PLpgSQL 5%
Shell 1.3%
Other 0.5%