From 72fd3e3b8768697366fc5333a4def46f01730de8 Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Thu, 3 Sep 2020 09:12:49 -0500 Subject: [PATCH] super simple --- Dockerfile | 10 +-- lib/linter.sh | 65 +++++---------- lib/linterVersions.sh | 185 ++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 212 insertions(+), 48 deletions(-) create mode 100755 lib/linterVersions.sh diff --git a/Dockerfile b/Dockerfile index b16d60c5..a9fda8f6 100644 --- a/Dockerfile +++ b/Dockerfile @@ -306,11 +306,6 @@ ENV PATH="$PATH":"$GOROOT"/bin:"$GOPATH"/bin RUN mkdir -p ${GOPATH}/src ${GOPATH}/bin RUN go get mvdan.cc/sh/v3/cmd/shfmt -############################# -# Bootstrap npm-groovy-lint # -############################# -RUN npm-groovy-lint --version - ########################################### # Load GitHub Env Vars for GitHub Actions # ########################################### @@ -395,6 +390,11 @@ COPY lib /action/lib ################################## COPY TEMPLATES /action/lib/.automation +################################### +# Run to build file with versions # +################################### +# RUN /action/lib/linterVersions.sh + ###################### # Set the entrypoint # ###################### diff --git a/lib/linter.sh b/lib/linter.sh index 8282bee8..ed531bbf 100755 --- a/lib/linter.sh +++ b/lib/linter.sh @@ -17,6 +17,8 @@ source /action/lib/buildFileList.sh # Source the function script(s) source /action/lib/validation.sh # Source the function script(s) # shellcheck source=/dev/null source /action/lib/worker.sh # Source the function script(s) +# shellcheck source=/dev/null +source /action/lib/linterVersions.sh # Source the function script(s) ########### # GLOBALS # @@ -128,6 +130,8 @@ TERRAFORM_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${TERRAFORM_FILE_NAME}" # Path TYPESCRIPT_FILE_NAME="${TYPESCRIPT_ES_CONFIG_FILE:-.eslintrc.yml}" # Name of the file TYPESCRIPT_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${TYPESCRIPT_FILE_NAME}" # Path to the Typescript lint rules TYPESCRIPT_STANDARD_LINTER_RULES='' # ENV string to pass when running js standard +# Version File info +VERSION_FILE='/action/lib/linter-versions.txt' # File to store linter versions # YAML Vars YAML_FILE_NAME="${YAML_CONFIG_FILE:-.yaml-lint.yml}" # Name of the file YAML_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${YAML_FILE_NAME}" # Path to the yaml lint rules @@ -459,51 +463,26 @@ GetLinterVersions() { debug "---------------------------------------------" debug "Linter Version Info:" - ########################################################## - # Go through the array of linters and print version info # - ########################################################## - for LINTER in "${LINTER_ARRAY[@]}"; do - #################### - # Get the versions # - #################### - if [[ ${LINTER} == "arm-ttk" ]]; then - # Need specific command for ARM - mapfile -t GET_VERSION_CMD < <(grep -iE 'version' "${ARM_TTK_PSD1}" | xargs 2>&1) - elif [[ ${LINTER} == "protolint" ]] || [[ ${LINTER} == "editorconfig-checker" ]] || [[ ${LINTER} == "bash-exec" ]]; then - # Need specific command for Protolint and editorconfig-checker - mapfile -t GET_VERSION_CMD < <(echo "--version not supported") - elif [[ ${LINTER} == "lintr" ]]; then - # Need specific command for lintr (--slave is deprecated in R 4.0 and replaced by --no-echo) - mapfile -t GET_VERSION_CMD < <(R --slave -e "r_ver <- R.Version()\$version.string; \ - lintr_ver <- packageVersion('lintr'); \ - glue::glue('lintr { lintr_ver } on { r_ver }')") - elif [[ ${LINTER} == "lua" ]]; then - # Semi standardversion command - mapfile -t GET_VERSION_CMD < <("${LINTER}" -v 2>&1) - elif [[ ${LINTER} == "terrascan" ]]; then - mapfile -t GET_VERSION_CMD < <("${LINTER}" version 2>&1) - else - # Standard version command - mapfile -t GET_VERSION_CMD < <("${LINTER}" --version 2>&1) - fi + ################################ + # Cat the linter versions file # + ################################ + CAT_CMD=$(cat ${VERSION_FILE} 2>&1) - ####################### - # Load the error code # - ####################### - ERROR_CODE=$? + ####################### + # Load the error code # + ####################### + ERROR_CODE=$? - ############################## - # Check the shell for errors # - ############################## - if [ ${ERROR_CODE} -ne 0 ] || [ -z "${GET_VERSION_CMD[*]}" ]; then - warn "[${LINTER}]: Failed to get version info for:" - else - ########################## - # Print the version info # - ########################## - debug "Successfully found version for ${F[W]}[${LINTER}]${F[B]}: ${F[W]}${GET_VERSION_CMD[*]}" - fi - done + ############################## + # Check the shell for errors # + ############################## + if [ ${ERROR_CODE} -ne 0 ]; then + # Failure + warn "Failed to view version file:[${VERSION_FILE}]" + else + # Success + info "${CAT_CMD}" + fi ######################### # Print version footers # diff --git a/lib/linterVersions.sh b/lib/linterVersions.sh new file mode 100755 index 00000000..1f021436 --- /dev/null +++ b/lib/linterVersions.sh @@ -0,0 +1,185 @@ +#!/usr/bin/env bash + +################################################################################ +################################################################################ +########### Super-Linter (Get the linter versions) @admiralawkbar ############## +################################################################################ +################################################################################ + +######################### +# Source Function Files # +######################### +# shellcheck source=/dev/null +source /action/lib/log.sh # Source the function script(s) + +########### +# GLOBALS # +########### +MAIN_FILE='/action/lib/linter.sh' # Main file for super-linter +VERSION_FILE='/action/lib/linter-versions.txt' # File to store linter versions +LINTER_ARRAY=() # Array of languages to get versions +DEFAULT_IFS="${IFS}" # Get the Default IFS for updating +ARM_TTK_PSD1='/usr/bin/arm-ttk' # Powershell var + +################################################################################ +########################## FUNCTIONS BELOW ##################################### +################################################################################ +################################################################################ +#### Function GetLinterArray ################################################### +GetLinterArray() { + ################################## + # Make sure we can find the file # + ################################## + if [ ! -f "${MAIN_FILE}" ]; then + fatal "Failed to find:[${MAIN_FILE}]" + fi + + ############################### + # Get the array from the file # + ############################### + RAW_DATA=$(awk '/LINTER_ARRAY=\(/,/\)/' "${MAIN_FILE}" 2>&1) + + ####################### + # Load the error code # + ####################### + ERROR_CODE=$? + + ############################## + # Check the shell for errors # + ############################## + if [ $ERROR_CODE -ne 0 ]; then + error "Failed to get data from:[${MAIN_FILE}]" + fatal "RAW_DATA:[$RAW_DATA]" + fi + + ################################# + # Split the trash off the front # + ################################# + CLEANER_DATA=$(echo "${RAW_DATA}" | cut -d'(' -f2 | cut -d')' -f1 | tr -d '\n') + + ##################################################### + # Remove first and last "'" for easy breaking apart # + ##################################################### + MORE_CLEAN=$(echo "${CLEANER_DATA:1:${#CLEANER_DATA}-2}") + + ########################## + # Set IFS for this event # + ########################## + IFS="' '" + + ################## + # Load the array # + ################## + read -r -a LINTER_ARRAY <<< "${MORE_CLEAN}" + + ################ + # Set IFS back # + ################ + IFS="${DEFAULT_IFS}" +} +################################################################################ +#### Function GetLinterVersions ################################################ +GetLinterVersions() { + ######################### + # Print version headers # + ######################### + info "---------------------------------------------" + info "Linter Version Info:" + + ########################################################## + # Go through the array of linters and print version info # + ########################################################## + for LINTER in "${LINTER_ARRAY[@]}"; do + if [ -n "${LINTER}" ]; then + echo "Linter:[${LINTER}]" + #################### + # Get the versions # + #################### + if [[ ${LINTER} == "arm-ttk" ]]; then + # Need specific command for ARM + mapfile -t GET_VERSION_CMD < <(grep -iE 'version' "${ARM_TTK_PSD1}" | xargs 2>&1) + elif [[ ${LINTER} == "protolint" ]] || [[ ${LINTER} == "editorconfig-checker" ]] || [[ ${LINTER} == "bash-exec" ]]; then + # Need specific command for Protolint and editorconfig-checker + mapfile -t GET_VERSION_CMD < <(echo "--version not supported") + elif [[ ${LINTER} == "lintr" ]]; then + # Need specific command for lintr (--slave is deprecated in R 4.0 and replaced by --no-echo) + mapfile -t GET_VERSION_CMD < <(R --slave -e "r_ver <- R.Version()\$version.string; \ + lintr_ver <- packageVersion('lintr'); \ + glue::glue('lintr { lintr_ver } on { r_ver }')") + elif [[ ${LINTER} == "lua" ]]; then + # Semi standardversion command + mapfile -t GET_VERSION_CMD < <("${LINTER}" -v 2>&1) + elif [[ ${LINTER} == "terrascan" ]]; then + mapfile -t GET_VERSION_CMD < <("${LINTER}" version 2>&1) + elif [[ ${LINTER} == "checkstyle" ]]; then + mapfile -t GET_VERSION_CMD < <("java -jar /usr/bin/${LINTER}" --version 2>&1) + else + # Standard version command + mapfile -t GET_VERSION_CMD < <("${LINTER}" --version 2>&1) + fi + + ####################### + # Load the error code # + ####################### + ERROR_CODE=$? + + ############################## + # Check the shell for errors # + ############################## + if [ ${ERROR_CODE} -ne 0 ] || [ -z "${GET_VERSION_CMD[*]}" ]; then + warn "[${LINTER}]: Failed to get version info for:" + WriteFile "${LINTER}" "Failed to get version info" + else + ########################## + # Print the version info # + ########################## + info "Successfully found version for ${F[W]}[${LINTER}]${F[B]}: ${F[W]}${GET_VERSION_CMD[*]}" + WriteFile "${LINTER}" "${GET_VERSION_CMD}" + fi + fi + done + + ######################### + # Print version footers # + ######################### + info "---------------------------------------------" +} +################################################################################ +#### Function WriteFile ######################################################## +WriteFile() { + ############## + # Read Input # + ############## + LINTER="$1" # Name of the linter + VERSION="$2" # Version returned from check + + ################################# + # Write the data to output file # + ################################# + WRITE_CMD=$(echo "${LINTER}: ${VERSION}" >> "${VERSION_FILE}" 2>&1) + + ####################### + # Load the error code # + ####################### + ERROR_CODE=$? + + ############################## + # Check the shell for errors # + ############################## + if [ $ERROR_CODE -ne 0 ]; then + fatal "Failed to write data to file:[${WRITE_CMD}]" + fi +} +################################################################################ +############################### MAIN ########################################### +################################################################################ + +########################### +# Get the languages array # +########################### +GetLinterArray + +##################### +# GetLinterVersions # +##################### +GetLinterVersions