diff --git a/.github/workflows/master.yml b/.github/workflows/master.yml index 0c8ef389..3425b523 100644 --- a/.github/workflows/master.yml +++ b/.github/workflows/master.yml @@ -11,14 +11,18 @@ jobs: steps: - name: Checkout uses: actions/checkout@v3 + - name: Set up CI Image Metadata id: docker_meta_ci - uses: crazy-max/ghaction-docker-meta@v1 + uses: docker/metadata-action@v4 with: images: solidnerd/bookstack-dev - tag-sha: true + tags: | + type=sha + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 + - name: Build Image uses: docker/build-push-action@v3 with: @@ -31,42 +35,51 @@ jobs: labels: ${{ steps.docker_meta_ci.outputs.labels }} cache-from: type=registry,ref=solidnerd/bookstack-dev:master outputs: type=docker,dest=/tmp/image-bookstack.tar + - name: Upload artifact uses: actions/upload-artifact@v3 with: name: image-bookstack-master path: /tmp/image-bookstack.tar if-no-files-found: warn + e2e: runs-on: ubuntu-latest needs: build steps: - name: Checkout uses: actions/checkout@v3 + - name: Download artifact uses: actions/download-artifact@v3 with: name: image-bookstack-master path: /tmp + - name: Load Docker image run: | docker load --input /tmp/image-bookstack.tar docker image ls -a + push: runs-on: ubuntu-20.04 needs: e2e steps: - name: Checkout uses: actions/checkout@v3 + - name: Set up Docker Hub Image Metadata id: docker_meta - uses: crazy-max/ghaction-docker-meta@v1 + uses: docker/metadata-action@v4 with: images: solidnerd/bookstack,ghcr.io/solidnerd/docker-bookstack - tag-semver: | - {{version}} - {{major}}.{{minor}} - {{major}}.{{minor}}.{{patch}} + tags: | + type=semver,pattern={{version}} + type=semver,pattern={{major}}.{{minor}} + type=semver,pattern={{major}}.{{minor}}.{{patch}} + # Get "master" for master-branch changes + type=ref,event=branch + - name: Download artifact uses: actions/download-artifact@v3 with: @@ -77,22 +90,27 @@ jobs: run: | docker load --input /tmp/image-bookstack.tar docker image ls -a + - name: Set up QEMU uses: docker/setup-qemu-action@v2 + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 + - name: Login to DockerHub if: github.event_name != 'pull_request' - uses: docker/login-action@v1 + uses: docker/login-action@v2 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_PASSWORD }} + - name: Login to GitHub Container Registry - uses: docker/login-action@v1 + uses: docker/login-action@v2 with: registry: ghcr.io username: ${{ github.repository_owner }} password: ${{ secrets.CR_PAT }} + - name: Build and Push uses: docker/build-push-action@v3 with: diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml index 2af1a9d7..f774e944 100644 --- a/.github/workflows/pr.yml +++ b/.github/workflows/pr.yml @@ -11,14 +11,18 @@ jobs: steps: - name: Checkout uses: actions/checkout@v3 + - name: Docker meta ci id: docker_meta_ci - uses: crazy-max/ghaction-docker-meta@v1 + uses: docker/metadata-action@v4 with: images: solidnerd/bookstack-dev - tag-sha: true + tags: | + type=sha + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 + - name: Build and push Dev uses: docker/build-push-action@v3 with: @@ -32,27 +36,32 @@ jobs: cache-from: type=registry,ref=solidnerd/bookstack-dev:master cache-to: type=inline outputs: type=docker,dest=/tmp/image-bookstack.tar + - name: Upload artifact uses: actions/upload-artifact@v3 with: name: image-bookstack path: /tmp/image-bookstack.tar if-no-files-found: warn + e2e: runs-on: ubuntu-latest needs: build steps: - name: Checkout uses: actions/checkout@v3 + - name: Download artifact uses: actions/download-artifact@v3 with: name: image-bookstack path: /tmp if-no-files-found: warn + - name: Load Docker image run: | docker load --input /tmp/image-bookstack.tar docker image ls -a + - name: Execute End-to-End Test run: make e2e diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index e648c2ab..6fbdcc3a 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -11,14 +11,18 @@ jobs: steps: - name: Checkout uses: actions/checkout@v3 + - name: Set up CI Image Metadata id: docker_meta_ci - uses: crazy-max/ghaction-docker-meta@v1 + uses: docker/metadata-action@v4 with: images: solidnerd/bookstack-dev - tag-sha: true + tags: | + type=sha + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 + - name: Build and push Dev uses: docker/build-push-action@v3 with: @@ -31,66 +35,79 @@ jobs: labels: ${{ steps.docker_meta_ci.outputs.labels }} cache-from: type=registry,ref=solidnerd/bookstack-dev:master outputs: type=docker,dest=/tmp/image-bookstack.tar + - name: Upload artifact uses: actions/upload-artifact@v3 with: name: image-bookstack-master path: /tmp/image-bookstack.tar + e2e: runs-on: ubuntu-latest needs: build steps: - name: Checkout uses: actions/checkout@v3 + - name: Download artifact uses: actions/download-artifact@v3 with: name: image-bookstack-master path: /tmp + - name: Load Docker image run: | docker load --input /tmp/image-bookstack.tar docker image ls -a + push: runs-on: ubuntu-20.04 needs: e2e steps: - name: Checkout uses: actions/checkout@v3 + - name: Set up Docker Hub Image Metadata id: docker_meta - uses: crazy-max/ghaction-docker-meta@v1 + uses: docker/metadata-action@v4 with: images: solidnerd/bookstack,ghcr.io/solidnerd/docker-bookstack - tag-semver: | - {{version}} - {{major}}.{{minor}} - {{major}}.{{minor}}.{{patch}} + tags: + type=semver,pattern={{version}} + type=semver,pattern={{major}}.{{minor}} + type=semver,pattern={{major}}.{{minor}}.{{patch}} + - name: Download artifact uses: actions/download-artifact@v3 with: name: image-bookstack-master path: /tmp + - name: Load Docker image run: | docker load --input /tmp/image-bookstack.tar docker image ls -a + - name: Set up QEMU uses: docker/setup-qemu-action@v2 + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v2 + - name: Login to DockerHub if: github.event_name != 'pull_request' - uses: docker/login-action@v1 + uses: docker/login-action@v2 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_PASSWORD }} + - name: Login to GitHub Container Registry - uses: docker/login-action@v1 + uses: docker/login-action@v2 with: registry: ghcr.io username: ${{ github.repository_owner }} password: ${{ secrets.CR_PAT }} + - name: Build and Push master uses: docker/build-push-action@v3 with: @@ -103,6 +120,7 @@ jobs: labels: ${{ steps.docker_meta.outputs.labels }} cache-from: type=registry,ref=solidnerd/bookstack-dev:${{ github.sha }} cache-to: type=registry,ref=solidnerd/bookstack-dev:${{ github.sha }} + create-release: runs-on: ubuntu-20.04 needs: push @@ -110,11 +128,13 @@ jobs: # To use this repository's private action, you must check out the repository - name: Checkout uses: actions/checkout@v3 + - name: Generate changelog id: changelog - uses: metcalfc/changelog-generator@v3.0.0 + uses: metcalfc/changelog-generator@v4.0.1 with: myToken: ${{ secrets.GITHUB_TOKEN }} + - name: Create Release id: create_release uses: actions/create-release@v1.1.4 diff --git a/Dockerfile b/Dockerfile index f8450376..24bfdb75 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,5 +1,5 @@ FROM alpine:3 as bookstack -ENV BOOKSTACK_VERSION=22.04.2 +ENV BOOKSTACK_VERSION=22.10.1 RUN apk add --no-cache curl tar RUN set -x; \ curl -SL -o bookstack.tar.gz https://github.com/BookStackApp/BookStack/archive/v${BOOKSTACK_VERSION}.tar.gz \