name: Update PPA Packages on: workflow_dispatch: inputs: package: description: 'Package to upload (dms, dms-git, dms-greeter, or all)' required: false default: 'dms-git' rebuild_release: description: 'Release number for rebuilds (e.g., 2, 3, 4 for ppa2, ppa3, ppa4)' required: false default: '' schedule: - cron: '0 */3 * * *' # Every 3 hours for dms-git builds jobs: check-updates: name: Check for updates runs-on: ubuntu-latest outputs: has_updates: ${{ steps.check.outputs.has_updates }} packages: ${{ steps.check.outputs.packages }} steps: - name: Checkout uses: actions/checkout@v4 with: fetch-depth: 0 - name: Check for updates id: check run: | if [[ "${{ github.event_name }}" == "schedule" ]]; then echo "packages=dms-git" >> $GITHUB_OUTPUT echo "Checking if dms-git source has changed..." # Get current commit hash (8 chars to match changelog format) CURRENT_COMMIT=$(git rev-parse --short=8 HEAD) # Extract commit hash from changelog # Format: dms-git (0.6.2+git2264.c5c5ce84) questing; urgency=medium CHANGELOG_FILE="distro/ubuntu/dms-git/debian/changelog" if [[ -f "$CHANGELOG_FILE" ]]; then CHANGELOG_COMMIT=$(head -1 "$CHANGELOG_FILE" | grep -oP '\.[a-f0-9]{8}' | tr -d '.' || echo "") if [[ -n "$CHANGELOG_COMMIT" ]]; then if [[ "$CURRENT_COMMIT" == "$CHANGELOG_COMMIT" ]]; then echo "has_updates=false" >> $GITHUB_OUTPUT echo "📋 Commit $CURRENT_COMMIT already in changelog, skipping upload" else echo "has_updates=true" >> $GITHUB_OUTPUT echo "📋 New commit detected: $CURRENT_COMMIT (changelog has $CHANGELOG_COMMIT)" fi else echo "has_updates=true" >> $GITHUB_OUTPUT echo "📋 Could not extract commit from changelog, proceeding with upload" fi else echo "has_updates=true" >> $GITHUB_OUTPUT echo "📋 No changelog file found, proceeding with upload" fi elif [[ -n "${{ github.event.inputs.package }}" ]]; then echo "packages=${{ github.event.inputs.package }}" >> $GITHUB_OUTPUT echo "has_updates=true" >> $GITHUB_OUTPUT echo "Manual trigger: ${{ github.event.inputs.package }}" else echo "packages=dms-git" >> $GITHUB_OUTPUT echo "has_updates=true" >> $GITHUB_OUTPUT fi upload-ppa: name: Upload to PPA needs: check-updates runs-on: ubuntu-latest if: | github.event_name == 'workflow_dispatch' || needs.check-updates.outputs.has_updates == 'true' steps: - name: Checkout uses: actions/checkout@v4 with: fetch-depth: 0 - name: Set up Go uses: actions/setup-go@v5 with: go-version: '1.24' cache: false - name: Install build dependencies run: | sudo apt-get update sudo apt-get install -y \ debhelper \ devscripts \ dput \ lftp \ build-essential \ fakeroot \ dpkg-dev - name: Configure GPG env: GPG_KEY: ${{ secrets.GPG_PRIVATE_KEY }} run: | echo "$GPG_KEY" | gpg --import GPG_KEY_ID=$(gpg --list-secret-keys --keyid-format LONG | grep sec | awk '{print $2}' | cut -d'/' -f2) echo "DEBSIGN_KEYID=$GPG_KEY_ID" >> $GITHUB_ENV - name: Determine packages to upload id: packages run: | if [[ "${{ github.event_name }}" == "schedule" ]]; then echo "packages=${{ needs.check-updates.outputs.packages }}" >> $GITHUB_OUTPUT echo "Triggered by schedule: uploading git package" elif [[ -n "${{ github.event.inputs.package }}" ]]; then echo "packages=${{ github.event.inputs.package }}" >> $GITHUB_OUTPUT echo "Manual trigger: ${{ github.event.inputs.package }}" else echo "packages=${{ needs.check-updates.outputs.packages }}" >> $GITHUB_OUTPUT fi - name: Upload to PPA env: REBUILD_RELEASE: ${{ github.event.inputs.rebuild_release }} run: | PACKAGES="${{ steps.packages.outputs.packages }}" # Export to ensure it's available to subprocesses if [ -n "$REBUILD_RELEASE" ]; then export REBUILD_RELEASE echo "✓ Using rebuild release number: ppa$REBUILD_RELEASE" fi if [[ "$PACKAGES" == "all" ]]; then echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" echo "Uploading dms to PPA..." if [ -n "$REBUILD_RELEASE" ]; then echo "🔄 Using rebuild release number: ppa$REBUILD_RELEASE" fi echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" REBUILD_RELEASE="$REBUILD_RELEASE" bash distro/scripts/ppa-upload.sh "distro/ubuntu/dms" dms questing echo "" echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" echo "Uploading dms-git to PPA..." echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" REBUILD_RELEASE="$REBUILD_RELEASE" bash distro/scripts/ppa-upload.sh "distro/ubuntu/dms-git" dms-git questing echo "" echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" echo "Uploading dms-greeter to PPA..." echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" REBUILD_RELEASE="$REBUILD_RELEASE" bash distro/scripts/ppa-upload.sh "distro/ubuntu/dms-greeter" danklinux questing else PPA_NAME="$PACKAGES" echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" echo "Uploading $PACKAGES to PPA..." echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━" REBUILD_RELEASE="$REBUILD_RELEASE" bash distro/scripts/ppa-upload.sh "distro/ubuntu/$PACKAGES" "$PPA_NAME" questing fi - name: Summary run: | echo "### PPA Package Upload Complete" >> $GITHUB_STEP_SUMMARY echo "" >> $GITHUB_STEP_SUMMARY echo "- **Packages**: ${{ steps.packages.outputs.packages }}" >> $GITHUB_STEP_SUMMARY if [[ "${{ needs.check-updates.outputs.has_updates }}" == "false" ]]; then echo "- **Status**: Skipped (no changes detected)" >> $GITHUB_STEP_SUMMARY fi PACKAGES="${{ steps.packages.outputs.packages }}" if [[ "$PACKAGES" == "all" ]]; then echo "- **PPA dms**: https://launchpad.net/~avengemedia/+archive/ubuntu/dms/+packages" >> $GITHUB_STEP_SUMMARY echo "- **PPA dms-git**: https://launchpad.net/~avengemedia/+archive/ubuntu/dms-git/+packages" >> $GITHUB_STEP_SUMMARY echo "- **PPA danklinux**: https://launchpad.net/~avengemedia/+archive/ubuntu/danklinux/+packages" >> $GITHUB_STEP_SUMMARY elif [[ "$PACKAGES" == "dms" ]]; then echo "- **PPA**: https://launchpad.net/~avengemedia/+archive/ubuntu/dms/+packages" >> $GITHUB_STEP_SUMMARY elif [[ "$PACKAGES" == "dms-git" ]]; then echo "- **PPA**: https://launchpad.net/~avengemedia/+archive/ubuntu/dms-git/+packages" >> $GITHUB_STEP_SUMMARY elif [[ "$PACKAGES" == "dms-greeter" ]]; then echo "- **PPA**: https://launchpad.net/~avengemedia/+archive/ubuntu/danklinux/+packages" >> $GITHUB_STEP_SUMMARY fi if [[ -n "${{ steps.packages.outputs.version }}" ]]; then echo "- **Version**: ${{ steps.packages.outputs.version }}" >> $GITHUB_STEP_SUMMARY fi echo "" >> $GITHUB_STEP_SUMMARY echo "Builds will appear once Launchpad processes the uploads." >> $GITHUB_STEP_SUMMARY