Skip to content

Release

Release #58

Workflow file for this run

name: "Release"
on:
workflow_dispatch: {}
permissions:
contents: write
jobs:
release:
runs-on: macos-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
submodules: 'true'
token: ${{ secrets.ORG_GITHUB_TOKEN }}
- name: Fetch All Tags
run: git fetch --force --tags
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version: "1.21"
- name: Set Release Version
id: version
run: |
echo "RELEASE_VERSION=$(date +v%Y.%-m.%-d)" >> $GITHUB_OUTPUT
- name: Import GPG Key
id: import_gpg
uses: crazy-max/ghaction-import-gpg@v6
with:
gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }}
passphrase: ${{ secrets.GPG_PASSPHRASE }}
- name: Setup Docker macOS
if: runner.os == 'macos'
# https://github.com/actions/runner-images/issues/17#issuecomment-1537238473
# https://github.com/abiosoft/colima/blob/main/docs/FAQ.md#cannot-connect-to-the-docker-daemon-at-unixvarrundockersock-is-the-docker-daemon-running
run: |
brew install docker
brew install jq
colima start
echo DOCKER_HOST="unix://${HOME}/.colima/default/docker.sock" >> $GITHUB_ENV
- name: Login to Public ECR
uses: docker/login-action@v3
with:
registry: ${{ secrets.ECR_PUBLIC_REGISTRY }}
username: ${{ secrets.ECR_PUBLIC_AWS_ACCESS_KEY_ID }}
password: ${{ secrets.ECR_PUBLIC_AWS_SECRET_ACCESS_KEY }}
env:
AWS_REGION: us-east-1
- name: Ensure Release Does Not Exist
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
gh release delete ${{ steps.version.outputs.RELEASE_VERSION }} || true
- name: Ensure Changelog
run: |
git config user.name "OpsLevel Bots"
git config user.email "bots@opslevel.com"
if test -f ./.changes/${{ steps.version.outputs.RELEASE_VERSION }}.md
then
echo "Skip Changie..."
else
go install github.com/miniscruff/changie@latest
changie batch ${{ steps.version.outputs.RELEASE_VERSION }}
changie merge
git add .
git commit -m "Cut Release '${{ steps.version.outputs.RELEASE_VERSION }}'"
git push origin HEAD
fi
git tag -f ${{ steps.version.outputs.RELEASE_VERSION }} -m "Cut Release '${{ steps.version.outputs.RELEASE_VERSION }}'"
git push -f origin refs/tags/${{ steps.version.outputs.RELEASE_VERSION }}
- name: Run GoReleaser
uses: goreleaser/goreleaser-action@v5.0.0
with:
args: release --clean --release-notes=../.changes/${{ steps.version.outputs.RELEASE_VERSION }}.md
workdir: ./src
env:
GPG_FINGERPRINT: ${{ steps.import_gpg.outputs.fingerprint }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
ORG_GITHUB_TOKEN: ${{ secrets.ORG_GITHUB_TOKEN }}
- name: Docker Build And Push
env:
IMAGE: "public.ecr.aws/opslevel/kubectl-opslevel"
TAG: ${{ steps.version.outputs.RELEASE_VERSION }}
run: |
docker build -t "${IMAGE}:latest" -t "${IMAGE}:{TAG}" .
docker push "${IMAGE}:latest"
docker push "${IMAGE}:${TAG}"
- name: Report Release To OpsLevel
uses: opslevel/report-deploy-github-action@v0.7.0
with:
integration_url: ${{ secrets.DEPLOY_INTEGRATION_URL }}
service: "opslevel_kubernetes_sync"