diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 22ea3bd2b2..8f7d819f81 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -403,3 +403,65 @@ jobs: - name: NPM build run: npm run build:bit:cloud + + + check-failures: + name: Check for failures + if: always() + runs-on: ubuntu-20.04 + needs: + - cloc + - setup + - build-oss-selfhost + - build-cloud + - build-commercial-selfhost + - build-qa + - windows + steps: + - name: Check if any job failed + env: + CLOC_STATUS: ${{ needs.cloc.result }} + SETUP_STATUS: ${{ needs.setup.result }} + BUILD_OSS_SELFHOST_STATUS: ${{ needs.build-oss-selfhost.result }} + BUILD_CLOUD_STATUS: ${{ needs.build-cloud.result }} + BUILD_COMMERCIAL_SELFHOST_STATUS: ${{ needs.build-commercial-selfhost.result }} + BUILD_QA: ${{ needs.build-qa.result }} + WINDOWS: ${{ needs.windows.result }} + run: | + if [ "$CLOC_STATUS" = "failure" ]; then + exit 1 + elif [ "$SETUP_STATUS" = "failure" ]; then + exit 1 + elif [ "$BUILD_OSS_SELFHOST_STATUS" = "failure" ]; then + exit 1 + elif [ "$BUILD_CLOUD_STATUS" = "failure" ]; then + exit 1 + elif [ "$BUILD_COMMERCIAL_SELFHOST_STATUS" = "failure" ]; then + exit 1 + elif [ "$BUILD_QA" = "failure" ]; then + exit 1 + elif [ "$WINDOWS" = "failure" ]; then + exit 1 + fi + + - name: Login to Azure - Prod Subscription + uses: Azure/login@77f1b2e3fb80c0e8645114159d17008b8a2e475a + if: failure() + with: + creds: ${{ secrets.AZURE_PROD_KV_CREDENTIALS }} + + - name: Retrieve secrets + id: retrieve-secrets + uses: Azure/get-keyvault-secrets@80ccd3fafe5662407cc2e55f202ee34bfff8c403 + if: failure() + with: + keyvault: "bitwarden-prod-kv" + secrets: "devops-alerts-slack-webhook-url" + + - name: Notify Slack on failure + uses: act10ns/slack@e4e71685b9b239384b0f676a63c32367f59c2522 # v1.2.2 + if: failure() + env: + SLACK_WEBHOOK_URL: ${{ steps.retrieve-secrets.outputs.devops-alerts-slack-webhook-url }} + with: + status: ${{ job.status }}