mirror of
				https://github.com/pion/webrtc.git
				synced 2025-10-26 00:30:35 +08:00 
			
		
		
		
	 0ecbcfeb4f
			
		
	
	0ecbcfeb4f
	
	
	
		
			
			Demonstrate how using the new ICEUDPMux multiple PeerConnections can be served via a single port.
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <html>
 | |
|   <head>
 | |
|     <title>ice-single-port</title>
 | |
|   </head>
 | |
| 
 | |
|   <body>
 | |
|     <h3> ICE Selected Pairs </h3>
 | |
|     <div id="iceSelectedPairs"></div> <br />
 | |
|   </body>
 | |
| 
 | |
|   <script>
 | |
|     let createPeerConnection = () => {
 | |
|       let pc = new RTCPeerConnection()
 | |
|       let dc = pc.createDataChannel('data')
 | |
| 
 | |
|       dc.onopen = () => {
 | |
|         let el = document.createElement('template')
 | |
|         let selectedPair = pc.sctp.transport.iceTransport.getSelectedCandidatePair()
 | |
| 
 | |
|         el.innerHTML = `<div>
 | |
|           <ul>
 | |
|              <li> <i> Local</i> - ${selectedPair.local.candidate}</li>
 | |
|              <li> <i> Remote</i> - ${selectedPair.remote.candidate} </li>
 | |
|           </ul>
 | |
|         </div>`
 | |
| 
 | |
|         document.getElementById('iceSelectedPairs').appendChild(el.content.firstChild);
 | |
|       }
 | |
| 
 | |
|       pc.createOffer()
 | |
|         .then(offer => {
 | |
|           pc.setLocalDescription(offer)
 | |
| 
 | |
|           return fetch(`/doSignaling`, {
 | |
|             method: 'post',
 | |
|             headers: {
 | |
|               'Accept': 'application/json, text/plain, */*',
 | |
|               'Content-Type': 'application/json'
 | |
|             },
 | |
|             body: JSON.stringify(offer)
 | |
|           })
 | |
|         })
 | |
|         .then(res => res.json())
 | |
|         .then(res => pc.setRemoteDescription(res))
 | |
|         .catch(alert)
 | |
|     }
 | |
| 
 | |
|     for (i = 0; i < 10; i++) {
 | |
|       createPeerConnection()
 | |
|     }
 | |
|   </script>
 | |
| </html>
 |