1682 Commits

Author SHA1 Message Date
happybell80
e38b337832 docs: Slack 봇 설치 오류 문서 수정 (완벽한 지시서로)
- 해결 방안: 구체적인 수정 위치 및 내용 명시
- 교훈: Raw SQL 위험성, ORM 사용 권장 추가
- 코드 블록 제거, 파일명:줄번호 형식 준수

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-15 18:33:07 +09:00
1068b3d0a2 docs: Slack 봇 설치 workspace_id 컬럼 오류 트러블슈팅
문제: workspace_member 테이블에 존재하지 않는 workspace_id 컬럼 조회 시도
원인: DB 스키마 변경 후 slack.py:408-413 쿼리 미반영
해결: user.team_id 직접 조회로 수정 필요 (로컬 개발자)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-15 18:24:24 +09:00
happybell80
0be1548ccc docs: Slack Lists 동적 매핑 및 LLM 에러 복구 해결 방안 추가
- Slack Lists 컬럼 조회 API + 동적 매핑으로 하드코딩 제거
- LangGraph 체크포인트 + LLM 기반 에러 분석 노드 추가
- 페이로드 수정 후 재시도 구조 설계

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-15 13:06:47 +09:00
happybell80
893e613981 docs: FastAPI 구조 원칙에 LangGraph 워크플로우 규칙 추가
- 복잡한 다단계 처리는 LangGraph 적극 활용
- 체크포인트 필수 (PostgresSaver)
- stateless 금지 (프레임워크 가치 없음)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-15 12:39:19 +09:00
happybell80
8a8a56484f Merge branch 'main' of https://git.ro-being.com/ivada_Ro-being/DOCS 2025-10-15 12:34:40 +09:00
Claude-51124
0adf06aa41 docs: IR 분석 실패 원인 분석 문서 추가
- 251015_claude_coldmail_ir_analysis_failure.md: IR 분석 실패 근본 원인 및 해결 방안 (99줄)
- 251015_claude_coldmail_workflow_langgraph_test.md: 문제 4 섹션 분리, 참조 링크 추가

