3.6 KiB
3.6 KiB
UUID 체계 전환 및 대화 저장 오류 해결
작성일: 2025-09-11
최종 수정일: 2025-09-24
작성자: happybell80
문제 상황
-
PostgreSQL 테이블명 단수형 통일 후 발생한 연쇄 문제
- conversation_log 테이블 id 자동증가 미작동
- Slack ID를 UUID 필드에 저장 시도로 타입 오류
- Gateway와 rb8001 간 UUID 전달 미구현
-
주요 오류 메시지
- 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
- JWT에서 UUID 추출:
3550cef6-63e1-4ceb-8802-a25c9d1c6917 - X-User-Id 헤더로 전달
- 정상 저장 및 조회
Slack → Gateway → rb8001
- Slack ID:
U09C98KBGHX - Gateway에서 oauth_id로 UUID 조회:
53529291-5050-4daa-89fb-008b546feb63 - X-User-Id 헤더로 전달
- 정상 저장 및 조회
수정된 파일
- 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 반환 필수
필수 작업
- Gateway에서 UUID 변환 실패 시 403 반환
- user 테이블에 Slack 사용자 사전 등록
- ChromaDB 검색 시 UUID만 사용
- 디버깅 시간 단축 (명확한 에러로 원인 파악 용이)
관련 문제
- Slack 요청은 OAuth 인증 없이 직접
/slack/events로 전송 - JWT 토큰 없이 Slack 웹훅이 직접 호출
- DB에서 oauth_id로 UUID 조회 시 oauth_provider='slack' 조건 필수