2024-08-27 14:46:04 +02:00
|
|
|
name: Build and deploy rust container images
|
2024-06-10 15:00:00 +02:00
|
|
|
|
|
|
|
on:
|
|
|
|
workflow_dispatch:
|
|
|
|
push:
|
2024-06-11 17:30:21 +02:00
|
|
|
paths:
|
|
|
|
- 'rust/**'
|
2024-06-12 12:57:34 +02:00
|
|
|
- '.github/workflows/rust-docker-build.yml'
|
2024-06-10 15:00:00 +02:00
|
|
|
branches:
|
2024-06-11 17:30:21 +02:00
|
|
|
- 'master'
|
2024-06-10 15:00:00 +02:00
|
|
|
|
|
|
|
jobs:
|
|
|
|
build:
|
|
|
|
name: Build and publish container image
|
|
|
|
strategy:
|
|
|
|
matrix:
|
|
|
|
image:
|
|
|
|
- capture
|
|
|
|
- hook-api
|
|
|
|
- hook-janitor
|
|
|
|
- hook-worker
|
2024-08-23 09:27:59 +02:00
|
|
|
- cyclotron-janitor
|
|
|
|
- cyclotron-fetch
|
2024-08-27 07:35:04 +02:00
|
|
|
- property-defs-rs
|
2024-06-10 15:00:00 +02:00
|
|
|
runs-on: depot-ubuntu-22.04-4
|
|
|
|
permissions:
|
|
|
|
id-token: write # allow issuing OIDC tokens for this workflow run
|
|
|
|
contents: read # allow reading the repo contents
|
|
|
|
packages: write # allow push to ghcr.io
|
|
|
|
|
2024-08-27 14:46:04 +02:00
|
|
|
outputs:
|
|
|
|
digest: ${{ steps.docker_build.outputs.digest }}
|
|
|
|
|
2024-06-11 17:30:21 +02:00
|
|
|
defaults:
|
|
|
|
run:
|
|
|
|
working-directory: rust
|
|
|
|
|
2024-06-10 15:00:00 +02:00
|
|
|
steps:
|
|
|
|
- name: Check Out Repo
|
2024-06-11 17:30:21 +02:00
|
|
|
# Checkout project code
|
|
|
|
# Use sparse checkout to only select files in rust directory
|
|
|
|
# Turning off cone mode ensures that files in the project root are not included during checkout
|
2024-06-10 15:00:00 +02:00
|
|
|
uses: actions/checkout@v3
|
2024-06-11 17:30:21 +02:00
|
|
|
with:
|
|
|
|
sparse-checkout: 'rust/'
|
|
|
|
sparse-checkout-cone-mode: false
|
2024-06-10 15:00:00 +02:00
|
|
|
|
|
|
|
- name: Set up Depot CLI
|
|
|
|
uses: depot/setup-action@v1
|
|
|
|
|
2024-08-12 15:36:12 +02:00
|
|
|
- name: Set up QEMU
|
|
|
|
uses: docker/setup-qemu-action@v3
|
2024-06-10 15:00:00 +02:00
|
|
|
with:
|
2024-08-12 15:36:12 +02:00
|
|
|
image: tonistiigi/binfmt:latest
|
|
|
|
platforms: all
|
2024-06-10 15:00:00 +02:00
|
|
|
|
|
|
|
- name: Login to ghcr.io
|
2024-08-12 15:36:12 +02:00
|
|
|
uses: docker/login-action@v3
|
2024-06-10 15:00:00 +02:00
|
|
|
with:
|
|
|
|
registry: ghcr.io
|
|
|
|
username: ${{ github.actor }}
|
|
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
2024-06-11 17:30:21 +02:00
|
|
|
logout: false
|
2024-06-10 15:00:00 +02:00
|
|
|
|
|
|
|
- name: Docker meta
|
|
|
|
id: meta
|
2024-06-18 09:21:21 +02:00
|
|
|
uses: docker/metadata-action@v5
|
2024-06-10 15:00:00 +02:00
|
|
|
with:
|
2024-06-11 17:30:21 +02:00
|
|
|
images: ghcr.io/posthog/posthog/${{ matrix.image }}
|
2024-06-10 15:00:00 +02:00
|
|
|
tags: |
|
|
|
|
type=ref,event=pr
|
|
|
|
type=ref,event=branch
|
|
|
|
type=semver,pattern={{version}}
|
|
|
|
type=semver,pattern={{major}}.{{minor}}
|
|
|
|
type=sha
|
|
|
|
|
|
|
|
- name: Set up Docker Buildx
|
|
|
|
id: buildx
|
|
|
|
uses: docker/setup-buildx-action@v2
|
|
|
|
|
|
|
|
- name: Build and push image
|
|
|
|
id: docker_build
|
|
|
|
uses: depot/build-push-action@v1
|
|
|
|
with:
|
2024-06-11 17:30:21 +02:00
|
|
|
context: ./rust/
|
|
|
|
file: ./rust/Dockerfile
|
2024-06-10 15:00:00 +02:00
|
|
|
push: true
|
|
|
|
tags: ${{ steps.meta.outputs.tags }}
|
|
|
|
labels: ${{ steps.meta.outputs.labels }}
|
2024-08-12 15:36:12 +02:00
|
|
|
platforms: linux/arm64,linux/amd64
|
2024-06-10 15:00:00 +02:00
|
|
|
cache-from: type=gha
|
|
|
|
cache-to: type=gha,mode=max
|
|
|
|
build-args: BIN=${{ matrix.image }}
|
|
|
|
|
|
|
|
- name: Container image digest
|
|
|
|
run: echo ${{ steps.docker_build.outputs.digest }}
|
2024-08-27 14:46:04 +02:00
|
|
|
|
|
|
|
deploy:
|
|
|
|
name: Deploy capture-replay
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
needs: build
|
|
|
|
if: github.ref == 'refs/heads/master'
|
|
|
|
steps:
|
|
|
|
- name: get deployer token
|
|
|
|
id: deployer
|
|
|
|
uses: getsentry/action-github-app-token@v3
|
|
|
|
with:
|
|
|
|
app_id: ${{ secrets.DEPLOYER_APP_ID }}
|
|
|
|
private_key: ${{ secrets.DEPLOYER_APP_PRIVATE_KEY }}
|
|
|
|
|
|
|
|
- name: Trigger livestream deployment
|
|
|
|
uses: peter-evans/repository-dispatch@v3
|
|
|
|
with:
|
|
|
|
token: ${{ steps.deployer.outputs.token }}
|
|
|
|
repository: PostHog/charts
|
|
|
|
event-type: commit_state_update
|
|
|
|
client-payload: |
|
|
|
|
{
|
|
|
|
"values": {
|
|
|
|
"image": {
|
|
|
|
"sha": "${{ needs.build.outputs.digest }}"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"release": "capture-replay",
|
|
|
|
"commit": ${{ toJson(github.event.head_commit) }},
|
|
|
|
"repository": ${{ toJson(github.repository) }},
|
|
|
|
"labels": []
|
|
|
|
}
|