summaryrefslogtreecommitdiff
path: root/db-update
diff options
context:
space:
mode:
Diffstat (limited to 'db-update')
-rwxr-xr-xdb-update107
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)