73 lines
2.4 KiB
Text
Executable file
73 lines
2.4 KiB
Text
Executable file
# SPDX-License-Identifier: GPL-2.0
|
|
# Copyright (C) 2018-present Team LibreELEC (https://libreelec.tv)
|
|
|
|
_get_file_already_downloaded() {
|
|
[ ! -f "${PACKAGE}" -o ! -f "${STAMP_URL}" -o ! -f "${STAMP_SHA}" ] && return 1
|
|
[ -n "${PKG_SHA256}" -a "$(cat ${STAMP_SHA} 2>/dev/null)" != "${PKG_SHA256}" ] && return 1
|
|
return 0
|
|
}
|
|
|
|
# Latest file already present, exit now...
|
|
_get_file_already_downloaded && exit 0
|
|
|
|
lock_source_dir "${1}"
|
|
|
|
# Check again in case of concurrent access - if nothing needs to be downloaded, exit now...
|
|
_get_file_already_downloaded && exit 0
|
|
|
|
# Check if a package source directory already exists and clean it out if it does
|
|
if [ -d "${SOURCES}/${1}" ]; then
|
|
build_msg "CLR_CLEAN" "DELETE" "(${1}/${1}-*)"
|
|
rm -rf "${SOURCES}/${1}/${1}-"*
|
|
fi
|
|
|
|
# At this point, we need to download something...
|
|
build_msg "CLR_GET" "GET" "${1} (archive)" "indent"
|
|
|
|
pkg_lock_status "GETPKG" "${PKG_NAME}" "unpack" "downloading package..."
|
|
|
|
PACKAGE_MIRROR="${DISTRO_MIRROR}/${PKG_NAME}/${PKG_SOURCE_NAME}"
|
|
[ "${VERBOSE}" != "yes" ] && WGET_OPT=-q
|
|
WGET_CMD="wget --secure-protocol=TLSv1_2 --output-file=- --timeout=30 --tries=3 --passive-ftp --no-check-certificate -c ${WGET_OPT} --progress=bar:force --show-progress -O ${PACKAGE}"
|
|
|
|
# unset LD_LIBRARY_PATH to stop wget from using toolchain/lib and loading libssl.so/libcrypto.so instead of host libraries
|
|
unset LD_LIBRARY_PATH
|
|
|
|
rm -f "${STAMP_URL}" "${STAMP_SHA}"
|
|
|
|
PKG_URLS="${PKG_URL}"
|
|
if [ -n "${PACKAGE_MIRROR}" ]
|
|
then
|
|
PKG_URLS="${PKG_URL} ${PACKAGE_MIRROR}"
|
|
fi
|
|
|
|
NBWGET=10
|
|
while [ ${NBWGET} -gt 0 ]; do
|
|
for url in ${PKG_URLS}; do
|
|
if [[ "$PKG_USETOKEN" == "yes" ]]; then
|
|
if [[ $url == https://github.com/* ]] && [[ -n $COREELEC_GHTOKEN ]]; then
|
|
WGET_HEADER=--header="Authorization: token $COREELEC_GHTOKEN"
|
|
fi
|
|
else
|
|
WGET_HEADER=--header=""
|
|
fi
|
|
|
|
rm -f "${PACKAGE}"
|
|
if ${WGET_CMD} "$WGET_HEADER" "${url}"; then
|
|
CALC_SHA256=$(sha256sum "${PACKAGE}" | cut -d" " -f1)
|
|
|
|
[ -z "${PKG_SHA256}" -o "${PKG_SHA256}" = "${CALC_SHA256}" ] && break 2
|
|
|
|
build_msg "CLR_WARNING" "WARNING" "Incorrect checksum calculated on downloaded file: got ${CALC_SHA256} wanted ${PKG_SHA256}"
|
|
fi
|
|
done
|
|
NBWGET=$((NBWGET - 1))
|
|
done
|
|
|
|
if [ ${NBWGET} -eq 0 ]; then
|
|
die "\nCannot get ${1} sources : ${PKG_URL}\nTry later!"
|
|
else
|
|
build_msg "CLR_INFO" "INFO" "Calculated checksum: ${CALC_SHA256}"
|
|
echo "${PKG_URL}" > "${STAMP_URL}"
|
|
echo "${CALC_SHA256}" > "${STAMP_SHA}"
|
|
fi
|