name: site on: push: branches: tags: paths: - ".github/workflows/ci-site.yml" - "site/**" - "README.md" - "Dockerfile.site" pull_request: paths: - ".github/workflows/ci-site.yml" - "site/**" - "README.md" - "Dockerfile.site" jobs: build: runs-on: ubuntu-latest steps: - name: checkout uses: actions/checkout@v2 - name: set up QEMU uses: docker/setup-qemu-action@v1 - name: set up Docker Buildx id: buildx uses: docker/setup-buildx-action@v1 - name: available platforms run: echo ${{ steps.buildx.outputs.platforms }} - name: build and deploy master image site to ghcr.io and dockerhub if: ${{ github.ref == 'refs/heads/master' }} env: GITHUB_PACKAGE_TOKEN: ${{ secrets.PKG_TOKEN }} USERNAME: ${{ github.actor }} GITHUB_SHA: ${{ github.sha}} GITHUB_REF: ${{ github.ref}} run: | ref="$(echo ${GITHUB_REF} | cut -d'/' -f3)" echo GITHUB_REF - $ref echo ${GITHUB_PACKAGE_TOKEN} | docker login ghcr.io -u ${USERNAME} --password-stdin docker buildx build -f Dockerfile.site --push --no-cache --platform linux/amd64,linux/arm/v7,linux/arm64 \ -t ghcr.io/${USERNAME}/reproxy-site:${ref} . - name: deploy tagged (latest) site to ghcr.io and dockerhub if: ${{ startsWith(github.ref, 'refs/tags/') }} env: GITHUB_PACKAGE_TOKEN: ${{ secrets.PKG_TOKEN }} USERNAME: ${{ github.actor }} GITHUB_SHA: ${{ github.sha}} GITHUB_REF: ${{ github.ref}} run: | ref="$(echo ${GITHUB_REF} | cut -d'/' -f3)" echo GITHUB_REF - $ref echo ${GITHUB_PACKAGE_TOKEN} | docker login ghcr.io -u ${USERNAME} --password-stdin docker buildx build -f Dockerfile.site --push --no-cache --platform linux/amd64,linux/arm/v7,linux/arm64 \ -t ghcr.io/${USERNAME}/reproxy-site:${ref} -t ghcr.io/${USERNAME}/reproxy-site:latest . - name: remote site deployment from master if: ${{ github.ref == 'refs/heads/master' }} env: UPDATER_KEY: ${{ secrets.UPDATER_KEY }} run: curl https://jess.umputun.com/update/reproxy-site/${UPDATER_KEY}