Annotation of embedaddon/lighttpd/doc/initscripts/rc.lighttpd, revision 1.1
1.1 ! misho 1: #! /bin/sh
! 2: # Copyright (c) 1995-2002 SuSE Linux AG, Nuernberg, Germany.
! 3: # All rights reserved.
! 4: #
! 5: # Author: Kurt Garloff <feedback@suse.de>
! 6: #
! 7: # /etc/init.d/FOO
! 8: #
! 9: # and symbolic its link
! 10: #
! 11: # /(usr/)sbin/rcFOO
! 12: #
! 13: # LSB compliant service control script; see http://www.linuxbase.org/spec/
! 14: #
! 15: # System startup script for some example service or daemon FOO (template)
! 16: #
! 17: ### BEGIN INIT INFO
! 18: # Provides: FOO
! 19: # Required-Start: $remote_fs $syslog
! 20: # Required-Stop: $remote_fs $syslog
! 21: # Default-Start: 3 5
! 22: # Default-Stop: 0 1 2 6
! 23: # Description: Start FOO to allow XY and provide YZ
! 24: # continued on second line by '#<TAB>'
! 25: ### END INIT INFO
! 26: #
! 27: # Note on Required-Start: It does specify the init script ordering,
! 28: # not real dependencies. Depencies have to be handled by admin
! 29: # resp. the configuration tools (s)he uses.
! 30:
! 31: # Source SuSE config (if still necessary, most info has been moved)
! 32: test -r /etc/rc.config && . /etc/rc.config
! 33:
! 34: # Check for missing binaries (stale symlinks should not happen)
! 35: LIGHTTPD_BIN=/usr/sbin/lighttpd
! 36: test -x $LIGHTTPD_BIN || exit 5
! 37:
! 38: # Check for existence of needed config file and read it
! 39: LIGHTTPD_CONFIG=/etc/sysconfig/lighttpd
! 40: test -r $LIGHTTPD_CONFIG || exit 6
! 41: . $LIGHTTPD_CONFIG
! 42:
! 43: # Shell functions sourced from /etc/rc.status:
! 44: # rc_check check and set local and overall rc status
! 45: # rc_status check and set local and overall rc status
! 46: # rc_status -v ditto but be verbose in local rc status
! 47: # rc_status -v -r ditto and clear the local rc status
! 48: # rc_failed set local and overall rc status to failed
! 49: # rc_failed <num> set local and overall rc status to <num><num>
! 50: # rc_reset clear local rc status (overall remains)
! 51: # rc_exit exit appropriate to overall rc status
! 52: # rc_active checks whether a service is activated by symlinks
! 53: . /etc/rc.status
! 54:
! 55: # First reset status of this service
! 56: rc_reset
! 57:
! 58: # Return values acc. to LSB for all commands but status:
! 59: # 0 - success
! 60: # 1 - generic or unspecified error
! 61: # 2 - invalid or excess argument(s)
! 62: # 3 - unimplemented feature (e.g. "reload")
! 63: # 4 - insufficient privilege
! 64: # 5 - program is not installed
! 65: # 6 - program is not configured
! 66: # 7 - program is not running
! 67: #
! 68: # Note that starting an already running service, stopping
! 69: # or restarting a not-running service as well as the restart
! 70: # with force-reload (in case signalling is not supported) are
! 71: # considered a success.
! 72:
! 73: case "$1" in
! 74: start)
! 75: echo -n "Starting lighttpd"
! 76: ## Start daemon with startproc(8). If this fails
! 77: ## the echo return value is set appropriate.
! 78:
! 79: # NOTE: startproc returns 0, even if service is
! 80: # already running to match LSB spec.
! 81: startproc $LIGHTTPD_BIN -f $LIGHTTPD_CONF_PATH
! 82:
! 83: # Remember status and be verbose
! 84: rc_status -v
! 85: ;;
! 86: stop)
! 87: echo -n "Shutting down lighttpd"
! 88: ## Stop daemon with killproc(8) and if this fails
! 89: ## set echo the echo return value.
! 90:
! 91: killproc -TERM $LIGHTTPD_BIN
! 92:
! 93: # Remember status and be verbose
! 94: rc_status -v
! 95: ;;
! 96: try-restart)
! 97: ## Stop the service and if this succeeds (i.e. the
! 98: ## service was running before), start it again.
! 99: ## Note: try-restart is not (yet) part of LSB (as of 0.7.5)
! 100: $0 status >/dev/null && $0 restart
! 101:
! 102: # Remember status and be quiet
! 103: rc_status
! 104: ;;
! 105: restart)
! 106: ## Stop the service and regardless of whether it was
! 107: ## running or not, start it again.
! 108: $0 stop
! 109: $0 start
! 110:
! 111: # Remember status and be quiet
! 112: rc_status
! 113: ;;
! 114: force-reload|reload)
! 115: ## Like force-reload, but if daemon does not support
! 116: ## signalling, do nothing (!)
! 117:
! 118: # If it supports signalling:
! 119: echo -n "Reload service LIGHTTPD"
! 120: killproc -INT $LIGHTTPD_BIN
! 121: $0 start
! 122: touch /var/run/lighttpd.pid
! 123: rc_status -v
! 124:
! 125: ## Otherwise if it does not support reload:
! 126: #rc_failed 3
! 127: #rc_status -v
! 128: ;;
! 129: status)
! 130: echo -n "Checking for service LIGHTTPD: "
! 131: ## Check status with checkproc(8), if process is running
! 132: ## checkproc will return with exit status 0.
! 133:
! 134: # Return value is slightly different for the status command:
! 135: # 0 - service running
! 136: # 1 - service dead, but /var/run/ pid file exists
! 137: # 2 - service dead, but /var/lock/ lock file exists
! 138: # 3 - service not running
! 139:
! 140: # NOTE: checkproc returns LSB compliant status values.
! 141: checkproc $LIGHTTPD_BIN
! 142: rc_status -v
! 143: ;;
! 144: probe)
! 145: ## Optional: Probe for the necessity of a reload,
! 146: ## print out the argument which is required for a reload.
! 147:
! 148: test /etc/lighttpd/lighttpd.conf -nt /var/run/lighttpd.pid && echo reload
! 149: ;;
! 150: *)
! 151: echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload|probe}"
! 152: exit 1
! 153: ;;
! 154: esac
! 155: rc_exit
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>