Есть ли API для хром://webrtc-internals/variables в javascript?
Я хочу получить доступ к некоторым зарегистрированным переменным в chrome://webrtc-internals/
, но я ничего не нашел в google - даже не описание графиков, которые я вижу.
Меня особенно интересуют packetsLost
, googCurrentDelayMs
и googNacksSent
.
, почему я хочу получить доступ к внутренним файлам webrtc
Я пишу приложение Google Chrome, которое разделяет видеопоток (p2p). Он использует peerjs для совместного использования потока с другими одноранговыми узлами, который, в свою очередь, использует реализацию googles webrtc под ним. Чтобы сделать мое приложение идеальным, мне нужно знать, когда происходит большая задержка. Поскольку я вижу задержку, зарегистрированную в chrome://webrtc-internals/
, мне было интересно, могу ли я получить к ней доступ через javascript.
Я предполагаю, что API для chrome://webrtc-internals/
-menu отсутствует.
Ответы
Ответ 1
Я нашел его - пришлось просканировать пару сообществ-сообществ google (поток 1, thread2):
var peerjs = new Peer(...); // initialize peerJS
var connections = peerjs.connections;
Подключения - это объект:
Object {2e1c5694-e6ef-e1b2-22d5-84a3807961d4: Array[3]}
2e1c5694-e6ef-e1b2-22d5-84a3807961d4: Array[3]
0: DataConnection
1: MediaConnection
2: MediaConnection
length: 3
__proto__: Array[0]
__proto__: Object
Взгляните на любой из этих объектов соединения:
var rtcPeerConn = connectionObject.pc; // RTCPeerConnection
rtcPeerConn.getStats(function callback(connStats){
var rtcStatsReports = connStats.result() // array of available status-reports
// each status-report object has many status variables, such as
// googCurrentDelayMs. You need to iterate over all object and check
// their names to find the one status report you want
rtcStatsReports[7].names() // returns all available variables for that report
var googCurrentDelayMs = rtcStatsReports[7].stat('googCurrentDelayMs')
console.log(googCurrentDelayMs) // finally - googCurrentDelayMs :-)
})
Ответ 2
Afer много разбирается, вот как мне удалось получить компьютер с помощью twilio SDK.
var rtcPeerConn =Twilio.Device.activeConnection();
rtcPeerConn.options.mediaStreamFactory.protocol.pc.getStats(function callback(report) {
var rtcStatsReports = report.result();
for (var i=0; i<rtcStatsReports.length; i++) {
var statNames = rtcStatsReports[i].names();
// filter the ICE stats
if (statNames.indexOf("transportId") > -1) {
var logs = "";
for (var j=0; j<statNames.length; j++) {
var statName = statNames[j];
var statValue = rtcStatsReports[i].stat(statName);
logs = logs + statName + ": " + statValue + ", ";
}
console.log(logs);
}
}
});
//Вычислить errorRate Packetlost/packetsent
var rtcPeerConn =Twilio.Device.activeConnection();
rtcPeerConn.options.mediaStreamFactory.protocol.pc.getStats(function callback(report) {
var error, pcksent;
var rtcStatsReports = report.result();
for (var i=0; i<rtcStatsReports.length; i++) {
var statNames = rtcStatsReports[i].names();
// filter the ICE stats
if (statNames.indexOf("packetsSent") > -1) {
var logs = "";
for (var j=0; j<statNames.length; j++) {
var statName = statNames[j];
var statValue = rtcStatsReports[i].stat(statName);
if(statName=="packetsLost")
error= statValue;
if(statName =="packetsSent")
pcksent = statValue;
logs = logs +"n:" +statName + ": " + statValue + ", ";
}
console.log(error/pcksent);
}
}
});