Skip to content

v0.0.67

v0.0.67 #29

Workflow file for this run

name: Deploy
on:
release:
types: [released]
jobs:
build-and-push-docker:
name: Build and push Docker image
runs-on: ubuntu-latest
permissions:
packages: write
contents: read
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Login to Docker Hub
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Generate docker tags
id: meta
uses: docker/metadata-action@v4
with:
# list of Docker images to use as base name for tags
images: |
ghcr.io/${{ github.repository }}/bffsrv
# generate Docker tags based on the following events/attributes
tags: |
type=semver,pattern=v{{version}}
- name: Build and push
uses: docker/build-push-action@v4
with:
push: true
context: .
file: bffsrv.Dockerfile
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
deploy-kubernetes:
needs: [build-and-push-docker]
name: Deploy Kubernetes
environment: production
runs-on: ubuntu-latest
permissions:
contents: 'read'
id-token: 'write'
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: azure/setup-kubectl@v2.0
- id: 'auth'
uses: 'google-github-actions/auth@v1'
with:
credentials_json: '${{ secrets.GCP_CREDENTIALS }}'
- name: 'Set up Cloud SDK'
uses: 'google-github-actions/setup-gcloud@v1'
- name: 'Use gcloud CLI'
run: 'gcloud info'
- id: 'get-credentials'
uses: 'google-github-actions/get-gke-credentials@v1'
with:
cluster_name: 'us-east'
location: 'us-east1'
- uses: Azure/k8s-deploy@v4
with:
namespace: 'default'
manifests: |
infra/k8s
images: 'ghcr.io/strideynet/bsky-furry-feed/bffsrv:${{ github.ref_name }}'
deploy-feeds:
needs: [deploy-kubernetes]
name: Deploy Feeds
environment: production
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: actions/setup-go@v4
with:
go-version: "1.23"
cache: false
- name: Deploy feeds
env:
BFF_HOSTNAME: feed.furryli.st
BLUESKY_USERNAME: furryli.st
BLUESKY_PASSWORD: ${{ secrets.BLUESKY_PASSWORD }}
run: go run ./cmd/bffctl/ -e production bsky publish-feeds