forked from linuxer/Runit-Service-Manager
		
	Compare commits
	
		
			22 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 6959074db1 | |||
| 931a5f45cb | |||
| 90062cb1fa | |||
| 54a6c3f17f | |||
| 2a494bcdc4 | |||
| 2e63f5b5a0 | |||
| 95ebba50e3 | |||
| 0506889700 | |||
| 59d2325f73 | |||
| 0477798c9e | |||
| 750cde1aa1 | |||
| 16f8b86d1b | |||
| 3bd632a39b | |||
| b17e0376bc | |||
| 250654bfdb | |||
| edbabda2df | |||
| 9d13a0576b | |||
| 27bcdec74f | |||
| 6815946574 | |||
| f4e12ec2e1 | |||
| 533d0e6250 | |||
| 3a69fa0a14 | 
							
								
								
									
										1
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								LICENSE
									
									
									
									
									
								
							| @@ -1,5 +1,6 @@ | ||||
| Copyright 2020 Dave Eddy <dave@daveeddy.com> (https://www.daveeddy.com) | ||||
| Forked as a contribution to Artix Linux by linuxer <linuxer@artixlinux.org> | ||||
| Forked by nikolar <nikolar@artixlinux.org> (24. 12. 2022) | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||||
|  | ||||
|   | ||||
							
								
								
									
										117
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										117
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,7 +1,114 @@ | ||||
| # Runit-Service-Manager | ||||
| # `rsm` - Runit Service Manager | ||||
|  | ||||
| - This is the CLI Runit Service Manager {rsv}, forked from Void Service Manager {vsv}  https://github.com/bahamas10/vsv/blob/master/vsv | ||||
| - This is the CLI Runit Service Manager {rsm}, forked from Void Service Manager {vsv}  https://github.com/bahamas10/vsv/blob/master/vsv | ||||
|  | ||||
| - Terminal Commands are exactly the same as sv, but produces a beautified layout. | ||||
|  | ||||
|  | ||||
| - Terminal Commands are exactly the same as sv, but produces a beautified layout. | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Manage and view runit services. | ||||
|  | ||||
| Usage | ||||
| ----- | ||||
|  | ||||
| Quick Examples: | ||||
|  | ||||
| - `rsm` - show all services | ||||
| - `rsm status` - same as above | ||||
| - `rsm stop <svc>` - stop a service | ||||
| - `rsm start <svc>` - start a service | ||||
| - `rsm restart <svc>` - restart a service, or start service right after `rsm enable <svc>` | ||||
| - `rsm enable <svc>` - enable a service (autostart at boot) | ||||
| - `rsm disable <svc>` - disable a service (no autostart at boot) | ||||
| - `rsm hup <svc>` - refresh a service (`SIGHUP`) | ||||
| - `rsm logs <svc>` or `rsm alllogs <svc>` - lists all logs for a service (access and error) | ||||
| - `rsm errorlogs <svc>` - lists all error logs for a service | ||||
|  | ||||
| Status: | ||||
|  | ||||
| The `status` subcommand has the following fields: | ||||
|  | ||||
| - `SERVICE` - the service (directory) name. | ||||
| - `STATE` - the service state: output from `.../$service/supervise/stat`. | ||||
| - `ENABLED` - if the service is enabled (lacks the `.../$service/down` file). | ||||
| - `PID` - the pid of the process being monitored. | ||||
| - `COMMAND` - arg0 from the pid being monitored (first field of `/proc/$pid/cmdline`. | ||||
| - `TIME` - time the service has been in whatever state it is in. | ||||
|  | ||||
| Command Usage: | ||||
|  | ||||
|     [rsm]    Manage and view runit services | ||||
|     [rsm]    Made specifically for Void Linux but should work anywhere | ||||
|     [rsm]    Author: Dave Eddy <dave@daveeddy.com> (bahamas10) | ||||
|  | ||||
|     USAGE: | ||||
|     rsm [OPTIONS] [SUBCOMMAND] [<ARGS>] | ||||
|     rsm [-u] [-d <dir>] [-h] [-t] [SUBCOMMAND] [...] | ||||
|  | ||||
|     OPTIONS: | ||||
|     -c <yes|no|auto>          Enable/disable color output, defaults to auto | ||||
|     -d <dir>                  Directory to look into, defaults to env SVDIR or /var/service if unset | ||||
|     -h                        Print this message and exit | ||||
|     -l                        Show log processes, this is a shortcut for 'status -l' | ||||
|     -t                        Tree view, this is a shortcut for 'status -t' | ||||
|     -u                        User mode, this is a shortcut for '-d ~/runit/service' | ||||
|     -v                        Increase verbosity | ||||
|     -V                        Print the version number and exit | ||||
|  | ||||
|     ENV: | ||||
|     SVDIR                     The directory to use, passed to the 'sv' command, can | ||||
|                               be overridden with '-d <dir>' | ||||
|  | ||||
|     SUBCOMMANDS: | ||||
|     status [-lt] [filter]     Default subcommand, show process status | ||||
|                               '-t' enables tree mode (process tree) | ||||
|                               '-l' enables log mode (show log processes) | ||||
|                               'filter' is an optional string to match service names against | ||||
|  | ||||
|     enable <svc> [...]        Enable the service(s) (remove the "down" file, does not start service) | ||||
|  | ||||
|     disable <svc> [...]       Disable the service(s) (create the "down" file, does not stop service) | ||||
|  | ||||
|     Any other subcommand gets passed directly to the 'sv' command, see sv(1) for the | ||||
|     full list of subcommands and information about what each does specifically. | ||||
|     Common subcommands: | ||||
|  | ||||
|     start <service>           Start the service | ||||
|     stop <service>            Stop the service | ||||
|     restart <service>         Restart the service | ||||
|     reload <service>          Reload the service (send SIGHUP) | ||||
|  | ||||
|     EXAMPLES: | ||||
|     rsm                       Show service status in /var/service | ||||
|     rsm status                Same as above | ||||
|     rsm -t                    Show service status + pstree output | ||||
|     rsm status -t             Same as above | ||||
|     rsm status tty            Show service status for any service that matches tty* | ||||
|     rsm check uuidd           Check the uuidd svc, wrapper for 'sv check uuidd' | ||||
|     rsm restart sshd          Restart sshd, wrapper for 'sv restart sshd' | ||||
|     rsm -u                    Show service status in ~/runit/service | ||||
|     rsm -u restart ssh-agent  Restart ssh-agent in ~/runit/service/ssh-agent | ||||
|  | ||||
| Syntax | ||||
| ------ | ||||
|  | ||||
| This project uses: | ||||
|  | ||||
| - Bash Style Guide: https://www.daveeddy.com/bash/ | ||||
| - `shellcheck`: https://github.com/koalaman/shellcheck | ||||
|  | ||||
| ``` | ||||
| $ make check | ||||
| shellcheck rsm | ||||
| ``` | ||||
|  | ||||
| Installation | ||||
| ------------ | ||||
|  | ||||
| - You'll have to change the `$SVDIR` and `$RUNSVDIR` variables to your distro's | ||||
| configuration to make the autocompletion work properly. | ||||
|  | ||||
| License | ||||
| ------- | ||||
|  | ||||
| MIT License | ||||
|   | ||||
							
								
								
									
										33
									
								
								autocompletion/bash/rsm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								autocompletion/bash/rsm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| #/usr/bin/env bash | ||||
|  | ||||
| _rsm_completions() { | ||||
| 	SVDIR='/etc/runit/sv' | ||||
| 	RUNSVDIR='/etc/runit/runsvdir/default' | ||||
|  | ||||
| 	if [ "${#COMP_WORDS[@]}" -eq 3 ] | ||||
| 	then | ||||
| 		cmd="${COMP_WORDS[1]}" | ||||
| 		# notify-send "$cmd" | ||||
| 		case "$cmd" in | ||||
| 			status|enable|logs|alllogs|errorlogs) | ||||
| 				COMPREPLY=($(compgen -W "$(ls -1 $SVDIR | xargs echo)" \ | ||||
| 					"${COMP_WORDS[2]}")) | ||||
| 				;; | ||||
| 			disable|start|stop|restart|reload) | ||||
| 				COMPREPLY=($(compgen -W "$(ls -1 $RUNSVDIR | xargs echo)" \ | ||||
| 					"${COMP_WORDS[2]}")) | ||||
| 				;; | ||||
|  | ||||
| 		esac | ||||
| 	elif [ "${#COMP_WORDS[@]}" -eq 2 ] | ||||
| 	then | ||||
| 		COMPREPLY=($(compgen -W "status enable disable start \ | ||||
| 			stop restart reload logs alllogs errorlogs" "${COMP_WORDS[1]}")) | ||||
| 	else | ||||
| 		COMPREPLY=('wtf') | ||||
| 	fi | ||||
|  | ||||
| 	return 0 | ||||
| } | ||||
|  | ||||
| complete -F _rsm_completions rsm | ||||
							
								
								
									
										129
									
								
								autocompletion/zsh/_rsm
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										129
									
								
								autocompletion/zsh/_rsm
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,129 @@ | ||||
| #compdef rsm | ||||
|  | ||||
| _rsm_all_services() { | ||||
| 	local IFS=$'\n' | ||||
| 	# Extract names and email addresses from gpg --list-keys | ||||
| 	_values 'Active services' $(ls -1 "$SVDIR") | ||||
| } | ||||
|  | ||||
| _rsm_active_services() { | ||||
| 	local IFS=$'\n' | ||||
| 	# Extract names and email addresses from gpg --list-keys | ||||
| 	_values 'Active services' $(ls -1 "$RUNSVDIR") | ||||
| } | ||||
|  | ||||
| _rsm_common_args() { | ||||
| 	_arguments : \ | ||||
| 		'-c[Enable/disable color output, defaults to auto]:Enable color:(yes no auto)' \ | ||||
| 		'-d[Directory to look into, defaults to env SVDIR or /run/runit/service is unset]:directory:_files -/' \ | ||||
| 		'-h[Print this message and exit]' \ | ||||
| 		"-l[Show log processes, this is a shortcut for 'status -l']" \ | ||||
| 		"-t[Tree view, this is a shortcut for 'status -t']" \ | ||||
| 		"-u[User mode, this is a shortcut for '-d ~/runit/service']" \ | ||||
| 		'-v[Increase verbosity]' \ | ||||
| 		'-V[Print the version number and exit]' | ||||
| } | ||||
|  | ||||
| _rsm_subcommands() { | ||||
| 	local subcommands=( | ||||
| 		'status:Default subcommand, show process status' | ||||
| 		'enable:Enable the service(s) (remove the "down" file, does not start service' | ||||
| 		'disable:Disable the service(s) (create the "down" file, does not stop service' | ||||
| 		'start:Start the service' | ||||
| 		'stop:Stop the service' | ||||
| 		'restart:Restart the service' | ||||
| 		'reload:Reload the service (send SIGHUP)' | ||||
| 		"logs:Outputs the service's logfilenames and their access & error logs from /var/log/<serice>/" | ||||
| 		'alllogs:The same like logs <service>' | ||||
| 		"errorlogs:Outputs the service's logfilenames and their errorlogs from /var/log/<service>/" | ||||
| 	) | ||||
| 	_describe -t commands 'rsm' subcommands | ||||
| } | ||||
|  | ||||
| _rsm() { | ||||
| 	local -a args subcommands cmd havesubcmd tmpwords lastcmd SVDIR RUNSVDIR | ||||
| 	# NOTE Change there variables to your configuration | ||||
| 	SVDIR='/etc/runit/sv' | ||||
| 	RUNSVDIR='/etc/runit/runsvdir/default' | ||||
| 	havesubcmd=NONE | ||||
| 	tmpwords=("${words[@]}") | ||||
|  | ||||
| 	while true | ||||
| 	do | ||||
| 		cmd="${tmpwords[2]}" | ||||
| 		case "$cmd" in | ||||
| 			-h|-V) | ||||
| 				# Help and version options override everything else | ||||
| 				return | ||||
| 				;; | ||||
| 			-c) | ||||
| 				havesubcmd=OPTARG | ||||
| 				shift tmpwords | ||||
| 				;; | ||||
| 			-d) | ||||
| 				havesubcmd=OPTARG | ||||
| 				shift tmpwords | ||||
| 				;; | ||||
| 			-*) | ||||
| 				havesubcmd=OPT | ||||
| 				shift tmpwords | ||||
| 				;; | ||||
| 			"") | ||||
| 				break | ||||
| 				;; | ||||
| 			*) | ||||
| 				if [ "$havesubcmd" = OPTARG ] | ||||
| 				then | ||||
| 					if [ "$lastcmd" = "-d" ] | ||||
| 					then | ||||
| 						SVDIR="$cmd" | ||||
| 					fi | ||||
| 					havesubcmd=OPT | ||||
| 					shift tmpwords | ||||
| 				else | ||||
| 					havesubcmd=SUBCMD | ||||
| 					break | ||||
| 				fi | ||||
| 				;; | ||||
| 		esac | ||||
| 		lastcmd="$cmd" | ||||
| 	done | ||||
|  | ||||
| 	if [ "$havesubcmd" = SUBCMD ] | ||||
| 	then | ||||
| 		words=("${tmpwords[@]}") | ||||
|  | ||||
| 		cmd="${words[2]}" | ||||
| 		# CURRENT=$((CURRENT - 1)) | ||||
| 		shift words | ||||
| 		case "$cmd" in | ||||
| 			status) | ||||
| 				_rsm_active_services | ||||
| 				_arguments : \ | ||||
| 					'-t[Enables tree mode (process tree)]' \ | ||||
| 					'-l[Enables log mode (show log processes)]' | ||||
| 				;; | ||||
| 			enable|logs|alllogs|errorlogs) | ||||
| 				_rsm_all_services | ||||
| 				;; | ||||
| 			disable|start|stop|restart|reload) | ||||
| 				_rsm_active_services | ||||
| 				;; | ||||
| 			*) | ||||
| 				_rsm_subcommands | ||||
| 				;; | ||||
| 		esac | ||||
| 	else | ||||
| 		if [ "$havesubcmd" = NONE ] || [ "$havesubcmd" = OPT ] | ||||
| 		then | ||||
| 			_rsm_subcommands | ||||
| 			_rsm_common_args | ||||
| 		elif [ "$havesubcmd" = OPTARG ] | ||||
| 		then | ||||
| 			_rsm_common_args | ||||
| 		fi | ||||
| 	fi | ||||
| 	return 0 | ||||
| } | ||||
|  | ||||
| _rsm | ||||
							
								
								
									
										165
									
								
								rsm
									
									
									
									
									
								
							
							
						
						
									
										165
									
								
								rsm
									
									
									
									
									
								
							| @@ -1,14 +1,24 @@ | ||||
