hgzero/design/backend/sequence/inner/meeting-충돌해결.puml
ondal 715add4dbc 외부/내부 시퀀스 설계 일관성 개선 및 표준화
주요 변경사항:

[Critical]
- API 엔드포인트 통일: POST /api/minutes/{minutesId}/finalize
- 이벤트 이름 표준화: MinutesFinalized

[Warning]
- API Gateway 라우팅 규칙 문서화 (외부 시퀀스 7개 파일)
- 대시보드 API 경로 통일: GET /api/dashboard
- AI 제안 병합 프로세스 상세 문서화
- 회의록 확정 검증 로직 5단계 상세화

[Minor]
- Redis 캐시 TTL 명시 (7개 파일, TTL 정책 표준화)
- 대시보드 페이지네이션 파라미터 추가
- 에러 응답 포맷 표준화 (14개 에러 응답)

총 31개 파일 수정, 34건의 개선 사항 적용

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-10-23 09:48:06 +09:00

93 lines
2.1 KiB
Plaintext

@startuml
!theme mono
title 충돌 해결 내부 시퀀스
participant "WebSocket<<E>>" as WebSocket
participant "CollaborationController" as Controller
participant "CollaborationService" as Service
participant "ConflictResolver" as Resolver
participant "TranscriptService" as TranscriptService
database "Redis Cache<<E>>" as Cache
queue "Event Hub<<E>>" as EventHub
WebSocket -> Controller: onConflict(conflictData)
activate Controller
Controller -> Service: resolveConflict(meetingId, conflictData)
activate Service
Service -> Cache: get(meeting:{id}:conflicts)
activate Cache
note right of Cache
충돌 목록 조회:
- 발생 시간
- 관련 사용자
- 충돌 영역
end note
Cache --> Service: conflictList
deactivate Cache
Service -> Resolver: analyzeConflict(conflictData)
activate Resolver
Resolver -> Resolver: detectConflictType()
note right of Resolver
충돌 유형 분석:
- 동일 위치 수정
- 삭제-수정 충돌
- 순서 변경 충돌
end note
Resolver -> Resolver: applyStrategy()
note right of Resolver
해결 전략:
- 자동 병합 (단순 충돌)
- 최신 우선 (시간 기반)
- 수동 해결 필요 (복잡)
end note
Resolver --> Service: resolutionResult
deactivate Resolver
alt auto-resolved
Service -> TranscriptService: applyResolution(meetingId, resolution)
activate TranscriptService
TranscriptService --> Service: mergedContent
deactivate TranscriptService
Service -> Cache: del(meeting:{id}:conflicts)
activate Cache
Cache --> Service: OK
deactivate Cache
else manual-required
Service -> Cache: SET meeting:{id}:conflicts\n(TTL: 1시간)
activate Cache
note right of Cache
충돌 정보 캐싱:
- TTL: 1시간
- 충돌 정보 저장
- 수동 해결 대기
end note
Cache --> Service: OK
deactivate Cache
end
Service ->> EventHub: publish(ConflictResolvedEvent)
activate EventHub
note right of EventHub
이벤트 발행:
- 자동 해결: 동기화
- 수동 필요: 알림
end note
deactivate EventHub
Service --> Controller: ResolutionResponse
deactivate Service
Controller --> WebSocket: send(resolution)
deactivate Controller
@enduml