freeswitch-stable: cleanup init script

- clean up variable names
 - add options to uci config to enable/disable logging
 - remove option change_perm as it's hacky
 - change check before mkdir and friends to prevent
   overwriting/chown/chmod of existing files/directories (important)

Signed-off-by: Sebastian Kemper <sebastian_ml@gmx.net>
This commit is contained in:
Sebastian Kemper 2018-11-12 22:29:25 +01:00
parent 92bdfa634d
commit 84bf41e139
2 changed files with 53 additions and 53 deletions

View file

@ -3,8 +3,9 @@ config freeswitch 'general'
option enabled '0'
option user 'freeswitch'
option group 'freeswitch'
option log_stderr '1'
option log_stdout '1'
option options '-nonat -np'
option change_perm '0'
config freeswitch 'directories'
option cache '/tmp/freeswitch/cache'

View file

@ -7,89 +7,88 @@ USE_PROCD=1
#PROCD_DEBUG=1
FS=freeswitch
LOGGER="/usr/bin/logger -p user.err -s -t $FS"
NAME=freeswitch
COMMAND=/usr/bin/$NAME
# used in both start_service() and stop_service()
fs_dir_run=/var/run/$FS
LOGGER="/usr/bin/logger -p user.err -s -t $NAME"
start_service() {
local change_perm
local dir
local enabled
local fs_user
local fs_group
local user
local group
local fs_dir_cache
local fs_dir_db
local fs_dir_etc=/etc/$FS
local fs_dir_localstate=/var/lib/$FS
local fs_dir_log
local fs_dir_recordings
local fs_dir_storage
local fs_dir_temp
local log_stderr
local log_stdout
local OPTIONS
local dir_cache
local dir_db
local dir_etc=/etc/$NAME
local dir_localstate=/var/lib/$NAME
local dir_log
local dir_recordings
local dir_run=/var/run/$NAME
local dir_storage
local dir_temp
local PROG=/usr/bin/$FS
local options
config_load $FS
config_load $NAME
config_get_bool enabled general enabled 0
if [ $enabled -eq 0 ]; then
$LOGGER service not enabled in /etc/config/$FS
$LOGGER service not enabled in /etc/config/$NAME
exit 1
fi
config_get fs_user general user $FS
config_get fs_group general group $FS
config_get user general user $NAME
config_get group general group $NAME
config_get fs_dir_cache directories cache /tmp/$FS/cache
config_get fs_dir_db directories db /tmp/$FS/db
config_get fs_dir_log directories log /tmp/$FS/log
config_get fs_dir_recordings directories recordings /tmp/$FS/recordings
config_get fs_dir_storage directories storage /tmp/$FS/storage
config_get fs_dir_temp directories temp /tmp/$FS/temp
config_get_bool log_stderr general log_stderr 1
config_get_bool log_stdout general log_stdout 1
for dir in "$fs_dir_cache" "$fs_dir_db" "$fs_dir_localstate" \
"$fs_dir_log" "$fs_dir_recordings" "$fs_dir_run" "$fs_dir_storage" \
"$fs_dir_temp"
config_get dir_cache directories cache /tmp/$NAME/cache
config_get dir_db directories db /tmp/$NAME/db
config_get dir_log directories log /tmp/$NAME/log
config_get dir_recordings directories recordings /tmp/$NAME/recordings
config_get dir_storage directories storage /tmp/$NAME/storage
config_get dir_temp directories temp /tmp/$NAME/temp
for dir in "$dir_cache" "$dir_db" "$dir_localstate" \
"$dir_log" "$dir_recordings" "$dir_run" "$dir_storage" \
"$dir_temp"
do
[ -n "$dir" ] && {
[ ! -e "$dir" ] && {
mkdir -p "$dir"
chown "$fs_user":"$fs_group" "$dir"
chown "$user":"$group" "$dir"
chmod 750 "$dir"
}
done
config_get_bool change_perm general change_perm 0
[ $change_perm -eq 1 ] && [ -d "$fs_dir_etc" ] && {
find "$fs_dir_etc" -type f -exec chown root:"$fs_group" {} \;
find "$fs_dir_etc" -type f -exec chmod 640 {} \;
}
config_get OPTIONS general options
config_get options general options
procd_open_instance
# starting with full path seems cleaner judging by 'ps' output
procd_set_param command $PROG
procd_set_param command $COMMAND
# need to specify all or none of -conf, -log, and -db
procd_append_param command \
-cache "$fs_dir_cache" \
-conf "$fs_dir_etc" \
-db "$fs_dir_db" \
-g "$fs_group" \
-log "$fs_dir_log" \
-recordings "$fs_dir_recordings" \
-run "$fs_dir_run" \
-storage "$fs_dir_storage" \
-temp "$fs_dir_temp" \
-u "$fs_user" \
$OPTIONS \
-cache "$dir_cache" \
-conf "$dir_etc" \
-db "$dir_db" \
-g "$group" \
-log "$dir_log" \
-recordings "$dir_recordings" \
-run "$dir_run" \
-storage "$dir_storage" \
-temp "$dir_temp" \
-u "$user" \
$options \
-c
# forward stderr to logd
procd_set_param stderr 1
procd_set_param stderr $log_stderr
# same for stdout
procd_set_param stdout $log_stdout
procd_close_instance
}