Skip to content

Build and Distribute #22

Build and Distribute

Build and Distribute #22

Workflow file for this run

name: Build and Distribute Sofia-Sip
on:
push:
branches: [ master ]
paths:
- "**"
- "!debian/changelog"
workflow_dispatch:
concurrency:
group: ${{ github.head_ref || github.ref }}
env:
# Docker base image without tag (tags are DISTRO_CODENAME)
BASE_IMAGE: signalwire/build-deb-action
jobs:
sofia_build_rpm:
name: 'Build Rpm'
uses: s3rj1k/actions-template/.github/workflows/ci-rpm-packages.yml@ci-deb-packages
with:
PROJECT_NAME: sofia-sip
RUNNER: ubuntu-latest
PACKAGER: 'packager Andrey Volk <[email protected]>'
PLATFORM: amd64
secrets: inherit
sofia_build_deb:
name: 'Build Deb'
uses: s3rj1k/actions-template/.github/workflows/ci-deb-packages-v2.yml@ci-deb-packages
strategy:
fail-fast: false
matrix:
distro_codename:
- bookworm
- bullseye
- buster
- stretch
platform:
- amd64
- arm
with:
PROJECT_NAME: sofia-sip
RUNNER: ubuntu-latest
BASE_IMAGE: ${{ env.BASE_IMAGE }}

Check failure on line 46 in .github/workflows/all.yml

View workflow run for this annotation

GitHub Actions / Build and Distribute Sofia-Sip

Invalid workflow file

The workflow is not valid. .github/workflows/all.yml (Line: 46, Col: 19): Unrecognized named-value: 'env'. Located at position 1 within expression: env.BASE_IMAGE
DISTRO_CODENAME: ${{ matrix.distro_codename }}
PLATFORM: ${{ matrix.platform }}
generate_meta_deb:
name: 'Meta DEB'
needs: [ sofia_build_deb ]
strategy:
matrix:
distro_codename:
- bookworm
- bullseye
- buster
- stretch
platform:
- amd64
- arm
uses: s3rj1k/actions-template/.github/workflows/ci-libs-metadata-v2.yml@ci-deb-packages
with:
ARTIFACT_NAME: deb-${{ matrix.distro_codename }}-${{ matrix.platform }}-artifact
OS_PLATFORM: deb-${{ matrix.platform }}
RUNNER: ubuntu-latest
FILE_PATH_PREFIX: /var/www/sofia-deb-${{ matrix.platform }}/${{ github.run_id }}-${{ github.run_number }}
generate_meta_rpm:
name: 'Meta RPM'
needs: [ sofia_build_rpm ]
strategy:
matrix:
platform:
- amd64
uses: s3rj1k/actions-template/.github/workflows/ci-libs-metadata-v2.yml@ci-deb-packages
with:
ARTIFACT_NAME: rpm-${{ matrix.platform }}-artifact
OS_PLATFORM: rpm-${{ matrix.platform }}
RUNNER: ubuntu-latest
FILE_PATH_PREFIX: /var/www/sofia-rpm-${{ matrix.platform }}/${{ github.run_id }}-${{ github.run_number }}
distribute_matrix:
if: github.ref == 'refs/heads/main'
permissions: write-all
name: 'Copy to remote'
needs: [ sofia_build_rpm, sofia_build_deb ]
strategy:
matrix:
os_platform:
- deb-amd64
- deb-arm
- rpm-amd64
uses: s3rj1k/actions-template/.github/workflows/cd-scp.yml@ci-deb-packages
with:
ARTIFACT_NAME: ${{ matrix.os_platform }}-artifact
TARGET_FOLDER: /var/www/sofia-${{ matrix.os_platform }}/${{ github.run_id }}-${{ github.run_number }}
RUNNER: ubuntu-latest
FILES: '*.tar.gz'
CREATE_DESTINATION_FOLDERS: true
secrets:
# Explicit define secrets for better understanding but it could be just inherit
PROXY_URL: ${{ secrets.PROXY_URL }}
USERNAME: ${{ secrets.USERNAME }}
HOSTNAME: ${{ secrets.HOSTNAME }}
TELEPORT_TOKEN: ${{ secrets.TELEPORT_TOKEN }}
distribute_meta_deb:
if: github.ref == 'refs/heads/main'
permissions: write-all
name: 'Copy meta to remote'
needs: generate_meta
strategy:
matrix:
os:
- deb
platform:
- amd64
- arm
uses: s3rj1k/actions-template/.github/workflows/cd-libs-metadata.yml@ci-deb-packages
with:
ARTIFACT_NAME: ${{ matrix.os }}-${{ matrix.platform }}-meta
LIB_NAME: sofia-sip
TARGET_OS: ${{ matrix.os }}
TARGET_PLATFORM: ${{ matrix.platform }}
RUNNER: ubuntu-latest
TARGET_REPO: signalwire/bamboo_gha_trigger
secrets:
GH_BOT_DEPLOY_TOKEN: ${{ secrets.PAT }}
distribute_meta_rpm:
if: github.ref == 'refs/heads/main'
permissions: write-all
name: 'Copy meta to remote'
needs: generate_meta
strategy:
matrix:
os:
- rpm
platform:
- amd64
uses: s3rj1k/actions-template/.github/workflows/cd-libs-metadata.yml@ci-deb-packages
with:
ARTIFACT_NAME: ${{ matrix.os }}-${{ matrix.platform }}-meta
LIB_NAME: sofia-sip
TARGET_OS: ${{ matrix.os }}
TARGET_PLATFORM: ${{ matrix.platform }}
RUNNER: ubuntu-latest
TARGET_REPO: signalwire/bamboo_gha_trigger
secrets:
GH_BOT_DEPLOY_TOKEN: ${{ secrets.PAT }}
distribute_hash:
if: github.ref == 'refs/heads/main'
permissions: write-all
name: 'Copy hash to remote'
needs: [ distribute_meta_deb, distribute_meta_rpm ]
uses: s3rj1k/actions-template/.github/workflows/cd-scp.yml@ci-deb-packages
strategy:
matrix:
os_platform:
- deb-amd64
- deb-arm
- rpm-amd64
with:
RUNNER: ubuntu-latest
CREATE_DESTINATION_FOLDERS: false
EXEC_COMMANDS: 'echo "${{ github.sha }}" > /var/www/sofia-${{ matrix.os_platform }}/${{ github.run_id }}-${{ github.run_number }}/hash.txt'
secrets:
PROXY_URL: ${{ secrets.PROXY_URL }}
USERNAME: ${{ secrets.USERNAME }}
HOSTNAME: ${{ secrets.HOSTNAME }}
TELEPORT_TOKEN: ${{ secrets.TELEPORT_TOKEN }}