DOCS/plans/250901_rb8001_chat_history_implementation_plan.md
happybell80 b25d84ff4f docs: rb8001 대화 히스토리 구현 계획 수립
- rb10508_micro 구현 코드 참조
- 현재 상태 분석 및 구현 방향 정리
- API 엔드포인트 추가 계획
2025-09-01 18:44:10 +09:00

1.6 KiB

rb8001 카톡 스타일 대화 히스토리 구현 계획

작성일: 2025-09-01

대상: rb8001 (프로덕션 로빙)

참조: rb10508_micro 구현 코드


현재 상태 분석

  • rb10508_micro: /api/config 엔드포인트 구현됨 (endpoints.py:407)
  • rb8001: API 엔드포인트 없음 (추가 필요)

수정 필요 파일

백엔드 (rb8001)

  1. app/core/config.py - 환경변수 추가 (MESSAGE_BATCH_SIZE=30, USER_MAPPING)
  2. app/state/database.py - get_paginated_conversations() 함수 추가
  3. main.py - /api/config, /api/messages 엔드포인트 추가
  4. docker-compose.yml - 환경변수 설정

프론트엔드 (frontend-customer)

  1. src/services/robeing-api.ts - getConfig(), getMessages() 함수 추가
  2. src/components/chat-interface.tsx - 무한 스크롤, 날짜 구분선 구현

API 스펙

// GET /api/config
{ message_batch_size: 30, max_messages_in_dom: 200 }

// GET /api/messages?before={timestamp}&limit=30
{ 
  messages: [...], 
  has_more: true 
}

주의사항

API 경로

# main.py에 직접 추가 (rb8001은 router 분리 없음)
@app.get("/api/config")
@app.get("/api/messages")

rb10508_micro 참조 코드

# rb10508_micro/app/config.py:101-103
MESSAGE_BATCH_SIZE: int = int(os.getenv("MESSAGE_BATCH_SIZE", 30))
SCROLL_THRESHOLD: int = int(os.getenv("SCROLL_THRESHOLD", 100))
MAX_MESSAGES_IN_DOM: int = int(os.getenv("MAX_MESSAGES_IN_DOM", 200))

구현 순서

  1. 백엔드 API 추가 (1시간)
  2. 프론트엔드 통합 (1시간)
  3. 테스트 및 배포 (30분)