SyntaxError при отправке удаленных ледяных кандидатов в WebRTC

Я использую сервер SimpleSignalling для соединения двух узлов. Основной процесс:

PubNub транслирует создание узла A

pubnub.subscribe( {
      channel : 'mimis/peer/awaken',
      message : function( msg ) {
          var dest_uid = msg
          if( server.uid() != dest_uid ) {
              onawaken( dest_uid )
          }
      },
  } )

Peer B создает новое PeerConnection

function onawaken( uid ) {
    var servers = null
    connections[uid] = new webkitRTCPeerConnection( servers,
                                                    { optional: [{ RtpDataChannels: true }] } )

    function gotCandidate( event ) {
        if( event.candidate ) {
            server.send( event.candidate, uid, server.room() )
        }
    }
    connections[uid].onicecandidate = gotCandidate

    try {
        channels[uid] = connections[uid].createDataChannel( "mimisChannel",
                                                            { reliable: false } )
    } catch (e) {
        console.error( 'Failed to create data channel. ' +
                       'You need Chrome M25 or later with RtpDataChannel enabled' )
    }

    function gotLocalDescription( desc ) {
        connections[uid].setLocalDescription( desc )
        server.send( desc, uid, server.room() )
    }

    connections[uid].createOffer( gotLocalDescription )
}

PeerConnection создает ответ

function onoffer( offer, uid ) {
    connections[uid] = new webkitRTCPeerConnection( servers,
                                                    { optional: [{ RtpDataChannels: true }] } )

    function gotRemoteDescription( desc ) {
        connections[uid].setRemoteDescription( desc )
        server.send( desc, uid, server.room() )
    }

    connections[uid].createAnswer( gotRemoteDescription )

    function gotReceiveChannel( event ) {
        channels[uid] = event.channel
    }

    connections[uid].ondatachannel = gotReceiveChannel
}

Кандидаты ICE принимаются в виде сообщений от сервера SimpleSignaling.

server.onmessage = function( msg, uid, room ) {
    if( msg.type == 'offer' ) {
        onoffer( msg, uid )
    } else if( msg.candidate ) {
        try {
            connections[uid].addIceCandidate( msg )
        } catch( e ) {
            console.error( 'connections[uid].addIceCandidate', e )
        }
    } else {
        console.warn( 'server.onmessage: Unknown message type', msg )
    }
}

Обработчик onawaken onicecandidate работает правильно. Когда открыты две вкладки, вторая получит объекты-кандидаты JSON. Когда я передаю их в connections[uid].addIceCandidate, я получаю сообщение об ошибке TypeMismatchError: DOM Exception 17.

код и demo онлайн.


То, что передается addIceCandidate, должно быть RTCIceCandidate. Окончательный код выглядит так:

server.onmessage = function( msg, uid, room ) {
      var candidate = new RTCIceCandidate( msg )
      connections[uid].addIceCandidate( candidate )
}

Теперь я получаю SyntaxError: DOM Exception 12. Теоретически это связано с тем, что я звоню addIceCandidate до setRemoteDescription . У меня есть setRemoteDescription в createAnswer, но обратный вызов никогда не выполняется.


К onoffer я добавил:

connections[uid].setRemoteDescription( new RTCSessionDescription( offer ) )

Это устранило синтаксические ошибки. Сообщения ICE теперь успешно отправляются, но connections[uid].ondatachannel никогда не вызывается.


person dysbulic    schedule 28.06.2013    source источник


Ответы (1)


Я добавил обработчик результата createAnswer. Теперь программа работает.

server.onmessage = function( msg, uid, room ) {
    if( msg.type == 'answer' ) {
        connections[uid].setRemoteDescription( new RTCSessionDescription( msg ) )
    }
}

Рабочий код представляет собой настенное приложение, которое связывает любых пользователей с открытой страницей. Он работает по адресу wholcomb.github.io/SimpleSignaling/.

person dysbulic    schedule 28.06.2013