make snmpd uci aware, Signed-off-by: Frdric Moulins <ffrrrr@gmail.com>
[openwrt/svn-archive/archive.git] / libs / net-snmp / files / snmpd.init
index 269c8793befa6bc4456bc64d57ba7c7c7f7032f2..8fffa9d3d8720e61fc3c650e314be4a7d40536a8 100644 (file)
@@ -1,5 +1,5 @@
 #!/bin/sh /etc/rc.common
-# Copyright (C) 2006 OpenWrt.org
+# Copyright (C) 2008 OpenWrt.org
 START=50
 
 DEFAULT=/etc/default/snmpd
@@ -7,17 +7,93 @@ LIB_D=/var/lib/snmp
 LOG_D=/var/log
 RUN_D=/var/run
 PID_F=$RUN_D/snmpd.pid
+RUN_C=$RUN_D/snmpd.conf
 
-
+snmpd_com2sec_add() {
+       local cfg="$1"
+       config_get secname "$cfg" secname
+       [ -n "$secname" ] || return 0
+       config_get source "$cfg" source
+       [ -n "$source" ] || return 0
+       config_get community "$cfg" community
+       [ -n "$community" ] || return 0
+       echo "com2sec $secname $source $community" >> $RUN_C
+}
+snmpd_group_add() {
+       local cfg="$1"
+       config_get group "$cfg" group
+       [ -n "$group" ] || return 0
+       config_get version "$cfg" version
+       [ -n "$version" ] || return 0
+       config_get secname "$cfg" secname
+       [ -n "$secname" ] || return 0
+       echo "group $group $version $secname" >> $RUN_C
+}
+snmpd_view_add() {
+       local cfg="$1"
+       config_get viewname "$cfg" viewname
+       [ -n "$viewname" ] || return 0
+       config_get type "$cfg" type
+       [ -n "$type" ] || return 0
+       config_get oid "$cfg" oid
+       [ -n "$oid" ] || return 0
+       # optional mask
+       config_get mask "$cfg" mask
+       echo "view $viewname $type $oid $mask" >> $RUN_C
+}
+snmpd_access_add() {
+       local cfg="$1"
+       config_get group "$cfg" group
+       [ -n "$group" ] || return 0
+       config_get context "$cfg" context
+       [ -n $context ] || return 0
+       [ "$context" == "none" ] && context='""'
+       config_get version "$cfg" version
+       [ -n "$version" ] || return 0
+       config_get level "$cfg" level
+       [ -n "$level" ] || return 0
+       config_get prefix "$cfg" prefix
+       [ -n "$prefix" ] || return 0
+       config_get read "$cfg" read
+       [ -n "$read" ] || return 0
+       config_get write "$cfg" write
+       [ -n "$write" ] || return 0
+       config_get notify "$cfg" notify
+       [ -n "$notify" ] || return 0
+       echo "access $group $context $version $level $prefix $read $write $notify" >> $RUN_C
+}
+snmpd_pass_add() {
+       local cfg="$1"
+       local pass='pass'
+       
+       config_get miboid "$cfg" miboid
+       [ -n "$miboid" ] || return 0
+       config_get prog "$cfg" prog
+       [ -n "$prog" ] || return 0
+       config_get_bool persist "$cfg" persist 0
+       [ $persist -ne 0 ] && pass='pass_persist'
+       config_get priority "$cfg" priority
+       priority=${priority:+-p $priority}
+       echo "$pass $priority $miboid $prog" >> $RUN_C
+}
 start() {
-       [ -f $DEFAULT ] && . $DEFAULT
        [ -d $LIB_D ] || mkdir -p $LIB_D
        [ -d $LOG_D ] || mkdir -p $LOG_D
        [ -d $RUN_D ] || mkdir -p $RUN_D
-       snmpd $OPTIONS
-}
+       [ -f $RUN_C ] && rm -f $RUN_C
+       
+       config_load snmpd
+       
+       config_foreach snmpd_com2sec_add com2sec
+       config_foreach snmpd_group_add group
+       config_foreach snmpd_view_add view
+       config_foreach snmpd_access_add access
+       config_foreach snmpd_pass_add pass
 
+       [ -f $DEFAULT ] && . $DEFAULT
+       $DEBUG /usr/sbin/snmpd $OPTIONS
+}
 stop() {
        [ -f $PID_F ] && kill $(cat $PID_F)
+       [ -f $RUN_C ] && rm -f $RUN_C
 }
-