0
0
Fork 0
mirror of https://github.com/nextcloud/docker.git synced 2025-02-05 02:58:27 +01:00

fix(hooks): Clear state delineation / consistent output

Signed-off-by: Josh <josh.t.richards@gmail.com>
This commit is contained in:
Josh 2024-11-26 12:00:46 -05:00 committed by GitHub
parent eeeb4edc24
commit f360440588
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -23,32 +23,39 @@ run_as() {
run_path() {
local hook_folder_path="/docker-entrypoint-hooks.d/$1"
local return_code=0
local found=0
echo "=> Searching for hook scripts (*.sh) to run, located in the folder: ${hook_folder_path}"
echo "=> Searching for hook scripts (*.sh) to run, located in the folder \"${hook_folder_path}\""
if ! [ -d "${hook_folder_path}" ] || directory_empty "${hook_folder_path}"; then
echo "=> Skipping the hook folder \"${hook_folder_path}\", because it doesn't exist or is empty"
echo "==> Skipped: the \"$1\" folder is empty (or does not exist)"
return 0
fi
(
find "${hook_folder_path}" -maxdepth 1 -iname '*.sh' '(' -type f -o -type l ')' -print | sort | while read -r script_file_path; do
find "${hook_folder_path}" -maxdepth 1 -iname '*.sh' '(' -type f -o -type l ')' -print | sort | (
while read -r script_file_path; do
if ! [ -x "${script_file_path}" ]; then
echo "==> The hook script \"${script_file_path}\" was skipped, because it didn't have the executable flag"
echo "==> The script \"${script_file_path}\" was skipped, because it lacks the executable flag"
found=$((found-1))
continue
fi
echo "==> Running the hook script (cwd: $(pwd)): \"${script_file_path}\""
echo "==> Running the script (cwd: $(pwd)): \"${script_file_path}\""
found=$((found+1))
run_as "${script_file_path}" || return_code="$?"
if [ "${return_code}" -ne "0" ]; then
echo "==> Failed at executing hook script \"${script_file_path}\". Exit code: ${return_code}"
echo "==> Failed at executing script \"${script_file_path}\". Exit code: ${return_code}"
exit 1
fi
echo "==> Finished the hook script: \"${script_file_path}\""
echo "==> Finished executing the script: \"${script_file_path}\""
done
if [ "$found" -lt "1" ]; then
echo "==> Skipped: the \"$1\" folder does not contain any valid scripts"
else
echo "=> Completed executing scripts in the \"$1\" folder"
fi
)
}