23 Commits

Author SHA1 Message Date
406eb2cca6 Minor fix 2024-01-02 20:02:34 +01:00
d240dbcb39 If current sessions SVDIR is not available, enable/disable the services in the default runlevel 2024-01-02 01:13:35 +01:00
6959074db1 Update help info 2022-12-26 19:39:22 +01:00
931a5f45cb Add bash autocompletion script. 2022-12-24 18:33:47 +01:00
90062cb1fa Add zsh autocompletion script and update the README. 2022-12-24 18:33:47 +01:00
54a6c3f17f Add support for NO_COLOR environoment variable 2022-12-24 18:33:47 +01:00
2a494bcdc4 Fix log printing 2022-12-24 18:33:47 +01:00
2e63f5b5a0 Change copyright info, bump version and remove unnecessary whitespace 2022-12-24 18:33:40 +01:00
95ebba50e3 Verbosity handling improvement, corrections of the services filtering output and help 2021-02-26 01:38:42 +02:00
0506889700 Fixed hanging on output, if no logs are found for a nonexist service 2021-02-02 20:30:43 +02:00
59d2325f73 Fixed: Incorrect status of services, on rsm list after enable <service> - rsm lists all right after enable/disable <service> 2021-01-23 21:50:34 +02:00
0477798c9e Code review, removed locals from logs() and errorlogs() and added them as globals 2021-01-21 21:01:25 +02:00
750cde1aa1 Improved -h switch output, changed color of the error log files output title 2021-01-21 20:12:07 +02:00
16f8b86d1b Fixed bug of improper listing logs, when script runs on /usr/bin 2021-01-21 13:07:54 +02:00
3bd632a39b Update README.md 2021-01-19 22:53:42 +02:00
b17e0376bc logs <svc> / alllogs <svc> / errorlogs <svc> added to rsm, as commands 2021-01-19 22:33:57 +02:00
250654bfdb New release number, 1.3.9 2021-01-13 21:06:00 +02:00
edbabda2df Updated Screenshot at README.md, with verbociry on 2021-01-13 21:01:43 +02:00
9d13a0576b Verbocity on by default, for better output 2021-01-13 20:57:59 +02:00
27bcdec74f Better code comments 2021-01-13 19:46:52 +02:00
6815946574 Tiny code beautification, to fit the rest part of the code 2021-01-13 04:55:57 +02:00
f4e12ec2e1 Updated README.md with the enable command, in details 2021-01-13 02:01:01 +02:00
533d0e6250 fixed link/unlink service, on enable/disable rsm commands 2021-01-12 23:36:08 +02:00
5 changed files with 343 additions and 18 deletions

View File

