# 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 컨테이너 간 통신시 네트워크 설정 확인 필요