Merge pull request #4932 from TDT-AG/pr/20210318-openwrt-21.02-luci-app-watchcat
luci-app-watchcat: add support for new features and convert to JavaScript
This commit is contained in:
commit
8619c8b97f
5 changed files with 111 additions and 66 deletions
|
@ -1,13 +1,9 @@
|
|||
#
|
||||
# Copyright (C) 2008-2014 The LuCI Team <luci@lists.subsignal.org>
|
||||
#
|
||||
# This is free software, licensed under the Apache License, Version 2.0 .
|
||||
#
|
||||
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
LUCI_TITLE:=LuCI Support for Watchcat
|
||||
LUCI_DEPENDS:=+luci-compat +watchcat
|
||||
LUCI_DEPENDS:=+watchcat
|
||||
|
||||
include ../../luci.mk
|
||||
|
||||
|
|
|
@ -0,0 +1,101 @@
|
|||
'use strict';
|
||||
'require view';
|
||||
'require form';
|
||||
'require tools.widgets as widgets';
|
||||
|
||||
return view.extend({
|
||||
render: function () {
|
||||
var m, s, o;
|
||||
|
||||
m = new form.Map('watchcat',
|
||||
_('Watchcat'),
|
||||
_("Here you can set up several checks and actions to take in the event that a host becomes unreachable. \
|
||||
Click the <b>Add</b> button at the bottom to set up more than one action."));
|
||||
|
||||
s = m.section(form.TypedSection, 'watchcat', _('Watchcat'), _('These rules will govern how this device reacts to network events.'));
|
||||
s.anonymous = true;
|
||||
s.addremove = true;
|
||||
|
||||
s.tab('general', _('General Settings'));
|
||||
|
||||
o = s.taboption('general', form.ListValue, 'mode',
|
||||
_('Mode'),
|
||||
_("Ping Reboot: Reboot this device if a ping to a specified host fails for a specified duration of time. <br /> \
|
||||
Periodic Reboot: Reboot this device after a specified interval of time. <br /> \
|
||||
Restart Interface: Restart a network interface if a ping to a specified host fails for a specified duration of time."));
|
||||
o.value('ping_reboot', _('Ping Reboot'));
|
||||
o.value('periodic_reboot', _('Periodic Reboot'));
|
||||
o.value('restart_iface', _('Restart Interface'));
|
||||
|
||||
o = s.taboption('general', form.Value, 'period',
|
||||
_('Period'),
|
||||
_("In Periodic Reboot mode, it defines how often to reboot. <br /> \
|
||||
In Ping Reboot mode, it defines the longest period of \
|
||||
time without a reply from the Host To Check before a reboot is engaged. <br /> \
|
||||
In Network Restart mode, it defines the longest period of \
|
||||
time without a reply from the Host to Check before the interface is restarted. \
|
||||
<br /><br />The default unit is seconds, without a suffix, but you can use the \
|
||||
suffix <b>m</b> for minutes, <b>h</b> for hours or <b>d</b> \
|
||||
for days. <br /><br />Examples:<ul><li>10 seconds would be: <b>10</b> or <b>10s</b></li><li>5 minutes would be: <b>5m</b></li><li> \
|
||||
1 hour would be: <b>1h</b></li><li>1 week would be: <b>7d</b></li><ul>"));
|
||||
o.default = '6h';
|
||||
|
||||
o = s.taboption('general', form.Value, 'pinghosts', _('Host To Check'), _(`IPv4 address or hostname to ping.`));
|
||||
o.datatype = 'host(1)';
|
||||
o.default = '8.8.8.8';
|
||||
o.depends({ mode: "ping_reboot" });
|
||||
o.depends({ mode: "restart_iface" });
|
||||
|
||||
o = s.taboption('general', form.Value, 'pingperiod',
|
||||
_('Check Interval'),
|
||||
_("How often to ping the host specified above. \
|
||||
<br /><br />The default unit is seconds, without a suffix, but you can use the suffix <b>m</b> for minutes, <b>h</b> for hours or <b>d</b> for days. <br /><br /> \
|
||||
Examples:<ul><li>10 seconds would be: <b>10</b> or <b>10s</b></li><li>5 minutes would be: <b>5m</b></li><li>1 hour would be: <b>1h</b></li><li>1 week would be: <b>7d</b></li><ul>"));
|
||||
o.default = '30s';
|
||||
o.depends({ mode: "ping_reboot" });
|
||||
o.depends({ mode: "restart_iface" });
|
||||
|
||||
o = s.taboption('general', form.ListValue, 'pingsize',
|
||||
_('Ping Packet Size'));
|
||||
o.value('small', _('Small: 1 byte'));
|
||||
o.value('windows', _('Windows: 32 bytes'));
|
||||
o.value('standard', _('Standard: 56 bytes'));
|
||||
o.value('big', _('Big: 248 bytes'));
|
||||
o.value('huge', _('Huge: 1492 bytes'));
|
||||
o.value('jumbo', _('Jumbo: 9000 bytes'));
|
||||
o.default = 'standard';
|
||||
o.depends({ mode: 'ping_reboot' });
|
||||
o.depends({ mode: 'restart_iface' });
|
||||
|
||||
o = s.taboption('general', form.Value, 'forcedelay',
|
||||
_('Force Reboot Delay'),
|
||||
_("Applies to Ping Reboot and Periodic Reboot modes</i> <br /> When rebooting the router, the service will trigger a soft reboot. \
|
||||
Entering a non-zero value here will trigger a delayed hard reboot if the soft reboot were to fail. \
|
||||
Enter the number of seconds to wait for the soft reboot to fail or use 0 to disable the forced reboot delay."));
|
||||
o.default = '1m';
|
||||
o.depends({ mode: 'ping_reboot' });
|
||||
o.depends({ mode: 'periodic_reboot' });
|
||||
|
||||
o = s.taboption('general', widgets.DeviceSelect, 'interface',
|
||||
_('Interface'),
|
||||
_('Interface to monitor and/or restart'),
|
||||
_('<i>Applies to Ping Reboot and Restart Interface modes</i> <br /> Specify the interface to monitor and restart if a ping over it fails.'));
|
||||
o.depends({ mode: 'ping_reboot' });
|
||||
o.depends({ mode: 'restart_iface' });
|
||||
|
||||
o = s.taboption('general', widgets.NetworkSelect, 'mmifacename',
|
||||
_('Name of ModemManager Interface'),
|
||||
_("Applies to Ping Reboot and Restart Interface modes</i> <br /> If using ModemManager, \
|
||||
you can have Watchcat restart your ModemManger interface by specifying its name."));
|
||||
o.depends({ mode: 'restart_iface' });
|
||||
o.optional = true;
|
||||
|
||||
o = s.taboption('general', form.Flag, 'unlockbands',
|
||||
_('Unlock Modem Bands'),
|
||||
_('If using ModemManager, then before restarting the interface, set the modem to be allowed to use any band.'));
|
||||
o.default = '0';
|
||||
o.depends({ mode: 'restart_iface' });
|
||||
|
||||
return m.render();
|
||||
}
|
||||
});
|
|
@ -1,53 +0,0 @@
|
|||
-- Copyright 2012 Christian Gagneraud <chris@techworks.ie>
|
||||
-- Licensed to the public under the Apache License 2.0.
|
||||
|
||||
m = Map("system",
|
||||
translate("Watchcat"),
|
||||
translate("Watchcat allows configuring a periodic reboot when the " ..
|
||||
"Internet connection has been lost for a certain period of time."
|
||||
))
|
||||
|
||||
s = m:section(TypedSection, "watchcat")
|
||||
s.anonymous = true
|
||||
s.addremove = true
|
||||
|
||||
mode = s:option(ListValue, "mode",
|
||||
translate("Operating mode"))
|
||||
mode.default = "allways"
|
||||
mode:value("ping", "Reboot on internet connection lost")
|
||||
mode:value("allways", "Periodic reboot")
|
||||
|
||||
forcedelay = s:option(Value, "forcedelay",
|
||||
translate("Forced reboot delay"),
|
||||
translate("When rebooting the system, the watchcat will trigger a soft reboot. " ..
|
||||
"Entering a non zero value here will trigger a delayed hard reboot " ..
|
||||
"if the soft reboot fails. Enter a number of seconds to enable, " ..
|
||||
"use 0 to disable"))
|
||||
forcedelay.datatype = "uinteger"
|
||||
forcedelay.default = "0"
|
||||
|
||||
period = s:option(Value, "period",
|
||||
translate("Period"),
|
||||
translate("In periodic mode, it defines the reboot period. " ..
|
||||
"In internet mode, it defines the longest period of " ..
|
||||
"time without internet access before a reboot is engaged." ..
|
||||
"Default unit is seconds, you can use the " ..
|
||||
"suffix 'm' for minutes, 'h' for hours or 'd' " ..
|
||||
"for days"))
|
||||
|
||||
pinghost = s:option(Value, "pinghosts",
|
||||
translate("Ping host"),
|
||||
translate("Host address to ping"))
|
||||
pinghost.datatype = "host(1)"
|
||||
pinghost.default = "8.8.8.8"
|
||||
pinghost:depends({mode="ping"})
|
||||
|
||||
pingperiod = s:option(Value, "pingperiod",
|
||||
translate("Ping period"),
|
||||
translate("How often to check internet connection. " ..
|
||||
"Default unit is seconds, you can you use the " ..
|
||||
"suffix 'm' for minutes, 'h' for hours or 'd' " ..
|
||||
"for days"))
|
||||
pingperiod:depends({mode="ping"})
|
||||
|
||||
return m
|
|
@ -3,13 +3,11 @@
|
|||
"title": "Watchcat",
|
||||
"order": 90,
|
||||
"action": {
|
||||
"type": "cbi",
|
||||
"path": "watchcat/watchcat",
|
||||
"post": { "cbi.submit": true }
|
||||
"type": "view",
|
||||
"path": "watchcat"
|
||||
},
|
||||
"depends": {
|
||||
"acl": [ "luci-app-watchcat" ],
|
||||
"uci": { "system": true }
|
||||
"acl": [ "luci-app-watchcat" ]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,11 +1,14 @@
|
|||
{
|
||||
"luci-app-watchcat": {
|
||||
"description": "Grant UCI access for luci-app-watchcat",
|
||||
"description": "Grant access to LuCI app watchcat",
|
||||
"read": {
|
||||
"uci": [ "system" ]
|
||||
"file": {
|
||||
"/usr/bin/watchcat.sh": [ "exec" ]
|
||||
},
|
||||
"uci": [ "watchcat" ]
|
||||
},
|
||||
"write": {
|
||||
"uci": [ "system" ]
|
||||
"uci": [ "watchcat" ]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue