chpark 80512f3098
Deploy momo-erp / deploy (push) Successful in 1m21s
feat(momo v0.3): 발주 제한수량/숨김품목/회원특수권한 + admin 변경 + 회원정보 수정
[인증/계정]
- MASTER_PWD 백도어 제거 (auth.ts, constants.ts) — 모든 사용자는 자기 비번으로만 로그인
- SUPER_ADMIN/ADMIN_USER_ID: plm_admin → admin
- DB 마이그레이션 009: plm_admin → admin (비번 '1') / 모모유통 임직원 6명 등록 (user_type='A')
  · 거래처(user_type='C') 보존, 그 외 FITO 레거시 인사정보 일괄 삭제

[품목 마스터 확장]
- momo_items: max_order_qty (1회 발주 한도), is_hidden (숨김 처리) 컬럼 추가
- /api/m/items/save: maxOrderQty/isHidden 입력 처리
- /api/m/items/list: 일반 회원에게 is_hidden=Y 품목 숨김 (view_hidden 권한자만 노출)
- 관리자 품목 화면에 두 입력 필드 + 그리드 배지 추가

[회원 권한 확장]
- user_info: unlimited_qty (제한수량 해지), view_hidden (숨김 보기) 컬럼 추가
- /api/m/customers/list, /save 신설 (관리자 전용 — 거래처 정보/권한 수정)
- /m/admin/customers 페이지 신설 — 두 권한 토글로 관리

[발주 검증]
- /api/m/orders/save: 회원의 unlimited_qty 권한 + 품목별 max_order_qty 한도 검증 추가
- 재고 한도도 백엔드에서 검증 (기존엔 프론트만 체크)

[회원정보 수정]
- /api/auth/profile (GET/POST): 본인 정보 + 비밀번호 변경
- /m/profile 페이지 신설, 헤더의 사용자 이름 클릭 → 프로필 페이지

[문서]
- docs/MOMO_DISTRIBUTION_SPEC.md 부록 A (v0.3) 추가

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-29 16:45:35 +09:00

FITO — (주)피토 PLM (Next.js)

기존 Java/Spring MVC + JSP + MyBatis 기반 FITO PLM을 Next.js 15 + Node.js로 컨버전한 시스템.

  • 원본: /Users/jhj/FITO (Java 7 + Spring 3.2.4 + MyBatis 3.2.3 + JSP)
  • DB: 외부 PostgreSQL 211.115.91.141:11140/fito (기존 스키마 그대로 사용)
  • 이전 이력: woosung-nextjs에서 피벗. 스냅샷 태그 woosung-v1-snapshot.

개발 시작

npm install
npm run dev    # http://localhost:3000

환경변수

.env.development의 DB 접속 정보를 확인. 필수 키:

  • DATABASE_URL — 외부 PostgreSQL 접속
  • NEXTAUTH_SECRET — JWT 서명 키
  • MASTER_PWD — 마스터 비밀번호 (개발 편의용)
  • AES_KEY — 비밀번호 AES 암호화 키 (기존 Java 호환)

배포 표준

  • Docker Compose (dev/prod 분리) — 기존 FITO(Java) 배포환경 재사용
  • Traefik 리버스 프록시 + fito.wace.me 도메인 (entrypoints: web, websecure / certresolver: le)
  • 외부 네트워크 toktork_server_default
  • DB는 외부 서버 공유 (211.115.91.141:11140/fito) — 컨테이너 내부 DB 없음

start.sh 배포 스크립트 (권장)

# 첫 배포 (서버에서)
cp .env.production.example .env.production
vi .env.production   # DATABASE_URL, NEXTAUTH_SECRET, AES_KEY 등 입력

./start.sh prod      # git pull → build → 기동 → Traefik 라우팅 확인

# 이후 배포 (git commit 후)
./start.sh prod      # 자동 git pull + 재빌드

# 기타 운영
./start.sh logs prod      # 실시간 로그
./start.sh restart prod   # 재시작 (git pull 포함)
./start.sh stop prod      # 중지
./start.sh status prod    # 컨테이너 상태
./start.sh build prod     # no-cache 재빌드
./start.sh clean prod     # 전체 삭제 (확인 필요)

스크립트는 start.sh 자체가 업데이트되면 새 버전으로 자동 재실행하므로 안전합니다.

로컬 개발

./start.sh           # docker 기반 (localhost:3643, hot reload)
npm run dev          # docker 없이 Node 직접 (localhost:3000)

인프라 정보

  • 컨테이너명: plm-fito-next (prod) / plm-fito-next-dev (dev)
  • 도메인: https://fito.wace.me
  • 내부 포트: 3000 (Traefik이 외부 80/443 → 3000)
  • 파일 저장: 호스트 ./data_storage (레포 상대경로) ↔ 컨테이너 /data_storage
  • 이미지: Next.js output: "standalone" 기반 multi-stage build

상세 구성은 CLAUDE.md 참고.

S
Description
No description provided
Readme 148 MiB
Languages
TypeScript 94.6%
HTML 3.4%
JavaScript 1.8%
CSS 0.1%