name: authentik-on-release on: release: types: [published, created] jobs: # Build build-server: runs-on: ubuntu-latest steps: - uses: actions/checkout@v1 - name: Docker Login Registry env: DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} run: docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD - name: Building Docker Image run: docker build --no-cache -t beryju/authentik:2021.4.6 -t beryju/authentik:latest -f Dockerfile . - name: Push Docker Container to Registry (versioned) run: docker push beryju/authentik:2021.4.6 - name: Push Docker Container to Registry (latest) run: docker push beryju/authentik:latest build-proxy: runs-on: ubuntu-latest steps: - uses: actions/checkout@v1 - uses: actions/setup-go@v2 with: go-version: "^1.15" - name: prepare go api client run: | cd outpost go get -u github.com/go-swagger/go-swagger/cmd/swagger swagger generate client -f ../swagger.yaml -A authentik -t pkg/ go build -v . - name: Docker Login Registry env: DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} run: docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD - name: Building Docker Image run: | cd outpost/ docker build \ --no-cache \ -t beryju/authentik-proxy:2021.4.6 \ -t beryju/authentik-proxy:latest \ -f proxy.Dockerfile . - name: Push Docker Container to Registry (versioned) run: docker push beryju/authentik-proxy:2021.4.6 - name: Push Docker Container to Registry (latest) run: docker push beryju/authentik-proxy:latest build-static: runs-on: ubuntu-latest steps: - uses: actions/checkout@v1 - name: prepare ts api client run: | docker run --rm -v $(pwd):/local openapitools/openapi-generator-cli generate -i /local/swagger.yaml -g typescript-fetch -o /local/web/api --additional-properties=typescriptThreePlus=true,supportsES6=true,npmName=authentik-api,npmVersion=1.0.0 - name: Docker Login Registry env: DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} run: docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD - name: Building Docker Image run: | cd web/ docker build \ --no-cache \ -t beryju/authentik-static:2021.4.6 \ -t beryju/authentik-static:latest \ -f Dockerfile . - name: Push Docker Container to Registry (versioned) run: docker push beryju/authentik-static:2021.4.6 - name: Push Docker Container to Registry (latest) run: docker push beryju/authentik-static:latest test-release: needs: - build-server - build-static - build-proxy runs-on: ubuntu-latest steps: - uses: actions/checkout@v1 - name: Run test suite in final docker images run: | sudo apt-get install -y pwgen echo "PG_PASS=$(pwgen 40 1)" >> .env echo "AUTHENTIK_SECRET_KEY=$(pwgen 50 1)" >> .env docker-compose pull -q docker-compose up --no-start docker-compose start postgresql redis docker-compose run -u root --entrypoint /bin/bash server -c "pip install --no-cache -r requirements-dev.txt && ./manage.py test authentik" sentry-release: needs: - test-release runs-on: ubuntu-latest steps: - uses: actions/checkout@v1 - name: Create a Sentry.io release uses: tclindner/sentry-releases-action@v1.2.0 env: SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} SENTRY_ORG: beryjuorg SENTRY_PROJECT: authentik SENTRY_URL: https://sentry.beryju.org with: tagName: 2021.4.6 environment: beryjuorg-prod