From 2a97d5533cba419f51da0b550b00a34bc9f50cce Mon Sep 17 00:00:00 2001 From: Ansuel Smith Date: Sat, 18 Sep 2021 16:17:27 +0200 Subject: luci-mod-status: cosmetic fix for isWPSEnabled in wifi status Drop isWPSEnabled table as it's really not needed and can directly included in the network table. Signed-off-by: Ansuel Smith --- .../htdocs/luci-static/resources/view/status/include/60_wifi.js | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) (limited to 'modules/luci-mod-status/htdocs/luci-static/resources/view') diff --git a/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js b/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js index 7cb3e78e7a..b03d1f4111 100644 --- a/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js +++ b/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js @@ -121,7 +121,7 @@ return baseclass.extend({ var WPS_button = null; - if (this.isWPSEnabled[net.sid]) { + if (net.isWPSEnabled) { if (net.wps_status == 'Active') { WPS_button = E('button', { 'class' : 'cbi-button cbi-button-remove', @@ -190,7 +190,7 @@ return baseclass.extend({ }, this, radios_networks_hints[i]))); if (hasWPS && uci.get('wireless', radios_networks_hints[i].sid, 'wps_pushbutton') == '1') { - this.isWPSEnabled[radios_networks_hints[i].sid] = true; + radios_networks_hints[i].isWPSEnabled = true; tasks.push(L.resolveDefault(this.handleGetWPSStatus(radios_networks_hints[i].getIfname()), null) .then(L.bind(function(net, data) { net.wps_status = data ? data.pbc_status : _('No Data'); @@ -204,8 +204,6 @@ return baseclass.extend({ }, this)); }, - isDeviceAdded: {}, - render: function(data) { var seen = {}, radios = data[0], -- cgit v1.2.3 From 085c4a08f5bf50919731304a962cfcd2b592d523 Mon Sep 17 00:00:00 2001 From: Ansuel Smith Date: Sat, 18 Sep 2021 16:25:23 +0200 Subject: luci-mod-status: fix wrong logic for maclist adding feature Currently any new entry added to the black/whitelist deletes the others. Fix this and improve the rule apply by firstly disconnect the wifi client. Fixes: #5343 Signed-off-by: Ansuel Smith --- .../resources/view/status/include/60_wifi.js | 27 ++++++++++------------ 1 file changed, 12 insertions(+), 15 deletions(-) (limited to 'modules/luci-mod-status/htdocs/luci-static/resources/view') diff --git a/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js b/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js index b03d1f4111..333884449f 100644 --- a/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js +++ b/modules/luci-mod-status/htdocs/luci-static/resources/view/status/include/60_wifi.js @@ -48,21 +48,18 @@ return baseclass.extend({ ev.currentTarget.disabled = true; ev.currentTarget.blur(); - if (exec == 'addlist') { - var macs = [ mac ] + /* Disconnect client before adding to maclist */ + wifinet.disconnectClient(mac, true, 5, 60000); - for (var mac in this.iface_maclist) { - macs.push(mac) - } + if (exec == 'addlist') { + wifinet.maclist.push(mac); - uci.set('wireless', wifinet.sid, 'maclist', macs); + uci.set('wireless', wifinet.sid, 'maclist', wifinet.maclist); return uci.save() .then(L.bind(L.ui.changes.init, L.ui.changes)) .then(L.bind(L.ui.changes.displayChanges, L.ui.changes)); } - - wifinet.disconnectClient(mac, true, 5, 60000); }, handleGetWPSStatus: function(wifinet) { @@ -234,14 +231,14 @@ return baseclass.extend({ var rows = []; for (var i = 0; i < networks.length; i++) { - var macfilter = uci.get('wireless', networks[i].sid, 'macfilter'); + var macfilter = uci.get('wireless', networks[i].sid, 'macfilter'), + maclist = {}; if (macfilter != null && macfilter != 'disable') { - this.isDeviceAdded = {}; - var macs = L.toArray(uci.get('wireless', networks[i].sid, 'maclist')); - for (var j = 0; j < macs.length; j++) { - var mac = macs[j].toUpperCase(); - this.isDeviceAdded[mac] = true; + networks[i].maclist = L.toArray(uci.get('wireless', networks[i].sid, 'maclist')); + for (var j = 0; j < networks[i].maclist.length; j++) { + var mac = networks[i].maclist[j].toUpperCase(); + maclist[mac] = true; } } @@ -324,7 +321,7 @@ return baseclass.extend({ if (assoclist.firstElementChild.childNodes.length < 6) assoclist.firstElementChild.appendChild(E('th', { 'class': 'th cbi-section-actions' })); - if (macfilter != null && macfilter != 'disable' && !this.isDeviceAdded[bss.mac]) { + if (macfilter != null && macfilter != 'disable' && !maclist[bss.mac]) { row.push(new L.ui.ComboButton('button', { 'addlist': macfilter == 'allow' ? _('Add to Whitelist') : _('Add to Blacklist'), 'disconnect': _('Disconnect') -- cgit v1.2.3