PDF 업로드 실패 → RAG 검색 0건 → IR 분석 "N/A" → Lists API 에러 연쇄 효과 분석.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-15 12:32:24 +09:00
happybell80
d2120d93a9 docs: 시스템 메트릭 문서 미해결 섹션 제거 및 해결 완료 표시
- "미해결 문제" → "최종 해결 (2025-07-15)"
- Prometheus + Grafana 대체 사실 명시
- frontend-base/backend/metrics_database.py 참조 추가
- "후속 작업" 섹션 삭제 (완료됨)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-15 12:17:47 +09:00
6a61fba2b7 docs: Slack 사용자 403 team 매핑 불일치 해결
- U09BQSLB11R, U09DWLARFQQ 403 Forbidden 이슈
- slack_workspace.team_id와 user.team_id 불일치 원인
- database.py:363-369 JOIN 실패 분석
- 사용자 팀 변경으로 해결 (Robeing → Company-X)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-15 12:12:10 +09:00
Claude-51124
18d5309d2d docs: 100줄 이하로 축소 및 추측 제거
128줄 → 95줄
- 불필요한 설명 제거
- 핵심 사실만 기록
- 추측 내용 삭제
2025-10-15 00:14:44 +09:00
Claude-51124
a071f8b159 docs: 문서 작성 원칙 준수하도록 수정
- 파일 크기 222줄 → 128줄 (100줄 이하 목표)
- 코드 블록 최소화 (파일명:줄번호로 대체)
- 파일 참조 일관성 개선
2025-10-15 00:13:34 +09:00
Claude-51124
319677af2e Merge branch 'main' of https://git.ro-being.com/ivada_Ro-being/DOCS 2025-10-15 00:11:39 +09:00
Claude-51124
f4cd53257b docs: Coldmail workflow LangGraph 테스트 트러블슈팅
- Docker 빌드 dependency resolution 타임아웃 해결 (openai>=1.110.0)
- Slack 401 에러 해결 (토큰 워크스페이스 불일치 + API Key 누락)
- PDF 업로드 중복 파일 처리 (PostgreSQL 직접 삭제)
- Lists API 통합 테스트 결과 및 IR 분석 실패 이슈
- 교훈 및 남은 작업 정리
2025-10-15 00:11:33 +09:00
happybell80
7a2c722bb8 refactor: 문서에서 불필요한 코드 블록 제거
- 파일명:줄번호만 명시 (코드 블록 제거)
- 223줄 → 195줄 (28줄 감소)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 23:43:02 +09:00
happybell80
9e04b83707 docs: SSHFS 긴 파일명 해결 방안 구현 완료 반영
- skill-rag-file 커밋 dfe6978 반영
- upload.py 수정 완료 표시
- coldmail workflow 재테스트 대기

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 23:41:39 +09:00
Claude-51124
1b6a0b3140 docs: SSHFS 긴 파일명 처리 실패 이슈 추가
- coldmail workflow PDF 업로드 500 에러 원인 파악
- OSError [Errno 74] Bad message: 파일명 길이 제한
- 해결 방안: document_id 기반 파일명으로 변경

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 23:38:53 +09:00
happybell80
504bb6f399 docs: 콜드메일 IR 분석 시나리오 완료 문서화
- 구현 계획 섹션 제거 (모두 완료됨)
- 최종 테스트 및 배포 상태 추가
- 리팩토링 커밋 이력 추가 (6777165, fd89d8d, 28ef36c)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 23:28:03 +09:00
happybell80
e94146dc08 docs: 우선순위 2,3,4 완료 반영
- 커밋 해시 추가: 0ef3489, c2ac162
- 각 우선순위별 완료 표시 및 파일:줄번호
- 교훈 추가: LangGraph 직렬화, DRY + 파일 크기 제한

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:52:51 +09:00
happybell80
8431340ae2 docs: LangGraph 워크플로우 테스트 완료 추가
- rb8001/tests/test_langgraph_workflow.py 검증 완료
- State 필드, 노드 플로우, 조건부 엣지 테스트 완료
- 97줄 유지

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:43:08 +09:00
happybell80
81e2e22ac3 docs: 의사코드 제거, 파일:줄번호 + 함수 시그니처만 명시
- 의사코드 제거 (문서 작성 원칙 준수)
- 함수 시그니처, 반환 타입만 명시
- 파일명:줄번호 참조 간결화
- 97줄 유지

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:41:25 +09:00
happybell80
ba38062b6a docs: LangGraph 워크플로우 코드 원칙 준수 (파일 분리, 위치 수정)
- app/workflows/ → app/services/workflows/ (311 FastAPI 구조 원칙)
- coldmail_email_fetcher.py 생성 (fetch 로직 분리)
- coldmail_processor.py 생성 (process 로직 분리)
- 노드에서 기존 services 함수 재사용 (DRY 원칙)
- coldmail_briefing.py 최종 206줄 (300줄 제한 준수)
- 98줄 유지

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:38:37 +09:00
happybell80
7871542014 docs: ColdmailState에 user_id, start_time, now 필드 추가
- ColdmailState에 user_id: str, start_time: str, now: str 추가
- coldmail_briefing.py:86-101 유지 (user_id, start_time, now 계산)
- initial_state에 user_id, start_time.isoformat(), now.isoformat() 포함
- 각 노드에서 state["user_id"], state["start_time"], state["now"] 접근
- send_summary_node에서 datetime.fromisoformat() 변환
- 96줄 유지

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:36:54 +09:00
happybell80
4e8a85c23f docs: LangGraph 워크플로우 session 처리 및 조건부 엣지 추가
- ColdmailState에서 session 제거 (직렬화 불가)
- 각 노드에서 async with aiohttp.ClientSession() 개별 생성
- route_after_filter 함수 추가
- add_conditional_edges로 filter → END or process 분기
- process 노드에서 for 루프로 여러 이메일 처리
- try-except로 IR 실패 시 continue 명시
- 96줄 유지

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:34:09 +09:00
happybell80
b0ddfc0dc4 docs: 콜드메일 시나리오 줄번호 검증 및 LangGraph 구체화
- 우선순위 2: ir_analyzer.py:155 JSON 전처리 로직 구체화
- 우선순위 3: coldmail_briefing.py:188,291 정확한 위치 검증
- 우선순위 4: LangGraph StateGraph, 노드, 엣지 구현 방법 명시
- 구현 완료 섹션 축약 (7줄로 압축)
- 분석 결과 예시 1줄로 축약
- 95줄 (100줄 이하 준수)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:28:31 +09:00
happybell80
b6a60d725c docs: 콜드메일 시나리오 구현 계획 상세화
- 우선순위 1: Lists 파일 첨부 완료 표시
- 우선순위 2: ir_analyzer.py:155 JSON 전처리 구체화
- 우선순위 3: coldmail_briefing.py:144,176,291 수정 위치 명시
- 우선순위 4: LangGraph 워크플로우 구조 정의
- 미구현/버그 섹션 제거 (구현 계획에 통합)
- 교훈 간소화, 100줄 이하 유지

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:25:35 +09:00
Claude-51124
1942d68df5 docs: 콜드메일 IR 분석 시나리오 테스트 결과 반영
- 우선순위 1 완료 표시 (Slack Lists 파일 첨부)
- 우선순위 3 줄번호 수정: 255 → 291
- probability → confidence 수정 (ValuationResult 실제 속성)
- 베이지안 투자 확률 → 밸류에이션 및 신뢰도로 수정
- 95줄 (100줄 이하 유지)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:11:54 +09:00
happybell80
d8432ca542 docs: Slack Lists 파일 첨부 구현 완료로 업데이트
- 구현 완료 섹션: 커밋 정보, 테스트 결과 추가
- 교훈 → 참고로 변경, 사실만 나열
- 향후/예상 표현 제거

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 22:00:50 +09:00
happybell80
a9bcc712bd docs: X-API-Key 헤더, 파일 메타, MIME 타입, 컬럼 ID 동적 매핑 보완 2025-10-14 21:43:05 +09:00
happybell80
2e7cee0b84 docs: 1-2단계 API 구현 세부사항 보충 (DB 접근, 에러 핸들링, import) 2025-10-14 21:37:06 +09:00
happybell80
cb7e728349 docs: Slack Lists 파일 첨부 3단계 구체화 및 81줄로 축소 2025-10-14 21:33:22 +09:00
happybell80
34dd99d90c docs: Slack Lists 파일 첨부 해결 방안 구체화 및 100줄 이하 준수 2025-10-14 21:30:23 +09:00
happybell80
932f54b83a docs: Slack Lists 파일 첨부 우선순위 1로 상향 2025-10-14 21:26:39 +09:00
happybell80
cb37b797f7 docs: LangGraph 적용 계획 추가 (우선순위 4) 2025-10-14 21:24:48 +09:00
happybell80
ce573f522f docs: IR 자동 분석 시나리오 구현 계획 구체화 및 100줄 이하 준수 2025-10-14 21:22:18 +09:00
Claude-51124
54782ac8be docs: Slack Lists 파일 첨부 테스트 결과 및 문서 작성 원칙 준수
- 100줄 이하로 축소 (153줄 → 84줄)
- 이모지 제거
- 테스트 파일 위치 skill-slack/tests/로 수정
- 교훈 섹션 유지

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 21:10:23 +09:00
1ff7c14ce0 Add 51123 centroid initialization and performance analysis
- pgvector extension 설치 완료
- coldmail_embedding_clusters 테이블 생성 및 초기화
- 160개 샘플로 centroid 계산 (coldmail 80, normal 80)
- 임베딩 필터 성능 테스트: 75% 정확도
- 웹 검색 기반 개선 방안 조사 (2025 최신 기법)
- 결론: 하이브리드 접근(임베딩 1차 → LLM 2차) 적합

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 16:47:16 +09:00
Claude-51124
8cbf999ad5 docs: coldmail 하이브리드 필터 구현 완료 및 임베딩 이슈 문서화
- 구현 완료: 임베딩/LLM/Naive Bayes 3단계 하이브리드
- 임베딩 필터 이슈: centroid 샘플에 파일명 형식 미포함으로 실패
- 현재: LLM fallback 작동 (100% 정확도)
- 학습 루프: Naive Bayes 동적, 임베딩 정적

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 16:43:50 +09:00
happybell80
badbf93be3 docs: coldmail DB 초기 데이터 설정 완료 반영
- pgvector extension 설치 완료 표시
- coldmail_embedding_clusters 초기 데이터 저장 완료
- centroid 상세: coldmail 36단어 평균, normal 20단어 평균, 각 384차원
- 구현 준비 완료 상태

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 16:16:27 +09:00
happybell80
75f2a850e4 docs: coldmail DB 테이블 구조 상세화
- coldmail_embedding_clusters 스키마 명시: UUID PRIMARY KEY, VECTOR(384)
- 초기 데이터: coldmail/normal centroid 2개 (coldmail_classifier 56단어 기반)
- 목적 명확화: 의미 유사도 비교용 정적 참조점 (학습 안함)
- coldmail_classifier와 독립: 단어 빈도(동적) vs 벡터 중심점(정적), 서로 참조 없음
- 서버 위치: 51123 (기존 coldmail_classifier와 동일)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 16:05:22 +09:00
happybell80
72bb66b8eb docs: coldmail 하이브리드 필터 구현 계획 정교화
- Phase 1: skill-embedding(8515) /embed 엔드포인트, 384차원 명시
- Phase 2: Gemini gemini-2.5-flash-lite 모델명 추가
- Phase 3: coldmail_filter.py:44-52 정규식 교체 위치 명시
- Phase 4: scheduler→services 리팩토링 상세화 (76-263줄, 8단계 워크플로우)
- DB: pgvector extension, coldmail_embedding_clusters 스키마 추가
- 환경변수: SKILL_EMBEDDING_URL 참조 파일 명시

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 15:56:28 +09:00
Claude-51124
3138475f72 docs: coldmail 필터 테스트 검증 완료 (Phase 1-3)
- Phase 1: 임베딩 유사도 테스트 (384차원, coldmail 0.204 > normal 0.156)
- Phase 2: Gemini LLM 분류 테스트 (100% 정확도)
- Phase 3: 하이브리드 통합 테스트 (3단계 순차 실행)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 15:31:43 +09:00
Claude-51124
5e52e7c832 docs: 문서 오류 수정 (임베딩 차원 768→384, 파일명 오류)
- Phase 1 DB 테이블: VECTOR(768) → VECTOR(384)
  (skill-embedding 실제 모델: multilingual-MiniLM-L12-v2, 384차원)