| #!/usr/bin/env bash | ||||
| # | ||||
| # Void Linux service manager (runit) | ||||
| # Artix Linux service manager (runit) | ||||
| # Forked and further developed, by: nikolar <nikolar@artixlinux.org> | ||||
| # Fork Date: December 24, 2022 | ||||
| # | ||||
| # Author: Dave Eddy <dave@daveeddy.com> | ||||
| # Forked and further developed, by: linuxer <linuxer@artixlinux.org> | ||||
| # Fork Date: August 15, 2020 as rsv | ||||
| # Renamed and further developed as rsm from: January 10, 2021 | ||||
| # | ||||
| # Original Author (vsv): Dave Eddy <dave@daveeddy.com> | ||||
| # Date: August 29, 2018 | ||||
| # License: MIT | ||||
|  | ||||
| RSM_VERSION='v1.3.6' | ||||
| RSM_VERSION='v1.4.7' | ||||
|  | ||||
| export SVDIR=${SVDIR:-/run/runit/service/} | ||||
| export LOGDIR="/var/log/" | ||||
| export RSVDIR="/run/runit/service/" | ||||
| export FLDIR=${FLDIR:-/etc/runit/sv/} | ||||
|  | ||||
|  | ||||
| charup='✔' | ||||
| chardown='X' | ||||
| @@ -115,14 +125,16 @@ usage() { | ||||
| 	logo=$(getlogo) | ||||
|  | ||||
| 	cat <<EOF | ||||
| $colormagenta ______   ____   _  _ | ||||
| $colormagenta | | \ \ / ___\ | \/ |  $colorgreen Runit Service Manager ($RSM_VERSION) | ||||
| $colormagenta | |_/ / \____  | || |  $colorgreen Source: https://github.com/bahamas10/vsv | ||||
| $colormagenta ______   ____  __  __ | ||||
| $colormagenta | | \ \ / ___\ | \/ |  $colorgreen Runit Service Manager for Artix Linux ($RSM_VERSION) | ||||
| $colormagenta | |_/ / \____  | || |  $colorgreen Source: https://gitea.artixlinux.org/nikolar/Runit-Service-Manager | ||||
| $colormagenta | | \ \ \____/ | || |  $colorgreen MIT License | ||||
|  | ||||
| $logo   $colorblue Manage and view runit services | ||||
| $logo   $colorblue Made specifically for Void Linux but should work anywhere | ||||
| $logo   $colorblue Author: Dave Eddy <dave@daveeddy.com> (bahamas10) | ||||
| $logo   $colorblue Forked specifically for Artix Linux and renamed to rsm, for further development | ||||
| $logo   $colorblue Maitained by nikolar <nikolar@artixlinux.org> (nikolar in #artix) | ||||
|  | ||||
| ${coloryellow}USAGE:${colorgreen} | ||||
| $progname [OPTIONS] [SUBCOMMAND] [<ARGS>] | ||||
| @@ -130,7 +142,7 @@ $progname [-u] [-d <dir>] [-h] [-t] [SUBCOMMAND] [...] | ||||
|  | ||||
| ${coloryellow}OPTIONS:${colorgreen} | ||||
| ${colorgreen}-c <yes|no|auto>         $cr Enable/disable color output, defaults to auto | ||||
| ${colorgreen}-d <dir>                 $cr Directory to look into, defaults to env SVDIR or /var/service if unset | ||||
| ${colorgreen}-d <dir>                 $cr Directory to look into, defaults to env SVDIR or /run/runit/service is unset | ||||
| ${colorgreen}-h                       $cr Print this message and exit | ||||
| ${colorgreen}-l                       $cr Show log processes, this is a shortcut for 'status -l' | ||||
| ${colorgreen}-t                       $cr Tree view, this is a shortcut for 'status -t' | ||||
| @@ -160,6 +172,10 @@ ${colorgreen}start <service>          $cr Start the service | ||||
| ${colorgreen}stop <service>           $cr Stop the service | ||||
| ${colorgreen}restart <service>        $cr Restart the service | ||||
| ${colorgreen}reload <service>         $cr Reload the service (send SIGHUP) | ||||
| ${colorgreen}logs <service>           $cr Outputs the service's logfilenames and their access & error logs from /var/log/<serice>/ | ||||
| ${colorgreen}alllogs <service>        $cr The same like logs <service> | ||||
| ${colorgreen}errorlogs <service>      $cr Outputs the service's logfilenames and their errorlogs from /var/log/<serice>/ | ||||
|  | ||||
|  | ||||
| ${coloryellow}EXAMPLES:${colorgreen} | ||||
| ${colorgreen}$progname                      $cr Show service status in /var/service | ||||
| @@ -379,7 +395,9 @@ do_status() { | ||||
| 		fi | ||||
|  | ||||
| 		if [[ -n $filter && $svc != *"$filter"* ]]; then | ||||
| 			verbose "filtering out '$svc' because match '$filter'" | ||||
| 			if [[ $verbosity != 1 ]]; then | ||||
| 				verbose "filtering out '$svc' because it does not match '$filter'" | ||||
| 			fi | ||||
| 			continue | ||||
| 		fi | ||||
|  | ||||
| @@ -449,7 +467,7 @@ do_enable_disable() { | ||||
| 		fi | ||||
|  | ||||
| 		# ensure service exists | ||||
| 		if ! [[ -d $svc ]]; then | ||||
| 		if ! [[ -d ${FLDIR}${svc} ]]; then | ||||
| 			rmsg -1 "service directory '$svc' does not exist" >&2 | ||||
| 			continue | ||||
| 		fi | ||||
| @@ -462,6 +480,9 @@ do_enable_disable() { | ||||
| 				if ! rm -f "$file"; then | ||||
| 					rmsg 1 "failed to enable '$svc'" | ||||
| 					ret=1 | ||||
| 				else | ||||
| 					ln -s ${FLDIR}${svc} ${SVDIR} | ||||
| 					do_status | ||||
| 				fi | ||||
| 				;; | ||||
| 			disable) | ||||
| @@ -469,6 +490,9 @@ do_enable_disable() { | ||||
| 				if ! disable_message "$svc" > "$file"; then | ||||
| 					rmsg 1 "failed to disable '$svc'" | ||||
| 					ret=1 | ||||
| 				else | ||||
| 					unlink ${SVDIR}${svc} | ||||
| 					do_status | ||||
| 				fi | ||||
| 				;; | ||||
| 			*) | ||||
| @@ -482,6 +506,102 @@ do_enable_disable() { | ||||
| 	return "$ret" | ||||
| } | ||||
|  | ||||
| # show logs | ||||
| do_show_logs() { | ||||
| 	local cmd=$1 | ||||
| 	local svc | ||||
| 	local ret=0 | ||||
| 	local file | ||||
| 	shift | ||||
|  | ||||
| 	# Loop all arguments as services | ||||
| 	msg "Running $progname $cmd $*" | ||||
|  | ||||
| 	for svc in "$@"; do | ||||
| 		# Validate service name | ||||
| 		if ! [[ $svc =~ $svc_re ]]; then | ||||
| 			rmsg -1 "unexpected characters in name: '$svc'" >&2 | ||||
| 			continue | ||||
| 		fi | ||||
| 	done | ||||
|  | ||||
|  | ||||
| 	if [ -h "${RSVDIR}${cmd}" ] | ||||
| 	then | ||||
| 		if [ -d "${RSVDIR}${cmd}" ] | ||||
| 		then | ||||
| 			# TODO check for logs before globing non-existent directories | ||||
| 			printf "\n%20s\n" "${colorgreen}The following log files found:" | ||||
| 			local logs_files_array=($(ls /var/log/$cmd/{*.*,current})) | ||||
| 			printf "\n$colorblue" | ||||
| 			printf '%s\n' "${logs_files_array[@]}" | ||||
|  | ||||
| 			printf "\n$colormagenta" | ||||
| 			read -n 1 -s -r -p "Press any key to continue" | ||||
|  | ||||
| 			printf "\n" | ||||
| 			printf "\n${colorcyan}Log files full output:\n" | ||||
| 			printf "${coloryellow}\n" | ||||
| 			printf "${coloryellow}${opt}" | ||||
|  | ||||
| 			tail -n 10  ${LOGDIR}${cmd}/{*.*,current} | less | ||||
| 			printf "\n" | ||||
| 		fi | ||||
| 	else | ||||
| 			printf "\n%20s\n" "${colorred}The service's ${cmd} log files have not been found or do not exist" | ||||
| 	fi | ||||
|  | ||||
| 	rmsg "$ret" "[$progname $cmd $*], exit code: $ret" | ||||
| 	return "$ret" | ||||
| } | ||||
|  | ||||
| # show error logs | ||||
| do_show_err_logs() { | ||||
| 	local cmd=$1 | ||||
| 	local svc | ||||
| 	local ret=0 | ||||
| 	local file | ||||
| 	shift | ||||
|  | ||||
| 	# Loop all arguments as services | ||||
| 	msg "Running $progname $cmd $*" | ||||
|  | ||||
| 	for svc in "$@"; do | ||||
| 		# Validate service name | ||||
| 		if ! [[ $svc =~ $svc_re ]]; then | ||||
| 			rmsg -1 "unexpected characters in name: '$svc'" >&2 | ||||
| 			continue | ||||
| 		fi | ||||
| 	done | ||||
|  | ||||
| 	if [ -h "${RSVDIR}${cmd}" ] | ||||
| 	then | ||||
| 		if ! [ -d ${RSVDIR}${cmd} ] | ||||
| 		then | ||||
| 			printf "\n%20s\n" "${colorred}The following error log files found:" | ||||
| 			local logs_files_array=($(ls /var/log/$cmd/*error*.*)) | ||||
| 			printf "\n$colorblue" | ||||
| 			printf '%s\n' "${logs_files_array[@]}" | ||||
|  | ||||
| 			printf "\n$colormagenta" | ||||
| 			read -n 1 -s -r -p "Press any key to continue" | ||||
|  | ||||
| 			printf "\n" | ||||
| 			printf "\n${colorcyan}Log files full output:\n" | ||||
| 			printf "${coloryellow}\n" | ||||
| 			printf "${coloryellow}${opt}" | ||||
|  | ||||
| 			tail -n 10  ${LOGDIR}${cmd}/*error*.* | more | ||||
| 			printf "\n" | ||||
| 		fi | ||||
| 	else | ||||
| 			printf "\n%20s\n" "${colorred}The service's ${cmd} error log files have not been found or do not exist" | ||||
| 	fi | ||||
|  | ||||
| 	rmsg "$ret" "[$progname $cmd $*], exit code: $ret" | ||||
| 	return "$ret" | ||||
| } | ||||
|  | ||||
| # handle any other subcommand | ||||
| do_sv_cmd() { | ||||
| 	if (($# < 2)); then | ||||
| @@ -496,14 +616,14 @@ do_sv_cmd() { | ||||
| 	return "$ret" | ||||
| } | ||||
|  | ||||
| colors_set=false | ||||
| color_arg= | ||||
| tree=false | ||||
| log=false | ||||
| do_usage=-1 | ||||
| verbosity=0 | ||||
| verbosity=1 | ||||
| while getopts 'c:d:hltuvV' option; do | ||||
| 	case "$option" in | ||||
| 		c) setcolors "$OPTARG"; colors_set=true;; | ||||
| 		c) color_arg="$OPTARG";; | ||||
| 		d) SVDIR=$OPTARG;; | ||||
| 		h) do_usage=0;; | ||||
| 		l) log=true; cmd='status';; | ||||
| @@ -516,7 +636,16 @@ while getopts 'c:d:hltuvV' option; do | ||||
| done | ||||
| shift "$((OPTIND - 1))" | ||||
|  | ||||
| $colors_set || setcolors auto | ||||
| if [ -n "$NO_COLOR" ] && [ -z "$color_arg" ] | ||||
| then | ||||
| 	setcolors off | ||||
| elif [ -n "$color_arg" ] | ||||
| then | ||||
| 	setcolors "$color_arg" | ||||
| else | ||||
| 	setcolors auto | ||||
| fi | ||||
|  | ||||
|  | ||||
| # we wait until the colors are optionally set to output the usage message | ||||
| if ((do_usage > -1)); then | ||||
| @@ -540,6 +669,16 @@ case "$cmd" in | ||||
| 	enable|disable) | ||||
| 		do_enable_disable "$cmd" "$@" | ||||
| 		;; | ||||
| 	logs) | ||||
| 		do_show_logs "$@" | ||||
| 		;; | ||||
| 	alllogs) | ||||
| 		do_show_logs "$@" | ||||
| 		;; | ||||
| 	errorlogs) | ||||
| 		do_show_err_logs "$@" | ||||
| 		;; | ||||
|  | ||||
| 	*) | ||||
| 		if $tree; then | ||||
| 			rmsg -1 "-t can only be specified with 'status'" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user