diff --git a/troubleshooting/250920_news_db_persistence_implementation.md b/troubleshooting/250920_news_db_persistence_implementation.md new file mode 100644 index 0000000..b1a734e --- /dev/null +++ b/troubleshooting/250920_news_db_persistence_implementation.md @@ -0,0 +1,71 @@ +# News 시스템 DB 영속화 구현 완료 + +## 개요 +- **일시**: 2025-09-20 +- **작업자**: Claude Code +- **목표**: News 시스템에 DB 영속화 기능 구현 (Phase 3) +- **결과**: ✅ 성공 + +## 구현 내용 + +### 1. rb_news 테이블 생성 +```sql +CREATE TABLE IF NOT EXISTS rb_news ( + id UUID PRIMARY KEY DEFAULT gen_random_uuid(), + title TEXT NOT NULL, + url TEXT NOT NULL UNIQUE, + summary TEXT, + slack_message_ts VARCHAR(100), + slack_channel_id VARCHAR(100), + is_published BOOLEAN DEFAULT FALSE, + published_at TIMESTAMP WITH TIME ZONE, + created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW() +); +``` + +### 2. NewsPostingSkill 수정 +- `save_news_to_db()` 메소드 추가: 뉴스를 DB에 저장 +- `update_news_published_status()` 메소드 추가: 게시 완료시 상태 업데이트 +- PostgreSQL 연결 설정 추가 + +### 3. 테스트 엔드포인트 추가 +- `/api/schedule/test-news`: 뉴스 수집 및 DB 저장 테스트용 + +## 문제 해결 과정 + +### 문제 1: skill-news API 파라미터 오류 +- **증상**: "queries" 필드 사용으로 400 에러 +- **원인**: API가 "keywords" 필드를 요구 +- **해결**: rb8001 코드는 이미 올바른 "keywords" 사용 중 + +### 문제 2: 뉴스가 0개 반환 +- **증상**: skill-news가 뉴스를 찾았지만 "새 기사 0개" 반환 +- **원인**: companyx_news_posting.json에 이미 수집된 기사로 저장됨 +- **해결**: 캐시 파일 초기화 + - `/app/data/sent_news.json` 초기화 + - `/app/data/companyx_news_posting.json` 백업 후 초기화 + +## 테스트 결과 +``` +ID: 0727dbfe-b04b-4dfc-83d1-7adc74351608 +Title: 악어에듀, 2025 에듀테크 코리아서 글로벌혁신 부문 수상... +URL: https://www.ajunews.com/view/20250919134944158 +Published: False, Channel: C09C98KK2TT +Created: 2025-09-20 11:54:42.541580+09:00 +``` + +## 작동 흐름 +1. rb8001이 skill-news API 호출하여 뉴스 수집 +2. Slack 채널에 인터랙티브 메시지 게시 +3. 동시에 rb_news 테이블에 저장 (is_published=False) +4. 사용자가 "게시하기" 버튼 클릭시 is_published=True로 업데이트 + +## 주의사항 +- DM으로 보내는 뉴스는 DB에 저장하지 않음 (채널 게시만 저장) +- skill-news의 캐시로 인해 중복 뉴스는 반환되지 않음 +- 환경변수 COMPANY_X_NEWS_KEYWORDS는 쉼표로 구분된 키워드 사용 + +## 교훈 +- API 문서 없이 작업시 실제 엔드포인트 테스트로 파라미터 확인 필요 +- 캐시 시스템이 있는 경우 테스트시 캐시 초기화 고려 +- Docker 컨테이너 간 통신시 네트워크 설정 확인 필요 \ No newline at end of file