docs: 프론트백엔드 연결 및 workspace 전환 트러블슈팅 추가

This commit is contained in:
happybell80 2025-07-30 11:31:35 +09:00
parent 707ce92efa
commit e0366a18e4

View File

@ -0,0 +1,163 @@
# 프론트엔드-백엔드 연결 및 Company → Workspace 전환
**날짜**: 2025-07-30
**작업자**: happybell80 & Claude
**관련 프로젝트**: frontend-customer, auth-server
## 오전 10시 30분
### 프론트엔드 모바일 뷰포트 문제 해결
**문제점**:
- 모바일에서 채팅창이 16:9 비율로 고정되어 본문이 2-3개 메시지만 표시됨
- `aspect-video` 클래스로 인한 높이 제한
**해결 방안** (Sequential Design 분석):
1. 모바일에서 aspect-video 제거
2. 전체 높이 활용하도록 변경
3. 최대 너비 600px, 최소 높이 300px 설정
**수정 내용**:
```tsx
// game-layout.tsx
// 변경 전
<div className="w-full aspect-video max-h-full">
// 변경 후
<div className="w-full h-full min-h-[300px] max-w-[600px] mx-auto">
```
**추가 최적화**:
- 채팅 인터페이스 패딩/간격 모바일 최적화
- 헤더, 메시지, 입력창 컴팩트하게 조정
## 오전 10시 45분
### 프론트엔드-백엔드 연결 아키텍처 재검토
**초기 잘못된 이해**:
- 각 로빙이 자체 프론트엔드를 포함한다고 생각
- 로빙 컨테이너 내부에 프론트엔드를 통합하려 시도
**올바른 아키텍처**:
```
51123 서버 (프론트엔드)
├── frontend-customer (중앙 집중식)
├── 항상 켜져있음
└── 여러 로빙 API와 통신
51124 서버 (로빙들)
├── rb8001 (경량 API only)
├── rb10508_test (경량 API only)
├── rb10408 (경량 API only)
└── 레벨업 시 재시작 가능
```
**핵심 이유**:
1. 로빙 레벨업 시 컨테이너 재시작 → 프론트엔드 끊김 방지
2. 로빙 컨테이너 경량화 유지
3. UX 연속성 보장
## 오전 11시 00분
### 사용자-로빙 매핑 플로우 설계
**Sequential Design 분석 결과**:
- 현재 auth-server에 사용자-로빙 매핑 테이블 없음
- 개별 사용자 정보 저장 테이블 없음
- JWT/세션 기반 인증만 존재
**필요한 DB 확장**:
1. `users` 테이블: 개별 사용자 정보
2. `workspace_members` 테이블: 사용자-워크스페이스-로빙 매핑
3. `workspaces` 테이블: companies 테이블 이름 변경
**개발 우선순위**:
1. auth-server 데이터 모델 확장
2. 로빙 할당 API 구현
3. 프론트엔드 Auth Context 확장
4. 프론트엔드-로빙 연결
## 오전 11시 15분
### Company → Workspace 용어 변환
**변환 이유**:
- "Company"는 개인 사용자에게 부적합
- "Workspace"는 개인/기업 모두에게 자연스러움
- Slack, Notion 등 이미 검증된 용어
**DB 모델 생성**:
1. `app/models/user.py` - User, WorkspaceMember 모델
2. `app/models/workspace.py` - Workspace 모델 (Company 대체)
3. `migrations/add_user_workspace_tables.sql` - 마이그레이션 SQL
**새로운 테이블 구조**:
```sql
-- users 테이블
CREATE TABLE users (
id UUID PRIMARY KEY,
email VARCHAR(255) UNIQUE NOT NULL,
name VARCHAR(255),
oauth_provider VARCHAR(50),
...
);
-- workspace_members 테이블
CREATE TABLE workspace_members (
workspace_id UUID REFERENCES workspaces(id),
user_id UUID REFERENCES users(id),
role VARCHAR(50),
robing_id VARCHAR(100), -- 할당된 로빙
...
);
```
## 오전 11시 25분
### Company → Workspace 변환 작업
**Sequential Design 분석으로 영향받는 파일 파악**:
1. `app/api/companies.py``app/api/workspaces.py`
2. `app/providers/slack.py` - OAuth 처리
3. `app/api/slack_router.py` - Slack 이벤트 라우팅
4. `app/db/init_db.py` - DB 초기화
5. `app/main.py` - 라우터 등록
**변환 작업**:
1. `company.py` 파일 삭제
2. 모든 import 문 변경
3. 변수명/함수명 변경 (company → workspace)
4. API 엔드포인트 경로 변경
**API 엔드포인트 변경**:
```
/api/companies → /api/workspaces
/api/companies/{company_id} → /api/workspaces/{workspace_id}
/api/companies/subdomain/{subdomain} → /api/workspaces/subdomain/{subdomain}
```
## 교훈
1. **아키텍처 이해의 중요성**
- 초기에 잘못 이해하면 큰 시간 낭비
- 프론트엔드와 백엔드 분리 이유를 명확히 파악
- 컨테이너 재시작과 UX 연속성 고려
2. **Sequential Design의 효과**
- 체계적인 분석으로 누락 요소 발견
- 의존성 파악으로 올바른 개발 순서 결정
- 영향 범위 파악으로 안전한 변환
3. **용어 선택의 중요성**
- 개인/기업 모두를 포괄하는 용어 선택
- 업계 표준 용어 사용 (Workspace)
- 일관성 있는 변환 작업
4. **DB 설계 우선**
- 데이터 모델이 없으면 기능 구현 불가
- 사용자-로빙 매핑은 핵심 요구사항
- 마이그레이션 스크립트 미리 준비
---
**작성 완료**: 2025-07-30 11:30