How to configure a WebRTC signaling server for connection to the mobile app

1

I'm trying to integrate a WebRTC signaling server with a mobile application in React Native and communicate with a command line in typescript. The signaling server is tested in this TS code:

import service from '../src/service'
import Connection from '../src'

let io, caller, responder, channelsCount, evlog

let params = {
    roomName: 'chatRoom',
    signallingServer: 'http://localhost:3000',
    rtcOpts: {iceServers: [{urls: 'stun:stun.l.google.com:19301'}]},
    debugMode: false
}

const responder_message = 'Hello caller! I am responder.'
const caller_message = 'Hello responder! I am caller.'

// sequence of channel ready is not guaranted (so use variables)
var responder_see_channel = false
var caller_see_channel = false

function launching() {
  io = service()
  caller = new Connection(params)
  responder = new Connection(params)
  evlog = []
  channelsCount = 0
}

function shutdown() {
  responder.close()
  caller.close()
  io.close()
}

function log(event) {
  evlog.push(event)
}

function communication(done) {

  log('begin communication')

  responder.on('ready', function () {
    responder.on('channel:ready', function () {
      responder_see_channel = true
    })
    responder.on('message', function (data) {
      log('responder received: ' + data.text)
      log('responder send: ' + responder_message)
      responder.sendMessage(responder_message)
    })
  })

  caller.on('ready', function () {
    caller.on('channel:ready', function () {
      caller_see_channel = true
      log('caller send: ' + caller_message)
      caller.sendMessage(caller_message)
    })
    caller.on('message', function (data) {
      log('caller received: ' + data.text)
      log('end communication')
      done()
    })
  })

}

beforeAll(() => {
  launching()
})

afterAll(() => {
  shutdown()
})

test('client may be created without options', () => {
  const conn = new Connection()
  conn.close()
})

test('client is debuggable', () => {
  const conn = new Connection({debugMode: true})
  conn.close()
})

test('perform bidirectional communications', done => {
  communication(done)
})

test('begin communication', () => {
  expect(evlog[0]).toBe(
    'begin communication'
  )
})

test('responder receive event channel:ready', () => {
  expect(responder_see_channel).toBe(true)
})

test('caller receive event channel:ready', () => {
  expect(caller_see_channel).toBe(true)
})

test('caller send: ' + caller_message, () => {
  expect(evlog[1]).toBe(
    'caller send: ' + caller_message
  )
})

test('responder received: ' + caller_message, () => {
  expect(evlog[2]).toBe(
    'responder received: ' + caller_message
  )
})

test('responder send: ' + responder_message, () => {
  expect(evlog[3]).toBe(
    'responder send: ' + responder_message
  )
})

test('caller received: ' + responder_message, () => {
  expect(evlog[4]).toBe(
    'caller received: ' + responder_message
  )
})

test('end communication', () => {
  expect(evlog[5]).toBe(
    'end communication'
  )
})

In this case the signaling server is in this TS code below:

import service from './service'

service();
    
asked by anonymous 23.08.2017 / 20:31

0 answers