2023-03-27 07:35:51 -04:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2023-03-29 08:13:26 -04:00
|
|
|
###### script header ######
|
|
|
|
|
2023-03-27 07:35:51 -04:00
|
|
|
lib=$(realpath @@BASE_LIB@@) || exit 1
|
2023-03-29 08:13:26 -04:00
|
|
|
stat "${lib}" >> /dev/null || exit 1
|
2023-03-27 07:35:51 -04:00
|
|
|
|
|
|
|
# shellcheck source=../sh/lib.bash
|
|
|
|
if ! source "${lib}"; then
|
|
|
|
echo "Error: could not find import"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2023-03-29 08:13:26 -04:00
|
|
|
go=$(realpath @@GO@@)
|
|
|
|
stat "${go}" >> /dev/null
|
|
|
|
govulncheck=$(realpath @@GOVULNCHECK@@)
|
|
|
|
stat "${govulncheck}" >> /dev/null
|
|
|
|
|
|
|
|
cd "${BUILD_WORKSPACE_DIRECTORY}"
|
|
|
|
|
|
|
|
###### script body ######
|
2023-03-27 07:35:51 -04:00
|
|
|
|
|
|
|
submodules=$(${go} list -f '{{.Dir}}' -m)
|
|
|
|
|
|
|
|
PATH=$(dirname "${go}"):${PATH}
|
|
|
|
|
2023-06-14 07:58:21 -04:00
|
|
|
check() {
|
|
|
|
err=0
|
|
|
|
|
2024-06-05 10:45:27 -04:00
|
|
|
echo "Scanning Go vulnerability DB for known vulnerabilities in modules:"
|
2023-06-14 07:58:21 -04:00
|
|
|
for mod in ${submodules}; do
|
|
|
|
echo " ${mod}"
|
|
|
|
echo -n " "
|
2024-06-05 10:45:27 -04:00
|
|
|
CGO_ENABLED=0 ${govulncheck} -C "${mod}" "./..." || err=$?
|
2023-06-14 07:58:21 -04:00
|
|
|
done
|
|
|
|
|
|
|
|
exit "${err}"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if test -v SILENT; then
|
|
|
|
check > /dev/null
|
|
|
|
else
|
|
|
|
check
|
|
|
|
fi
|