summaryrefslogtreecommitdiffhomepage
path: root/protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js
diff options
context:
space:
mode:
authorFlorian Eckert <fe@dev.tdt.de>2023-07-03 11:55:08 +0200
committerGitHub <noreply@github.com>2023-07-03 11:55:08 +0200
commit51d9b9d33f35c5c1452909677a75b6ac7ccf6de6 (patch)
treee943a65f5d4510d0e38c591afd3937f058a517e8 /protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js
parentb06de7e4a11c5d17c8a1334b7806ba1ea90de3ca (diff)
parent594bc35b870c09ea47a66a59c5dfafd47b9b17d5 (diff)
Merge pull request #6451 from lvoegl/pr/20230602-proto-modemmanager-status
luci-proto-modemmanager: add status page
Diffstat (limited to 'protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js')
-rw-r--r--protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js44
1 files changed, 7 insertions, 37 deletions
diff --git a/protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js b/protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js
index 501f759646..34b71addd6 100644
--- a/protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js
+++ b/protocols/luci-proto-modemmanager/htdocs/luci-static/resources/protocol/modemmanager.js
@@ -2,39 +2,7 @@
'require fs';
'require form';
'require network';
-
-function getModemList() {
- return fs.exec_direct('/usr/bin/mmcli', [ '-L' ]).then(function(res) {
- var lines = (res || '').split(/\n/),
- tasks = [];
-
- for (var i = 0; i < lines.length; i++) {
- var m = lines[i].match(/\/Modem\/(\d+)/);
- if (m)
- tasks.push(fs.exec_direct('/usr/bin/mmcli', [ '-m', m[1] ]));
- }
-
- return Promise.all(tasks).then(function(res) {
- var modems = [];
-
- for (var i = 0; i < res.length; i++) {
- var man = res[i].match(/manufacturer: ([^\n]+)/),
- mod = res[i].match(/model: ([^\n]+)/),
- dev = res[i].match(/device: ([^\n]+)/);
-
- if (dev) {
- modems.push({
- device: dev[1].trim(),
- manufacturer: (man ? man[1].trim() : '') || '?',
- model: (mod ? mod[1].trim() : '') || dev[1].trim()
- });
- }
- }
-
- return modems;
- });
- });
-}
+'require modemmanager_helper as helper';
network.registerPatternVirtual(/^mobiledata-.+$/);
network.registerErrorCode('MM_CONNECT_FAILED', _('Connection attempt failed.'));
@@ -83,10 +51,12 @@ return network.registerProtocol('modemmanager', {
o.ucioption = 'device';
o.rmempty = false;
o.load = function(section_id) {
- return getModemList().then(L.bind(function(devices) {
- for (var i = 0; i < devices.length; i++)
- this.value(devices[i].device,
- '%s - %s'.format(devices[i].manufacturer, devices[i].model));
+ return helper.getModems().then(L.bind(function(devices) {
+ for (var i = 0; i < devices.length; i++) {
+ var generic = devices[i].modem.generic;
+ this.value(generic.device,
+ '%s - %s'.format(generic.manufacturer, generic.model));
+ }
return form.Value.prototype.load.apply(this, [section_id]);
}, this));
};