Skip to content

v1.6.3

v1.6.3 #27

---
on: # yamllint disable-line rule:truthy
release:
types:
- published
name: πŸ“¦ Build PHAR release
jobs:
build-release:
runs-on: ubuntu-latest
timeout-minutes: 4
strategy:
matrix:
php-version:
- '8.2'
dependencies:
- locked
env:
DLOAD_PHAR: ".build/phar/dload.phar"
DLOAD_PHAR_SIGNATURE: ".build/phar/dload.phar.asc"
GPG_KEYS: ".build/phar/keys.asc"
GPG_KEYS_ENCRYPTED: ".github/phar/keys.asc.gpg"
steps:
- name: πŸ“¦ Check out the codebase
uses: actions/checkout@v5
- name: πŸ› οΈ Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php-version }}
ini-values: error_reporting=E_ALL
coverage: none
tools: composer, box
- name: πŸ› οΈ Setup problem matchers
run: |
echo "::add-matcher::${{ runner.tool_cache }}/php.json"
- name: πŸ€– Validate composer.json and composer.lock
run: composer validate --ansi --strict
- name: πŸ“₯ Install dependencies with composer
uses: ramsey/composer-install@v3
with:
composer-options: "--no-dev"
- name: πŸ” Validate configuration for box-project/box
run: box validate box.json.dist --ansi
- name: πŸ“¦ Build PHAR
run: box compile
- name: πŸ’₯ Show info about dload.phar with box-project/box
run: box info ${{ env.DLOAD_PHAR }} --ansi
- name: πŸ€” Run dload.phar help command
run: ${{ env.DLOAD_PHAR }} --help
- name: πŸ” Show gpg version
run: gpg --version
- name: πŸ”‘ Decrypt keys.asc.gpg with gpg
run: gpg --batch --output ${{ env.GPG_KEYS }} --passphrase "${{ secrets.GPG_DECRYPT_PASSPHRASE }}" --yes --decrypt ${{ env.GPG_KEYS_ENCRYPTED }}
- name: πŸ“₯ Import keys from keys.asc with gpg
run: gpg --batch --import ${{ env.GPG_KEYS }}
- name: πŸ” Sign dload.phar with gpg
run: gpg --armor --local-user "${{ secrets.GPG_LOCAL_USER }}" --output ${{ env.DLOAD_PHAR_SIGNATURE }} --passphrase "${{ secrets.GPG_KEY_PASSPHRASE }}" --pinentry-mode loopback --yes --detach-sig ${{ env.DLOAD_PHAR }}
- name: ❎ Remove decrypted keys.asc
run: rm ${{ env.GPG_KEYS }}
- name: πŸ“€ Upload release assets
uses: softprops/[email protected]
if: startsWith(github.ref, 'refs/tags/')
with:
token: "${{ secrets.RELEASE_TOKEN }}"
files: |
${{ env.DLOAD_PHAR }}
${{ env.DLOAD_PHAR_SIGNATURE }}