ICE ( Interactive Connectivity Establishment ) 프레임워크로 STUN, TURN 서버를 통해 상대 Peer에 유동적으로 연결
프론트엔드 프레임워크 : Vue 사용
데스크탑, 모바일별 별도 레이아웃 제공
방 번호 입력부분 랜덤 버튼 클릭시 랜덤 UUID 생성 후 자동으로 서버에 중복확인 요청
랜덤 대신 수동으로 직접 입력도 가능
data:image/s3,"s3://crabby-images/e63cf/e63cf3cdbc6049beb1c984ff665525a62e693948" alt=""
data:image/s3,"s3://crabby-images/db5a3/db5a3b043e2d1c98daf9b86c6358796eeafe6721" alt=""
WebRTC DataChannel을 통해 텍스트 기반 통신 활용
우측 상단 버튼을 통해 해당 화면 진입시 PIP모드가 가능한 환경일경우 PIP 모드 실행
data:image/s3,"s3://crabby-images/5d663/5d663d10bd773caa22b73faaa540e212d2f020c0" alt=""
npm install
npm run build
1-1. HTML, JS, CSS 파일 요청 처리
1-2. PWA ( Progessive Web App ) 적용을 위한 manifest.json 파일 요청 처리
1-3. 추가 PWA asset ( 앱 아이콘, 스크린샷 등 ) 파일 요청 처리
1-4. .well-known 내부 파일 요청 처리
2-1. Room 사용자들의 WebRTC SDP ( Session Description Protocol : offer / answer / candidate ) 교환
2-2. 기타 정보 ( login, logout, randomCheck ) 교환
{type, from, to, data} 형태로 메세지를 보내고 받음
예시)
offer) => to 방의 모든 사용자
{ type: 'offer', from: 'my-sessionId', to: '', data: 'WebRTC offer' }
answer) => to 방의 특정 사용자
{ type: 'answer', from: 'my-sessionId', to: 'target-sessionId', data: 'WebRTC answer' }
candidate) => to 방의 특정 사용자
{ type: 'candidate', from: 'my-sessionId', to: 'target-sessionId', data: 'WebRTC candidate' }
※STUN 서버는 클라이언트 측에서 Google의 STUN 서버를 우선 사용
( /SSL 폴더에 cert1.pem, privkey1.pem, chain1.pem 파일이 필요합니다. - HTTPS 서버용 키 / 별도 발급 필요 )
npm install
node app.js