- 구현 완료: test_coldmail_filter.py → test_coldmail_briefing.py

테스트 결과:
- skill-embedding (8515) 정상
- 모델: multilingual-MiniLM-L12-v2
- 차원: 384

Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 15:26:22 +09:00
Claude-51124
4dc8bf3e4c docs: troubleshooting 문서 통합 (plans 삭제, 102줄)
- plans/251014_claude_coldmail_hybrid_implementation.md 삭제
- troubleshooting/251014_claude_coldmail_filter_tokenization_issue.md 통합
  - 문제 분석 + 해결 방안 + 구현 계획 + 교훈 (102줄)
  - 코드 블록 최소화, 파일명:줄번호로 참조
  - 구현 완료 섹션 추가 (커밋 7c5b033)

문서 작성 원칙 준수 (100줄 이하, 주제별 분리 대신 축약)

Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 15:18:56 +09:00
happybell80
d26bada28b docs: 문서 작성 원칙 준수 - 중복 제거 및 간결화 2025-10-14 15:08:23 +09:00
happybell80
96170c9888 docs: 문서 작성 원칙 준수 - 파일명:줄번호 형식 수정
- 코드 블록 제거, 파일명:줄번호로 대체
- scripts/download_recipe_images.cjs:37,41-44,53
- src/pages/LunchWorldcup.tsx:177,213,252,189,195,201,235,286,311,231
- 312_문서_작성_원칙.md 준수

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 15:07:12 +09:00
happybell80
2d7c31216f docs: 점심 월드컵 이미지 교체 및 색상 통일 해결 내용 추가
- 만개의 레시피 크롤링 방법 추가
- purple-pink 브랜드 컬러 통일 내역 기록
- 커밋 해시 참조 추가

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 15:05:27 +09:00
happybell80
400243cd4a docs: 나무위키 이미지 크롤링 실패 트러블슈팅
- Playwright 크롤링 시도 → 7/15 성공, 8/15 실패
- SVG 플레이스홀더 이미지 다운로드 (실제 음식 사진 아님)
- 타임아웃 3건, 이미지 없음 4건
- 교훈: 저작권 명확한 소스(Pixabay/Unsplash) 사용 필수
- 다음 단계: download_korean_pixabay.sh 실행

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 13:18:46 +09:00
Claude-51124
bf6873a2f0 docs: 문서 작성 원칙 준수 (100줄 이하 분리, 코드 블록 최소화)
- troubleshooting: 분석 문서 (129줄)
  - 문제 상황 및 근본 원인
  - 3단계 하이브리드 아키텍처
  - 기술 선택 근거 및 교훈
