diff options
Diffstat (limited to 'db-update')
-rwxr-xr-x | db-update | 107 |
1 files changed, 107 insertions, 0 deletions
diff --git a/db-update b/db-update new file mode 100755 index 0000000..3c06f63 --- /dev/null +++ b/db-update @@ -0,0 +1,107 @@ +#!/bin/bash + +. "$(dirname "$(readlink -e "$0")")/config" +. "$(dirname "$(readlink -e "$0")")/db-functions" + +if [[ $STAGING = *luke* ]]; then + set -x + PKGEXT='.pkg.tar.?z' +fi + +if [ $# -ge 1 ]; then + warning "Calling %s with a specific repository is no longer supported" "${0##*/}" + exit 1 +fi + +# Find repos with packages to release +staging_repos=($(find "${STAGING}" -mindepth 1 -type f -name "*${PKGEXT}" -printf '%h\n' | sort -u)) +if [ $? -ge 1 ]; then + die "Could not read %s" "${STAGING}" +fi + +repos=() +for staging_repo in "${staging_repos[@]##*/}"; do + if in_array "${staging_repo}" "${PKGREPOS[@]}"; then + repos+=("${staging_repo}") + fi +done + +# TODO: this might lock too much (architectures) +for repo in "${repos[@]}"; do + for pkgarch in "${ARCHES[@]}"; do + repo_lock "${repo}" "${pkgarch}" || exit 1 + done +done + +# check if packages are valid +for repo in "${repos[@]}"; do + if ! check_repo_permission "${repo}"; then + die "You don't have permission to update packages in %s" "${repo}" + fi + pkgs=($(getpkgfiles "${STAGING}/${repo}/"*${PKGEXT})) + if [ $? -eq 0 ]; then + for pkg in "${pkgs[@]}"; do + if [ -h "${pkg}" ]; then + die "Package %s is a symbolic link" "${repo}/${pkg##*/}" + fi + if ! check_pkgfile "${pkg}"; then + die "Package %s is not consistent with its meta data" "${repo}/${pkg##*/}" + fi + if ! check_pkgrepos "${pkg}"; then + die "Package %s already exists in another repository" "${repo}/${pkg##*/}" + fi + done + # This is fucking obnoxious + #if ! check_splitpkgs ${repo} "${pkgs[@]}"; then + # die "Missing split packages for %s" "${repo}" + #fi + else + die "Could not read %s" "${STAGING}" + fi +done + +for repo in "${repos[@]}"; do + msg "Updating [%s]..." "${repo}" + any_pkgs=($(getpkgfiles "${STAGING}/${repo}/"*-any${PKGEXT} 2>/dev/null)) + for pkgarch in "${ARCHES[@]}"; do + add_pkgs=() + arch_pkgs=($(getpkgfiles "${STAGING}/${repo}/"*-"${pkgarch}"${PKGEXT} 2>/dev/null)) + for pkg in "${arch_pkgs[@]}" "${any_pkgs[@]}"; do + pkgfile="${pkg##*/}" + msg2 "%s (%s)" "${pkgfile}" "${pkgarch}" + # any packages might have been moved by the previous run + if [ -f "${pkg}" ]; then + mv "${pkg}" "$FTP_BASE/${PKGPOOL}" + fi + ln -s "../../../${PKGPOOL}/${pkgfile}" "$FTP_BASE/$repo/os/${pkgarch}" + # also move signatures + if [ -f "${pkg}.sig" ]; then + mv "${pkg}.sig" "$FTP_BASE/${PKGPOOL}" + fi + if [ -f "$FTP_BASE/${PKGPOOL}/${pkgfile}.sig" ]; then + ln -s "../../../${PKGPOOL}/${pkgfile}.sig" "$FTP_BASE/$repo/os/${pkgarch}" + fi + add_pkgs+=("${pkgfile}") + done + if [ ${#add_pkgs[@]} -ge 1 ]; then + arch_repo_add "${repo}" "${pkgarch}" "${add_pkgs[@]}" + fi + done +done + +for repo in "${repos[@]}"; do + for pkgarch in "${ARCHES[@]}"; do + repo_unlock "${repo}" "${pkgarch}" + done +done + +cd "${STAGING}" +while read -r file; do + pub="${FTP_BASE}/${file}" + if [[ -f "$pub" ]]; then + warning "file already exists: %s" "${file}" + else + mkdir -p -- "${pub%/*}" + mv -vn "$file" "$pub" + fi +done < <(find other sources -type f 2>/dev/null) |