Add codec reporting (if present in lib-jitsi-meet output) to connection stats (#6054)

* Add codec reporting to the stats window for connections.
This will report the audio/video codecs, if reported by lib-jitsi-meet.
This commit is contained in:
Russell Graves 2020-08-13 15:56:14 -06:00 committed by GitHub
parent 4ca4e242b1
commit 2aa6f7ff4b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 59 additions and 2 deletions

View File

@ -102,6 +102,7 @@
"bandwidth": "Estimated bandwidth:", "bandwidth": "Estimated bandwidth:",
"bitrate": "Bitrate:", "bitrate": "Bitrate:",
"bridgeCount": "Server count: ", "bridgeCount": "Server count: ",
"codecs": "Codecs (A/V): ",
"connectedTo": "Connected to:", "connectedTo": "Connected to:",
"e2e_rtt": "E2E RTT:", "e2e_rtt": "E2E RTT:",
"framerate": "Frame rate:", "framerate": "Frame rate:",

View File

@ -340,6 +340,7 @@ class ConnectionIndicator extends AbstractConnectionIndicator<Props, State> {
bandwidth, bandwidth,
bitrate, bitrate,
bridgeCount, bridgeCount,
codec,
e2eRtt, e2eRtt,
framerate, framerate,
maxEnabledResolution, maxEnabledResolution,
@ -355,6 +356,7 @@ class ConnectionIndicator extends AbstractConnectionIndicator<Props, State> {
bandwidth = { bandwidth } bandwidth = { bandwidth }
bitrate = { bitrate } bitrate = { bitrate }
bridgeCount = { bridgeCount } bridgeCount = { bridgeCount }
codec = { codec }
connectionSummary = { this._getConnectionStatusTip() } connectionSummary = { this._getConnectionStatusTip() }
e2eRtt = { e2eRtt } e2eRtt = { e2eRtt }
framerate = { framerate } framerate = { framerate }

View File

@ -122,6 +122,7 @@ const statsEmitter = {
_onStatsUpdated(localUserId: string, stats: Object) { _onStatsUpdated(localUserId: string, stats: Object) {
const allUserFramerates = stats.framerate || {}; const allUserFramerates = stats.framerate || {};
const allUserResolutions = stats.resolution || {}; const allUserResolutions = stats.resolution || {};
const allUserCodecs = stats.codec || {};
// FIXME resolution and framerate are maps keyed off of user ids with // FIXME resolution and framerate are maps keyed off of user ids with
// stat values. Receivers of stats expect resolution and framerate to // stat values. Receivers of stats expect resolution and framerate to
@ -129,7 +130,8 @@ const statsEmitter = {
// stats objects. // stats objects.
const modifiedLocalStats = Object.assign({}, stats, { const modifiedLocalStats = Object.assign({}, stats, {
framerate: allUserFramerates[localUserId], framerate: allUserFramerates[localUserId],
resolution: allUserResolutions[localUserId] resolution: allUserResolutions[localUserId],
codec: allUserCodecs[localUserId]
}); });
this._emitStatsUpdate(localUserId, modifiedLocalStats); this._emitStatsUpdate(localUserId, modifiedLocalStats);
@ -138,8 +140,9 @@ const statsEmitter = {
// and update remote user stats as needed. // and update remote user stats as needed.
const framerateUserIds = Object.keys(allUserFramerates); const framerateUserIds = Object.keys(allUserFramerates);
const resolutionUserIds = Object.keys(allUserResolutions); const resolutionUserIds = Object.keys(allUserResolutions);
const codecUserIds = Object.keys(allUserCodecs);
_.union(framerateUserIds, resolutionUserIds) _.union(framerateUserIds, resolutionUserIds, codecUserIds)
.filter(id => id !== localUserId) .filter(id => id !== localUserId)
.forEach(id => { .forEach(id => {
const remoteUserStats = {}; const remoteUserStats = {};
@ -156,6 +159,12 @@ const statsEmitter = {
remoteUserStats.resolution = resolution; remoteUserStats.resolution = resolution;
} }
const codec = allUserCodecs[id];
if (codec) {
remoteUserStats.codec = codec;
}
this._emitStatsUpdate(id, remoteUserStats); this._emitStatsUpdate(id, remoteUserStats);
}); });
} }

View File

@ -34,6 +34,11 @@ type Props = {
*/ */
bridgeCount: number, bridgeCount: number,
/**
* Audio/video codecs in use for the connection.
*/
codec: Object,
/** /**
* A message describing the connection quality. * A message describing the connection quality.
*/ */
@ -219,6 +224,45 @@ class ConnectionStatsTable extends Component<Props> {
); );
} }
/**
* Creates a a table row as a ReactElement for displaying codec, if present.
* This will typically be something like "Codecs (A/V): opus, vp8".
*
* @private
* @returns {ReactElement}
*/
_renderCodecs() {
const { codec, t } = this.props;
if (!codec) {
return;
}
let codecString;
// Only report one codec, in case there are multiple for a user.
Object.keys(codec || {})
.forEach(ssrc => {
const { audio, video } = codec[ssrc];
codecString = `${audio}, ${video}`;
});
if (!codecString) {
codecString = 'N/A';
}
return (
<tr>
<td>
<span>{ t('connectionindicator.codecs') }</span>
</td>
<td>{ codecString }</td>
</tr>
);
}
/** /**
* Creates a table row as a ReactElement for displaying a summary message * Creates a table row as a ReactElement for displaying a summary message
* about the current connection status. * about the current connection status.
@ -452,6 +496,7 @@ class ConnectionStatsTable extends Component<Props> {
{ isRemoteVideo ? this._renderRegion() : null } { isRemoteVideo ? this._renderRegion() : null }
{ this._renderResolution() } { this._renderResolution() }
{ this._renderFrameRate() } { this._renderFrameRate() }
{ this._renderCodecs() }
{ isRemoteVideo ? null : this._renderBridgeCount() } { isRemoteVideo ? null : this._renderBridgeCount() }
</tbody> </tbody>
</table> </table>