All checks were successful
poll-upstream / check (push) Successful in 1s
Add %__gpg_sign_cmd macro to ~/.rpmmacros with --batch, --no-tty, and --pinentry-mode loopback so rpm --addsign works without a TTY in CI. Also add signing progress output and post-sign verification to publish-repo.sh for easier debugging. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
27 lines
727 B
Bash
Executable File
27 lines
727 B
Bash
Executable File
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
RPM_DIR="${1:?usage: $0 <rpm-directory>}"
|
|
REMOTE_DIR="/var/www/rpm/fedora/43/x86_64"
|
|
|
|
# sign each rpm with the imported gpg key
|
|
for rpm in "${RPM_DIR}"/*.rpm; do
|
|
echo "signing ${rpm}..."
|
|
rpm --addsign "${rpm}"
|
|
rpm --checksig "${rpm}"
|
|
done
|
|
|
|
install --directory --mode 700 ~/.ssh
|
|
echo "${RSYNC_SSH_KEY}" | install --mode 600 /dev/stdin ~/.ssh/id_ed25519
|
|
ssh-keyscan -H oolon.kosherinata.internal > ~/.ssh/known_hosts 2>/dev/null
|
|
|
|
rsync \
|
|
--archive \
|
|
--verbose \
|
|
--chmod D755,F644 \
|
|
"${RPM_DIR}/"*.rpm \
|
|
"${RSYNC_TARGET}:${REMOTE_DIR}/"
|
|
ssh "${RSYNC_TARGET}" "cd ${REMOTE_DIR} && createrepo_c --update ."
|
|
|
|
echo "Published $(ls ${RPM_DIR}/*.rpm | wc -l) RPMs"
|