@@ -1,5 +1,6 @@
Copyright 2020 Dave Eddy <dave@daveeddy.com> (https://www.daveeddy.com) Copyright 2020 Dave Eddy <dave@daveeddy.com> (https://www.daveeddy.com)
Forked as a contribution to Artix Linux by linuxer <linuxer@artixlinux.org> 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: 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:

View File

@@ -1,11 +1,10 @@
# `rsm` - Runit Service Manager # `rsm` - Runit Service Manager
===================================
- This is the CLI Runit Service Manager {rsm}, 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.
![](https://imgur.com/jxQUIGb.png) ![](https://imgur.com/S9zdEIU.png)
## Manage and view runit services. ## Manage and view runit services.
@@ -18,10 +17,12 @@ Quick Examples:
- `rsm status` - same as above - `rsm status` - same as above
- `rsm stop <svc>` - stop a service - `rsm stop <svc>` - stop a service
- `rsm start <svc>` - start a service - `rsm start <svc>` - start a service
- `rsm restart <svc>` - restart 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 enable <svc>` - enable a service (autostart at boot)
- `rsm disable <svc>` - disable a service (no autostart at boot) - `rsm disable <svc>` - disable a service (no autostart at boot)
- `rsm hup <svc>` - refresh a service (`SIGHUP`) - `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: Status:
@@ -101,6 +102,12 @@ $ make check
shellcheck rsm 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 License
------- -------

33
autocompletion/bash/rsm Normal file
View 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
View 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

181
rsm
View File

@@ -1,14 +1,25 @@
#!/usr/bin/env bash #!/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 # Date: August 29, 2018
# License: MIT # License: MIT
RSM_VERSION='v1.3.7' RSM_VERSION='v1.4.9'
export RUNSVDIR=${RUNSVDIR:-/etc/runit/runsvdir}
export SVDIR=${SVDIR:-/run/runit/service/} export SVDIR=${SVDIR:-/run/runit/service/}
export LOGDIR="/var/log/"
export RSVDIR="/run/runit/service/"
export FLDIR=${FLDIR:-/etc/runit/sv/}
charup='✔' charup='✔'
chardown='X' chardown='X'
@@ -116,13 +127,15 @@ usage() {
cat <<EOF cat <<EOF
$colormagenta ______ ____ __ __ $colormagenta ______ ____ __ __
$colormagenta | | \ \ / ___\ | \/ | $colorgreen Runit Service Manager ($RSM_VERSION) $colormagenta | | \ \ / ___\ | \/ | $colorgreen Runit Service Manager for Artix Linux ($RSM_VERSION)
$colormagenta | |_/ / \____ | || | $colorgreen Source: https://gitea.artixlinux.org/linuxer/Runit-Service-Manager $colormagenta | |_/ / \____ | || | $colorgreen Source: https://gitea.artixlinux.org/nikolar/Runit-Service-Manager
$colormagenta | | \ \ \____/ | || | $colorgreen MIT License $colormagenta | | \ \ \____/ | || | $colorgreen MIT License
$logo $colorblue Manage and view runit services $logo $colorblue Manage and view runit services
$logo $colorblue Made specifically for Void Linux but should work anywhere $logo $colorblue Made specifically for Void Linux but should work anywhere
$logo $colorblue Author: Dave Eddy <dave@daveeddy.com> (bahamas10) $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} ${coloryellow}USAGE:${colorgreen}
$progname [OPTIONS] [SUBCOMMAND] [<ARGS>] $progname [OPTIONS] [SUBCOMMAND] [<ARGS>]
@@ -130,7 +143,7 @@ $progname [-u] [-d <dir>] [-h] [-t] [SUBCOMMAND] [...]
${coloryellow}OPTIONS:${colorgreen} ${coloryellow}OPTIONS:${colorgreen}
${colorgreen}-c <yes|no|auto> $cr Enable/disable color output, defaults to auto ${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}-h $cr Print this message and exit
${colorgreen}-l $cr Show log processes, this is a shortcut for 'status -l' ${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' ${colorgreen}-t $cr Tree view, this is a shortcut for 'status -t'
@@ -160,6 +173,10 @@ ${colorgreen}start <service> $cr Start the service
${colorgreen}stop <service> $cr Stop the service ${colorgreen}stop <service> $cr Stop the service
${colorgreen}restart <service> $cr Restart the service ${colorgreen}restart <service> $cr Restart the service
${colorgreen}reload <service> $cr Reload the service (send SIGHUP) ${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} ${coloryellow}EXAMPLES:${colorgreen}
${colorgreen}$progname $cr Show service status in /var/service ${colorgreen}$progname $cr Show service status in /var/service
@@ -379,7 +396,9 @@ do_status() {
fi fi
if [[ -n $filter && $svc != *"$filter"* ]]; then 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 continue
fi fi
@@ -449,7 +468,7 @@ do_enable_disable() {
fi fi
# ensure service exists # ensure service exists
if ! [[ -d $svc ]]; then if ! [[ -d ${FLDIR}${svc} ]]; then
rmsg -1 "service directory '$svc' does not exist" >&2 rmsg -1 "service directory '$svc' does not exist" >&2
continue continue
fi fi
@@ -462,6 +481,14 @@ do_enable_disable() {
if ! rm -f "$file"; then if ! rm -f "$file"; then
rmsg 1 "failed to enable '$svc'" rmsg 1 "failed to enable '$svc'"
ret=1 ret=1
else
if [ -L "${SVDIR}" ]
then
ln -s "${FLDIR}${svc}" "${SVDIR}"
else
ln -s "${FLDIR}${svc}" "${RUNSVDIR}/default" # default runlevel
fi
do_status
fi fi
;; ;;
disable) disable)
@@ -469,6 +496,14 @@ do_enable_disable() {
if ! disable_message "$svc" > "$file"; then if ! disable_message "$svc" > "$file"; then
rmsg 1 "failed to disable '$svc'" rmsg 1 "failed to disable '$svc'"
ret=1 ret=1
else
if [ -L "${SVDIR}" ]
then
unlink "${SVDIR}${svc}"
else
unlink "${RUNSVDIR}/default/${svc}" # default runlevel
fi
do_status
fi fi
;; ;;
*) *)
@@ -482,6 +517,102 @@ do_enable_disable() {
return "$ret" 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 # handle any other subcommand
do_sv_cmd() { do_sv_cmd() {
if (($# < 2)); then if (($# < 2)); then
@@ -496,14 +627,14 @@ do_sv_cmd() {
return "$ret" return "$ret"
} }
colors_set=false color_arg=
tree=false tree=false
log=false log=false
do_usage=-1 do_usage=-1
verbosity=0 verbosity=1
while getopts 'c:d:hltuvV' option; do while getopts 'c:d:hltuvV' option; do
case "$option" in case "$option" in
c) setcolors "$OPTARG"; colors_set=true;; c) color_arg="$OPTARG";;
d) SVDIR=$OPTARG;; d) SVDIR=$OPTARG;;
h) do_usage=0;; h) do_usage=0;;
l) log=true; cmd='status';; l) log=true; cmd='status';;
@@ -516,7 +647,16 @@ while getopts 'c:d:hltuvV' option; do
done done
shift "$((OPTIND - 1))" 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 # we wait until the colors are optionally set to output the usage message
if ((do_usage > -1)); then if ((do_usage > -1)); then
@@ -525,7 +665,12 @@ if ((do_usage > -1)); then
fi fi
# move to the service directory # move to the service directory
cd "$SVDIR" || fatal "failed to enter dir: $SVDIR" if [ -L "$SVDIR" ]
then
cd "$SVDIR" || fatal "failed to enter dir: $SVDIR"
else
cd "$RUNSVDIR/default" || fatal "failed to enter dir: $FLDIR"
fi
# figure out 'cmd' command # figure out 'cmd' command
if [[ -z $cmd ]]; then if [[ -z $cmd ]]; then
@@ -540,6 +685,16 @@ case "$cmd" in
enable|disable) enable|disable)
do_enable_disable "$cmd" "$@" do_enable_disable "$cmd" "$@"
;; ;;
logs)
do_show_logs "$@"
;;
alllogs)
do_show_logs "$@"
;;
errorlogs)
do_show_err_logs "$@"
;;
*) *)
if $tree; then if $tree; then
rmsg -1 "-t can only be specified with 'status'" rmsg -1 "-t can only be specified with 'status'"