strongswan-starter.ipsec.init 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. #! /bin/sh
  2. ### BEGIN INIT INFO
  3. # Provides: vpn
  4. # Required-Start: $network $local_fs
  5. # Required-Stop: $network $local_fs
  6. # Default-Start: 2 3 4 5
  7. # Default-Stop: 0 1 6
  8. # Short-Description: Strongswan IPsec services
  9. ### END INIT INFO
  10. # Author: Rene Mayrhofer <rene@mayrhofer.eu.org>
  11. # PATH should only include /usr/* if it runs after the mountnfs.sh script
  12. PATH=/sbin:/usr/sbin:/bin:/usr/bin
  13. DESC="strongswan IPsec services"
  14. NAME=ipsec
  15. DAEMON=/usr/sbin/$NAME
  16. PIDFILE=/var/run/$NAME.pid
  17. SCRIPTNAME=/etc/init.d/$NAME
  18. # Exit if the package is not installed
  19. [ -x "$DAEMON" ] || exit 0
  20. # Read configuration variable file if it is present
  21. [ -r /etc/default/$NAME ] && . /etc/default/$NAME
  22. # Load the VERBOSE setting and other rcS variables
  23. . /lib/init/vars.sh
  24. # Define LSB log_* functions.
  25. # Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
  26. . /lib/lsb/init-functions
  27. #
  28. # Function that starts the daemon/service
  29. #
  30. do_start()
  31. {
  32. # Return
  33. # 0 if daemon has been started
  34. # 1 if daemon was already running
  35. # 2 if daemon could not be started
  36. start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \
  37. || return 1
  38. start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- start \
  39. || return 2
  40. }
  41. #
  42. # Function that stops the daemon/service
  43. #
  44. do_stop()
  45. {
  46. # Return
  47. # 0 if daemon has been stopped
  48. # 1 if daemon was already stopped
  49. # 2 if daemon could not be stopped
  50. # other if a failure occurred
  51. # give the proper signal to stop
  52. start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- stop \
  53. || return 2
  54. # but kill if that didn't work
  55. start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
  56. RETVAL="$?"
  57. [ "$RETVAL" = 2 ] && return 2
  58. # Wait for children to finish too if this is a daemon that forks
  59. # and if the daemon is only ever run from this initscript.
  60. # If the above conditions are not satisfied then add some other code
  61. # that waits for the process to drop all resources that could be
  62. # needed by services started subsequently. A last resort is to
  63. # sleep for some time.
  64. start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
  65. [ "$?" = 2 ] && return 2
  66. # Many daemons don't delete their pidfiles when they exit.
  67. rm -f $PIDFILE
  68. return "$RETVAL"
  69. }
  70. do_reload() {
  71. $DAEMON reload
  72. return 0
  73. }
  74. case "$1" in
  75. start)
  76. [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
  77. do_start
  78. case "$?" in
  79. 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
  80. 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
  81. esac
  82. ;;
  83. stop)
  84. [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
  85. do_stop
  86. case "$?" in
  87. 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
  88. 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
  89. esac
  90. ;;
  91. status)
  92. $DAEMON status
  93. ;;
  94. reload|force-reload)
  95. log_daemon_msg "Reloading $DESC" "$NAME"
  96. do_reload
  97. log_end_msg $?
  98. ;;
  99. restart)
  100. log_daemon_msg "Restarting $DESC" "$NAME"
  101. do_stop
  102. case "$?" in
  103. 0|1)
  104. do_start
  105. case "$?" in
  106. 0) log_end_msg 0 ;;
  107. 1) log_end_msg 1 ;; # Old process is still running
  108. *) log_end_msg 1 ;; # Failed to start
  109. esac
  110. ;;
  111. *)
  112. # Failed to stop
  113. log_end_msg 1
  114. ;;
  115. esac
  116. ;;
  117. *)
  118. echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
  119. exit 3
  120. ;;
  121. esac
  122. :