Skip to content

Update rover components #105

Update rover components

Update rover components #105

name: Update rover components
on:
schedule:
- cron: '0 18 * * 0' # 6:00 PM UTC every Sunday (2:00 AM Singapore Time)
workflow_dispatch:
jobs:
update-rover-components:
runs-on: ubuntu-latest
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Install Dependencies
run: |
sudo apt-get update
sudo apt-get install -y jq
- name: Get Latest Docker Compose
id: get-latest-docker-compose-version
run: |
version=$(curl -s https://api.github.com/repos/docker/compose/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionDockerCompose=$version" >> $GITHUB_OUTPUT
- name: Get Latest Golang Version
id: get-latest-golang-version
run: |
version=$(curl -sSL https://golang.org/VERSION?m=text | grep go | cut -c 3-)
echo "versionGolang=$version" >> $GITHUB_OUTPUT
- name: Get Latest Kubectl Version
id: get-latest-versionKubectl-version
run: |
version=$(curl -s https://api.github.com/repos/kubernetes/kubernetes/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionKubectl=$version" >> $GITHUB_OUTPUT
- name: Get Latest Kubelogin Version
id: get-latest-kubelogin-version
run: |
version=$(curl -s https://api.github.com/repos/Azure/kubelogin/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionKubelogin=$version" >> $GITHUB_OUTPUT
- name: Get Latest Packer Version
id: get-latest-packer-version
run: |
version=$(curl -sL https://api.github.com/repos/hashicorp/packer/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionPacker=$version" >> $GITHUB_OUTPUT
- name: Get Latest PowerShell Version
id: get-latest-powershell-version
run: |
version=$(curl -sL https://api.github.com/repos/PowerShell/PowerShell/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionPowershell=$version" >> $GITHUB_OUTPUT
- name: Get Latest Ansible Version
id: get-latest-ansible-version
run: |
version=$(curl --silent "https://api.github.com/repos/ansible/ansible/releases/latest" | grep '"tag_name":' | sed -E 's/.*"([^"]+)".*/\1/' | cut -c 2-)
echo "versionAnsible=$version" >> $GITHUB_OUTPUT
- name: Get Latest Vault Version
id: get-latest-vault-version
run: |
version=$(curl -s https://api.github.com/repos/hashicorp/vault/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionVault=$version" >> $GITHUB_OUTPUT
- name: Get Latest Terrascan Version
id: get-latest-terrascan-version
run: |
version=$(curl -s https://api.github.com/repos/tenable/terrascan/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionTerrascan=$version" >> $GITHUB_OUTPUT
- name: Get Latest Azure DevOps Agent Version
id: get-latest-azdo-version
run: |
version=$(curl -s "https://api.github.com/repos/microsoft/azure-pipelines-agent/releases/latest" | jq -r '.tag_name' | sed 's/^v//')
echo "versionAzdo=$version" >> $GITHUB_OUTPUT
- name: Get Latest GitHub Runner Version
id: get-latest-github-runner-version
run: |
version=$(curl -sL https://api.github.com/repos/actions/runner/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionGithubRunner=$version" >> $GITHUB_OUTPUT
- name: Get Latest Gitlab Runner Version
id: get-latest-gitlab-runner-version
run: |
version=$(curl -s "https://gitlab.com/api/v4/projects/gitlab-org%2Fgitlab-runner/releases" | jq -r '.[].tag_name | select(test("^v[0-9]+\\.[0-9]+\\.[0-9]+$";""))' | sort -rV | head -n1 | sed 's/^v//')
echo "versionGitlab=$version" >> $GITHUB_OUTPUT
- name: Get Latest tfupdate Version
id: get-latest-tfupdate-version
run: |
version=$(curl -s https://api.github.com/repos/minamijoyo/tfupdate/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionTfupdate=$version" >> $GITHUB_OUTPUT
- name: Get Latest Terraform Cloud Agent Version
id: get-latest-tfc-agent-version
run: |
version=$(curl -s https://api.github.com/repos/hashicorp/terraform-docs-agents/releases/latest | jq -r '.tag_name' | cut -c 2-)
echo "versionTfc=$version" >> $GITHUB_OUTPUT
- name: Update latest Terraform Versions
id: get-latest-terraform-versions
run: |
versionsTerraform=$(curl -s https://api.github.com/repos/hashicorp/terraform/releases | jq -r '.[] | select(.draft == false) | .tag_name' | sort -rV | awk -F. '!a[$1"."$2]++{print substr($0,2)}' | head -n 5)
echo "${versionsTerraform}" > .env.terraform
sed -i '$a\' .env.terraform
- name: Update other components
run: |
versionDockerCompose=${{ steps.get-latest-docker-compose-version.outputs.versionDockerCompose }}
versionGolang=${{ steps.get-latest-golang-version.outputs.versionGolang }}
versionKubelogin=${{ steps.get-latest-kubelogin-version.outputs.versionKubelogin }}
versionKubectl=${{ steps.get-latest-versionKubectl-version.outputs.versionKubectl }}
versionPacker=${{ steps.get-latest-packer-version.outputs.versionPacker }}
versionPowershell=${{ steps.get-latest-powershell-version.outputs.versionPowershell }}
versionVault=${{ steps.get-latest-vault-version.outputs.versionVault }}
versionAnsible=${{ steps.get-latest-ansible-version.outputs.versionAnsible }}
versionTerrascan=${{ steps.get-latest-terrascan-version.outputs.versionTerrascan }}
versionTfupdate=${{ steps.get-latest-tfupdate-version.outputs.versionTfupdate }}
versionAzdo=${{ steps.get-latest-azdo-version.outputs.versionAzdo }}
versionGithubRunner=${{ steps.get-latest-github-runner-version.outputs.versionGithubRunner }}
versionTfc=${{ steps.get-latest-tfc-agent-version.outputs.versionTfc }}
versionGitlab=${{ steps.get-latest-gitlab-runner-version.outputs.versionGitlab }}
sed -i "s/versionDockerCompose=\"[^\"]*\"/versionDockerCompose=\"$versionDockerCompose\"/g" docker-bake.override.hcl
sed -i "s/versionGolang=\"[^\"]*\"/versionGolang=\"$versionGolang\"/g" docker-bake.override.hcl
sed -i "s/versionKubelogin=\"[^\"]*\"/versionKubelogin=\"$versionKubelogin\"/g" docker-bake.override.hcl
sed -i "s/versionKubectl=\"[^\"]*\"/versionKubectl=\"$versionKubectl\"/g" docker-bake.override.hcl
sed -i "s/versionPacker=\"[^\"]*\"/versionPacker=\"$versionPacker\"/g" docker-bake.override.hcl
sed -i "s/versionPowershell=\"[^\"]*\"/versionPowershell=\"$versionPowershell\"/g" docker-bake.override.hcl
sed -i "s/versionVault=\"[^\"]*\"/versionVault=\"$versionVault\"/g" docker-bake.override.hcl
sed -i "s/versionAnsible=\"[^\"]*\"/versionAnsible=\"$versionAnsible\"/g" docker-bake.override.hcl
sed -i "s/versionAzdo=\"[^\"]*\"/versionAzdo=\"$versionAzdo\"/g" docker-bake.override.hcl
sed -i "s/versionGithubRunner=\"[^\"]*\"/versionGithubRunner=\"$versionGithubRunner\"/g" docker-bake.override.hcl
sed -i "s/versionTfc=\"[^\"]*\"/versionTfc=\"$versionTfc\"/g" docker-bake.override.hcl
sed -i "s/versionGitlab=\"[^\"]*\"/versionGitlab=\"$versionGitlab\"/g" docker-bake.override.hcl
sed -i "s/versionTerrascan=\"[^\"]*\"/versionTerrascan=\"$versionTerrascan\"/g" docker-bake.override.hcl
sed -i "s/versionTfupdate=\"[^\"]*\"/versionTfupdate=\"$versionTfupdate\"/g" docker-bake.override.hcl
- name: Create Pull Request
uses: peter-evans/[email protected]
with:
token: ${{ secrets.GITHUB_TOKEN }}
commit-message: Update components versions
branch: components-update
title: Update rover components
body: This pull request updates the ```docker-bake.override.hcl``` and ```.env.terraform``` with latest available versions.