- plans: 구현 계획 문서 (94줄)
  - Phase별 상세 작업 내용
  - DB 스키마 및 함수 설계
  - 테스트 케이스 및 일정

코드 블록 대신 파일명:줄번호로 참조 변경

Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 13:07:29 +09:00
Claude-51124
8fa7298150 docs: Coldmail 필터 토큰화 문제 분석 및 KoBERT+LLM+Bayes 하이브리드 개선 방안
- 9시 5분 IR deck 미전송 원인 분석 완료
- 근본 원인: 정규식 토큰화의 한국어 형태소 분리 실패
- 해결책: 3단계 하이브리드 아키텍처 제안
  1단계: KoBERT 임베딩 (고속 필터링, 90%)
  2단계: Gemini LLM (정밀 분류, 10%)
  3단계: Naive Bayes (실시간 학습)
- 구현 계획 및 예상 시간(12h) 포함

Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 13:01:14 +09:00
happybell80
72fb4a1072 docs: Slack Lists 문서에 전체 시나리오 참조 추가
- 전체 시나리오: 251014_coldmail_ir_analysis_scenario.md
- 문제 상황에 전체 목표 명시 (IR 분석 → 평가 → 확률 → 보고서)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 01:32:21 +09:00
happybell80
6268e13b70 docs: 콜드메일 IR 자동 분석 전체 시나리오 추가
- 최종 목표: 평일 9시 5분 자동 IR 분석 → Slack 보고서
- 구현 완료: 파일 처리, AI 분석, Slack 통합
- 미구현: LLM JSON 파싱, 파일 첨부, 분석 메시지 포맷
- 분석 예시: 굿베이션 투자 확률 0% (베이지안)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-14 01:30:56 +09:00