diff --git a/.github/workflows/ci_shellcheck.yml b/.github/workflows/ci_shellcheck.yml index 17a21cf5c..9eab4c9fb 100644 --- a/.github/workflows/ci_shellcheck.yml +++ b/.github/workflows/ci_shellcheck.yml @@ -7,8 +7,8 @@ on: push: paths: - '*.sh' - - '*/*.sh' - - '*/*/*.sh' + - 'scripts/*.sh' + - 'scripts/utilities/*.sh' # A workflow run is made up of one or more jobs that can run sequentially or in parallel jobs: @@ -27,7 +27,7 @@ jobs: run: | # check bash files (bash -n, shellcheck -x) err=0 - for i in $(find . -maxdepth 2 -name '*.sh'); do + for i in $(find . -maxdepth 3 -name '*.sh'); do echo "==================== $i" bash -n $i if [ $? -ne 0 ]; then diff --git a/remoteWebsiteInstall.sh b/remoteWebsiteInstall.sh index 23e710221..660afd36d 100755 --- a/remoteWebsiteInstall.sh +++ b/remoteWebsiteInstall.sh @@ -104,7 +104,7 @@ function enter_yes_no() fi done - return ${RESULT} + return "${RESULT}" } # prompt the user to press any key. @@ -163,7 +163,7 @@ function display_box() else echo -e "${DIALOG_TEXT}" fi - return ${RET} + return "${RET}" fi # Don't use: it's redundant most of the time --backtitle "${DIALOG_BACK_TITLE}" \ @@ -593,7 +593,7 @@ function check_if_files_exist() fi done - return ${RET_CODE} + return "${RET_CODE}" } # Deletes a file from the remote server. diff --git a/scripts/checkAllsky.sh b/scripts/checkAllsky.sh index b870c711c..a78f0b3a9 100755 --- a/scripts/checkAllsky.sh +++ b/scripts/checkAllsky.sh @@ -868,4 +868,4 @@ else fi fi -exit ${RET} +exit "${RET}" diff --git a/scripts/generateForDay.sh b/scripts/generateForDay.sh index 4eae661f7..ebfcaea63 100755 --- a/scripts/generateForDay.sh +++ b/scripts/generateForDay.sh @@ -183,14 +183,14 @@ if [[ ${TYPE} == "GENERATE" ]]; then [[ -n ${DEBUG_ARG} ]] && echo "${ME}: Executing: ${CMD}" # shellcheck disable=SC2086 eval ${CMD} - RET=$? + local RET=$? if [[ ${RET} -ne 0 ]]; then echo -e "${RED}${ME}: Command Failed: ${CMD}${NC}" elif [[ ${SILENT} == "false" ]]; then echo -e "\tDone" fi - return ${RET} + return "${RET}" } else diff --git a/scripts/installUpgradeFunctions.sh b/scripts/installUpgradeFunctions.sh index 6cbe32c74..d7581df40 100644 --- a/scripts/installUpgradeFunctions.sh +++ b/scripts/installUpgradeFunctions.sh @@ -605,9 +605,9 @@ function replace_website_placeholders() config.camera "camera" "${CAMERA}" \ config.lens "lens" "${LENS}" \ config.computer "computer" "${COMPUTER}" \ - config.AllskyVersion "AllskyVersion" "${ALLSKY_VERSION}" \ - ${MINI_TLAPSE_DISPLAY} "mini_display" "${MINI_TLAPSE_DISPLAY_VALUE}" \ - ${MINI_TLAPSE_URL} "mini_url" "${MINI_TLAPSE_URL_VALUE}" + "${WEBSITE_ALLSKY_VERSION}" "AllskyVersion" "${ALLSKY_VERSION}" \ + "${MINI_TLAPSE_DISPLAY}" "mini_display" "${MINI_TLAPSE_DISPLAY_VALUE}" \ + "${MINI_TLAPSE_URL}" "mini_url" "${MINI_TLAPSE_URL_VALUE}" } diff --git a/scripts/postData.sh b/scripts/postData.sh index a6274ae6e..62ae3a110 100755 --- a/scripts/postData.sh +++ b/scripts/postData.sh @@ -83,7 +83,7 @@ while [[ $# -gt 0 ]]; do esac shift done -[[ ${RET} -ne 0 ]] && usage_and_exit ${RET} +[[ ${RET} -ne 0 ]] && usage_and_exit "${RET}" [[ ${HELP} == "true" ]] && usage_and_exit 0 diff --git a/scripts/postToMap.sh b/scripts/postToMap.sh index e33a5cc54..325d38608 100755 --- a/scripts/postToMap.sh +++ b/scripts/postToMap.sh @@ -73,7 +73,7 @@ function check_URL() else # Make sure it's a valid URL. Some servers don't return anything if the user agent is "curl". - local CONTENT="$( curl --user-agent Allsky --location --head --silent --show-error --connect-timeout ${TIMEOUT} "${URL}" 2>&1 )" + local CONTENT="$( curl --user-agent Allsky --location --head --silent --show-error --connect-timeout "${TIMEOUT}" "${URL}" 2>&1 )" local RET=$? if [[ ${DEBUG} == "true" ]]; then echo -e "\n${wDEBUG}" @@ -356,7 +356,7 @@ if [[ ${UPLOAD} == "true" ]]; then else echo -e "${ERROR_MSG_START}${E}${wNC}" fi - exit ${RETURN_CODE} + exit "${RETURN_CODE}" fi # Get the return string from the server. It's the last line of output. diff --git a/scripts/saveImage.sh b/scripts/saveImage.sh index 6b04b9557..f39025fe0 100755 --- a/scripts/saveImage.sh +++ b/scripts/saveImage.sh @@ -363,7 +363,7 @@ if [[ ${SAVE_IMAGE} == "true" ]]; then # Remove the oldest files if we haven't reached the limit. if [[ ${LEFT} -le 0 ]]; then KEEP=$((TIMELAPSE_MINI_IMAGES - TIMELAPSE_MINI_FREQUENCY)) - x="$( tail -${KEEP} "${MINI_TIMELAPSE_FILES}" )" + x="$( tail "-${KEEP}" "${MINI_TIMELAPSE_FILES}" )" echo -e "${x}" > "${MINI_TIMELAPSE_FILES}" if [[ ${ALLSKY_DEBUG_LEVEL} -ge 3 ]]; then echo -en "${YELLOW}${ME}: Replaced ${TIMELAPSE_MINI_FREQUENCY} oldest, LEFT=$LEFT, KEEP=$KEEP" diff --git a/scripts/testUpload.sh b/scripts/testUpload.sh index b3965994d..9e1fc38e0 100755 --- a/scripts/testUpload.sh +++ b/scripts/testUpload.sh @@ -302,4 +302,4 @@ if [[ -s ${MSG_FILE} ]]; then fi rm -f "${MSG_FILE}" -exit ${RET} +exit "${RET}" diff --git a/scripts/utilities/allsky-config.sh b/scripts/utilities/allsky-config.sh index f102c7341..89574f55a 100755 --- a/scripts/utilities/allsky-config.sh +++ b/scripts/utilities/allsky-config.sh @@ -42,6 +42,7 @@ while [[ $# -gt 0 ]]; do *) CMD="${ARG}" shift + # shellcheck disable=SC2124 CMD_ARGS="${@}" break; ;; @@ -84,6 +85,7 @@ PATH="${PATH}:${ALLSKY_UTILITIES}" # Show all the supported cameras. function show_supported_cameras() { + # shellcheck disable=SC2124 local ARGS="${@}" #shellcheck disable=SC2086 @@ -98,7 +100,7 @@ function show_supported_cameras() ARGS="$( prompt "${PROMPT}" "${OPTS[@]}" )" fi - #shellcheck disable=SC2086 + # shellcheck disable=SC2086 show_supported_cameras.sh ${ARGS} } @@ -114,10 +116,13 @@ function show_connected_cameras() else local FORMAT="%-6s %-8s %s\n" echo + # shellcheck disable=SC2059 printf "${FORMAT}" "Type" "Number" "Model" + # shellcheck disable=SC2059 printf "${FORMAT}" "====" "======" "=====" echo -e "${CAMERAS}" | while read -r TYPE NUM MODEL do + # shellcheck disable=SC2059 printf "${FORMAT}" "${TYPE}" "${NUM}" "${MODEL}" done fi @@ -127,9 +132,10 @@ function show_connected_cameras() # Show all the currently connected cameras. function new_rpi_camera_info() { + # shellcheck disable=SC2124 local ARGS="${@}" # optional - #shellcheck disable=SC2086 + # shellcheck disable=SC2086 get_RPi_camera_info.sh ${ARGS} } @@ -232,6 +238,7 @@ function run_command() { COMMAND="${1}" shift + # shellcheck disable=SC2124 ARGUMENTS="${@}" if ! type "${COMMAND}" > /dev/null 2>&1 ; then echo -e "\n${RED}${ME}: Unknown command '${COMMAND}'.${NC}" >&2 @@ -268,7 +275,7 @@ function prompt() exit 2 else echo "${OPT}" - return ${RET} + return "${RET}" fi } @@ -294,7 +301,7 @@ if [[ -z ${CMD} ]]; then run_command "${COMMAND}" RET=$? - [[ ${ALLOW_MORE_COMMANDS} == "false" ]] && exit ${RET} + [[ ${ALLOW_MORE_COMMANDS} == "false" ]] && exit "${RET}" while true; do echo -e "\n\n" echo -e "${YELLOW}${BOLD}" diff --git a/scripts/utilities/installSamba.sh b/scripts/utilities/installSamba.sh index ce8f82feb..3afdc87cd 100755 --- a/scripts/utilities/installSamba.sh +++ b/scripts/utilities/installSamba.sh @@ -75,6 +75,7 @@ echo echo -en "${BOLD}" echo "=============================================" echo -n "Press RETURN to continue with installation: " +# shellcheck disable=SC2034 read -r x echo -e "${NC}"