feat: adopt SpiceDB for authorization #2974
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: cicd | |
on: | |
push: | |
branches: [ '*' ] | |
tags: [ 'v*' ] | |
pull_request: | |
permissions: | |
contents: read | |
pull-requests: read | |
env: | |
# renovate: dev-tag | |
DEV_TAG: '12' | |
jobs: | |
envs: | |
runs-on: ubuntu-22.04 | |
steps: | |
- run: echo "This is needed because sometimes env is not accessible, whereas the output of this step is" | |
outputs: | |
DEV_TAG: ${{ env.DEV_TAG }} | |
detect-changes: | |
runs-on: ubuntu-22.04 | |
outputs: | |
services: ${{ steps.aggregate-changes.outputs.services }} | |
libs: ${{ steps.aggregate-changes.outputs.libs }} | |
images: ${{ steps.aggregate-changes.outputs.images }} | |
commit_hash: ${{ steps.commit.outputs.short }} | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Detect changes in libs | |
id: changes-in-libs | |
uses: tj-actions/changed-files@v44 | |
with: | |
files: | | |
.github/** | |
libs/** | |
.dockerignore | |
Dockerfile.service | |
- name: Detect changes in services | |
id: changes-in-services | |
uses: tj-actions/changed-files@v44 | |
with: | |
files: | | |
services/*-svc/** | |
- name: Detect changes in images | |
id: changes-in-images | |
uses: tj-actions/changed-files@v44 | |
with: | |
files: | | |
images/** | |
- name: Aggregate changes | |
id: aggregate-changes | |
run: | | |
echo "images=$(echo $changesInImages | awk -F / '$1 ~ /images/ {print $2}' | uniq | grep -v dev-go-custom | jq -R . | jq -sc .)" >> $GITHUB_OUTPUT | |
if [[ "$libsChanged" == "true" ]]; then | |
# Exception for the Python "impulse_svc". Our workflows are very Golang opinionated. | |
echo "services=$(ls services | grep -v 'impulse_svc' | uniq | jq -R . | jq -sc .)" >> $GITHUB_OUTPUT | |
# Exception for "libs/proto_helpers" due to the fact that this package does not require any direct external packages. | |
# If the CI runs "go get .", the command exits (1) with "go: .: no package to get in current directory". | |
echo "libs=$(ls libs | grep -v -e 'python' -e 'proto_helpers' | uniq | jq -R . | jq -sc .)" >> $GITHUB_OUTPUT | |
echo "images=$(ls images | grep -v dev-go-custom | uniq | jq -R . | jq -sc .)" >> $GITHUB_OUTPUT | |
else | |
echo "services=$(echo $changesInServices | awk -F / '$1 ~ /services/ {print $2}' | uniq | jq -R . | jq -sc .)" >> $GITHUB_OUTPUT | |
fi | |
env: | |
libsChanged: ${{ steps.changes-in-libs.outputs.any_changed }} | |
changesInServices: ${{ steps.changes-in-services.outputs.all_changed_files }} | |
changesInImages: ${{ steps.changes-in-images.outputs.all_changed_files }} | |
- name: Get commit hash | |
id: commit | |
uses: pr-mpt/actions-commit-hash@v3 | |
with: | |
commit: "${{ github.sha }}" | |
- name: Summarize | |
run: | | |
echo "services: $services" >> $GITHUB_STEP_SUMMARY | |
echo "images: $images" >> $GITHUB_STEP_SUMMARY | |
env: | |
services: ${{ steps.aggregate-changes.outputs.services }} | |
images: ${{ steps.aggregate-changes.outputs.images }} | |
cicd-go: | |
needs: detect-changes | |
if: ${{ needs.detect-changes.outputs.services != '[]' && needs.detect-changes.outputs.services != '' }} | |
strategy: | |
matrix: | |
service: ${{ fromJson(needs.detect-changes.outputs.services) }} | |
permissions: | |
contents: read | |
pull-requests: read | |
packages: write | |
uses: ./.github/workflows/cicd-go.yaml | |
with: | |
deploy: ${{ github.event_name != 'pull_request' && (github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v')) }} | |
service: ${{ matrix.service }} | |
secrets: inherit | |
ci-go-libs: | |
needs: detect-changes | |
if: ${{ needs.detect-changes.outputs.libs != '[]' && needs.detect-changes.outputs.libs != '' }} | |
strategy: | |
matrix: | |
lib: ${{ fromJson(needs.detect-changes.outputs.libs) }} | |
uses: ./.github/workflows/ci-go-libs.yaml | |
with: | |
lib: ${{ matrix.lib }} | |
secrets: inherit | |
cicd-images: | |
needs: | |
- detect-changes | |
- envs | |
if: ${{ needs.detect-changes.outputs.images != '[]' && needs.detect-changes.outputs.images != '' }} | |
strategy: | |
matrix: | |
image: ${{ fromJson(needs.detect-changes.outputs.images) }} | |
permissions: | |
contents: read | |
pull-requests: read | |
packages: write | |
uses: ./.github/workflows/cicd-images.yaml | |
with: | |
deploy: ${{ github.event_name != 'pull_request' && (github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v')) }} | |
image: ${{ matrix.image }} | |
custom_tag: ${{ matrix.image == 'dev-go' && needs.envs.outputs.DEV_TAG || '' }} | |
secrets: inherit | |
fly-deploy-staging: | |
needs: detect-changes | |
if: ${{ github.event_name != 'pull_request' && (github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v')) && needs.detect-changes.outputs.services != '[]' && needs.detect-changes.outputs.services != '' }} | |
strategy: | |
fail-fast: false | |
max-parallel: 2 | |
matrix: | |
service: ${{ fromJson(needs.detect-changes.outputs.services) }} | |
uses: ./.github/workflows/fly-deploy.yaml | |
with: | |
service: ${{ matrix.service }} | |
app: ${{ vars.FLY_ORGANIZATION_STAGING }}-${{ matrix.service }} | |
organization: ${{ vars.FLY_ORGANIZATION_STAGING }} | |
version: ${{ needs.detect-changes.outputs.commit_hash }} | |
environment: "staging" | |
secrets: inherit | |
fly-deploy-prod: | |
needs: detect-changes | |
# TODO | |
# For now, it's ok to deploy if ANY version tag is pushed to (we assume it's the newest version and needs deployment) | |
# In the future we need to be able to deploy to different, API incompatible, production environments | |
# Maybe even automate resource creation | |
if: ${{ github.event_name != 'pull_request' && startsWith(github.ref, 'refs/tags/v') && needs.detect-changes.outputs.services != '[]' && needs.detect-changes.outputs.services != '' }} | |
strategy: | |
fail-fast: false | |
max-parallel: 2 | |
matrix: | |
service: ${{ fromJson(needs.detect-changes.outputs.services) }} | |
uses: ./.github/workflows/fly-deploy.yaml | |
with: | |
service: ${{ matrix.service }} | |
app: ${{ vars.FLY_ORGANIZATION_PROD }}-${{ matrix.service }} | |
organization: ${{ vars.FLY_ORGANIZATION_PROD }} | |
version: ${{ needs.detect-changes.outputs.commit_hash }} | |
environment: "production" | |
secrets: inherit |