fixes wifi

This commit is contained in:
Sebastian Hildebrandt 2021-02-10 17:13:26 +01:00
parent 14b4892feb
commit c39f52c54f

View File

@ -33,8 +33,7 @@ function wifiQualityFromDB(db) {
return result <= 100 ? result : 100; return result <= 100 ? result : 100;
} }
function wifiFrequencyFromChannel(channel) { const _wifi_frequencies = {
const frequencies = {
1: 2412, 1: 2412,
2: 2417, 2: 2417,
3: 2422, 3: 2422,
@ -108,8 +107,20 @@ function wifiFrequencyFromChannel(channel) {
189: 4945, 189: 4945,
192: 4960, 192: 4960,
196: 4980 196: 4980
}; };
return {}.hasOwnProperty.call(frequencies, channel) ? frequencies[channel] : null;
function wifiFrequencyFromChannel(channel) {
return {}.hasOwnProperty.call(_wifi_frequencies, channel) ? _wifi_frequencies[channel] : null;
}
function wifiChannelFromFrequencs(frequency) {
let channel = 0;
for (let key in _wifi_frequencies) {
if ({}.hasOwnProperty.call(_wifi_frequencies, key)) {
if (_wifi_frequencies[key] === frequency) { channel = key; }
}
}
return channel;
} }
function ifaceListLinux() { function ifaceListLinux() {
@ -178,11 +189,13 @@ function wpaConnectionLinux(iface) {
const cmd = `wpa_cli -i ${iface} status 2>&1`; const cmd = `wpa_cli -i ${iface} status 2>&1`;
try { try {
const lines = execSync(cmd).toString().split('\n'); const lines = execSync(cmd).toString().split('\n');
const freq = util.toInt(util.getValue(lines, 'freq', '='));
return { return {
ssid: util.getValue(lines, 'ssid', '='), ssid: util.getValue(lines, 'ssid', '='),
uuid: util.getValue(lines, 'uuid', '='), uuid: util.getValue(lines, 'uuid', '='),
security: util.getValue(lines, 'key_mgmt', '='), security: util.getValue(lines, 'key_mgmt', '='),
freq: util.getValue(lines, 'freq', '='), freq,
channel: wifiChannelFromFrequencs(freq),
bssid: util.getValue(lines, 'bssid', '=').toLowerCase() bssid: util.getValue(lines, 'bssid', '=').toLowerCase()
}; };
} catch (e) { } catch (e) {
@ -481,7 +494,7 @@ function wifiConnections(callback) {
const ssid = nmiDetails.ssid || wpaDetails.ssid; const ssid = nmiDetails.ssid || wpaDetails.ssid;
const network = networkList.filter(nw => nw.ssid === ssid); const network = networkList.filter(nw => nw.ssid === ssid);
const nmiConnection = nmiConnectionLinux(ssid); const nmiConnection = nmiConnectionLinux(ssid);
const channel = network && network.length && network[0].channel ? network[0].channel : null; const channel = network && network.length && network[0].channel ? network[0].channel : (wpaDetails && wpaDetails.channel ? wpaDetails.channel : null);
const bssid = network && network.length && network[0].bssid ? network[0].bssid : (wpaDetails && wpaDetails.bssid ? wpaDetails.bssid : null); const bssid = network && network.length && network[0].bssid ? network[0].bssid : (wpaDetails && wpaDetails.bssid ? wpaDetails.bssid : null);
if (ssid && bssid) { if (ssid && bssid) {
result.push({ result.push({