DOCS/troubleshooting/250924_happybell80_UUID_체계_전환_및_대화저장_오류.md
happybell80 417332d9e5 docs: Gateway UUID 403 차단 구현 방안 업데이트
- 라우터 분리 아키텍처 문서화
- 파일 구조 및 핵심 로직 정리
- 영향 범위 명시
2025-09-24 14:46:37 +09:00

3.6 KiB

UUID 체계 전환 및 대화 저장 오류 해결

작성일: 2025-09-11

최종 수정일: 2025-09-24

작성자: happybell80


문제 상황

  1. PostgreSQL 테이블명 단수형 통일 후 발생한 연쇄 문제

    • conversation_log 테이블 id 자동증가 미작동
    • Slack ID를 UUID 필드에 저장 시도로 타입 오류
    • Gateway와 rb8001 간 UUID 전달 미구현
  2. 주요 오류 메시지

    - null value in column "id" of relation "conversation_log" violates not-null constraint
    - invalid input syntax for type uuid: "U09C98KBGHX"
    - 'MemoryManager' object has no attribute 'collection_name'
    - 'RobeingRouter' object has no attribute 'is_valid_uuid'
    

해결 과정

1. rb8001 UUID 체계 전환

  • app/router/router.py: X-User-Id 헤더 우선 사용 처리

2. conversation_log id 자동증가 해결

  • 테이블에 SERIAL 없어 MAX(id)+1로 수동 생성

3. Gateway Slack ID→UUID 변환

  • oauth_id와 oauth_provider='slack' 조건으로 조회

4. Slack Handler UUID 처리

  • X-User-Id 헤더에서 UUID 추출 및 context 저장

데이터 흐름 정리

Frontend → Gateway → rb8001

  1. JWT에서 UUID 추출: 3550cef6-63e1-4ceb-8802-a25c9d1c6917
  2. X-User-Id 헤더로 전달
  3. 정상 저장 및 조회

Slack → Gateway → rb8001

  1. Slack ID: U09C98KBGHX
  2. Gateway에서 oauth_id로 UUID 조회: 53529291-5050-4daa-89fb-008b546feb63
  3. X-User-Id 헤더로 전달
  4. 정상 저장 및 조회

수정된 파일

  • rb8001/app/router/router.py
  • rb8001/app/state/database.py
  • rb8001/app/router/slack_handler.py
  • robeing-gateway/app/main.py

결과 확인

  • 총 545개 대화 저장, NULL user_id 0개
  • 오늘 2개 저장: 김종태(53529291-5050-4daa-89fb-008b546feb63), frontend 사용자
  • Gateway UUID 변환 성공: Slack ID → UUID 정상 작동

추가 수정 사항

뉴스 중복 방지

  • skill-news fallback 제거: 새 뉴스 없을 때 API 호출 제거

헬스체크 로그 레벨 조정

  • DEBUG 레벨로 변경하여 로그 노이즈 감소

교훈

  • DB 스키마와 코드 모델 일치 필수
  • UUID 체계 전환 시 모든 경로 점검
  • 헤더 기반 인증 정보는 일관된 위치에서 처리

2025-09-24 Gateway UUID 변환 실패 시 403 차단

구현 방안: 라우터 분리

파일 구조

robeing-gateway/app/
├── routers/slack.py         # Slack 엔드포인트
├── services/slack_proxy.py  # UUID 변환 및 포워딩
└── exceptions.py            # UserNotRegisteredError

핵심 로직

  • url_verification: 항상 200 반환 (UUID 체크 제외)
  • 이벤트/인터랙티브: UUID 변환 실패 시 403 반환
  • X-User-Id 헤더: UUID 변환 성공 시에만 추가

영향 범위

  • 변경 없음: nginx, Slack 앱 설정, rb8001
  • 필수 작업: user 테이블에 oauth_id 사전 등록

2025-09-24 UUID 중심 원칙 확립

원칙

  • 모든 내부 로직은 UUID만 사용
  • Gateway가 UUID 변환 책임
  • UUID 없으면 403 차단

영향받는 서비스

  • rb8001:8001: X-User-Id 헤더 필수
  • Slack 인터랙티브: UUID 없으면 버튼 액션 실패
  • 예외: url_verification은 200 반환 필수

필수 작업

  1. Gateway에서 UUID 변환 실패 시 403 반환
  2. user 테이블에 Slack 사용자 사전 등록
  3. ChromaDB 검색 시 UUID만 사용
  • 디버깅 시간 단축 (명확한 에러로 원인 파악 용이)

관련 문제

  • Slack 요청은 OAuth 인증 없이 직접 /slack/events로 전송
  • JWT 토큰 없이 Slack 웹훅이 직접 호출
  • DB에서 oauth_id로 UUID 조회 시 oauth_provider='slack' 조건 필수