Merge pull request #4208 from dedeckeh/pr-netsnmp-fw
net-snmp: add inbound firewall rule support
This commit is contained in:
commit
916f14aacf
3 changed files with 34 additions and 1 deletions
|
@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=net-snmp
|
PKG_NAME:=net-snmp
|
||||||
PKG_VERSION:=5.7.3
|
PKG_VERSION:=5.7.3
|
||||||
PKG_RELEASE:=4
|
PKG_RELEASE:=5
|
||||||
|
|
||||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
|
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
|
||||||
PKG_SOURCE_URL:=@SF/net-snmp
|
PKG_SOURCE_URL:=@SF/net-snmp
|
||||||
|
|
|
@ -87,3 +87,6 @@ config engineid
|
||||||
# option engineid 'LEDE'
|
# option engineid 'LEDE'
|
||||||
option engineidtype '3'
|
option engineidtype '3'
|
||||||
option engineidnic 'eth0'
|
option engineidnic 'eth0'
|
||||||
|
|
||||||
|
config snmpd general
|
||||||
|
# list network 'wan'
|
||||||
|
|
|
@ -210,6 +210,28 @@ snmpd_engineid_add() {
|
||||||
[ -n "$engineidnic" ] && echo "engineIDNic $engineidnic" >> $CONFIGFILE
|
[ -n "$engineidnic" ] && echo "engineIDNic $engineidnic" >> $CONFIGFILE
|
||||||
}
|
}
|
||||||
|
|
||||||
|
snmpd_setup_fw_rules() {
|
||||||
|
local net="$1"
|
||||||
|
local zone
|
||||||
|
|
||||||
|
zone=$(fw3 -q network "$net" 2>/dev/null)
|
||||||
|
|
||||||
|
local handled_zone
|
||||||
|
for handled_zone in $HANDLED_SNMP_ZONES; do
|
||||||
|
[ "$handled_zone" = "$zone" ] && return
|
||||||
|
done
|
||||||
|
|
||||||
|
json_add_object ""
|
||||||
|
json_add_string type rule
|
||||||
|
json_add_string src "$zone"
|
||||||
|
json_add_string proto udp
|
||||||
|
json_add_string dest_port 161
|
||||||
|
json_add_string target ACCEPT
|
||||||
|
json_close_object
|
||||||
|
|
||||||
|
HANDLED_SNMP_ZONES="$HANDLED_SNMP_ZONES $zone"
|
||||||
|
}
|
||||||
|
|
||||||
start_service() {
|
start_service() {
|
||||||
[ -f "$CONFIGFILE" ] && rm -f "$CONFIGFILE"
|
[ -f "$CONFIGFILE" ] && rm -f "$CONFIGFILE"
|
||||||
|
|
||||||
|
@ -243,6 +265,14 @@ start_service() {
|
||||||
procd_append_param netdev "$iface"
|
procd_append_param netdev "$iface"
|
||||||
done
|
done
|
||||||
|
|
||||||
|
procd_open_data
|
||||||
|
|
||||||
|
json_add_array firewall
|
||||||
|
config_list_foreach general network snmpd_setup_fw_rules
|
||||||
|
json_close_array
|
||||||
|
|
||||||
|
procd_close_data
|
||||||
|
|
||||||
procd_close_instance
|
procd_close_instance
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue