# 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
