Add Homer events
parent
655bf1a217
commit
930fcb69de
|
|
@ -58,7 +58,7 @@ export const Consumer = PropTypes.shape(
|
|||
supported : PropTypes.bool.isRequired,
|
||||
locallyPaused : PropTypes.bool.isRequired,
|
||||
remotelyPaused : PropTypes.bool.isRequired,
|
||||
profile : PropTypes.oneOf([ 'none', 'low', 'medium', 'high' ]),
|
||||
profile : PropTypes.oneOf([ 'none', 'default', 'low', 'medium', 'high' ]),
|
||||
track : PropTypes.any,
|
||||
codec : PropTypes.string
|
||||
});
|
||||
|
|
|
|||
File diff suppressed because it is too large
Load Diff
|
|
@ -13,10 +13,10 @@
|
|||
"domready": "^1.0.8",
|
||||
"hark": "^1.1.6",
|
||||
"js-cookie": "^2.2.0",
|
||||
"mediasoup-client": "^2.0.6",
|
||||
"mediasoup-client": "^2.0.10",
|
||||
"node-random-name": "^1.0.1",
|
||||
"prop-types": "^15.6.0",
|
||||
"protoo-client": "^2.0.5",
|
||||
"protoo-client": "^2.0.7",
|
||||
"random-string": "^0.2.0",
|
||||
"react": "^16.2.0",
|
||||
"react-clipboard.js": "^1.1.3",
|
||||
|
|
@ -40,21 +40,21 @@
|
|||
"babel-preset-es2015": "^6.24.1",
|
||||
"babel-preset-react": "^6.24.1",
|
||||
"babelify": "^8.0.0",
|
||||
"browser-sync": "^2.21.0",
|
||||
"browserify": "^14.5.0",
|
||||
"browser-sync": "^2.23.6",
|
||||
"browserify": "^15.2.0",
|
||||
"del": "^3.0.0",
|
||||
"envify": "^4.1.0",
|
||||
"eslint": "^4.14.0",
|
||||
"eslint": "^4.17.0",
|
||||
"eslint-plugin-import": "^2.8.0",
|
||||
"eslint-plugin-react": "^7.5.1",
|
||||
"gulp": "git://github.com/gulpjs/gulp.git#4.0",
|
||||
"eslint-plugin-react": "^7.6.1",
|
||||
"gulp": "^4.0.0",
|
||||
"gulp-css-base64": "^1.3.4",
|
||||
"gulp-eslint": "^4.0.0",
|
||||
"gulp-header": "^1.8.9",
|
||||
"gulp-eslint": "^4.0.2",
|
||||
"gulp-header": "^2.0.1",
|
||||
"gulp-if": "^2.0.2",
|
||||
"gulp-plumber": "^1.1.0",
|
||||
"gulp-plumber": "^1.2.0",
|
||||
"gulp-rename": "^1.2.2",
|
||||
"gulp-stylus": "^2.6.0",
|
||||
"gulp-stylus": "^2.7.0",
|
||||
"gulp-touch-cmd": "0.0.1",
|
||||
"gulp-uglify": "^3.0.0",
|
||||
"gulp-util": "^3.0.8",
|
||||
|
|
@ -63,6 +63,6 @@
|
|||
"nib": "^1.1.2",
|
||||
"vinyl-buffer": "^1.0.1",
|
||||
"vinyl-source-stream": "^2.0.0",
|
||||
"watchify": "^3.9.0"
|
||||
"watchify": "^3.10.0"
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,7 +1,5 @@
|
|||
module.exports =
|
||||
{
|
||||
// DEBUG env variable For the NPM debug module.
|
||||
debug : '*INFO* *WARN* *ERROR* *mediasoup-worker*',
|
||||
// Listening hostname for `gulp live|open`.
|
||||
domain : 'localhost',
|
||||
tls :
|
||||
|
|
|
|||
|
|
@ -0,0 +1,359 @@
|
|||
'use strict';
|
||||
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
const Logger = require('./Logger');
|
||||
|
||||
const STATS_INTERVAL = 4000; // TODO
|
||||
|
||||
const logger = new Logger('Homer');
|
||||
|
||||
function homer(server)
|
||||
{
|
||||
if (!process.env.MEDIASOUP_HOMER_OUTPUT)
|
||||
throw new Error('MEDIASOUP_HOMER_OUTPUT env not set');
|
||||
|
||||
server.on('newroom', (room) =>
|
||||
{
|
||||
const fileName = path.join(process.env.MEDIASOUP_HOMER_OUTPUT, String(room.id));
|
||||
|
||||
console.warn(fileName);
|
||||
const stream = fs.createWriteStream(fileName, { flags: 'a' });
|
||||
|
||||
emit(
|
||||
{
|
||||
event : 'server.newroom',
|
||||
roomId : room.id,
|
||||
rtpCapabilities : room.rtpCapabilities
|
||||
},
|
||||
stream);
|
||||
|
||||
handleRoom(room, stream);
|
||||
});
|
||||
}
|
||||
|
||||
function handleRoom(room, stream)
|
||||
{
|
||||
const baseEvent =
|
||||
{
|
||||
roomId : room.id
|
||||
};
|
||||
|
||||
room.on('close', () =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'room.close'
|
||||
}),
|
||||
stream);
|
||||
|
||||
stream.end();
|
||||
});
|
||||
|
||||
room.on('newpeer', (peer) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'room.newpeer',
|
||||
peerName : peer.name,
|
||||
rtpCapabilities : peer.rtpCapabilities
|
||||
}),
|
||||
stream);
|
||||
|
||||
handlePeer(peer, baseEvent, stream);
|
||||
});
|
||||
}
|
||||
|
||||
function handlePeer(peer, baseEvent, stream)
|
||||
{
|
||||
baseEvent = Object.assign({}, baseEvent,
|
||||
{
|
||||
peerName : peer.name
|
||||
});
|
||||
|
||||
peer.on('close', (originator) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'peer.close',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
peer.on('newtransport', (transport) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'peer.newtransport',
|
||||
transportId : transport.id,
|
||||
direction : transport.direction,
|
||||
iceLocalCandidates : transport.iceLocalCandidates
|
||||
}),
|
||||
stream);
|
||||
|
||||
handleTransport(transport, baseEvent, stream);
|
||||
});
|
||||
|
||||
peer.on('newproducer', (producer) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'peer.newproducer',
|
||||
producerId : producer.id,
|
||||
kind : producer.kind,
|
||||
transportId : producer.transport.id,
|
||||
rtpParameters : producer.rtpParameters
|
||||
}),
|
||||
stream);
|
||||
|
||||
handleProducer(producer, baseEvent, stream);
|
||||
});
|
||||
|
||||
peer.on('newconsumer', (consumer) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'peer.newconsumer',
|
||||
consumerId : consumer.id,
|
||||
kind : consumer.kind,
|
||||
sourceId : consumer.source.id,
|
||||
rtpParameters : consumer.rtpParameters
|
||||
}),
|
||||
stream);
|
||||
|
||||
handleConsumer(consumer, baseEvent, stream);
|
||||
});
|
||||
|
||||
// Must also handle existing Consumers at the time the Peer was created.
|
||||
for (const consumer of peer.consumers)
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'peer.newconsumer',
|
||||
consumerId : consumer.id,
|
||||
kind : consumer.kind,
|
||||
sourceId : consumer.source.id,
|
||||
rtpParameters : consumer.rtpParameters
|
||||
}),
|
||||
stream);
|
||||
|
||||
handleConsumer(consumer, baseEvent, stream);
|
||||
}
|
||||
}
|
||||
|
||||
function handleTransport(transport, baseEvent, stream)
|
||||
{
|
||||
baseEvent = Object.assign({}, baseEvent,
|
||||
{
|
||||
transportId : transport.id
|
||||
});
|
||||
|
||||
const statsInterval = setInterval((stats) =>
|
||||
{
|
||||
transport.getStats()
|
||||
.then((stats) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'transport.stats',
|
||||
stats : stats
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
}, STATS_INTERVAL);
|
||||
|
||||
transport.on('close', (originator) =>
|
||||
{
|
||||
clearInterval(statsInterval);
|
||||
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'transport.close',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
transport.on('iceselectedtuplechange', (iceSelectedTuple) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'transport.iceselectedtuplechange',
|
||||
iceSelectedTuple : iceSelectedTuple
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
transport.on('icestatechange', (iceState) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'transport.icestatechange',
|
||||
iceState : iceState
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
transport.on('dtlsstatechange', (dtlsState) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'transport.dtlsstatechange',
|
||||
dtlsState : dtlsState
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
}
|
||||
|
||||
function handleProducer(producer, baseEvent, stream)
|
||||
{
|
||||
baseEvent = Object.assign({}, baseEvent,
|
||||
{
|
||||
producerId : producer.id
|
||||
});
|
||||
|
||||
const statsInterval = setInterval((stats) =>
|
||||
{
|
||||
producer.getStats()
|
||||
.then((stats) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'producer.stats',
|
||||
stats : stats
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
}, STATS_INTERVAL);
|
||||
|
||||
producer.on('close', (originator) =>
|
||||
{
|
||||
clearInterval(statsInterval);
|
||||
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'producer.close',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
producer.on('pause', (originator) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'producer.pause',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
producer.on('resume', (originator) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'producer.resume',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
}
|
||||
|
||||
function handleConsumer(consumer, baseEvent, stream)
|
||||
{
|
||||
baseEvent = Object.assign({}, baseEvent,
|
||||
{
|
||||
consumerId : consumer.id
|
||||
});
|
||||
|
||||
const statsInterval = setInterval((stats) =>
|
||||
{
|
||||
consumer.getStats()
|
||||
.then((stats) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'consumer.stats',
|
||||
stats : stats
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
}, STATS_INTERVAL);
|
||||
|
||||
consumer.on('close', (originator) =>
|
||||
{
|
||||
clearInterval(statsInterval);
|
||||
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'consumer.close',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
consumer.on('handled', () =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'consumer.handled',
|
||||
transportId : consumer.transport.id
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
consumer.on('unhandled', () =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'consumer.handled'
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
consumer.on('pause', (originator) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'consumer.pause',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
consumer.on('resume', (originator) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'consumer.resume',
|
||||
originator : originator
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
|
||||
consumer.on('effectiveprofilechange', (profile) =>
|
||||
{
|
||||
emit(Object.assign({}, baseEvent,
|
||||
{
|
||||
event : 'consumer.effectiveprofilechange',
|
||||
profile : profile
|
||||
}),
|
||||
stream);
|
||||
});
|
||||
}
|
||||
|
||||
function emit(event, stream)
|
||||
{
|
||||
// Add timestamp.
|
||||
event.timestamp = Date.now();
|
||||
|
||||
const line = JSON.stringify(event);
|
||||
|
||||
console.warn(line);
|
||||
|
||||
stream.write(line);
|
||||
stream.write('\n');
|
||||
}
|
||||
|
||||
module.exports = homer;
|
||||
File diff suppressed because it is too large
Load Diff
|
|
@ -11,11 +11,11 @@
|
|||
"debug": "^3.1.0",
|
||||
"express": "^4.16.2",
|
||||
"mediasoup": "^2.0.7",
|
||||
"protoo-server": "^2.0.5"
|
||||
"protoo-server": "^2.0.7"
|
||||
},
|
||||
"devDependencies": {
|
||||
"gulp": "git://github.com/gulpjs/gulp.git#4.0",
|
||||
"gulp-eslint": "^4.0.0",
|
||||
"gulp-plumber": "^1.1.0"
|
||||
"gulp": "^4.0.0",
|
||||
"gulp-eslint": "^4.0.2",
|
||||
"gulp-plumber": "^1.2.0"
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -6,7 +6,7 @@ process.title = 'mediasoup-demo-server';
|
|||
|
||||
const config = require('./config');
|
||||
|
||||
process.env.DEBUG = config.debug || '*INFO* *WARN* *ERROR*';
|
||||
process.env.DEBUG = process.env.DEBUG || '*INFO* *WARN* *ERROR* *mediasoup-worker*';
|
||||
|
||||
/* eslint-disable no-console */
|
||||
console.log('- process.env.DEBUG:', process.env.DEBUG);
|
||||
|
|
@ -24,6 +24,7 @@ const colors = require('colors/safe');
|
|||
const repl = require('repl');
|
||||
const Logger = require('./lib/Logger');
|
||||
const Room = require('./lib/Room');
|
||||
const homer = require('./lib/homer');
|
||||
|
||||
const logger = new Logger();
|
||||
|
||||
|
|
@ -44,6 +45,10 @@ const mediaServer = mediasoup.Server(
|
|||
rtcMaxPort : config.mediasoup.rtcMaxPort
|
||||
});
|
||||
|
||||
// Do Homer stuff.
|
||||
if (process.env.MEDIASOUP_HOMER_OUTPUT)
|
||||
homer(mediaServer);
|
||||
|
||||
global.SERVER = mediaServer;
|
||||
|
||||
mediaServer.on('newroom', (room) =>
|
||||
|
|
|
|||
Loading…
Reference in New Issue