luci-app-dawn: error message when service not running
Display a nicer error message when the DAWN service is not running Signed-off-by: Daniel Vijge <danielvijge@gmail.com>
This commit is contained in:
parent
e8029b0828
commit
69eeebe23d
3 changed files with 37 additions and 7 deletions
|
@ -7,13 +7,13 @@ let callDawnGetNetwork, callDawnGetHearingMap, callHostHints;
|
||||||
callDawnGetNetwork = rpc.declare({
|
callDawnGetNetwork = rpc.declare({
|
||||||
object: 'dawn',
|
object: 'dawn',
|
||||||
method: 'get_network',
|
method: 'get_network',
|
||||||
expect: { }
|
expect: { }
|
||||||
});
|
});
|
||||||
|
|
||||||
callDawnGetHearingMap = rpc.declare({
|
callDawnGetHearingMap = rpc.declare({
|
||||||
object: 'dawn',
|
object: 'dawn',
|
||||||
method: 'get_hearing_map',
|
method: 'get_hearing_map',
|
||||||
expect: { }
|
expect: { }
|
||||||
});
|
});
|
||||||
|
|
||||||
callHostHints = rpc.declare({
|
callHostHints = rpc.declare({
|
||||||
|
@ -22,6 +22,12 @@ callHostHints = rpc.declare({
|
||||||
expect: { }
|
expect: { }
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function isDawnRPCAvailable() {
|
||||||
|
return rpc.list("dawn").then(function(signatures) {
|
||||||
|
return 'dawn' in signatures && 'get_network' in signatures.dawn && 'get_hearing_map' in signatures.dawn;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
function getAvailableText(available) {
|
function getAvailableText(available) {
|
||||||
return ( available ? _('Available') : _('Not available') );
|
return ( available ? _('Available') : _('Not available') );
|
||||||
}
|
}
|
||||||
|
@ -59,16 +65,26 @@ function getFormattedNumber(num, decimals, divider = 1) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function getHostnameFromMAC(hosthints, mac) {
|
function getHostnameFromMAC(hosthints, mac) {
|
||||||
return ( hosthints[mac] && hosthints[mac].name ? hosthints[mac].name + ' (' + mac + ')' : mac);
|
return ( hosthints[mac] && hosthints[mac].name ? hosthints[mac].name + ' (' + mac + ')' : mac );
|
||||||
|
}
|
||||||
|
|
||||||
|
function getDawnServiceNotRunningErrorMessage() {
|
||||||
|
return E('div', { 'class': 'alert-message fade-in warning' }, [
|
||||||
|
E('h4', _('DAWN service unavailable')),
|
||||||
|
E('p', _('Unable to query the DAWN service via ubus, the service appears to be stopped.')),
|
||||||
|
E('a', { 'href': L.url('admin/system/startup') }, _('Check Startup services'))
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return L.Class.extend({
|
return L.Class.extend({
|
||||||
callDawnGetNetwork: callDawnGetNetwork,
|
callDawnGetNetwork: callDawnGetNetwork,
|
||||||
callDawnGetHearingMap: callDawnGetHearingMap,
|
callDawnGetHearingMap: callDawnGetHearingMap,
|
||||||
callHostHints: callHostHints,
|
callHostHints: callHostHints,
|
||||||
|
isDawnRPCAvailable: isDawnRPCAvailable,
|
||||||
getAvailableText: getAvailableText,
|
getAvailableText: getAvailableText,
|
||||||
getYesText: getYesText,
|
getYesText: getYesText,
|
||||||
getChannelFromFrequency: getChannelFromFrequency,
|
getChannelFromFrequency: getChannelFromFrequency,
|
||||||
getFormattedNumber: getFormattedNumber,
|
getFormattedNumber: getFormattedNumber,
|
||||||
getHostnameFromMAC: getHostnameFromMAC
|
getHostnameFromMAC: getHostnameFromMAC,
|
||||||
|
getDawnServiceNotRunningErrorMessage: getDawnServiceNotRunningErrorMessage
|
||||||
});
|
});
|
||||||
|
|
|
@ -10,8 +10,12 @@ return view.extend({
|
||||||
|
|
||||||
load: function() {
|
load: function() {
|
||||||
return Promise.all([
|
return Promise.all([
|
||||||
dawn.callDawnGetHearingMap(),
|
dawn.isDawnRPCAvailable().then(function(isAvailable) {
|
||||||
dawn.callDawnGetNetwork(),
|
return ( isAvailable ? dawn.callDawnGetHearingMap() : null )
|
||||||
|
}),
|
||||||
|
dawn.isDawnRPCAvailable().then(function(isAvailable) {
|
||||||
|
return ( isAvailable ? dawn.callDawnGetNetwork() : null )
|
||||||
|
}),
|
||||||
dawn.callHostHints()
|
dawn.callHostHints()
|
||||||
]);
|
]);
|
||||||
},
|
},
|
||||||
|
@ -37,6 +41,10 @@ return view.extend({
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!dawnHearingMapData || !dawnNetworkData) {
|
||||||
|
return dawn.getDawnServiceNotRunningErrorMessage();
|
||||||
|
}
|
||||||
|
|
||||||
const body = E([
|
const body = E([
|
||||||
E('h2', _('Hearing Map'))
|
E('h2', _('Hearing Map'))
|
||||||
]);
|
]);
|
||||||
|
|
|
@ -10,7 +10,9 @@ return view.extend({
|
||||||
|
|
||||||
load: function() {
|
load: function() {
|
||||||
return Promise.all([
|
return Promise.all([
|
||||||
dawn.callDawnGetNetwork(),
|
dawn.isDawnRPCAvailable().then(function(isAvailable) {
|
||||||
|
return ( isAvailable ? dawn.callDawnGetNetwork() : null );
|
||||||
|
}),
|
||||||
dawn.callHostHints()
|
dawn.callHostHints()
|
||||||
]);
|
]);
|
||||||
},
|
},
|
||||||
|
@ -20,6 +22,10 @@ return view.extend({
|
||||||
const dawnNetworkData = data[0];
|
const dawnNetworkData = data[0];
|
||||||
const hostHintsData = data[1];
|
const hostHintsData = data[1];
|
||||||
|
|
||||||
|
if (!dawnNetworkData) {
|
||||||
|
return dawn.getDawnServiceNotRunningErrorMessage();
|
||||||
|
}
|
||||||
|
|
||||||
const body = E([
|
const body = E([
|
||||||
E('h2', _('Network Overview'))
|
E('h2', _('Network Overview'))
|
||||||
]);
|
]);
|
||||||
|
|
Loading…
Reference in a new issue