[115525a] | 1 | #!/bin/bash |
---|
| 2 | #/** |
---|
| 3 | #@file ogfunctions.sh |
---|
| 4 | #@brief Generic functions for OpenGnsys Server and OpenGnsys Repository. |
---|
| 5 | #@version 1.1.1 - Initial version |
---|
| 6 | #@author Ramón M. Gómez, ETSII Universidad de Sevilla |
---|
| 7 | #@date 2017-10-08 |
---|
| 8 | #*/ |
---|
| 9 | |
---|
| 10 | |
---|
| 11 | # Showing an error message. |
---|
| 12 | function raiseError() { |
---|
| 13 | case "$1" in |
---|
| 14 | usage) |
---|
| 15 | echo "$PROG: Usage error: Type \"$PROG help\"" >&2 |
---|
| 16 | exit 1 ;; |
---|
| 17 | notfound) |
---|
| 18 | echo "$PROG: Resource not found: $2" >&2 |
---|
| 19 | exit 2 ;; |
---|
| 20 | access) |
---|
| 21 | echo "$PROG: Access error: $2" >&2 |
---|
| 22 | exit 3 ;; |
---|
| 23 | download) |
---|
| 24 | echo "$PROG: Download error: $2" >&2 |
---|
| 25 | exit 4 ;; |
---|
[8495409] | 26 | cancel) |
---|
| 27 | echo "$PROG: Operation cancelled: $2" >&2 |
---|
| 28 | exit 5 ;; |
---|
[115525a] | 29 | *) |
---|
| 30 | echo "$PROG: Unknown error" >&2 |
---|
| 31 | exit 1 ;; |
---|
| 32 | esac |
---|
| 33 | } |
---|
| 34 | |
---|
| 35 | # Showing help message. |
---|
| 36 | function help() { |
---|
| 37 | [ -n "$1" ] && DESCRIPTION="$1" || DESCRIPTION=$(grep "^#@brief" "$0" | cut -f2- -d" ") |
---|
| 38 | shift |
---|
| 39 | if [ -n "$1" ]; then |
---|
| 40 | USAGE="$1" |
---|
| 41 | shift |
---|
| 42 | else |
---|
| 43 | USAGE=$(grep "^#@usage" "$0" | cut -f2- -d" ") |
---|
| 44 | [ -n "$USAGE" ] && PARAMS=$(awk '$1=="#@param" {sub($1,""); print "\t",$0}' "$0") |
---|
| 45 | fi |
---|
| 46 | # Showing help. |
---|
| 47 | echo "$PROG: ${DESCRIPTION:-"no description"}" |
---|
| 48 | echo "Usage: ${USAGE:-"no usage info"}" |
---|
| 49 | [ -n "$PARAMS" ] && echo -e "$PARAMS" |
---|
| 50 | if [ -n "$*" ]; then |
---|
| 51 | echo "Examples:" |
---|
| 52 | while (( "$#" )); do |
---|
| 53 | echo -e "\t$1" |
---|
| 54 | shift |
---|
| 55 | done |
---|
| 56 | fi |
---|
| 57 | exit 0 |
---|
| 58 | } |
---|
| 59 | |
---|
[8495409] | 60 | # Functions to manage a service. |
---|
| 61 | function restart() { |
---|
| 62 | _service restart "$1" |
---|
| 63 | } |
---|
| 64 | function start() { |
---|
| 65 | _service start "$1" |
---|
| 66 | } |
---|
| 67 | function stop() { |
---|
| 68 | _service stop "$1" |
---|
| 69 | } |
---|
| 70 | |
---|
| 71 | |
---|
| 72 | ### Meta-functions and private functions. |
---|
| 73 | |
---|
[115525a] | 74 | # Metafunction to check if JSON result exists. |
---|
| 75 | JQ=$(which jq 2>/dev/null) || raiseError notfound "Need to install \"jq\"." |
---|
| 76 | function jq() { |
---|
| 77 | local OUTPUT |
---|
| 78 | OUTPUT=$($JQ "$@") || return $? |
---|
| 79 | [[ "$OUTPUT" = "null" ]] && return 1 |
---|
| 80 | echo "$OUTPUT" |
---|
| 81 | } |
---|
| 82 | |
---|
[8495409] | 83 | # Private function to acts on a service (do not use directly). |
---|
| 84 | function _service() { |
---|
| 85 | local ACTION="$1" |
---|
| 86 | local SERVICE="$2" |
---|
| 87 | if which systemctl 2>/dev/null; then |
---|
| 88 | systemctl "$ACTION" "$SERVICE" |
---|
| 89 | elif which service 2>/dev/null; then |
---|
| 90 | service "$SERVICE" "$ACTION" |
---|
| 91 | elif [ -x /etc/init.d/"$SERVICE" ]; then |
---|
| 92 | /etc/init.d/"$SERVICE" "$ACTION" |
---|
| 93 | else |
---|
| 94 | raiseError notfound "Service $SERVICE" |
---|
| 95 | fi |
---|
| 96 | } |
---|