Release #58
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: "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" |