added radius init script mit increased debugging
authorAndreas Steffen <andreas.steffen@strongswan.org>
Thu, 2 Sep 2010 11:19:24 +0000 (13:19 +0200)
committerAndreas Steffen <andreas.steffen@strongswan.org>
Thu, 2 Sep 2010 20:19:37 +0000 (22:19 +0200)
testing/hosts/alice/etc/init.d/radiusd [new file with mode: 0755]

diff --git a/testing/hosts/alice/etc/init.d/radiusd b/testing/hosts/alice/etc/init.d/radiusd
new file mode 100755 (executable)
index 0000000..8334385
--- /dev/null
@@ -0,0 +1,64 @@
+#!/sbin/runscript
+
+opts="${opts} reload"
+
+depend() {
+       need net
+       use dns
+}
+
+checkconfig() {
+       # set the location of log files
+       if ! cd /var/log/radius ; then
+               eerror "Failed to change current directory to /var/log/radius"
+               return 1
+       fi
+
+       if [ ! -d /var/run/radiusd ] && ! mkdir /var/run/radiusd ; then
+               eerror "Failed to create /var/run/radiusd"
+               return 1
+       fi
+       
+       if [ ! -f /etc/raddb/radiusd.conf ] ; then
+               eerror "No /etc/raddb/radiusd.conf file exists!"
+               return 1
+       fi
+
+       RADIUSD_OPTS="-xx"
+       RADIUSD_USER=`grep '^ *user *=' /etc/raddb/radiusd.conf | cut -d ' ' -f 3`
+       RADIUSD_GROUP=`grep '^ *group *=' /etc/raddb/radiusd.conf | cut -d ' ' -f 3`
+       if [ -n "${RADIUSD_USER}" ] && ! getent passwd ${RADIUSD_USER} > /dev/null ; then
+               eerror "${RADIUSD_USER} user missing!"
+               return 1
+       fi
+       if [ -n "${RADIUSD_GROUP}" ] && ! getent group ${RADIUSD_GROUP} > /dev/null ; then
+               eerror "${RADIUSD_GROUP} group missing!"
+               return 1
+       fi
+
+       # radius.log is created before privileges are dropped - need to set proper permissions on it
+       [ -f radius.log ] || touch radius.log || return 1
+
+       chown -R "${RADIUSD_USER:-root}:${RADIUSD_GROUP:-root}" . /var/run/radiusd && \
+               chmod -R u+rwX,g+rX . /var/run/radiusd || return 1
+}
+
+start() {
+       checkconfig || return 1
+
+       ebegin "Starting radiusd"
+       start-stop-daemon --start --quiet --exec /usr/sbin/radiusd -- ${RADIUSD_OPTS} >/dev/null
+       eend $?
+}
+
+stop () {
+       ebegin "Stopping radiusd"
+       start-stop-daemon --stop --quiet --pidfile=/var/run/radiusd/radiusd.pid
+       eend $?
+}
+
+reload () {
+       ebegin "Reloading radiusd"
+       kill -HUP `</var/run/radiusd/radiusd.pid`
+       eend $?
+}