luci-app-firewall: add address range inputs for traffic rules
authorJo-Philipp Wich <jo@mein.io>
Wed, 21 Feb 2024 13:45:34 +0000 (14:45 +0100)
committerJo-Philipp Wich <jo@mein.io>
Wed, 21 Feb 2024 14:33:08 +0000 (15:33 +0100)
Ref: https://forum.openwrt.org/t/question-about-firewall-rules/188656
Signed-off-by: Jo-Philipp Wich <jo@mein.io>
applications/luci-app-firewall/htdocs/luci-static/resources/tools/firewall.js

index ec0ee369ea7c3c9f55cd7d8be290d258ae043f83..f9d7dc611c8deba692e200414ed2ee77f16264c2 100644 (file)
@@ -6,6 +6,7 @@
 'require form';
 'require network';
 'require firewall';
+'require validation';
 'require tools.prng as random';
 
 var protocols = [
@@ -455,9 +456,10 @@ return baseclass.extend({
 
        addIPOption: function(s, tab, name, label, description, family, hosts, multiple) {
                var o = s.taboption(tab, multiple ? this.CBIDynamicMultiValueList : form.Value, name, label, description);
+               var fw4 = L.hasSystemFeature('firewall4');
 
                o.modalonly = true;
-               o.datatype = 'list(neg(ipmask("true")))';
+               o.datatype = (fw4 && validation.types.iprange) ? 'list(neg(or(ipmask("true"),iprange)))' : 'list(neg(ipmask("true")))';
                o.placeholder = multiple ? _('-- add IP --') : _('any');
 
                if (family != null) {